DockerでHadoopを実行しイメージを作成する方法

DockerでHadoopを実行しイメージを作成する方法

車輪の再発明として、ここでは再パッケージ化を使用して Docker ベースの Hadoop イメージを生成します。

Hadoop クラスターが依存するソフトウェアは jdk、ssh などです。したがって、これら 2 つの項目と Hadoop 関連パッケージがイメージにパッケージ化されている限り、

設定ファイルの準備

1. Hadoop 関連の設定ファイル: core-site.xml、hdfs-site.xml、mapred-site.xml、yarn-site.xml、slaves、hadoop-env.sh
2. ssh設定ファイル: ssh_config
3. Hadoop クラスターの起動ファイル: start-hadoop.sh

画像を作成する

1. インストールの依存関係

apt-get update を実行 && \
 apt-get install -y openssh-server openjdk-8-jdk wget

2. Hadoopパッケージをダウンロードする

wget http://mirror.bit.edu.cn/apache/hadoop/common/hadoop-2.10.0/hadoop-2.10.0.tar.gz && \ を実行します。
tar -xzvf hadoop-2.10.0.tar.gz && \
ローカルの hadoop ディレクトリを /usr/local/hadoop ディレクトリにコピーします。
rm hadoop-2.10.0.tar.gz && \
rm /usr/local/hadoop/share/doc -rf

3. 環境変数を設定する

環境変数 JAVA_HOME=/usr/lib/jvm/java-8-openjdk-amd64 
環境変数 HADOOP_HOME=/usr/local/hadoop 
環境変数PATH=$PATH:/usr/local/hadoop/bin:/usr/local/hadoop/sbin

4. パスワード不要のノードログイン用のSSHキーを生成する

ssh-keygen -t rsa -f ~/.ssh/id_rsa -P '' && \ を実行します。
cat ~/.ssh/id_rsa.pub >> ~/.ssh/authorized_keys

5. Hadoop 関連のディレクトリを作成し、関連する設定ファイルをコピーし、関連するファイルに実行権限を追加し、最後にネームノード ノードをフォーマットします。各ノードが起動したら、ssh サービスを開始します。

