SSHを使用したSCPによるファイル転送の方法とは?SCPコマンドの使い方について紹介

SSHプロトコルを使用したSCPによるファイル転送の方法とは?
今回は、SCPによるファイル転送について説明します。SCPはSSHプロトコルを使用しているため、通信は暗号化されます。事前にSSH接続可能な状態にしておいてください。
ここでは、以下について紹介いたします。
・SCPの基本的な使い方
・ファイル名を変更した転送
・複数ファイルの転送
・ワイルドカード転送
・再帰的な転送
・ファイル情報を保持したまま転送
SSHプロトコルを使用した、SCPによるファイル転送に興味のある方は、ぜひご覧ください。
環境情報
ローカルをPowerShell、リモートをWSL2(Windows Subsystem for Linux 2)のubuntuとします。ローカルの情報は以下です。
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:\>
|
リモートの情報は以下です。
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接続可能な状態にしておいてください。
基本的な使い方
SCPコマンドの基本的な使い方を紹介します。以下のように記述します。
1
|
SCP [opution] 転送元 転送先
|
SSH接続可能な状態でなければ、SCPでファイル転送できません。
ローカルからリモートにファイル転送するには、以下のように記述します。
1
2
3
4
|
PS C:\> SCP C:\test\test.txt ${ホスト名}:~/
Enter passphrase for key 'C:\Users\${ユーザ名}/.ssh/id_rsa':
test.txt 100% 12 3.3KB/s 00:00
PS C:\>
|
逆にリモートからローカルにファイル転送するには、以下のように記述します。
1
2
3
4
|
PS C:\> SCP ${ホスト名}:~/test.txt C:\test\
Enter passphrase for key 'C:\Users\${ユーザ名}/.ssh/id_rsa':
test.txt 100% 12 0.0KB/s 00:00
PS C:\>
|
ファイル名を変更した転送
転送時にファイル名を指定することで、ファイル名を変更した転送ができます。
1
2
3
4
|
PS C:\> SCP C:\test\test.txt ${ホスト名}:~/test2.txt
Enter passphrase for key 'C:\Users\${ユーザ名}/.ssh/id_rsa':
test2.txt 100% 12 0.0KB/s 00:00
PS C:\>
|
複数ファイルの転送
複数ファイルをスペース区切りで指定して、転送することができます。
1
2
3
4
5
6
|
PS C:\> SCP C:\test\test1.txt C:\test\test2.txt C:\test\test3.txt ${ホスト名}:~/
Enter passphrase for key 'C:\Users\${ユーザ名}/.ssh/id_rsa':
test1.txt 100% 12 2.3KB/s 00:00
test2.txt 100% 12 0.6KB/s 00:00
test3.txt 100% 12 0.5KB/s 00:00
PS C:\>
|
ワイルドカード転送
ワイルドカード指定で転送することができます。
1
2
3
4
5
6
7
8
|
PS C:\> SCP C:\test\test*.txt ${ホスト名}:~/
Enter passphrase for key 'C:\Users\${ユーザ名}/.ssh/id_rsa':
test1.txt 100% 12 0.8KB/s 00:00
test2.txt 100% 12 0.8KB/s 00:00
test3.txt 100% 12 0.0KB/s 00:00
test4.txt 100% 12 0.0KB/s 00:00
test5.txt 100% 12 0.8KB/s 00:00
PS C:\>
|
再帰的な転送
rオプションを付与することで、再帰的に転送できます。
1
2
3
4
5
6
7
8
|
PS C:\> SCP -r C:\test ${ホスト名}:~/
Enter passphrase for key 'C:\Users\${ユーザ名}/.ssh/id_rsa':
test1.txt 100% 12 0.8KB/s 00:00
test2.txt 100% 12 0.0KB/s 00:00
test3.txt 100% 12 0.0KB/s 00:00
test4.txt 100% 12 0.0KB/s 00:00
test5.txt 100% 12 0.0KB/s 00:00
PS C:\>
|
リモート側では、ディレクトリごと転送されていることが確認できます。
1
2
3
4
5
6
7
8
|
remote:~$ find test/
test/
test/test1.txt
test/test2.txt
test/test3.txt
test/test4.txt
test/test5.txt
remote:~$
|
ファイル情報を保持したまま転送
pオプションを付与することで、タイムスタンプなどのファイル情報を保持したまま転送できます。
1
2
3
4
5
6
7
8
|
PS C:\> SCP -rp C:\test ${ホスト名}:~/
Enter passphrase for key 'C:\Users\${ユーザ名}/.ssh/id_rsa':
test1.txt 100% 12 0.0KB/s 00:00
test2.txt 100% 12 0.0KB/s 00:00
test3.txt 100% 12 0.8KB/s 00:00
test4.txt 100% 12 0.0KB/s 00:00
test5.txt 100% 12 0.0KB/s 00:00
PS C:\>
|
ローカル側のファイル情報を確認します。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
|
PS C:\> ls C:\test
ディレクトリ: C:\test
Mode LastWriteTime Length Name
---- ------------- ------ ----
-a---- 2020/12/31 17:03 12 test1.txt
-a---- 2020/12/31 17:03 12 test2.txt
-a---- 2020/12/31 17:03 12 test3.txt
-a---- 2020/12/31 17:03 12 test4.txt
-a---- 2020/12/31 17:03 12 test5.txt
PS C:\>
|
リモート側のファイル情報を確認します。タイムスタンプが保持されたまま転送されていることが分かります。
1
2
3
4
5
6
7
8
9
10
|
remote:~$ ls -la test/
total 28
drwxrwxrwx 2 ${ユーザ名} ${ユーザ名} 4096 Dec 31 17:11 .
drwxr-xr-x 6 ${ユーザ名} ${ユーザ名} 4096 Dec 31 17:15 ..
-rw-rw-rw- 1 ${ユーザ名} ${ユーザ名} 12 Dec 31 17:03 test1.txt
-rw-rw-rw- 1 ${ユーザ名} ${ユーザ名} 12 Dec 31 17:03 test2.txt
-rw-rw-rw- 1 ${ユーザ名} ${ユーザ名} 12 Dec 31 17:03 test3.txt
-rw-rw-rw- 1 ${ユーザ名} ${ユーザ名} 12 Dec 31 17:03 test4.txt
-rw-rw-rw- 1 ${ユーザ名} ${ユーザ名} 12 Dec 31 17:03 test5.txt
remote:~$
|
まとめ
いかがでしたでしょうか。SSHプロトコルを使用したSCPでのファイル転送について紹介しました。ここで紹介した以外にもSCPのオプションはありますので、調べてみてください。
SSHとSCPはセットで使い方をマスターしておくとよいでしょう。ぜひご自身でコマンドを書いて、理解を深めてください。
ネプラス株式会社はサービス開始から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ソフトウェア健康保険組合」です。
さらに様々なサービスをお得に利用できるベネフィットステーションにも加入いただきます。
-
東証プライム上場企業グループ
ネプラスは東証プライム上場「株式会社オープンアップグループ」のグループ企業です。
安定した経営基盤とグループ間のスムーズな連携でコロナ禍でも安定した雇用を実現させています。
ネプラス株式会社に興味を持った方へ
ネプラス株式会社では、インフラエンジニアを募集しています。
年収をアップしたい!スキルアップしたい!大手の上流案件にチャレンジしたい!
オンライン面接も随時受付中。ぜひお気軽にご応募ください。

