CentOS7增加或修改SSH端口号

CentOS7增加或修改SSH端口号

https://blog.csdn.net/ausboyue/article/details/53691953

 

前言:开启某服务或软件的端口,要从该服务或软件监听的端口(多以修改配置文件为主),SeLinux和防火墙(FireWall)的安全策略下手。如果使用阿里云,腾讯等第三方服务器还需要对管理控制台的安全组下手。

 

下面进入主题,如果有什么问题请查看下面的补充栏:

第一步:修改SSH配置文件(注意是sshd_config而不是ssh_config,多了个d)

[plain]
view plain
copy

  1. vim /etc/ssh/sshd_config  

找到“#Port 22”,这一行直接键入“yyp”复制该行到下一行,然后把两行的“#”号即注释去掉,修改成:

Port 22

Port 10086

SSH默认监听端口是22,如果你不强制说明别的端口,”Port 22”注不注释都是开放22访问端口。上面我保留了22端口,防止之后因为各种权限和配置问题,导致连22端口都不能访问了,那就尴尬了。等一切都ok了,再关闭22端口。

Ok,继续,我增加了10086端口,大家修改端口时候最好挑10000~65535之间的端口号,10000以下容易被系统或一些特殊软件占用,或是以后新应用准备占用该端口的时候,却被你先占用了,导致软件无法运行。

第二步:如果你关闭了SELinux可以忽略第二步。

先查看SELinux开放给ssh使用的端口

[plain]
view plain
copy

  1. semanage port -l|grep ssh  

我的系统打印如下:

ssh_port_t                    tcp      22

可知,SELinux没有给SSH开放10086端口,那么我们来添加该端口:

[plain]
view plain
copy

  1. semanage port -a -t ssh_port_t -p tcp 10086  

完成后,再次查看

[plain]
view plain
copy

  1. semanage port -l|grep ssh  

ssh_port_t                    tcp      22,10086

第三步:如果你关闭了防火墙,可以忽略第三步,话说防火墙不开启太危险了,建议开启。

先查看防火墙是否开启了10086端口:

[plain]
view plain
copy

  1. firewall-cmd –permanent–query-port=10086/tcp  

打印结果如下:

no

表示没有开放10086端口,那么添加下该端口:

[plain]
view plain
copy

  1. firewall-cmd –permanent–add-port=10086/tcp  

打印结果如下:

success

重新加载防火墙策略:

[plain]
view plain
copy

  1. firewall-cmd –reload  

执行成功后,查看10086端口是否被开启:

[plain]
view plain
copy

  1. firewall-cmd –permanent–query-port=10086/tcp  

打印结果如下:

yes

第四步:重启SSH服务和防火墙,最好也重启下服务器

[plain]
view plain
copy

  1. systemctl restart sshd  
  2. systemctl restart firewalld.service  
  3. shutdown -r now  

第五步:尝试通过10086端口登录SSH,或者进入该服务器直接本地访问SSH如下:

[plain]
view plain
copy

  1. ssh root@localhost -p 10086  

如果成功,说明10086已经完全可以使用了,接下来你就可以根据上述步骤把sshd_config的Port22注释掉,SELinux和防火墙(Firewalld关闭22端口就OK,大工造成!

以下2017.11.27 补充更新———>

 第六步:修改第三方服务器安全组策略。如果没有第三方服务器,上述已经完成了本文的目标,可以忽略第六步。下面直接上阿里云的示例图:

CentOS7增加或修改SSH端口号

 

补充栏—————————————————————————–

 

1.查看某端口是否被占用,以10086为例:

[plain]
view plain
copy

  1. netstat -lnp|grep 10086  

如果没有任何打印,说明没有被占用。有打印的话,说明被占用了,一般会列出哪个进程占用。

 

2.查看是否开启了SELinux

[plain]
view plain
copy

  1. sestatus -v  

如果输出结果为:

SELinux status:                 disabled

说明有打开,可以通过修改SELinux的配置开启或关闭它:

[plain]
view plain
copy

  1. vim /etc/selinux/config  

找到:

SELINUX=disabled

修改成:

SELINUX=enforcing

重启一下,就OK。

 

3.semanage命令无法使用,或说找不到该命令。说明没有配置该命令,可以进行以下命令进行安装:

[plain]
view plain
copy

  1. yum -y installpolicycoreutils-python-2.5-9.el7.x86_64  

关于它的依赖库我就不作赘述,可以百度下更全面的安装semanage教程。

4.CentOS7防火墙改为firewalld了,而不是iptables,对应的命令也请百度下,这里不作赘述。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/113420.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)


相关推荐

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号