AWSにTensorflow GPUをセットアップする
AWS管理コンソールにログインし、以下の画面を表示します。
data:image/s3,"s3://crabby-images/d3d4c/d3d4c150799cb0606564fb31bf730792ad74e46e" alt="AWS管理コンソール画面"
「EC2」を選択してください。
data:image/s3,"s3://crabby-images/6e1dd/6e1ddd9818aa56efe0914ebf86f99b244edc28d6" alt="Launch Instance"
「Launch Instance」をクリックしてください。
2つの選択肢があります。
- ゼロからインスタンスを作成する (あまり簡単ではありません)
- 既存のAMIを利用する
Amazonが提供するディープラーニングのためのAMIを使いましょう。
data:image/s3,"s3://crabby-images/006e9/006e97e21d303634907bd99d53b41c0bd224b2ad" alt="AMI"
パブリックAMIからインスタンスを作成する
サイドバーから「Spot Requests」をクリックします。
data:image/s3,"s3://crabby-images/2c128/2c128ec4e6b5f40c0fcbaf36e9a38034318a9e8a" alt="Spot Requests"
これは安価なオプションです。
詳細は https://aws.amazon.com/ec2/spot/ を参照してください。
data:image/s3,"s3://crabby-images/6751e/6751e48e39517cb56c49f60b189cd116e7bf94e1" alt=""
「Request Spot Instance」をクリックします。
data:image/s3,"s3://crabby-images/3efb8/3efb8f1e0b401397b6bd186ecaaf6fa13d1c0331" alt=""
“AMI” Selectを選択します。
data:image/s3,"s3://crabby-images/4b17a/4b17a03889db64040d0f35d6c98e3f7b603d30e2" alt=""
「Community AMIs」を選択し、あなたのリージョンのAMIコードをタイプして、「Select」をクリックします。
“Instance type”は、 SelectをクリックしてGPU Instanceを選択します。
data:image/s3,"s3://crabby-images/dd49f/dd49f93beaeb57117f500207cf0eebd4d970b1bc" alt=""
“GPU Instances” でフィルターをかけ、“g2.2xlarge”を選択します。
“Allocation strategy”は‘Lowest price’に、“Maximum price”は‘Use automated bidding’ にしておきます。
Nextをクリックします。
data:image/s3,"s3://crabby-images/3a66a/3a66a652c01d90d700df51196f1894b3938c1b45" alt=""
“Create new key pair” をクリックします。
data:image/s3,"s3://crabby-images/69516/69516ed7d91dfea8c96ed145b8e2c7403dccfa1d" alt=""
“.pem”ファイルをダウンロードし、安全な場所に保存します。
このキー無しではインスタンスを起動することができません。
また、キーのコピーは無効となるのでオリジナルのみを保管してください。
data:image/s3,"s3://crabby-images/50ba5/50ba5c0842327217bf0ea94f83260ff350e15c37" alt=""
“Create new Security Group”をクリックします。
data:image/s3,"s3://crabby-images/d9633/d96338ee2b90a675fb26be1e8587527462ea99f7" alt=""
セキュリティー設定を上記と同様に記入します。
Port‘8888’はJupyter notebookをホストするポートです。
他のフィールドはそのままにしておきます。
Reviewをクリックします。
data:image/s3,"s3://crabby-images/51a5c/51a5ccad65594ebd14ed48e036a203ad6ead714e" alt=""
最後に”Launch” をクリックします。
data:image/s3,"s3://crabby-images/43e61/43e6175cde7bd7fa4f2baf6df88b7281c696bfd9" alt=""
1~2分間で、‘active’に変わるはずです。
サイドバーからInstancesをクリックします。
data:image/s3,"s3://crabby-images/ac0dd/ac0dd8b44a0634450e4f7096dcf1ed42804f927c" alt=""
ご覧の様に、’Demo_ GPU ‘が’running’のステータスになっています。
インスタンスが完全に起動しました。
次のステップではインスタンスに接続します。
SSHを使用してインスタンスに接続する
active Instanceを選択し、“Connect”をクリックします。
data:image/s3,"s3://crabby-images/1e06b/1e06bf20eaa1efaeff8137c74770e42904d7aa45" alt=""
ターミナルを開きます。(Mac/Linuxの場合)
Windowsの場合はPuTTYを使用します。
.pem ファイルのあるディレクトリに移動します。
私の場合は “~/Documents/AWS” でした。
data:image/s3,"s3://crabby-images/57c4e/57c4eaadea38935e98c5434153d9abb3628a1408" alt=""
“sudo chmod 400 demo-key.pem”と入力します。
例の中からSSHコマンドを入力します。私の場合は以下でした。
sudo ssh -i “demo-key.pem” ubuntu@ec2–54–203–11–42.us-west-2.compute.amazonaws.com
“root -> ubuntu”に置き換える事を忘れないでください。
data:image/s3,"s3://crabby-images/f05d1/f05d1c2081a6db41124ddf4e2a121e2b838355e8" alt=""
yes と入力します。
data:image/s3,"s3://crabby-images/63de2/63de268077a07f75bbe039b75fc0e3688ed84fb1" alt=""
SSHで仮想マシンに接続されました。
次のステップでは、Jupyter notebookにブラウザ経由でアクセスできるようにします。
Jupyter notebookにブラウザ経由でアクセスする
始めにJupyter Notebookをインストールします。
sudo pip install jupyter
“ipython”と入力します。
data:image/s3,"s3://crabby-images/e54ea/e54ea61eca37dbea81165a0250e2370543d3501f" alt=""
from IPython.lib import passwd
passwd()
‘sha1:005e7c81ba50:75d71db1cbafb1f9fe78fc59d9a42590d716f3c5’
Sha1を安全な場所に保管します。後で必要になります。
下記の通り入力します。
jupyter notebook --generate-config
ウェブからアクセスするためには、Jupyter サーバーのための証明書を作成する必要があります。
私はCertsディレクトリに証明書を保管しようと思います。
mkdir certs
cd certs
sudo openssl req -x509 -nodes -days 365 -newkey rsa:1024 -keyout democert.pem -out democert.pem
data:image/s3,"s3://crabby-images/c63de/c63de51b1829dbd51162aacd454aab2ea0b75dae" alt=""
”Democert.pem” が取得されたはずです。
これからJupyter コンフィグレーション・ファイルを編集します。
cd ~/.jupyter/
vi jupyter_notebook_config.py
“i”を押して編集を始めます。
data:image/s3,"s3://crabby-images/58176/58176dcc1addece00d7eca898d645ee0582afa6a" alt=""
# Configuration file for jupyter-notebook.
c = get_config()
# Kernel config
c.IPKernelApp.pylab = 'inline' # if you want plotting support always in your notebook
# Notebook config
#location of your certificate key
c.NotebookApp.certfile = u'/home/ubuntu/certs/democert.pem' #location of your certificate file
c.NotebookApp.ip = '*'
c.NotebookApp.open_browser = False #so that the ipython notebook does not opens up a browser by default
c.NotebookApp.password =
u'sha1:005e7c81ba50:75d71db1cbafb1f9fe78fc59d9a42590d716f3c5' #the encrypted password we generated above
# It is a good idea to put it on a known, fixed port
c.NotebookApp.port = 8888
編集を終了するには“esc”、ファイルを保存してvim editor を終了するには”:wq” をコマンドします。
ホームディレクトリの中に“Notebooks”フォルダーを作成し、Jupyter notebookを保存します。
cd ~
mkdir Notebooks
cd Notebooks
Type
nohup jupyter notebook
to start the server.
“nohup” ensures that the server is running even if you close ssh connection to the server
data:image/s3,"s3://crabby-images/f72fe/f72fe2ff1f8a52dba1553c480b4d3a78674e989f" alt=""
ターミナルを直接終了することにより、接続を切断できます。
新しいターミナルインスタンス、新しいタブ、SSHサーバーを開き、Notebookディレクトリに移動します。
cat nohup.out
data:image/s3,"s3://crabby-images/c2574/c2574da7c24a679947caeda4acb3324b6d2d7961" alt=""
The Jupyter Notebook is running at: https://[all ip addresses on your system]:8888/
あなたのパブリックIPアドレスがAWSコンソールから確認できます。
data:image/s3,"s3://crabby-images/79203/7920306a93b7cfba09ab4a0f8ad2d1dd28b9821b" alt=""
ブラウザに以下の様に入力します。
https://ec2–54–203–11–42.us-west-2.compute.amazonaws.com:8888
data:image/s3,"s3://crabby-images/2fc3a/2fc3a9956bad845917fe09d1f71cd710e7bc31dd" alt=""
“Add Exception”をクリックし、続いて“Confirm Security Exception”をクリックします。
data:image/s3,"s3://crabby-images/af359/af359fc8dff0b533766f44dd3967b2e3dcad3931" alt=""
パスワードを入力します。
新しいiPython notebookを作成してtensorflowをテストしましょう。
data:image/s3,"s3://crabby-images/9833a/9833a5b28e36310fe6c6eb01abbda8384a27c76f" alt=""
data:image/s3,"s3://crabby-images/2259f/2259fdee0193b1d04242620127bd5427511f98ab" alt=""
ご覧の様に‘tensorflow’がインポートされました。
アウトプットにCUDAライブラリが含まれているので‘nohup.out’はGPUが使用中である事を示しています
もしサーバーを終了したかったり、またはport:8888が他のサーバーによって使用中の場合
data:image/s3,"s3://crabby-images/f2c6b/f2c6b0a2acb5970c34864bdc130e1ae3abbb8a7d" alt=""
Port 8888 already in use
既に稼働しているサーバーを終了するには
lsof nohup.out
kill -9 <PID>
data:image/s3,"s3://crabby-images/4654d/4654d93be9a6cee6699166e8d630b0c2712a784a" alt=""
作業が終わったら、”Spot Request”のキャンセルを忘れないでください。
Spot Requests -> Select the request -> Action -> Cancel Request
原文
https://chatbotslife.com/aws-setup-for-deep-learning-fda04db6df75
チャットボットライフとの提携により、翻訳し掲載しています。
チャットボットライフとは、最新のボット、AI、NLP、ツール等を扱うメディアです。