208 lines
4.2 KiB
Markdown
Raw Normal View History

2021-03-18 23:32:36 +08:00
# 命令参数
2021-03-14 15:40:53 +08:00
2021-04-06 19:05:35 +08:00
::: tip
2021-04-04 13:06:43 +08:00
Xray 使用 Go 风格的命令及参数
2021-03-14 15:40:53 +08:00
:::
## 获取基本命令
您可以运行 `xray help` 来获得所有 xray 最基础的用法, 以及可用的命令及说明。
2021-03-14 15:40:53 +08:00
```
Xray is a platform for building proxies.
Usage:
xray <command> [arguments]
The commands are:
run Run Xray with config, the default command
version Show current version of Xray
api Call an API in an Xray process
convert Convert configs
2021-03-14 15:40:53 +08:00
tls TLS tools
uuid Generate UUIDv4 or UUIDv5
x25519 Generate key pair for x25519 key exchange
wg Generate key pair for wireguard key exchange
2021-03-14 15:40:53 +08:00
Use "xray help <command>" for more information about a command.
```
### xray run
指定一个或多个配置文件,并运行。
使用方法:
2021-03-26 14:01:07 +08:00
2021-03-14 15:40:53 +08:00
```
xray run [-c config.json] [-confdir dir]
```
```
Run Xray with config, the default command.
The -config=file, -c=file flags set the config files for
2021-03-14 15:40:53 +08:00
Xray. Multiple assign is accepted.
The -confdir=dir flag sets a dir with multiple json config
The -format=json flag sets the format of config files.
Default "auto".
2021-03-14 15:40:53 +08:00
The -test flag tells Xray to test config files only,
without launching the server.
2021-03-14 15:40:53 +08:00
The -dump flag tells Xray to print the merged config.
```
`-config=` / `-c=` 用于指定使用的配置文件的位置,支持多文件配置。
`-confdir=` 用于指定一个包含多个配置文件的文件夹。
`-format=` 用于指定使用的配置文件的格式。
`-test` 用于测试配置文件的合法性。
`-dump` 用于显示多文件配置文件合并之后的效果。
::: tip
配置文件除了默认的 JSON 格式外,也可以使用 TOML 和 YAML。在不指定格式的前提下会通过文件扩展名识别。
:::
```
xray run -dump
```
用以输出多文件配置融合之后的结果。
2021-03-14 15:40:53 +08:00
### xray version
输出 Xray 版本、 Golang 版本等信息。
使用方法:
2021-03-26 14:01:07 +08:00
2021-03-14 15:40:53 +08:00
```
xray version
```
### xray api
调用 Xray 的 gRPC API需要在配置文件中开启。
使用方法:
2021-03-26 14:01:07 +08:00
2021-03-14 15:40:53 +08:00
```
xray api <command> [arguments]
```
```
restartlogger Restart the logger
stats Get statistics
statsquery Query statistics
statssys Get system statistics
adi Add inbounds
ado Add outbounds
rmi Remove inbounds
rmo Remove outbounds
```
### xray convert
把配置文件转换成 protobuf 或者把 typedMessage 转换成 json
使用方法:
```
xray convert <command> [arguments]
The commands are:
pb Convert multiple json configs to protobuf
json Convert typedMessage to json
```
pb 子命令使用示例:
```bash
# 用法xray convert pb [-debug] [-type] [json file] [json file] ...
# 把三个配置合并成 mix.pb
xray convert pb c1.json c2.json c3.json > mix.pb
# 使用 -debug 选项查看 mix.pb 的内容
xray convert pb -debug mix.pb
# 使用 mix.pb 启动 Xray-core
xray -c mix.pb
# 详细说明
xray help convert pb
```
json 子命令使用示例:
```bash
# 用法xray convert json [-type] [stdin:] [typedMessage file]
tmsg='{
"type": "xray.proxy.shadowsocks.Account",
"value": "CgMxMTEQBg=="
}'
echo ${tmsg} | xray convert json stdin:
# 上面这个命令的输出结果是:
'{
"cipherType": "AES_256_GCM",
"password": "111"
}'
# 详细说明
xray help convert json
```
2021-03-14 15:40:53 +08:00
### xray tls
一些与 TLS 相关的工具。
使用方法:
2021-03-26 14:01:07 +08:00
2021-03-14 15:40:53 +08:00
```
xray tls <command> [arguments]
```
```
cert Generate TLS certificates
ping Ping the domain with TLS handshake
certChainHash Calculate TLS certificates hash.
2021-03-14 15:40:53 +08:00
```
### xray uuid
生成 UUID。
使用方法:
2021-03-26 14:01:07 +08:00
2021-03-14 15:40:53 +08:00
```
xray uuid [-i "example"]
2021-03-14 15:40:53 +08:00
```
### xray x25519
生成 x25519 密钥对。
使用方法:
```
xray x25519 [-i "(base64.RawURLEncoding)" --std-encoding ]
```
### xray wg
生成 wireguard curve25519 密钥对。
使用方法:
```
xray wg [-i "(base64.StdEncoding)"]
```
2021-03-14 15:40:53 +08:00
::: tip
`-config` 没有指定时Xray 将先后尝试从以下路径加载 `config.json` :
2021-03-26 14:01:07 +08:00
2021-03-14 15:40:53 +08:00
- 工作目录Working Directory
- [环境变量](../config/features/env.md#资源文件路径)中 `Xray.location.asset` 所指定的路径
2021-03-26 14:01:07 +08:00
:::