Linux下代理服务器(proxy)配置
Linux下有很多程序都只有命令行接口,对于这类程序,它们通过代理服务器(proxy)访问网络的方式也不尽相同。在本文中Easwy总结了一些常用Linux程序配置代理服务器的方法。
[ 通用代理服务器配置 ]
对于大多数Linux控制台程序,例如Debian或Ubuntu中的apt-get和aptitude命令、git命令、wget命令,这些程序都使用http_proxy和ftp_proxy环境变量来获取代理服务的配置。
方法是在你的~/.bashrc里加上类似下面的话:
export http_proxy=http://username:password@proxyserver:port/ export ftp_proxy=http://username:password@proxyserver:port/
如果你的代理服务器需要用户名和密码才能访问,需要填写上面的username和passwd部分,否则的话,省略这两部分。
例如,假设你的代理服务器为192.168.1.1,端口是8080,用户名为easwy,密码是123456,那么应该这样设置这两个环境变量:
export http_proxy=http://easwy:123456@192.168.1.1:8080 export ftp_proxy=http://easwy:123456@192.168.1.1:8080
这样配置之后,退出再登录一次,或者直接使用下面的命令source一下.bashrc:
source ~/.bashrc
现在,上述程序就可以通过代理服务器访问网络了。
[ subversion的代理服务器配置 ]
要配置subversion的代理服务器,需要修改$HOME/.subversion/servers文件,在此文件的[global]段加上:
http-proxy-host = 192.168.1.1 http-proxy-port = 8080 http-proxy-username = easwy http-proxy-password = 123456
现在svn就可以使用代理服务器访问版本库了。
[ yum的代理服务器配置 ]
如果想让CentOS中的yum可以通过代理服务器更新程序,则需要修改文件/etc/yum.conf,在此文件中加上:
proxy=http://easwy:123456@192.168.1.1:8080
有些局域网环境上网需要使用代理上网,图形界面的很好解决就设置一下浏览器的代理就好了,但是Linux纯命令行的界面就需要手动配置了。
如果要全局用户使用应用于所有的Shell,就需要修改 /etc/profile 文件
1 # vi /etc/profile
在文件中添加以下配置
1 http_proxy=proxy.abc.com:8080 2 https_proxy=$http_proxy 3 ftp_proxy=user:password@proxy.abc.com:8080 4 no_proxy=*.abc.com,10.*.*.*,192.168.*.*,*.local,localhost,127.0.0.1 5 export http_proxy https_proxy ftp_proxy no_proxy
其中:
http_proxy:http协议使用代理服务器地址;
https_proxy:https协议使用安全代理地址;
ftp_proxy:ftp协议使用代理服务器地址;
user:代理使用的用户名;
password:代理使用用户名的密码;
proxy.abc.com:代理地址,可以是IP,也可以是域名;
8080:使用的端口;
no_proxy:不使用代理的主机或IP。
保存退出,注销重新登陆系统即可生效。
此方法只适合配置http代理,使用socket代理上网的另有其他配置方法。
server端需要安装、配置shadowsocks,启动ss-server
1,安装shadowsocks
|
1
2
|
yum install python-pippip install shadowsocks |
2,配置shadowsocks
创建shadowsocks配置文件
|
1
2
3
4
5
6
7
8
9
10
|
[root@AliCloudInstance opt]# cat /etc/shadowsocks.json{"server":"47.91.1xx.1xx","server_port":10666,"local_port":1080,"password":"MyPassWord","timeout":600,"method":"aes-256-cfb"}[root@AliCloudInstance opt]# |
3,启动ss-server
可以同步命令行使用ss-server指定配置文件直接启动
|
1
|
ssserver -c /etc/shadowsocks.json |
不过还是推荐放到supervisor中启动,如果没有supervisor,通过yum或者pip安装下即可
|
1
2
3
4
5
6
7
8
9
|
[root@AliCloudInstance opt]# tail -7 /etc/supervisord.conf[program:shadowsocks]command=ssserver -c /etc/shadowsocks.jsonautostart=trueautorestart=trueuser=rootlog_stderr=truelogfile=/var/log/shadowsocks.log[root@AliCloudInstance opt]# |
shadowsocks服务端到此配置结束,启动后会监听上面配置的端口,此时就可以通过各种ss客户端进行连接使用了。
|
1
2
3
4
5
|
[root@AliCloudInstance opt]# ss -lntup|grep ssserverudp UNCONN 0 0 *:56925 *:* users:(("ssserver",5497,6))udp UNCONN 0 0 47.91.1xx.1xx:10666 *:* users:(("ssserver",5497,4))tcp LISTEN 0 128 47.91.1xx.1xx:10666 *:* users:(("ssserver",5497,3))[root@AliCloudInstance opt]# |
Client端
cilent端需要安装、配置shadowsocks,启动sslocal,安装配置polipo或者proxychains
1,安装、配置shadowsocks(同server端)
|
1
2
|
yum install python-pippip install shadowsocks |
2,配置shadowsocks
创建shadowsocks配置文件
|
1
2
3
4
5
6
7
8
9
10
|
[root@thatsit opt]# cat /etc/shadowsocks.json{"server":"47.91.1xx.1xx","server_port":10666,"local_port":1080,"password":"MyPassWord","timeout":600,"method":"aes-256-cfb"}[root@thatsit opt]# |
3,启动ss客户端
|
1
2
3
4
5
|
[root@thatsit polipo]# sslocal -c /etc/shadowsocks.json -d startINFO: loading config from /etc/shadowsocks.json2017-02-28 23:06:48 INFO loading libcrypto from libcrypto.so.10started[root@thatsit polipo]# |
启动之后,本地会监听一个tcp的1080端口和一个udp的1080端口
|
1
2
3
4
|
[root@thatsit polipo]# ss -lntup|grep sslocaludp UNCONN 0 0 127.0.0.1:1080 *:* users:(("sslocal",24079,5))tcp LISTEN 0 128 127.0.0.1:1080 *:* users:(("sslocal",24079,4))[root@thatsit polipo]# |
4,安装polipo将socks5协议转为http协议
Shadowsocks使用socks5协议,而终端很多工具目前只支持http和https等协议,所以我们为终端设置Shadowsocks的思路就是将socks5协议转换成http协议,然后为终端设置即可。
①安装polipo(github地址:https://github.com/jech/polipo)
|
1
2
3
4
|
git clone https://github.com/jech/polipo.gitcd polipomake allmake install |
②配置polipo
|
1
2
3
4
5
6
7
|
[root@thatsit polipo]# cat /etc/polipo/configsocksParentProxy = "127.0.0.1:1080"socksProxyType = socks5logFile = /var/log/polipologLevel = 99logSyslog = true[root@thatsit polipo]# |
polipo -v 可以查看支持的选项
③启动polipo:
|
1
|
/root/polipo/polipo -c /etc/polipo/config |
polipo监听8123端口
|
1
2
3
|
[root@thatsit polipo]# ss -lntup|grep polipotcp LISTEN 0 128 127.0.0.1:8123 *:* users:(("polipo",23399,5))[root@thatsit polipo]# |
④添加http_proxy环境变量,实现全局代理
当前会话生效
|
1
|
export http_proxy=http://localhost:8123 |
取消此环境变量,关闭代理
|
1
|
unset http_proxy |
同时可以将下面环境变量设置的语句添加到/etc/profile、~/.bashrc等文件来实现更大的代理范围
|
1
|
export http_proxy=http://127.0.0.1:8123 |
⑤测试
|
1
2
3
|
[root@thatsit ~]# curl ip.gs当前 IP:47.91.1xx.1xx 来自:美国加利福尼亚州圣克拉拉 阿里云[root@thatsit ~]# |
Linux下代理服务器(proxy)配置的更多相关文章
- Linux下安装和配置JDK与Tomcat(升级版)
在这个版本 Linux下安装和配置JDK与Tomcat(入门版) 的基础上优化升级 1.下载相关软件 apache-tomcat-6.0.37.tar.gz jdk-6u25-linux-i586-r ...
- [Linux]Linux下安装和配置solr/tomcat/IK分词器 详细实例二.
为了更好的排版, 所以将IK分词器的安装重启了一篇博文, 大家可以接上solr的安装一同查看.[Linux]Linux下安装和配置solr/tomcat/IK分词器 详细实例一: http://ww ...
- Linux下Redis服务器安装配置
说明:操作系统:CentOS1.安装编译工具yum install wget make gcc gcc-c++ zlib-devel openssl openssl-devel pcre-devel ...
- Linux下SVN服务器安装配置及客户端安装说明
原文地址:http://wenku.baidu.com/link?url=h3dVAMx4azpOXEND5HQEE6nliE8-zc0GSQ03yv4cUs1vXMALXF64UsK7kT7kXm_ ...
- linux下通过acl配置灵活目录文件权限(可用于ftp,web服务器的用户权限控制)
linux下通过acl配置灵活目录文件权限(可用于ftp,web服务器的用户权限控制) 发表于2012//07由feng linux 本身的ugo rwx的权限,对于精确的权限控制很是力不从心的,ac ...
- linux下golang的配置
linux下golang的配置 之前开发golang一直在windows下,今天在linux下试了一下 ,遇到一些梗,比如go 找不到 sync包.花了一小时全部解决,把过程记录一下. 安装 go 我 ...
- 转载-Linux下svn搭建配置流程
Linux下svn搭建配置流程 一. 源文件编译安装.源文件共两个,为: 1. 下载subversion源文件 subversion-1.6.1.tar.gz http://d136 ...
- Linux下PHP安装配置MongoDB数据库连接扩展
Web服务器: IP地址:192.168.21.127 PHP安装路径:/usr/local/php 实现目的: 安装PHP的MongoDB数据库扩展,通过PHP程序连接MongoDB数据库 具体操作 ...
- Linux下安装与配置Nginx
一.准备 Nginx版本:nginx-1.7.7.tar.gz 请自行到官网下载对应的版本. 二.步骤 ♦在Linux新建一个queenLove用户 [root@localhost /]# use ...
随机推荐
- HashMap与TreeMap的区别?
HashMap与TreeMap的区别? 解答:HashMap通过hashcode对其内容进行快速查找,而TreeMap中所有的元素都保持着某种固定的顺序,如果你需要得到一个有序的结果你就应该使用Tre ...
- java锁和同步
Java 语言设计中的一大创新就是:第一个把跨平台线程模型和锁模型应用到语言中去,Java 语言包括了跨线程的关键字synchronized 和 volatile,使用关键字和java类库就能够简单的 ...
- WHERE字句
structured query language(非过程性的结构查询语言) 主要内容: 数据库怎么限制里面的数据: 数据库怎么排列里面的数据. WHERE子句: --WHERE字句起到的是对数据库查 ...
- Django - admin后台、auth权限
admin后台 一.创建一个管理员用户 (1).设置时区.语言(可选步骤) 打开settings.py,改成下面那样 LANGUAGE_CODE = 'zh-Hans' TIME_ZONE = 'As ...
- SqlBulkCopy 通过泛型数组批量插入
public void SqlBulkCopy<T>(string tablename, List<T> list) { Type recordType = typeof(T) ...
- Android 生成keystore,两种方式
一.eclipse 中生成android keystore 建立任意一个android项目(例如:AntForAndroid) 右键AntForAndroid根目录弹出菜单->Android T ...
- 中间件MQ选型要点
转载自: https://www.cnblogs.com/doit8791/p/10227474.html 参考: http://www.52im.net/thread-1647-1-1.html ...
- 2015-03-10——简析javascript对象
对于构造函数,它是Function对象的一个实例,可以定义自己的静态成员先实例化出对象,后执行function中内部代码 静态成员: var abc = function () {}; //既是一 ...
- win7下设置smtp的方法
在win7中开启SMTP服务的方法如下: 1. 首先确定是否开启IIS服务:在运行中输入“inetmgr”,若提示出错,则表明未安装.进入步骤2,否则进入步骤3: 2.打开控制面板->程序-&g ...
- 解决ajax无法给js全局变量赋值的问题
解决ajax无法给js全局变量赋值的问题 http://blog.csdn.net/qq_26222859/article/details/51543433 在ajax中是无法给js中的全局变量赋值的 ...