OmniRoute/docs/i18n/vi/VM_DEPLOYMENT_GUIDE.md
diegosouzapw fd2a1320e0 fix: resolve issues #462, #471 — deprecate gemini-cli, regenerate VM guide i18n
- #462: Mark gemini-cli provider as deprecated in providers.ts
  Add deprecated, deprecationReason, hasFree, freeNote, authHint, apiHint
  to Zod provider schema
- #471: Add VM_DEPLOYMENT_GUIDE.md to DOC_SOURCE_FILES in generate-multilang.mjs
  Delete 29 stale PT-language copies and regenerate from EN source
  for all 30 locales (29 auto-translated + 1 Czech from PR #482)
2026-03-19 15:57:55 -03:00

12 KiB
Raw Blame History

OmniRoute — Hướng dẫn triển khai trên VM với Cloudflare

🌐 Languages: 🇺🇸 English | 🇧🇷 Português (Brasil) | 🇪🇸 Español | 🇫🇷 Français | 🇮🇹 Italiano | 🇷🇺 Русский | 🇨🇳 中文 (简体) | 🇩🇪 Deutsch | 🇮🇳 हिन्दी | 🇹🇭 ไทย | 🇺🇦 Українська | 🇸🇦 العربية | 🇯🇵 日本語 | 🇻🇳 Tiếng Việt | 🇧🇬 Български | 🇩🇰 Dansk | 🇫🇮 Suomi | 🇮🇱 עברית | 🇭🇺 Magyar | 🇮🇩 Bahasa Indonesia | 🇰🇷 한국어 | 🇲🇾 Bahasa Melayu | 🇳🇱 Nederlands | 🇳🇴 Norsk | 🇵🇹 Português (Portugal) | 🇷🇴 Română | 🇵🇱 Polski | 🇸🇰 Slovenčina | 🇸🇪 Svenska | 🇵🇭 Filipino | 🇨🇿 Čeština

Hướng dẫn đầy đủ để cài đặt và định cấu hình OmniRoute trên VM (VPS) với miền được quản lý qua Cloudflare.


Điều kiện tiên quyết

Mục Tối thiểu Được đề xuất
CPU 1 vCPU 2 vCPU
RAM 1 GB 2 GB
Đĩa SSD 10GB SSD 25 GB
HĐH Ubuntu 22.04 LTS Ubuntu 24.04 LTS
Miền Đã đăng ký trên Cloudflare
Docker Công cụ Docker 24+ Docker 27+

Các nhà cung cấp đã được thử nghiệm: Akamai (Linode), DigitalOcean, Vultr, Hetzner, AWS Lightsail.


1. Cấu hình VM

1.1 Tạo phiên bản

Trên nhà cung cấp VPS ưa thích của bạn:

  • Chọn Ubuntu 24.04 LTS
  • Chọn gói tối thiểu (1 vCPU / 1 GB RAM)
  • Đặt mật khẩu root mạnh hoặc định cấu hình khóa SSH
  • Lưu ý IP công cộng (ví dụ: 203.0.113.10)

1.2 Kết nối qua SSH

ssh root@203.0.113.10

1.3 Cập nhật hệ thống

apt update && apt upgrade -y

1.4 Cài đặt Docker

# Install dependencies
apt install -y ca-certificates curl gnupg

# Add official Docker repository
install -m 0755 -d /etc/apt/keyrings
curl -fsSL https://download.docker.com/linux/ubuntu/gpg | gpg --dearmor -o /etc/apt/keyrings/docker.gpg
chmod a+r /etc/apt/keyrings/docker.gpg
echo "deb [arch=$(dpkg --print-architecture) signed-by=/etc/apt/keyrings/docker.gpg] https://download.docker.com/linux/ubuntu $ (. /etc/os-release && echo “$VERSION_CODENAME”) stable" | tee /etc/apt/sources.list.d/docker.list > /dev/null
apt update
apt install -y docker-ce docker-ce-cli containerd.io docker-compose-plugin

1.5 Cài đặt nginx

apt install -y nginx

1.6 Cấu hình tường lửa (UFW)

ufw default deny incoming
ufw default allow outgoing
ufw allow 22/tcp    # SSH
ufw allow 80/tcp    # HTTP (redirect)
ufw allow 443/tcp   # HTTPS
ufw enable

Mẹo: Để bảo mật tối đa, hãy hạn chế cổng 80 và 443 đối với IP Cloudflare. Xem phần Advanced Security.


2. Cài đặt OmniRoute

2.1 Tạo thư mục cấu hình

mkdir -p /opt/omniroute

2.2 Tạo tệp biến môi trường

cat > /opt/omniroute/.env << EOF
# === Security ===
JWT_SECRET=CHANGE-TO-A-UNIQUE-64-CHAR-SECRET-KEY
INITIAL_PASSWORD=YourSecurePassword123!
API_KEY_SECRET=REPLACE-WITH-ANOTHER-SECRET-KEY
STORAGE_ENCRYPTION_KEY=REPLACE-WITH-THIRD-SECRET-KEY
STORAGE_ENCRYPTION_KEY_VERSION=v1
MACHINE_ID_SALT=CHANGE-TO-A-UNIQUE-SALT

# === App ===
PORT=20128
NODE_ENV=production
HOSTNAME=0.0.0.0
DATA_DIR=/app/data
STORAGE_DRIVER=sqlite
ENABLE_REQUEST_LOGS=true
AUTH_COOKIE_SECURE=false
REQUIRE_API_KEY=false

# === Domain (change to your domain) ===
BASE_URL=https://llms.seudominio.com
NEXT_PUBLIC_BASE_URL=https://llms.seudominio.com

# === Cloud Sync (optional) ===
# CLOUD_URL=https://cloud.omniroute.online
# NEXT_PUBLIC_CLOUD_URL=https://cloud.omniroute.online
EOF

⚠️ QUAN TRỌNG: Tạo các khóa bí mật duy nhất! Sử dụng openssl rand -hex 32 cho mỗi khóa.

2.3 Khởi động container

docker pull diegosouzapw/omniroute:latest

docker run -d \
  --name omniroute \
  --restart unless-stopped \
  --env-file /opt/omniroute/.env \
  -p 20128:20128 \
  -v omniroute-data:/app/data \
  diegosouzapw/omniroute:latest

2.4 Xác minh rằng nó đang chạy

docker ps | grep omniroute
docker logs omniroute --tail 20

Nó sẽ hiển thị: [DB] SQLite database readylistening on port 20128.


3. Cấu hình nginx (Proxy ngược)

3.1 Tạo chứng chỉ SSL (Nguồn gốc Cloudflare)

Trong bảng điều khiển Cloudflare:

  1. Đi tới SSL/TLS → Máy chủ gốc
  2. Nhấp vào Tạo chứng chỉ
  3. Giữ nguyên giá trị mặc định (15 năm, *.yourdomain.com)
  4. Sao chép Chứng chỉ xuất xứKhóa riêng
mkdir -p /etc/nginx/ssl

# Paste the certificate
nano /etc/nginx/ssl/origin.crt

# Paste the private key
nano /etc/nginx/ssl/origin.key

chmod 600 /etc/nginx/ssl/origin.key

3.2 Cấu hình Nginx

cat > /etc/nginx/sites-available/omniroute << NGINX
# Default server — blocks direct access via IP
server {
    listen 80 default_server;
    listen [::]:80 default_server;
    listen 443 ssl default_server;
    listen [::]:443 ssl default_server;
    ssl_certificate     /etc/nginx/ssl/origin.crt;
    ssl_certificate_key /etc/nginx/ssl/origin.key;
    server_name _;
    return 444;
}

# OmniRoute — HTTPS
server {
    listen 443 ssl;
    listen [::]:443 ssl;
    server_name llms.yourdomain.com;  # Change to your domain

    ssl_certificate     /etc/nginx/ssl/origin.crt;
    ssl_certificate_key /etc/nginx/ssl/origin.key;
    ssl_protocols TLSv1.2 TLSv1.3;

    client_max_body_size 100M;

    location / {
        proxy_pass http://127.0.0.1:20128;
        proxy_set_header Host $host;
        proxy_set_header X-Real-IP $remote_addr;
        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
        proxy_set_header X-Forwarded-Proto $scheme;

        # WebSocket support
        proxy_http_version 1.1;
        proxy_set_header Upgrade $http_upgrade;
        proxy_set_header Connection “upgrade”;

        # SSE (Server-Sent Events) — streaming AI responses
        proxy_buffering off;
        proxy_cache off;
        proxy_read_timeout 300s;
        proxy_send_timeout 300s;
    }
}

# HTTP → HTTPS redirect
server {
    listen 80;
    listen [::]:80;
    server_name llms.yourdomain.com;
    return 301 https://$server_name$request_uri;
}
NGINX

3.3 Kích hoạt và kiểm tra

# Remove default configuration
rm -f /etc/nginx/sites-enabled/default

# Enable OmniRoute
ln -sf /etc/nginx/sites-available/omniroute /etc/nginx/sites-enabled/omniroute

# Test and reload
nginx -t && systemctl reload nginx

4. Cấu hình DNS Cloudflare

4.1 Thêm bản ghi DNS

Trong bảng điều khiển Cloudflare → DNS:

Loại Tên Nội dung Ủy nhiệm
A llms 203.0.113.10 (IP VM) Được ủy quyền

4.2 Định cấu hình SSL

Trong SSL/TLS → Tổng quan:

  • Chế độ: Đầy đủ (Nghiêm ngặt)

Trong SSL/TLS → Chứng chỉ biên:

  • Luôn sử dụng HTTPS: Bật
  • Phiên bản TLS tối thiểu: TLS 1.2
  • Tự động ghi lại HTTPS: Bật

4.3 Kiểm tra

curl -sI https://llms.seudominio.com/health
# Should return HTTP/2 200

5. Vận hành và bảo trì

Nâng cấp lên phiên bản mới

docker pull diegosouzapw/omniroute:latest
docker stop omniroute && docker rm omniroute
docker run -d --name omniroute --restart unless-stopped \
  --env-file /opt/omniroute/.env \
  -p 20128:20128 \
  -v omniroute-data:/app/data \
  diegosouzapw/omniroute:latest

Xem nhật ký

docker logs -f omniroute          # Real-time stream
docker logs omniroute --tail 50   # Last 50 lines

Sao lưu cơ sở dữ liệu thủ công

# Copy data from the volume to the host
docker cp omniroute:/app/data ./backup-$(date +%F)

# Or compress the entire volume
docker run --rm -v omniroute-data:/data -v $(pwd):/backup \
  alpine tar czf /backup/omniroute-data-$(date +%F).tar.gz /data

Khôi phục từ bản sao lưu

docker stop omniroute
docker run --rm -v omniroute-data:/data -v $(pwd):/backup \
  alpine sh -c “rm -rf /data/* && tar xzf /backup/omniroute-data-YYYY-MM-DD.tar.gz -C /”
docker start omniroute

6. Bảo mật nâng cao

Hạn chế nginx đối với IP Cloudflare

cat > /etc/nginx/cloudflare-ips.conf << CF
# Cloudflare IPv4 ranges — update periodically
# https://www.cloudflare.com/ips-v4/
set_real_ip_from 173.245.48.0/20;
set_real_ip_from 103.21.244.0/22;
set_real_ip_from 103.22.200.0/22;
set_real_ip_from 103.31.4.0/22;
set_real_ip_from 141.101.64.0/18;
set_real_ip_from 108.162.192.0/18;
set_real_ip_from 190.93.240.0/20;
set_real_ip_from 188.114.96.0/20;
set_real_ip_from 197.234.240.0/22;
set_real_ip_from 198.41.128.0/17;
set_real_ip_from 162.158.0.0/15;
set_real_ip_from 104.16.0.0/13;
set_real_ip_from 104.24.0.0/14;
set_real_ip_from 172.64.0.0/13;
set_real_ip_from 131.0.72.0/22;
real_ip_header CF-Connecting-IP;
CF

Thêm phần sau vào nginx.conf bên trong khối http {}:

include /etc/nginx/cloudflare-ips.conf;

Cài đặt failed2ban

apt install -y fail2ban
systemctl enable fail2ban
systemctl start fail2ban

# Check status
fail2ban-client status sshd

Chặn quyền truy cập trực tiếp vào cổng Docker

# Prevent direct external access to port 20128
iptables -I DOCKER-USER -p tcp --dport 20128 -j DROP
iptables -I DOCKER-USER -i lo -p tcp --dport 20128 -j ACCEPT

# Persist the rules
apt install -y iptables-persistent
netfilter-persistent save

7. Triển khai lên Cloudflare Workers (Tùy chọn)

Để truy cập từ xa thông qua Cloudflare Workers (không để lộ trực tiếp VM):

# In the local repository
cd omnirouteCloud
npm install
npx wrangler login
npx wrangler deploy

Xem tài liệu đầy đủ tại omnirouteCloud/README.md.


Tóm tắt cổng

Cảng Dịch vụ Truy cập
22 SSH Công khai (với Fail2ban)
80 nginx HTTP Chuyển hướng → HTTPS
443 nginx HTTPS Qua Proxy Cloudflare
20128 OmniRoute Chỉ Localhost (thông qua nginx)