0

0

CentOS怎么访问别的端口_CentOS端口查看与远程访问配置教程

雪夜

雪夜

发布时间:2025-08-29 10:18:01

|

822人浏览过

|

来源于php中文网

原创

要实现CentOS端口远程访问,需依次确认服务监听、防火墙放行和SELinux策略。首先用ss -tulnp | grep LISTEN检查服务是否监听目标端口,确保绑定地址为0.0.0.0或外部IP;接着通过firewall-cmd --zone=public --add-port=端口/tcp --permanent开放防火墙端口并重载;若仍无法访问,排查SELinux是否阻止,可使用semanage port添加端口上下文或临时设为宽容模式测试;同时确认云平台安全组或路由器已配置端口转发,客户端使用正确IP和端口通过telnet或curl测试连通性。

centos怎么访问别的端口_centos端口查看与远程访问配置教程

在CentOS系统上访问其他端口,核心在于确保目标服务正在监听该端口,并且CentOS的防火墙(通常是

firewalld
)允许外部流量通过该端口。远程访问则需要客户端知道CentOS机器的IP地址和正确的端口号,同时CentOS本身的SELinux策略也可能需要调整。

解决方案

要实现CentOS端口的查看与远程访问配置,我们需要系统性地处理几个环节:首先确认服务是否已启动并监听在目标端口;其次,配置系统防火墙以允许外部连接;最后,检查SELinux是否对端口访问造成了限制。

首先,我们得确认目标服务确实在运行,并且监听了你期望的那个端口。很多时候,大家会忘记服务本身都没启动,或者配置错了监听地址(比如只监听了

127.0.0.1
)。你可以用
netstat
ss
命令快速查看。

如果服务已经监听,下一步就是调整防火墙。CentOS 7及更高版本默认使用

firewalld
。你需要用
firewall-cmd
命令来开放端口。记住,开放端口后一定要重新加载防火墙配置,否则改动不会生效。

最后,别忘了SELinux。它是一个强大的安全机制,但也可能在无形中阻止了你对某些端口的访问。如果前面两步都没问题,但还是无法访问,那很有可能就是SELinux在作祟。你可以暂时将其设置为宽容模式进行测试,或者为你的服务端口添加正确的SELinux上下文。

如何查看CentOS系统当前开放了哪些端口?

要搞清楚CentOS系统上哪些端口正被监听、哪些服务正在使用它们,这其实是诊断任何网络问题的起点。我个人习惯用

netstat
,因为它功能强大且信息量足,但
ss
命令在现代Linux系统上效率更高,尤其是在处理大量连接时。

最常用的命令是:

netstat -tulnp | grep LISTEN

或者,如果你更喜欢

ss

ss -tulnp | grep LISTEN

这两个命令会列出所有处于“LISTEN”(监听)状态的TCP和UDP端口,以及对应的进程ID(PID)和程序名称。

  • -t
    显示TCP连接。
  • -u
    显示UDP连接。
  • -l
    仅显示监听状态的套接字。
  • -n
    以数字形式显示地址和端口号,避免进行域名解析,加快显示速度。
  • -p
    显示使用套接字的进程信息。

通过输出,你可以清楚地看到哪个进程(

PID/Program name
列)正在监听哪个IP地址(
Local Address
列)的哪个端口。例如,如果看到
0.0.0.0:80
,这意味着Apache或Nginx正在监听所有网络接口的80端口。如果看到
127.0.0.1:3306
,那MySQL可能只允许本地连接。

有时候,如果想更细致地查看某个特定端口的情况,你可以直接在

grep
后面加上端口号,比如:

ss -tulnp | grep 8080

这能帮助你快速定位到你关心的那个端口是否被占用,以及是被哪个服务占用的。

CentOS防火墙(firewalld)怎么开放指定端口以允许远程访问?

在CentOS上,

firewalld
是管理防火墙规则的利器。它的设计哲学是区域(zones),这让安全策略的配置变得更加灵活和易于管理。通常,我们处理的远程访问都涉及到
public
区域。

要开放一个端口,例如8080端口,你需要执行以下命令:

sudo firewall-cmd --zone=public --add-port=8080/tcp --permanent

这里:

  • --zone=public
    指定了规则应用到
    public
    区域。这是最常见的对外开放区域。
  • --add-port=8080/tcp
    告诉
    firewalld
    开放TCP协议的8080端口。如果你需要开放UDP端口,将
    tcp
    改为
    udp
  • --permanent
    意味着这条规则会在系统重启后依然生效。如果你不加这个参数,规则只在当前会话有效,重启后就会丢失。

添加规则后,非常关键的一步是重新加载防火墙配置,让新的规则立即生效:

sudo firewall-cmd --reload

你也可以通过以下命令来验证端口是否已经成功开放:

通义万相
通义万相

通义万相,一个不断进化的AI艺术创作大模型

下载
sudo firewall-cmd --zone=public --list-ports

这会列出

