{"id":47309,"date":"2023-11-08T10:40:44","date_gmt":"2024-01-05T21:09:47","guid":{"rendered":"https:\/\/www.silicloud.com\/zh\/blog\/%e9%a6%96%e6%ac%a1%e4%bd%bf%e7%94%a8spark\/"},"modified":"2024-05-04T08:06:07","modified_gmt":"2024-05-04T00:06:07","slug":"%e9%a6%96%e6%ac%a1%e4%bd%bf%e7%94%a8spark","status":"publish","type":"post","link":"https:\/\/www.silicloud.com\/zh\/blog\/%e9%a6%96%e6%ac%a1%e4%bd%bf%e7%94%a8spark\/","title":{"rendered":"\u9996\u6b21\u4f7f\u7528Spark"},"content":{"rendered":"<p>\u4ece\u5f00\u59cb\u5230\u6267\u884c<\/p>\n<p>1. \u5b89\u88c5Scala<\/p>\n<pre class=\"post-pre\"><code>brew install scala\r\n<\/code><\/pre>\n<p>2. \u590d\u5236 Spark<\/p>\n<pre class=\"post-pre\"><code>git clone https:\/\/github.com\/apache\/spark.git\r\n<\/code><\/pre>\n<p>3. \u79fb\u81f3Spark\u7684\u6839\u76ee\u5f55<\/p>\n<pre class=\"post-pre\"><code>cd spark \r\n<\/code><\/pre>\n<p>\u5c06\u7248\u672c\u66f4\u6539\u4e3a1.3.1<\/p>\n<pre class=\"post-pre\"><code>git checkout -b version2 v1.3.1\r\n<\/code><\/pre>\n<p>\u4f7f\u7528mvn\u547d\u4ee4\u8fdb\u884c\u5b89\u88c5<\/p>\n<pre class=\"post-pre\"><code>mvn -DskipTests clean package\r\n<\/code><\/pre>\n<p>\u5728work\/logs\/test.txt\u4e2d\u521b\u5efa\u6d4b\u8bd5\u6570\u636e\u3002<\/p>\n<p>\u6267\u884cspark-shell<\/p>\n<pre class=\"post-pre\"><code>macbook:spark user$ .\/bin\/spark-shell \r\n\r\nWelcome to\r\n      ____              __\r\n     \/ __\/__  ___ _____\/ \/__\r\n    _\\ \\\/ _ \\\/ _ `\/ __\/  '_\/\r\n   \/___\/ .__\/\\_,_\/_\/ \/_\/\\_\\   version 1.3.1\r\n      \/_\/\r\n\r\n<\/code><\/pre>\n<p>\u4ece\u672c\u5730\u6587\u4ef6\u751f\u6210RDD\u3002<\/p>\n<pre class=\"post-pre\"><code>scala&gt; val file = sc.textFile(\"work\/logs\/test.txt\")\r\nfile: org.apache.spark.rdd.RDD[String] = MapPartitionsRDD[1] at textFile at &lt;console&gt;:21\r\n<\/code><\/pre>\n<p>\u4f7f\u7528\u7528\u62371\u7684\u5217\u8fdb\u884c\u6620\u5c04\u3002<\/p>\n<pre class=\"post-pre\"><code>scala&gt; val filter = file.filter(_.contains(\"user1\"))\r\nfilter: org.apache.spark.rdd.RDD[String] = MapPartitionsRDD[3] at filter at &lt;console&gt;:23\r\n<\/code><\/pre>\n<p>10. \u6253\u5370\u5904\u7406<\/p>\n<pre class=\"post-pre\"><code>scala&gt;  println(filter.count)\r\n2\r\n<\/code><\/pre>\n<h1>\u4f7f\u7528spark-submit\u547d\u4ee4\u521b\u5efa\u4e00\u4e2astandalone\u3002<\/h1>\n<p>\u5c06\u5df2\u5b89\u88c5\u7684 Spark \u6dfb\u52a0\u5230\u8def\u5f84\u4e2d<\/p>\n<pre class=\"post-pre\"><code>echo 'alias spark-shell=\"~\/work\/spark\/bin\/spark-shell\"' &gt;&gt;~\/.bash_aliases\r\necho 'alias spark-submit=\"~\/work\/spark\/bin\/spark-submit\"'&gt;&gt;~\/.bash_aliases\r\nsource ~\/.bash_alias\r\n<\/code><\/pre>\n<p>2. \u5b89\u88c5sbt\u3002<\/p>\n<pre class=\"post-pre\"><code>brew install sbt\r\n<\/code><\/pre>\n<p>3.\u6587\u4ef6\u7684\u67b6\u6784<\/p>\n<p>3.\u6587\u4ef6\u7684\u7ec4\u6210<\/p>\n<pre class=\"post-pre\"><code>$ mkdir ~\/work\r\n$ cd work\r\n$ mkdir spark\r\n$ mkdir spark\/src\r\n$ mkdir spark\/src\/main\r\n$ mkdir spark\/src\/main\/scala\r\n$ mkdir spark\/project\r\n$ mkdir spark\/log\r\n$ vi spark\/log\/access_log #access_log\u306f\u9069\u5b9c\u7528\u610f\r\n$ mkdir spark\/target\r\n<\/code><\/pre>\n<p>\u521b\u5efa\u4e00\u4e2abuild.sbt\u6587\u4ef6 \u203b1<\/p>\n<pre class=\"post-pre\"><code><span class=\"c1\">\/\/build-version<\/span>\r\n<span class=\"n\">version<\/span> <span class=\"o\">:=<\/span> <span class=\"s\">\"0.1\"<\/span> \r\n\r\n<span class=\"c1\">\/\/scalaVersion<\/span>\r\n<span class=\"n\">scalaVersion<\/span> <span class=\"o\">:=<\/span> <span class=\"s\">\"2.11.7\"<\/span> \r\n\r\n<span class=\"mf\">5.<\/span><span class=\"n\">\u4f9d\u5b58\u30e9\u30a4\u30d6\u30e9\u30ea\u306einstall<\/span>\r\n<span class=\"n\">libraryDependencies<\/span> <span class=\"o\">++=<\/span> <span class=\"nc\">Seq<\/span><span class=\"o\">(<\/span>\r\n   <span class=\"s\">\"org.xerial\"<\/span> <span class=\"o\">%<\/span> <span class=\"s\">\"sqlite-jdbc\"<\/span> <span class=\"o\">%<\/span> <span class=\"s\">\"3.7.2\"<\/span><span class=\"o\">,<\/span>\r\n   <span class=\"s\">\"org.apache.spark\"<\/span> <span class=\"o\">%%<\/span> <span class=\"s\">\"spark-core\"<\/span> <span class=\"o\">%<\/span> <span class=\"s\">\"1.3.1\"<\/span> <span class=\"o\">%<\/span> <span class=\"s\">\"provided\"<\/span><span class=\"o\">,<\/span>\r\n   <span class=\"c1\">\/\/\"org.apache.spark\" %% \"spark-streaming\" % \"1.3.1\"<\/span>\r\n   <span class=\"c1\">\/\/\"org.apache.spark\" %% \"spark-streaming-kafka\" % \"1.3.1\"<\/span>\r\n<span class=\"o\">)<\/span>\r\n\r\n<span class=\"c1\">\/\/\u203b3 \u91cd\u8907\u9632\u6b62<\/span>\r\n<span class=\"n\">assemblyMergeStrategy<\/span> <span class=\"n\">in<\/span> <span class=\"n\">assembly<\/span> <span class=\"o\">:=<\/span> <span class=\"o\">{<\/span>\r\n  <span class=\"k\">case<\/span> <span class=\"nc\">PathList<\/span><span class=\"o\">(<\/span><span class=\"s\">\"javax\"<\/span><span class=\"o\">,<\/span> <span class=\"s\">\"servlet\"<\/span><span class=\"o\">,<\/span> <span class=\"n\">xs<\/span> <span class=\"k\">@<\/span> <span class=\"k\">_<\/span><span class=\"o\">*)<\/span>         <span class=\"k\">=&gt;<\/span> <span class=\"nv\">MergeStrategy<\/span><span class=\"o\">.<\/span><span class=\"py\">first<\/span>\r\n  <span class=\"k\">case<\/span> <span class=\"nc\">PathList<\/span><span class=\"o\">(<\/span><span class=\"n\">ps<\/span> <span class=\"k\">@<\/span> <span class=\"k\">_<\/span><span class=\"o\">*)<\/span> <span class=\"k\">if<\/span> <span class=\"nv\">ps<\/span><span class=\"o\">.<\/span><span class=\"py\">last<\/span> <span class=\"n\">endsWith<\/span> <span class=\"s\">\".properties\"<\/span> <span class=\"k\">=&gt;<\/span> <span class=\"nv\">MergeStrategy<\/span><span class=\"o\">.<\/span><span class=\"py\">first<\/span>\r\n  <span class=\"k\">case<\/span> <span class=\"nc\">PathList<\/span><span class=\"o\">(<\/span><span class=\"n\">ps<\/span> <span class=\"k\">@<\/span> <span class=\"k\">_<\/span><span class=\"o\">*)<\/span> <span class=\"k\">if<\/span> <span class=\"nv\">ps<\/span><span class=\"o\">.<\/span><span class=\"py\">last<\/span> <span class=\"n\">endsWith<\/span> <span class=\"s\">\".xml\"<\/span> <span class=\"k\">=&gt;<\/span> <span class=\"nv\">MergeStrategy<\/span><span class=\"o\">.<\/span><span class=\"py\">first<\/span>\r\n  <span class=\"k\">case<\/span> <span class=\"nc\">PathList<\/span><span class=\"o\">(<\/span><span class=\"n\">ps<\/span> <span class=\"k\">@<\/span> <span class=\"k\">_<\/span><span class=\"o\">*)<\/span> <span class=\"k\">if<\/span> <span class=\"nv\">ps<\/span><span class=\"o\">.<\/span><span class=\"py\">last<\/span> <span class=\"n\">endsWith<\/span> <span class=\"s\">\".types\"<\/span> <span class=\"k\">=&gt;<\/span> <span class=\"nv\">MergeStrategy<\/span><span class=\"o\">.<\/span><span class=\"py\">first<\/span>\r\n  <span class=\"k\">case<\/span> <span class=\"nc\">PathList<\/span><span class=\"o\">(<\/span><span class=\"n\">ps<\/span> <span class=\"k\">@<\/span> <span class=\"k\">_<\/span><span class=\"o\">*)<\/span> <span class=\"k\">if<\/span> <span class=\"nv\">ps<\/span><span class=\"o\">.<\/span><span class=\"py\">last<\/span> <span class=\"n\">endsWith<\/span> <span class=\"s\">\".class\"<\/span> <span class=\"k\">=&gt;<\/span> <span class=\"nv\">MergeStrategy<\/span><span class=\"o\">.<\/span><span class=\"py\">first<\/span>\r\n  <span class=\"k\">case<\/span> <span class=\"s\">\"application.conf\"<\/span>                            <span class=\"k\">=&gt;<\/span> <span class=\"nv\">MergeStrategy<\/span><span class=\"o\">.<\/span><span class=\"py\">concat<\/span>\r\n  <span class=\"k\">case<\/span> <span class=\"s\">\"unwanted.txt\"<\/span>                                <span class=\"k\">=&gt;<\/span> <span class=\"nv\">MergeStrategy<\/span><span class=\"o\">.<\/span><span class=\"py\">discard<\/span>\r\n  <span class=\"k\">case<\/span> <span class=\"n\">x<\/span> <span class=\"k\">=&gt;<\/span>\r\n    <span class=\"k\">val<\/span> <span class=\"nv\">oldStrategy<\/span> <span class=\"k\">=<\/span> <span class=\"o\">(<\/span><span class=\"n\">assemblyMergeStrategy<\/span> <span class=\"n\">in<\/span> <span class=\"n\">assembly<\/span><span class=\"o\">).<\/span><span class=\"py\">value<\/span>\r\n    <span class=\"nf\">oldStrategy<\/span><span class=\"o\">(<\/span><span class=\"n\">x<\/span><span class=\"o\">)<\/span>\r\n<span class=\"o\">}<\/span>\r\n<\/code><\/pre>\n<p>\u521b\u5efa6.plugin.sbt\u6587\u4ef6<\/p>\n<pre class=\"post-pre\"><code><span class=\"n\">logLevel<\/span> <span class=\"o\">:=<\/span> <span class=\"nv\">Level<\/span><span class=\"o\">.<\/span><span class=\"py\">Warn<\/span>\r\n<span class=\"nf\">addSbtPlugin<\/span><span class=\"o\">(<\/span><span class=\"s\">\"com.eed3si9n\"<\/span> <span class=\"o\">%<\/span> <span class=\"s\">\"sbt-assembly\"<\/span> <span class=\"o\">%<\/span> <span class=\"s\">\"0.12.0\"<\/span><span class=\"o\">)<\/span>\r\n<\/code><\/pre>\n<p>\u89e3\u6790access_log\u6587\u4ef6\u5e76\u83b7\u53d6\u8bb0\u5f55\u6570\uff08\u793a\u4f8b.scala\uff09<\/p>\n<pre class=\"post-pre\"><code><span class=\"k\">import<\/span> <span class=\"nn\">org.apache.spark._<\/span>\r\n<span class=\"k\">import<\/span> <span class=\"nn\">org.apache.spark.SparkConf<\/span>\r\n<span class=\"k\">import<\/span> <span class=\"nn\">org.apache.spark.SparkContext<\/span>\r\n<span class=\"c1\">\/\/import org.apache.spark.streaming.{Time, Seconds, StreamingContext}<\/span>\r\n\r\n<span class=\"k\">object<\/span> <span class=\"nc\">ExampleApp<\/span> <span class=\"o\">{<\/span>\r\n  <span class=\"k\">def<\/span> <span class=\"nf\">main<\/span><span class=\"o\">(<\/span><span class=\"n\">args<\/span><span class=\"k\">:<\/span> <span class=\"kt\">Array<\/span><span class=\"o\">[<\/span><span class=\"kt\">String<\/span><span class=\"o\">])<\/span> <span class=\"o\">{<\/span>\r\n    <span class=\"c1\">\/\/\u7528\u610f\u3057\u305faccess_log<\/span>\r\n    <span class=\"k\">val<\/span> <span class=\"nv\">logFile<\/span> <span class=\"k\">=<\/span> <span class=\"s\">\"log\/access_log\"<\/span>\r\n    <span class=\"c1\">\/\/AppName\u306e\u8a2d\u5b9a\u30b3\u30e1\u30f3\u30c8\u3067\u66f8\u3044\u3066\u3044\u308b\u304csubmit\u30b3\u30de\u30f3\u30c9\u62bc\u4e0b\u6642\u306b\u8aad\u307f\u8fbc\u307e\u308c\u308bAppName\u306f\u30d5\u30a1\u30a4\u30eb\u540d<\/span>\r\n    <span class=\"k\">val<\/span> <span class=\"nv\">conf<\/span> <span class=\"k\">=<\/span> <span class=\"k\">new<\/span> <span class=\"nc\">SparkConf<\/span><span class=\"o\">().<\/span><span class=\"py\">setAppName<\/span><span class=\"o\">(<\/span><span class=\"s\">\"Example Application\"<\/span><span class=\"o\">)<\/span>\r\n    <span class=\"c1\">\/\/sparkcontext\u306e\u30a4\u30f3\u30b9\u30bf\u30f3\u30b9\u751f\u6210<\/span>\r\n    <span class=\"k\">val<\/span> <span class=\"nv\">sc<\/span> <span class=\"k\">=<\/span> <span class=\"k\">new<\/span> <span class=\"nc\">SparkContext<\/span><span class=\"o\">(<\/span><span class=\"n\">conf<\/span><span class=\"o\">)<\/span>\r\n    <span class=\"c1\">\/\/access_log\u30c7\u30fc\u30bf\u3092\u53d6\u5f97\u3068\u540c\u6642\u306b\u30ad\u30e3\u30c3\u30b7\u30e5\u306b\u8aad\u307f\u8fbc\u307f<\/span>\r\n    <span class=\"k\">val<\/span> <span class=\"nv\">logData<\/span> <span class=\"k\">=<\/span> <span class=\"nv\">sc<\/span><span class=\"o\">.<\/span><span class=\"py\">textFile<\/span><span class=\"o\">(<\/span><span class=\"n\">logFile<\/span><span class=\"o\">,<\/span> <span class=\"mi\">2<\/span><span class=\"o\">).<\/span><span class=\"py\">cache<\/span><span class=\"o\">()<\/span>\r\n    <span class=\"c1\">\/\/logData\u306e\u4e2d\u304b\u3089link\u3092\u53d6\u5f97+count<\/span>\r\n    <span class=\"k\">val<\/span> <span class=\"nv\">index<\/span> <span class=\"k\">=<\/span> <span class=\"nv\">logData<\/span><span class=\"o\">.<\/span><span class=\"py\">filter<\/span><span class=\"o\">(<\/span><span class=\"n\">line<\/span> <span class=\"k\">=&gt;<\/span> <span class=\"nv\">line<\/span><span class=\"o\">.<\/span><span class=\"py\">contains<\/span><span class=\"o\">(<\/span><span class=\"s\">\"index.html\"<\/span><span class=\"o\">)).<\/span><span class=\"py\">count<\/span><span class=\"o\">()<\/span>\r\n    <span class=\"k\">val<\/span> <span class=\"nv\">html1<\/span> <span class=\"k\">=<\/span> <span class=\"nv\">logData<\/span><span class=\"o\">.<\/span><span class=\"py\">filter<\/span><span class=\"o\">(<\/span><span class=\"n\">line<\/span> <span class=\"k\">=&gt;<\/span> <span class=\"nv\">line<\/span><span class=\"o\">.<\/span><span class=\"py\">contains<\/span><span class=\"o\">(<\/span><span class=\"s\">\"1.html\"<\/span><span class=\"o\">)).<\/span><span class=\"py\">count<\/span><span class=\"o\">()<\/span>\r\n    <span class=\"k\">val<\/span> <span class=\"nv\">html2<\/span> <span class=\"k\">=<\/span> <span class=\"nv\">logData<\/span><span class=\"o\">.<\/span><span class=\"py\">filter<\/span><span class=\"o\">(<\/span><span class=\"n\">line<\/span> <span class=\"k\">=&gt;<\/span> <span class=\"nv\">line<\/span><span class=\"o\">.<\/span><span class=\"py\">contains<\/span><span class=\"o\">(<\/span><span class=\"s\">\"2.html\"<\/span><span class=\"o\">)).<\/span><span class=\"py\">count<\/span><span class=\"o\">()<\/span>\r\n    <span class=\"k\">val<\/span> <span class=\"nv\">gif1<\/span>  <span class=\"k\">=<\/span> <span class=\"nv\">logData<\/span><span class=\"o\">.<\/span><span class=\"py\">filter<\/span><span class=\"o\">(<\/span><span class=\"n\">line<\/span> <span class=\"k\">=&gt;<\/span> <span class=\"nv\">line<\/span><span class=\"o\">.<\/span><span class=\"py\">contains<\/span><span class=\"o\">(<\/span><span class=\"s\">\"1.gif\"<\/span><span class=\"o\">)).<\/span><span class=\"py\">count<\/span><span class=\"o\">()<\/span>\r\n    <span class=\"k\">val<\/span> <span class=\"nv\">gif2<\/span>  <span class=\"k\">=<\/span> <span class=\"nv\">logData<\/span><span class=\"o\">.<\/span><span class=\"py\">filter<\/span><span class=\"o\">(<\/span><span class=\"n\">line<\/span> <span class=\"k\">=&gt;<\/span> <span class=\"nv\">line<\/span><span class=\"o\">.<\/span><span class=\"py\">contains<\/span><span class=\"o\">(<\/span><span class=\"s\">\"2.gif\"<\/span><span class=\"o\">)).<\/span><span class=\"py\">count<\/span><span class=\"o\">()<\/span>\r\n    <span class=\"c1\">\/\/\u8868\u793a<\/span>\r\n    <span class=\"nf\">println<\/span><span class=\"o\">(<\/span><span class=\"s\">\"Lines with index.html: %s\"<\/span><span class=\"o\">.<\/span><span class=\"py\">format<\/span><span class=\"o\">(<\/span><span class=\"n\">index<\/span><span class=\"o\">))<\/span>\r\n    <span class=\"nf\">println<\/span><span class=\"o\">(<\/span><span class=\"s\">\"Lines with 1.html: %s\"<\/span><span class=\"o\">.<\/span><span class=\"py\">format<\/span><span class=\"o\">(<\/span><span class=\"n\">html1<\/span><span class=\"o\">))<\/span>\r\n    <span class=\"nf\">println<\/span><span class=\"o\">(<\/span><span class=\"s\">\"Lines with 2.html: %s\"<\/span><span class=\"o\">.<\/span><span class=\"py\">format<\/span><span class=\"o\">(<\/span><span class=\"n\">html2<\/span><span class=\"o\">))<\/span>\r\n    <span class=\"nf\">println<\/span><span class=\"o\">(<\/span><span class=\"s\">\"Lines with 1.gif:  %s\"<\/span><span class=\"o\">.<\/span><span class=\"py\">format<\/span><span class=\"o\">(<\/span><span class=\"n\">gif1<\/span><span class=\"o\">))<\/span>\r\n    <span class=\"nf\">println<\/span><span class=\"o\">(<\/span><span class=\"s\">\"Lines with 2.gif:  %s\"<\/span><span class=\"o\">.<\/span><span class=\"py\">format<\/span><span class=\"o\">(<\/span><span class=\"n\">gif2<\/span><span class=\"o\">))<\/span>\r\n  <span class=\"o\">}<\/span>\r\n<span class=\"o\">}<\/span>\r\n<\/code><\/pre>\n<p>8. \u521b\u5efa.jar\u6587\u4ef6 \u203b1<\/p>\n<pre class=\"post-pre\"><code>sbt assembly\r\n<\/code><\/pre>\n<p>9. \u8fd0\u884cspark-submit<\/p>\n<pre class=\"post-pre\"><code>spark-submit --class ExampleApp target\/scala-2.11\/scala-assembly-0.1.jar\r\n<\/code><\/pre>\n<p>10. \u6267\u884c\u7ed3\u679c\uff08\u4ec5\u7ed3\u679c\uff09\u3002<\/p>\n<pre class=\"post-pre\"><code>Lines with index.html: 141882\r\nLines with 1.html: 19996\r\nLines with 2.html: 18567\r\nLines with 1.gif:  20996\r\nLines with 2.gif:  52393\r\n<\/code><\/pre>\n<p>11.\u7b49\u7b49\u3002<\/p>\n<p>\u8bf7\u7528\u7a7a\u884c\u5c06Name\u3001Version\u3001ScalaVersion\u3001LibraryDependencies\u7b49\u5185\u5bb9\u5206\u522b\u5199\u5728\u4e00\u8d77\u3002\u5728\u6700\u540e\u4e5f\u8981\u52a0\u4e0a\u4e00\u4e2a\u7a7a\u884c\u3002<\/p>\n<p>\u203b2<\/p>\n<p>\u6839\u636esbt\u7684\u7248\u672c\uff0c\u4f3c\u4e4e\u9700\u8981\u8fdb\u884c\u4e00\u4e9b\u63cf\u8ff0\u3002<br \/>\n\u5728\u5f53\u524d\u7684\u7248\u672c\u4e2d\uff0c\u4f1a\u51fa\u73b0\u9519\u8bef\u3002<\/p>\n<p>\u203b3\uff08\u53ea\u9700\u4e00\u79cd\u9009\u9879\uff09<\/p>\n<p>\u203b3<\/p>\n<p>\u5728\u521d\u59cb\u8bbe\u7f6e\u4e2d\uff0c\u6ca1\u6709\u8fd9\u4e2a\u63cf\u8ff0\uff0c\u5bfc\u81f4\u4f9d\u8d56\u5e93\u91cd\u590d\uff0c\u5bfc\u81f4\u5728\u521b\u5efajar\u6587\u4ef6\u65f6\u53d1\u751f\u9519\u8bef\u3002<\/p>\n","protected":false},"excerpt":{"rendered":"<p>\u4ece\u5f00\u59cb\u5230\u6267\u884c 1. \u5b89\u88c5Scala brew install scala 2. \u590d\u5236 Spark git cl [&hellip;]<\/p>\n","protected":false},"author":9,"featured_media":0,"comment_status":"closed","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[1],"tags":[],"class_list":["post-47309","post","type-post","status-publish","format-standard","hentry","category-uncategorized"],"yoast_head":"<!-- This site is optimized with the Yoast SEO Premium plugin v21.5 (Yoast SEO v21.5) - https:\/\/yoast.com\/wordpress\/plugins\/seo\/ -->\n<title>\u9996\u6b21\u4f7f\u7528Spark - Blog - Silicon Cloud<\/title>\n<meta name=\"robots\" content=\"index, follow, max-snippet:-1, max-image-preview:large, max-video-preview:-1\" \/>\n<link rel=\"canonical\" href=\"https:\/\/www.silicloud.com\/zh\/blog\/\u9996\u6b21\u4f7f\u7528spark\/\" \/>\n<meta property=\"og:locale\" content=\"zh_CN\" \/>\n<meta property=\"og:type\" content=\"article\" \/>\n<meta property=\"og:title\" content=\"\u9996\u6b21\u4f7f\u7528Spark\" \/>\n<meta property=\"og:description\" content=\"\u4ece\u5f00\u59cb\u5230\u6267\u884c 1. \u5b89\u88c5Scala brew install scala 2. \u590d\u5236 Spark git cl [&hellip;]\" \/>\n<meta property=\"og:url\" content=\"https:\/\/www.silicloud.com\/zh\/blog\/\u9996\u6b21\u4f7f\u7528spark\/\" \/>\n<meta property=\"og:site_name\" content=\"Blog - Silicon Cloud\" \/>\n<meta property=\"article:published_time\" content=\"2024-01-05T21:09:47+00:00\" \/>\n<meta property=\"article:modified_time\" content=\"2024-05-04T00:06:07+00:00\" \/>\n<meta name=\"author\" content=\"\u6e05, \u626c\" \/>\n<meta name=\"twitter:card\" content=\"summary_large_image\" \/>\n<meta name=\"twitter:label1\" content=\"\u4f5c\u8005\" \/>\n\t<meta name=\"twitter:data1\" content=\"\u6e05, \u626c\" \/>\n\t<meta name=\"twitter:label2\" content=\"\u9884\u8ba1\u9605\u8bfb\u65f6\u95f4\" \/>\n\t<meta name=\"twitter:data2\" content=\"2 \u5206\" \/>\n<script type=\"application\/ld+json\" class=\"yoast-schema-graph\">{\"@context\":\"https:\/\/schema.org\",\"@graph\":[{\"@type\":\"WebPage\",\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/%e9%a6%96%e6%ac%a1%e4%bd%bf%e7%94%a8spark\/\",\"url\":\"https:\/\/www.silicloud.com\/zh\/blog\/%e9%a6%96%e6%ac%a1%e4%bd%bf%e7%94%a8spark\/\",\"name\":\"\u9996\u6b21\u4f7f\u7528Spark - Blog - Silicon Cloud\",\"isPartOf\":{\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/#website\"},\"datePublished\":\"2024-01-05T21:09:47+00:00\",\"dateModified\":\"2024-05-04T00:06:07+00:00\",\"author\":{\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/#\/schema\/person\/cb5556d2501da73d864cac945e8d9461\"},\"breadcrumb\":{\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/%e9%a6%96%e6%ac%a1%e4%bd%bf%e7%94%a8spark\/#breadcrumb\"},\"inLanguage\":\"zh-Hans\",\"potentialAction\":[{\"@type\":\"ReadAction\",\"target\":[\"https:\/\/www.silicloud.com\/zh\/blog\/%e9%a6%96%e6%ac%a1%e4%bd%bf%e7%94%a8spark\/\"]}]},{\"@type\":\"BreadcrumbList\",\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/%e9%a6%96%e6%ac%a1%e4%bd%bf%e7%94%a8spark\/#breadcrumb\",\"itemListElement\":[{\"@type\":\"ListItem\",\"position\":1,\"name\":\"\u9996\u9875\",\"item\":\"https:\/\/www.silicloud.com\/zh\/blog\/\"},{\"@type\":\"ListItem\",\"position\":2,\"name\":\"\u9996\u6b21\u4f7f\u7528Spark\"}]},{\"@type\":\"WebSite\",\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/#website\",\"url\":\"https:\/\/www.silicloud.com\/zh\/blog\/\",\"name\":\"Blog - Silicon Cloud\",\"description\":\"\",\"inLanguage\":\"zh-Hans\"},{\"@type\":\"Person\",\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/#\/schema\/person\/cb5556d2501da73d864cac945e8d9461\",\"name\":\"\u6e05, \u626c\",\"image\":{\"@type\":\"ImageObject\",\"inLanguage\":\"zh-Hans\",\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/#\/schema\/person\/image\/\",\"url\":\"https:\/\/secure.gravatar.com\/avatar\/32a4239de8ff29adace466261d309424a1e5fe9f7e3036bf89fe03f2e3dbe717?s=96&d=mm&r=g\",\"contentUrl\":\"https:\/\/secure.gravatar.com\/avatar\/32a4239de8ff29adace466261d309424a1e5fe9f7e3036bf89fe03f2e3dbe717?s=96&d=mm&r=g\",\"caption\":\"\u6e05, \u626c\"},\"url\":\"https:\/\/www.silicloud.com\/zh\/blog\/author\/qingyang\/\"},{\"@type\":\"ImageObject\",\"inLanguage\":\"zh-Hans\",\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/%e9%a6%96%e6%ac%a1%e4%bd%bf%e7%94%a8spark\/#local-main-organization-logo\",\"url\":\"\",\"contentUrl\":\"\",\"caption\":\"Blog - Silicon Cloud\"}]}<\/script>\n<!-- \/ Yoast SEO Premium plugin. -->","yoast_head_json":{"title":"\u9996\u6b21\u4f7f\u7528Spark - Blog - Silicon Cloud","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:\/\/www.silicloud.com\/zh\/blog\/\u9996\u6b21\u4f7f\u7528spark\/","og_locale":"zh_CN","og_type":"article","og_title":"\u9996\u6b21\u4f7f\u7528Spark","og_description":"\u4ece\u5f00\u59cb\u5230\u6267\u884c 1. \u5b89\u88c5Scala brew install scala 2. \u590d\u5236 Spark git cl [&hellip;]","og_url":"https:\/\/www.silicloud.com\/zh\/blog\/\u9996\u6b21\u4f7f\u7528spark\/","og_site_name":"Blog - Silicon Cloud","article_published_time":"2024-01-05T21:09:47+00:00","article_modified_time":"2024-05-04T00:06:07+00:00","author":"\u6e05, \u626c","twitter_card":"summary_large_image","twitter_misc":{"\u4f5c\u8005":"\u6e05, \u626c","\u9884\u8ba1\u9605\u8bfb\u65f6\u95f4":"2 \u5206"},"schema":{"@context":"https:\/\/schema.org","@graph":[{"@type":"WebPage","@id":"https:\/\/www.silicloud.com\/zh\/blog\/%e9%a6%96%e6%ac%a1%e4%bd%bf%e7%94%a8spark\/","url":"https:\/\/www.silicloud.com\/zh\/blog\/%e9%a6%96%e6%ac%a1%e4%bd%bf%e7%94%a8spark\/","name":"\u9996\u6b21\u4f7f\u7528Spark - Blog - Silicon Cloud","isPartOf":{"@id":"https:\/\/www.silicloud.com\/zh\/blog\/#website"},"datePublished":"2024-01-05T21:09:47+00:00","dateModified":"2024-05-04T00:06:07+00:00","author":{"@id":"https:\/\/www.silicloud.com\/zh\/blog\/#\/schema\/person\/cb5556d2501da73d864cac945e8d9461"},"breadcrumb":{"@id":"https:\/\/www.silicloud.com\/zh\/blog\/%e9%a6%96%e6%ac%a1%e4%bd%bf%e7%94%a8spark\/#breadcrumb"},"inLanguage":"zh-Hans","potentialAction":[{"@type":"ReadAction","target":["https:\/\/www.silicloud.com\/zh\/blog\/%e9%a6%96%e6%ac%a1%e4%bd%bf%e7%94%a8spark\/"]}]},{"@type":"BreadcrumbList","@id":"https:\/\/www.silicloud.com\/zh\/blog\/%e9%a6%96%e6%ac%a1%e4%bd%bf%e7%94%a8spark\/#breadcrumb","itemListElement":[{"@type":"ListItem","position":1,"name":"\u9996\u9875","item":"https:\/\/www.silicloud.com\/zh\/blog\/"},{"@type":"ListItem","position":2,"name":"\u9996\u6b21\u4f7f\u7528Spark"}]},{"@type":"WebSite","@id":"https:\/\/www.silicloud.com\/zh\/blog\/#website","url":"https:\/\/www.silicloud.com\/zh\/blog\/","name":"Blog - Silicon Cloud","description":"","inLanguage":"zh-Hans"},{"@type":"Person","@id":"https:\/\/www.silicloud.com\/zh\/blog\/#\/schema\/person\/cb5556d2501da73d864cac945e8d9461","name":"\u6e05, \u626c","image":{"@type":"ImageObject","inLanguage":"zh-Hans","@id":"https:\/\/www.silicloud.com\/zh\/blog\/#\/schema\/person\/image\/","url":"https:\/\/secure.gravatar.com\/avatar\/32a4239de8ff29adace466261d309424a1e5fe9f7e3036bf89fe03f2e3dbe717?s=96&d=mm&r=g","contentUrl":"https:\/\/secure.gravatar.com\/avatar\/32a4239de8ff29adace466261d309424a1e5fe9f7e3036bf89fe03f2e3dbe717?s=96&d=mm&r=g","caption":"\u6e05, \u626c"},"url":"https:\/\/www.silicloud.com\/zh\/blog\/author\/qingyang\/"},{"@type":"ImageObject","inLanguage":"zh-Hans","@id":"https:\/\/www.silicloud.com\/zh\/blog\/%e9%a6%96%e6%ac%a1%e4%bd%bf%e7%94%a8spark\/#local-main-organization-logo","url":"","contentUrl":"","caption":"Blog - Silicon Cloud"}]}},"_links":{"self":[{"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/posts\/47309","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/users\/9"}],"replies":[{"embeddable":true,"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/comments?post=47309"}],"version-history":[{"count":2,"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/posts\/47309\/revisions"}],"predecessor-version":[{"id":97132,"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/posts\/47309\/revisions\/97132"}],"wp:attachment":[{"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/media?parent=47309"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/categories?post=47309"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/tags?post=47309"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}