Xray panel supporting multi-protocol multi-user expire day & traffic & IP limit (Vmess, Vless, Trojan, ShadowSocks, Wireguard, Tunnel, Mixed, HTTP, Tun) https://t.me/XrayUI
  • Go 46%
  • TypeScript 44.6%
  • Shell 6.5%
  • CSS 2.1%
  • JavaScript 0.5%
  • Other 0.2%
Find a file
2026-06-15 23:50:05 +02:00
.github ci: use .nvmrc for setup-node version in codeql/release workflows 2026-06-15 23:50:05 +02:00
.vscode feat(postgres): in-panel backup/restore and consistent CLI backend 2026-05-31 17:53:34 +02:00
deploy ci(smoke): retry transient GitHub download failures 2026-06-14 21:17:59 +02:00
docs feat(inbounds): add Real client IP presets to capture visitor IP behind CDN/relay 2026-06-15 23:50:04 +02:00
frontend feat(nodes): per-node client IP attribution for IP-limit 2026-06-15 23:50:05 +02:00
internal feat(nodes): per-node client IP attribution for IP-limit 2026-06-15 23:50:05 +02:00
media docs(readme): revamp README and sync all translations 2026-06-02 03:03:14 +02:00
tools/openapigen refactor: replace custom geo manager with Xray-core native geodata auto-update 2026-06-10 18:27:12 +02:00
windows_files Update OpenSSL installer to version 3.6.0 2026-01-05 18:49:30 +01:00
.dockerignore refactor: focused service files, leaf subpackages, and an internal/ layout (#5167) 2026-06-10 15:19:22 +02:00
.env.example feat(docker): support XUI_PORT runtime override (#5240) 2026-06-14 21:15:08 +02:00
.gitattributes feat: release-driven golden-image & unattended-install deployment pipeline (#5323) 2026-06-14 18:08:35 +02:00
.gitignore fix(nodes): "Invalid input" when saving a node with inbound sync mode "all" 2026-06-12 02:29:46 +02:00
.nvmrc Security hardening: sessions, SSRF, CSP nonce, CSRF logout, trusted proxies (#4275) 2026-05-13 12:52:52 +02:00
CONTRIBUTING.md Test-quality audit: fix 2 prod bugs, strengthen weak tests, add mutation/fuzz/CI tooling (#5345) 2026-06-15 15:17:03 +02:00
docker-compose.yml feat(docker): support XUI_PORT runtime override (#5240) 2026-06-14 21:15:08 +02:00
DockerEntrypoint.sh fix(iplimit): ban UDP as well as TCP in fail2ban action (#5350) 2026-06-15 17:34:23 +02:00
Dockerfile refactor: focused service files, leaf subpackages, and an internal/ layout (#5167) 2026-06-10 15:19:22 +02:00
DockerInit.sh feat(mtproto): add MTProto (FakeTLS) protocol via managed mtg sidecar (#5076) 2026-06-08 14:28:19 +02:00
go.mod chore(deps): bump telego to v1.10.0 2026-06-15 21:15:38 +02:00
go.sum chore(deps): bump telego to v1.10.0 2026-06-15 21:15:38 +02:00
install.sh ci(smoke): retry transient GitHub download failures 2026-06-14 21:17:59 +02:00
LICENSE 3x-ui 2023-02-09 22:48:06 +03:30
main.go fix(inbounds): show remark first, else inbound tag, in client labels 2026-06-12 20:37:37 +02:00
README.ar_EG.md feat(env): allow setting the initial URI path for the web panel (#5149) 2026-06-11 12:51:54 +02:00
README.es_ES.md feat(env): allow setting the initial URI path for the web panel (#5149) 2026-06-11 12:51:54 +02:00
README.fa_IR.md feat(env): allow setting the initial URI path for the web panel (#5149) 2026-06-11 12:51:54 +02:00
README.md feat: release-driven golden-image & unattended-install deployment pipeline (#5323) 2026-06-14 18:08:35 +02:00
README.ru_RU.md feat(env): allow setting the initial URI path for the web panel (#5149) 2026-06-11 12:51:54 +02:00
README.tr_TR.md feat(env): allow setting the initial URI path for the web panel (#5149) 2026-06-11 12:51:54 +02:00
README.zh_CN.md feat(env): allow setting the initial URI path for the web panel (#5149) 2026-06-11 12:51:54 +02:00
update.sh fix(script): SSL management fixes (#4994, #5010, #5070) 2026-06-12 01:22:30 +02:00
x-ui.rc fix(alpine): restart_xray uses rc-service; OpenRC reload reads pidfile contents 2026-05-11 09:05:36 +02:00
x-ui.service.arch Update ExecReload command in x-ui.service.debian (#5219) 2026-06-12 12:09:48 +02:00
x-ui.service.debian Update ExecReload command in x-ui.service.debian (#5219) 2026-06-12 12:09:48 +02:00
x-ui.service.rhel Update ExecReload command in x-ui.service.debian (#5219) 2026-06-12 12:09:48 +02:00
x-ui.sh fix(iplimit): ban UDP as well as TCP in fail2ban action (#5350) 2026-06-15 17:34:23 +02:00

English | فارسی | العربية | 中文 | Español | Русский | Türkçe

3x-ui

Release Build GO Version Downloads License Go Reference Go Report Card

3X-UI is an advanced, open-source web control panel for managing Xray-core servers. It provides a clean, multi-language interface for deploying, configuring, and monitoring a wide range of proxy and VPN protocols — from a single VPS to multi-node deployments.

Built as an enhanced fork of the original X-UI project, 3X-UI adds broader protocol support, improved stability, per-client traffic accounting, and many quality-of-life features.

Important

This project is intended for personal use only. Please do not use it for illegal purposes or in a production environment.

Features

  • Multi-protocol inbounds — VLESS, VMess, Trojan, Shadowsocks, WireGuard, Hysteria2, HTTP, SOCKS (Mixed), Dokodemo-door / Tunnel, and TUN.
  • Modern transports & security — TCP (Raw), mKCP, WebSocket, gRPC, HTTPUpgrade, and XHTTP, secured with TLS, XTLS, and REALITY.
  • Fallbacks — serve multiple protocols on a single port (e.g. VLESS and Trojan on 443) using Xray's fallback support.
  • Per-client management — traffic quotas, expiry dates, IP limits, live online status, and one-click share links, QR codes, and subscriptions.
  • Traffic statistics — per inbound, per client, and per outbound, with reset controls.
  • Multi-node support — manage and scale across multiple servers from a single panel.
  • Outbound & routing — WARP, NordVPN, custom routing rules, load balancers, and outbound proxy chaining.
  • Built-in subscription server with multiple output formats and custom page templates.
  • Telegram bot for remote monitoring and management.
  • RESTful API with in-panel Swagger documentation.
  • Flexible storage — SQLite (default) or PostgreSQL.
  • 13 UI languages with dark and light themes.
  • Fail2ban integration for enforcing per-client IP limits.

Screenshots

Click to expand Overview Inbounds Add client Configs

Quick Start

bash <(curl -Ls https://raw.githubusercontent.com/mhsanaei/3x-ui/master/install.sh)

During installation a random username, password, and access path are generated. After installation, run x-ui to open the management menu, where you can start/stop the service, view or reset your login credentials, manage SSL certificates, and more.

For full documentation, please visit the project Wiki.

Unattended install & cloud images

The installer also runs non-interactively for cloud-init and golden images. Set XUI_NONINTERACTIVE=1 (or pipe with no TTY) and it installs end-to-end with zero prompts, generating random credentials and writing them to /etc/x-ui/install-result.env. See deploy/ for:

Supported Platforms

Operating systems: Ubuntu, Debian, Armbian, Fedora, CentOS, RHEL, AlmaLinux, Rocky Linux, Oracle Linux, Amazon Linux, Virtuozzo, Arch, Manjaro, Parch, openSUSE (Tumbleweed / Leap), Alpine, and Windows.

Architectures: amd64 · 386 · arm64 (aarch64) · armv7 · armv6 · armv5 · s390x.

Database Options

3X-UI supports two backends, chosen during the install:

  • SQLite (default) — a single file at /etc/x-ui/x-ui.db. Zero setup, ideal for small and medium deployments.
  • PostgreSQL — recommended for high client counts or multi-node setups. The installer can install PostgreSQL locally for you, or accept a DSN to an existing server.

At runtime the backend is selected via environment variables (the installer writes these to /etc/default/x-ui for you):

XUI_DB_TYPE=postgres
XUI_DB_DSN=postgres://xui:password@127.0.0.1:5432/xui?sslmode=disable

Migrating an existing SQLite install to PostgreSQL

x-ui migrate-db --dsn "postgres://xui:password@127.0.0.1:5432/xui?sslmode=disable"
# then set XUI_DB_TYPE and XUI_DB_DSN in /etc/default/x-ui and restart:
systemctl restart x-ui

The source SQLite file is left untouched; remove it manually once you have verified the new backend.

Docker

The default docker compose up -d keeps using SQLite. To run with the bundled PostgreSQL service, uncomment the two XUI_DB_* env lines in docker-compose.yml and start with the profile:

docker compose --profile postgres up -d

The image bundles Fail2ban (enabled by default) to enforce per-client IP limits. Fail2ban bans offenders with iptables, which requires the NET_ADMIN capability. docker-compose.yml already grants it via cap_add; if you start the container with docker run instead, add the capabilities yourself, otherwise bans are logged but never applied:

docker run -d --cap-add=NET_ADMIN --cap-add=NET_RAW ... ghcr.io/mhsanaei/3x-ui

Environment Variables

Variable Description Default
XUI_DB_TYPE Database backend: sqlite or postgres sqlite
XUI_DB_DSN PostgreSQL connection string (when XUI_DB_TYPE=postgres)
XUI_DB_FOLDER Directory for the SQLite database file /etc/x-ui
XUI_DB_MAX_OPEN_CONNS Maximum open connections (PostgreSQL pool)
XUI_DB_MAX_IDLE_CONNS Maximum idle connections (PostgreSQL pool)
XUI_INIT_WEB_BASE_PATH The initial URI path for the web panel /
XUI_ENABLE_FAIL2BAN Enable Fail2ban-based IP-limit enforcement true
XUI_LOG_LEVEL Log verbosity (debug, info, warning, error) info
XUI_DEBUG Enable debug mode false

Supported Languages

The panel UI is available in 13 languages:

English · فارسی · العربية · 中文(简体) · 中文(繁體) · Español · Русский · Українська · Türkçe · Tiếng Việt · 日本語 · Bahasa Indonesia · Português (Brasil)

Contributing

Contributions are welcome. Please read the Contributing Guide before opening an issue or pull request.

A Special Thanks to

Acknowledgment

  • Iran v2ray rules (License: GPL-3.0): Enhanced v2ray/xray and v2ray/xray-clients routing rules with built-in Iranian domains and a focus on security and adblocking.
  • Russia v2ray rules (License: GPL-3.0): This repository contains automatically updated V2Ray routing rules based on data on blocked domains and addresses in Russia.

Community Tools

Tools and integrations built by the community around 3x-ui.

  • terraform-provider-3x-ui (License: MIT): Manage inbounds, clients, panel settings, and Xray configuration as code with Terraform / OpenTofu.

Support project

If this project is helpful to you, you may wish to give it a🌟

Buy Me A Coffee
Crypto donation button by NOWPayments

Stargazers over Time

Stargazers over time