2015-09-15 06:04:18 -04:00
|
|
|
|
# V2Ray 简明教程
|
|
|
|
|
|
|
|
|
|
## 工作机制
|
|
|
|
|
|
|
|
|
|
你需要至少两个 Point Server(设为 A、B)才可以正常穿墙。以网页浏览为例,你的浏览器和 A 以 Socks 5 协议通信,B 和目标网站之间以 HTTP 协议通信,A 和 B 之间使用 V2Ray 的自有协议 [VMess](https://github.com/V2Ray/v2ray-core/blob/master/spec/vmess.md) 通信,如下图:
|
|
|
|
|
|
|
|
|
|
![](https://github.com/V2Ray/v2ray-core/blob/master/spec/v2ray.png)
|
|
|
|
|
|
|
|
|
|
通常 Point A 运行在你自己的电脑,Point B 运行在一台海外的 VPS 中。
|
|
|
|
|
|
|
|
|
|
## 安装 V2Ray Point Server
|
|
|
|
|
[安装 V2Ray](https://github.com/V2Ray/v2ray-core/blob/master/spec/install.md)
|
|
|
|
|
|
|
|
|
|
## 配置 V2Ray Point Server
|
|
|
|
|
### Point A
|
|
|
|
|
示例配置保存于 vpoint_socks_vmess.json 文件中,格式如下:
|
|
|
|
|
```javascript
|
|
|
|
|
{
|
|
|
|
|
"port": 1080, // 监听端口
|
|
|
|
|
"inbound": {
|
|
|
|
|
"protocol": "socks", // 传入数据所用协议
|
|
|
|
|
"file": "in_socks.json" // socks 配置文件
|
|
|
|
|
},
|
|
|
|
|
"outbound": {
|
|
|
|
|
"protocol": "vmess", // 中继协议
|
|
|
|
|
"file": "out_vmess.json" // vmess 配置文件
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
另外还需要两个文件,保存于同一文件夹下:
|
|
|
|
|
|
|
|
|
|
```javascript
|
|
|
|
|
// in_socks.json
|
|
|
|
|
{
|
|
|
|
|
"auth": "noauth" // 认证方式,暂时只支持匿名
|
2015-10-04 17:39:59 -04:00
|
|
|
|
"udp": false // 如果要使用 UDP 转发,请改成 true
|
2015-09-15 06:04:18 -04:00
|
|
|
|
}
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
```javascript
|
|
|
|
|
// out_vmess.json
|
|
|
|
|
{
|
|
|
|
|
"vnext": [
|
|
|
|
|
{
|
2015-09-15 07:02:01 -04:00
|
|
|
|
"address": "127.0.0.1", // Point B 的 IP 地址,IPv4 或 IPv6,不支持域名
|
2015-09-19 05:55:59 -04:00
|
|
|
|
"port": 27183, // Point B 的监听端口,请更换成其它的值
|
2015-09-15 06:04:18 -04:00
|
|
|
|
"users": [
|
2015-09-19 05:55:59 -04:00
|
|
|
|
{"id": "ad937d9d-6e23-4a5a-ba23-bce5092a7c51"} // 用户 ID,必须包含在 Point B 的配置文件中。此 ID 将被用于通信的认证,请自行更换随机的 ID,可以使用 https://www.uuidgenerator.net/ 来生成新的 ID。
|
2015-10-04 17:39:59 -04:00
|
|
|
|
],
|
|
|
|
|
"network": "tcp" // 如果要使用 UDP 转发,请改成 "tcp,udp"
|
2015-09-15 06:04:18 -04:00
|
|
|
|
}
|
|
|
|
|
]
|
|
|
|
|
}
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
### Point B
|
|
|
|
|
示例配置保存于 vpoint_vmess_freedom.json 文件中,格式如下:
|
|
|
|
|
```javascript
|
|
|
|
|
{
|
2015-09-19 05:55:59 -04:00
|
|
|
|
"port": 27183, // 监听端口,必须和 out_vmess.json 中指定的一致
|
2015-09-15 06:04:18 -04:00
|
|
|
|
"inbound": {
|
2015-09-19 05:55:59 -04:00
|
|
|
|
"protocol": "vmess", // 中继协议,不用改
|
2015-09-15 06:04:18 -04:00
|
|
|
|
"file": "in_vmess.json" // vmess 配置文件
|
|
|
|
|
},
|
|
|
|
|
"outbound": {
|
2015-09-19 05:55:59 -04:00
|
|
|
|
"protocol": "freedom", // 出口协议,不用改
|
2015-09-15 06:04:18 -04:00
|
|
|
|
"file": "" // 暂无配置
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
另外还需要 in_vmess.json:
|
|
|
|
|
```javascript
|
|
|
|
|
// in_vmess.json
|
|
|
|
|
{
|
|
|
|
|
"clients": [
|
2015-09-19 05:55:59 -04:00
|
|
|
|
{"id": "ad937d9d-6e23-4a5a-ba23-bce5092a7c51"} // 认可的用户 ID,必须包含 out_vmess.json 中的用户 ID
|
2015-10-04 17:39:59 -04:00
|
|
|
|
],
|
|
|
|
|
"udp": false // 如果要使用 UDP 转发,请改成 true
|
2015-09-15 06:04:18 -04:00
|
|
|
|
}
|
|
|
|
|
```
|
|
|
|
|
|
2015-09-18 13:54:01 -04:00
|
|
|
|
### 其它
|
2015-09-19 05:55:59 -04:00
|
|
|
|
* V2Ray 的用户验证基于时间,请确保 A 和 B 所在机器的系统时间误差在一分钟以内。
|
|
|
|
|
* json 配置文件实际上不支持注释(即“//”之后的部分,在使用时请务必删去)。
|
2015-09-18 13:54:01 -04:00
|
|
|
|
|
2015-09-15 06:04:18 -04:00
|
|
|
|
## 运行
|
|
|
|
|
|
|
|
|
|
Point Server A
|
|
|
|
|
|
|
|
|
|
./server --config="vpoint_socks_vmess.json 的绝对路径"
|
|
|
|
|
|
|
|
|
|
Point Server B
|
|
|
|
|
|
|
|
|
|
./server --config="vpoint_vmess_freedom.json 的绝对路径"
|
|
|
|
|
|
2015-09-24 06:54:10 -04:00
|
|
|
|
## 测试服务器可用性
|
2015-09-15 06:04:18 -04:00
|
|
|
|
|
|
|
|
|
curl -v --socks5-hostname 127.0.0.1:1080 https://www.google.com/
|
|
|
|
|
|
2015-09-24 06:54:10 -04:00
|
|
|
|
## 调试
|
|
|
|
|
|
|
|
|
|
使用过程中遇到任何问题,请参考[错误信息](https://github.com/V2Ray/v2ray-core/blob/master/spec/errors.md)。
|