LoginSignup
27

More than 5 years have passed since last update.

CLIプラグインでBluemixのアプリにssh接続

Last updated at Posted at 2015-12-05

1. はじめに

Bluemixで作業していると、これもうインスタンスに直接ログインできれば早いのにーと思うことがよくあります。そのような使い方はBluemixの仕様に合わないとしても、デバッグのためにちょっとsshで繋いでコマンドを叩けるといろいろと捗りそうです。

BluemixのベースになっているCloud Foundryでは、以前はCLI(Command Line Interface)でcf tunnel というコマンドが使えて、直接コンテナにログインすることができたと聞きます。しかし、現在のversion 6のCLIではサポートされていません。

SDK for Node.js の環境であれば、ライブ編集のモードをONにしてシェルでのアクセスが可能です。これは非常に便利です。他のランタイムでも同様の機能を使うにはどうすればいいのでしょうか。

2. CF CLIプラグインでコンテナアクセス

コンテナにアクセスできるように作られたビルドパックは存在します。しかしシェルでアクセスすること自体が目的ではなく、あくまでもアプリのデバッグのための手段と考えると、構築済みのインスタンスに手軽にアクセスできることが求められます。

そこで見つけたのは標準のcfコマンドの機能を拡張するプラグイン。Cloud Foundryが公開しているコミュニティプラグインの一覧にある、cf console というプラグインを使うとコンテナにアクセスできると書かれています。 tmate.ioという外部のサービスを中継点として、Bluemix上のコンテナと繋がる仕組みのようです。早速試してみしまょう。

cfconsole.jpg

CLIのプラグインについては、以前の記事 CLIプラグインでもっと快適にBluemixを操る を参照してください。

3. cf consoleのセットアップから接続まで

それでは cf console を導入してみましょう。下記の例は、CF-communityという名前のプラグインリポジトリが設定されている前提です。

install-plugin
letsfacethefact@instance-1:~/tmp$ cf install-plugin Console -r CF-community
**Attention: Plugins are binaries written by potentially untrusted authors. Install and use plugins at your own r
isk.**
Do you want to install the plugin Console? (y or n)> y
Looking up 'Console' from repository 'CF-community'
7984168 bytes downloaded...
Installing plugin /tmp/cf-plugin-console...
OK
Plugin Console v0.0.0 successfully installed.

letsfacethefact@instance-1:~$ cf plugins
Listing Installed Plugins...
OK
Plugin Name   Version   Command Name   Command Help   
Console       N/A       console        Start a live console   

letsfacethefact@instance-1:~$ 

導入ができたので、cf consoleプラグインを使ってBluemix上のコンテナに接続してみましょう。接続先は何でもいいのですが、ここでは下記のようなPHPのインスタンスをターゲットにします。

PHP

letsfacethefact@instance-1:~$ cf apps
Getting apps in org xxx@xxx.com / space Sandbox as xxx@xxx.com...
OK
name         requested state   instances   memory   disk   urls   
PHPAppUSDC   started           1/1         128M     1G     phpappusdc.mybluemix.net   
letsfacethefact@instance-1:~$ cf app PHPAppUSDC
Showing health and status for app PHPAppUSDC in org xxx@xxx.com / space Sandbox as xxx@xxx.com...
OK
requested state: started
instances: 1/1
usage: 128M x 1 instances
urls: phpappusdc.mybluemix.net
last uploaded: Sat Dec 5 23:27:27 UTC 2015
stack: cflinuxfs2
buildpack: php_buildpack
     state     since                    cpu    memory          disk           details   
#0   running   2015-12-05 11:28:19 PM   0.3%   58.9M of 128M   124.3M of 1G      
letsfacethefact@instance-1:~$ 

PHPのインスタンスに向けて cf console を実行。

console
letsfacethefact@instance-1:~$ cf console PHPAppUSDC
> Finding app guid for PHPAppUSDC ... bbb121f2-7b11-498d-90b4-ad1923219481 
{bbb121f2-7b11-498d-90b4-ad1923219481 PHPAppUSDC false} 
> Updating app to connect to tmate.
> Updating app start command to 'curl -s https://raw.githubusercontent.com/danhigham/cf-console/master/install.s
h > /tmp/install.sh && bash /tmp/install.sh && sleep 3600'.
> Changing instance count to 2.
> Checking app log datestamps.

letsfacethefact@instance-1:~$ cf app PHPAppUSDC
Showing health and status for app PHPAppUSDC in org xxx@xxx.com / space Sandbox as xxx@xxx.com...
OK

