Spark & Alluxio

概述

Alluxio(在1.0版本之前名为Tachyon)是一个以内存分布式存储系统。它统一了数据访问的方式,为上层计算框架和底层存储系统构建了桥梁。 应用只需要连接Alluxio即可访问存储在底层任意存储系统中的数据。此外,Alluxio的以内存为中心的架构使得数据的访问速度能比现有常规方案快几个数量级。

Spark使用Alluxio的好处有如下几点:

  • 数据可以长期存储在内存中,多个应用可以共享缓存数据
  • 数据缓存在JVM外部可以减少程序的GC时间
  • 缓存的数据不会因为程序的意外崩溃而消失
  • Alluxiou与Hadoop兼容,无需修改spark代码,可直接运行

配置

Alluxio的编译部署

从源码主分支编译支持Spark,Hadoop2.4的Alluxio

git clone git://github.com/alluxio/alluxio.git
cd alluxio
mvn install -Pspark -Dhadoop.version=2.4.1 -DskipTests

如果需要编译一个指定的版本,使用gitcheckout命令即可,例如编译1.2版本

cd alluxio
git checkout v1.2.0

在HDFS上配置Alluxio

编译完成后,修改配置文件

cd alluxio/conf
cp alluxio-env.sh.template alluxio-env.sh
ALLUXIO_UNDERFS_ADDRESS=hdfs://localhost:9000/alluxio
ALLUXIO_MASTER_HOSTNAME=xxx
ALLUXIO_RAM_FOLDER=/home/admin/alluxio/ramdisk

在Spark上配置Alluxio

可以在spark-env.sh中配置SPARK_CLASSPATH

export SPARK_CLASSPATH=/usr/install/alluxio/core/client/target/alluxio-core-client-1.3.0-SNAPSHOT-jar-with-dependencies.jar

在spark1.6以上,可以配置在spark-defaults.conf

spark.executor.extraClassPath /usr/install/alluxio/core/client/target/alluxio-core-client-1.3.0-SNAPSHOT-jar-with-dependencies.jar
spark.driver.extraClassPath /usr/install/alluxio/core/client/target/alluxio-core-client-1.3.0-SNAPSHOT-jar-with-dependencies.jar

修改spark/conf下的core-site.xml

<property>
  <name>fs.alluxio.implname>
  <value>alluxio.hadoop.FileSystemvalue>
  <description>The Alluxio FileSystem (Hadoop 1.x and 2.x)description>
property>
<property>
  <name>fs.alluxio-ft.implname>
  <value>alluxio.hadoop.FaultTolerantFileSystemvalue>
  <description>The Alluxio FileSystem (Hadoop 1.x and 2.x) with fault tolerant supportdescription>
property>
<property>
  <name>fs.AbstractFileSystem.alluxio.implname>
  <value>alluxio.hadoop.AlluxioFileSystemvalue>
  <description>The Alluxio AbstractFileSystem (Hadoop 2.x)description>
property>

启动Alluxio

./bin/alluxio format
./bin/alluxio-start.sh local

此时可以通过http://localhost:19999访问Alluxio web ui,运行一个test

./bin/alluxio runTests

如果运行成功可以在Browse中看到生成的default_tests_files文件

在Alluxio上运行Spark

就和从普通的文件系统中读取文件一样

将LICENSE上传到HDFS的alluxio目录

hadoop fs -put -f /alluxio/LICENSE hdfs://localhost:9000/alluxio/LICENSE

进行一些操作

val s = sc.textFile("alluxio://localhost:19998/LICENSE")
val double = s.map(line => line + line)
double.saveAsTextFile("alluxio://localhost:19998/LICENSE2")

可以在web ui 中看到保存的文件,当然DataFrame的操作也是一样的,例如

val df = sc.parallelize(Seq("zhangsan","lisi")).toDF("name")
df.write.parquet("alluxio://localhost:19998/people")

一些运行截图

Spark & Alluxio_第1张图片

你可能感兴趣的:(Spark)