- 首先检查哪个进程占用了22端口:
bashCopy Code
sudo lsof -i :22 sudo ss -tulnp | grep :22
- 强制终止残留的sshd进程:
bashCopy Code
sudo kill -9 6300 # 根据日志中的PID 6300
- 清理systemd残留状态:
bashCopy Code
sudo systemctl reset-failed ssh.service
- 检查并修复SSH配置文件:
bashCopy Code
sudo sshd -t # 测试配置文件语法 sudo nano /etc/ssh/sshd_config # 检查配置
- 重启SSH服务:
bashCopy Code
sudo systemctl restart ssh
- 验证服务状态:
bashCopy Code
sudo systemctl status ssh
如果问题仍然存在,可以尝试:
- 更改SSH端口(临时解决方案):
bashCopy Code
sudo sed -i 's/#Port 22/Port 2222/' /etc/ssh/sshd_config sudo systemctl restart ssh
- 完全重新安装SSH服务:
bashCopy Code
sudo apt purge openssh-server sudo apt install openssh-server
- 检查防火墙设置:
bashCopy Code
sudo ufw status sudo iptables -L
- 查看详细日志:
bashCopy Code
journalctl -u ssh.service -b --no-pager
sshd -t报错: Missing privilege separation directory: /run/sshd
![]()
DeepSeek-R1 回答完成
这个错误表明SSH服务缺少必要的权限分离目录 /run/sshd。以下是解决方案:
- 首先手动创建缺失的目录:
bashCopy Code
sudo mkdir /run/sshd sudo chmod 0755 /run/sshd
- 然后检查目录权限是否正确:
bashCopy Code
ls -ld /run/sshd
应该显示:drwxr-xr-x 2 root root
- 重新测试SSH配置:
bashCopy Code
sudo sshd -t
- 如果仍然报错,可能需要完全重启SSH服务:
bashCopy Code
sudo systemctl restart ssh
- 永久解决方案(防止重启后目录消失):
bashCopy Code
sudo nano /etc/tmpfiles.d/sshd.conf
添加以下内容:
textCopy Code
d /run/sshd 0755 root root
- 应用配置:
bashCopy Code
sudo systemd-tmpfiles --create
- 验证最终状态:
bashCopy Code
sudo sshd -t sudo systemctl status ssh
这个错误通常发生在系统重启后临时目录被清除的情况下。通过tmpfiles.d配置可以确保目录在每次启动时自动重建。
2万+

被折叠的 条评论
为什么被折叠?



