FTP
ファイル転送プロトコルは、サーバーからコンピューターネットワーク(インターネットを含む)上のクライアントにコンピューターファイルを転送するために使用される標準の通信プロトコルです。 FTPは、クライアントとサーバー間で個別の制御とデータ接続を使用するクライアントサーバーモデルアーキテクチャに基づいて構築されています。
FTPは、システム間で大きなファイルを監視または移動するために常に人気があります。ファイルを中央サーバーに追加すると、ファイルにアクセスしたいユーザーはそこからファイルにアクセスできます。
SSH
SFTPは、安全なトンネリングプロトコルであるSecure Shell 2(SSH2)を使用したトンネリングでセキュリティを強化することを目的としています。 FTP接続をエミュレートし、TCPポート22を使用したファイル転送用のファイアウォールに適した暗号化されたチャネルを提供します。
SSHは、すべてのセッション制御コマンドを含むファイル転送セッション全体を常に完全に暗号化することで、セキュリティを強化します。 FTPおよびSSL接続用に開く必要がある2つのポートに対して、ファイアウォールで1つのポートを開く必要があります。
追加機能として、Secure FTPは送信中にすべてのデータを圧縮するため、ファイル転送が高速化されます。
関連コンテンツ
- LinuxでSFTPクライアントを操作する方法–10sftpコマンド
- Debian11サーバーでSFTPサーバーをセットアップする方法
- Pythonスクリプトを使用してSFTPサーバーからファイルをダウンロードする
- golangを使用してSFTPサーバーからファイルを一覧表示、アップロード、およびダウンロードする
- OpenSUSELeap15.3サーバーでSFTPサーバーを設定する方法
- CentOS 8 /RHEL8サーバーでSFTPサーバーをセットアップする方法
Ubuntu20.04でSFTPサーバーを起動して実行する
このガイドでは、Ubuntu20.04にSFTPサーバーをインストールしてセットアップするプロセスについて説明します。次の手順を実行します:
-
sftp
のインストール およびssh
Ubuntuのソフトウェア - SFTPユーザーとグループの作成
- SSHサービスの構成
- ターミナルを使用したサーバーへの接続–Linuxコマンドライン
1。 Ubuntuへのsshソフトウェアのインストール
ssh
を提供するソフトウェアが必要です およびsftp
Ubuntuのサーバーソフトウェア
マシンが更新されていることを確認してください:
sudo apt update
sudo apt upgrade -y
sftp
以降 ssh
に依存しています 、SSHまたはOpenSSHのいずれかがまだマシンにインストールされていない場合は、それらをインストールする必要があります。
ssh
をインストールします。 デーモン:
sudo apt install ssh
出力
$ sudo apt install ssh
Reading package lists... Done
Building dependency tree
Reading state information... Done
The following packages were automatically installed and are no longer required:
libllvm11 libxdamage1
Use 'sudo apt autoremove' to remove them.
The following NEW packages will be installed:
ssh
0 upgraded, 1 newly installed, 0 to remove and 0 not upgraded.
Need to get 5,084 B of archives.
After this operation, 120 kB of additional disk space will be used.
Get:1 http://ports.ubuntu.com/ubuntu-ports focal-security/main arm64 ssh all 1:8.2p1-4ubuntu0.2 [5,084 B]
Fetched 5,084 B in 0s (26.8 kB/s)
Selecting previously unselected package ssh.
(Reading database ... 104454 files and directories currently installed.)
Preparing to unpack .../ssh_1%3a8.2p1-4ubuntu0.2_all.deb ...
Unpacking ssh (1:8.2p1-4ubuntu0.2) ...
Setting up ssh (1:8.2p1-4ubuntu0.2) ...
2。 SFTPユーザーとグループの作成
SFTPサーバーにログインするユーザーとグループを作成する必要があります。
- 必要な名前でグループを作成します。
sftpgroup1
を使用しますsudo addgroup sftpgroup1
出力:
# sudo addgroup sftpgroup1
Adding group 'sftpgroup1' (GID 1002) ...
Done.
- 作成したグループに追加する名前のユーザーを作成します。
sftpuser1
を使用します ユーザーのために。sudo useradd -m sftpuser1 -g sftpgroup1
- 新しいSFTPユーザーにパスワードを追加します
sudo passwd sftpuser1
出力:
# sudo passwd sftpuser1
New password:
Retype new password:
passwd: password updated successfully
- 次のコマンドを使用して、新しいSFTPユーザーに新しいホームディレクトリへの完全なアクセスを許可します。
sudo chmod 700 /home/sftpuser1/
SSHサービスの構成
sftpトラフィックを受け入れるようにsshサービスを設定する必要があります。 /etc/ssh/sshd_config
にあるssh構成ファイルに次の構成を追加します。 :
ターミナルで、次のコマンドを使用して、vimで構成ファイルを開きます。
sudo vim /etc/ssh/sshd_config
次に、このコンテンツをファイルの最後に追加します:
Match group sftpgroup1
ChrootDirectory /home
X11Forwarding no
AllowTcpForwarding no
ForceCommand internal-sftp
上記の構成は、sftpgroup1グループ(Match group sftpgroup1
)のユーザーを許可することを目的としています。 )これらのファイルへの他の通常のSSHアクセスを防ぎながら、SFTP経由でホームディレクトリにアクセスして使用する。
SSHD構成ファイルを保存して閉じます。
SSHサービスを再起動して、以前の変更を適用します。
sudo systemctl restart ssh
4。ターミナルを使用したサーバーへの接続–Linuxコマンドライン
コマンドラインターミナルを使用して、SFTPへのログインをテストできます。これは、sftpサーバーでローカルに実行することもできます。
ログインコマンドの形式は次のとおりです。
sftp [user]@[host]
サーバーに接続しましょう。 SFTPのユーザー名とパスワードが必要になります。
sftp [email protected]
出力:
$ sftp [email protected]
The authenticity of host '127.0.0.1 (127.0.0.1)' can't be established.
ECDSA key fingerprint is SHA256:99KvuL95zO2CQbC8X0Re/Q+cYrJgqQgzpf1leemnjmY.
Are you sure you want to continue connecting (yes/no/[fingerprint])? yes
Warning: Permanently added '127.0.0.1' (ECDSA) to the list of known hosts.
[email protected]'s password:
Connected to 127.0.0.1.
sftp>
これにより、サーバーにログインします。デフォルトのディレクトリは/home
です ChrootDirectory /home
で指定されたディレクトリ sshサーバー構成のディレクティブ。
基本的なsftpコマンド
バージョンの確認:
sftp> version
SFTP protocol version 3
sftp>
リモート作業ディレクトリを表示する
リモートサーバー上の現在の作業ディレクトリを確認する必要がある場合は、pwd
コマンドが便利です:
sftp> pwd
Remote working directory: /sftpuser1
sftp>
ローカルマシンの作業ディレクトリを表示
ローカルシステムの現在の作業ディレクトリを表示するには、lpwd
を使用します コマンド。
sftp> lpwd
Local working directory: /home/ubuntu
sftp>
作成されたユーザーは、そのディレクトリにのみアクセスできます。次のコマンドでそのディレクトリに切り替えましょう:
sftp> cd sftpuser1
sftp>
SFTPユーザーのホームディレクトリに移動し、次のように新しいディレクトリを作成してみてください。
sftp> ls
sftpuser1 ubuntu
sftp> cd sftpuser1
sftp> ls
sftp> mkdir datadir
sftp> ls
datadir
ファイルのアップロード
ローカルから行う
次のコマンド構文を使用して、ファイルをリモートサーバーにアップロードします。
$ sftp {user}@{host}:{remote-path} <<< $'put {local-path}'
例:
$ sftp [email protected]:/sftpuser1/ <<< $'put ./citizix.txt'
[email protected]'s password:
Connected to 127.0.0.1.
Changing to: /sftpuser1/
sftp> put ./citizix.txt
Uploading ./citizix.txt to /sftpuser1/citizix.txt
./citizix.txt
sftpサーバーから実行
次のコマンドを使用します:ls
ファイルを一覧表示するには、lls
ローカルリストの場合、put
ファイルをアップロードする場合:
sftp>
sftp> pwd
Remote working directory: /sftpuser1/datadir
sftp> ls
sftp> lls
citizix.txt snap tmp
sftp> put citizix.txt
Uploading citizix.txt to /sftpuser1/datadir/citizix.txt
citizix.txt 100% 32 25.8KB/s 00:00
sftp> ls
citizix.txt
sftp>
一度に複数のファイルをアップロードするには、mput
を使用できます 以下の例のようなコマンド。 mput
を使用できます data[23]
のような正規表現を使用 data2
をアップロードするには 、data3
data1
を無視します 。 mput
では、任意のワイルドカードまたは正規表現を使用できます 。
sftp>
sftp> pwd
Remote working directory: /sftpuser1/data
sftp> ls
sftp> lls
data1 data2 data3
sftp> mput data[23]
Uploading data2 to /sftpuser1/data/data2
data2 100% 0 0.0KB/s 00:00
Uploading data3 to /sftpuser1/data/data3
data3 100% 0 0.0KB/s 00:00
sftp> ls
data2 data3
ファイルのダウンロード
ローカルマシンから実行
リモートサーバーからファイルをダウンロードするには、次のコマンド構文を使用します。
$ sftp {user}@{remote-host}:{remote-file-name} {local-file-name}
sftpを使用して1行でファイルをダウンロードするデモは次のとおりです。
# sftp [email protected]:/sftpuser1/citizix.txt .
[email protected]'s password:
Connected to 127.0.0.1.
Fetching /sftpuser1/citizix.txt to ./citizix.txt
/sftpuser1/citizix.txt 100% 32 26.7KB/s 00:00
リモートsftpサーバーから実行
get
を使用してサーバーから単一のファイルをダウンロードします 。 data2
のダウンロード例
sftp>
sftp> ls
data2 data3
sftp> lls
sftp> get data2
Fetching /sftpuser1/data/data2 to data2
sftp> lls
data2
sftp>
mget
を使用する この例のように複数のファイルをダウンロードするには
sftp>
sftp> ls
data2 data3
sftp> lls
sftp> mget data*
Fetching /sftpuser1/data/data2 to data2
Fetching /sftpuser1/data/data3 to data3
sftp> lls
data2 data3
sftp>
ディレクトリの作成と削除
コマンドmkdir
を使用します およびrmdir
ディレクトリを作成および削除するには
sftp>
sftp> ls
sftp> mkdir data
sftp> ls
data
sftp> rmdir data
sftp>
ファイルの削除
コマンドrm
を使用します ファイルを削除するには
sftp> rm data*
Removing /sftpuser1/data/data2
Removing /sftpuser1/data/data3
sftp>
ファイルの名前変更
sftp>
sftp> ls
data3
sftp> rename data3 data_original
sftp> ls
data_original
sftp>
ファイルシステムの使用状況の確認
「パス」を含む現在のディレクトリまたはファイルシステムの統計を表示します。dfコマンドを使用します。 -hフラグを使用して、人間が読める形式で統計を表示できます。表示される統計は、リモートSFTPサーバーのそれぞれのファイルシステムに関するものであり、ローカルマシンのファイルシステムに関するものではないことに注意してください。
sftp> df
Size Used Avail (root) %Capacity
29540600 5917856 22103188 23622744 20%
sftp> df -h
Size Used Avail (root) %Capacity
28.2GB 5.6GB 21.1GB 22.5GB 20%
ヘルプの取得
SFTPで使用可能なコマンドと構文に関するヘルプを取得するには、「?」または「help」を使用してください。
sftp> ?
出力:
sftp> ?
Available commands:
bye Quit sftp
cd path Change remote directory to 'path'
chgrp [-h] grp path Change group of file 'path' to 'grp'
chmod [-h] mode path Change permissions of file 'path' to 'mode'
chown [-h] own path Change owner of file 'path' to 'own'
df [-hi] [path] Display statistics for current directory or
filesystem containing 'path'
exit Quit sftp
get [-afpR] remote [local] Download file
help Display this help text
lcd path Change local directory to 'path'
lls [ls-options [path]] Display local directory listing
lmkdir path Create local directory
ln [-s] oldpath newpath Link remote file (-s for symlink)
lpwd Print local working directory
ls [-1afhlnrSt] [path] Display remote directory listing
lumask umask Set local umask to 'umask'
mkdir path Create remote directory
progress Toggle display of progress meter
put [-afpR] local [remote] Upload file
pwd Display remote working directory
quit Quit sftp
reget [-fpR] remote [local] Resume download file
rename oldpath newpath Rename remote file
reput [-fpR] local [remote] Resume upload file
rm path Delete remote file
rmdir path Remove remote directory
symlink oldpath newpath Symlink remote file
version Show SFTP version
!command Execute 'command' in local shell
! Escape to local shell
? Synonym for help
詳細については、sftpのマニュアルページを参照してください。
$ man sftp
SFTPセッションを終了します
最後に、bye
を使用してsftpを終了できます。 、exit
、またはquit
:
sftp> exit
$
結論
このガイドでは、sftpサーバーをセットアップし、サーバーで実行できる基本的な操作について説明しました。