requested state: started
instances: 2/2
usage: 128M x 2 instances
urls: phpappusdc.mybluemix.net
last uploaded: Sat Dec 5 23:27:27 UTC 2015
stack: cflinuxfs2
buildpack: php_buildpack

state     since                    cpu    memory          disk           details   
#0   running   2015-12-05 11:28:19 PM   0.3%   58.9M of 128M   124.3M of 1G      
#1   running   2015-12-06 12:18:19 AM   0.4%   63.1M of 128M   135.5M of 1G      
letsfacethefact@instance-1:~$ 

PHPのインスタンスに tmate.io に接続するためのモジュールが導入されるとともに、インスタンスが一つ追加されたようです。
接続に必要な情報を取得するためにアプリケーションのログを確認してみます。

log確認
letsfacethefact@instance-1:~$ cf logs PHPAppUSDC --recent | more

(省略)

2015-12-06T00:18:17.76+0000 [App/1]      OUT ./include/event2/thread.h
2015-12-06T00:18:17.76+0000 [App/1]      OUT ./include/event2/util.h
2015-12-06T00:18:17.76+0000 [App/1]      OUT ./bin/tmate
2015-12-06T00:18:18.65+0000 [App/1]      OUT 3ezDwQr220BXfcvYRo8BX4U8x@sf1.tmate.io
letsfacethefact@instance-1:~$ 

ログの一番下にtmate.io への接続情報が出力されていますね。
この情報を使って sshで接続してみましょう。

ssh接続
letsfacethefact@instance-1:~$ ssh 3ezDwQr220BXfcvYRo8BX4U8x@sf1.tmate.io

接続完了!
vcap@194mt78p9ai:~$ stty -echo; ps_orig=`echo $PS1`; PS1=""
       __                             _
  ___ / _|   ___ ___  _ __  ___  ___ | | ___
 / __| |_   / __/ _ \| '_ \/ __|/ _ \| |/ _ \
| (__|  _| | (_| (_) | | | \__ \ (_) | |  __/
 \___|_|    \___\___/|_| |_|___/\___/|_|\___|

3ezDwQr220BXfcvYRo8BX4U8x@sf1.tmate.io

vcap@194mt78p9ai:~$ 

────────────────────────────────────────────────────────────────────────────────────────────────────────────────
vcap@194mt78p9ai:~$ $HOME/.bp/bin/start
00:18:18 httpd   | [Sun Dec 06 00:18:18.918515 2015] [mpm_event:notice] [pid 77:tid 140482411562816] AH00489: Ap
ache/2.4.16 (Unix) configured -- resuming normal operations
00:18:18 httpd   | [Sun Dec 06 00:18:18.918721 2015] [mpm_event:info] [pid 77:tid 140482411562816] AH00490: Serv
er built: Jul 22 2015 20:20:52
00:18:18 httpd   | [Sun Dec 06 00:18:18.918747 2015] [core:notice] [pid 77:tid 140482411562816] AH00094: Command
 line: '/app/httpd/bin/httpd -f /home/vcap/app/httpd/conf/httpd.conf -D FOREGROUND'
00:18:18 php-fpm | [06-Dec-2015 00:18:18] NOTICE: fpm is running, pid 80
00:18:18 php-fpm | [06-Dec-2015 00:18:18] NOTICE: ready to handle connections
01:07:11 httpd   | [Sun Dec 06 01:07:11.126478 2015] [core:info] [pid 77:tid 140482411562816] AH00096: removed P
ID file /home/vcap/app/httpd/logs/httpd.pid (pid=77)
01:07:11 httpd   | [Sun Dec 06 01:07:11.126506 2015] [mpm_event:notice] [pid 77:tid 140482411562816] AH00492: ca
ught SIGWINCH, shutting down gracefully
vcap@194mt78p9ai:~$ 

0:bash*                                                                                                         

接続成功!
BluemixのPHPのコンテナにsshで入れました。簡単ですね。繋がってしまえば後はご自由に。vcapというユーザーの権限の範囲でコマンド叩き放題です:grinning:

4. 注意点とまとめ

  • cf console プラグインを使えば、簡単にBluemixのコンテナにログインできることが確認できました。ただし、このプラグインは osx および linux64 プラットフォーム用です。Windows環境は正式にはサポートされていません。

  • ログに出力されるsshのログイン情報は ephemeral なもの、とのこと。つまりすぐに失効してしまいます。必要な都度、接続情報を確認してください。

  • cf console を実行するとインスタンスが一つ追加されます。作業後は元に戻しておきましょう。

  • 今回試した方法は tmate.io という外部サービスを利用した方法です。実際の使用にあたっては、そのリスクも勘案する必要があります。

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
27