SSH端口转发
假定有三台主机A、B、C。由于种种原因(无论是防火墙还是路由原因),AC两台主机之间无法连通。但是B却可以和A、C连通。这时候就可以用本地端口转发来实现A和C通过B来连通。
A 192.168.7.27
B 192.168.6.19
C 192.168.30.68
首先 服务器监听一个本地端口 比如说1085(注意防火墙要开放)
查看端口是否开放
netstat -anop | grep 1085
未开放的话 需要在防火墙设置
centos有两个防火墙firewall和iptables
firewall-cmd --zone=public --add-port=1085/tcp --permanent
iptables -A INPUT -p tcp --dport 1085 -j ACCEPT
都开启呗
接着SSH 转发设置
ssh -f -N -D 127.0.0.1:1085 -p 22 192.168.6.19
以上的意思是监听本地 1085端口,1085端口接收到数据 转发给192.168.6.19 的22端口
php代理curl设置
curl_setopt($ch, CURLOPT_PROXY, "127.0.0.1"); //代理服务器地址
curl_setopt($ch, CURLOPT_PROXYPORT,1085); //代理服务器端口
curl_setopt($ch, CURLOPT_PROXYPORT,1085); //代理服务器端口
curl_setopt($ch,CURLOPT_PROXYTYPE,CURLPROXY_SOCKS5); 协议