端口访问被拒绝的解决方案

端口访问被拒绝的解决方案

ps:本人亲测,阿里云2核4G5M的服务器性价比很高,新用户一块多一天,老用户三块多一天,最高可以买三年,感兴趣的可以戳一下:阿里云折扣服务器

问题描述:
比如在本机telent到192.168.8.170 主机的9000 端口,被拒绝。
[zhu@hadoop log]$ telnet 192.168.8.170 9000 
Trying 192.168.8.170... 
telnet: connect to address 192.168.8.170: Connection refused 原因:原因有两个
  ● 一个是被防火墙拦截
  ● 或者该端口的监听地址为本机(127.0.0.1),如果这样的话,只有从本机发起的对端口的访问被允许,而外部主机访问被拒绝。可以通过“netstat -anp | grep 9000”命令查看该端口的监听地址:
       [zhu@hadoop log]$ netstat -anp | grep 9000 
(Not all processes could be identified, non-owned process info
will not be shown, you would have to be root to see it all.)
tcp 0 0 ::ffff:127.0.0.1:9000 :::* LISTEN 6614/java
tcp 0 0 ::ffff:127.0.0.1:46722 ::ffff:127.0.0.1:9000 TIME_WAIT -
tcp 0 0 ::ffff:127.0.0.1:46729 ::ffff:127.0.0.1:9000 TIME_WAIT -
tcp 0 0 ::ffff:127.0.0.1:46723 ::ffff:127.0.0.1:9000 ESTABLISHED 6733/java
tcp 0 0 ::ffff:127.0.0.1:46726 ::ffff:127.0.0.1:9000 TIME_WAIT -
tcp 0 0 ::ffff:127.0.0.1:46730 ::ffff:127.0.0.1:9000 ESTABLISHED 6976/java
tcp 0 0 ::ffff:127.0.0.1:9000 ::ffff:127.0.0.1:46730 ESTABLISHED 6614/java
tcp 0 0 ::ffff:127.0.0.1:9000 ::ffff:127.0.0.1:46723 ESTABLISHED 6614/java
有上图可知,9000端口监听的地址为本地地址(127.0.0.1)

解决方法:
  ● 如果防火墙过滤了访问该端口的请求则设置过滤规则,放行该端口或者关闭防火墙
  ● 如果监听地址为本机地址则修改其监听地址为真是ip地址(如192.168.8.119)。
比如在hadoop中,可以更改本机地址(eg:localhost——>hadoop),然后在/etc/hosts配置文件中加入主机hadoop和ip 192.168.8.119的映射关系,然后修改core-site.xml中fs.default.name的值为"hdfs://hadoop:9000"。

总结:
1、先从A服务器(telnet IP 端口)这样测试B服务器的端口,发现访问被拒绝

2、查看B服务器的该端口是否有服务(netstat -apn|grep 该端口)

3、如果没有服务,则启动该端口上的服务,如果有,则查看该服务的监听IP

上图说明该服务的监听IP是所有IP


上图说明该服务的监听IP是本地IP,所以会拒绝其他IP访问

4、如果监听IP是本地IP,则需要配置监听IP为A服务器的IP,这样A服务器才能正常访问B服务器该服务及端口
### EMQX 8083 端口访问被拒的原因分析 EMQX 的 8083 端口通常用于 WebSocket 协议连接,允许通过浏览器或其他支持 WebSocket 的客户端与 MQTT Broker 进行通信[^1]。如果遇到 8083 端口访问拒绝的情况,可能由以下几个原因引起: #### 1. **防火墙或安全组配置** 如果服务器上启用了防火墙或者云服务提供商的安全组规则未开放 8083 端口,则外部请求会被阻止。可以通过以下命令检查并调整防火墙设置: ```bash sudo firewall-cmd --list-all sudo firewall-cmd --add-port=8083/tcp --permanent sudo firewall-cmd --reload ``` #### 2. **Docker 映射端口冲突** 在使用 Docker 启动容器时,如果宿主机上的其他进程占用了目标端口(如 RabbitMQ 使用了默认的 1883 和 8083),则需要重新映射端口号[^3]。例如,在启动容器时可以将 8083 映射到另一个可用端口(如 58083)。 #### 3. **WebSocket 功能未启用** 默认情况下,EMQX 可能并未开启 WebSocket 支持。可以在 `emqx.conf` 文件中确认以下配置项是否存在并已正确设置: ```conf listener.websocket.8083 = 0.0.0.0:8083 ``` 若该监听器未定义或地址绑定错误,需手动添加上述配置[^4]。 #### 4. **权限不足** 某些操作系统可能会限制非特权用户绑定低于 1024 的端口。尽管 8083 超过此范围,但如果尝试绑定低优先级网络接口也可能失败。此时可考虑更改绑定 IP 地址为具体网卡地址而非通配符 `0.0.0.0`。 --- ### 解决方法总结 针对以上提到的各种可能性,以下是具体的解决方案: - **检查防火墙/安全组**:确保宿主机和云端环境均放开了对应端口流量。 - **验证 Docker 参数**:运行容器时注意指定正确的 `-p` 参数以完成端口转发操作;若有冲突应合理规划替代数值。 - **审查配置文件**:打开 `/etc/emqx/emqx.conf` 查找关于 websocket 部分的内容,并依据实际需求调整其状态以及参数细节[^2]^。 - **测试连通性工具**:利用 telnet 或 netstat 命令检测本地机器能否正常抵达所设定的服务位置点比如执行如下指令查看是否有相应进程正在监听特定端口: ```bash netstat -tuln | grep :8083 ``` 最后重启服务使改动生效后再试一次原先的操作流程看问题是否得到妥善处理。 ```python import socket def test_port(host='localhost', port=8083): sock = socket.socket(socket.AF_INET, socket.SOCK_STREAM) result = sock.connect_ex((host, port)) if result == 0: print(f"Port {port} is open.") else: print(f"Port {port} is closed or unreachable.") test_port() ```
评论 8
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值