squid可以用来作为代理服务器软件,由于公司网络限制,使用代理来访问github
1. 安装squid
# rpm -qa | grep squid
squid-3.3.8-26.el7_2.4.x86_64 // 表示安装过
yum -y install squid // 安装
squid开机自启动-非必须
systemctl enable squid.service
配置squid
sudo vim /etc/squid/squid.conf
找到
http_access deny all
在之前添加下面数行内容
# 使用basic用户名密码验证规则
auth_param basic program /usr/lib64/squid/basic_ncsa_auth /etc/squid/passwd
# 最多用户5个
auth_param basic children 5
# 连接代理服务器时的回显信息
auth_param basic realm aliyun proxy
# 认证超时时间
auth_param basic credentialsttl 2 hours
# 用户需要认证,用户名为myproxy,用户名可以自己修改
acl myproxy proxy_auth REQUIRED
# myproxy用户放开http访问
http_access allow myproxy
增加2句隐藏真实ip变成匿名代理 这是squid 3.1的写法
via off
forwarded_for delete
如果想要修改代理的端口号,在配置文件中找到http_prot配置项,修改端口号即可,默认为3128端口:
http_port 3128
squid 用户名密码认证
使用apache 携带的工具htpasswd生成密码文件并添加相应的用户信息
默认htpasswd工具未安装,可以通过指令yum install httpd-tools
安装以后就有htpasswd工具了
使用命令生成用户名和密码信息,myproxy
是上面你设置的用户名:
htpasswd -c /etc/squid/passwd myproxy
根据提示输入密码即可,htpasswd会在/etc/squid/passwd文件中写入一行配置信息,用户名和md5过的密码
配置代理时输入密码为原密码,不是md5值
启动服务
sudo systemctl start squid.service
可以使用命令netstat -ntpl查看服务是否起来了
# netstat -ntpl | grep 3128
tcp6 0 0 :::3128 :::* LISTEN 29764/(squid-1)
给浏览器firefox设置代理
选项 -> 常规 -> 网络设置 -> 设置...
,进去选择手动代理配置
,在HTTP代理
和HTTPS 代理
中填上你的ip地址和代理配置的端口号(默认3128),勾选上底下的如果密码已保存,不提示身份验证
,即可
随便访问一个网页,会弹出输入密码的窗口,填上你的用户名(上面的例子是myproxy)和密码(明文密码,不是生成的md5值),即可访问网络
给git bash配置代理
在目录C:\Users\你的用户名\.ssh
目录下新建config文件,追加上代理指令
ProxyCommand "C:\Program Files\Git\mingw64\bin\connect.exe" -H 127.0.0.1:1234 %h %p
C:\Program Files\Git\mingw64\bin\connect.exe
是git bash安装路径,-H
表示使用http代理,127.0.0.1:1234
是代理服务器的ip地址和端口号
在git bash窗口下使用ssh git@github.com -vT
可以测试代理服务器是否起作用,v表示显示调试信息