Linux如何修改SSH默认的22端口?

在Linux系统中,修改SSH服务的默认端口号22是提升服务器安全性的常见操作,可有效防止自动化扫描和暴力破解攻击,以下是详细的修改步骤及注意事项,涵盖不同Linux发行版的操作差异。

linux 如何修改22

修改SSH默认端口的操作步骤

备份SSH配置文件

修改前务必备份原始配置文件,避免操作失误导致服务异常,以CentOS/Ubuntu为例,执行以下命令:

sudo cp /etc/ssh/sshd_config /etc/ssh/sshd_config.bak

编辑SSH配置文件

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

sudo vi /etc/ssh/sshd_config

找到以下行(可能被注释,需取消):

#Port 22

将其修改为自定义端口(建议选择1024以上的端口,避免与系统服务冲突,例如2222),并确保新端口未被占用(可通过netstat -tuln | grep 端口号检查),若需同时保留22端口供临时测试,可新增一行:

Port 22
Port 2222

保存文件后退出(vi中按wq)。

linux 如何修改22

配置防火墙规则

不同Linux发行版的防火墙工具不同,需分别设置允许新端口的访问:

  • CentOS (使用firewalld)

    sudo firewall-cmd --permanent --add-port=2222/tcp  # 添加永久规则
    sudo firewall-cmd --reload  # 重载防火墙
  • Ubuntu (使用ufw)

    sudo ufw allow 2222/tcp  # 允许2222端口
    sudo ufw reload  # 重载防火墙

下表总结了不同发行版的防火墙配置命令差异:

发行版 防火墙工具 添加端口命令 重载规则命令
CentOS 7+ firewalld firewall-cmd --permanent --add-port=端口号/tcp firewall-cmd --reload
Ubuntu 18.04+ UFW ufw allow 端口号/tcp ufw reload

重启SSH服务

使配置生效,重启SSH服务:

linux 如何修改22

sudo systemctl restart sshd  # CentOS/RHEL
sudo systemctl restart ssh   # Ubuntu/Debian

验证修改结果

  • 检查端口监听状态
    netstat -tuln | grep 2222  # 应显示LISTEN状态
  • 测试新端口连接
    在本地终端使用新端口远程登录:

    ssh -p 2222 username@服务器IP

    若连接成功,说明修改成功;若失败,检查防火墙规则、SSH配置文件语法(sshd -t)及SELinux设置(CentOS需执行sudo setsebool -P ssh_port_t 1)。

注意事项

  1. 端口选择:避免使用1-1024的特权端口及常见服务端口(如80、443),防止冲突。
  2. 避免锁 out:修改前确保有其他方式登录服务器(如控制台),或先保留22端口测试,确认无误后再关闭22端口。
  3. SELinux配置:若开启SELinux,需执行semanage port -a -t ssh_port_t -p tcp 2222添加新端口标签。

相关问答FAQs

Q1:修改SSH端口后无法连接,可能的原因有哪些?
A:常见原因包括:① 防火墙未开放新端口;② SSH配置文件语法错误(可通过sshd -t检查);③ SELinux阻止新端口访问(需执行semanage port添加端口);④ 服务器安全组(如云服务器ECS/VPC)未开放新端口,建议依次排查以上项,并使用telnet IP 端口号测试端口连通性。

Q2:是否可以同时监听多个SSH端口?
A:可以,在/etc/ssh/sshd_config中添加多行Port指令即可,

Port 22
Port 2222
Port 8022

重启SSH服务后,客户端可通过任意指定端口连接,但需注意,每增加一个端口都需在防火墙和安全组中开放相应规则,避免安全风险。

原创文章,发布者:酷番叔,转转请注明出处:https://cloud.kd.cn/ask/22096.html

(0)
酷番叔酷番叔
上一篇 2025年9月9日 07:54
下一篇 2025年9月9日 08:09

相关推荐

  • Linux系统如何制作启动盘?步骤与工具方法详解

    在Linux系统制作启动盘是安装操作系统、进行系统救援或运行Live环境的基础操作,其核心是将Linux系统镜像文件(ISO)写入可移动存储设备(如U盘),使设备具备引导功能,以下是详细的操作步骤、工具选择及注意事项,帮助用户顺利完成启动盘制作,准备工作在开始制作启动盘前,需确保以下准备工作就绪:Linux系统……

    2025年9月9日
    3200
  • firewalld状态怎么查?

    firewalld是Linux系统的动态防火墙管理工具,支持区域划分、服务定义,允许运行时更新规则并区分运行时与永久配置。

    2025年7月7日
    5000
  • Linux如何启用IPv6?

    在Linux系统中启用IPv6(互联网协议第6版)是应对IPv4地址枯竭、提升网络性能的重要操作,尤其对于需要访问IPv6-only服务的环境至关重要,以下是详细的启用步骤,涵盖系统配置、网络接口设置及服务验证等关键环节,检查内核IPv6支持现代Linux发行版默认已内置IPv6内核模块,可通过以下命令确认支持……

    2025年10月8日
    1300
  • Linux系统中如何切换中英文输入?

    在Linux系统中,中英文切换是日常使用中常见的需求,主要分为图形界面和命令行环境两种场景,图形界面下的切换通常依赖输入法框架和桌面环境设置,而命令行环境则通过系统语言变量实现,以下从不同场景出发,详细介绍具体操作方法,图形界面下的中英文切换图形界面的中英文切换主要涉及输入法切换(中文输入法与英文键盘模式切换……

    2025年10月1日
    1200
  • 软件包该更新了吗?

    在 Linux 系统中开启 GD 库(用于图像处理的扩展库)主要涉及 PHP 环境的配置,以下是详细操作指南,适用于主流 Linux 发行版:GD 库的作用GD 库是 PHP 的核心图像处理扩展,用于生成/处理图片(如验证码、水印、缩略图等),常见应用场景:WordPress/Drupal 等 CMS 的图片处……

    2025年7月26日
    4400

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

联系我们

400-880-8834

在线咨询: QQ交谈

邮件:HI@E.KD.CN

关注微信