该项目用于一键部署 Trojan-Go 到 Vultr,并使用 Cloudflare 自动配置域名解析,Let's Encrypt 自动生成证书。
- 创建 SSH 私钥+公钥(对应配置项
ssh_private_key
),在 Vultr 上添加公钥,获取到公钥的ID(对应配置项ssh_key_id
) - 在 Vultr 中创建 API Token (对应配置项
vultr_token
) - 在 Cloudflare 中获取域名的 ZoneID(对应配置项
cloudflare_zone_id
) - 在 Cloudflare 中创建 API Token,权限分配
Zone/DNS/Edit
(对应配置项cloudflare_api_token
)
vultr_token
: Vultr API Tokencloudflare_api_token
:Cloudflare API Tokencloudflare_zone_id
:Cloudflare Zone IDssh_key_id
:SSH 公钥 IDssh_private_key
:SSH 私钥路径domain
:域名password
:Trojan-Go 密码region
:服务器部署区域plan
:服务器规格
在 新加坡 创建一个实例
export VULTR_ACCESS_TOKEN=Vultr API Token
export CLOUDFLARE_API_TOKEN=Cloudflare API Token
export CLOUDFLARE_ZONE_ID=Cloudflare Zone ID
terraform apply -var vultr_token=$VULTR_ACCESS_TOKEN \
-var cloudflare_api_token=$CLOUDFLARE_API_TOKEN \
-var cloudflare_zone_id=$CLOUDFLARE_ZONE_ID \
-var domain=hello-sgp.example.com \
-var password=fre4-0edv-7cQ \
-var region=sgp \
-var ssh_private_key=~/.ssh/id_rsa
注意:一定要修改 domain 和 password!
客户端配置示例
Surge:
Vultr = trojan, hello-sgp.example.com, 443, password=fre4-0edv-7cQ, skip-cert-verify=true, sni=hello-sgp.example.com
Clash:
{
"name": "Vultr",
"password": "fre4-0edv-7cQ",
"port": 443,
"server": "hello-sgp.example.com",
"skip-cert-verify": true,
"sni": "hello-sgp.example.com",
"type": "trojan"
}