Reverse proxy - Truy cập từ domain vào nhiều server trên 1 public IP

Reverse proxy - Truy cập từ domain vào nhiều server trên 1 public IP

Truy cập từ domain vào cùng 1 port 80 trên 2 server khác nhau trong cùng 1 public IP tại nhà

Bạn đang cài đặt ở nhà 2 máy tính (raspberry và PC của bạn) cùng cần truy cập theo domain với port 80,443 tuy nhiên bạn không thể setup trên cùng 1 public IP này port để truy cập vào server khác nhau, chúng sẽ liên tục chiếm quyền trên 1 public IP này. Vậy đâu là giải pháp hiệu quả?

Nhà mạng chỉ cung cấp 1 địa chỉ IP tại 1 thời điểm, trong trường hợp bạn cần public 1 server với port 80 và 443 thì đơn giản chỉ cần NAT để open port. Tuy nhiên vấn đề sẽ phát sinh khi bạn bắt đầu setup nhiều server trong cùng 1 server với cùng port hoặc khác server IP nhưng cùng port, hệ thống mạng gia đình sẽ không cho phép việc này. Bạn cần một cơ chế ở giữa để phân bổ với domain nào truy cập vào public IP sẽ được truy cập vào local IP server tương ứng để lấy dữ liệu. Khái niệm này gọi là reverse proxy, và có nhiều công cụ để thực hiện. Ở đây mình giới thiệu công cụ đơn giản nhất Caddy.

Cài đặt Caddy bằng Docker

Bạn có thể cài đặt Caddy bằng nhiều cách thông qua hướng dẫn ở đây.

Mình chọn cách cài đặt bằng Docker để có thể dễ dàng xóa đi khi cần mà không ảnh hưởng đến hệ thống.

Tạo file compose.yml

mkdir ~/caddy
cd ~/caddy
nano compose.yml

Nhập vào nội dung sau

services:
  caddy:
    image: caddy:2.7.6-alpine
    container_name: caddy
    restart: unless-stopped
    ports:
      - "80:80"
      - "443:443"
      - "443:443/udp"
    volumes:
      - ./Caddyfile:/etc/caddy/Caddyfile
      - ./html:/var/www/html
      - ./caddy_data:/data
      - ./caddy_config:/config

Tạo thêm file Caddyfile

nano CaddyfileCode language: Nginx (nginx)

và nhập tạm vào nội dung

:80 {
	respond "Hello, world!"
}

Kích hoạt Caddy

docker compose up -d

Mở trình duyệt truy cập vào địa chỉ http://<IP>, nếu thấy hiện ra dòng chữ Hello, world! nghĩa là Caddy đã được cài đặt và kích hoạt thành công.

Cấu hình Caddy làm Reverse Proxy

Để cấu hình Caddy làm Reverse Proxy cho Portainer đang chạy ở địa chỉ 192.168.0.50:9000, mình chỉnh sửa file Caddyfile và bổ sung thêm 3 dòng sau

portainer.thuanbui.me {
	reverse_proxy 192.168.0.50:9000
}

Sau đó khởi động lại Caddy bằng lệnh

docker compose exec -w /etc/caddy caddy caddy reload

Chờ 1-2 phút để Caddy hoàn thành bước xác thực chứng chỉ SSL, giờ mình đã có thể truy cập Portainer thông qua địa chỉ https://portainer.thuanbui.me

Trong trường hợp Portainer và caddy nằm cùng trên 1 server, bạn có thể tham khảo bài viết dưới đây để biết cách thiết lập các container vào chung 1 docker network và chỉnh sửa lại Caddyfile như sau

portainer.thuanbui.me {
	reverse_proxy portainer
}

P/s: Có những công cụ khác để quản lý proxy bằng UI, bạn có thể tham khảo bài viết https://thuanbui.me/nginx-proxy-manager-reverse-proxy-openlitespeed-docker/

Bạn đã đăng ký thành công vào Geek Playground
Tuyệt vời! Tiếp theo, hoàn tất thanh toán để có quyền truy cập đầy đủ vào Geek Playground
Chào mừng trở lại! Bạn đã đăng nhập thành công.
Thành công! Tài khoản của bạn đã được kích hoạt đầy đủ, bạn hiện có quyền truy cập vào tất cả nội dung.
Thành công! Thông tin thanh toán của bạn đã được cập nhật.
Cập nhật thông tin thanh toán không thành công.