一、前言

在我早期的爬墙经历里,我是非常热衷于自己动手造梯子的,并不是说买别人的机场服务不好,而是自己造的梯子稳定性和速度绝对是第一,也极少担心被墙。

来自2021年的更新: 现在自建梯子更推荐应急使用, 主力还是购买机场的服务比较好。

大学在读期间成功申办了一张某银行的 Visa 信用卡,因此褥到了 Google Cloud 的一年半免费试用(第一次申请成功后隔了半年通过 YouTube 上的教程成功重置试用时间,因此总试用时间是一年半)。

眼下,12月份 Google Cloud 的试用就要到期,而最低配机器算上流量费估计每个月也得二三十,对我来说还是蛮昂贵的,因为我除了爬墙就不会用 Google Cloud 的机器做别的事情了。

为了避免12月份之后无梯子可用,今天我尝试了在搬瓦工Centos6下安装并配置V2ray+SSL+TLS+CDN,写下此文作为记录。

二、开始搭建吧

由于我的搬瓦工机器是较早购买的,安装的 CentOS6 系统,并不受 V2ray 官方提供的安装脚本支持,因此在搜索引擎上查找到一份解决方案,记录于此。 (来源:http://bbs.itzmx.com/forum.php?mod=viewthread&tid=89057 )

注意!!此博文更偏向于写给自己看的笔记,因此只描述关键步骤,非关键步骤将会略过

如果某位萌新路人看到了这篇文章,也可以发 email 跟我交流: [email protected]

1、CentOS6 下安装 V2ray

下载&安装官方安装脚本

bash <(curl -L -s https://install.direct/go.sh)

会提示以下报错

Updating software repo
Failed to set locale, defaulting to C
Repository epel is listed more than once in the configuration
Installing daemon
Failed to set locale, defaulting to C
Repository epel is listed more than once in the configuration
Failed to install daemon. Please install it manually.

解决办法 将下述代码保存为/etc/init.d/v2ray

#!/bin/sh
#
# v2ray        Startup script for v2ray
#
# chkconfig: - 24 76
# processname: v2ray
# pidfile: /var/run/v2ray.pid
# description: V2Ray proxy services
#

### BEGIN INIT INFO
# Provides:          v2ray
# Required-Start:    $network $local_fs $remote_fs
# Required-Stop:     $remote_fs
# Default-Start:     2 3 4 5
# Default-Stop:      0 1 6
# Short-Description: V2Ray proxy services
# Description:       V2Ray proxy services
### END INIT INFO

DESC=v2ray
NAME=v2ray
DAEMON=/usr/bin/v2ray/v2ray
PIDFILE=/var/run/$NAME.pid
LOCKFILE=/var/lock/subsys/$NAME
SCRIPTNAME=/etc/init.d/$NAME
RETVAL=0

DAEMON_OPTS="-config /etc/v2ray/config.json"

# Exit if the package is not installed
[ -x $DAEMON ] || exit 0

# Read configuration variable file if it is present
[ -r /etc/default/$NAME ] && . /etc/default/$NAME

# Source function library.
. /etc/rc.d/init.d/functions

start() {
  local pids=$(pgrep -f $DAEMON)
  if [ -n "$pids" ]; then
    echo "$NAME (pid $pids) is already running"
    RETVAL=0
    return 0
  fi

  echo -n $"Starting $NAME: "

  mkdir -p /var/log/v2ray
  $DAEMON $DAEMON_OPTS 1>/dev/null 2>&1 &
  echo $! > $PIDFILE

  sleep 2
  pgrep -f $DAEMON >/dev/null 2>&1
  RETVAL=$?
  if [ $RETVAL -eq 0 ]; then
    success; echo
    touch $LOCKFILE
  else
    failure; echo
  fi
  return $RETVAL
}

stop() {
  local pids=$(pgrep -f $DAEMON)
  if [ -z "$pids" ]; then
    echo "$NAME is not running"
    RETVAL=0
    return 0
  fi

  echo -n $"Stopping $NAME: "
  killproc -p ${PIDFILE} ${NAME}
  RETVAL=$?
  echo
  [ $RETVAL = 0 ] && rm -f ${LOCKFILE} ${PIDFILE}
}

reload() {
  echo -n $"Reloading $NAME: "
  killproc -p ${PIDFILE} ${NAME} -HUP
  RETVAL=$?
  echo
}

rh_status() {
  status -p ${PIDFILE} ${DAEMON}
}

# See how we were called.
case "$1" in
  start)
    rh_status >/dev/null 2>&1 && exit 0
    start
    ;;
  stop)
    stop
    ;;
  status)
    rh_status
    RETVAL=$?
    ;;
  restart)
    stop
    start
    ;;
  reload)
    reload
  ;;
  *)
    echo "Usage: $SCRIPTNAME {start|stop|status|reload|restart}" >&2
    RETVAL=2
  ;;
