在Centos7下搭建Socks5代理服务器
什么是socket5(ss5、sk5,同下文)?
网络上的两个程序通过一个双向的通信连接实现数据的交换,这个连接的一端称为一个socket。
如图所示:
建立网络通信连接至少要一对端口号(socket)。socket本质是编程接口(API),对TCP/IP的封装,TCP/IP也要提供可供程序员做网络开发所用的接口,这就是Socket编程接口;HTTP是轿车,提供了封装或者显示数据的具体形式;Socket是发动机,提供了网络通信的能力。
Socket的英文原义是"孔"或"插座"。作为BSD UNIX的进程通信机制,取后一种意思。通常也称作"套接字",用于描述IP地址和端口,是一个通信链的句柄,可以用来实现不同虚拟机或不同计算机之间的通信。在Internet上的主机一般运行了多个服务软件,同时提供几种服务。每种服务都打开一个Socket,并绑定到一个端口上,不同的端口对应于不同的服务。
Socket正如其英文原意那样,像一个多孔插座。一台主机犹如布满各种插座的房间,每个插座有一个编号,有的插座提供220伏交流电, 有的提供110伏交流电,有的则提供有线电视节目。 客户软件将插头插到不同编号的插座,就可以得到不同的服务。
在Centos7下搭建Socks5代理服务器方法教程
依赖包 gcc gcc-c++ automake make pam-devel openldap-devel cyrus-sasl-devel openssl-devel
下载地址 http://ss5.sourceforge.net/
解压编译
tar zxvf ss5-3.8.9-8.tar.gz cd ss5-3.8.9 ./configure make make install
启动脚本加执行权限
chmod +x /etc/init.d/ss5
设置监听端口
vi /etc/sysconfig/ss5 # Add startup option here SS5_OPTS=" -u root -b 0.0.0.0:6666"
启动服务
systemctl start ss5
qq测试
如需使用用户名密码登录,修改配置文件中的两行
vi /etc/opt/ss5/ss5.conf auth 0.0.0.0/0 - u permit u 0.0.0.0/0 - 0.0.0.0/0 - - - - -
设置用户名和密码,一个用户和密码一行,用空格间隔
vi /etc/opt/ss5/ss5.passwd user1 123 user2 123
重启服务生效
service ss5 restart
启动SS5
1、赋予脚本启动权限
chmod u+x /etc/rc.d/init.d/ss5
chmod +x /etc/init.d/ss5
2、开机启动SS5
chkconfig --add ss5 # 可选加入开机启动
chkconfig --level 345 ss5 on # 可选启用开机启动
systemctl restart ss5 # Centos7是用systemctl来启动服务的
常用命令
systemctl status ss5 # 查看SOCKS服务状态
systemctl restart ss5 # 重新启动服务
systemctl stop ss5 # 停止服务
systemctl start ss5 # 启动服务
ps -ef|grep ss5 # 查看进程
netstat -ntlp # 列出所有端口
netstat -tunlp | grep 1080 # 查看当前端口是什么服务占用
netstat -napo | grep 12345 | wc -l # 查看Socket连接数
性能调优
调整内核参数,优化性能,以实现4G内存的vps跑10万个socket5代理连接
ulimit -SHn 10240
ulimit -SHs unlimited
echo 500000 >/proc/sys/net/nf_conntrack_max
(教程仅供参考,禁止用于非法用途)
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:niceseo99@gmail.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。
评论