d2ray is a single Docker container that provides easy 5-minute setups and braindead configurations for xtls-vision + reality.
- You can start with the example
docker-compose.yml
from this repo. - Adjust environment variables:
PORT
: the port Xray listens on.TARGET_HOST
: the target host to redirect non proxy connections.TARGET_PORT
: the target port to redirect non proxy connections.TARGET_SNI
: comma separated list of the target website's SNIs.USERS
: comma separated list of usernames that can access Xray.LOG_LEVEL
: the verbosity of Xray logs. Default:warn
.
docker compose up -d
- Test your connection.
All d2ray logs and private/public key pairs are stored in /etc/d2ray
in the container. You can mount an external folder to that location to persist settings. See the example docker-compose.yml
.
d2ray checks whether a key file exists at path /etc/xray/certs/keys
and generates a new key pair if not found.
You can either supply a pre-generated private key using xray x25519
or let d2ray generate one. The corresponding public key is printed to the container log (docker logs
), which clients use to connect.
If you are generating the keys yourself, the key file must contain exactly the output of xray x25519
.
docker compose down
docker compose pull
docker compose up -d
- The old xtls-vision + TLS + Nginx fallback has been branched out to the
vision
branch.