大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。
Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺
学习目标:
能够完成sftp服务的部署,且实现ssh和sftp的端口分离,不使用默认的端口,sftp用户的权限只可以访问该用户的家目录里的文件和其下的子目录,实现权限控制。
学习内容:
SFTP是SSH的一部分,SFTP没有单独的守护进程,它必须使用SSHD守护进程(端口号默认是22)来完成相应的连接操作,所以从某种意义上来说,SFTP并不像是一个服务器程序,而更像是一个客户端程序。
检查sftp 服务是否可用
1.1、systemctl status sshd
1.2、systemctl status sftpd
系统内开启ssh服务和sftp服务都是通过/usr/sbin/sshd这个后台程序监听22端口,而sftp服务作为一个子服务,是通过/etc/ssh/sshd_config配置文件中的Subsystem实现的,如果没有配置Subsystem参数,则系统是不能进行sftp访问的
从ssh服务分离sftp服务
- 复制SSH相关文件,作为sftp的配置文件
1、 拷贝/usr/lib/systemd/system/目录下的sshd.service文件,放到/etc/systemd/system/目录下,命名为:sftpd.service
cp /usr/lib/systemd/system/sshd.service /etc/systemd/system/sftpd.service
2、 拷贝/etc/pam.d/目录下的sshd文件,放到同目录,命名为:sftpd
cp /etc/pam.d/sshd /etc/pam.d/sftpd
3、拷贝/etc/ssh/目录下的sshd_config文件,放到同目录,命名为:sftpd_config
cp /etc/ssh/sshd_config /etc/ssh/sftpd_config
4、对service和rcsftpd进行软连接
ln -sf /usr/sbin/service /usr/sbin/rcsftpd
5、对sshd和sftpd进行软连接
ln -sf /usr/sbin/sshd /usr/sbin/sftpd
6、拷贝/etc/sysconfig/目录下的sshd文件,放到同目录,命名为:sftp
cp /etc/sysconfig/sshd /etc/sysconfig/sftp
7、 拷贝/var/run/目录下的sshd.pid文件,放到同目录,命名为:sftpd.pid
cp /var/run/sshd.pid /var/run/sftpd.pid
- 修改配置文件
1、 修改/etc/systemd/system/目录下sftpd.service文件
vim /etc/systemd/system/sftpd.service
[Unit]
Description=sftpd server daemon
Documentation=man:sshd(8) man:sshd_config(5)
After=network.target sshd-keygen.service
Wants=sshd-keygen.service
[Service]
Type=notify
EnvironmentFile=/etc/sysconfig/sftp
ExecStart=/usr/sbin/sftpd -f /etc/ssh/sftpd_config
ExecReload=/bin/kill -HUP $MAINPID
KillMode=process
Restart=on-failure
RestartSec=42s
[Install]
WantedBy=multi-user.target
- 修改/etc/ssh/目录下的sftpd_config文件
vim /etc/ssh/sftpd_config
下面标红的需要执行,标绿的可不执行,看自己是否需要单独设置允许root登录和其他用户怎么管理而定
①找到第17行,将
Port 22
改成
Port 20022
②找到第38行,将
#PermitRootLogin yes
改成
PermitRootLogin no
就是取消该行的注释,并将yes改成no,这行参数的目的是拒绝root用户登录
③找到116行,将
#PidFile /var/run/sshd.pid
改成
PidFile /var/run/sftpd.pid
就是取消该行的注释,并将sshd.pid改成sftpd.pid
④找到第132行,将
Subsystem sftp /usr/libexec/openssh/sftp-server
注释
#Subsystem sftp /usr/libexec/openssh/sftp-server并添以下5行
Subsystem sftp internal-sftp
Match User sftpuser
ChrootDirectory /home/sftpuser/ ##此配置是指定sftp用户的家目录,可访问的目录
drwxr-xr-x. 4 root root 4096 Aug 9 15:16 home
drwxr-xr-x 3 root root 4096 Aug 9 16:38 sftpuser
drwxrwxrwx 3 sftpuser sftpuser 4096 Aug 9 19:42 csm
ForceCommand internal-sftp
X11Forwarding no
AllowTcpForwarding no
就是注释132行,并将132行下面,添加5行内容。
- 清空/var/run/目录下的sftpd.pid文件内容
echo “” > /var/run/sftpd.pid - 添加sftp的专用账户
useradd sftpuser
passwd sftpuser
usermod -s /bin/false sftpuser - 重启sftpd服务
systemctl daemon-reload
systemctl start sftpd - 查看ssh服务和sftp服务状态
systemctl status sshd
systemctl status sftpd - 查看端口分离情况
lsof -i:22
lsof -i:20022 - 登录验证
sftp -P 20022 user @serverip
sftp -P 22 user @serverip
说明:
如果后续不想让用户通过22好端口登录服务,可修改、etc/ssh/sshd_config文件,注释掉
#Subsystem sftp /usr/libexec/openssh/sftp-server
然后重启ssh服务
学习产出:
能够完成sftp服务的搭建并实现端口分离,可以随意自定义端口
发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/193895.html原文链接:https://javaforall.cn
【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛
【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...