Ubuntu16.04下偽分散式環境搭建之hadoop、jdk、Hbase、phoenix的安裝與配置

来源:https://www.cnblogs.com/why5125/archive/2018/02/07/8427239.html
-Advertisement-
Play Games

一、準備工作 安裝包鏈接: https://pan.baidu.com/s/1i6oNmOd 密碼: i6nc 環境準備 修改hostname: $ sudo vi /etc/hostname why 修改IP 地址: $ sudo vi /etc/network/interfaces auto e ...


一、準備工作

安裝包鏈接: https://pan.baidu.com/s/1i6oNmOd 密碼: i6nc

環境準備

修改hostname:

$ sudo vi /etc/hostname

why

修改IP 地址:

$ sudo vi /etc/network/interfaces

auto eth0

iface eth0 inet static

address 192.16.13.11

netmask 255.255.255.0

gateway 192.16.13.254

重啟網路服務生效:

$ sudo ifdown eth0 && sudo ifup eth0

修改ip 與主機名的對應關係:

$ sudo vi /etc/hosts

192.16.13.11 why

 

1.1創建hadoop用戶

 $ sudo useradd -m hadoop -s /bin/bash  #創建hadoop用戶,並使用/bin/bash作為shell

   $ sudo passwd hadoop                   #為hadoop用戶設置密碼,輸入兩次

   $ sudo adduser hadoop sudo             #為hadoop用戶增加管理員許可權,方便部署

   $ su - hadoop                          #將當前用戶切換到hadoop用戶

   $ sudo apt-get update                  #更新hadoop用戶的apt,方便後續軟體安裝

1.2安裝SSH,並配置SSH無密碼登陸

$ sudo apt-get install openssh-server   #ubuntu預設安裝了SSH client,此處安裝SSH server

$ ssh-keygen -t rsa

$ sudo localhost                        #登陸SSH,第一次登陸輸入yes

$ exit                                  #退出登錄的ssh localhost

$ cat ./id_rsa.pub >> ./authorized_keys #加入授權

 

$ ssh localhost                         #無需密碼登陸,可看到如下界面

 

 

二、安裝jdk

$ sudo tar zxvf jdk-8u92-linux-x64.tar.gz  -C /usr/lib     #/ 解壓到/usr/lib/jvm目錄下

$ cd /usr/lib/jvm                                 #進入該目錄

$ mv  jdk1.8.0_92 java                         #重命名為java

$ vi ~/.bashrc                                 #給JDK配置環境變數

export JAVA_HOME=/usr/lib/jvm/java

export JRE_HOME=${JAVA_HOME}/jre

export CLASSPATH=.:${JAVA_HOME}/lib:${JRE_HOME}/lib

export PATH=${JAVA_HOME}/bin:$PATH

$ source ~/.bashrc                       #使新配置的環境變數生效

$ java -version                          #檢測是否安裝成功,查看java版本

 

安裝hadoop

$ sudo tar -zxvf  hadoop-2.6.2.tar.gz -C /usr/local    #解壓到/usr/local目錄下

$ cd /usr/local

$ sudo mv  hadoop-2.6.2    hadoop                      #重命名為hadoop

$ sudo chown -R hadoop ./hadoop                        #修改文件許可權

$ vi ~/.bashrc  

export HADOOP_HOME=/usr/local/hadoop

export CLASSPATH=$($HADOOP_HOME/bin/hadoop classpath):$CLASSPATH

export HADOOP_COMMON_LIB_NATIVE_DIR=$HADOOP_HOME/lib/native

export PATH=$PATH:$HADOOP_HOME/bin:$HADOOP_HOME/sbin

$ source ~/.bashrc                       #使新配置的環境變數生效

Hadoop 可以在單節點上以偽分散式的方式運行,Hadoop 進程以分離的 Java 進程來運行,節點既作為 NameNode 也作為 DataNode,同時,讀取的是 HDFS 中的文件。Hadoop 的配置文件位於 /usr/local/hadoop/etc/hadoop/ 中,偽分散式需要修改2個配置文件 core-site.xml 和 hdfs-site.xml 。Hadoop的配置文件是 xml 格式,每個配置以聲明 property 的 name 和 value 的方式來實現。

首先將jdk的路徑添(export JAVA_HOME=/usr/lib/jvm/java 
)加到hadoop-env.sh文件 

接下來修改core-site.xml文件:

<configuration>

        <property>

             <name>hadoop.tmp.dir</name>

             <value>file:/usr/local/hadoop/tmp</value>

             <description>Abase for other temporary directories.</description>

        </property>

        <property>

             <name>fs.defaultFS</name>

             <value>hdfs://localhost:9000</value>

        </property>

</configuration>

 

接下來修改配置文件 hdfs-site.xml

<configuration>

        <property>

             <name>dfs.replication</name>

             <value>1</value>

        </property>

        <property>

             <name>dfs.namenode.name.dir</name>

             <value>file:/usr/local/hadoop/tmp/dfs/name</value>

        </property>

        <property>

             <name>dfs.datanode.data.dir</name>

             <value>file:/usr/local/hadoop/tmp/dfs/data</value>

        </property>

</configuration>

修改 slaves ,添加節點名 why

Hadoop 的運行方式是由配置文件決定的(運行 Hadoop 時會讀取配置文件),因此如果需要從偽分散式模式切換回非分散式模式,需要刪除 core-site.xml 中的配置項。此外,偽分散式雖然只需要配置 fs.defaultFS 和 dfs.replication 就可以運行(可參考官方教程),不過若沒有配置 hadoop.tmp.dir 參數,則預設使用的臨時目錄為 /tmp/hadoo-hadoop,而這個目錄在重啟時有可能被系統清理掉,導致必須重新執行 format 才行。所以我們進行了設置,同時也指定 dfs.namenode.name.dir 和 dfs.datanode.data.dir,否則在接下來的步驟中可能會出錯。