public
区域中所有已开放的端口。如果你看到
8080/tcp
在列表中,那么恭喜你,防火墙这一关算是过了。

对于一些常见的服务,

firewalld
甚至提供了预定义的服务(services),比如HTTP、HTTPS、SSH等。直接添加服务会比添加端口更方便,因为它会处理所有相关的端口和协议。例如,开放HTTP服务(默认80端口):

sudo firewall-cmd --zone=public --add-service=http --permanent
sudo firewall-cmd --reload

选择添加端口还是添加服务,取决于你的具体需求。如果你的服务运行在一个非标准端口上,那就老老实实地添加端口;如果是标准服务,用服务名会更简洁。

为什么我开放了端口但还是无法从远程访问CentOS服务?

这绝对是很多人在配置远程访问时会遇到的“鬼打墙”问题。你明明按照教程把端口开了,防火墙也重载了,但从外部就是连不上。别急,这背后通常有几个常见的原因,我们得逐一排查。

1. 服务本身没有监听在正确的IP或端口上: 这是最常见也最容易被忽视的问题。防火墙只是允许流量通过,但如果你的服务压根就没启动,或者它只监听了

127.0.0.1
(本地回环地址),那么外部流量即便能穿过防火墙,也找不到对应的服务。

  • 排查方法: 再次使用
    ss -tulnp | grep YOUR_PORT
    命令。仔细查看
    Local Address
    一列。如果你看到
    127.0.0.1:YOUR_PORT
    ,那么服务就只监听本地。你需要修改服务本身的配置文件,让它监听
    0.0.0.0
    (所有接口)或者你的服务器对外IP地址。
  • 举例: Nginx或Apache的
    listen
    指令,MySQL的
    bind-address
    参数等。

2. SELinux的阻挠: SELinux(Security-Enhanced Linux)是CentOS的一道额外安全屏障,它比防火墙更深入地控制进程对系统资源的访问。即使防火墙放行了端口,SELinux也可能阻止某个服务在非标准端口上运行,或者阻止它接收网络连接。

  • 排查方法: 检查SELinux日志(
    sudo tail -f /var/log/audit/audit.log
    sudo journalctl -t selinux
    ),看是否有
    denied
    的日志条目。
  • 解决方案:
    • 临时禁用(不推荐生产环境):
      sudo setenforce 0
      。如果此时能访问,说明是SELinux的问题。
    • 永久配置(推荐): 为你的服务端口添加SELinux上下文。例如,如果你想让HTTP服务在8080端口运行:
      sudo semanage port -a -t http_port_t -p tcp 8080
      sudo systemctl restart your_service # 重启服务以应用SELinux策略

      你需要根据你的服务类型选择正确的

      _port_t
      类型。如果不知道,可以查看
      /etc/selinux/targeted/modules/active/ports.conf
      或使用
      semanage port -l
      列出已知的端口类型。

3. 中间网络设备(路由器、公司防火墙)的阻挡: 你的CentOS服务器可能处于一个更大的网络环境中,比如家庭路由器后面、企业防火墙之后,或者云服务提供商的安全组/网络ACL。这些设备本身可能有自己的防火墙规则,阻止了外部对你CentOS端口的访问。

  • 排查方法:
    • 如果你在云上,检查你的云服务商的安全组(Security Group)或网络ACL(Network Access Control List),确保它们允许来自外部IP的流量访问你的CentOS实例的对应端口。
    • 如果你在内网,检查你的路由器或上级防火墙是否做了端口转发(Port Forwarding)或端口映射(Port Mapping),将外部请求转发到你的CentOS服务器的内部IP和端口。
  • 解决方案: 配置这些中间设备的规则,允许流量通过。

4. 客户端连接问题: 最后,也要确保你从客户端连接时使用的IP地址、端口号和协议都是正确的。

  • 排查方法:
    • 使用
      telnet
      nc
      (netcat)从客户端测试连通性。例如:
      telnet YOUR_CENTOS_IP YOUR_PORT
      。如果连接成功(通常会显示
      Connected to ...
      ),说明网络和服务器端口都是通的,问题可能出在应用层。如果连接超时或拒绝,那很可能就是上面提到的网络或服务器配置问题。
    • 对于Web服务,尝试
      curl http://YOUR_CENTOS_IP:YOUR_PORT

解决这类问题需要一点耐心,一步步地缩小范围,通常都能找到症结所在。

如何让CentOS上的服务监听特定的IP地址或所有接口?

服务的监听地址配置,直接决定了它能响应哪些网络请求。默认情况下,很多服务可能会被配置为只监听

127.0.0.1
(即localhost),这意味着它们只能接收来自CentOS本机内部的连接请求。要允许远程访问,服务必须监听在
0.0.0.0
(代表所有可用的网络接口)或者服务器的特定对外IP地址。

这个配置通常在服务的主配置文件中进行。不同的服务,其配置文件和参数名都不一样,但核心思想是类似的。

