sftpコマンド入門|安全なファイル送受信の具体的な手順
はじめに:なぜSFTPを選ぶのか? ファイル転送の安全性について
インターネットを介してファイルをやり取りすることは、現代のデジタルワークフローにおいて不可欠な要素です。ウェブサイトの更新、データ共有、バックアップの実施など、さまざまな場面でファイル転送プロトコルが利用されています。しかし、ファイル転送はセキュリティ上のリスクと常に隣り合わせです。機密性の高い情報が盗聴されたり、改ざんされたりする危険性があります。
ファイル転送に使われるプロトコルとして、最も古くから利用されているのがFTP(File Transfer Protocol)です。FTPはシンプルで使いやすいという利点がありますが、致命的な欠点があります。それは、認証情報(ユーザー名とパスワード)や転送されるファイルデータがすべて平文でやり取りされるという点です。もし悪意のある第三者がネットワーク上の通信を傍受した場合、簡単に認証情報を盗み出し、サーバーに不正アクセスしたり、転送中のデータを盗み見たり改ざんしたりすることができてしまいます。このため、現代においてインターネット経由でFTPをそのまま使用することは、非常に危険であると認識されています。
FTPのセキュリティ問題を解決するために開発されたのが、FTPS(FTP over SSL/TLS)とSFTP(SSH File Transfer Protocol)です。
- FTPS は、FTPの仕組みはそのままに、SSL/TLSという暗号化技術で通信を保護するプロトコルです。これにより、認証情報やデータは暗号化され、傍受されても内容を解読されるリスクが低減されます。FTPSには、制御コネクションのみを暗号化するImplicit SSLと、制御・データコネクションの確立後に明示的に暗号化を開始するExplicit SSLのモードがあります。しかし、FTPの特性上、制御用とは別にデータ転送用のポートが必要になる場合が多く、ファイアウォール設定が複雑になりがちです。
- SFTP は、FTPとは全く異なるプロトコルであり、SSH(Secure Shell)上で動作します。SSHは、もともとリモートで安全にコマンドを実行するために開発されたプロトコルであり、通信内容は強力に暗号化されます。SFTPはこのSSHのセキュアなトンネルを利用してファイル転送を行います。SFTPの最大の特徴は、認証情報もファイルデータも、SSHによってすべて暗号化されて転送される点です。また、データ転送用の特別なポートを開ける必要がなく、SSHが使用する標準ポート(デフォルトは22番ポート)のみを利用するため、ファイアウォール設定も比較的容易です。
これらの比較から、特にセキュリティが重視される場面において、SFTPが非常に優れた選択肢であることがわかります。FTPのような平文での通信は避け、FTPSやSFTPのような暗号化されたプロトコルを利用するべきです。そして、SSHの仕組みを利用するSFTPは、多くのLinux/UnixサーバーでSSHが標準で利用可能であること、単一ポートで済むことなどから、手軽かつ安全なファイル転送手段として広く普及しています。
本記事では、このSFTPをコマンドラインから利用するための方法について、初心者の方にも分かりやすく、具体的な手順を交えて詳しく解説します。SFTPコマンドの基本的な使い方から、安全性をさらに高めるための設定、そして日々の運用で役立つ自動化の方法まで、SFTPをマスターするためのステップを順に追っていきましょう。
第1章: SFTPとは何か? なぜ安全なのか?
この章では、SFTPプロトコルの基本的な仕組みと、なぜSFTPが安全なファイル転送手段として推奨されるのかを掘り下げて説明します。
1.1 SFTPの定義と位置づけ
SFTPは「SSH File Transfer Protocol」の略称です。その名の通り、SFTPはSSH(Secure Shell)プロトコル上で動作するファイル転送プロトコルです。SFTPはFTPを置き換えることを目的に開発されましたが、FTPとは互換性がありません。SFTPはSSHプロトコルの一部として機能し、SSHセッション内でファイル操作に関するコマンドやデータを受け渡します。
SFTPは、TCP/IPネットワーク上でクライアントとサーバー間でファイルを安全に転送するために設計されています。SFTPはファイル操作(ファイルやディレクトリのリスト表示、作成、削除、名前変更、パーミッション変更など)のための豊富な機能を提供します。
1.2 SFTP、FTP、FTPSの技術的な違い
先ほど概要で触れましたが、ここでより技術的な観点から3つのプロトコルの違いを比較してみましょう。
特徴 | FTP (File Transfer Protocol) | FTPS (FTP over SSL/TLS) | SFTP (SSH File Transfer Protocol) |
---|---|---|---|
基盤となるプロトコル | 独自のプロトコル(TCP/IP) | FTP + SSL/TLS | SSH (Secure Shell) |
ポート | 制御: 21, データ: 20またはランダムポート | 制御: 21またはランダムポート, データ: 990またはランダムポート | SSH: 22 (デフォルト) |
暗号化 | なし(認証情報・データともに平文) | あり(SSL/TLSによる暗号化) | あり(SSHによる暗号化) |
認証 | ユーザー名/パスワード (平文) | ユーザー名/パスワード (+証明書による認証も可能) | ユーザー名/パスワード または 公開鍵認証 |
ファイアウォール | データポートがランダムになる場合があり、設定が複雑になりやすい | FTPと同様、データポートが問題になることがある | SSHポート(通常22)のみで済むため容易 |
プロトコルの種類 | ファイル転送専用プロトコル | ファイル転送プロトコル(暗号化拡張) | SSHサブシステム(ファイル転送機能) |
コマンド | ASCIIベースのFTPコマンド (USER , PASS , GET , PUT など) |
FTPコマンド (AUTH TLS , PROT P など暗号化関連コマンドが追加) |
バイナリベースのSFTPプロトコルパケット |
最も重要な違いは「暗号化」の有無と「基盤となるプロトコル」です。SFTPはSSHのセキュアな通信路をそのまま利用するため、認証情報からファイルデータ、さらにはファイル操作に関するコマンドそのものまで、すべてがSSHによって強力に暗号化されます。これにより、中間者攻撃や盗聴に対して非常に高い耐性を持っています。
FTPSも暗号化を提供しますが、FTPプロトコルの上にSSL/TLSを被せているため、FTPの根本的な問題点(複数のポートを使用する可能性があることなど)を引き継いでしまう場合があります。また、SSL/TLSの証明書管理が必要になります。
一方、SFTPはFTPの仕組みとは無関係であり、SSHが確立されればその後の通信はすべてSSHの保護下に置かれます。これは設計上の大きな優位点であり、シンプルさと安全性を両立させています。
1.3 SFTPがSSH上で動作する仕組み
SFTPはSSHプロトコルの「サブシステム」として動作します。クライアントがSSHサーバーに接続し、認証が成功した後、クライアントはサーバーに対して「SFTPサブシステムを開始してほしい」という要求を送信します。サーバーがその要求を受け入れると、SSHセッション内にSFTPプロトコルを処理するための専用のチャンネルが開設されます。
このチャンネルを通じて、クライアントとサーバーはSFTPプロトコルに沿ったパケットを交換します。例えば、クライアントがファイル一覧を取得するコマンドを送信すると、そのコマンドはSSHによって暗号化されてサーバーに送られます。サーバーは暗号化されたコマンドを受け取り、復号化して処理し、結果(ファイル一覧データ)を再びSSHで暗号化してクライアントに返します。ファイル転送も同様で、ファイルデータは小さなパケットに分割され、それぞれがSSHで暗号化されて送受信されます。
この仕組みにより、SFTPクライアントとSFTPサーバー間の通信は、常にSSHのセキュリティによって保護されます。通信経路上でデータを傍受されても、内容を解読することは極めて困難です。
1.4 SFTPを使うメリット・デメリット
メリット:
- 高い安全性: SSHによる強力な暗号化により、認証情報やファイルデータが保護される。中間者攻撃や盗聴のリスクを大幅に低減できる。
- 単一ポート: SSHが使用するポート(デフォルト22)のみで制御とデータ転送の両方を行うため、ファイアウォール設定が容易。
- SSH環境で利用可能: 多くのLinux/Unixサーバーに標準でSSHサーバーが搭載されており、追加のデーモンやサービスの設定が不要な場合が多い。
- 豊富なファイル操作機能: ファイルのアップロード/ダウンロードだけでなく、リモートでのファイル削除、名前変更、パーミッション/所有者変更、シンボリックリンク作成などが可能。
- 公開鍵認証によるセキュリティ強化: パスワード認証に加えて、より安全な公開鍵認証を利用できる。
デメリット:
- SSHサーバーが必要: SFTPを利用するには、接続先サーバーでSSHサーバーが稼働している必要がある。
- オーバーヘッド: SSHの暗号化/復号化処理のため、FTPと比較するとわずかに転送速度が低下する可能性がある(ただし、通常の使用では体感できるほどではないことが多い)。
- FTPとの非互換性: SFTPはFTPプロトコルとは全く異なるため、既存のFTPクライアントやサーバーをそのまま利用することはできない。
これらの点を踏まえると、SFTPは特にサーバー間のデータ連携や、リモートサーバーへの安全なファイルアップロード/ダウンロードにおいて、非常に優れた選択肢と言えます。
第2章: SFTPを始める前の準備
SFTPコマンドを使って安全なファイル転送を始める前に、いくつか準備しておきたいことがあります。クライアント側とサーバー側の環境について確認しましょう。
2.1 クライアント側の環境
SFTPコマンドは、OpenSSHというソフトウェアスイートに含まれるプログラムの一つです。OpenSSHは多くのLinuxディストリビューションやmacOSに標準で搭載されています。
- Linux / macOS: ほとんどの場合、ターミナルを開いて
sftp
コマンドを実行すれば利用できます。もしコマンドが見つからない場合は、openssh-client
のようなパッケージ名で検索し、インストールしてください(例: Debian/Ubuntuならsudo apt update && sudo apt install openssh-client
、Fedora/CentOS/RHELならsudo yum install openssh-clients
)。 - Windows: 以前のWindowsでは標準搭載されていませんでしたが、Windows 10/11以降のバージョンではOpenSSHクライアントがオプション機能として利用可能です。
- 確認方法: コマンドプロンプトまたはPowerShellで
sftp
コマンドを実行してみてください。 - 有効化/インストール: もしコマンドが見つからない場合、設定アプリの「アプリ」->「オプション機能」->「機能を追加する」から「OpenSSH クライアント」を検索してインストールできます。
- WSL (Windows Subsystem for Linux): WSLをインストールしている場合は、WSL環境内でLinux版の
sftp
コマンドを利用できます。これが最も手軽かもしれません。 - サードパーティ製クライアント: PuTTYやWinSCPなどのGUIクライアントも広く使われています。これらはSFTPをサポートしていますが、本記事ではコマンドラインの
sftp
を対象とします。
- 確認方法: コマンドプロンプトまたはPowerShellで
必要なのは、sftp
コマンドが実行できる環境です。
2.2 サーバー側の環境
接続先のサーバー側には、SFTPサービスを提供するSSHサーバーが必要です。
- SSHサーバーの稼働: サーバー側で
sshd
(SSHデーモン) が稼働している必要があります。ほとんどのLinux/Unixサーバーではデフォルトでインストールされ、起動しています。 - SFTPサブシステムの有効化:
sshd
の設定ファイル (/etc/ssh/sshd_config
など) で、SFTPサブシステムが有効になっている必要があります。通常はデフォルトで有効になっています。Subsystem sftp /usr/lib/openssh/sftp-server
のような設定行があれば有効です。 - 接続ユーザーの準備: SFTPで接続するためのユーザーアカウントがサーバーに存在している必要があります。
- ファイアウォール設定: サーバー側のファイアウォールで、SSHポート(デフォルト22番)への接続が許可されている必要があります。
2.3 接続に必要な情報
SFTP接続を確立するために、以下の情報が必要です。
- ホスト名またはIPアドレス: 接続先サーバーのネットワーク上の名前またはアドレス。
- ユーザー名: 接続先サーバーに存在するアカウントのユーザー名。
- 認証情報:
- パスワード: ユーザーアカウントのパスワード。
- または 秘密鍵: 公開鍵認証を使用する場合の秘密鍵ファイル。
これらの準備が整ったら、いよいよSFTPコマンドを使って接続してみましょう。
第3章: SFTP接続の基本手順
SFTPコマンドを使った接続は、主に「インタラクティブモード」と「非インタラクティブモード(バッチモード)」の2つの方法があります。まずは対話形式で操作を行うインタラクティブモードについて説明します。
3.1 コマンドの基本形
SFTPコマンドの基本的な書式は以下の通りです。
bash
sftp [オプション] [ユーザー名@]ホスト名[:パス]
オプション
: SFTPコマンドの動作を制御する様々なオプションを指定します。よく使うオプションについては後述します。ユーザー名@
: 接続先のユーザー名を指定します。省略した場合、ローカル環境の現在のユーザー名が使われます。ホスト名
: 接続先サーバーのホスト名またはIPアドレスを指定します。:パス
: 接続成功後、最初に移動したいリモートディレクトリのパスを指定できます。省略した場合は、接続ユーザーのホームディレクトリが初期ディレクトリとなります。
3.2 インタラクティブモードでの接続
最も一般的なSFTPの利用方法です。コマンドを実行すると、SFTPサーバーに接続し、接続が成功すると sftp>
というプロンプトが表示され、対話形式で様々なSFTPコマンドを実行できるようになります。
例1: パスワード認証での接続
bash
sftp username@hostname_or_ip
例: sftp [email protected]
または sftp [email protected]
コマンドを実行すると、パスワードの入力を求められます。
[email protected]'s password:
正しいパスワードを入力してEnterを押すと、接続が確立され、sftp>
プロンプトが表示されます。
sftp>
これでSFTPセッションが始まりました。
例2: ポート番号を指定して接続
SSHサーバーが標準の22番ポート以外で稼働している場合、-P
オプションでポート番号を指定します(-p
はSSHプロトコルバージョン指定に使われるため、ポート指定は-P
が大文字であることに注意)。
bash
sftp -P 2222 username@hostname_or_ip
例: sftp -P 2222 [email protected]
パスワードまたは秘密鍵による認証後、接続が確立されます。
例3: 接続時に初期ディレクトリを指定
接続成功後、特定のディレクトリに移動したい場合は、ホスト名の後ろにコロン :
とパスを指定します。
bash
sftp username@hostname_or_ip:/path/to/remote/directory
例: sftp [email protected]:/var/www/html
この場合、接続成功時にリモートの /var/www/html
ディレクトリが現在のディレクトリとなります。
例4: 公開鍵認証での接続
SFTPはSSH上で動作するため、パスワード認証だけでなく、より安全な公開鍵認証を利用できます。デフォルトの秘密鍵ファイル(通常 ~/.ssh/id_rsa
や ~/.ssh/id_ed25519
など)を使用する場合、特別なオプションは不要です。
bash
sftp username@hostname_or_ip
SSHエージェントに秘密鍵が登録されているか、秘密鍵ファイルが適切な場所に置かれていれば、パスワード入力なしで接続できる場合があります。パスフレーズが設定されている場合は、パスフレーズの入力が求められます。
デフォルト以外の秘密鍵ファイルを使用する場合は、-i
オプションで秘密鍵ファイルを指定します。
bash
sftp -i /path/to/your/private/key username@hostname_or_ip
例: sftp -i ~/.ssh/my_example_key [email protected]
この場合も、パスフレーズが設定されていれば入力を求められます。公開鍵認証の詳細と設定方法については、後述のセキュリティ強化の章で詳しく解説します。
3.3 接続エラー時のトラブルシューティング
SFTP接続がうまくいかない場合、いくつかの原因が考えられます。
- “Connection refused” または接続タイムアウト:
- サーバーのIPアドレスまたはホスト名が間違っている。
- サーバーでSSHデーモン (
sshd
) が起動していない。 - サーバー側のファイアウォールがSSHポート(デフォルト22番)をブロックしている。
- クライアント側のネットワーク環境(ローカルファイアウォール、ルーター設定など)が接続を妨げている。
- 指定したポート番号 (
-P
オプション) が間違っている。
- “Permission denied” またはパスワード/鍵認証の失敗:
- ユーザー名が間違っている。
- パスワードが間違っている。
- 公開鍵認証を使用している場合、クライアント側の秘密鍵がサーバー側の
authorized_keys
に対応する公開鍵が登録されていない、または登録に問題がある。 - 秘密鍵ファイルのパスが間違っている、またはパーミッションが不正(SSHでは秘密鍵ファイルのパーミッションが厳しい)。
- サーバー側でそのユーザーのSSH/SFTPログインが制限されている(例:
DenyUsers
,AllowUsers
, シェルが無効になっているなど)。 - SELinuxなどのセキュリティ機構がSFTPアクセスを制限している。
- “Subsystem ‘sftp’ for ssh2 not found”:
- サーバー側のSSH設定ファイル (
sshd_config
) でSFTPサブシステムが正しく設定されていない、または無効になっている。 sftp-server
プログラムのパスが間違っている、または実行パーミッションがない。
- サーバー側のSSH設定ファイル (
エラーメッセージをよく確認し、一つずつ原因を潰していくことが重要です。サーバー側の /var/log/auth.log
(またはシステムのログファイル) にSSH接続試行に関するログが出力されていることが多いので、サーバー管理者にログを確認してもらうことも有効です。
接続が確立され sftp>
プロンプトが表示されれば、ファイル転送や操作の準備は完了です。次の章では、SFTPセッション中に使える様々なコマンドについて解説します。
第4章: SFTPの主要コマンド(インタラクティブモード)
SFTPセッションに入ると、sftp>
プロンプトが表示され、様々なコマンドを実行してリモートサーバー上のファイルやディレクトリを操作できます。これらのコマンドは、FTPコマンドと似ているものも多いですが、SFTP独自の機能や使い方も存在します。
この章では、SFTPインタラクティブモードでよく使う主要なコマンドをカテゴリ別に紹介します。
4.1 ヘルプコマンド
SFTPセッション中に使えるコマンドを知りたい場合は、以下のコマンドを実行します。
help
?
どちらも同じ機能で、利用可能なSFTPコマンドとその簡単な説明が表示されます。
sftp> help
Available commands:
cd path Change remote directory to path
lcd path Change local directory to path
[...] (以下省略)
4.2 ローカルディレクトリ操作
これらのコマンドは、SFTPクライアントが動作しているローカルマシン上のディレクトリを操作します。
lpwd
: Local Print Working Directory の略。ローカルの現在のディレクトリのフルパスを表示します。
sftp> lpwd
Local working directory: /home/user/documentslcd [ディレクトリ]
: Local Change Directory の略。ローカルの現在のディレクトリを指定したディレクトリに移動します。引数を省略した場合、ローカルユーザーのホームディレクトリに移動します。
sftp> lcd /tmp
sftp> lpwd
Local working directory: /tmp
4.3 リモートディレクトリ操作
これらのコマンドは、SFTP接続先のサーバー上のディレクトリを操作します。
pwd
: Print Working Directory の略。リモートの現在のディレクトリのフルパスを表示します。
sftp> pwd
Remote working directory: /home/remoteusercd [ディレクトリ]
: Change Directory の略。リモートの現在のディレクトリを指定したディレクトリに移動します。引数を省略した場合、リモートユーザーのホームディレクトリに移動します。
sftp> cd /var/www/html
sftp> pwd
Remote working directory: /var/www/html
存在しないディレクトリや、アクセス権がないディレクトリを指定するとエラーになります。ls [オプション] [パス]
: List files の略。リモートのファイルやディレクトリの一覧を表示します。ls
コマンドは、SSH経由でリモートで実行されるのではなく、SFTPプロトコルで「指定パスの内容をリストせよ」という要求をサーバーに送ることで実現されます。- オプションなし: 現在のリモートディレクトリのファイル/ディレクトリ名を表示。
sftp> ls
file1.txt documents/ image.jpg public_html/ -l
オプション: 詳細なリスト表示(ファイルタイプ、パーミッション、リンク数、所有者、グループ、サイズ、更新日時、ファイル名)。これはUnix/Linuxのls -l
コマンドの出力に似ています。ll
というエイリアスもよく使われます。
sftp> ls -l
-rw-r--r-- 1 remoteuser remoteuser 1024 Jan 15 10:00 file1.txt
drwxr-xr-x 2 remoteuser remoteuser 4096 Jan 14 09:30 documents
-rw-rw-r-- 1 remoteuser remoteuser 153600 Jan 15 11:20 image.jpg
drwxr-xr-x 3 remoteuser remoteuser 4096 Jan 10 14:00 public_html-a
オプション: ドットファイル(.
で始まる隠しファイル)も表示。-t
オプション: 更新日時でソート。- これらのオプションは組み合わせて使用できます(例:
ls -la
)。 - 特定のパスを指定してリスト表示することも可能です。
sftp> ls /var/log
syslog auth.log kern.log ...
- オプションなし: 現在のリモートディレクトリのファイル/ディレクトリ名を表示。
mkdir [ディレクトリ]
: Make Directory の略。リモートに新しいディレクトリを作成します。
sftp> mkdir new_folder
sftp> ls
... new_folder/ ...rmdir [ディレクトリ]
: Remove Directory の略。リモートの空のディレクトリを削除します。空でないディレクトリは削除できません。
sftp> rmdir empty_folder
rm [ファイル]
: Remove file の略。リモートのファイルを削除します。
sftp> rm outdated_file.txt
4.4 ファイル転送
SFTPの最も重要な機能です。ファイルをローカルとリモート間で安全に転送します。
put [ローカルファイル] [リモートパス]
: ローカルからリモートへファイルをアップロードします。- 単一ファイルのアップロード:
sftp> put my_local_file.txt
Uploading my_local_file.txt to /home/remoteuser/my_local_file.txt
my_local_file.txt 100% 512KB 5.1MB/s 00:00
ローカルファイル名と同じ名前で、リモートの現在のディレクトリにアップロードされます。 - 別名でアップロード、または特定のディレクトリにアップロード: リモートパスにファイル名やディレクトリを指定します。
sftp> put report.pdf /home/remoteuser/documents/final_report.pdf
Uploading report.pdf to /home/remoteuser/documents/final_report.pdf
report.pdf 100% 1MB 10.0MB/s 00:00
指定したリモートディレクトリが存在しない場合や、書き込み権限がない場合はエラーになります。
- 単一ファイルのアップロード:
get [リモートファイル] [ローカルパス]
: リモートからローカルへファイルをダウンロードします。- 単一ファイルのダウンロード:
sftp> get remote_log.txt
Fetching /home/remoteuser/remote_log.txt to remote_log.txt
remote_log.txt 100% 20KB 2.0MB/s 00:00
リモートファイル名と同じ名前で、ローカルの現在のディレクトリにダウンロードされます。 - 別名でダウンロード、または特定のディレクトリにダウンロード: ローカルパスにファイル名やディレクトリを指定します。
sftp> get /var/www/html/index.html /tmp/downloaded_index.html
Fetching /var/www/html/index.html to /tmp/downloaded_index.html
index.html 100% 5KB 0.5MB/s 00:00
指定したローカルディレクトリが存在しない場合や、書き込み権限がない場合はエラーになります。
- 単一ファイルのダウンロード:
mput [ローカルファイル...]
: Multiple PUT の略。複数のファイルをローカルからリモートへ一括でアップロードします。ワイルドカード(*
,?
など)を使用できます。
sftp> mput *.jpg
sftp> mput report_*.csv
ワイルドカードにマッチしたファイルごとに確認を求められるのがデフォルトの動作です。これをスキップするには、-y
オプションを付けます(例:mput -y *.txt
)。mget [リモートファイル...]
: Multiple GET の略。複数のファイルをリモートからローカルへ一括でダウンロードします。ワイルドカードを使用できます。
sftp> mget logs_*.log
sftp> mget data_?/archive
mput
と同様に、-y
オプションで確認をスキップできます。put -r [ローカルディレクトリ] [リモートパス]
: ディレクトリとその内容を再帰的にアップロードします。
sftp> put -r my_local_project /home/remoteuser/projects/
ローカルのmy_local_project
ディレクトリが、リモートの/home/remoteuser/projects/
以下にコピーされます。get -r [リモートディレクトリ] [ローカルパス]
: ディレクトリとその内容を再帰的にダウンロードします。
sftp> get -r /var/www/html/backup /home/user/downloads/website_backup
リモートの/var/www/html/backup
ディレクトリが、ローカルの/home/user/downloads/website_backup
以下にコピーされます。
ファイル転送時には、転送速度や進捗状況が表示されるため、大きなファイルの転送でも状況を確認できます。
4.5 ファイル管理コマンド
リモートサーバー上のファイルの属性を変更するコマンドです。
rename [古い名前] [新しい名前]
: リモートのファイルやディレクトリの名前を変更します。
sftp> rename old_file.txt new_file.txt
sftp> rename temp_folder final_folderchmod [パーミッション] [ファイル]
: リモートのファイルのパーミッション(アクセス権)を変更します。パーミッションは、数値形式(例:755
)または記号形式(例:u+rwx,go=rx
)で指定できます。
sftp> chmod 644 public_file.txt
sftp> chmod u+x,g+x script.sh
ディレクトリに対しても使用できます(例:chmod 755 my_directory
)。chown [所有者] [ファイル]
: リモートのファイルの所有者(ユーザー)を変更します。所有者はユーザーID(UID)またはユーザー名で指定できます。
sftp> chown 1001 data_file.dat # UIDで指定
sftp> chown webuser index.html # ユーザー名で指定
このコマンドを実行するには、通常、リモートサーバー上で適切な権限(root権限など)が必要です。一般ユーザーは自分の所有するファイルの所有者を変更できない場合が多いです。chgrp [グループ] [ファイル]
: リモートのファイルのグループを変更します。グループはグループID(GID)またはグループ名で指定できます。
sftp> chgrp 100 data_file.dat # GIDで指定
sftp> chgrp www-data index.html # グループ名で指定
このコマンドも、通常は適切な権限が必要です。一般ユーザーは自分が所属するグループにのみグループを変更できる場合があります。symlink [ターゲット] [リンク名]
: リモートにシンボリックリンクを作成します。
sftp> symlink /var/log/syslog /home/remoteuser/mylog
これにより、リモートの/home/remoteuser/mylog
が/var/log/syslog
へのシンボリックリンクとなります。
4.6 その他のコマンド
version
: SFTPプロトコルのバージョンを表示します。
sftp> version
SFTP protocol version 3! [コマンド]
: SFTPセッションを終了せずに、ローカルマシンのシェルコマンドを実行します。
sftp> ! ls -l /tmp
-rw-r--r-- 1 user user 1024 Jan 16 10:00 local_temp_file.txt
sftp>
コマンドを指定しない!
のみの場合、新しいローカルシェルセッションが開始されます。SFTPに戻るにはexit
と入力します。
sftp> !
$ pwd
/home/user/documents
$ exit
sftp>bye
またはquit
: SFTPセッションを終了し、ローカルシェルのプロンプトに戻ります。
sftp> bye
これらのコマンドを組み合わせることで、SFTPインタラクティブモードで安全かつ柔軟なファイル操作を行うことができます。
第5章: 安全性をさらに高める設定と実践
SFTPはSSH上で動作するため、デフォルトである程度の安全性は確保されています。しかし、SSH自体の設定やユーザー管理を適切に行うことで、さらにセキュリティを強化することができます。この章では、特に重要な公開鍵認証とSFTP専用ユーザーの設定について詳しく解説します。
5.1 公開鍵認証
SFTP(そしてSSH全般)において、パスワード認証よりもはるかに安全とされるのが公開鍵認証です。パスワード認証は、パスワードが漏洩したり、ブルートフォース攻撃(総当たり攻撃)によって解読されたりするリスクがあります。一方、公開鍵認証は、数学的に関連付けられた公開鍵と秘密鍵のペアを使用するため、これらのリスクを大幅に軽減できます。
公開鍵認証の仕組み:
- クライアント側で、公開鍵と秘密鍵のペアを生成します。
- 生成された公開鍵を、接続先のサーバーのユーザーアカウントの特定の場所(通常
~/.ssh/authorized_keys
ファイル)に登録します。秘密鍵はクライアント側で厳重に保管します。 - クライアントがSSH/SFTP接続を試みると、サーバーはクライアントに対して「持っている秘密鍵に対応する公開鍵で、特定のデータを暗号化(または署名)して返してください」と要求します。
- クライアントは要求されたデータを秘密鍵で処理し、サーバーに返します。
- サーバーは、クライアントから受け取った公開鍵を使って、クライアントからのレスポンスが正当な秘密鍵から生成されたものであるかを確認します。
- 確認が成功すれば、クライアントは認証されたと見なされ、パスワード入力なしで接続が許可されます。
このプロセスにおいて、秘密鍵がネットワーク上を流れることはありません。また、公開鍵から秘密鍵を推測することは(現代の技術では)非常に困難です。
公開鍵認証の設定手順:
-
クライアント側での鍵ペア生成:
ターミナルを開き、ssh-keygen
コマンドを実行します。bash
ssh-keygen -t rsa -b 4096 -C "[email protected]"
*-t rsa
: RSA方式で鍵ペアを生成します(他の方式もありますが、RSAが一般的です)。-t ed25519
など、より新しい方式も推奨されています。
*-b 4096
: 鍵の長さを指定します。長いほど安全ですが、生成や認証に時間がかかります。デフォルトは2048ビットですが、4096ビットが推奨されることが多いです。
*-C "..."
: 鍵にコメントを追加します。通常はメールアドレスなどを入れますが、任意の文字列で構いません。コマンドを実行すると、鍵ファイルを保存する場所とファイル名を尋ねられます。デフォルト(通常
~/.ssh/id_rsa
)で問題なければそのままEnterを押し、任意のファイル名にしたい場合はパスを指定します。次に、パスフレーズの入力を求められます。
Enter passphrase (empty for no passphrase):
Enter same passphrase again:
パスフレーズは必ず設定することを強く推奨します。 パスフレーズは、秘密鍵を使用する際に必要となる追加のパスワードのようなものです。これにより、もし秘密鍵ファイルが盗まれても、パスフレーズを知らない限り悪用されるリスクを減らせます。パスフレーズを設定しない場合、秘密鍵ファイルだけで認証ができてしまうため、秘密鍵が漏洩した場合のリスクが高まります。
パスフレーズを入力すると、鍵ペア(id_rsa
とid_rsa.pub
のような名前)が指定した場所に生成されます。id_rsa
が秘密鍵、id_rsa.pub
が公開鍵です。 -
サーバー側への公開鍵の登録:
生成した公開鍵ファイル(例:id_rsa.pub
)の内容を、接続先サーバーのSFTP接続に使用するユーザーのホームディレクトリにある~/.ssh/authorized_keys
ファイルに追加します。最も簡単な方法は
ssh-copy-id
コマンドを使用することです。
bash
ssh-copy-id -i ~/.ssh/id_rsa.pub username@hostname_or_ip
*-i ~/.ssh/id_rsa.pub
: 使用する公開鍵ファイルを指定します。デフォルトの鍵を使う場合は省略できます。このコマンドは、一度だけパスワード認証や既存の鍵認証でサーバーに接続し、公開鍵ファイルの内容をサーバー側の
~/.ssh/authorized_keys
ファイルの末尾に自動的に追加してくれます。ssh-copy-id
コマンドが利用できない場合は、ローカルで公開鍵ファイルの内容をコピーし、リモートに接続(パスワード認証などで)した後、サーバー上でエディタを使って~/.ssh/authorized_keys
ファイルを開き、公開鍵の内容を貼り付けて保存する必要があります。authorized_keys
ファイルとその親ディレクトリ (~/.ssh
) のパーミッションが適切に設定されている必要があります。
*~/.ssh
:700
(所有者のみ読み書き実行可能)
*~/.ssh/authorized_keys
:600
(所有者のみ読み書き可能)
パーミッションが緩すぎると、SSHサーバーはセキュリティ上の理由からその鍵ファイルを無視します。 -
SFTP接続の確認:
公開鍵の登録後、SFTPコマンドで接続を試みます。
bash
sftp username@hostname_or_ip
パスフレーズを設定している場合は、パスフレーズの入力を求められます。パスフレーズを入力して接続できれば成功です。パスフレーズを設定していない場合は、パスワードもパスフレーズも聞かれずに接続できるはずです。
ssh-agent の利用:
パスフレーズ付きの秘密鍵を使う場合、接続のたびにパスフレーズを入力するのは面倒です。ssh-agent
は、秘密鍵とパスフレーズをメモリ上に保持し、必要なときにSSHクライアントに提供するプログラムです。これにより、一度 ssh-agent
に秘密鍵を登録すれば、そのエージェントが起動している間はパスフレーズの入力が不要になります。
ssh-agent
を起動します(多くのデスクトップ環境ではログイン時に自動起動されます)。
bash
eval "$(ssh-agent -s)"- 秘密鍵を
ssh-agent
に登録します。
bash
ssh-add ~/.ssh/id_rsa
パスフレーズの入力を求められるので、入力します。
これで、ssh-agent
が秘密鍵を保持している間は、SFTP接続時にパスフレーズを聞かれなくなります。ただし、ssh-agent
はシステムの再起動などで終了するため、必要に応じて再度起動・登録が必要です。
公開鍵認証は、パスワード認証に比べて格段に安全です。SFTPを利用する際は、可能な限り公開鍵認証を導入することを強く推奨します。さらにセキュリティを高めるためには、サーバー側でパスワード認証を無効化し、公開鍵認証のみを受け付けるように設定することも検討すべきです(これは /etc/ssh/sshd_config
で PasswordAuthentication no
を設定することで可能です)。
5.2 SFTP専用ユーザーの作成と制限
サーバー上のユーザーアカウントの中には、SFTPによるファイル転送のみを許可し、シェルログインや他のコマンド実行は許可したくない場合があります。例えば、ウェブサイトのファイルをアップロードするユーザーや、特定のデータを定期的に連携するためのユーザーなどです。このようなユーザーに対して、セキュリティリスクを最小限に抑えるための設定を行います。
SFTP専用ユーザーを作成する理由:
- 権限の最小化: SFTPによる特定のディレクトリへのアクセスのみを許可し、システム全体のファイルにアクセスできないようにする。
- シェルログインの禁止: ユーザーがサーバー上で意図しないコマンドを実行したり、システムを操作したりするのを防ぐ。
- セキュリティ侵害時の被害範囲限定: もしSFTPアカウントが不正アクセスされた場合でも、被害を特定のディレクトリ内に限定できる。
SFTP専用ユーザーの設定手順例:
以下の手順は一般的なLinuxサーバー (sshd_config
の設定が必要) を想定しています。設定変更にはサーバーのroot権限が必要です。
- SFTP専用の新しいグループを作成: SFTPユーザーを管理するためのグループを作成します。
bash
sudo groupadd sftpusers - SFTP専用ユーザーを作成: 新しいユーザーアカウントを作成し、作成したグループに所属させます。シェルのログインを禁止するために、シェルとして
/sbin/nologin
などを指定します。
bash
sudo useradd -m -g sftpusers -s /sbin/nologin sftpuser1
sudo passwd sftpuser1 # パスワードを設定(公開鍵認証のみにする場合でも、設定しておくのが無難)
-m
はホームディレクトリを作成するオプションです。-s /sbin/nologin
はこのユーザーがシェルログインできないように設定します。 - SFTPアクセスを許可するディレクトリを設定: ユーザーがアクセスできるルートディレクトリを設定します。このディレクトリは、rootユーザーまたは信頼できるユーザーが所有し、書き込み権限はrootのみである必要があります(非常に重要なセキュリティ要件)。
例えば、/sftpdata/sftpuser1
をこのユーザーのルートディレクトリとして設定する場合。
bash
sudo mkdir -p /sftpdata/sftpuser1
sudo chown root:root /sftpdata/sftpuser1 # ルートディレクトリはroot所有
sudo chmod 755 /sftpdata/sftpuser1 # 書き込み権限はrootのみ
ユーザーがファイルをアップロードできるように、このルートディレクトリの中に、ユーザーが書き込み可能なディレクトリを作成します。
bash
sudo mkdir /sftpdata/sftpuser1/upload
sudo chown sftpuser1:sftpusers /sftpdata/sftpuser1/upload # ユーザーが所有
sudo chmod 755 /sftpdata/sftpuser1/upload # ユーザーが書き込み可能
ユーザーはSFTP接続後、/upload
ディレクトリにファイルをアップロードできるようになります。 -
sshd_config
の設定変更: SSHサーバーの設定ファイル/etc/ssh/sshd_config
を編集し、SFTP専用ユーザーの設定を追加します。ファイルの末尾などに以下のブロックを追加します。
conf
Match Group sftpusers
ChrootDirectory /sftpdata/%u # ユーザーのルートディレクトリを指定。%uはユーザー名に置き換えられる。
ForceCommand internal-sftp # ユーザーが接続したらSFTPサブシステムのみを実行させる
AllowTcpForwarding no
X11Forwarding no
PermitTunnel noMatch Group sftpusers
:sftpusers
グループに所属するユーザーに対して以下の設定を適用します。ChrootDirectory /sftpdata/%u
: このユーザーのSFTPセッションにおけるルートディレクトリを/sftpdata/sftpuser1
(%u
がsftpuser1
に置き換わる) に変更します。ユーザーはこのディレクトリより上の階層には移動できません。このChrootDirectoryで指定されたディレクトリとその親ディレクトリは、rootユーザーが所有し、グループや他のユーザーへの書き込み権限がないように設定する必要があるというSSHの重要なセキュリティ要件があります。上記の手順3で/sftpdata/sftpuser1
をroot所有にしたのはこのためです。ForceCommand internal-sftp
: このユーザーが接続した際に、強制的にSSH標準のSFTPサーバープログラム (internal-sftp
) を実行させます。これにより、ユーザーが他のSSHコマンドを実行することを防ぎます。AllowTcpForwarding no
,X11Forwarding no
,PermitTunnel no
: SSHのポートフォワーディングなどの機能を無効化し、SFTP以外の操作を制限します。
-
SSHサービスの再起動:
sshd_config
の変更を反映するために、SSHサービスを再起動します。
bash
sudo systemctl restart sshd # または service sshd restart - SFTP接続の確認: SFTP専用ユーザーでSFTP接続を試みます。
bash
sftp sftpuser1@hostname_or_ip
接続後、pwd
コマンドを実行すると/
と表示されるはずです(ChrootDirectoryがルートになっているため)。ls
コマンドで/upload
ディレクトリが見え、その中にファイルをアップロードできることを確認します。cd ..
などで親ディレクトリに移動しようとしても拒否されるはずです。SSHで直接ログインを試みても拒否されることを確認します。
この設定により、SFTP専用ユーザーは指定されたディレクトリ内でのファイル操作のみが可能となり、サーバー全体のセキュリティリスクを大幅に低減できます。
5.3 ファイアウォール設定
SFTPはSSHと同じポートを使用します(デフォルト22番)。サーバー側でファイアウォールが有効になっている場合、このポートへの外部からの接続を許可する必要があります。
- firewalld (CentOS/RHEL 7+):
bash
sudo firewall-cmd --permanent --add-service=ssh
sudo firewall-cmd --reload
または、ポート番号を指定する場合:
bash
sudo firewall-cmd --permanent --add-port=22/tcp # または使用しているポート番号
sudo firewall-cmd --reload - ufw (Ubuntu/Debian):
bash
sudo ufw allow ssh
sudo ufw reload
または、ポート番号を指定する場合:
bash
sudo ufw allow 22/tcp # または使用しているポート番号
sudo ufw reload
セキュリティをさらに高めるためには、信頼できる特定のIPアドレスまたはネットワークからの接続のみを許可するようにファイアウォールを設定することを検討します。
5.4 ログ監視
SFTPを含むSSHのアクセスログは、セキュリティ上の重要な情報源です。サーバーのログファイル(通常 /var/log/auth.log
や /var/log/syslog
)には、SSH接続の試行、認証の成功・失敗、SFTPセッションの開始などが記録されます。
これらのログを定期的に監視することで、不審なアクセス試行や認証失敗の多発(ブルートフォース攻撃の可能性)などを早期に発見できます。ログ監視ツール(例: Fail2ban による不正アクセス試行IPの自動ブロック)の導入も有効です。
第6章: スクリプトを使ったSFTP操作の自動化(非インタラクティブモード)
SFTPコマンドのインタラクティブモードは手動での操作に便利ですが、定期的なファイル転送や定型的な作業を行う場合は、スクリプトによる自動化が有効です。SFTPコマンドは、バッチファイルを使用することで非インタラクティブモードでの実行が可能です。
6.1 なぜ自動化が必要か?
- 定期的なタスク: 毎日深夜にログファイルをバックアップサーバーに転送する、毎朝基幹システムからデータをダウンロードする、といった定型的なタスク。
- 定型的なデータ連携: パートナー企業や拠点間で特定のファイルを自動的に送受信する。
- 手動作業の削減: 繰り返し行うファイル操作を自動化し、人的ミスを減らす。
- バッチ処理: 多数のファイルをまとめて処理する必要がある場合。
6.2 sftp -b
オプション(バッチファイル)を使った方法
sftp
コマンドは -b
オプションを使用することで、標準入力や指定されたファイルからコマンドを読み込み、非インタラクティブに実行することができます。
bash
sftp -b batchfile [オプション] [ユーザー名@]ホスト名[:パス]
-b batchfile
: 実行するSFTPコマンドを記述したファイル(バッチファイル)を指定します。-b -
と指定すると標準入力からコマンドを読み込みます。
バッチファイルの作成:
バッチファイルには、インタラクティブモードで実行するのと同じSFTPコマンドを1行に1つずつ記述します。ただし、一部のコマンド(例: !
や help
)はバッチファイルでは使用できません。主にファイル転送 (put
, get
, mput
, mget
) やディレクトリ移動 (cd
, lcd
), ファイル削除 (rm
), 終了 (quit
, bye
) などのコマンドが使用されます。
バッチファイル例 (transfer_batch.txt
):
lcd /home/user/local_data
cd /home/remoteuser/remote_storage
put report_latest.csv
get backup_config.tar.gz /home/user/backup_downloads/
rm old_data_file.txt
quit
このバッチファイルは以下の操作を行います。
- ローカルの現在のディレクトリを
/home/user/local_data
に変更。 - リモートの現在のディレクトリを
/home/remoteuser/remote_storage
に変更。 - ローカルの
report_latest.csv
をリモートの/home/remoteuser/remote_storage
にアップロード。 - リモートの
backup_config.tar.gz
をローカルの/home/user/backup_downloads/
にダウンロード(ローカルファイル名は同じ)。 - リモートの
old_data_file.txt
を削除。 - SFTPセッションを終了。
バッチファイルの実行:
作成したバッチファイルを -b
オプションで指定して sftp
コマンドを実行します。
bash
sftp -b transfer_batch.txt username@hostname_or_ip
パスワード認証の場合、コマンド実行後にパスワード入力を求められます。
[email protected]'s password:
パスワードを入力すると、バッチファイルに書かれたコマンドが順番に実行され、処理が完了するとSFTPコマンドは終了します。
6.3 自動化におけるセキュリティの考慮事項
自動化スクリプトは、通常、ユーザーの介入なしに実行されるため、セキュリティには特に注意が必要です。
- 公開鍵認証の利用: 自動化ではパスワード入力を手動で行うことができません。パスワード認証を自動化するには、パスワードをスクリプト内に平文で記述したり、SSHpassのようなツールを使ったりする方法がありますが、これらはセキュリティリスクが非常に高いため推奨されません。代わりに、パスフレーズなしの公開鍵認証を使用するのが一般的です。
- パスフレーズなし公開鍵のリスク: パスフレーズなしの秘密鍵は、ファイルが漏洩した場合に誰でもそれを使って認証できてしまうという大きなリスクを伴います。このリスクを軽減するために、以下の対策を組み合わせるべきです。
- 鍵のパーミッション: 秘密鍵ファイルのパーミッションを
600
(所有者のみ読み書き可能) に設定し、他のユーザーからアクセスできないようにします。 - SFTP専用ユーザーとChroot: 鍵を使うユーザーをSFTP専用ユーザーにし、アクセスできるディレクトリを厳しく制限します(前章参照)。もし鍵が漏洩しても、被害範囲を限定できます。
- 特定のIPからの接続のみ許可: SSHサーバーの設定やファイアウォールで、その鍵を使うユーザーは特定のIPアドレスからのみ接続できるように制限します。
- 定期的な鍵のローテーション: リスクを減らすために、鍵ペアを定期的に新しいものに交換します。
- 鍵のパーミッション: 秘密鍵ファイルのパーミッションを
- バッチファイルの内容: バッチファイル自体も機密情報(ファイルパスなど)を含む可能性があるため、適切なパーミッションを設定し、権限のないユーザーが読み取れないように保護する必要があります。
- エラーハンドリング: バッチファイル中のコマンドが失敗した場合、後続のコマンドが意図せず実行されたり、重要なファイルが転送されないまま放置されたりする可能性があります。スクリプト内で
sftp
コマンドの終了コードを確認し、エラーが発生した場合は適切な処理(ログ記録、管理者への通知など)を行うように実装することが望ましいです。sftp
コマンドは、バッチファイル中のコマンドが一つでも失敗すると、通常は非ゼロの終了コードを返します。
例: バッチファイルとパスフレーズなし公開鍵、エラーハンドリング
- SFTP専用ユーザー
sftpuser1
の公開鍵認証を設定(パスフレーズなし)。 sftpuser1
のsshd_config
での制限設定(Chrootなど)を行う。- 秘密鍵ファイル
~/.ssh/id_sftpuser1
を作成し、パーミッションを600
に設定。 -
バッチファイル
transfer_batch.txt
を作成し、パーミッションを600
に設定。 -
シェルスクリプトを作成し、
sftp
コマンドを実行。
“`bash
#!/bin/bashSFTP_USER=”sftpuser1″
SFTP_HOST=”hostname_or_ip”
PRIVATE_KEY=”/home/user/.ssh/id_sftpuser1″
BATCH_FILE=”/home/user/transfer_batch.txt”
LOG_FILE=”/home/user/sftp_transfer.log”echo “$(date): Starting SFTP transfer…” | tee -a “$LOG_FILE”
sftp -b “$BATCH_FILE” -i “$PRIVATE_KEY” “$SFTP_USER@$SFTP_HOST” >> “$LOG_FILE” 2>&1
if [ $? -eq 0 ]; then
echo “$(date): SFTP transfer completed successfully.” | tee -a “$LOG_FILE”
# 成功時の追加処理(例: 元ファイルの移動/削除)
else
echo “$(date): SFTP transfer failed!” | tee -a “$LOG_FILE”
# 失敗時の通知処理(例: メール送信)
exit 1
fiexit 0
``
sftp
このスクリプトは、コマンドの標準出力と標準エラー出力をログファイルにリダイレクトし、
sftpコマンドの終了コード (
$?`) を確認して成否を判断しています。
このようなスクリプトを cron
などと組み合わせることで、指定した時間に自動的にSFTP転送を実行できます。ただし、自動化スクリプトの実行環境自体のセキュリティ(スクリプトファイル、秘密鍵ファイルの保護)も重要です。
6.4 その他の自動化方法
SFTPコマンドのバッチモード以外にも、SSH/SFTPを利用した自動化手段はいくつか存在します。
- scp (Secure Copy): SSH上で動作するファイルコピーコマンド。単一のファイルやディレクトリのコピーに特化しており、SFTPのようにリモートでのファイル操作(削除、名前変更など)はできませんが、単純な転送には手軽に使えます。
- rsync over SSH:
rsync
コマンドをSSH上で実行することで、差分転送による効率的な同期やバックアップが可能です。 - SSHライブラリ: プログラミング言語(Pythonのparamikoライブラリなど)からSSH/SFTPを制御し、より複雑なロジックを含むファイル転送処理を実装できます。
本記事は sftp
コマンドに焦点を当てているため詳細は割愛しますが、自動化の要件に応じてこれらの選択肢も検討すると良いでしょう。しかし、手軽にバッチ処理を行うという点では、sftp -b
が強力な選択肢となります。
第7章: よくあるトラブルと解決策
SFTPを利用する際に遭遇しやすいトラブルとその解決策をまとめました。
7.1 接続できない
最も頻繁に発生するトラブルです。原因は多岐にわたります。
- エラーメッセージ: “Connection refused”, “Connection timed out”, “Permission denied (publickey,password).”, “No route to host”, “ssh: connect to host … port …: Connection refused” など。
- 原因と解決策:
- ホスト名またはIPアドレスが間違っている: 正しい接続先情報を確認します。DNS名前解決ができているか
ping
コマンドなどで確認します。 - サーバーのSSHデーモンが起動していない: サーバー側で
sshd
サービスが稼働しているか確認します(例:sudo systemctl status sshd
)。起動していなければ起動します(例:sudo systemctl start sshd
)。 - ファイアウォールでSSHポートがブロックされている: サーバー側(およびクライアント側、経路上)のファイアウォール設定を確認し、SSHポート(デフォルト22番、またはカスタムポート)への接続が許可されているか確認します。
telnet hostname_or_ip port
やnc -vz hostname_or_ip port
コマンドで特定のポートに接続できるかテストできます。 - 指定したポート番号が間違っている:
sftp -P
オプションで指定したポート番号がサーバー側のSSHポートと一致しているか確認します。 - ユーザー名またはパスワードが間違っている: 正しいユーザー名とパスワードを使用しているか確認します。大文字・小文字や特殊文字に注意します。
- 公開鍵認証がうまくいかない:
- クライアント側: 指定した秘密鍵ファイル (
-i
オプション) が正しいパスか、ファイルが存在するか確認します。秘密鍵ファイルのパーミッションが600
であるか確認します(chmod 600 ~/.ssh/your_private_key
)。パスフレーズが設定されている場合、正しく入力しているか確認します。ssh-agent
を使っている場合、鍵が正しく登録されているかssh-add -l
で確認します。 - サーバー側: 接続ユーザーのホームディレクトリに
.ssh
ディレクトリが存在し、パーミッションが700
であるか確認します。.ssh/authorized_keys
ファイルが存在し、パーミッションが600
であるか確認します。authorized_keys
ファイルの中に、クライアント側の公開鍵の内容が正しくコピーされているか確認します。余分な改行やスペースが入っていないか、コメント部分も含めて正確にコピーされているか確認します。
- クライアント側: 指定した秘密鍵ファイル (
- サーバー側でユーザーのSSHログインが制限されている:
sshd_config
ファイルのAllowUsers
,DenyUsers
,AllowGroups
,DenyGroups
ディレクティブや、ユーザーのシェル設定 (/etc/passwd
など) でログインが制限されていないか確認します。 - SELinuxなどのセキュリティ機能による制限: SELinuxがEnforcingモードの場合、SFTPの特定の操作やChroot環境が制限されることがあります。SELinuxログ(
/var/log/audit/audit.log
など)を確認し、関連する拒否ログがないか確認します。必要に応じてSELinuxポリシーを調整するか、Permissiveモードで一時的にテストします。
- ホスト名またはIPアドレスが間違っている: 正しい接続先情報を確認します。DNS名前解決ができているか
7.2 ファイル転送が途中で止まる、非常に遅い、または切断される
- エラーメッセージ: 転送中のハング、タイムアウト、”Write failed”, “Read failed”, “packet_write_wait: Connection to …: Broken pipe” など。
- 原因と解決策:
- ネットワークの問題: クライアントとサーバー間のネットワーク接続が不安定(パケットロス、帯域幅不足)である可能性があります。
ping
やtraceroute
コマンドでネットワークの状態を確認します。可能な場合は、より安定したネットワーク環境で試します。 - サーバーまたはクライアントのディスク容量不足: 転送先デバイスに十分な空き容量がない場合、転送が失敗します。
df -h
コマンドなどでディスク使用量を確認します。 - サーバーの負荷: サーバーのCPU、メモリ、ディスクI/Oが高負荷になっている場合、SFTPの処理が遅延したり、タイムアウトしたりすることがあります。サーバー管理者に状況を確認してもらいます。
- SSHタイムアウト設定: SSHサーバーやクライアント側の設定で、アイドル状態のセッションが一定時間後に切断されるように設定されている場合があります。これは通常、大きなファイルの転送中には影響しませんが、転送速度が極端に遅い場合や、バッチ処理間の待ち時間が長い場合に影響する可能性があります。SSHクライアント側で
ServerAliveInterval
やServerAliveCountMax
オプション(ssh_config
またはsftp -o
オプションで指定可能)を設定することで、セッションを維持するためのキープアライブパケットを送信できます。 - SFTPサーバー(sshd)の問題: SFTPサブシステムや
sshd
プロセス自体に問題が発生している可能性も考えられます。サーバーのシステムログを確認します。
- ネットワークの問題: クライアントとサーバー間のネットワーク接続が不安定(パケットロス、帯域幅不足)である可能性があります。
7.3 パーミッションエラーでファイル操作(作成、削除、名前変更、アップロード、ダウンロード)ができない
- エラーメッセージ: “Permission denied”, “Failure”, “Operation not permitted” など。
- 原因と解決策:
- リモート側のディレクトリ/ファイルのパーミッション: 接続ユーザーがリモートのファイルまたはディレクトリに対して、必要な操作(読み取り、書き込み、実行)を行う権限を持っていない場合に発生します。
ls -l
コマンドでリモートのパーミッションを確認します。必要に応じてchmod
,chown
,chgrp
コマンドでパーミッションや所有者を変更します(これらのコマンド自体を実行する権限が必要)。 - ローカル側のディレクトリ/ファイルのパーミッション: ダウンロードやアップロードの際に、ローカルのファイルまたはディレクトリに対して、SFTPクライアントを実行しているユーザーが必要な権限を持っていない場合に発生します。ローカル側のパーミッションも確認します。
- chroot環境での問題: SFTP専用ユーザーでChrootDirectoryが設定されている場合、ユーザーはChrootDirectory以下のファイルシステムしか見ることができません。また、ChrootDirectoryやその親ディレクトリのパーミッション設定が厳密に要求されます(前述)。これらの設定が正しくないと、ログインできても意図した場所にアクセスできなかったり、特定の操作ができなかったりします。
sshd_config
の設定とChrootDirectoryのパーミッションを確認します。ChrootDirectory以下に、ユーザーが書き込み可能なディレクトリが適切に作成・設定されているか確認します。 - SELinuxによる制限: SELinuxがSFTPアクセスを制限している可能性があります。関連ログを確認します。
- リモート側のディレクトリ/ファイルのパーミッション: 接続ユーザーがリモートのファイルまたはディレクトリに対して、必要な操作(読み取り、書き込み、実行)を行う権限を持っていない場合に発生します。
7.4 バッチファイルが意図した通りに動作しない
- 原因と解決策:
- バッチファイル中のコマンドの誤り: バッチファイルに記述したSFTPコマンドのスペルミスや引数の誤りがないか確認します。インタラクティブモードで同じコマンドを手動で実行してみて、期待通りの動作をするか確認するのが最も簡単な方法です。
- パスやファイル名の間違い: バッチファイル中のローカルパスやリモートパスが間違っている、またはファイルが存在しない可能性があります。
- バッチファイルでサポートされていないコマンド:
!
やhelp
など、一部のインタラクティブコマンドはバッチファイルでは使用できません。 - パスワード入力を求められている: パスワード認証を使用しているのに、パスワード入力が自動化できていない(スクリプトやツールを使っていない)ため、処理が停止しています。公開鍵認証(パスフレーズなし鍵を含む)に切り替えるか、パスワード入力を自動化する別の手段を検討します(ただしセキュリティリスクに注意)。
- エラーハンドリングがない: バッチファイル中の最初のコマンドが失敗した場合、後続のコマンドが期待通りに動作しないことがあります。
sftp
コマンドの終了コードを確認するスクリプトでラップするなど、エラーハンドリングを実装します。 - カレントディレクトリの問題: バッチファイル中の相対パスは、
sftp
コマンド実行時のカレントディレクトリ(ローカル)と、SFTP接続成功時のリモートカレントディレクトリ(通常ホームディレクトリ)を基準とします。lcd
やcd
コマンドで明示的にディレクトリを移動するか、バッチファイル中で常に絶対パスを使用することで問題を回避できます。
これらのトラブルシューティングのヒントは、問題解決の一助となるはずです。重要なのは、エラーメッセージをよく読み、一つずつ可能性のある原因を順番に確認していくことです。サーバー側のシステムログも、問題の原因を特定する上で非常に役立ちます。
まとめ:安全なファイル転送の実践に向けて
本記事では、SFTPコマンドの基本的な使い方から、安全性を高めるための設定、さらにはスクリプトによる自動化まで、SFTPを活用するための幅広い知識を解説しました。
SFTPがFTPやFTPSと比較して優れている点は、SSHプロトコル上で動作することによる高い安全性にあります。認証情報もデータもすべて暗号化されるため、ネットワーク上の盗聴や改ざんのリスクを大幅に低減できます。また、単一のポート(デフォルト22番)のみを使用するため、ファイアウォール設定が容易であることも大きな利点です。
SFTPコマンドを使いこなすことで、コマンドラインから対話形式で手軽にファイル転送やリモートファイル操作を行うことができます。put
や get
によるファイル転送、ls
や cd
によるリモートディレクトリ操作、mkdir
, rm
, rename
などを使ったファイル管理は、サーバー管理や開発作業において非常に役立ちます。
さらに、セキュリティを強化するためには、単にSFTPを使うだけでなく、SSH自体の設定も重要です。特に、パスワード認証よりも安全な公開鍵認証を導入すること、SFTPによるファイル転送のみを許可するSFTP専用ユーザーを作成し、ChrootDirectory
や ForceCommand internal-sftp
といった設定でアクセス範囲を制限することは、サーバー全体のセキュリティレベルを大きく向上させます。
定期的なファイル転送やバックアップ、データ連携などのタスクを自動化したい場合は、sftp -b
オプションを使ったバッチファイルによる非インタラクティブ実行が有効です。自動化を行う際は、パスフレーズなし公開鍵認証を利用することが多いですが、その際には鍵ファイルの適切な保護、SFTP専用ユーザーによるアクセス制限、ファイアウォール設定など、複合的なセキュリティ対策を講じることが不可欠です。
インターネットを介したファイル転送には常にリスクが伴います。SFTPのようなセキュアなプロトコルを選択し、本記事で解説したようなセキュリティ設定と運用上の注意点を守ることで、大切なデータを安全にやり取りできるようになります。
SFTPコマンドは、その安全性と機能の豊富さから、システム管理者や開発者、あるいは安全なデータ共有を求めるすべての人にとって、習得しておくべき重要なツールの一つです。ぜひ本記事を参考に、SFTPコマンドを日々の業務で活用し、安全なファイル転送を実践してください。