esac
exit $RETVAL

赋予执行权限,加入开机启动

chmod a+x /etc/init.d/v2ray
chkconfig v2ray on

验证是否能够启动

service v2ray start
启动 v2ray:       [确定]

停止 V2ray 服务

service v2ray stop

2、获取 SSL 证书

证书可以使用 Let's Encrypt 生成,我这里是用的腾讯云的诚信亚洲免费证书,具体流程请询问搜索引擎,这里贴一个申请链接:https://console.cloud.tencent.com/ssl/apply

3、服务器安装 Nginx

具体步骤请询问搜索引擎。

4、配置 V2ray

编辑v2ray配置文件

cd /etc/v2ray
vim config.json

用以下内容替换

{
  "inbounds": [
    {
      "port": 10000, # 请留意此行
      "listen":"127.0.0.1", # 只监听本地,避免被外部扫端口
      "protocol": "vmess",
      "settings": {
        "clients": [
          {
            "id": "", # uuid随机值,可在uuid.online生成
            "alterId": 64
          }
        ]
      },
      "streamSettings": {
        "network": "ws",
        "wsSettings": {
        "path": "/ray" # 请留意此行
        }
      }
    }
  ],
  "outbounds": [
    {
      "protocol": "freedom",
      "settings": {}
    }
  ]
}

配置完毕后启动 v2ray 服务

service v2ray start

5、配置 Nginx 反向代理

首先要上传SSL证书到服务器,步骤略,腾讯云有相关教程。

然后,在 nginx 配置文件加入如下内容

server {
  listen       80;
  server_name  你的域名;
	charset utf8;
	
	rewrite ^(.*)$ https://你的域名$1 permanent;
}

server {
    listen       443;
    server_name  你的域名;
	charset utf8;
	ssl on;
	ssl_certificate /etc/nginx/ssl/1_xxx_bundle.crt; # 改成你的ssl证书目录
	ssl_certificate_key /etc/nginx/ssl/2_xxx.key; # 改成你的ssl目录
	ssl_session_timeout 5m;
	ssl_protocols TLSv1 TLSv1.1 TLSv1.2; # 按照这个协议配置
	ssl_ciphers ECDHE-RSA-AES128-GCM-SHA256:HIGH:!aNULL:!MD5:!RC4:!DHE; # 按照这个套件配置
	ssl_prefer_server_ciphers on;
	
	root         /var/www/xxx/; # 网站目录,此可以用于伪装正常网站,随便放点什么网页在里面
	index index.html index.htm;
	error_page  404 403 500 502 503 504  /404.html;
	
	location /ray { # 此处/ray要与v2ray配置文件里的path对应上
		proxy_redirect off;
        proxy_pass http://127.0.0.1:10000; # 此处10000要与v2ray配置文件里的port对应上
        proxy_http_version 1.1;
        proxy_set_header Upgrade $http_upgrade;
        proxy_set_header Connection "upgrade";
        proxy_set_header Host $http_host;

        # 以下两行可在 v2ray 的 access.log 日志文件里记录真实ip
        proxy_set_header X-Real-IP $remote_addr;
        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
	}

}

配置完毕后重启 nginx 服务

service nginx restart

6、在 cdn 上增加 a 记录,指向这台服务器

cdn 建议使用 cloudflare, 此步骤略,请询问搜索引擎

同时还要配置 cdn 启动 https

7、配置 v2ray 客户端

建议使用图形化客户端,windows 下 可以使用 v2rayN, macOS 下使用 v2rayX, 去 github 上找一下都能找到。这里简述一下 v2rayX 里的关键字段怎么填写:(其实我是懒得截图上传图片)

地址:你的域名

端口:443

alterId: 64 (跟你服务端上v2ray配置文件保持一致)

level: 0

Security: 这是加密方式,随便选,都可以

Network: ws

勾选"使用TLS"

完成了!!!可以上网冲浪了!!

如果访问不了的话,检查一下你本机的时间是否与服务器时间差距过大(不能超过90s)

date #查看当前时间
date -r 13:00:00 #设置时间