From ca490df8e1c501fbbe4f401854d8b1821bcf1daf Mon Sep 17 00:00:00 2001 From: "arraykeys@gmail.com" Date: Mon, 11 Sep 2017 19:13:54 +0800 Subject: [PATCH] Signed-off-by: arraykeys@gmail.com --- README.md | 60 +++++++++++++++++++++++++++++++++++++++++++++++++ install.sh | 36 +++++++++++++++++++++++++++++ install_auto.sh | 32 ++++++++++++++++++++++++++ uninstall.sh | 4 ++++ 4 files changed, 132 insertions(+) create mode 100644 README.md create mode 100755 install.sh create mode 100755 install_auto.sh create mode 100644 uninstall.sh diff --git a/README.md b/README.md new file mode 100644 index 0000000..fb28283 --- /dev/null +++ b/README.md @@ -0,0 +1,60 @@ +# goproxy +快速使用: +提示:所有操作需要root权限. + +0.如果你的VPS是linux64位的系统,那么只需要执行下面一句,就可以完成自动安装和配置. +# wget https://github.com/snail007/goproxy/blob/master/install_auto.sh -O - | sh + + + +如果你的vps不是linux64位系统,请按照下面的半自动步骤安装: +1.登录你的VPS,下载守护进程monexec,选择合适你的版本,vps一般选择"linux_amd64.tar.gz"的即可. +下载地址:https://github.com/reddec/monexec/releases +比如下载到/root/proxy/ +执行: +# mkdir /root/proxy/ +# cd /root/proxy/ +# wget https://github.com/reddec/monexec/releases/download/v0.1.1/monexec_0.1.1_linux_amd64.tar.gz +2.下载proxy +下载地址:https://github.com/snail007/goproxy/releases +# cd /root/proxy/ +# wget https://github.com/snail007/goproxy/blob/master/release-2.0/proxy-linux-amd64.tar.gz +3.下载自动安装脚本 +# cd /root/proxy/ +# wget https://github.com/snail007/goproxy/blob/master/install.sh +# chmod +x install.sh +# ./install.sh + + +进一步了解: +1、作为普通一级代理。 +默认监听0.0.0.0:33080端口,可以使用-p修改端口,-i修改绑定ip。 +默认情况 +./proxy +指定ip和端口 +./proxy -i 192.168.1.100 -p 60080 + +2、作为普通二级代理。 +可以通过-P指定上级代理,格式是IP:端口 +./proxy -P "192.168.1.100:60080" -p 33080 + +3、作为加密一级代理。 +加密模式的一级代理需要和加密的二级代理配合。 +加密模式需要证书和key文件,在linux上并安装了openssl命令,可以直接通过下面的命令生成证书和key文件。 +./proxy keygen +会在当前目录下面生成一个证书文件proxy.crt和key文件proxy.key。 +比如在你的vps上运行加密一级代理,使用参数-x即可,默认会使用程序相同目录下面的证书文件proxy.crt和key文件proxy.key。 +./proxy -x +或者使用-c和-k指定证书和key文件,ip和端口。 +./proxy -x -c "proxy.crt" -k "proxy.key" -p 58080 + +4、作为加密二级代理。 +加密模式的二级代理需要和加密的一级代理配合。加密模式的二级代理和加密模式的一级代理要使用相同的证书和key文件。 +默认会使用程序相同目录下面的证书文件proxy.crt和key文件proxy.key。 +比如在你的windows电脑上允许二级加密代理,需要-P指定上级代理,同时设置-Ps代表是加密的上级代理。 +假设一级代理vps外网IP是:115.34.9.63。   +./proxy.exe -Ps -P "115.34.9.63:58080" -c "proxy.crt" -k "proxy.key" -p 18080 +然后设置你的windos系统中,需要通过代理上网的程序的代理为http模式,地址为:127.0.0.1,端口为:18080, +然后程序即可通过加密通道通过vps上网。 + +任何使用问题欢迎邮件交流:arraykeys@gmail.com diff --git a/install.sh b/install.sh new file mode 100755 index 0000000..61e59f7 --- /dev/null +++ b/install.sh @@ -0,0 +1,36 @@ +#!/bin/bash +# install monexec +tar zxvf monexec_*.tar.gz +cd monexec_* +cp monexec /usr/bin/ +chmod +x /usr/bin/monexec + +# #install proxy +tar zxvf proxy-*.tar.gz +cd proxy-* +cp proxy /usr/bin/ +cp proxyd /usr/bin/ +chmod +x /usr/bin/proxy +chmod +x /usr/bin/proxyd +if [ ! -e /etc/proxy ]; then + mkdir /etc/proxy + cp proxy.toml /etc/proxy/ +fi + +if [ ! -e /etc/proxy/proxy.crt ]; then + cd /etc/proxy/ + proxy keygen >/dev/null 2>&1 +fi + +if [ ! -e /etc/proxy/blocked ]; then + cd /etc/proxy/ + cp blocked /etc/proxy/ +fi + +if [ ! -e /etc/proxy/direct ]; then + cd /etc/proxy/ + cp direct /etc/proxy/ +fii + +echo "install done" +proxyd \ No newline at end of file diff --git a/install_auto.sh b/install_auto.sh new file mode 100755 index 0000000..083c97e --- /dev/null +++ b/install_auto.sh @@ -0,0 +1,32 @@ +#!/bin/bash + +rm -rf /tmp/proxy +mkdir /tmp/proxy +cd /tmp/proxy +wget https://github.com/reddec/monexec/releases/download/v0.1.1/monexec_0.1.1_linux_amd64.tar.gz +wget https://github.com/snail007/goproxy/blob/master/release-2.0/proxy-linux-amd64.tar.gz + +# install monexec +tar zxvf monexec_*.tar.gz +cd monexec_* +cp monexec /usr/bin/ +chmod +x /usr/bin/monexec + +# #install proxy +tar zxvf proxy-*.tar.gz +cd proxy-* +cp proxy /usr/bin/ +cp proxyd /usr/bin/ +chmod +x /usr/bin/proxy +chmod +x /usr/bin/proxyd +if [ ! -e /etc/proxy ]; then + mkdir /etc/proxy + cp proxy.toml /etc/proxy/ +fi + +if [ ! -e /etc/proxy/proxy.crt ]; then + cd /etc/proxy/ + proxy keygen >/dev/null 2>&1 +fi +echo "install done" +proxyd \ No newline at end of file diff --git a/uninstall.sh b/uninstall.sh new file mode 100644 index 0000000..3f7e9d5 --- /dev/null +++ b/uninstall.sh @@ -0,0 +1,4 @@ +#!/bin/bash +rm -rf /usr/bin/proxy +rm -rf /usr/bin/proxyd +echo "uninstall done"