Skip to main content

subscription and config generation tool for v2ray

Project description

PyPI - Version Build Status MIT/Apache-2 licensed

v2raysub

v2sub 主要是为了给在纯命令的 Linux 环境使用 v2ray 提供一些辅助,比如订阅分组、切换节点配置、给 proxychains 创建别名等。虽然工具能在 Windows 和 Mac 环境使用,但是对于桌面环境,可以考虑其它选择,比如 v2rayN

安装方法

pip install v2raysub

v2sub 依赖 v2ray,除了 手动安装 外,也可以在安装了 v2sub 后通过以下命令尝试安装

v2sub install v2ray
# 如果网不通,可尝试指定可用的代理
v2sub install --proxy <server:port> v2ray

proxychains 工具不是必须的,需要的话也可以通过 v2sub 尝试安装

v2sub install proxychains

订阅分享支持的链接格式

  • shadowsocks(ss://[method:]<password>@<server>:<port>[#remark] | ss://base64
  • trojan(trojan://<password>@<server>:<port>[?options...}[#remark] | trojan://base64
  • vmess(vmess://base64
  • http / https(订阅分组)
  • 其它协议,可以用编写 plugins 的方式,自定义解析和生成 outbound 配置

注意事项

  • 确保 v2ray 和 proxychains 所在的目录已经添加到了 PATH 环境变量中,使 v2sub 能够找到它们(对于Windows,如果通过 v2sub install 安装的话,则不需要)
  • 对于 Mac 环境,由于 SIP(System Integrity Protection)特性,一些在 /usr/bin/ 等目录中的命令不能直接走代理,比如 /usr/bin/curl。这可以用命令对应的参数来指定代理,像 curl 可以使用 --proxy 来指定,也可以考虑进 Recovery 模式执行 csrutil disable 来将 SIP 禁掉。

v2ray服务启动方式

v2sub 有两种启动 v2ray 服务的模式:

  1. v2sub node start (临时服务):主要是给临时使用的,不过即使 shell 退出了,它也会在后台运行,可以通过 v2sub node stop 停止
  2. v2sub service start(系统服务):以系统服务方式运行,运行前需要通过 v2sub service install 来安装服务,默认是自启动的,对于 Linux 环境,只支持 systemd 类型的服务管理器

使用方法

除了下面说明外,更多使用方法可直接看 v2sub --help

1. 初始化配置

v2sub init

这一步是必须的,这会在家目录的 .v2sub 文件夹内生成一个初始的 v2ray 配置文件 base_config.json,里面没有 outbounds 的设置,在实际启动 v2ray 的时候,会根据这个文件生成对应的配置文件。

初始化之后可根据需要执行 v2sub config edit 来对配置文件进行修改,配置条目的说明可以看:v2ray 配置文件,修改完成之后,在 Linux 和 Mac 环境中会对 v2ray 服务自动重启,而 Windows 需要手动重启。

2. 订阅节点或者节点分组

# 添加
v2sub subscribe add <url>
# 更新分组
v2sub subscribe update
v2sub subscribe update --all
# 删除节点或分组
v2sub subscribe delete
v2sub subscribe delete --all
# 查看订阅列表
v2sub subscribe show
# 纯解析节点或分组,不会添加到列表中
v2sub subscribe parse <url>

url 可以是单个节点(比如: ss://...),也可以是分组订阅链接(比如:https://xxx.com/subscribe?token=xxx),订阅分组需要执行 http 请求,如果网不通可以指定可用的代理

v2sub subscribe --proxy <server:port> add <url>

3. 选择节点

在启动临时服务或者安装系统服务前都得先选择一个节点以生成对应的 v2ray 配置文件,这两种模式选择节点的方法分别是:

  1. v2sub node select
  2. v2sub service select

如果订阅列表中有独立节点和分组,会有类似下面的选择提示:

# anonymous内是独立节点列表,groups则是分组列表
choose subscribe type:
 » base config
   anonymous
   groups
   <Cancel>
# base config 指的是直接复用默认的base_config.json里面的设置,默认没有配置带proxy tag的outbound
# anonymous 指的是直接以类似 ss://...,这种方式添加的非分组的订阅链接
# groups 指的是订阅分组

**notes: **在服务启动之后也可以重新执行 select 来切换节点

4. 启动临时服务

# 启动
v2sub node start
# 停止
v2sub node stop
# 重启
v2sub node restart
# 查看运行状态
v2sub node status
# 切换节点
v2sub node select

默认端口号:

  • sock5: 23338
  • http: 23339

5. 安装和启动 v2sub 系统服务

# 安装服务(Windows环境这一步需要编译服务,可能需要些时间)
v2sub service install
# 启动服务
v2sub service start
# 停止服务
v2sub service stop
# 重启
v2sub service restart
# 查看服务运行状态
v2sub service status
# 切换节点
v2sub service select
# 卸载服务
v2sub service uninstall

默认端口号:

  • sock5: 22338
  • http: 22339

6. 应用代理

a. shell 内临时生效

# linux shell
export http_proxy='http://127.0.0.1:<端口号>'
export https_proxy='http://127.0.0.1:<端口号>'

# powershell
$env:http_proxy='http://127.0.0.1:<端口号>'
$env:https_proxy='http://127.0.0.1:<端口号>'

# cmd
set http_proxy=http://127.0.0.1:<端口号>
set https_proxy=http://127.0.0.1:<端口号>

b. proxychains 别名

# 执行后会提示你选择应用的是临时服务还是系统服务模式,并提供别名
v2sub proxychains alias
# 删除别名
v2sub proxychains alias --delete <别名>
# 显示所有别名
v2sub proxychains alias --list-all

创建别名之后,在 Windows 环境需要重启你的 powershell 或者 cmd,Linux 或 Mac 需要执行 source <shell配置文件> 来使别名生效。

这只是创建一个 proxychains 的配置文件和命令别名,不会对 v2ray 服务运行有影响,使用的时候要确保对应的服务运行中。

# 比如创建了一个别名为vproxy,在确保对应的服务运行后,可以这样使用
vproxy curl https://ipinfo.io/ip

c. 系统代理设置

对于 Windows 和 Mac 执行以下命令可以启用或禁用系统代理设置,Windows 是修改 IE 的 http 代理设置,Mac 则是修改网络接口的 http 和 socks 设置。对于 Linux,由于发行版众多,v2sub 的目标也不是桌面环境,所以不提供这个设置,有需要的话手动设置。

# 启用
v2sub config proxy enable
# 禁用
v2sub config proxy disable

d. 允许局域网连接

使用以下两个命令可以允许或禁止其它机器连接对应的代理服务,为了安全起见,修改之后请手动添加或删除防火墙规则。

# 允许
v2sub config lan allow
# 禁止
v2sub config lan disallow

7. 路由规则设置

# 可以用以下命令管理direct或block路由规则

# 添加direct规则
v2sub config direct add
# 删除direct规则
v2sub config direct remove
# 查看direct规则
v2sub config direct list

# 添加block规则
v2sub config block add
# 删除block规则
v2sub config block remove
# 查看block规则
v2sub config block list

Plugin

可以在 ~/.v2sub/plugins 目录中,添加自定义的 python 脚本,v2sub 在初始化时会自动加载里面的所有脚本。这主要是为了能自定义解析一些除了 v2sub 本来不支持的其它协议,对于 ss、trojan、vmess 这些 v2sub 本来支持的协议,如果在解析或者生成配置文件有问题,也可以在扩展中将原本的解析方法给替换掉。

# 扩展例子 ~/.v2sub/plugins/hh.py

import re

from urllib.parse import urlparse, unquote, ParseResult

from v2raysub import cli as v2cli, protocol, util

# 给 v2sub 添加了两个新命令
# 可以用 v2sub foo 和 v2sub bar 来调用这两个命令
@v2cli.cli.command("foo")
def foo():
    print('foo command')


@v2cli.cli.command("bar")
def bar():
    print('bar command')

# 解析 hh://...
def parse_hh(url: ParseResult) -> object:
    result = {'success': 0}

    url = urlparse(f'hh://{protocol.regular_content(url)}')
    pattern = r'^(?P<password>.+)@(?P<server>.+):(?P<port>\d+)$'

    match = re.match(pattern, url.netloc)
    if match is None:
        result['reason'] = 'invalid hoohoo params'
        return result

    result['success'] = 1
    result['protocol'] = 'hoohoo'
    result['remark'] = unquote(url.fragment)
    result['server'] = match['server']
    result['port'] = match['port']
    result['identify'] = match['password']
    result['method'] = 'chacha20'
    result['options'] = util.parse_query_string(url.query)

    return result


# 为 hoohoo 这个假的协议生成 v2ray 配置文件
def generate_hoohoo_outbound(config, node, node_info, node_options) -> object:
    config['settings']['servers'] = [{
        'address': node_info['server'],
        'method': node_info['method'],
        'ota': False,
        'password': node_info['identify'],
        'port': int(node_info['port'])
    }]
    config['streamSettings'] = {
        "network": "tcp"
    }

    if node_options.get('tls', '0') == '1':
        config['streamSettings']['security'] = 'tls'

    return config


# init_plugin 会被 v2sub 自动调用
def init_plugin(app):
    # 注册 url 解析器
    protocol.register_parser('hh', parse_hh)
    # 注册配置文件生成器
    protocol.register_generator('hoohoo', generate_hoohoo_outbound)

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

v2raysub-0.3.1.tar.gz (43.3 kB view details)

Uploaded Source

Built Distribution

v2raysub-0.3.1-py3-none-any.whl (36.1 kB view details)

Uploaded Python 3

File details

Details for the file v2raysub-0.3.1.tar.gz.

File metadata

  • Download URL: v2raysub-0.3.1.tar.gz
  • Upload date:
  • Size: 43.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.1 CPython/3.12.5

File hashes

Hashes for v2raysub-0.3.1.tar.gz
Algorithm Hash digest
SHA256 dc7ad30560721847bd973bf51682b189b3ff9e84e560cac979eb704ca1c463ee
MD5 f08655254bc36e8f42442cd605adfadc
BLAKE2b-256 5bb80f423b79a523b0c4d5457b1c09e85c7050827c0dcc278c9330c233a8565d

See more details on using hashes here.

File details

Details for the file v2raysub-0.3.1-py3-none-any.whl.

File metadata

  • Download URL: v2raysub-0.3.1-py3-none-any.whl
  • Upload date:
  • Size: 36.1 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.1 CPython/3.12.5

File hashes

Hashes for v2raysub-0.3.1-py3-none-any.whl
Algorithm Hash digest
SHA256 37c9832581887b1b08a552fec0dee2ed3aed7f92159c804465e575d725a114ad
MD5 eb0d746bf4de95869e566665a8ab8a23
BLAKE2b-256 0265cafbf3c4c7d7d80341bb0ebd4c8ad81a68addb7c425f113eced5c6ff062c

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page