问题描述
在github上找了一个Agent&Server项目,将Agent部署在华为云服务器,Server跑在windows上,想要用Server操纵被代理的云服务器,但是出现连接超时问题
解决思路
基于TCP的Socket 编程进行的是端到端的通信,也就是说需要知道Agent代理主机的ip地址,以及Agent的应用进程端口号。
所以怀疑可能是ip地址或端口号出了问题
排查过程
首先在Agent部署的云服务器上使用lsof命令查看Agent的应用进程端口号(对应外部主机要连接的端口号)
可以看到该端口号处于基于 TCP 协议的 Socket 程序函数调用过程中的listen状态,正在监听网络中来自其他主机的TCP连接。所以Agent程序正常启动且端口号也没有问题
端口号没有问题,就只能是ip的问题了,根本没有找到对应的主机,突然想起来这应该是和其他主机想要连接云服务器的mysql服务是一样的,需要到云服务器安全组开放对应端口号
至此问题已经解决,如果说是使用虚拟机的话,只要开放防火墙中对应端口,或者直接关闭防火墙(不安全)就可以了
开放防火墙对应端口命令:firewall-cmd --zone=public --add-port=9200/tcp --permanent
命令含义:
–zone #作用域
–add-port=9200/tcp #添加端口,格式为:端口/通讯协议
–permanent #永久生效,没有此参数重启后失效
关闭防火墙命令:systemctl stop firewalld