Trojan的主页:https://trojan-gfw.github.io/trojan/

步骤一: 购买、部署VPS

推荐使用**Vultr**, 因为“便宜”。

我安装的是“CentOS 8” ,自带了BBR,因此不用再手动设置。

步骤二:申请域名,设置DNS解析,申请证书

我使用的是腾讯云的域名和免费的证书。

步骤三:部署并配置Nginx

1
2
3
4
5
6
yum install nginx
nginx -h # 查看nginx的命令帮助
nginx # 启动nginx
nginx -t # 检查配置文件是否有效
nginx -s stop # 关闭nginx
nginx -s reload # 重新加载配置文件

nginx默认的配置文件在/etc/nginx/nginx.conf

设置防火墙

1
2
3
4
firewall-cmd  --permanent --add-port=80/tcp
firewall-cmd  --permanent --add-port=443/tcp
firewall-cmd --list-port 
    80/tcp 443/tcp  # 配置生效

步骤四:部署并配置Trojan

1
2
3
sudo bash -c "$(curl -fsSL https://raw.githubusercontent.com/trojan-gfw/trojan-quickstart/master/trojan-quickstart.sh)"
或者
sudo bash -c "$(wget -O- https://raw.githubusercontent.com/trojan-gfw/trojan-quickstart/master/trojan-quickstart.sh)"

安装完成后配置文件路径: /usr/local/etc/trojan/config.json

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
# 配置文件中需要修改的地方
    "password": [
        "trojan的连接密码"
    ],
# 以及
"ssl": {
        "cert": "证书crt文件的路径",
        "key": "证书key文件的路径",
        "key_password": "证书的密码",
}

启动:systemctl start trojan

重启:systemctl restart trojan

查看状态:systemctl status trojan

关闭:systemctl stop trojan

开机自启:systemctl enable trojan

步骤五 : 客户端设置

windows端客户端

使用的是V2rayN V3.27

服务器 -> 添加[Trojan]服务器 ->

  • 服务器地址:VPS的IP地址
  • 服务器端口 : 443
  • 密码 : 步骤四中配置的“trojan的连接密码”
  • 域名(SNI) : 填写证书的域名

ubuntu

参考 https://xbsj6147.xyz/pagesv2/download-linux.html

官网参数介绍

下载页面

1
2
3
tar xvf trojan-1.16.0-linux-amd64.tar.xz
cd trojan
vim config.json

配置内容如下

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
{
    "run_type": "client",
    "local_addr": "0.0.0.0",
    "local_port": 1080,
    "remote_addr": "服务器地址",
    "remote_port": 443,
    "password": [
        "trojan连接密码"
    ],
    "log_level": 1,
    "ssl": {
        "verify": false,
        "verify_hostname" : false,
        "cert": "",
        "cipher": "ECDHE-ECDSA-AES128-GCM-SHA256:ECDHE-RSA-AES128-GCM-SHA256:ECDHE-ECDSA-AES256-GCM-SHA384:ECDHE-RSA-AES256-GCM-SHA384:ECDHE-ECDSA-CHACHA20-POLY1305:ECDHE-RSA-CHACHA20-POLY1305:DHE-RSA-AES128-GCM-SHA256:DHE-RSA-AES256-GCM-SHA384",
        "cipher_tls13": "TLS_AES_128_GCM_SHA256:TLS_CHACHA20_POLY1305_SHA256:TLS_AES_256_GCM_SHA384",
        "sni":"",
        "alpn": [
                "h2",
            "http/1.1"
        ],
        "reuse_session": true,
        "session_ticket": false,
        "session_timeout": 600,
        "curves": ""
    },
    "tcp": {
        "prefer_ipv4": false,
        "no_delay": true,
        "keep_alive": true,
        "reuse_port": false,
        "fast_open": false,
        "fast_open_qlen": 20
    },
    "mysql": {
        "enabled": false,
        "server_addr": "127.0.0.1",
        "server_port": 3306,
        "database": "trojan",
        "username": "trojan",
        "password": "",
        "key": "",
        "cert": "",
        "ca": ""
    }
}

配置systemctl管理

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
cat > /etc/systemd/system/trojan.service <<-EOF
[Unit]
Description=trojan
After=network.target

[Service]
Type=simple
PIDFile=/home/myye/trojan/trojan.pid
ExecStart=/home/myye/trojan/trojan -c /home/myye/trojan/config.json -l /home/myye/trojan/trojan.log
ExecReload=/bin/kill -HUP $MAINPID
Restart=on-failure
RestartSec=1s

[Install]
WantedBy=multi-user.target

EOF

设置开机自启动sudo systemctl enable trojan