安装命令:
# 添加EPEL仓库,然后更新yum源:sudo yum install epel-releasesudo yum update# 安装sudo yum install -y tinyproxy修改配置:
vim /etc/tinyproxy/tinyproxy.conf修改 Port 端口,默认为 8888Port 8888注释掉 Allow 127.0.0.1,表示允许所有人访问代理启动服务:service tinyproxy start日志:/var/log/tinyproxy/tinyproxy.log本地测试:curl -x ‘ip:port’ -v icanhazip.com
注意点&坑:
我一开始用的芝麻VPS,到这一步后,在vps上用局域网IP可以通过代理服务器访问,但在本地通过公网IP就无法访问,最后发现是由于外网无法访问该服务器,试过开放端口等操作,无果,云立方的是直接可以通过公网IP使用代理yum安装时,报错:yum doesn’t have enough cached data to continue, 解决办法:将/etc/yum.repos.d/epel.repo中的mirrorlist改为baseurl/etc/resolv.conf文件中增加 nameserver 144.144.144.144在断开重播时,有时adsl-start会执行失败,报错:“/usr/sbin/adsl-start: line 217: 5749 Terminated C O N N E C T " CONNECT " CONNECT"@" > /dev/null 2>&1”,最后发现可能是断开连接的不干净,多执行几次adsl-stop,在执行adsl-start就会成功了在代理服务tinyproxy运行期间,报过这个错:Waiting servers (0) is less than MinSpareServers (5). Creating new child.,原因是达到最大连接数,无法创建新的连接处理请求,代理服务也就挂了,重启代理服务即可,解决办法vim /etc/tinyproxy/tinyproxy.confMaxClients 100 -> 500 # 最大连接数Timeout 600 -> 20 # 超时时间(1) 安装Python Python依赖
sudo yum install yum-utilssudo yum-builddep pythonPython源码连接:https://www.python.org/ftp/python/
curl -O https://www.python.org/ftp/python/3.5.0/Python-3.5.0.tgz我在用curl时无法下载,可以到官网下载指定版本的Python,然后传到服务器上
tar xf Python-3.5.0.tgzcd Python-3.5.0./configuremakesudo make install安装完成后通过python3 -V来查看当前版本
(2) 安装虚拟环境
cd ~mkdir venvcd venvpython3 -m venv python3-forcrawlsource ~/venv/python3-forcrawl/bin/activate(3) 安装相应的python库
pip install requests# 安装其他环境导出的库pip install -r requirements.txtpip install tornadosudo yum install -y redis# 启动服务redis-server >> /dev/null 2>&1 连接redisredis-climongo数据库(可以不进行安装,实现基本的代理功能不需要该库)# yum中没有mongo的下载源,需要手动添加vi /etc/yum.repos.d/mongodb-org-3.4.repo# 写入以下信息,针对centos7[mongodb-org-3.4]name=MongoDB Repositorybaseurl=https://repo.mongodb.org/yum/redhat/7/mongodb-org/3.4/x86_64/gpgcheck=1enabled=1gpgkey=https://www.mongodb.org/static/pgp/server-3.4.asc# 安装sudo yum install -y mongodb-org启动:systemctl start mongod.service注意点&坑:
ssh链接时,报错Permission denied (publickey,gssapi-keyex,gssapi-with-mic),解决办法:通过阿里云web终端登录到服务器,修改ssh配置文件vim /etc/ssh/sshd_config更改:PasswordAuthentication no(默认yes)或打开注释:PermitRootLogin yes1、客户端:动态vps
通过Python执行断开连接&拨号的操作,成功后匹配获取公网IP,通过requests库将IP发送至服务端为了避免恶意干扰,可以加上一个传输秘钥,服务器验证传输秘钥,验证失败的不进行IP更新设置定时任务来实现IP的更换传送的数据中,包含IP、秘钥、name(区分vps服务器)2、服务端:固定IP服务器
使用tornado启动服务,提供两个接口
post接口:接收客户端发送的IP,验证秘钥成功后,以name为key,ip&port为val,存入redisget接口:从redis中取出ip&port并返回代理检测程序:可用于检测IP的可用性,剔除失效IP
版权声明:我们致力于保护作者版权,注重分享,被刊用文章【代理服务器搭建(利用adsl拨号服务器VPS构建代理IP池)】因无法核实真实出处,未能及时与作者取得联系,或有版权异议的,请联系管理员,我们会立即处理! 部分文章是来自自研大数据AI进行生成,内容摘自(百度百科,百度知道,头条百科,中国民法典,刑法,牛津词典,新华词典,汉语词典,国家院校,科普平台)等数据,内容仅供学习参考,不准确地方联系删除处理!;
工作时间:8:00-18:00
客服电话
电子邮件
beimuxi@protonmail.com
扫码二维码
获取最新动态