常见服务的配置示例:

  1. Apache HTTP Server (httpd):

    httpd.conf
    或其包含的配置文件中,查找
    listen
    指令。

    • 监听所有接口的80端口:
      Listen 0.0.0.0:80

      或者简单地:

      Listen 80

      (当只指定端口时,Apache默认监听所有接口。)

    • 监听特定IP地址的80端口:
      Listen 192.168.1.100:80
  2. Nginx:

    nginx.conf
    或其
    sites-available
    目录下的虚拟主机配置文件中,查找
    listen
    指令。

    • 监听所有接口的80端口:
      listen 80;

      listen 0.0.0.0:80;
    • 监听特定IP地址的80端口:
      listen 192.168.1.100:80;
  3. MySQL/MariaDB:

    my.cnf
    (通常在
    /etc/my.cnf
    /etc/mysql/my.cnf.d/
    中)中,查找
    bind-address
    参数。

    • 监听所有接口:
      bind-address = 0.0.0.0

      (注意:这在生产环境中可能存在安全风险,除非有其他安全措施。)

    • 监听特定IP地址:
      bind-address = 192.168.1.100
    • 只监听本地(默认或常见配置):
      bind-address = 127.0.0.1

配置后的操作:

修改完服务的配置文件后,务必重启服务,以使更改生效。 例如:

sudo systemctl restart httpd
sudo systemctl restart nginx
sudo systemctl restart mysqld # 或 mariadb

重启后,再次使用

ss -tulnp | grep YOUR_PORT
命令来确认服务是否已经按照你的配置监听在正确的IP地址上。如果一切顺利,你应该能看到服务监听在
0.0.0.0
或你指定的对外IP上,这样外部客户端才能成功连接。

相关专题

更多
mysql修改数据表名
mysql修改数据表名

MySQL修改数据表:1、首先查看数据库中所有的表,代码为:‘SHOW TABLES;’;2、修改表名,代码为:‘ALTER TABLE 旧表名 RENAME [TO] 新表名;’。php中文网还提供MySQL的相关下载、相关课程等内容,供大家免费下载使用。

664

2023.06.20

MySQL创建存储过程
MySQL创建存储过程

存储程序可以分为存储过程和函数,MySQL中创建存储过程和函数使用的语句分别为CREATE PROCEDURE和CREATE FUNCTION。使用CALL语句调用存储过程智能用输出变量返回值。函数可以从语句外调用(通过引用函数名),也能返回标量值。存储过程也可以调用其他存储过程。php中文网还提供MySQL创建存储过程的相关下载、相关课程等内容,供大家免费下载使用。

246

2023.06.21

mongodb和mysql的区别
mongodb和mysql的区别

mongodb和mysql的区别:1、数据模型;2、查询语言;3、扩展性和性能;4、可靠性。本专题为大家提供mongodb和mysql的区别的相关的文章、下载、课程内容,供大家免费下载体验。

281

2023.07.18

mysql密码忘了怎么查看
mysql密码忘了怎么查看

MySQL是一个关系型数据库管理系统,由瑞典MySQL AB 公司开发,属于 Oracle 旗下产品。MySQL 是最流行的关系型数据库管理系统之一,在 WEB 应用方面,MySQL是最好的 RDBMS 应用软件之一。那么mysql密码忘了怎么办呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

514

2023.07.19

mysql创建数据库
mysql创建数据库

MySQL是一个关系型数据库管理系统,由瑞典MySQL AB 公司开发,属于 Oracle 旗下产品。MySQL 是最流行的关系型数据库管理系统之一,在 WEB 应用方面,MySQL是最好的 RDBMS 应用软件之一。那么mysql怎么创建数据库呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

253

2023.07.25

mysql默认事务隔离级别
mysql默认事务隔离级别

MySQL是一种广泛使用的关系型数据库管理系统,它支持事务处理。事务是一组数据库操作,它们作为一个逻辑单元被一起执行。为了保证事务的一致性和隔离性,MySQL提供了不同的事务隔离级别。php中文网给大家带来了相关的教程以及文章欢迎大家前来学习阅读。

386

2023.08.08

sqlserver和mysql区别
sqlserver和mysql区别

SQL Server和MySQL是两种广泛使用的关系型数据库管理系统。它们具有相似的功能和用途,但在某些方面存在一些显著的区别。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

529

2023.08.11

mysql忘记密码
mysql忘记密码

MySQL是一种关系型数据库管理系统,关系数据库将数据保存在不同的表中,而不是将所有数据放在一个大仓库内,这样就增加了速度并提高了灵活性。那么忘记mysql密码我们该怎么解决呢?php中文网给大家带来了相关的教程以及其他关于mysql的文章,欢迎大家前来学习阅读。

599

2023.08.14

PS使用蒙版相关教程
PS使用蒙版相关教程

本专题整合了ps使用蒙版相关教程,阅读专题下面的文章了解更多详细内容。

23

2026.01.19

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Rust 教程
Rust 教程

共28课时 | 4.6万人学习

PostgreSQL 教程
PostgreSQL 教程

共48课时 | 7.5万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号