Linux怎么禁止Root用户远程登录_Linux系统SSH加固与安全设置【教程】
技术百科
尼克
发布时间:2025-12-31
浏览: 次 禁止Root用户远程登录的五种方法:一、修改sshd_config中PermitRootLogin为no;二、结合AllowUsers限定可登录用户;三、关闭PasswordAuthentication并启用PubkeyAuthentication;四、新建普通用户并配置sudo免密提权;五、重启sshd服务并验证生效。
如果您在Linux系统中运行SSH服务,但希望阻止root用户通过网络直接登录服务器,则可能是由于默认配置允许root远程访问,带来严重安全风险。以下是禁止Root用户远程登录的多种操作方法:
一、修改sshd_config中PermitRootLogin参数
该方法通过禁用SSH服务对root用户的直接认证入口,是最基础且广泛适用的安全控制手段。核心在于将PermitRootLogin设为no,使SSH守护进程拒绝任何以root身份发起的连接请求。
1、使用具有root权限的账户登录系统,执行命令编辑SSH主配置文件:
vim /etc/ssh/sshd_config
2、在文件中定位到PermitRootLogin所在行(可输入/PermitRootLogin后按回车搜索)
3、若该行被注释(以#开头),先删除#符号;再将值修改为no,确保行内容为:
PermitRootLogin no
4、检查是否存在重复的PermitRootLogin配置项,保留唯一一行并确认其未被注释
5、保存文件并退出编辑器
二、结合AllowUsers限制可登录用户范围
该方法在禁用root登录的基础上,进一步显式声明仅允许特定普通用户通过SSH接入,形成双重访问控制层,有效缩小攻击面。
1、在编辑/etc/ssh/sshd_config文件时,在PermitRootLogin no下方新增AllowUsers行
2、指定一个或多个已创建的普通用户名,多个用户之间用空格分隔,例如:
AllowUsers admin user1
3、确保所列用户已存在且密码或密钥认证已配置完成
4、保存配置文件
三、关闭密码认证并强制使用密钥登录
该方法不单独禁用root,而是通过移除密码验证通道,使包括root在内的所有用户无法凭密码远程登录,仅支持预置公钥的用户接入,大幅提升抗暴力破解能力。
1、编辑/etc/ssh/sshd_config文件
2、找到PasswordAuthentication行,将其值改为no:
PasswordAuthentication no
3、找到PubkeyAuthentication行,确保其值为yes:
PubkeyAuthentication
yes
4、确认AuthorizedKeysFile配置指向正确路径(默认为.ssh/authorized_keys)
5、为待登录的普通用户预先部署SSH公钥至其家目录下的.ssh/authorized_keys文件中
四、新建普通用户并配置免密切换权限
该方法在禁用root远程登录后,保障运维人员仍能高效获取root权限,避免因频繁输入密码导致操作中断,同时维持最小权限原则。
1、创建新普通用户,例如test:
useradd -m -s /bin/bash test
2、为该用户设置密码:
passwd test
3、将用户加入wheel组(CentOS/RHEL)或sudo组(Ubuntu/Debian):
usermod -aG wheel test
4、编辑sudoers文件:
visudo
5、取消以下行的注释(或添加该行):
%wheel ALL=(ALL) NOPASSWD: ALL
6、保存退出,此时test用户可通过sudo su -直接切换至root而无需再次输入密码
五、重启SSH服务并验证配置生效
所有配置变更必须通过重启SSH守护进程才能加载,否则修改将不产生实际效果。重启前应保持当前会话活跃,以防配置错误导致完全失联。
1、根据系统类型执行对应重启命令:
systemctl restart sshd(适用于CentOS 7+/Ubuntu 16.04+)
2、若系统为旧版(如CentOS 6),则执行:
service sshd restart
3、新开一个终端窗口,尝试以root身份连接:
ssh root@服务器IP
4、确认返回错误信息为Permission denied, please try again.或连接被拒绝
5、使用已授权的普通用户登录,验证是否可正常接入并执行sudo命令
# ai
# 多个
# 基础上
# 重启
# 适用于
# 设为
# 配置文件
# word
# linux
# centos
# ubuntu
# linux系统
# ssh
# debian
# try
# bash
# 普通用户
# 输入密码
# 远程登录
# vim
# 公钥
相关栏目:
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
AI推广<?muma echo $count; ?>
】
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
SEO优化<?muma echo $count; ?>
】
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
技术百科<?muma echo $count; ?>
】
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
谷歌推广<?muma echo $count; ?>
】
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
百度推广<?muma echo $count; ?>
】
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
网络营销<?muma echo $count; ?>
】
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
案例网站<?muma echo $count; ?>
】
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
精选文章<?muma echo $count; ?>
】
相关推荐
- php打包exe怎么传递参数_命令行参数接收方法【
- Win11色盲模式怎么开_Win11屏幕颜色滤镜设
- Go语言中正确反序列化多个同级XML元素为结构体切
- C#如何在一个XML文件中查找并替换文本内容
- mac怎么分屏_MAC双屏显示与分屏操作技巧【指南
- Win11怎么关闭触摸键盘图标_Windows11
- Linux怎么修改用户密码_Linux系统pass
- php下载安装选zip还是msi格式_两种安装包对
- Python与OpenAI接口集成实战_生成式AI
- Windows10电脑怎么设置虚拟光驱_Win10
- PHP主流架构怎么处理表单验证_规则与自定义【技巧
- Python对象比较与排序_魔术方法解析【教程】
- 如何使用Golang配置安全开发环境_防止敏感信息
- Win10如何备份注册表_Win10注册表备份步骤
- 微信企业付款回调PHP怎么接收_处理企业付款异步通
- Windows10电脑怎么设置自动连接WiFi_W
- 如何将文本文件中的竖排字符串转换为横排字符串
- Python函数接口稳定性_版本演进解析【指导】
- Python项目维护经验_长期演进说明【指导】
- Win11开机自检怎么关闭_跳过Win11开机磁盘
- PHP主流架构怎么监控运行状态_工具推荐【操作】
- Python高性能计算项目教程_NumPyCyth
- Mac如何将HEIC图片格式转为JPG_Mac批量
- PythonFastAPI项目实战教程_API接口
- 如何在Golang中实现CI/CD流水线自动化测试
- c# 在高并发下使用反射发射(Reflection
- 如何在 Go 中可靠地测试含 time.Time
- php订单日志怎么按状态筛选_php筛选不同状态订
- Python模块的__name__属性如何由导入方
- Linux如何挂载新硬盘_Linux磁盘分区格式化
- Python变量绑定机制_引用模型解析【教程】
- 如何使用Golang管理模块版本_Golanggo
- 如何在Golang中解压文件_Golang com
- php下载安装后memory_limit怎么设置_
- Windows11怎么用“记事本”自动换行与编码
- 如何在Golang中实现并发消息队列消费者_Gol
- Win11如何添加/删除输入法 Win11切换中英
- C++中引用和指针有什么区别?(代码说明)
- Win11怎么开启游戏模式_Windows11优化
- MAC怎么在照片中添加水印_MAC自带编辑工具文字
- Windows10电脑怎么设置电源按钮_Win10
- Win11怎么设置ip地址_Windows 11手
- Python实现图数据库操作_Neo4j核心CRU
- Windows10如何彻底关闭自动更新_Win10
- Win11怎么关闭自动调节屏幕亮度_Windows
- Win11怎么开启自动HDR画质_Windows1
- Win11怎么设置按流量计费_Win11限制后台流
- Windows10系统怎么查看系统版本_Win10
- c++如何判断文件是否存在_c++ filesys
- php订单日志权限怎么设_php订单日志文件权限设

QQ客服