ssh接続でのconfigファイルの便利な使い方やconfigファイルの記述方法をご紹介!

ssh接続でのconfigファイルの便利な使い方
今回は、ssh接続でのconfigファイルの便利な使い方を説明します。通常、「ssh ユーザ名@IPアドレス」のようなコマンドでssh接続しますが、configファイルを作成することで、sshコマンドをシンプルに記述できます。
ここでは、sshクライアントはPowerShell、sshサーバはWSL2(Windows Subsystem for Linux 2)のubuntuとします。WindowsPC 1台で完結します。
ssh接続でのconfigファイルの使い方に興味のある方はぜひご覧ください。
環境情報
PowerShellからWSL2のubuntuにssh接続します。sshクライアントの情報は以下です。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
|
PS C:\> $PSVersionTable
Name Value
---- -----
PSVersion 5.1.18362.1171
PSEdition Desktop
PSCompatibleVersions {1.0, 2.0, 3.0, 4.0...}
BuildVersion 10.0.18362.1171
CLRVersion 4.0.30319.42000
WSManStackVersion 3.0
PSRemotingProtocolVersion 2.3
SerializationVersion 1.1.0.1
PS C:\> ssh -V
OpenSSH_for_Windows_7.7p1, LibreSSL 2.6.5
PS C:\>
|
sshサーバの情報は以下です。
1
2
3
4
5
6
|
~$ cat /etc/issue
Ubuntu 20.04.1 LTS \n \l
~$ ssh -V
OpenSSH_8.2p1 Ubuntu-4ubuntu0.1, OpenSSL 1.1.1f 31 Mar 2020
~$
|
基本的な使い方
sshクライアントからは「ssh ユーザ名@IPアドレス」のように接続しますが、configファイルを作成することで、この記述を簡潔にできます。configファイルはクライアント側に作成します。~/.ssh/configファイルがなければ新規作成してください。
configファイルの内容は、例えば以下のように記述します。
1
2
3
4
|
Host myhost
HostName 192.168.0.1
User myuser
IdentityFile ~/.ssh/id_rsa
|
クライアントからは以下のコマンドでssh接続します。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
|
PS C:\> ssh myhost
Enter passphrase for key 'C:\Users\${ユーザ名}/.ssh/id_rsa':
Welcome to Ubuntu 20.04.1 LTS (GNU/Linux 4.19.128-microsoft-standard x86_64)
* Documentation: https://help.ubuntu.com
* Management: https://landscape.canonical.com
* Support: https://ubuntu.com/advantage
System information as of Wed Dec 30 19:18:50 JST 2020
System load: 0.08 Processes: 11
Usage of /: 0.4% of 250.98GB Users logged in: 0
Memory usage: 2% IPv4 address for eth0: 192.168.0.1
Swap usage: 0%
0 updates can be installed immediately.
0 of these updates are security updates.
Last login: Wed Dec 30 18:46:14 2020 from 172.18.51.97
ssh_server:~$
|
sshコマンドが簡潔に記述できていることが分かります。
コメント
configファイルには#でコメントを記述できます。以下のように記述します。
1
2
3
4
5
6
7
|
Host myhost
# ホスト名
HostName 192.168.0.1
# ユーザー名
User myuser
# 接続用の鍵ファイルパス
IdentityFile ~/.ssh/id_rsa
|
「ssh myhost」コマンドでssh接続できることが分かります。コメントを書いたほうが分かりやすくなります。
ssh接続の切断防止
ssh接続後に一定時間経過すると、自動的に接続が切断されます。ServerAliveIntervalを設定することで、接続の切断防止ができます。指定秒周期でパケット送信することで、接続を維持します。
configファイルには以下のように記述します。
1
2
3
4
5
6
7
8
9
|
Host myhost
# ホスト名
HostName 192.168.0.1
# ユーザー名
User myuser
# 接続用の鍵ファイルパス
IdentityFile ~/.ssh/id_rsa
# コネクションの切断防止(60秒周期でパケット送信)
ServerAliveInterval 60
|
複数ホスト指定
複数ホストを指定することもできます。configファイルには以下のように記述します。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
|
Host myhost
# ホスト名
HostName 192.168.0.1
# ユーザー名
User myuser
# 接続用の鍵ファイルパス
IdentityFile ~/.ssh/id_rsa
# コネクションの切断防止(60秒周期でパケット送信)
ServerAliveInterval 60
Host myhost2
# ホスト名
HostName 192.168.0.2
# ユーザー名
User myuser2
# 接続用の鍵ファイルパス
IdentityFile ~/.ssh/id_rsa
# コネクションの切断防止(60秒周期でパケット送信)
ServerAliveInterval 60
|
sshクライアントからは以下のコマンドで接続します。
1
2
|
PS C:\> ssh myhost
PS C:\> ssh myhost2
|
ワイルドカード指定
ワイルドカードで指定することもできます。configファイルには以下のように記述します。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
|
Host *-group1
# ユーザー名
User myuser
# 接続用の鍵ファイルパス
IdentityFile ~/.ssh/id_rsa
# コネクションの切断防止(60秒周期でパケット送信)
ServerAliveInterval 60
Host *-group2
# ユーザー名
User myuser2
# 接続用の鍵ファイルパス
IdentityFile ~/.ssh/id_rsa2
# コネクションの切断防止(60秒周期でパケット送信)
ServerAliveInterval 60
Host mcn1*
# ホスト名
Hostname 192.168.0.1
Host mcn2*
# ホスト名
Hostname 192.168.0.2
Host mcn1-group1, mcn1-group2, mcn2-group1, mcn2-group2
|
sshクライアントからは以下のコマンドで接続します。
1
2
3
4
|
PS C:\> ssh mcn1-group1
PS C:\> ssh mcn1-group2
PS C:\> ssh mcn2-group1
PS C:\> ssh mcn2-group2
|
まとめ
いかがでしたでしょうか。ssh接続でのconfigファイルの使い方を紹介しました。configファイルを作成することで、sshコマンドをシンプルに記述できます。
ここで紹介したconfigファイルのオプション以外にも様々なオプションがありますので、調べてみてください。ぜひご自身でコマンドを書いて、理解を深めてください。
ネプラス株式会社はサービス開始から10年以上
『エンジニアの生涯価値の向上』をミッションに掲げ、
多くのインフラエンジニア・ネットワークエンジニアの就業を支援してきました。
ネプラス株式会社はこんな会社です
秋葉原オフィスにはネプラス株式会社をはじめグループのIT企業が集結!
数多くのエンジニアが集まります。

