
* translation: add Arabic support into language manager * translation: add Arabic language support * translation: add Arabic language support in README files
24 KiB
English | فارسی | العربية | 中文 | Español | Русский
لوحة تحكم ويب متقدمة • مبنية على Xray Core
تنبيه: المشروع ده للتعلم الشخصي والتواصل فقط. رجاءً استخدمه بشكل قانوني.
لو المشروع عجبك وساعدك، ممكن تدعمنا بعمل 🌟
- USDT (TRC20):
TXncxkvhkDWGts487Pjqq1qT9JmwRUz8CC
- MATIC (polygon):
0x41C9548675D044c6Bfb425786C765bc37427256A
- LTC (Litecoin):
ltc1q2ach7x6d2zq0n4l0t4zl7d7xe2s6fs7a3vspwv
التثبيت والتحديث
لتثبيت المشروع أو تحديثه، نفذ الأمر ده:
bash <(curl -Ls https://raw.githubusercontent.com/mhsanaei/3x-ui/master/install.sh)
تثبيت النسخة القديمة (مش موصى بيها)
لو عايز تثبت نسخة معينة، استخدم الأمر ده، مثلاً نسخة v1.7.9
:
VERSION=v1.7.9 && bash <(curl -Ls "https://raw.githubusercontent.com/mhsanaei/3x-ui/$VERSION/install.sh") $VERSION
شهادة SSL
اضغط لعرض تفاصيل شهادة SSL
ACME
عشان تدير شهادات SSL باستخدام ACME:
- تأكد إن الدومين بتاعك متربط صح بالسيرفر.
- شغّل أمر
x-ui
في الترمينال واختار خيار "إدارة شهادات SSL". - هتلاقي الخيارات دي:
- Get SSL: الحصول على شهادة SSL.
- Revoke: إلغاء شهادة SSL موجودة.
- Force Renew: تجديد شهادة SSL بالقوة.
- Show Existing Domains: عرض كل شهادات الدومين المتوفرة على السيرفر.
- Set Certificate Paths for the Panel: تعيين مسارات الشهادة عشان البانل يستخدمها.
Certbot
لتثبيت واستخدام Certbot:
apt-get install certbot -y
certbot certonly --standalone --agree-tos --register-unsafely-without-email -d yourdomain.com
certbot renew --dry-run
Cloudflare
السكريبت بتاع الإدارة فيه آلية مدمجة للتقديم على شهادة SSL من خلال Cloudflare. عشان تستخدمها، هتحتاج:
- بريد إلكتروني مسجل على Cloudflare.
- الـ Global API Key بتاع Cloudflare.
- الدومين لازم يكون مربوط للسيرفر الحالي عن طريق Cloudflare.
كيفية الحصول على Global API Key من Cloudflare:
- شغّل أمر
x-ui
في الترمينال واختار "Cloudflare SSL Certificate". - ادخل على Cloudflare API Tokens.
- دوس على "View Global API Key" (شوف الصورة التوضيحية):
- يمكن تحتاج تعيد تسجيل الدخول، وبعدها هتظهر الـ API Key (شوف الصورة التوضيحية):
عند الاستخدام، ادخل اسم الدومين، البريد الإلكتروني، وAPI Key. المخطط كالتالي:
التثبيت والتحديث يدويًا
اضغط لعرض تفاصيل التثبيت اليدوي
الاستخدام
- لتحميل أحدث نسخة من الباكدج المظغوطة مباشرة على السيرفر، نفذ الأمر التالي:
ARCH=$(uname -m)
case "${ARCH}" in
x86_64 | x64 | amd64) XUI_ARCH="amd64" ;;
i*86 | x86) XUI_ARCH="386" ;;
armv8* | armv8 | arm64 | aarch64) XUI_ARCH="arm64" ;;
armv7* | armv7) XUI_ARCH="armv7" ;;
armv6* | armv6) XUI_ARCH="armv6" ;;
armv5* | armv5) XUI_ARCH="armv5" ;;
s390x) echo 's390x' ;;
*) XUI_ARCH="amd64" ;;
esac
wget https://github.com/MHSanaei/3x-ui/releases/latest/download/x-ui-linux-${XUI_ARCH}.tar.gz
- بعد تحميل الباكدج، نفذ الأوامر دي للتثبيت أو التحديث:
ARCH=$(uname -m)
case "${ARCH}" in
x86_64 | x64 | amd64) XUI_ARCH="amd64" ;;
i*86 | x86) XUI_ARCH="386" ;;
armv8* | armv8 | arm64 | aarch64) XUI_ARCH="arm64" ;;
armv7* | armv7) XUI_ARCH="armv7" ;;
armv6* | armv6) XUI_ARCH="armv6" ;;
armv5* | armv5) XUI_ARCH="armv5" ;;
s390x) echo 's390x' ;;
*) XUI_ARCH="amd64" ;;
esac
cd /root/
rm -rf x-ui/ /usr/local/x-ui/ /usr/bin/x-ui
tar zxvf x-ui-linux-${XUI_ARCH}.tar.gz
chmod +x x-ui/x-ui x-ui/bin/xray-linux-* x-ui/x-ui.sh
cp x-ui/x-ui.sh /usr/bin/x-ui
cp -f x-ui/x-ui.service /etc/systemd/system/
mv x-ui/ /usr/local/
systemctl daemon-reload
systemctl enable x-ui
systemctl restart x-ui
التثبيت باستخدام Docker
اضغط لعرض تفاصيل Docker
الاستخدام
-
تثبيت Docker:
bash <(curl -sSL https://get.docker.com)
-
نسخ مستودع المشروع:
git clone https://github.com/MHSanaei/3x-ui.git cd 3x-ui
-
تشغيل الخدمة:
docker compose up -d
ممكن تضيف الخيار
--pull always
عشان Docker يسحب أحدث صورة لو موجودة. (راجع مستندات Docker للمزيد من التفاصيل).أو
docker run -itd \ -e XRAY_VMESS_AEAD_FORCED=false \ -v $PWD/db/:/etc/x-ui/ \ -v $PWD/cert/:/root/cert/ \ --network=host \ --restart=unless-stopped \ --name 3x-ui \ ghcr.io/mhsanaei/3x-ui:latest
-
التحديث إلى أحدث نسخة:
cd 3x-ui docker compose down docker compose pull 3x-ui docker compose up -d
-
إزالة 3x-ui من Docker:
docker stop 3x-ui docker rm 3x-ui cd -- rm -r 3x-ui
إعدادات Nginx
اضغط لعرض إعدادات البروكسي العكسي (Reverse Proxy)
Reverse Proxy باستخدام Nginx
location / {
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header X-Forwarded-Proto $scheme;
proxy_set_header Host $http_host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header Range $http_range;
proxy_set_header If-Range $http_if_range;
proxy_redirect off;
proxy_pass http://127.0.0.1:2053;
}
استخدام Nginx مع sub-path
- تأكد إن "URI Path" في إعدادات
/sub
للبانل متطابق. - لازم يكون رابط
url
في إعدادات البانل منتهي بـ/
.
location /sub {
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header X-Forwarded-Proto $scheme;
proxy_set_header Host $http_host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header Range $http_range;
proxy_set_header If-Range $http_if_range;
proxy_redirect off;
proxy_pass http://127.0.0.1:2053;
}
نظام التشغيل الموصى به
- Ubuntu 22.04+
- Debian 12+
- CentOS 8+
- OpenEuler 22.03+
- Fedora 36+
- Arch Linux
- Parch Linux
- Manjaro
- Armbian
- AlmaLinux 9.5+
- Rocky Linux 9.5+
- Oracle Linux 8+
- OpenSUSE Tubleweed
- Amazon Linux 2023
- Virtuozzo Linux 8+
- Windows x64
المعماريات والأجهزة المدعومة
اضغط لعرض تفاصيل المعماريات والأجهزة المدعومة
منصتنا بتدعم مجموعة متنوعة من المعماريات والأجهزة عشان تناسب بيئات مختلفة. أبرز المعماريات هي:
- amd64: المعمارية القياسية للكمبيوترات الشخصية والسيرفرات.
- x86 / i386: مستخدمة على نطاق واسع في أجهزة الديسكتوب واللاب توب.
- armv8 / arm64 / aarch64: موجهة للأجهزة المحمولة والمضمنة زي Raspberry Pi 4, Raspberry Pi 3, Raspberry Pi Zero 2/Zero 2 W, Orange Pi 3 LTS، وغيرها.
- armv7 / arm / arm32: للأجهزة المحمولة والأجهزة المضمنة القديمة، مثل Orange Pi Zero LTS, Orange Pi PC Plus, Raspberry Pi 2.
- armv6 / arm / arm32: للأجهزة المضمنة القديمة جداً، زي Raspberry Pi 1, Raspberry Pi Zero/Zero W.
- armv5 / arm / arm32: معمارية أقدم مرتبطة بالأنظمة المضمنة القديمة.
- s390x: مستخدمة في الحواسيب الرئيسية من IBM وتوفر أداء عالي واعتمادية للمشاريع الكبيرة.
اللغات
- English (إنجليزي)
- Persian (فارسي)
- Traditional Chinese (الصيني التقليدي)
- Simplified Chinese (الصيني المبسط)
- Japanese (ياباني)
- Russian (روسي)
- Vietnamese (فيتنامي)
- Spanish (إسباني)
- Indonesian (إندونيسي)
- Ukrainian (أوكراني)
- Turkish (تركي)
- Português (Brazil) (برتغالي - البرازيل)
الميزات
- مراقبة حالة النظام
- البحث داخل كل الإدخالات والعملاء
- ثيم داكن وفاتح
- دعم تعدد المستخدمين والبروتوكولات
- دعم بروتوكولات زي VMESS، VLESS، Trojan، Shadowsocks، Dokodemo-door، Socks، HTTP، wireguard
- دعم بروتوكولات XTLS الأصلية مثل RPRX-Direct، Vision، REALITY
- إحصائيات الترافيك، تحديد حد للترافيك، وتحديد فترة انتهاء الصلاحية
- قوالب إعدادات Xray قابلة للتخصيص
- دعم لوحة تحكم عبر HTTPS (بإستخدام الدومين الخاص وشهادة SSL)
- دعم التقديم على شهادات SSL بلمسة واحدة والتجديد التلقائي
- لمزيد من إعدادات التخصيص المتقدمة، راجع إعدادات البانل
- إصلاح مسارات الـ API (سيتم إنشاء إعدادات للمستخدم مع الـ API)
- دعم تغيير الإعدادات من خلال الخيارات المتوفرة في البانل
- دعم تصدير/استيراد قاعدة البيانات من خلال البانل
إعدادات البانل الافتراضية
اضغط لعرض تفاصيل الإعدادات الافتراضية
اسم المستخدم، الباسورد، البورت ومسار الويب الأساسي
لو مش هتعدل الإعدادات دي، هتتولد تلقائياً (ده مش بينطبق على Docker).
الإعدادات الافتراضية لـ Docker:
- اسم المستخدم: admin
- الباسورد: admin
- البورت: 2053
إدارة قاعدة البيانات:
ممكن تعمل نسخ احتياطية واسترجاع لقاعدة البيانات مباشرة من البانل.
- مسار قاعدة البيانات:
/etc/x-ui/x-ui.db
المسار الأساسي للويب
-
إعادة تعيين المسار الأساسي:
- افتح الترمينال.
- نفذ أمر
x-ui
. - اختار خيار "إعادة تعيين المسار الأساسي للويب".
-
توليد أو تخصيص المسار:
- المسار هيتولد تلقائياً، أو ممكن تدخل مسار مخصص.
-
عرض الإعدادات الحالية:
- لمشاهدة الإعدادات الحالية، نفذ أمر
x-ui settings
في الترمينال أو استخدم خيار "عرض الإعدادات الحالية" في البانل.
- لمشاهدة الإعدادات الحالية، نفذ أمر
توصية الأمان:
- لتحسين الأمان، استخدم كلمة طويلة وعشوائية في مسار URL الخاص بالبانل.
مثال:
http://ip:port/*webbasepath*/panel
http://domain:port/*webbasepath*/panel
إعداد WARP
اضغط لعرض تفاصيل إعداد WARP
الاستخدام
لإصدارات v2.1.0
وما بعدها:
WARP مدمج ومش محتاج تثبيت إضافي. فعل الإعدادات المطلوبة من خلال البانل.
تحديد IP
اضغط لعرض تفاصيل تحديد IP
الاستخدام
ملحوظة: تحديد IP ممكن مايشتغلش صح مع IP Tunnel.
- للإصدارات حتى
v1.6.1
:- تحديد IP مدمج في البانل.
للإصدارات v1.7.0
وما بعدها:
لتفعيل وظيفة تحديد IP، هتحتاج تثبيت fail2ban
والملفات المطلوبة من خلال الخطوات دي:
-
شغل أمر
x-ui
في الترمينال واختار "إدارة تحديد IP". -
هتلاقي الخيارات التالية:
- تغيير مدة الحظر: لتعديل مدة الحظر.
- رفع الحظر عن الجميع: لإلغاء كل الحظر الحالي.
- عرض السجلات: لمراجعة السجلات.
- حالة Fail2ban: لمراجعة حالة fail2ban.
- إعادة تشغيل Fail2ban: لإعادة تشغيل خدمة fail2ban.
- إلغاء تثبيت Fail2ban: لإلغاء تثبيت fail2ban مع إعداداته.
-
حدد مسار سجل الوصول على البانل من خلال ضبط
Xray Configs/log/Access log
على./access.log
ثم احفظ وأعد تشغيل x-ui.
-
للإصدارات قبل
v2.1.3
:- هتحتاج تضبط مسار سجل الوصول يدويًا في إعدادات Xray:
"log": { "access": "./access.log", "dnsLog": false, "loglevel": "warning" },
- هتحتاج تضبط مسار سجل الوصول يدويًا في إعدادات Xray:
-
للإصدارات
v2.1.3
وما بعدها:- في خيار لضبط
access.log
مباشرة من البانل.
- في خيار لضبط
بوت Telegram
اضغط لعرض تفاصيل بوت Telegram
الاستخدام
تدعم لوحة التحكم إشعارات بترافيك يومي، تسجيل الدخول للبانل، نسخ احتياطية للقاعدة، حالة النظام، معلومات العملاء، وغيرها من الوظائف عن طريق بوت Telegram. عشان تستخدم البوت، لازم تضبط معلمات البوت في البانل، ومن ضمنهم:
- توكن Telegram
- ID شات الأدمن (يمكن إدخال أكثر من واحد بفواصل)
- وقت الإشعار (باستخدام صيغة cron)
- إشعار بتاريخ انتهاء الصلاحية
- إشعار حد الترافيك
- نسخ احتياطية للقاعدة
- إشعار حمل المعالج
صيغة مرجعية:
30 * * * * *
- إشعار عند الـ 30 ثانية من كل دقيقة.0 */10 * * * *
- إشعار عند أول ثانية من كل 10 دقايق.@hourly
- إشعار كل ساعة.@daily
- إشعار يومي (في تمام منتصف الليل).@weekly
- إشعار أسبوعي.@every 8h
- إشعار كل 8 ساعات.
ميزات بوت Telegram
- تقارير دورية.
- إشعارات عند تسجيل الدخول.
- إشعار عند تجاوز حمل المعالج.
- تنبيهات قبل انتهاء الصلاحية أو وصول حد الترافيك.
- دعم قوائم تقارير العملاء لو تم إضافة اسم مستخدم Telegram للمستخدم في الإعدادات.
- إمكانية البحث عن تقرير الترافيك باستخدام UUID (VMESS/VLESS) أو الباسورد (TROJAN) بشكل مجهول.
- بوت يعتمد على القوائم.
- البحث عن العملاء بالإيميل (للأدمن فقط).
- استعراض كافة الإدخالات.
- عرض حالة السيرفر.
- استعراض العملاء المستنفدين.
- استقبال النسخ الاحتياطية عند الطلب وفي التقارير الدورية.
- بوت متعدد اللغات.
إعداد بوت Telegram
-
ابدأ Botfather في حساب Telegram بتاعك:
-
أنشئ بوت جديد باستخدام أمر /newbot: هيسألك سؤالين، اسم للبوت واسم مستخدم (لازم ينتهي بكلمة "bot").
ادخل توكن البوت في الحقل رقم 3. ادخل ID المستخدم في الحقل رقم 4. الحسابات اللي بالـ ID ده هيبقى ليها صلاحية الأدمن. (يمكن إدخال أكثر من واحد بفواصل)
- كيفية الحصول على ID حساب Telegram؟ استخدم هذا البوت. شغله وهيدي الـ ID بتاعك.
مسارات API
اضغط لعرض تفاصيل مسارات API
الاستخدام
- توثيق الـ API
/login
مع بيانات المستخدم باستخدامPOST
:{username: '', password: ''}
لتسجيل الدخول.- المسار الأساسي لـ
/panel/api/inbounds
للعمليات التالية:
الطريقة | المسار | الفعل |
---|---|---|
GET |
"/list" |
استرجاع كل الإدخالات |
GET |
"/get/:id" |
استرجاع إدخال بالـ id |
GET |
"/getClientTraffics/:email" |
استرجاع ترافيك عميل بالإيميل |
GET |
"/getClientTrafficsById/:id" |
استرجاع ترافيك عميل بالـ id |
GET |
"/createbackup" |
البوت بيرسل نسخة احتياطية للأدمن |
POST |
"/add" |
إضافة إدخال |
POST |
"/del/:id" |
حذف إدخال |
POST |
"/update/:id" |
تحديث إدخال |
POST |
"/clientIps/:email" |
استرجاع عنوان IP للعميل |
POST |
"/clearClientIps/:email" |
مسح عنوان IP للعميل |
POST |
"/addClient" |
إضافة عميل للإدخال |
POST |
"/:id/delClient/:clientId" |
حذف عميل باستخدام clientId* |
POST |
"/updateClient/:clientId" |
تحديث بيانات عميل باستخدام clientId* |
POST |
"/:id/resetClientTraffic/:email" |
إعادة ضبط ترافيك عميل |
POST |
"/resetAllTraffics" |
إعادة ضبط الترافيك لكل الإدخالات |
POST |
"/resetAllClientTraffics/:id" |
إعادة ضبط ترافيك كل العملاء في إدخال معين |
POST |
"/delDepletedClients/:id" |
حذف العملاء المستنفدين في الإدخال (-1: الكل) |
POST |
"/onlines" |
استرجاع قائمة العملاء الأونلاين (الإيميلات) |
*- بالنسبة لحقل clientId
:
المتغيرات البيئية
اضغط لعرض تفاصيل المتغيرات البيئية
الاستخدام
المتغير | النوع | القيمة الافتراضية |
---|---|---|
XUI_LOG_LEVEL | "debug" | "info" | "warn" | "error" |
"info" |
XUI_DEBUG | boolean |
false |
XUI_BIN_FOLDER | string |
"bin" |
XUI_DB_FOLDER | string |
"/etc/x-ui" |
XUI_LOG_FOLDER | string |
"/var/log" |
مثال:
XUI_BIN_FOLDER="bin" XUI_DB_FOLDER="/etc/x-ui" go build main.go
المعاينة







شكر خاص لـ
التحيات
- Iran v2ray rules (الرخصة: GPL-3.0): قواعد محدثة لتوجيهات v2ray/xray مع تضمين دومينات إيرانية وتركيز على الأمان وحجب الإعلانات.
- Russia v2ray rules (الرخصة: GPL-3.0): المستودع ده بيحتوي على قواعد توجيه v2ray/xray محدثة تلقائيًا بناءً على بيانات الدومينات والعناوين المحظورة في روسيا.