{"id":8480,"date":"2022-04-14T18:09:05","date_gmt":"2022-04-14T16:09:05","guid":{"rendered":"https:\/\/myoceane.fr\/?p=8480"},"modified":"2022-04-15T02:53:00","modified_gmt":"2022-04-15T00:53:00","slug":"spark-%e5%b8%b8%e8%a6%8b%e9%8c%af%e8%aa%a4-nosuchmethoderror-classnotfound","status":"publish","type":"post","link":"https:\/\/myoceane.fr\/index.php\/spark-%e5%b8%b8%e8%a6%8b%e9%8c%af%e8%aa%a4-nosuchmethoderror-classnotfound\/","title":{"rendered":"[Spark] \u5e38\u898b\u932f\u8aa4 NoSuchMethodError\/ClassNotFound"},"content":{"rendered":"<div id=\"fb-root\"><\/div>\n<p style=\"text-align: justify;\">\u6ab8\u6aac\u7238\u5728\u958b\u767c Spark, Java, Scala \u7a0b\u5f0f\u7684\u6642\u5019\u5f88\u5e38\u9047\u5230 NoSuchMethodError\/ClassNotFound \u9019\u5169\u500b\u932f\u8aa4\uff0c\u901a\u5e38\u51fa\u73fe\u9019\u5169\u500b\u932f\u8aa4\u8a0a\u606f\u7684\u6642\u5019\uff0c\u4e3b\u8981\u539f\u56e0\u662f\u56e0\u70ba Java Package \u7684 Dependency Conflict\uff0c\u5728\u958b\u767c Spark \u7684\u61c9\u7528\u7684\u6642\u5019\u7a76\u7adf\u8981\u600e\u9ebd\u53bb\u8655\u7406\u6703\u6bd4\u8f03\u597d\uff1f\u672c\u7bc7\u60f3\u8981\u7d00\u9304\u5e7e\u500b\u5e38\u7528\u7684\u89e3\u6cd5\uff0c\u5305\u542bJava \u6307\u4ee4, JD-GUI \u8207 Maven Dependency:Tree \u7684\u4ecb\u7d39\u3002<\/p>\n<p style=\"text-align: justify;\">\u4e00\u822c\u4f86\u8aaa\u5e38\u898b\u7684 NoSuchMethodError \u6216\u662f ClassNotFound Error \u6703\u5982\u4e0b\u5716\u6240\u793a\uff0c\u5982\u679c\u662f ClassNotFoundError \u53ef\u80fd\u76f8\u5c0d\u6bd4\u8f03\u597d\u8655\u7406\uff0c\u53ea\u8981\u52a0\u4e0a\u76f8\u5c0d\u61c9\u7684 jar \u5c31\u53ef\u4ee5\u89e3\u6c7a\uff0c\u4ee5\u4e0b\u6211\u5011\u900f\u904e\u9019\u7684\u7bc4\u4f8b\u4ecb\u7d39\u61c9\u8a72\u8981\u600e\u9ebc Debug \u9019\u5169\u500b\u5e38\u898b\u932f\u8aa4\u3002&nbsp;<\/p>\n<pre class=\"lang:bash\">22\/04\/14 01:35:36.894 [task-result-getter-1] WARN  o.a.spark.scheduler.TaskSetManager - Lost task 0.0 in stage 11.0 (TID 156) (10.0.0.4 executor 0): java.lang.NoSuchMethodError: org.apache.parquet.hadoop.util.HadoopInputFile.getPath()Lorg\/apache\/hadoop\/fs\/Path;\n\tat org.apache.spark.sql.execution.datasources.parquet.ParquetFooterReader.readFooter(ParquetFooterReader.java:50)\n\tat org.apache.spark.sql.execution.datasources.parquet.ParquetFooterReader.readFooter(ParquetFooterReader.java:39)\n\tat org.apache.spark.sql.execution.datasources.parquet.ParquetFileFormat.footerFileMetaData$lzycompute$1(ParquetFileFormat.scala:268)\n\tat org.apache.spark.sql.execution.datasources.parquet.ParquetFileFormat.footerFileMetaData$1(ParquetFileFormat.scala:267)\n\tat org.apache.spark.sql.execution.datasources.parquet.ParquetFileFormat.$anonfun$buildReaderWithPartitionValues$2(ParquetFileFormat.scala:270)\n\tat org.apache.spark.sql.execution.datasources.FileScanRDD$anon$1.org$apache$spark$sql$execution$datasources$FileScanRDD$anon$readCurrentFile(FileScanRDD.scala:127)\n\tat org.apache.spark.sql.execution.datasources.FileScanRDD$anon$1.nextIterator(FileScanRDD.scala:187)\n\tat org.apache.spark.sql.execution.datasources.FileScanRDD$anon$1.hasNext(FileScanRDD.scala:104)\n\tat org.apache.spark.sql.execution.FileSourceScanExec$anon$1.hasNext(DataSourceScanExec.scala:522)\n\tat org.apache.spark.sql.catalyst.expressions.GeneratedClass$GeneratedIteratorForCodegenStage1.columnartorow_nextBatch_0$(Unknown Source)\n\tat org.apache.spark.sql.catalyst.expressions.GeneratedClass$GeneratedIteratorForCodegenStage1.processNext(Unknown Source)\n\tat org.apache.spark.sql.execution.BufferedRowIterator.hasNext(BufferedRowIterator.java:43)\n\tat org.apache.spark.sql.execution.WholeStageCodegenExec$anon$1.hasNext(WholeStageCodegenExec.scala:759)\n\tat org.apache.spark.sql.execution.SparkPlan.$anonfun$getByteArrayRdd$1(SparkPlan.scala:349)\n\tat org.apache.spark.rdd.RDD.$anonfun$mapPartitionsInternal$2(RDD.scala:898)\n\tat org.apache.spark.rdd.RDD.$anonfun$mapPartitionsInternal$2$adapted(RDD.scala:898)\n\tat org.apache.spark.rdd.MapPartitionsRDD.compute(MapPartitionsRDD.scala:52)\n\tat org.apache.spark.rdd.RDD.computeOrReadCheckpoint(RDD.scala:373)\n\tat org.apache.spark.rdd.RDD.iterator(RDD.scala:337)\n\tat org.apache.spark.scheduler.ResultTask.runTask(ResultTask.scala:90)\n\tat org.apache.spark.scheduler.Task.run(Task.scala:131)\n\tat org.apache.spark.executor.Executor$TaskRunner.$anonfun$run$3(Executor.scala:506)\n\tat org.apache.spark.util.Utils$.tryWithSafeFinally(Utils.scala:1462)\n\tat org.apache.spark.executor.Executor$TaskRunner.run(Executor.scala:509)\n\tat java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1149)\n\tat java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:624)\n\tat java.lang.Thread.run(Thread.java:748)<\/pre>\n<h4>\u9996\u5148\u5229\u7528 Java -tvf \u6307\u4ee4\u67e5\u51fa\u95dc\u9375\u7684 Jar \u6a94<\/h4>\n<p>\u901a\u5e38\u51fa\u73fe NoSuchMethodError \u4e3b\u8981\u662f\u56e0\u70ba\u4f7f\u7528\u5230\u7684 jar \u6709\u4f9d\u8cf4\u7684\u885d\u7a81 (Dependency Conflict) \u9019\u6642\u5019\u8981\u9664\u932f\u7684\u96e3\u5ea6\u5c31\u6703\u5f88\u9ad8\uff0c<a href=\"https:\/\/www.ibm.com\/support\/pages\/how-do-i-find-which-jar-file-contains-given-class-%C2%A0what-do-i-do-if-i-get-classnotfound-exception-or-similar-not-found-exception#:~:text=To%20find%20the%20.,your%20%24YFS_HOME%2Flib%20directory.\">IBM \u7684\u7db2\u7ad9<\/a>\u6709\u63d0\u4f9b\u4e00\u500b shell script \u7684\u7a0b\u5f0f\u78bc\u5e6b\u52a9\u6211\u5011\u5728\u5f88\u591a jar \u88e1\u9762\u627e\u5230\u7a76\u7adf\u662f\u54ea\u4e00\u500b jar \u6709\u7528\u5230\u67d0\u500b Class \u4e3b\u8981\u5c31\u662f\u5229\u7528 java -tvf \u6307\u4ee4\uff0c\u4ee5\u4e0b\u662f shell script \u7a0b\u5f0f\uff1a<\/p>\n<pre class=\"lang:bash\">if [ $# -ne 1 ]\nthen\n    echo \" \"\n    echo \" \"\n    echo \"Usage : FindClass.sh &lt;Class Name\/Part of ClassName &gt;\"\n    echo \" \"\n    exit -1\nfi\nfor i in `find . -name \"*.jar\"`\ndo\n    jar -tvf $i | grep -i $1 &amp;&amp; echo $i\ndone<\/pre>\n<p>\u9996\u5148\u5148 cd \u5230 spark \u5b58\u653e jars \u7684\u4f4d\u7f6e\uff0c\u901a\u5e38\u662f \/home\/spark-current\/jars \u63a5\u8457\u57f7\u884c\u4ee5\u4e0b\u6307\u4ee4\uff1a<\/p>\n<pre class=\"lang:bash\">root@5ba55ea3962d46d799fa96666151f347000000:\/$ cd \/home\/spark-current\/jars\nroot@5ba55ea3962d46d799fa96666151f347000000:\/home\/spark-current\/jars$ sh FindClass.sh HadoopInputFile\n  2437 Thu Sep 30 14:16:04 UTC 2021 org\/apache\/parquet\/hadoop\/util\/HadoopInputFile.class\n.\/parquet-hadoop-1.12.2.jar\n  2373 Wed Mar 02 11:36:40 UTC 2022 org\/apache\/parquet\/hadoop\/util\/HadoopInputFile.class\n.\/adam.jar<\/pre>\n<h4>\u63a5\u8457\u5229\u7528 JD-GUI \u6aa2\u67e5\u771f\u6b63\u9700\u8981\u7684 Jar \u6a94<\/h4>\n<p style=\"text-align: justify;\">\u900f\u904e\u7b2c\u4e00\u6b65\u7684 Java Command \u6211\u5011\u77e5\u9053\u4e86 parquet-hadoop-1.12.2.jar \u88e1\u9762\u6709 HadoopInputFile \u9019\u500b\u985e\u5225\uff0c\u65bc\u662f\u6211\u5011\u5229\u7528 JD-GUI \u53bb\u6aa2\u67e5\u5728 parquet-hadoop-1.12.2.jar \u88e1\u9762\u7684 HadoopInputFile \u662f\u5426\u6709 getPath() \u9019\u500b\u65b9\u6cd5\uff0c\u65bc\u4e0b\u9762\u622a\u5716\u6211\u5011\u767c\u73fe HadoopInputFile \u662f\u6709 getPath()\uff0c\u56e0\u6b64\u6211\u5011\u53ef\u4ee5\u63a8\u6e2c pyspark \u61c9\u8a72\u662f\u932f\u8aa4\u62c9\u5230\u4e86 adam.jar \u88e1\u9762\u7684 HadoopInputFile \u4e86\u3002<\/p>\n\n\n<figure class=\"wp-block-image size-large\"><img loading=\"lazy\" decoding=\"async\" width=\"1024\" height=\"593\" src=\"https:\/\/myoceane.fr\/wp-content\/uploads\/2022\/04\/jd_gui-1024x593.png\" alt=\"\" class=\"wp-image-8488\" srcset=\"https:\/\/myoceane.fr\/wp-content\/uploads\/2022\/04\/jd_gui-1024x593.png 1024w, https:\/\/myoceane.fr\/wp-content\/uploads\/2022\/04\/jd_gui-300x174.png 300w, https:\/\/myoceane.fr\/wp-content\/uploads\/2022\/04\/jd_gui-768x445.png 768w, https:\/\/myoceane.fr\/wp-content\/uploads\/2022\/04\/jd_gui-1536x889.png 1536w, https:\/\/myoceane.fr\/wp-content\/uploads\/2022\/04\/jd_gui-2048x1185.png 2048w\" sizes=\"auto, (max-width: 1024px) 100vw, 1024px\" \/><figcaption>\u5229\u7528 JD-GUI \u67e5\u770b HadoopInputFile \u7684 Methods<\/figcaption><\/figure>\n\n\n<h5>\u5229\u7528 Mvn Dependency:tree \u6aa2\u67e5\u5c08\u6848\u4e2d package \u7684\u4f9d\u8cf4\u95dc\u4fc2<\/h5>\n<p style=\"text-align: justify;\">\u9019\u908a\u7684 adam.jar \u662f\u4e00\u500b<a href=\"https:\/\/github.com\/bigdatagenomics\/adam\">\u7b2c\u4e09\u65b9\u958b\u6e90\u7684\u5c08\u6848<\/a>\uff0c\u6211\u5011\u5229\u7528 Maven Build \u4e4b\u5f8c\u7522\u751f\u51fa jar \u6a94\u653e\u5728 \/home\/spark-current\/jars \u88e1\u9762\u5c31\u53ef\u4ee5\u5728\u958b\u767c Spark \u7a0b\u5f0f\u7684\u6642\u5019\u4f7f\u7528\u5230 Adam \u7684\u51fd\u5f0f\u5eab\u3002<\/p>\n<p style=\"text-align: justify;\">\u7531\u65bc Adam \u662f\u4f7f\u7528 Maven \u7de8\u8b6f\u7684\uff0c\u6240\u4ee5\u6211\u5011\u53ef\u4ee5\u5229\u7528 mvn dependency:tree \u6307\u4ee4\u5728 pom.xml \u5f97\u5230\u4ee5\u4e0b\u7684\u7d50\u679c\uff0c\u767c\u73fe\u4ed6\u6709\u4f7f\u7528\u5230 org.apache.parquet:parquet-hadoop:jar:1.10.1:compile\uff0c\u56e0\u6b64\u7814\u5224\u662f parquet-hadoop.jar 1.10.1 \u8207 1.12.2 \u767c\u751f\u885d\u7a81\u3002<\/p>\n<pre class=\"lang:bash\">[INFO] org.bdgenomics.adam:adam-assembly-spark3_2.12:jar:LATEST\n[INFO] \\- org.bdgenomics.adam:adam-cli-spark3_2.12:jar:0.37.0-SNAPSHOT:compile\n[INFO]    +- org.bdgenomics.utils:utils-misc-spark3_2.12:jar:0.3.0:compile\n[INFO]    |  \\- org.scala-lang:scala-library:jar:2.12.10:compile\n[INFO]    +- org.bdgenomics.utils:utils-io-spark3_2.12:jar:0.3.0:compile\n[INFO]    |  \\- org.apache.httpcomponents:httpclient:jar:4.5.7:compile\n[INFO]    |     +- org.apache.httpcomponents:httpcore:jar:4.4.11:compile\n[INFO]    |     +- commons-logging:commons-logging:jar:1.2:compile\n[INFO]    |     \\- commons-codec:commons-codec:jar:1.11:compile\n[INFO]    +- org.bdgenomics.utils:utils-cli-spark3_2.12:jar:0.3.0:compile\n[INFO]    |  +- org.clapper:grizzled-slf4j_2.12:jar:1.3.4:compile\n[INFO]    |  |  \\- org.slf4j:slf4j-api:jar:1.7.30:compile\n[INFO]    |  \\- org.apache.parquet:parquet-avro:jar:1.10.1:compile\n[INFO]    |     +- org.apache.parquet:parquet-column:jar:1.10.1:compile\n[INFO]    |     |  +- org.apache.parquet:parquet-common:jar:1.10.1:compile\n[INFO]    |     |  \\- org.apache.parquet:parquet-encoding:jar:1.10.1:compile\n[INFO]    |     +- org.apache.parquet:parquet-hadoop:jar:1.10.1:compile\n[INFO]    |     |  +- org.apache.parquet:parquet-jackson:jar:1.10.1:compile\n[INFO]    |     |  \\- commons-pool:commons-pool:jar:1.6:compile\n[INFO]    |     \\- org.apache.parquet:parquet-format:jar:2.4.0:compile\n[INFO]    +- org.bdgenomics.bdg-formats:bdg-formats:jar:0.15.0:compile\n[INFO]    |  \\- org.apache.avro:avro:jar:1.8.2:compile\n[INFO]    |     +- org.codehaus.jackson:jackson-core-asl:jar:1.9.13:compile\n[INFO]    |     +- org.codehaus.jackson:jackson-mapper-asl:jar:1.9.13:compile\n[INFO]    |     +- com.thoughtworks.paranamer:paranamer:jar:2.8:compile\n[INFO]    |     +- org.xerial.snappy:snappy-java:jar:1.1.1.3:compile\n[INFO]    |     +- org.apache.commons:commons-compress:jar:1.8.1:compile\n[INFO]    |     \\- org.tukaani:xz:jar:1.5:compile\n[INFO]    +- org.bdgenomics.adam:adam-core-spark3_2.12:jar:0.37.0-SNAPSHOT:compile\n[INFO]    |  +- org.bdgenomics.utils:utils-intervalrdd-spark3_2.12:jar:0.3.0:compile\n[INFO]    |  +- com.esotericsoftware.kryo:kryo:jar:2.24.0:compile\n[INFO]    |  |  +- com.esotericsoftware.minlog:minlog:jar:1.2:compile\n[INFO]    |  |  \\- org.objenesis:objenesis:jar:2.1:compile\n[INFO]    |  +- commons-io:commons-io:jar:2.6:compile\n[INFO]    |  +- it.unimi.dsi:fastutil:jar:6.6.5:compile\n[INFO]    |  +- org.seqdoop:hadoop-bam:jar:7.10.0-atgx:compile\n[INFO]    |  |  \\- com.github.jsr203hadoop:jsr203hadoop:jar:1.0.3:compile\n[INFO]    |  +- com.github.samtools:htsjdk:jar:2.19.0:compile\n[INFO]    |  |  +- org.apache.commons:commons-jexl:jar:2.1.1:compile\n[INFO]    |  |  \\- gov.nih.nlm.ncbi:ngs-java:jar:2.9.0:compile\n[INFO]    |  +- com.google.guava:guava:jar:27.0-jre:compile\n[INFO]    |  |  +- com.google.guava:failureaccess:jar:1.0:compile\n[INFO]    |  |  +- com.google.guava:listenablefuture:jar:9999.0-empty-to-avoid-conflict-with-guava:compile\n[INFO]    |  |  +- org.checkerframework:checker-qual:jar:2.5.2:compile\n[INFO]    |  |  +- com.google.errorprone:error_prone_annotations:jar:2.2.0:compile\n[INFO]    |  |  +- com.google.j2objc:j2objc-annotations:jar:1.1:compile\n[INFO]    |  |  \\- org.codehaus.mojo:animal-sniffer-annotations:jar:1.17:compile\n[INFO]    |  \\- org.bdgenomics.adam:adam-codegen-spark3_2.12:jar:0.37.0-SNAPSHOT:compile\n[INFO]    +- org.bdgenomics.adam:adam-apis-spark3_2.12:jar:0.37.0-SNAPSHOT:compile\n[INFO]    +- args4j:args4j:jar:2.33:compile\n[INFO]    \\- net.codingwell:scala-guice_2.12:jar:4.2.1:compile\n[INFO]       +- com.google.inject:guice:jar:4.2.0:compile\n[INFO]       |  +- javax.inject:javax.inject:jar:1:compile\n[INFO]       |  \\- aopalliance:aopalliance:jar:1.0:compile\n[INFO]       +- org.scala-lang:scala-reflect:jar:2.12.6:compile\n[INFO]       \\- com.google.code.findbugs:jsr305:jar:1.3.9:compile\n[INFO] ------------------------------------------------------------------------<\/pre>\n<p>\u6b64\u6642\u9032\u4e00\u6b65\u7528 JD-GUI \u78ba\u8a8d\u767c\u73fe\u7684\u78ba\u662f\u56e0\u70ba parquet-hadoop-1.10.1.jar \u88e1\u9762\u7684 HadoopInputFile \u6c92\u6709 getPath() \u7684 Method\uff0c\u6b64\u6642\u6709\u5169\u500b\u9078\u64c7\uff0c\u5347\u7d1a adam \u652f\u63f4 1.12.1 \u6216\u662f\u5c07 parquet-hadoop-1.12.2 \u964d\u56de\u5230 1.10.1 \u9019\u5169\u500b\u65b9\u6cd5\u90fd\u53ef\u4ee5\u3002<\/p>\n\n\n<figure class=\"wp-block-image size-large\"><img loading=\"lazy\" decoding=\"async\" width=\"1024\" height=\"593\" src=\"https:\/\/myoceane.fr\/wp-content\/uploads\/2022\/04\/jd_gui1-1024x593.png\" alt=\"\" class=\"wp-image-8490\" srcset=\"https:\/\/myoceane.fr\/wp-content\/uploads\/2022\/04\/jd_gui1-1024x593.png 1024w, https:\/\/myoceane.fr\/wp-content\/uploads\/2022\/04\/jd_gui1-300x174.png 300w, https:\/\/myoceane.fr\/wp-content\/uploads\/2022\/04\/jd_gui1-768x445.png 768w, https:\/\/myoceane.fr\/wp-content\/uploads\/2022\/04\/jd_gui1-1536x890.png 1536w, https:\/\/myoceane.fr\/wp-content\/uploads\/2022\/04\/jd_gui1-2048x1187.png 2048w\" sizes=\"auto, (max-width: 1024px) 100vw, 1024px\" \/><\/figure>\n\n\n<p>\u6700\u5f8c\u5e0c\u671b\u4ee5\u4e0a\u7684\u7d93\u9a57\u5206\u4eab\u6709\u5e6b\u52a9\u88ab\u9019\u500b\u554f\u984c\u56f0\u4f4f\u7684\u7db2\u53cb\u3002<\/p>\n<p><a href=\"https:\/\/myoceane.fr\/?s=Spark\">\u53c3\u8003\u66f4\u591a\u6ab8\u6aac\u7238\u6709\u95dcSpark\u7684\u6587\u7ae0\uff1a<\/a><\/p>\n<p>1. <a href=\"https:\/\/myoceane.fr\/index.php\/spark-%E5%BB%BA%E7%BD%AE%E8%87%AA%E5%B7%B1%E7%9A%84-spark-history-server\/\">[Spark] \u5efa\u7f6e\u81ea\u5df1\u7684 Spark History Server<\/a><br \/>2. <a href=\"https:\/\/myoceane.fr\/index.php\/%e5%ae%89%e8%a3%9d-spark-%e5%88%b0%e9%81%a0%e7%ab%af%e4%bc%ba%e6%9c%8d%e5%99%a8\/\">\u5b89\u88dd Spark \u5230\u9060\u7aef\u4f3a\u670d\u5668<\/a><br \/>3. <a href=\"https:\/\/myoceane.fr\/index.php\/hadoop-hdfs-data-integrity-with-checksum\/\">[Hadoop] Hdfs Data Integrity with Checksum<\/a><\/p>","protected":false},"excerpt":{"rendered":"<p>\u6ab8\u6aac\u7238\u5728\u958b\u767c Spark, Java, Scala \u7a0b\u5f0f\u7684\u6642\u5019\u5f88\u5e38\u9047\u5230 NoSuchMethodError\/ClassNotFound \u9019\u5169\u500b\u932f\u8aa4\uff0c\u901a\u5e38\u51fa\u73fe\u9019\u5169\u500b\u932f\u8aa4\u8a0a\u606f\u7684\u6642\u5019\uff0c\u4e3b\u8981\u539f\u56e0\u662f\u56e0\u70ba Java Package \u7684 Dependency Conflict\uff0c\u5728\u958b\u767c Spark \u7684\u61c9\u7528\u7684\u6642\u5019\u7a76\u7adf\u8981\u600e\u9ebd\u53bb\u8655\u7406\u6703\u6bd4\u8f03\u597d\uff1f\u672c\u7bc7\u60f3\u8981\u7d00\u9304\u5e7e\u500b\u5e38\u7528\u7684\u89e3\u6cd5\uff0c\u5305\u542bJava \u6307\u4ee4, JD-GUI \u8207 Maven Dependency:Tree \u7684\u4ecb\u7d39\u3002<\/p>\n","protected":false},"author":1,"featured_media":5486,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[9,14],"tags":[1526,1525,152],"class_list":["post-8480","post","type-post","status-publish","format-standard","has-post-thumbnail","hentry","category-bigdata-ml","category-it-technology","tag-classnotfound","tag-nosuchmethoderror","tag-spark"],"yoast_head":"<!-- This site is optimized with the Yoast SEO plugin v24.6 - https:\/\/yoast.com\/wordpress\/plugins\/seo\/ -->\n<title>[Spark] \u5e38\u898b\u932f\u8aa4 NoSuchMethodError\/ClassNotFound<\/title>\n<meta name=\"description\" content=\"\u6ab8\u6aac\u7238\u5728\u958b\u767c Spark, Java, Scala \u7a0b\u5f0f\u7684\u6642\u5019\u5f88\u5e38\u9047\u5230 NoSuchMethodError\/ClassNotFound \u9019\u5169\u500b\u932f\u8aa4\uff0c\u901a\u5e38\u51fa\u73fe\u9019\u5169\u500b\u932f\u8aa4\u8a0a\u606f\u7684\u6642\u5019\uff0c\u4e3b\u8981\u539f\u56e0\u662f\u56e0\u70ba Java Package \u7684 Dependency Conflict\uff0c\u5728\u958b\u767c Spark \u7684\u61c9\u7528\u7684\u6642\u5019\u7a76\u7adf\u8981\u600e\u9ebd\u53bb\u8655\u7406\u6703\u6bd4\u8f03\u597d\uff1f\u672c\u7bc7\u60f3\u8981\u7d00\u9304\u5e7e\u500b\u5e38\u7528\u7684\u89e3\u6cd5\uff0c\u5305\u542bJava \u6307\u4ee4, JD-GUI \u8207 Maven Dependency:Tree \u7684\u4ecb\u7d39\u3002\" \/>\n<meta name=\"robots\" content=\"index, follow, max-snippet:-1, max-image-preview:large, max-video-preview:-1\" \/>\n<link rel=\"canonical\" href=\"https:\/\/myoceane.fr\/index.php\/spark-\u5e38\u898b\u932f\u8aa4-nosuchmethoderror-classnotfound\/\" \/>\n<meta property=\"og:locale\" content=\"en_US\" \/>\n<meta property=\"og:type\" content=\"article\" \/>\n<meta property=\"og:title\" content=\"[Spark] \u5e38\u898b\u932f\u8aa4 NoSuchMethodError\/ClassNotFound\" \/>\n<meta property=\"og:description\" content=\"\u6ab8\u6aac\u7238\u5728\u958b\u767c Spark, Java, Scala \u7a0b\u5f0f\u7684\u6642\u5019\u5f88\u5e38\u9047\u5230 NoSuchMethodError\/ClassNotFound \u9019\u5169\u500b\u932f\u8aa4\uff0c\u901a\u5e38\u51fa\u73fe\u9019\u5169\u500b\u932f\u8aa4\u8a0a\u606f\u7684\u6642\u5019\uff0c\u4e3b\u8981\u539f\u56e0\u662f\u56e0\u70ba Java Package \u7684 Dependency Conflict\uff0c\u5728\u958b\u767c Spark \u7684\u61c9\u7528\u7684\u6642\u5019\u7a76\u7adf\u8981\u600e\u9ebd\u53bb\u8655\u7406\u6703\u6bd4\u8f03\u597d\uff1f\u672c\u7bc7\u60f3\u8981\u7d00\u9304\u5e7e\u500b\u5e38\u7528\u7684\u89e3\u6cd5\uff0c\u5305\u542bJava \u6307\u4ee4, JD-GUI \u8207 Maven Dependency:Tree \u7684\u4ecb\u7d39\u3002\" \/>\n<meta property=\"og:url\" content=\"https:\/\/myoceane.fr\/index.php\/spark-\u5e38\u898b\u932f\u8aa4-nosuchmethoderror-classnotfound\/\" \/>\n<meta property=\"og:site_name\" content=\"\u60f3\u65b9\u6d89\u6cd5 - \u91cf\u74f6\u5916\u7684\u5929\u7a7a M-Y-Oceane\" \/>\n<meta property=\"article:published_time\" content=\"2022-04-14T16:09:05+00:00\" \/>\n<meta property=\"article:modified_time\" content=\"2022-04-15T00:53:00+00:00\" \/>\n<meta property=\"og:image\" content=\"https:\/\/myoceane.fr\/wp-content\/uploads\/2020\/06\/Apache_Spark_logo.svg_.png\" \/>\n\t<meta property=\"og:image:width\" content=\"1200\" \/>\n\t<meta property=\"og:image:height\" content=\"625\" \/>\n\t<meta property=\"og:image:type\" content=\"image\/png\" \/>\n<meta name=\"author\" content=\"\u6ab8\u6aac\u7238\" \/>\n<meta name=\"twitter:card\" content=\"summary_large_image\" \/>\n<meta name=\"twitter:label1\" content=\"Written by\" \/>\n\t<meta name=\"twitter:data1\" content=\"\u6ab8\u6aac\u7238\" \/>\n\t<meta name=\"twitter:label2\" content=\"Est. reading time\" \/>\n\t<meta name=\"twitter:data2\" content=\"5 minutes\" \/>\n<script type=\"application\/ld+json\" class=\"yoast-schema-graph\">{\"@context\":\"https:\/\/schema.org\",\"@graph\":[{\"@type\":\"Article\",\"@id\":\"https:\/\/myoceane.fr\/index.php\/spark-%e5%b8%b8%e8%a6%8b%e9%8c%af%e8%aa%a4-nosuchmethoderror-classnotfound\/#article\",\"isPartOf\":{\"@id\":\"https:\/\/myoceane.fr\/index.php\/spark-%e5%b8%b8%e8%a6%8b%e9%8c%af%e8%aa%a4-nosuchmethoderror-classnotfound\/\"},\"author\":{\"name\":\"\u6ab8\u6aac\u7238\",\"@id\":\"https:\/\/myoceane.fr\/#\/schema\/person\/4a4552fb8c27693083d465e12db7658b\"},\"headline\":\"[Spark] \u5e38\u898b\u932f\u8aa4 NoSuchMethodError\/ClassNotFound\",\"datePublished\":\"2022-04-14T16:09:05+00:00\",\"dateModified\":\"2022-04-15T00:53:00+00:00\",\"mainEntityOfPage\":{\"@id\":\"https:\/\/myoceane.fr\/index.php\/spark-%e5%b8%b8%e8%a6%8b%e9%8c%af%e8%aa%a4-nosuchmethoderror-classnotfound\/\"},\"wordCount\":118,\"commentCount\":0,\"publisher\":{\"@id\":\"https:\/\/myoceane.fr\/#\/schema\/person\/4a4552fb8c27693083d465e12db7658b\"},\"image\":{\"@id\":\"https:\/\/myoceane.fr\/index.php\/spark-%e5%b8%b8%e8%a6%8b%e9%8c%af%e8%aa%a4-nosuchmethoderror-classnotfound\/#primaryimage\"},\"thumbnailUrl\":\"https:\/\/myoceane.fr\/wp-content\/uploads\/2020\/06\/Apache_Spark_logo.svg_.png\",\"keywords\":[\"ClassNotFound\",\"NoSuchMethodError\",\"Spark\"],\"articleSection\":[\"Big Data &amp; Machine Learning\",\"IT Technology\"],\"inLanguage\":\"en-US\",\"potentialAction\":[{\"@type\":\"CommentAction\",\"name\":\"Comment\",\"target\":[\"https:\/\/myoceane.fr\/index.php\/spark-%e5%b8%b8%e8%a6%8b%e9%8c%af%e8%aa%a4-nosuchmethoderror-classnotfound\/#respond\"]}]},{\"@type\":\"WebPage\",\"@id\":\"https:\/\/myoceane.fr\/index.php\/spark-%e5%b8%b8%e8%a6%8b%e9%8c%af%e8%aa%a4-nosuchmethoderror-classnotfound\/\",\"url\":\"https:\/\/myoceane.fr\/index.php\/spark-%e5%b8%b8%e8%a6%8b%e9%8c%af%e8%aa%a4-nosuchmethoderror-classnotfound\/\",\"name\":\"[Spark] \u5e38\u898b\u932f\u8aa4 NoSuchMethodError\/ClassNotFound\",\"isPartOf\":{\"@id\":\"https:\/\/myoceane.fr\/#website\"},\"primaryImageOfPage\":{\"@id\":\"https:\/\/myoceane.fr\/index.php\/spark-%e5%b8%b8%e8%a6%8b%e9%8c%af%e8%aa%a4-nosuchmethoderror-classnotfound\/#primaryimage\"},\"image\":{\"@id\":\"https:\/\/myoceane.fr\/index.php\/spark-%e5%b8%b8%e8%a6%8b%e9%8c%af%e8%aa%a4-nosuchmethoderror-classnotfound\/#primaryimage\"},\"thumbnailUrl\":\"https:\/\/myoceane.fr\/wp-content\/uploads\/2020\/06\/Apache_Spark_logo.svg_.png\",\"datePublished\":\"2022-04-14T16:09:05+00:00\",\"dateModified\":\"2022-04-15T00:53:00+00:00\",\"description\":\"\u6ab8\u6aac\u7238\u5728\u958b\u767c Spark, Java, Scala \u7a0b\u5f0f\u7684\u6642\u5019\u5f88\u5e38\u9047\u5230 NoSuchMethodError\/ClassNotFound \u9019\u5169\u500b\u932f\u8aa4\uff0c\u901a\u5e38\u51fa\u73fe\u9019\u5169\u500b\u932f\u8aa4\u8a0a\u606f\u7684\u6642\u5019\uff0c\u4e3b\u8981\u539f\u56e0\u662f\u56e0\u70ba Java Package \u7684 Dependency Conflict\uff0c\u5728\u958b\u767c Spark \u7684\u61c9\u7528\u7684\u6642\u5019\u7a76\u7adf\u8981\u600e\u9ebd\u53bb\u8655\u7406\u6703\u6bd4\u8f03\u597d\uff1f\u672c\u7bc7\u60f3\u8981\u7d00\u9304\u5e7e\u500b\u5e38\u7528\u7684\u89e3\u6cd5\uff0c\u5305\u542bJava \u6307\u4ee4, JD-GUI \u8207 Maven Dependency:Tree \u7684\u4ecb\u7d39\u3002\",\"breadcrumb\":{\"@id\":\"https:\/\/myoceane.fr\/index.php\/spark-%e5%b8%b8%e8%a6%8b%e9%8c%af%e8%aa%a4-nosuchmethoderror-classnotfound\/#breadcrumb\"},\"inLanguage\":\"en-US\",\"potentialAction\":[{\"@type\":\"ReadAction\",\"target\":[\"https:\/\/myoceane.fr\/index.php\/spark-%e5%b8%b8%e8%a6%8b%e9%8c%af%e8%aa%a4-nosuchmethoderror-classnotfound\/\"]}]},{\"@type\":\"ImageObject\",\"inLanguage\":\"en-US\",\"@id\":\"https:\/\/myoceane.fr\/index.php\/spark-%e5%b8%b8%e8%a6%8b%e9%8c%af%e8%aa%a4-nosuchmethoderror-classnotfound\/#primaryimage\",\"url\":\"https:\/\/myoceane.fr\/wp-content\/uploads\/2020\/06\/Apache_Spark_logo.svg_.png\",\"contentUrl\":\"https:\/\/myoceane.fr\/wp-content\/uploads\/2020\/06\/Apache_Spark_logo.svg_.png\",\"width\":1200,\"height\":625,\"caption\":\"apache-spark\"},{\"@type\":\"BreadcrumbList\",\"@id\":\"https:\/\/myoceane.fr\/index.php\/spark-%e5%b8%b8%e8%a6%8b%e9%8c%af%e8%aa%a4-nosuchmethoderror-classnotfound\/#breadcrumb\",\"itemListElement\":[{\"@type\":\"ListItem\",\"position\":1,\"name\":\"Home\",\"item\":\"https:\/\/myoceane.fr\/\"},{\"@type\":\"ListItem\",\"position\":2,\"name\":\"[Spark] \u5e38\u898b\u932f\u8aa4 NoSuchMethodError\/ClassNotFound\"}]},{\"@type\":\"WebSite\",\"@id\":\"https:\/\/myoceane.fr\/#website\",\"url\":\"https:\/\/myoceane.fr\/\",\"name\":\"M-Y-Oceane \u60f3\u65b9\u6d89\u6cd5\u3002\u91cf\u74f6\u5916\u7684\u5929\u7a7a\",\"description\":\"\u60f3\u65b9\u6d89\u6cd5, France, Taiwan, Health, Information Technology\",\"publisher\":{\"@id\":\"https:\/\/myoceane.fr\/#\/schema\/person\/4a4552fb8c27693083d465e12db7658b\"},\"potentialAction\":[{\"@type\":\"SearchAction\",\"target\":{\"@type\":\"EntryPoint\",\"urlTemplate\":\"https:\/\/myoceane.fr\/?s={search_term_string}\"},\"query-input\":{\"@type\":\"PropertyValueSpecification\",\"valueRequired\":true,\"valueName\":\"search_term_string\"}}],\"inLanguage\":\"en-US\"},{\"@type\":[\"Person\",\"Organization\"],\"@id\":\"https:\/\/myoceane.fr\/#\/schema\/person\/4a4552fb8c27693083d465e12db7658b\",\"name\":\"\u6ab8\u6aac\u7238\",\"image\":{\"@type\":\"ImageObject\",\"inLanguage\":\"en-US\",\"@id\":\"https:\/\/myoceane.fr\/#\/schema\/person\/image\/\",\"url\":\"https:\/\/secure.gravatar.com\/avatar\/6cc678684664f8ad45a8d56a6630b183?s=96&d=mm&r=g\",\"contentUrl\":\"https:\/\/secure.gravatar.com\/avatar\/6cc678684664f8ad45a8d56a6630b183?s=96&d=mm&r=g\",\"caption\":\"\u6ab8\u6aac\u7238\"},\"logo\":{\"@id\":\"https:\/\/myoceane.fr\/#\/schema\/person\/image\/\"},\"url\":\"https:\/\/myoceane.fr\/index.php\/author\/johnny5584767gmail-com\/\"}]}<\/script>\n<!-- \/ Yoast SEO plugin. -->","yoast_head_json":{"title":"[Spark] \u5e38\u898b\u932f\u8aa4 NoSuchMethodError\/ClassNotFound","description":"\u6ab8\u6aac\u7238\u5728\u958b\u767c Spark, Java, Scala \u7a0b\u5f0f\u7684\u6642\u5019\u5f88\u5e38\u9047\u5230 NoSuchMethodError\/ClassNotFound \u9019\u5169\u500b\u932f\u8aa4\uff0c\u901a\u5e38\u51fa\u73fe\u9019\u5169\u500b\u932f\u8aa4\u8a0a\u606f\u7684\u6642\u5019\uff0c\u4e3b\u8981\u539f\u56e0\u662f\u56e0\u70ba Java Package \u7684 Dependency Conflict\uff0c\u5728\u958b\u767c Spark \u7684\u61c9\u7528\u7684\u6642\u5019\u7a76\u7adf\u8981\u600e\u9ebd\u53bb\u8655\u7406\u6703\u6bd4\u8f03\u597d\uff1f\u672c\u7bc7\u60f3\u8981\u7d00\u9304\u5e7e\u500b\u5e38\u7528\u7684\u89e3\u6cd5\uff0c\u5305\u542bJava \u6307\u4ee4, JD-GUI \u8207 Maven Dependency:Tree \u7684\u4ecb\u7d39\u3002","robots":{"index":"index","follow":"follow","max-snippet":"max-snippet:-1","max-image-preview":"max-image-preview:large","max-video-preview":"max-video-preview:-1"},"canonical":"https:\/\/myoceane.fr\/index.php\/spark-\u5e38\u898b\u932f\u8aa4-nosuchmethoderror-classnotfound\/","og_locale":"en_US","og_type":"article","og_title":"[Spark] \u5e38\u898b\u932f\u8aa4 NoSuchMethodError\/ClassNotFound","og_description":"\u6ab8\u6aac\u7238\u5728\u958b\u767c Spark, Java, Scala \u7a0b\u5f0f\u7684\u6642\u5019\u5f88\u5e38\u9047\u5230 NoSuchMethodError\/ClassNotFound \u9019\u5169\u500b\u932f\u8aa4\uff0c\u901a\u5e38\u51fa\u73fe\u9019\u5169\u500b\u932f\u8aa4\u8a0a\u606f\u7684\u6642\u5019\uff0c\u4e3b\u8981\u539f\u56e0\u662f\u56e0\u70ba Java Package \u7684 Dependency Conflict\uff0c\u5728\u958b\u767c Spark \u7684\u61c9\u7528\u7684\u6642\u5019\u7a76\u7adf\u8981\u600e\u9ebd\u53bb\u8655\u7406\u6703\u6bd4\u8f03\u597d\uff1f\u672c\u7bc7\u60f3\u8981\u7d00\u9304\u5e7e\u500b\u5e38\u7528\u7684\u89e3\u6cd5\uff0c\u5305\u542bJava \u6307\u4ee4, JD-GUI \u8207 Maven Dependency:Tree \u7684\u4ecb\u7d39\u3002","og_url":"https:\/\/myoceane.fr\/index.php\/spark-\u5e38\u898b\u932f\u8aa4-nosuchmethoderror-classnotfound\/","og_site_name":"\u60f3\u65b9\u6d89\u6cd5 - \u91cf\u74f6\u5916\u7684\u5929\u7a7a M-Y-Oceane","article_published_time":"2022-04-14T16:09:05+00:00","article_modified_time":"2022-04-15T00:53:00+00:00","og_image":[{"width":1200,"height":625,"url":"https:\/\/myoceane.fr\/wp-content\/uploads\/2020\/06\/Apache_Spark_logo.svg_.png","type":"image\/png"}],"author":"\u6ab8\u6aac\u7238","twitter_card":"summary_large_image","twitter_misc":{"Written by":"\u6ab8\u6aac\u7238","Est. reading time":"5 minutes"},"schema":{"@context":"https:\/\/schema.org","@graph":[{"@type":"Article","@id":"https:\/\/myoceane.fr\/index.php\/spark-%e5%b8%b8%e8%a6%8b%e9%8c%af%e8%aa%a4-nosuchmethoderror-classnotfound\/#article","isPartOf":{"@id":"https:\/\/myoceane.fr\/index.php\/spark-%e5%b8%b8%e8%a6%8b%e9%8c%af%e8%aa%a4-nosuchmethoderror-classnotfound\/"},"author":{"name":"\u6ab8\u6aac\u7238","@id":"https:\/\/myoceane.fr\/#\/schema\/person\/4a4552fb8c27693083d465e12db7658b"},"headline":"[Spark] \u5e38\u898b\u932f\u8aa4 NoSuchMethodError\/ClassNotFound","datePublished":"2022-04-14T16:09:05+00:00","dateModified":"2022-04-15T00:53:00+00:00","mainEntityOfPage":{"@id":"https:\/\/myoceane.fr\/index.php\/spark-%e5%b8%b8%e8%a6%8b%e9%8c%af%e8%aa%a4-nosuchmethoderror-classnotfound\/"},"wordCount":118,"commentCount":0,"publisher":{"@id":"https:\/\/myoceane.fr\/#\/schema\/person\/4a4552fb8c27693083d465e12db7658b"},"image":{"@id":"https:\/\/myoceane.fr\/index.php\/spark-%e5%b8%b8%e8%a6%8b%e9%8c%af%e8%aa%a4-nosuchmethoderror-classnotfound\/#primaryimage"},"thumbnailUrl":"https:\/\/myoceane.fr\/wp-content\/uploads\/2020\/06\/Apache_Spark_logo.svg_.png","keywords":["ClassNotFound","NoSuchMethodError","Spark"],"articleSection":["Big Data &amp; Machine Learning","IT Technology"],"inLanguage":"en-US","potentialAction":[{"@type":"CommentAction","name":"Comment","target":["https:\/\/myoceane.fr\/index.php\/spark-%e5%b8%b8%e8%a6%8b%e9%8c%af%e8%aa%a4-nosuchmethoderror-classnotfound\/#respond"]}]},{"@type":"WebPage","@id":"https:\/\/myoceane.fr\/index.php\/spark-%e5%b8%b8%e8%a6%8b%e9%8c%af%e8%aa%a4-nosuchmethoderror-classnotfound\/","url":"https:\/\/myoceane.fr\/index.php\/spark-%e5%b8%b8%e8%a6%8b%e9%8c%af%e8%aa%a4-nosuchmethoderror-classnotfound\/","name":"[Spark] \u5e38\u898b\u932f\u8aa4 NoSuchMethodError\/ClassNotFound","isPartOf":{"@id":"https:\/\/myoceane.fr\/#website"},"primaryImageOfPage":{"@id":"https:\/\/myoceane.fr\/index.php\/spark-%e5%b8%b8%e8%a6%8b%e9%8c%af%e8%aa%a4-nosuchmethoderror-classnotfound\/#primaryimage"},"image":{"@id":"https:\/\/myoceane.fr\/index.php\/spark-%e5%b8%b8%e8%a6%8b%e9%8c%af%e8%aa%a4-nosuchmethoderror-classnotfound\/#primaryimage"},"thumbnailUrl":"https:\/\/myoceane.fr\/wp-content\/uploads\/2020\/06\/Apache_Spark_logo.svg_.png","datePublished":"2022-04-14T16:09:05+00:00","dateModified":"2022-04-15T00:53:00+00:00","description":"\u6ab8\u6aac\u7238\u5728\u958b\u767c Spark, Java, Scala \u7a0b\u5f0f\u7684\u6642\u5019\u5f88\u5e38\u9047\u5230 NoSuchMethodError\/ClassNotFound \u9019\u5169\u500b\u932f\u8aa4\uff0c\u901a\u5e38\u51fa\u73fe\u9019\u5169\u500b\u932f\u8aa4\u8a0a\u606f\u7684\u6642\u5019\uff0c\u4e3b\u8981\u539f\u56e0\u662f\u56e0\u70ba Java Package \u7684 Dependency Conflict\uff0c\u5728\u958b\u767c Spark \u7684\u61c9\u7528\u7684\u6642\u5019\u7a76\u7adf\u8981\u600e\u9ebd\u53bb\u8655\u7406\u6703\u6bd4\u8f03\u597d\uff1f\u672c\u7bc7\u60f3\u8981\u7d00\u9304\u5e7e\u500b\u5e38\u7528\u7684\u89e3\u6cd5\uff0c\u5305\u542bJava \u6307\u4ee4, JD-GUI \u8207 Maven Dependency:Tree \u7684\u4ecb\u7d39\u3002","breadcrumb":{"@id":"https:\/\/myoceane.fr\/index.php\/spark-%e5%b8%b8%e8%a6%8b%e9%8c%af%e8%aa%a4-nosuchmethoderror-classnotfound\/#breadcrumb"},"inLanguage":"en-US","potentialAction":[{"@type":"ReadAction","target":["https:\/\/myoceane.fr\/index.php\/spark-%e5%b8%b8%e8%a6%8b%e9%8c%af%e8%aa%a4-nosuchmethoderror-classnotfound\/"]}]},{"@type":"ImageObject","inLanguage":"en-US","@id":"https:\/\/myoceane.fr\/index.php\/spark-%e5%b8%b8%e8%a6%8b%e9%8c%af%e8%aa%a4-nosuchmethoderror-classnotfound\/#primaryimage","url":"https:\/\/myoceane.fr\/wp-content\/uploads\/2020\/06\/Apache_Spark_logo.svg_.png","contentUrl":"https:\/\/myoceane.fr\/wp-content\/uploads\/2020\/06\/Apache_Spark_logo.svg_.png","width":1200,"height":625,"caption":"apache-spark"},{"@type":"BreadcrumbList","@id":"https:\/\/myoceane.fr\/index.php\/spark-%e5%b8%b8%e8%a6%8b%e9%8c%af%e8%aa%a4-nosuchmethoderror-classnotfound\/#breadcrumb","itemListElement":[{"@type":"ListItem","position":1,"name":"Home","item":"https:\/\/myoceane.fr\/"},{"@type":"ListItem","position":2,"name":"[Spark] \u5e38\u898b\u932f\u8aa4 NoSuchMethodError\/ClassNotFound"}]},{"@type":"WebSite","@id":"https:\/\/myoceane.fr\/#website","url":"https:\/\/myoceane.fr\/","name":"M-Y-Oceane \u60f3\u65b9\u6d89\u6cd5\u3002\u91cf\u74f6\u5916\u7684\u5929\u7a7a","description":"\u60f3\u65b9\u6d89\u6cd5, France, Taiwan, Health, Information Technology","publisher":{"@id":"https:\/\/myoceane.fr\/#\/schema\/person\/4a4552fb8c27693083d465e12db7658b"},"potentialAction":[{"@type":"SearchAction","target":{"@type":"EntryPoint","urlTemplate":"https:\/\/myoceane.fr\/?s={search_term_string}"},"query-input":{"@type":"PropertyValueSpecification","valueRequired":true,"valueName":"search_term_string"}}],"inLanguage":"en-US"},{"@type":["Person","Organization"],"@id":"https:\/\/myoceane.fr\/#\/schema\/person\/4a4552fb8c27693083d465e12db7658b","name":"\u6ab8\u6aac\u7238","image":{"@type":"ImageObject","inLanguage":"en-US","@id":"https:\/\/myoceane.fr\/#\/schema\/person\/image\/","url":"https:\/\/secure.gravatar.com\/avatar\/6cc678684664f8ad45a8d56a6630b183?s=96&d=mm&r=g","contentUrl":"https:\/\/secure.gravatar.com\/avatar\/6cc678684664f8ad45a8d56a6630b183?s=96&d=mm&r=g","caption":"\u6ab8\u6aac\u7238"},"logo":{"@id":"https:\/\/myoceane.fr\/#\/schema\/person\/image\/"},"url":"https:\/\/myoceane.fr\/index.php\/author\/johnny5584767gmail-com\/"}]}},"amp_enabled":false,"_links":{"self":[{"href":"https:\/\/myoceane.fr\/index.php\/wp-json\/wp\/v2\/posts\/8480","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/myoceane.fr\/index.php\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/myoceane.fr\/index.php\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/myoceane.fr\/index.php\/wp-json\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/myoceane.fr\/index.php\/wp-json\/wp\/v2\/comments?post=8480"}],"version-history":[{"count":20,"href":"https:\/\/myoceane.fr\/index.php\/wp-json\/wp\/v2\/posts\/8480\/revisions"}],"predecessor-version":[{"id":8510,"href":"https:\/\/myoceane.fr\/index.php\/wp-json\/wp\/v2\/posts\/8480\/revisions\/8510"}],"wp:featuredmedia":[{"embeddable":true,"href":"https:\/\/myoceane.fr\/index.php\/wp-json\/wp\/v2\/media\/5486"}],"wp:attachment":[{"href":"https:\/\/myoceane.fr\/index.php\/wp-json\/wp\/v2\/media?parent=8480"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/myoceane.fr\/index.php\/wp-json\/wp\/v2\/categories?post=8480"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/myoceane.fr\/index.php\/wp-json\/wp\/v2\/tags?post=8480"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}