Ubuntu 如何开启 Root 用户 SSH 登录

Ubuntu 如何开启 Root 用户 SSH 登录


前言

在使用 Ubuntu 服务器时,默认情况下 root 用户是无法直接通过 SSH 登录的。这是出于安全考虑的默认设置。但在某些场景下(如本地开发环境、内网服务器等),我们需要开启 root 用户的 SSH 登录权限。本文将手把手带你完成配置。

⚠️ 安全警告: 在生产环境中,不建议直接开放 root SSH 登录。推荐使用普通用户登录后通过 sudo 提权,或采用密钥认证方式替代密码登录。


环境说明

  • 系统:Ubuntu 20.04 / 22.04 / 24.04
  • 需要具备 sudo 权限的普通用户账号

步骤一:设置 Root 密码

如果你从未设置过 root 密码,需要先执行以下命令:

复制代码
sudo passwd root

按提示输入并确认新密码即可。


步骤二:修改 SSH 配置文件

使用编辑器打开 SSH 的主配置文件:

bash 复制代码
sudo nano /etc/ssh/sshd_config

在文件中找到 PermitRootLogin 这一行(默认可能被注释掉),将其修改为:

bash 复制代码
PermitRootLogin yes

💡 提示: 如果该行以 # 开头,需要先去掉 # 号再修改值。

保存并退出编辑器(nano 中按 Ctrl+O 保存,Ctrl+X 退出)。


步骤三:重启 SSH 服务

修改配置后,需要重启 SSH 服务使配置生效:

bash 复制代码
# Ubuntu 22.04 及以上
sudo systemctl restart ssh

# 通用方式
sudo service ssh restart

步骤四:验证配置是否生效

执行以下命令确认配置已生效:

perl 复制代码
sudo sshd -T | grep permitrootlogin

若输出结果为:

bash 复制代码
permitrootlogin yes

则说明配置成功。


PermitRootLogin 参数说明

参数值 说明
yes 允许 root 用户通过密码或密钥登录
prohibit-password 仅允许密钥方式登录(默认值,推荐)
forced-commands-only 仅允许执行特定命令
no 完全禁止 root 用户 SSH 登录

更安全的替代方案:密钥登录

如果你的目的是方便管理,强烈建议使用 SSH 密钥认证 而不是密码登录:

第一步: 将配置保持为仅允许密钥登录:

复制代码
PermitRootLogin prohibit-password

第二步: 将本地公钥添加到服务器:

bash 复制代码
# 将本地公钥复制到服务器 root 用户
ssh-copy-id root@your_server_ip

# 或手动追加
cat ~/.ssh/id_rsa.pub | sudo tee -a /root/.ssh/authorized_keys

第三步: 禁用密码登录(可选,进一步加强安全):

perl 复制代码
# 在 sshd_config 中设置
PasswordAuthentication no

常见问题

Q:修改后仍然无法登录怎么办?

检查防火墙是否开放了 22 端口:

lua 复制代码
sudo ufw status
sudo ufw allow ssh

Q:如何查看 SSH 登录日志?

bash 复制代码
sudo journalctl -u ssh -n 50
# 或
sudo tail -f /var/log/auth.log

Q:如何修改 SSH 默认端口?

sshd_config 中修改 Port 22 为其他端口号,可有效减少暴力破解风险。


总结

| 步骤 | 命令 |
|------------|----------------------------------|------------------------|
| 设置 root 密码 | sudo passwd root |
| 编辑配置文件 | sudo nano /etc/ssh/sshd_config |
| 修改配置项 | PermitRootLogin yes |
| 重启 SSH 服务 | sudo systemctl restart ssh |
| 验证配置 | `sudo sshd -T | grep permitrootlogin` |

配置完成后,即可使用 ssh root@your_server_ip 直接以 root 身份登录服务器。再次提醒,在生产环境中请优先使用密钥认证,避免使用密码登录,保障服务器安全。

相关推荐
Lv_沐曦5 小时前
银河麒麟桌面版安装、多屏配置、触摸校准
运维·docker·samba·vsftpd·银河麒麟·触控校准·多屏配置
半壶清水6 小时前
ubuntu下利用ns-3 + NetAnim搭建可视化路由选路过程的方法
linux·运维·ubuntu
ting94520006 小时前
SellerClaw 全栈技术深度拆解:基于多智能体集群的跨境电商全链路自动化系统实现
运维·自动化
三雷科技6 小时前
Rsync 命令详解:Linux 文件同步与备份的艺术
linux·运维·服务器
真实的菜6 小时前
Redis 从入门到精通(十三):性能优化与运维实战 —— 慢查询、内存优化、监控与安全
运维·redis·性能优化
j_xxx404_7 小时前
MySQL库操作硬核解析:字符集、校验规则、大小写比较、备份恢复与连接排查
运维·服务器·数据库·人工智能·mysql·ai·oracle
机汇五金_8 小时前
影响交换机箱体使用寿命的几个关键因素
运维·服务器·网络·python
无限进步_8 小时前
Linux进程终止——退出码、exit与_exit
linux·运维·服务器
小蜗子8 小时前
Windows 11 + RTX 5060 + WSL2 Ubuntu + NVIDIA DGL 容器
linux·运维·ubuntu
枕星而眠8 小时前
C++ 面向对象核心机制深度解析:多态性、虚函数、虚继承与 final 类
运维·开发语言·c++·后端