1.環境說明
java
master 192.168.0.223 mesos-masternode
slave 192.168.0.225 mesos-salvelinux
2.環境準備git
關閉防火牆apache
關閉selinuxvim
兩臺機器修改主機名master/slave框架
設置hosts,能互相解析ssh
3.master和slave配置ssh互信
maven
這裏配置hadoop用戶雙機互信,由於hadoop用hadoop用戶啓動ide
master yum -y install sshpass ssh-keygen 一路回車 ssh-copy-id -i ~/.ssh/id_rsa.pub hadoop@192.168.0.220 slave yum -y install sshpass ssh-keygen 一路回車 ssh-copy-id -i ~/.ssh/id_rsa.pub hadoop@192.168.0.201 測試ssh對方主機,不提示輸入密碼則OK
4.安裝JDK
tar zxvf jdk-8u65-linux-x64.tar.gz mv jdk1.8.0_65 /usr/jdk
4.1設置環境變量
export JAVA_HOME=/usr/jdk export JRE_HOME=/usr/jdk/jre export CLASSPATH=.:$CLASSPATH:$JAVA_HOME/lib:$JRE_HOME/lib export PATH=$PATH:$JAVA_HOME/bin:$JRE_HOME/bin 執行 source /etc/profile
4.2測試JDK
java -version #出現版本信息
5.安裝mesos主從,看其餘博客
安裝完成,會在/usr/local/lib下生成一個libmesos.so文件
6.安裝和配置Hadoop
master和slave
tar zxvf hadoop-2.5.0-cdh5.4.8.tar.gz mv hadoop-2.5.0-cdh5.4.8 /usr/hadoop cd /usr/hadoop mkdir -p tmp cd /usr/hadoop/ mv bin bin-mapreduce2/ ln -s bin-mapreduce1 bin mv example example-mapreduce2 ln -s example-mapreduce1 example cd etc/ mv hadoop hadoop-mapreduce2 ln -s hadoop-mapreduce1 hadoop
7.添加hadoop環境變量
vim /etc/profile export HADOOP_HOME=/usr/hadoop export PATH=$PATH:$HADOOP_HOME:$HADOOP_HOME/bin source /etc/profile
8.獲取hadoop on mesos的jar包
yum -y install maven openjdk-7-jdk git git clone cd hadoop mvn package #獲取jar包,jar包會在target下
9.把獲取的jar包放到hadoop安裝目錄下
master和slave
cp hadoop/target/hadoop-mesos-0.1.0.jar /usr/hadoop/share/hadoop/common/lib/
10.配置hadoop on mesos
master和slave
vim /usr/hadoop/etc/hadoop/mapred.site.xml <property> <name>mapred.job.tracker</name> <value>localhost:9001</value> </property> <property> <name>mapred.jobtracker.taskScheduler</name> <value>org.apache.hadoop.mapred.MesosScheduler</value> </property> <property> <name>mapred.mesos.taskScheduler</name> <value>org.apache.hadoop.mapred.JobQueueTaskScheduler</value> </property> <property> <name>mapred.mesos.master</name> <value>zk://192.168.0.223</value> </property> <property> <name>mapred.mesos.executor.uri</name> <value>hdfs://localhost:9000/hadoop-2.5.0-cdh5.2.0.tar.gz</value> </property>
11.給hadoop用戶權限
master和slave
chown -R hadoop:hadoop /usr/hadoop
12.在master上啓動jobtracker,鏈接mesos
su hadoop MESOS_NATIVE_LIBRARY=/usr/local/lib/libmesos.so hadoop jobtracker
13.測試
輸入 192.168.0.223:5050 看看框架裏有沒有hadoop
----------------------------------------------------------------------------------------
2、搭建完HDFS,搭建hadoop on mesos
按照搭建hadoop文檔配置完HDFS,須要配置core-site.xml,hdfs-site.xml,mapred-site.xml
mv bin bin-mapreduce2 ln -s bin-mapreduce1 bin #不用移動hadoop,搭建hadoop on mesos 的時候直接在hadoop裏修改
2.移動hdfs命令和start-dfs.sh
cd /usr/hadoop/bin-mapreduce2 cp hdfs /usr/hadoop/bin-mapreduce1 cd /usr/hadoop/sbin cp start-dfs.sh /sur/hadoop/bin-mapreduce1
3.搭建hadoop on mesos
修改mapred-site.xml配置文件
<property> <name>mapred.job.tracker</name> <value>localhost:9002</value> #改成9002 避免和hdfs-site.xml中的端口衝突 </property> <property> <name>mapred.jobtracker.taskScheduler</name> <value>org.apache.hadoop.mapred.MesosScheduler</value> </property> <property> <name>mapred.mesos.taskScheduler</name> <value>org.apache.hadoop.mapred.JobQueueTaskScheduler</value> </property> <property> <name>mapred.mesos.master</name> <value>zk://192.168.0.223</value> </property> <property> <name>mapred.mesos.executor.uri</name> <value>hdfs://localhost:9000/hadoop-2.5.0-cdh5.2.0.tar.gz</value> </property>
4.格式化和啓動HDFS
hdfs namenode -foramt start-dfs.sh
5.啓動hadoop on mesos
su hadoop MESOS_NATIVE_LIBRARY=/usr/local/lib/libmesos.so hadoop jobtracker