安装***

首先安装pip:

curl -LO "https://bootstrap.pypa.io/get-pip.py"
python get-pip.py

通过pip安装***:

$ pip install shadowsocks

$ vi /etc/shadowsocks.json
# 添加以下内容
{
  "server":        "123.45.67.89",    # ***服务器的IP
  "server_port":   "1234",            # ***服务器的端口
  "local_address": "127.0.0.1",       # 本机监听地址,不需要修改
  "local_port":    "5678",            # 本机监听端口,可以指定1024到65535之间的数字,和正在监听的端口不冲突即可
  "password":      "your_password",   # ***服务器的密码
  "method":        "aes-256-cfb",     # ***服务器的加密方式
  "timeout":       "300",
  "workers":       "1"
}

  

启动***:

# 以 daemon 模式启动 sslocal
sslocal -c /etc/shadowsocks.json -d start

# 确认 sslocal 已监听在预设端口
lsof -i | grep sslocal

# 开机启动
sh -c 'echo "sudo /usr/bin/sslocal -c /etc/shadowsocks.json -d start" >> /etc/rc.d/rc.local'

# 如果 rc.local 没有可执行权限就给它加上
if [ ! -x '/etc/rc.d/rc.local' ]; then
  chmod +x '/etc/rc.d/rc.local'
else
  echo 'rc.local already is executable!'
fi

  

测试***代理

***提供的代理是socks5类型,使用curl来测试代理是否生效:

$ curl --socks5 127.0.0.1:5678 http://httpbin.org/ip
{
  "origin": "123.45.67.89"       # 必须与 /etc/shadowsocks.json 中 server 字段的值相同
}

  

把socks5代理转换为http/https代理

许多命令仅支持http/https代理,不支持socks5代理,此时需要使用Privoxy把socks5代理转换为http/https代理。

安装Privoxy

# EPEL仓库已收录Privoxy
yum install -y privoxy

  

配置Privoxy

$ vi /etc/privoxy/config

# 确认下面这一行没有被注释掉
listen-address  127.0.0.1:8118
## 默认端口是8118,不需要修改

# 新增一行
forward-socks5t / 127.0.0.1:5678 .
## 端口必须与 /etc/shadowsocks.json 中 local_port 字段的值相同,
## 注意:行尾有一个英文句号(.)

  

启动Privoxy

systemctl start privoxy
ss -tnlp | grep :8118

# 开机启动
systemctl enable privoxy

  

测试Privoxy代理

$ curl --proxy https://127.0.0.1:8118 -Is https://google.com | grep -w 200
HTTP/1.1 200 Connection established

  

访问Google,返回的HTTP状态码是200,说明可以正常访问,证明https代理已经生效。

更方便的使用代理

并不是所有命令都像curl这样包含了设置代理的选项,即使有代理选项,每次执行命令都要输入也非常麻烦,其实还有更简单方便的用法。

临时启用代理

export http_proxy='127.0.0.1:8118'
export https_proxy='127.0.0.1:8118'

# 停用代理
export http_proxy=''
export https_proxy=''

  

设置shell函数快速启用代理

vi /etc/profile.d/vm-proxy.sh

  

粘贴以下内容:

function vm-proxy-on {
  export no_proxy="127.0.0.1,localhost,localaddress,.localdomain.com,tencentyun.com";
  export http_proxy='127.0.0.1:8118';
  export https_proxy=$http_proxy;
  echo 'HTTP proxy started.'
}
export -f vm-proxy-on

# 第二种声明函数的方式
vm-proxy-off() {
  unset http_proxy;
  unset https_proxy;
  echo 'HTTP proxy stopped.'
}
export -f vm-proxy-off

  

然后source文件:
chmod +x /etc/profile.d/vm-proxy.sh
source /etc/profile.d/vm-proxy.sh

  

此时就可以非常方便的启用或停用代理了:

$ vm-proxy-on
HTTP proxy started.

$ echo $https_proxy
127.0.0.1:8118

$ vm-proxy-off
HTTP proxy stopped.

  

原文出处链接:

https://liyang85.com/all-centos-7-command-line-tools-use-shadowsocks-and-privoxy-to-access-internet

