添加v2ray安装文档和配置示例 使用目录组织

This commit is contained in:
lingling 2025-04-02 21:02:12 +08:00
parent 2be8b8de9f
commit f24473e1bb
13 changed files with 841 additions and 805 deletions

2
README.MD Normal file
View File

@ -0,0 +1,2 @@
config目录是配置示例
install目录是安装脚本

View File

@ -1,127 +1,127 @@
socks多个出vmess多个入
```
{
"inbounds": [
{
"port": 9002,
"listen": "0.0.0.0",
"protocol": "vmess",
"settings": {
"clients": [
{
"id": "2ee57806-f6e4-482a-ef08-7360c04cd3e5",
"alterId": 64
}
]
},
"streamSettings": {
"network": "ws",
"security": "none",
"wsSettings": {
"path": "/",
"headers": {}
}
},
"tag": "vmess1",
"sniffing": {
"enabled": true,
"destOverride": [
"http",
"tls"
]
}
},
{
"port": 9003,
"listen": "0.0.0.0",
"protocol": "vmess",
"settings": {
"clients": [
{
"id": "2ee57806-f6e4-482a-ef08-7360c04cd3e5",
"alterId": 64
}
]
},
"streamSettings": {
"network": "ws",
"security": "none",
"wsSettings": {
"path": "/",
"headers": {}
}
},
"tag": "vmess2",
"sniffing": {
"enabled": true,
"destOverride": [
"http",
"tls"
]
}
}
],
"outbounds": [
{
"protocol": "socks",
"settings": {
"servers": [
{
"address": "34.125.84.146",
"port": 2222,
"users": [
{
"user": "us",
"pass": "us"
}
]
}
]
},
"tag": "socks1"
},
{
"protocol": "socks",
"settings": {
"servers": [
{
"address": "34.125.252.181",
"port": 3333,
"users": [
{
"user": "936",
"pass": "936"
}
]
}
]
},
"tag": "socks2"
},
{
"protocol": "blackhole",
"settings": {},
"tag": "blocked"
}
],
"routing": {
"rules": [
{
"type": "field",
"inboundTag": [
"vmess1"
],
"outboundTag": "socks1"
},
{
"type": "field",
"inboundTag": [
"vmess2"
],
"outboundTag": "socks2"
}
]
}
}
socks多个出vmess多个入
```
{
"inbounds": [
{
"port": 9002,
"listen": "0.0.0.0",
"protocol": "vmess",
"settings": {
"clients": [
{
"id": "2ee57806-f6e4-482a-ef08-7360c04cd3e5",
"alterId": 64
}
]
},
"streamSettings": {
"network": "ws",
"security": "none",
"wsSettings": {
"path": "/",
"headers": {}
}
},
"tag": "vmess1",
"sniffing": {
"enabled": true,
"destOverride": [
"http",
"tls"
]
}
},
{
"port": 9003,
"listen": "0.0.0.0",
"protocol": "vmess",
"settings": {
"clients": [
{
"id": "2ee57806-f6e4-482a-ef08-7360c04cd3e5",
"alterId": 64
}
]
},
"streamSettings": {
"network": "ws",
"security": "none",
"wsSettings": {
"path": "/",
"headers": {}
}
},
"tag": "vmess2",
"sniffing": {
"enabled": true,
"destOverride": [
"http",
"tls"
]
}
}
],
"outbounds": [
{
"protocol": "socks",
"settings": {
"servers": [
{
"address": "34.125.84.146",
"port": 2222,
"users": [
{
"user": "us",
"pass": "us"
}
]
}
]
},
"tag": "socks1"
},
{
"protocol": "socks",
"settings": {
"servers": [
{
"address": "34.125.252.181",
"port": 3333,
"users": [
{
"user": "936",
"pass": "936"
}
]
}
]
},
"tag": "socks2"
},
{
"protocol": "blackhole",
"settings": {},
"tag": "blocked"
}
],
"routing": {
"rules": [
{
"type": "field",
"inboundTag": [
"vmess1"
],
"outboundTag": "socks1"
},
{
"type": "field",
"inboundTag": [
"vmess2"
],
"outboundTag": "socks2"
}
]
}
}
```

View File

@ -1,116 +1,116 @@
{
"log": {
"access": "",
"error": "",
"loglevel": "warning"
},
"inbounds": [
{
"tag": "socks",
"port": 10808,
"listen": "127.0.0.1",
"protocol": "socks",
"sniffing": {
"enabled": true,
"destOverride": [
"http",
"tls"
]
},
"settings": {
"auth": "noauth",
"udp": true,
"allowTransparent": false
}
},
{
"tag": "socks2",
"port": 10807,
"listen": "127.0.0.1",
"protocol": "socks",
"sniffing": {
"enabled": true,
"destOverride": [
"http",
"tls"
]
},
"settings": {
"auth": "noauth",
"udp": true,
"allowTransparent": false
}
}
],
"outbounds": [
{
"protocol": "shadowsocks",
"settings": {
"servers": [
{
"address": "118.33.96.200",
"method": "aes-256-gcm",
"ota": false,
"password": "830",
"port": 21674,
"level": 1
}
]
},
"tag": "ip1"
},
{
"protocol": "shadowsocks",
"settings": {
"servers": [
{
"address": "59.9.252.146",
"method": "aes-256-gcm",
"ota": true,
"password": "901",
"port": 40826
}
]
},
"tag": "ip2"
},
{
"tag": "direct",
"protocol": "freedom",
"settings": {
}
},
{
"tag": "block",
"protocol": "blackhole",
"settings": {
"response": {
"type": "http"
}
}
}
],
"routing": {
"domainStrategy": "IPIfNonMatch",
"domainMatcher": "linear",
"rules": [
{
"type": "field",
"inboundTag": [
"socks"
],
"outboundTag": "ip1",
"enabled": true
},
{
"type": "field",
"inboundTag": [
"socks2"
],
"outboundTag": "ip2",
"enabled": true
}
]
}
{
"log": {
"access": "",
"error": "",
"loglevel": "warning"
},
"inbounds": [
{
"tag": "socks",
"port": 10808,
"listen": "127.0.0.1",
"protocol": "socks",
"sniffing": {
"enabled": true,
"destOverride": [
"http",
"tls"
]
},
"settings": {
"auth": "noauth",
"udp": true,
"allowTransparent": false
}
},
{
"tag": "socks2",
"port": 10807,
"listen": "127.0.0.1",
"protocol": "socks",
"sniffing": {
"enabled": true,
"destOverride": [
"http",
"tls"
]
},
"settings": {
"auth": "noauth",
"udp": true,
"allowTransparent": false
}
}
],
"outbounds": [
{
"protocol": "shadowsocks",
"settings": {
"servers": [
{
"address": "118.33.96.200",
"method": "aes-256-gcm",
"ota": false,
"password": "830",
"port": 21674,
"level": 1
}
]
},
"tag": "ip1"
},
{
"protocol": "shadowsocks",
"settings": {
"servers": [
{
"address": "59.9.252.146",
"method": "aes-256-gcm",
"ota": true,
"password": "901",
"port": 40826
}
]
},
"tag": "ip2"
},
{
"tag": "direct",
"protocol": "freedom",
"settings": {
}
},
{
"tag": "block",
"protocol": "blackhole",
"settings": {
"response": {
"type": "http"
}
}
}
],
"routing": {
"domainStrategy": "IPIfNonMatch",
"domainMatcher": "linear",
"rules": [
{
"type": "field",
"inboundTag": [
"socks"
],
"outboundTag": "ip1",
"enabled": true
},
{
"type": "field",
"inboundTag": [
"socks2"
],
"outboundTag": "ip2",
"enabled": true
}
]
}
}

View File

@ -1,32 +1,32 @@
{
"inbounds": [{
"port": 9000,
"protocol": "vless",
"settings": {
"clients": [{
"id": "2ee57806-f6e4-482a-ef08-7360c04cd3e5",
"alterId": 64
}],
"decryption": "none"
},
"streamSettings": {
"network": "ws",
"wsSettings": {
"path": "/"
}
}
}],
"outbounds": [{
"protocol": "socks",
"settings": {
"servers": [{
"address": "196.44.121.85",
"port": 12324,
"users": [{
"user": "14a3a26b5ae17",
"pass": "8da3b2741c"
}]
}]
}
}]
{
"inbounds": [{
"port": 9000,
"protocol": "vless",
"settings": {
"clients": [{
"id": "2ee57806-f6e4-482a-ef08-7360c04cd3e5",
"alterId": 64
}],
"decryption": "none"
},
"streamSettings": {
"network": "ws",
"wsSettings": {
"path": "/"
}
}
}],
"outbounds": [{
"protocol": "socks",
"settings": {
"servers": [{
"address": "196.44.121.85",
"port": 12324,
"users": [{
"user": "14a3a26b5ae17",
"pass": "8da3b2741c"
}]
}]
}
}]
}

View File

@ -1,32 +1,32 @@
{
"inbounds": [{
"port": 9000,
"protocol": "vless",
"settings": {
"clients": [{
"id": "2ee57806-f6e4-482a-ef08-7360c04cd3e5",
"alterId": 64
}],
"decryption": "none"
},
"streamSettings": {
"network": "ws",
"wsSettings": {
"path": "/"
}
}
}],
"outbounds": [{
"protocol": "socks",
"settings": {
"servers": [{
"address": "185.145.242.105",
"port": 7778,
"users": [{
"user": "X5H1R7q0i0C9",
"pass": "N6u1F0G5u8p0"
}]
}]
}
}]
{
"inbounds": [{
"port": 9000,
"protocol": "vless",
"settings": {
"clients": [{
"id": "2ee57806-f6e4-482a-ef08-7360c04cd3e5",
"alterId": 64
}],
"decryption": "none"
},
"streamSettings": {
"network": "ws",
"wsSettings": {
"path": "/"
}
}
}],
"outbounds": [{
"protocol": "socks",
"settings": {
"servers": [{
"address": "185.145.242.105",
"port": 7778,
"users": [{
"user": "X5H1R7q0i0C9",
"pass": "N6u1F0G5u8p0"
}]
}]
}
}]
}

View File

@ -1,195 +1,195 @@
{
"inbounds": [{
"port": 9000,
"protocol": "vless",
"settings": {
"clients": [{
"id": "2ee57806-f6e4-482a-ef08-7360c04cd3e5",
"alterId": 64,
"email": "user1@x.com"
},
{
"id": "2ee57806-f6e4-482a-ef08-7360c04cd3e6",
"alterId": 64,
"email": "user2@x.com"
},
{
"id": "2ee57806-f6e4-482a-ef08-7360c04cd3e7",
"alterId": 64,
"email": "user3@x.com"
},
{
"id": "2ee57806-f6e4-482a-ef08-7360c04cd3e8",
"alterId": 64,
"email": "user4@x.com"
},
{
"id": "2ee57806-f6e4-482a-ef08-7360c04cd3e9",
"alterId": 64,
"email": "user5@x.com"
},
{
"id": "2ee57806-f6e4-482a-ef08-7360c04cd310",
"alterId": 64,
"email": "user6@x.com"
},
{
"id": "2ee57806-f6e4-482a-ef08-7360c04cd311",
"alterId": 64,
"email": "user7@x.com"
}
],
"decryption": "none"
},
"streamSettings": {
"network": "ws",
"wsSettings": {
"path": "/"
}
}
}],
"outbounds": [{
"protocol": "socks",
"settings": {
"servers": [{
"address": "196.44.121.85",
"port": 12324,
"users": [{
"user": "14a3a26b5ae17",
"pass": "8da3b2741c"
}]
}]
},
"tag": "outbound1"
},
{
"protocol": "socks",
"settings": {
"servers": [{
"address": "46.34.55.68",
"port": 12324,
"users": [{
"user": "14a3a26b5ae17",
"pass": "8da3b2741c"
}]
}]
},
"tag": "outbound2"
},
{
"protocol": "socks",
"settings": {
"servers": [{
"address": "176.103.238.139",
"port": 12324,
"users": [{
"user": "14a3a26b5ae17",
"pass": "8da3b2741c"
}]
}]
},
"tag": "outbound3"
},
{
"protocol": "socks",
"settings": {
"servers": [{
"address": "195.95.205.25",
"port": 12324,
"users": [{
"user": "14a3a26b5ae17",
"pass": "8da3b2741c"
}]
}]
},
"tag": "outbound4"
},
{
"protocol": "socks",
"settings": {
"servers": [{
"address": "79.175.117.165",
"port": 12324,
"users": [{
"user": "14a3a26b5ae17",
"pass": "8da3b2741c"
}]
}]
},
"tag": "outbound5"
},
{
"protocol": "socks",
"settings": {
"servers": [{
"address": "45.90.48.242",
"port": 12324,
"users": [{
"user": "14a3a26b5ae17",
"pass": "8da3b2741c"
}]
}]
},
"tag": "outbound6"
},
{
"protocol": "socks",
"settings": {
"servers": [{
"address": "85.254.81.211",
"port": 12324,
"users": [{
"user": "14a3a26b5ae17",
"pass": "8da3b2741c"
}]
}]
},
"tag": "outbound7"
}
],
"routing": {
"rules": [{
"type": "field",
"outboundTag": "outbound1",
"inboundTag": "vless",
"user": ["user1@x.com"]
},
{
"type": "field",
"outboundTag": "outbound2",
"inboundTag": "vless",
"user": ["user2@x.com"]
},
{
"type": "field",
"outboundTag": "outbound3",
"inboundTag": "vless",
"user": ["user3@x.com"]
},
{
"type": "field",
"outboundTag": "outbound4",
"inboundTag": "vless",
"user": ["user4@x.com"]
},
{
"type": "field",
"outboundTag": "outbound5",
"inboundTag": "vless",
"user": ["user5@x.com"]
},
{
"type": "field",
"outboundTag": "outbound6",
"inboundTag": "vless",
"user": ["user6@x.com"]
},
{
"type": "field",
"outboundTag": "outbound7",
"inboundTag": "vless",
"user": ["user7@x.com"]
}
]
}
{
"inbounds": [{
"port": 9000,
"protocol": "vless",
"settings": {
"clients": [{
"id": "2ee57806-f6e4-482a-ef08-7360c04cd3e5",
"alterId": 64,
"email": "user1@x.com"
},
{
"id": "2ee57806-f6e4-482a-ef08-7360c04cd3e6",
"alterId": 64,
"email": "user2@x.com"
},
{
"id": "2ee57806-f6e4-482a-ef08-7360c04cd3e7",
"alterId": 64,
"email": "user3@x.com"
},
{
"id": "2ee57806-f6e4-482a-ef08-7360c04cd3e8",
"alterId": 64,
"email": "user4@x.com"
},
{
"id": "2ee57806-f6e4-482a-ef08-7360c04cd3e9",
"alterId": 64,
"email": "user5@x.com"
},
{
"id": "2ee57806-f6e4-482a-ef08-7360c04cd310",
"alterId": 64,
"email": "user6@x.com"
},
{
"id": "2ee57806-f6e4-482a-ef08-7360c04cd311",
"alterId": 64,
"email": "user7@x.com"
}
],
"decryption": "none"
},
"streamSettings": {
"network": "ws",
"wsSettings": {
"path": "/"
}
}
}],
"outbounds": [{
"protocol": "socks",
"settings": {
"servers": [{
"address": "196.44.121.85",
"port": 12324,
"users": [{
"user": "14a3a26b5ae17",
"pass": "8da3b2741c"
}]
}]
},
"tag": "outbound1"
},
{
"protocol": "socks",
"settings": {
"servers": [{
"address": "46.34.55.68",
"port": 12324,
"users": [{
"user": "14a3a26b5ae17",
"pass": "8da3b2741c"
}]
}]
},
"tag": "outbound2"
},
{
"protocol": "socks",
"settings": {
"servers": [{
"address": "176.103.238.139",
"port": 12324,
"users": [{
"user": "14a3a26b5ae17",
"pass": "8da3b2741c"
}]
}]
},
"tag": "outbound3"
},
{
"protocol": "socks",
"settings": {
"servers": [{
"address": "195.95.205.25",
"port": 12324,
"users": [{
"user": "14a3a26b5ae17",
"pass": "8da3b2741c"
}]
}]
},
"tag": "outbound4"
},
{
"protocol": "socks",
"settings": {
"servers": [{
"address": "79.175.117.165",
"port": 12324,
"users": [{
"user": "14a3a26b5ae17",
"pass": "8da3b2741c"
}]
}]
},
"tag": "outbound5"
},
{
"protocol": "socks",
"settings": {
"servers": [{
"address": "45.90.48.242",
"port": 12324,
"users": [{
"user": "14a3a26b5ae17",
"pass": "8da3b2741c"
}]
}]
},
"tag": "outbound6"
},
{
"protocol": "socks",
"settings": {
"servers": [{
"address": "85.254.81.211",
"port": 12324,
"users": [{
"user": "14a3a26b5ae17",
"pass": "8da3b2741c"
}]
}]
},
"tag": "outbound7"
}
],
"routing": {
"rules": [{
"type": "field",
"outboundTag": "outbound1",
"inboundTag": "vless",
"user": ["user1@x.com"]
},
{
"type": "field",
"outboundTag": "outbound2",
"inboundTag": "vless",
"user": ["user2@x.com"]
},
{
"type": "field",
"outboundTag": "outbound3",
"inboundTag": "vless",
"user": ["user3@x.com"]
},
{
"type": "field",
"outboundTag": "outbound4",
"inboundTag": "vless",
"user": ["user4@x.com"]
},
{
"type": "field",
"outboundTag": "outbound5",
"inboundTag": "vless",
"user": ["user5@x.com"]
},
{
"type": "field",
"outboundTag": "outbound6",
"inboundTag": "vless",
"user": ["user6@x.com"]
},
{
"type": "field",
"outboundTag": "outbound7",
"inboundTag": "vless",
"user": ["user7@x.com"]
}
]
}
}

View File

@ -1,158 +1,158 @@
#!/usr/bin/env python3
# -*- coding: utf-8 -*-
"""
V2Ray Docker 管理脚本
功能描述
该脚本用于管理 V2Ray Docker 容器的安装配置以及删除操作用户可以通过输入操作命令来实现以下功能
1. **安装 (install)**:
- 根据给定的服务器信息列表为每个服务器生成对应的 V2Ray 配置文件并启动 Docker 容器
- 配置文件包括 V2Ray `inbounds` `outbounds` 设置使用 WebSocket 协议
- 每个 Docker 容器的端口号从 9001 开始递增
2. **删除 (remove)**:
- 根据给定的服务器信息列表停止并删除 Docker 容器并删除相关的配置文件夹
- 清理 Docker 容器和配置目录以便完全删除相关的配置和容器
功能详情
- 配置文件目录`/etc/v2ray{port}/config.json`
- Docker 容器名称`v2ray_{port}`
- 每个服务器对应的端口号从 9001 开始递增
依赖
- `Docker`需要在系统中安装 Docker脚本通过 Docker 命令来启动和删除容器
- `os` `shutil` 模块用于操作文件和目录
- `json` 模块用于处理配置文件的 JSON 格式
使用示例
1. 安装并配置 V2Ray
python v2ray_docker_manager.py install
2. 删除已安装的 V2Ray 配置和 Docker 容器
python v2ray_docker_manager.py remove
作者
- 由用户定制的 V2Ray Docker 容器管理脚本
"""
import os
import json
import shutil
def write_config(file_path, server_address, user, password, port):
"""
将格式化的 JSON 配置写入指定文件如果文件的目录不存在则创建该目录
:param file_path: str配置文件的路径
:param server_address: str服务器地址
:param user: str用户名
:param password: str密码
:param port: int端口号
"""
# 定义客户端 ID
client_id = "2ee57806-f6e4-482a-ef08-7360c04cd3e5"
# 创建配置字典
config = {
"inbounds": [{
"port": 9000,
"protocol": "vless",
"settings": {
"clients": [{
"id": client_id,
"alterId": 64
}],
"decryption": "none"
},
"streamSettings": {
"network": "ws",
"wsSettings": {
"path": "/"
}
}
}],
"outbounds": [{
"protocol": "socks",
"settings": {
"servers": [{
"address": server_address,
"port": port,
"users": [{
"user": user,
"pass": password
}]
}]
}
}]
}
# 获取文件的目录路径
dir_name = os.path.dirname(file_path)
# 如果目录不存在,则创建目录
if dir_name and not os.path.exists(dir_name):
os.makedirs(dir_name)
# 将配置写入文件
with open(file_path, 'w', encoding='utf-8') as file:
json.dump(config, file, ensure_ascii=False, indent=4)
def install_v2ray(server_info_list):
"""
安装并配置 V2Ray Docker 容器
"""
for server_info in server_info_list:
# 使用冒号分割字符串
server_address, server_port, user, password, port = server_info.split(':')
# 构建配置文件路径
file_path = f'/etc/v2ray{port}/config.json'
# 写入配置
write_config(file_path, server_address, user, password, int(server_port))
# 运行 Docker 容器
docker_run_command = f'docker run -d -p {port}:9000 --name v2ray_{port} --restart=always -v /etc/v2ray{port}:/etc/v2ray teddysun/v2ray'
os.system(docker_run_command)
print(f"V2Ray 配置已写入 {file_path},并启动了 Docker 容器 v2ray_{port}")
def remove_v2ray(server_info_list):
"""
删除 V2Ray Docker 容器及其配置文件
"""
for server_info in server_info_list:
# 使用冒号分割字符串
_, _, _, _, port = server_info.split(':')
# 删除 Docker 容器
docker_stop_command = f'docker stop v2ray_{port} && docker rm v2ray_{port}'
os.system(docker_stop_command)
# 删除配置文件
config_dir = f'/etc/v2ray{port}'
if os.path.exists(config_dir):
shutil.rmtree(config_dir)
print(f"已删除 Docker 容器 v2ray_{port} 和配置目录 {config_dir}")
else:
print(f"未找到配置目录 {config_dir},跳过删除。")
# 示例用法
if __name__ == "__main__":
# 定义服务器信息列表
server_info_list = [
"38.33.77.252:17888:666666:666666:9001",
"38.6.101.39:17888:666666:666666:9002",
"38.6.126.202:17888:666666:666666:9003",
"38.6.102.89:17888:666666:666666:9004",
"38.6.103.77:17888:666666:666666:9005",
"38.33.74.197:17888:666666:666666:9006",
]
action = input("请输入操作 (install / remove): ").strip().lower()
if action == "install":
install_v2ray(server_info_list)
elif action == "remove":
remove_v2ray(server_info_list)
else:
print("无效的操作。请输入 'install''remove'")
#!/usr/bin/env python3
# -*- coding: utf-8 -*-
"""
V2Ray Docker 管理脚本
功能描述
该脚本用于管理 V2Ray Docker 容器的安装配置以及删除操作用户可以通过输入操作命令来实现以下功能
1. **安装 (install)**:
- 根据给定的服务器信息列表为每个服务器生成对应的 V2Ray 配置文件并启动 Docker 容器
- 配置文件包括 V2Ray `inbounds` `outbounds` 设置使用 WebSocket 协议
- 每个 Docker 容器的端口号从 9001 开始递增
2. **删除 (remove)**:
- 根据给定的服务器信息列表停止并删除 Docker 容器并删除相关的配置文件夹
- 清理 Docker 容器和配置目录以便完全删除相关的配置和容器
功能详情
- 配置文件目录`/etc/v2ray{port}/config.json`
- Docker 容器名称`v2ray_{port}`
- 每个服务器对应的端口号从 9001 开始递增
依赖
- `Docker`需要在系统中安装 Docker脚本通过 Docker 命令来启动和删除容器
- `os` `shutil` 模块用于操作文件和目录
- `json` 模块用于处理配置文件的 JSON 格式
使用示例
1. 安装并配置 V2Ray
python v2ray_docker_manager.py install
2. 删除已安装的 V2Ray 配置和 Docker 容器
python v2ray_docker_manager.py remove
作者
- 由用户定制的 V2Ray Docker 容器管理脚本
"""
import os
import json
import shutil
def write_config(file_path, server_address, user, password, port):
"""
将格式化的 JSON 配置写入指定文件如果文件的目录不存在则创建该目录
:param file_path: str配置文件的路径
:param server_address: str服务器地址
:param user: str用户名
:param password: str密码
:param port: int端口号
"""
# 定义客户端 ID
client_id = "2ee57806-f6e4-482a-ef08-7360c04cd3e5"
# 创建配置字典
config = {
"inbounds": [{
"port": 9000,
"protocol": "vless",
"settings": {
"clients": [{
"id": client_id,
"alterId": 64
}],
"decryption": "none"
},
"streamSettings": {
"network": "ws",
"wsSettings": {
"path": "/"
}
}
}],
"outbounds": [{
"protocol": "socks",
"settings": {
"servers": [{
"address": server_address,
"port": port,
"users": [{
"user": user,
"pass": password
}]
}]
}
}]
}
# 获取文件的目录路径
dir_name = os.path.dirname(file_path)
# 如果目录不存在,则创建目录
if dir_name and not os.path.exists(dir_name):
os.makedirs(dir_name)
# 将配置写入文件
with open(file_path, 'w', encoding='utf-8') as file:
json.dump(config, file, ensure_ascii=False, indent=4)
def install_v2ray(server_info_list):
"""
安装并配置 V2Ray Docker 容器
"""
for server_info in server_info_list:
# 使用冒号分割字符串
server_address, server_port, user, password, port = server_info.split(':')
# 构建配置文件路径
file_path = f'/etc/v2ray{port}/config.json'
# 写入配置
write_config(file_path, server_address, user, password, int(server_port))
# 运行 Docker 容器
docker_run_command = f'docker run -d -p {port}:9000 --name v2ray_{port} --restart=always -v /etc/v2ray{port}:/etc/v2ray teddysun/v2ray'
os.system(docker_run_command)
print(f"V2Ray 配置已写入 {file_path},并启动了 Docker 容器 v2ray_{port}")
def remove_v2ray(server_info_list):
"""
删除 V2Ray Docker 容器及其配置文件
"""
for server_info in server_info_list:
# 使用冒号分割字符串
_, _, _, _, port = server_info.split(':')
# 删除 Docker 容器
docker_stop_command = f'docker stop v2ray_{port} && docker rm v2ray_{port}'
os.system(docker_stop_command)
# 删除配置文件
config_dir = f'/etc/v2ray{port}'
if os.path.exists(config_dir):
shutil.rmtree(config_dir)
print(f"已删除 Docker 容器 v2ray_{port} 和配置目录 {config_dir}")
else:
print(f"未找到配置目录 {config_dir},跳过删除。")
# 示例用法
if __name__ == "__main__":
# 定义服务器信息列表
server_info_list = [
"38.33.77.252:17888:666666:666666:9001",
"38.6.101.39:17888:666666:666666:9002",
"38.6.126.202:17888:666666:666666:9003",
"38.6.102.89:17888:666666:666666:9004",
"38.6.103.77:17888:666666:666666:9005",
"38.33.74.197:17888:666666:666666:9006",
]
action = input("请输入操作 (install / remove): ").strip().lower()
if action == "install":
install_v2ray(server_info_list)
elif action == "remove":
remove_v2ray(server_info_list)
else:
print("无效的操作。请输入 'install''remove'")

View File

@ -1,150 +1,184 @@
#!/bin/bash
V2RAY_VERSION="v4.31.0"
V2RAY_ZIP="v2ray-linux-64.zip"
V2RAY_DIR="/usr/local/v2ray"
CONFIG_DIR="/etc/v2ray"
SERVICE_FILE="/usr/lib/systemd/system/v2ray.service"
USE_LOCAL=false
# 确保脚本是以 root 用户运行
if [ "$(id -u)" -ne 0 ]; then
echo "请以 root 用户运行该脚本!"
exit 1
fi
# 获取系统发行版名称
OS_TYPE=$(awk -F= '/^ID=/ { print $2 }' /etc/os-release)
# 安装依赖工具
function install_dependencies() {
echo "安装必要的依赖..."
if [ "$OS_TYPE" == "centos" ] || [ "$OS_TYPE" == "rhel" ]; then
yum install -y wget unzip
elif [ "$OS_TYPE" == "debian" ] || [ "$OS_TYPE" == "ubuntu" ]; then
apt update
apt install -y wget unzip
else
echo "不支持的操作系统类型:$OS_TYPE"
exit 1
fi
}
# 显示帮助信息
function show_help() {
echo "使用方法: $0 [install|uninstall] [--local]"
echo " install 安装 V2Ray"
echo " uninstall 卸载 V2Ray"
echo " --local 使用本地文件安装 (默认从 GitHub 下载)"
exit 0
}
# 解析命令参数
if [ $# -eq 0 ]; then
show_help
fi
ACTION=$1
if [ "$2" == "--local" ]; then
USE_LOCAL=true
fi
# 安装 V2Ray
function install_v2ray() {
echo "开始安装 V2Ray..."
# 安装依赖
install_dependencies
# 下载或使用本地文件
if [ "$USE_LOCAL" == "true" ]; then
echo "使用本地文件安装 V2Ray..."
if [ ! -f "$V2RAY_ZIP" ]; then
echo "错误:未找到本地文件 $V2RAY_ZIP,请放置到当前目录后重试!"
exit 1
fi
else
echo "从 GitHub 下载 V2Ray..."
wget -O "$V2RAY_ZIP" "https://github.com/v2fly/v2ray-core/releases/download/$V2RAY_VERSION/$V2RAY_ZIP"
fi
# 解压 V2Ray
echo "解压 V2Ray..."
mkdir -p v2ray
unzip -d v2ray "$V2RAY_ZIP"
# 复制 V2Ray 文件
echo "复制 V2Ray 文件..."
mkdir -p "$V2RAY_DIR"
cp v2ray/* "$V2RAY_DIR/"
# 创建配置目录
echo "创建配置目录..."
mkdir -p "$CONFIG_DIR"
cp vpoint_vmess_freedom.json "$CONFIG_DIR/config.json"
# 创建 systemd 服务文件
echo "创建 systemd 服务..."
cat <<EOF > "$SERVICE_FILE"
[Unit]
Description=V2Ray Service
Documentation=https://www.v2fly.org/
After=network.target nss-lookup.target
[Service]
User=nobody
CapabilityBoundingSet=CAP_NET_ADMIN CAP_NET_BIND_SERVICE
AmbientCapabilities=CAP_NET_ADMIN CAP_NET_BIND_SERVICE
NoNewPrivileges=true
ExecStart=$V2RAY_DIR/v2ray -config $CONFIG_DIR/config.json
Restart=on-failure
RestartPreventExitStatus=23
[Install]
WantedBy=multi-user.target
EOF
# 重新加载 systemd 并启动 V2Ray
echo "启动 V2Ray..."
systemctl daemon-reload
systemctl enable v2ray
systemctl start v2ray
echo "✅ V2Ray 安装完成!"
echo "你可以使用以下命令查看 V2Ray 运行状态:"
echo " systemctl status v2ray"
}
# 卸载 V2Ray
function uninstall_v2ray() {
echo "开始卸载 V2Ray..."
# 停止并禁用服务
echo "停止 V2Ray..."
systemctl stop v2ray
systemctl disable v2ray
# 删除文件
echo "删除 V2Ray 文件..."
rm -rf "$V2RAY_DIR" "$CONFIG_DIR" "$SERVICE_FILE"
# 重新加载 systemd
echo "重新加载 systemd 配置..."
systemctl daemon-reload
echo "✅ V2Ray 已成功卸载。"
}
# 根据参数执行相应操作
case "$ACTION" in
install)
install_v2ray
;;
uninstall)
uninstall_v2ray
;;
*)
show_help
;;
esac
#!/bin/bash
# ========================================
# V2Ray 安装与卸载脚本
#
# 该脚本用于在 Linux 服务器上安装或卸载 V2Ray。
# 支持从 GitHub 下载最新的 V2Ray 版本或使用本地文件进行安装。
# 还支持生成 systemd 服务以方便管理 V2Ray 服务。
#
# 适用系统:
# - CentOS / RHEL
# - Debian / Ubuntu
#
# 使用方法:
# 1. 赋予执行权限:
# chmod +x script.sh
#
# 2. 执行安装操作:
# sudo ./script.sh install
#
# 3. 使用本地文件安装(如果已经下载了 v2ray-linux-64.zip 文件):
# sudo ./script.sh install --local
#
# 4. 执行卸载操作:
# sudo ./script.sh uninstall
#
# 重要提示:
# - 必须以 root 用户运行脚本。
# - 使用 '--local' 时,需要确保 v2ray-linux-64.zip 文件在当前目录下。
# - 安装完成后可以使用 'systemctl status v2ray' 查看服务状态。
#
# 版权与参考:
# - V2Ray 官方网站https://www.v2fly.org/
# - V2Ray GitHub 发布页https://github.com/v2fly/v2ray-core/releases
# ========================================
V2RAY_VERSION="v4.31.0"
V2RAY_ZIP="v2ray-linux-64.zip"
V2RAY_DIR="/usr/local/v2ray"
CONFIG_DIR="/etc/v2ray"
SERVICE_FILE="/usr/lib/systemd/system/v2ray.service"
USE_LOCAL=false
# 确保脚本是以 root 用户运行
if [ "$(id -u)" -ne 0 ]; then
echo "请以 root 用户运行该脚本!"
exit 1
fi
# 获取系统发行版名称
OS_TYPE=$(awk -F= '/^ID=/ { print $2 }' /etc/os-release)
# 安装依赖工具
function install_dependencies() {
echo "安装必要的依赖..."
if [ "$OS_TYPE" == "centos" ] || [ "$OS_TYPE" == "rhel" ]; then
yum install -y wget unzip
elif [ "$OS_TYPE" == "debian" ] || [ "$OS_TYPE" == "ubuntu" ]; then
apt update
apt install -y wget unzip
else
echo "不支持的操作系统类型:$OS_TYPE"
exit 1
fi
}
# 显示帮助信息
function show_help() {
echo "使用方法: $0 [install|uninstall] [--local]"
echo " install 安装 V2Ray"
echo " uninstall 卸载 V2Ray"
echo " --local 使用本地文件安装 (默认从 GitHub 下载)"
exit 0
}
# 解析命令参数
if [ $# -eq 0 ]; then
show_help
fi
ACTION=$1
if [ "$2" == "--local" ]; then
USE_LOCAL=true
fi
# 安装 V2Ray
function install_v2ray() {
echo "开始安装 V2Ray..."
# 安装依赖
install_dependencies
# 下载或使用本地文件
if [ "$USE_LOCAL" == "true" ]; then
echo "使用本地文件安装 V2Ray..."
if [ ! -f "$V2RAY_ZIP" ]; then
echo "错误:未找到本地文件 $V2RAY_ZIP,请放置到当前目录后重试!"
exit 1
fi
else
echo "从 GitHub 下载 V2Ray..."
wget -O "$V2RAY_ZIP" "https://github.com/v2fly/v2ray-core/releases/download/$V2RAY_VERSION/$V2RAY_ZIP"
fi
# 解压 V2Ray
echo "解压 V2Ray..."
mkdir -p v2ray
unzip -d v2ray "$V2RAY_ZIP"
# 复制 V2Ray 文件
echo "复制 V2Ray 文件..."
mkdir -p "$V2RAY_DIR"
cp v2ray/* "$V2RAY_DIR/"
# 创建配置目录
echo "创建配置目录..."
mkdir -p "$CONFIG_DIR"
cp vpoint_vmess_freedom.json "$CONFIG_DIR/config.json"
# 创建 systemd 服务文件
echo "创建 systemd 服务..."
cat <<EOF > "$SERVICE_FILE"
[Unit]
Description=V2Ray Service
Documentation=https://www.v2fly.org/
After=network.target nss-lookup.target
[Service]
User=nobody
CapabilityBoundingSet=CAP_NET_ADMIN CAP_NET_BIND_SERVICE
AmbientCapabilities=CAP_NET_ADMIN CAP_NET_BIND_SERVICE
NoNewPrivileges=true
ExecStart=$V2RAY_DIR/v2ray -config $CONFIG_DIR/config.json
Restart=on-failure
RestartPreventExitStatus=23
[Install]
WantedBy=multi-user.target
EOF
# 重新加载 systemd 并启动 V2Ray
echo "启动 V2Ray..."
systemctl daemon-reload
systemctl enable v2ray
systemctl start v2ray
echo "✅ V2Ray 安装完成!"
echo "你可以使用以下命令查看 V2Ray 运行状态:"
echo " systemctl status v2ray"
}
# 卸载 V2Ray
function uninstall_v2ray() {
echo "开始卸载 V2Ray..."
# 停止并禁用服务
echo "停止 V2Ray..."
systemctl stop v2ray
systemctl disable v2ray
# 删除文件
echo "删除 V2Ray 文件..."
rm -rf "$V2RAY_DIR" "$CONFIG_DIR" "$SERVICE_FILE"
# 重新加载 systemd
echo "重新加载 systemd 配置..."
systemctl daemon-reload
echo "✅ V2Ray 已成功卸载。"
}
# 根据参数执行相应操作
case "$ACTION" in
install)
install_v2ray
;;
uninstall)
uninstall_v2ray
;;
*)
show_help
;;
esac