通过SFTP(Secure File Transfer Protocol)在Linux中远程管理服务器主要涉及安装和配置SFTP服务器、创建用户和用户组、设置权限、以及使用SFTP客户端进行文件操作。以下是详细步骤:
安装OpenSSH服务器(如果尚未安装):
在Debian/Ubuntu系统上:
sudo apt update sudo apt install openssh-server 在CentOS/RHEL系统上:
sudo yum update sudo yum install openssh-server 配置SSH配置文件 /etc/ssh/sshd_config:
Subsystem sftp /usr/lib/openssh/sftp-server Match Group sftpusers ChrootDirectory %h ForceCommand internal-sftp AllowTcpForwarding no X11Forwarding no 创建一个专门用于SFTP的用户组,并将需要使用SFTP的用户加入此组:
sudo groupadd sftpusers sudo usermod -aG sftpusers your_username 保证用户主目录的权限设置无误:
sudo chown root:root /home/your_username sudo chmod 755 /home/your_username 在用户的家目录下创建一个 .ssh 目录,并设置正确的权限:
mkdir /home/your_username/.ssh chmod 700 /home/your_username/.ssh 创建 authorized_keys 文件,并添加用户的公钥:
touch /home/your_username/.ssh/authorized_keys chmod 600 /home/your_username/.ssh/authorized_keys 将用户的公钥复制到 authorized_keys 文件中。
重启SSH服务以应用配置更改:
sudo systemctl restart sshd 你可以使用命令行的SFTP客户端或者图形化界面的SFTP客户端来与远程服务器建立连接。
sftp your_username@remote_host ls:显示远程目录的内容。cd:切换远程目录。get:从远程下载文件至本地。put:把本地文件上传到远程。mkdir:在远程创建新目录。rmdir:删除远程目录。rm:移除远程文件。exit 或 bye:退出SFTP会话。chrootDirectory 和 ForceCommand 等选项控制用户的访问范围。通过以上步骤,你可以安全有效地使用SFTP在Linux中远程管理服务器。