使用***客户端和Privoxy让所有CentOS 7命令行工具通过代理访问互联网(转载)的更多相关文章

  1. CentOS 6 命令行下安装 VirtualBox 虚拟机步骤

    CentOS 6 命令行下安装 VirtualBox 虚拟机步骤 1. 准备工作 安装内核更新 yum install kernel-develyum update kernel*如果内核有更新,则需 ...

  2. Linux(CentOS 7)命令行模式安装VMware Tools 详解

    本篇文章主要介绍了如何在Linux(CentOS 7)命令行模式安装VMware Tools,具有一定的参考价值,感兴趣的小伙伴们可以参考一下. 本例中为在Linux(以CentOS 7为例)安装VM ...

  3. 其他综合-CentOS 7 命令行显示优化

    CentOS 7 命令行显示优化 1.实验描述 通过 CentOS 7.6 的显示优化,为实现命令行显示提供良好视觉体验. [基于此文章的环境]点我快速打开文章 2.实验环境 使用软件的版本:VMwa ...

  4. 屹今为止最好用的HTTP客户端命令行工具-接口调试神器HTTPie

    一.思考❓❔ 1.你用过哪些http客户端调试工具? Postman 不够灵活 需要打开客户端, 麻烦 学习成本高 Jmeter 臃肿 麻烦 学习成本高 curl 参数多, 记不住 不够灵活 主要在L ...

  5. CentOS 7 命令行安装TeamViewer

    由于要通过要远程登录到内网的电脑(一台笔记本),用于在紧急情况下处理服务器故障.刚开始准备使用ssh端口转发,无奈vps转发速度太慢. 后面考虑使用TeamViewer远程控制Windows桌面,但是 ...

  6. centos/redhat命令行上传下载文件

    前言:客户端上没有安装xftp,winscp等等软件,无法将服务器上需要的文件下载到本地去解析,无法将本地的安装包上传到服务器上去,这个时候命令行就可以带你翱翔一波 配置如下: 服务器上: 1.安装需 ...

  7. CentOS 7命令行安装图形界面(GNOME、KDE等)

    CentOS 7 默认是没有图形化界面的,但我们很多人在习惯了 Windows 的图形化界面之后,总是希望有一个图形化界面从而方便我们使用,这里介绍一下 CentOS7安装图形化桌面系统的方法. 一. ...

  8. 30. CentOS终端命令行显示中文乱码的解决方法

    安装CentOS的时候选择了中文,结果在终端不能显示中文,都是乱码,解决方法:修改/etc/sysconfig/i18n,内容为   代码如下: LANG="zh_CN.GB18030&qu ...

  9. CentOS 7命令行安装GNOME、KDE图形界面(成功安装验证)

    来源:cnblogs.com/Amedeo  作者:Amedeo 正文 CentOS 7 默认是没有图形化界面的,但我们很多人在习惯了 Windows 的图形化界面之后,总是希望有一个图形化界面从而方 ...

随机推荐

  1. poj 2186 强连通+缩点

    题意:有一群牛,求被所有牛都认可的牛的个数 每个连通分量建一个缩点,出度为零的缩点包含的点的个数即为要求值 如果有多个出度为零的,直接输出零,否则输出那唯一一个出度为零的缩点包含的点的个数 #incl ...

  2. SCU - 4117 - Discover

    先上题目: D - Discover Time Limit:0MS     Memory Limit:0KB     64bit IO Format:%lld & %llu Submit St ...

  3. 通过PYTHON操作JIRA的COMMENT注释和TRANSITION工作流

    这是目前我们的自动化部署系统要作的,所以先实现吧. >>> from jira import JIRA >>> authed_jira = JIRA(server= ...

  4. redis--周边知识点

    一般Redis服务器内存超过128G内存的机器是非常少的 很少在redis中缓存视频,除非是快播,一般都是缓存文本字段 redis可视化的工具和SQL的管理工具是不一样的,最好是使用REDIS的she ...

  5. mysql 服务器监控系列-黄杉 mysqldba

    http://blog.csdn.net/mchdba/article/category/2220809

  6. 【机房收费系统C#版】——导出Excel

    前言 机房合作開始好长了一段时间.反重复复开了几次会,项目也是一拖再拖,作为组长.有80%的责任都在于我.为了不让这个项目陪着我过春节.要求自己一定要在这几天敲完. 还是一样的问题,用C#敲,从一開始 ...

  7. HDU 2830 Matrix Swapping II (预处理的线性dp)

    Matrix Swapping II Time Limit: 9000/3000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Other ...

  8. 打造终端下mutt收发邮件环境(fbterm,fetchmail,msmtp,procmail,mutt)

    实现mutt下收发邮件须要安装,mutt,fbterm,fetchmail,msmtp,procmail 下面是各配置文件.在home文件夹下,隐私信息有马赛克... .muttrc : 当中Mail ...

  9. POJ 3628 Bookshelf 2 题解

    本题解法非常多,由于给出的数据特殊性故此能够使用DFS和BFS,也能够使用01背包DP思想来解. 由于一般大家都使用DFS,这里使用非常少人使用的BFS.缺点是比DFS更加耗内存,只是长处是速度比DF ...

  10. luogu3807 【模板】 卢卡斯定理

    题目大意 对于一个很大的$n,m,p$如何求$C_{n+m}^m\mod p$? Lucas定理 若$n_i,m_i$分别是$n,m$在$p$进制下第$i$位的数字,则有 $$C_n^m\mod p= ...