-
インフラ業界に特化
ネットワーク・サーバー・データベース等、ITインフラ業界に特化。Cisco Systemsプレミアパートナーをはじめ各種ベンダーのパートナー企業です。
業界を知り尽くしているからこそ大手の取引先企業、経験豊富なエンジニアに選ばれています。
-
正社員なのにフリーランスのような働き方
正社員の方でも希望を聞いたうえでプロジェクトをアサインさせていただいており、フリーランスのような働き方が可能。帰社日もありません。
プロジェクト終了後もすぐに次の案件をご紹介させていただきますのでご安心ください。
-
大手直取引の高額案件
案件のほとんどが大手SIerやエンドユーザーからの直取引のためエンジニアの皆様へに高く還元できています。
Ciscoをはじめ、Juniper、Azure、Linux、AWS等インフラに特化した常時300件以上の案件があります。
-
スキルアップ支援
不要なコストを削減し、その分エンジニアの方へのスキルアップ支援(ネットワーク機器貸出、合格時の受験費用支給など)や給与で還元しています。
受験費用例)CCNP,CCIE:6-20万円、JNCIS:3-4万円、AWS:1-3万円など
※業務に関連する一定の資格のみ。各種条件がありますので詳しくは担当者へにお尋ねください。
-
現給与を保証します!※
前職の給与保証しており、昨年度は100%の方が給与アップを実現。収入面の不安がある方でも安心して入社していただけます。
※適用にはインフラエンジニアの業務経験1年以上、等一定の条件がございます。
-
インセンティブ制度
ネットワーク機器の販売・レンタル事業等、売上に貢献いただいた方にはインセンティブをお支払いしています。
取引先企業とエンジニア側、双方にメリットがあり大変好評をいただいています。
-
社会保険・福利厚生
社員の方は、社会保険を完備。健康保険は業界内で最も評価の高い「関東ITソフトウェア健康保険組合」です。
さらに様々なサービスをお得に利用できるベネフィットステーションにも加入いただきます。
-
東証プライム上場企業グループ
ネプラスは東証プライム上場「株式会社オープンアップグループ」のグループ企業です。
安定した経営基盤とグループ間のスムーズな連携でコロナ禍でも安定した雇用を実現させています。
ネプラス株式会社に興味を持った方へ
ネプラス株式会社では、インフラエンジニアを募集しています。
年収をアップしたい!スキルアップしたい!大手の上流案件にチャレンジしたい!
オンライン面接も随時受付中。ぜひお気軽にご応募ください。