mkdir -p ~/hdfs/namenode && \ を実行します。 
mkdir -p ~/hdfs/datanode && \
$HADOOP_HOME/logs に移動します。
config/* /tmp/ をコピーします
#ssh、hadoop 設定関連をコピー RUN mv /tmp/ssh_config ~/.ssh/config && \
ディレクトリを /tmp/hadoop-env.sh に変更します。 /usr/local/hadoop/etc/hadoop/hadoop-env.sh も変更します。
hdfs-site.xml をコピーして、ディレクトリを HADOOP_HOME/etc/hadoop/hdfs-site.xml にコピーします。 
mv /tmp/core-site.xml $HADOOP_HOME/etc/hadoop/core-site.xml && \
mv /tmp/mapred-site.xml $HADOOP_HOME/etc/hadoop/mapred-site.xml && \
yarn-site.xml を HADOOP_HOME/etc/hadoop/yarn-site.xml にコピーします。
mv /tmp/slaves $HADOOP_HOME/etc/hadoop/slaves && \
mv /tmp/start-hadoop.sh ~/start-hadoop.sh && \
mv /tmp/run-wordcount.sh ~/run-wordcount.sh
#実行権限を追加 RUN chmod +x ~/start-hadoop.sh && \
chmod +x ~/run-wordcount.sh && \
chmod +x $HADOOP_HOME/sbin/start-dfs.sh && \
chmod +x $HADOOP_HOME/sbin/start-yarn.sh 
#フォーマットネームノード
/usr/local/hadoop/bin/hdfs namenode -formatを実行します。 


Docker で Hadoop クラスターを実行する

上記の Dockerfile を通じてイメージが生成されたら、上記で生成されたイメージを使用して Hadoop クラスターを構築できます。ここでは、マスター ノードと 2 つのスレーブ ノードを起動します。

ブリッジ ネットワークを追加します。

docker ネットワーク作成 --driver=bridge solinx-hadoop

マスターノードを起動します。

docker run -itd --net=solinx-hadoop -p 10070:50070 -p 8088:8088 --name solinx-hadoop-master --hostname solinx-hadoop-master solinx/hadoop:0.1

Slave1 ノードを起動します。

docker run -itd --net=solinx-hadoop --name solinx-hadoop-slave1 --hostname solinx-hadoop-slave1 solinx/hadoop:0.1

Slave2 ノードを起動します。

docker run -itd --net=solinx-hadoop --name solinx-hadoop-slave2 --hostname solinx-hadoop-slave1 solinx/hadoop:0.1

マスター ノードに入り、スクリプトを実行して Hadoop クラスターを起動します。

要約する

以上が、Docker での Hadoop の実行とイメージ作成についてご紹介した内容です。お役に立てれば幸いです。ご質問がございましたら、メッセージを残していただければ、すぐに返信させていただきます。また、123WORDPRESS.COM ウェブサイトをサポートしてくださっている皆様にも感謝申し上げます。
この記事が役に立ったと思われた方は、ぜひ転載していただき、出典を明記してください。ありがとうございます!

以下もご興味があるかもしれません:
  • Hadoop マルチジョブ並列処理の詳細な例
  • 一般的な Hadoop エラーと解決策の詳細な説明
  • リモート デバッグ コードに IntelliJ IDEA を使用するように Hadoop を構成する方法
  • Spring と統合された Hadoop の使用方法に関する詳細なチュートリアル (ビッグ データのクイック スタート)
  • Windows で IDEA を使用して Hadoop 開発環境を構築する詳細な方法
  • Tencent Cloud 上で Hadoop 3.x 疑似クラスターを構築する方法を説明します
  • CentOS 7 は Hadoop 2.10 の高可用性 (HA) をビルドします
  • Hadoopを使用してファイルから指定されたコンテンツを抽出する方法を教えます

<<:  MySQL でよく使われる型変換関数の概要 (推奨)

>>:  Tencent インタビュー: SQL ステートメントの実行が非常に遅くなる理由は何ですか? ---後悔シリーズは見ないで(推奨)

推薦する

Vuexの補助関数の使い方

目次マップ状態マップゲッターマップミューテーションマップアクション複数のモジュールマップ状態 ...

Viteプロジェクトを作成する手順

目次序文yarn create は何をしますか?ソースコード分析プロジェクトの依存関係テンプレート構...

MYSQL8.0.13 無料インストール版 設定チュートリアル例 詳細説明

1. ダウンロード、例として8.0を取り上げますダウンロードアドレス: https://dev.my...

Vueのカスタムイベントコンテンツ配信の詳細な説明

1. これは理解するのが少し複雑なので、原理を注意深く読んで自分で入力していただければ幸いです。 &...

ECMAScriptにおけるプリミティブ値と参照値の詳しい説明

目次序文動的プロパティとは何ですか?値のコピー値の種類を決定する要約する序文これは JavaScri...

LeetCode の SQL 実装 (183. 注文をしたことがない顧客)

[LeetCode] 183.注文しない顧客Web サイトに、Customers テーブルと Or...

ウェブデザインにおけるインタラクション: ページングの問題に関する簡単な説明

機能: 前のページまたは次のページにジャンプします。要素: ページングの基本要素は、前のページ + ...

MySQL 5.7.18 MSI インストール グラフィック チュートリアル

この記事では、参考までにMySQL 5.7.18 MSIインストールチュートリアルを紹介します。具体...

なぜCSSをヘッドタグに配置する必要があるのか

考えてみてください。なぜcss 、 javascriptのようにbodyタグの末尾ではなく、 hea...

CSSでスペースを処理する方法

1. 宇宙のルールHTML コード内の空白は通常、ブラウザによって無視されます。 <p>...

ウェブページ作成によく使われる英語フォント

アリアルArial は、多くの Microsoft アプリケーションとともに配布されるサンセリフ T...

MySQL の 2 種類の一時テーブルの使用方法の詳細な説明

外部一時テーブルCREATE TEMPORARY TABLE によって作成された一時テーブルは、外部...

入力できない無効な値はアクションレイヤーに渡すことができません

フォームを入力不可にしたい場合は、フォームを次のように設定します。コードをコピーコードは次のとおりで...

Ubuntu 18.04 に vsftpd をインストールするための実装コード

vsftpdをインストールする $ sudo apt-get install vsftpd -y v...

Dockerコンテナ起動時に固定IPを設定する実装

Dockerインストール後のネットワークタイプ [root@insure updev]# docke...