配置完成後,執行 NameNode 的格式化

 

$ ./bin/hdfs namenode -format

啟動namenode和datanode進程,並查看啟動結果

$ ./sbin/start-dfs.sh

$ jps

啟動完成後,可以通過命令 jps 來判斷是否成功啟動,若成功啟動則會列出如下進程: “NameNode”、”DataNode” 和 “SecondaryNameNode” 

五、安裝Hbase

$ sudo tar -zxf hbase-1.1.2-hadoop2-bin.tar.gz  -C/usr/local  #解壓到usr/local目錄下

$ cd /usr/local

$ mv ./hbase-1.1.2-hadoop2 ./hbase    #重命名

$ sudo chown -R hadoop:hadoop  ./hbase  #修改許可權

配置命令行環境變數/etc/profile

export HBASE_HOME=/usr/local/hbase

export PATH=$HBASE_HOME/bin:$PATH

修改hbase的配置文件/conf/hbase-env.sh

export JAVA_HOME=/usr/lib/jvm/java

export HBASE_MANAGES_ZK=true

編輯.xml配置文件 conf/hbase-site.xml

<configuration>

        <property>

                <name>hbase.rootdir</name>

                <value>hdfs://localhost:9000/hbase</value>

                <description>數據存放的位置。</description>

        </property>

        <property>

                <name>hbase.cluster.distributed</name>

                <value>true</value>

        </property>

        <property>

                <name>hbase.zookeeper.quorum</name>

                <value>localhost</value>

        </property>

        <property>

                <name>dfs.replication</name>

                <value>1</value>

                <description>指定副本個數為1,因為偽分散式。</description>

        </property>

</configuration>

說明 
hbase.rootdir配置在hdfs文件系統上hbase存儲的路徑 
hbase.cluster.distributed配置是否是分散式的 
hbase.zookeeper.quorum配置zookeeper在哪個節點上 
dfs.replication配置副本個數 
註意:hbase.rootdir的主機和埠號與hadoop的配置文件core-site.xml的fs.default.name的主機和埠號一致 
啟動hbase,在bin目錄下執行命令start-hbase.sh 
啟動hbase之前,確保hadoop是運行正常的,並且可以寫入文件*

六、安裝phoenix

$ sudo tar -zxf phoenix-4.7.0-HBase-1.1-bin.tar.gz  -C/usr/local  #解壓到usr/local目錄下

$ cd /usr/local

把 hbase-site.xml 考到 phoenix  ./bin目錄下

把 phoenix-4.7.0-HBase-1.1-server.jar  包考到 hbase ./lib 下


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 這是MVVM之旅系列文章的第一篇,許多文章和書喜歡在開篇介紹某種技術的誕生背景和意義,但是我覺得對於程式員來說,一個能直接運行起來的程式或許能夠更直觀的讓他們瞭解這種技術。在這篇文章里,我將帶領大家一步一步創建一個最簡單的MVVM程式,程式雖然簡單,但是卻涵蓋了MVVM的基本要素,對於那些還不是很了 ...
  • 當一份web報表項目壓縮包躺在我的文件夾里時,我是完全懵的。作為一個學習了一個月java的asp.net小白,以前從來沒有接觸過這方面,我完全不知道從何入手。(出於其他原因,不方便貼圖,貼代碼) 手裡也有asp.net開發學習視頻,但都因為懶沒看。網上搜集了很多資料,得知這種web報表一般是由三層物 ...
  • 前言 童鞋們,大家好 我是專註.NET開發者社區建設的實踐者Rector。 首先,為自己間隔了兩個星期五再更新本系列文章找個不充分的理由:Rector最近工作,家庭的各種事務所致,希望大家諒解。 本文知識要點 回到本文的主題,還是關於系列文章:《一步一步創建ASP.NET MVC5程式Reposit ...
  • 前言:前面準備了那麼久的準備工作,現在終於可以開始構建我們自己的服務了。這篇博客就讓我們一起構建自己的第一個服務 審計日誌。 首先我們先創建兩個項目,一個控制台的服務啟動項目,一個業務的實現項目。(註:控制台項目可以引用業務項目,也可以不引用業務項目。因為surging支持熱部署) 在服務啟動項目中 ...
  • 1. 前言 HeaderedContentControl是WPF中就存在的控制項,這個控制項的功能很簡單:提供Header和Content兩個屬性,在UI上創建兩個ContentPresenter並分別綁定到Header和Content,讓這兩個ContentPresenter合體組成HeaderedC ...
  • 通過重寫 class 的 ToString() 來簡化獲取 enum 的 DescriptionAttribute 值 目錄 一、常見的 enum 類型 二、演變:class 版本的 enum 類型 三、演進:class 和 enum 兩者共存的版本 一、常見的 enum 類型 新建一個 Algor ...
  • 文章目錄: 1.語法 2.選項 3.參數 4.實例 4.1 獲取內置命令幫助信息 4.2 獲取外置命令幫助信息 1.語法 2.選項 3.參數 4.實例 4.1 獲取內置命令幫助信息 4.2 獲取外置命令幫助信息 help命令 help命令用於顯示shell內部命令的幫助信息。 1.語法 help [ ...
  • 一、 用grep在文件中搜索文本 grep能夠接受正則表達式,生成各種格式的輸出。除此之外,它還有大量有趣的選項。 1、 搜索包含特定模式的文本行: 2、 從stdin中讀取: 3、 單個grep命令可以對多個文件進行搜索: 4、 --color選項在輸出行中著重標記出匹配到的單詞: 5、 grep ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...