作成日
2014/11/25最終更新
2017/09/27記事区分
一般公開SSH関連で活用できると便利な以下の二つの事項についてまとめます。
- SSH接続の設定ファイル「~/.ssh/config」によく記述する内容
- SSH接続時に秘密鍵のパスワード入力を省略する ssh-agent の利用方法
SSH config
踏み台サーバ step を経由して internal-0001 にアクセスする設定ファイルの例を記載します。設定項目の意味については「man ssh_config」を参照してみてください。
~/.ssh/config
Host step
HostName step.example.com
User username
IdentityFile ~/.ssh/id_rsa
ServerAliveInterval 60
Host internal-0001
HostName 10.0.0.1
User username
IdentityFile ~/.ssh/id_rsa
ServerAliveInterval 60
ProxyCommand ssh -W %h:%p step
権限設定を忘れないようにしましょう。
$ chmod 600 ~/.ssh/config
以下のように直接ログインできるようになっています。
$ ssh internal-0001
この設定ファイルがない場合は
$ ssh username@step.example.com -i ~/.ssh/id_rsa
としてから
$ ssh username@10.0.0.1 -i ~/.ssh/id_rsa
とする必要がありました。Capistrano で internal-0001 にデプロイする際にこれでは困りますね。
SSH-agent
~/.bashrc などに以下の内容を追記します。ログイン時に一度だけパスワードを入力すれば、以降の入力は不要になります。
SSH_AGENT_FILE=$HOME/.ssh-agent
test -f $SSH_AGENT_FILE && source $SSH_AGENT_FILE
if ! ssh-add -l > /dev/null 2>&1; then
ssh-agent > $SSH_AGENT_FILE
source $SSH_AGENT_FILE
ssh-add $HOME/.ssh/id_rsa
fi
- ssh-agent : 実行するとプロセスが常駐します
- ssh-add : 常駐しているssh-agentプロセスに指定した秘密鍵を覚えさせるコマンドです
過去に作成された $SSH_AGENT_FILE が存在していれば、既にssh-agentが常駐している可能性があるため source でその情報を読み込んでおきます。実際にそのssh-agentが生きていてかつ秘密鍵を覚えている場合はなにもしませんが、そうでない場合は新規にssh-agentを常駐させて、秘密鍵を覚えさせます。
関連記事
- 使い所が難しいマイナーな運用コマンドコマンドのエイリアスを登録する (update-alternatives) mybin という名前のコマンドを登録 sudo update-alternatives --install /usr/local/bin/mybin mybin /usr/bin/echo 10 sudo update-alternatives --install /usr/local/bin/mybin mybin /...
- ipコマンドの基本的な使い方ネットワーク関連のコマンドはたくさんあります。しかしながら、その一部は ip コマンドに集約できます。 基本形 ("man ip" より抜粋) $ ip OBJECT COMMAND OBJECT: link, neigh, addr, route (等) COMMAND: show, add, delete (等) データリンク層のネットワークデバイス情報 (ifconfigコマンドの代用) M...
- プロセス関連のコマンドプロセスID関連 (ps, pgrep, pkill) 全プロセスを表示するためには $ ps ax とすればよく、その表示を見やすくするためには "u" と "w" を追加して $ ps auxw とすればよいです。表示件数自体は同じです。そのうち特定のコマンドのプロセスIDだけを表示したい場合は $ ps ax | grep 'my_script' | grep -v grep | awk '...
- rpmとyumのチートシートrpm (RedHat Package Manager または RPM Package Manager) はRedHat系のパッケージ管理ツールで、yum (Yellowdog Updater Modified) は内部的にrpmを実行するメタパッケージ管理ツールです。rpmには柔軟性がありyumには利便性があります。 rpmは "rpmパッケージファイル" があれば何でもインストールできますが、...
- メモリおよびディスクリソースを調査するために便利なコマンドおよび周辺知識メモリ使用量を表示 (free) 既定ではキロバイト単位で表示されます。オプション "-b", "-k", "-m", "-g" を付与して実行するとそれぞれバイト、キロ、メガ、ギガで表示されます。 $ free total used free shared buffers cached Mem: 510824 ...