コンテンツへスキップ
🛠️ToolsShed

SSH Configジェネレーター

複数ホスト用の~/.ssh/configエントリを生成します。

ホストエントリー 1
~/.ssh/config
Host myserver
  HostName 192.168.1.100
  User ubuntu
  IdentityFile ~/.ssh/id_rsa
  ServerAliveInterval 60

使い方:

  1. 出力を ~/.ssh/config に保存
  2. 実行: chmod 600 ~/.ssh/config
  3. 接続: ssh <HostAlias>

このツールについて

SSH Config Generatorは、複数のSSH接続を管理するプロセスを簡素化し、~/.ssh/configエントリをプログラムで生成します。SSHの設定ファイルを手動で編集して、各サーバーのホストエイリアス、IPアドレス、キーパスを暗記する代わりに、このツールを使用して構造化された形式ですべてのSSHホストを定義し、数秒で完全な設定ファイルを生成できます。整理されたSSH configを持つことは、異なるサーバーに頻繁に接続する開発者、システム管理者、DevOpsエンジニアにとって不可欠です。

ツールを使用するには、ホスト名、ポート、ユーザー名、識別ファイルパス、その他のSSHオプションなど、対応するSSH設定を持つSSHホストを入力します。ジェネレータはこれらのエントリをSSH config構文に従って自動的にフォーマットし、出力を表示します。その後、これを~/.ssh/configファイルに直接コピーするか、既存の設定に追加できます。このアプローチにより構文エラーが排除され、管理するサーバーの数に関係なく、すべてのホスト定義でフォーマットの一貫性が保証されます。

よくある質問

コード実装

import paramiko

# SSH with config file support using Paramiko
config = paramiko.SSHConfig()
with open('/home/user/.ssh/config') as f:
    config.parse(f)

host_config = config.lookup('myserver')
print(host_config)
# {'hostname': '192.168.1.100', 'user': 'ubuntu', 'port': '22'}

# Connect using resolved config
client = paramiko.SSHClient()
client.set_missing_host_key_policy(paramiko.AutoAddPolicy())
client.connect(
    hostname=host_config['hostname'],
    username=host_config.get('user', 'root'),
    port=int(host_config.get('port', 22)),
    key_filename=host_config.get('identityfile', [None])[0]
)
stdin, stdout, stderr = client.exec_command('uptime')
print(stdout.read().decode())
client.close()

Comments & Feedback

Comments are powered by Giscus. Sign in with GitHub to leave a comment.