- vừa được xem lúc

Dùng Nginx trên docker swarm và script để tạo và gia hạn ssl trên docker swarm.

0 0 59

Người đăng: Nham Van Hung

Theo Viblo Asia

1. Mở đầu

Như bài viết trước mình đã giới thiệu với các bạn về docker swarm, gluster, swarmpit. Bài biết này mình sẽ triển khai Nginx trên cụm swarm và script để tạo và gia hạn ssl trên cụm swarm của mình nhé. Cái này rất thích hợp cho các bạn triển khai nhiều domain trên cùng 1 cụm swarm.

2. Nào chúng ta cùng bắt đầu.

2.1 Trỏ domain về IP của 3 server trong cụm swarm

Cái này thì mình sẽ không viết. Các bạn chỉ cần lên giao diện quản lý domain và thực hiện thao tác trỏ IP là được.

2.2 Tạo container Nginx trên docker swarm

Đầu tiên chúng ta cần tạo container Nginx. Chúng ta đăng nhập vào giao diện quản lý cụm swarm theo link http://ipserver:888 như bài trước mình đã làm. Chọn Stacks => New Stack sau đó chúng ta điền như hình: image.png

 version: '3.3'
services: nginx: image: nginx:stable volumes: - /mnt/data/ceph/letsencrypt/data/:/data/letsencrypt/ - /mnt/data/ceph/letsencrypt/etc/:/etc/letsencrypt/ - /mnt/data/ceph/nginx/etc/:/etc/nginx/ - /mnt/data/www/:/www networks: - host logging: driver: json-file deploy: mode: global
networks: host: external: true
  • Ở đây chúng ta mount volumes để lấy file cấu hình ssl và cấu hình nginx lần lượt là /mn/data/ceph/letsencrypt//mnt/data/ceph/nginx/etc/
  • Thư mục chứa các file frontend là /mnt/data/www

2.3 Tạo file cấu hình nginx

Đăng nhập vào 1 trong 3 server trong cụm swarm Tạo đường dẫn /mn/data/ceph/letsencrypt//mnt/data/ceph/nginx/etc/ image.png image.png Các file trong thư mục /mnt/data/ceph/nginx/etc/ như 1 cấu hình nginx bình thường các bạn có thể cài nginx rồi coppy lên server . Ở đây ta chỉ chú ý đến file nginx.conf và thư mục conf.d chứa các file cấu hình cho từng domain File nginx.conf image.png

user nginx;
worker_processes 1; error_log /var/log/nginx/error.log warn;
pid /var/run/nginx.pid; events { worker_connections 1024;
} http { include /etc/nginx/mime.types; default_type application/octet-stream; log_format main '$remote_addr - $remote_user [$time_local] "$request" ' '$status $body_bytes_sent "$http_referer" ' '"$http_user_agent" "$http_x_forwarded_for"'; access_log /var/log/nginx/access.log main; sendfile on; #tcp_nopush on; keepalive_timeout 65; #gzip on; include /etc/nginx/conf.d/*.conf;
}
  • Trong thư mục conf.d ta tạo file daotaoyte.edu.vn.conf image.png
server { listen 443 ssl http2; listen [::]:443 ssl http2; server_name daotaoyte.edu.vn www.daotaoyte.edu.vn; ssl_certificate /etc/letsencrypt/live/daotaoyte.edu.vn/fullchain.pem; ssl_certificate_key /etc/letsencrypt/live/daotaoyte.edu.vn/privkey.pem; ssl_session_timeout 5m; ssl_protocols TLSv1 TLSv1.1 TLSv1.2; #ssl_ciphers "HIGH:!aNULL:!MD5 or HIGH:!aNULL:!MD5:!3DES"; ssl_prefer_server_ciphers on; charset utf-8; root /www/daotaoyte.edu.vn; location / { try_files $uri $uri/home.html home.html; } location /mail { proxy_pass http://localhost:5000/; } }

2.4 Tạo file để cấu hình ssl (https)

Ở đây mình sẽ dùng 1 script để tạo và gia hạn ssl mình sẽ giới thiệu với các bạn trong bài sau ?. Bây giờ mình sẽ xài luôn. image.png

2.5 Tạo file build và deploy nginx trên docker

  • Sau đó các bạn build file frontend và copy file đó vào thư mục /mnt/data/ww
  • Tiếp đó chúng ta chỉ cần deploy stacks nginx_proxy bằng cách lên giao diện swarmpit và ấn deploylà xong image.png

3. Kiểm tra

-Vào trang web vừa triển khai kiểm tra thử image.png Chúng ta đã triển khai thành công nginx trên cụm docker swarm. Do gluster nên dữ liệu đã được đồng bộ trên cả 3 server. Chúng ta trỏ IP cả 3 server về domain nhé. Điều này sẽ giúp phân tải cho server. Cảm ơn các bạn đã đọc bài viết của mình.

Bình luận

Bài viết tương tự

- vừa được xem lúc

Cài đặt WSL / WSL2 trên Windows 10 để code như trên Ubuntu

Sau vài ba năm mình chuyển qua code trên Ubuntu thì thật không thể phủ nhận rằng mình đã yêu em nó. Cá nhân mình sử dụng Ubuntu để code web thì thật là tuyệt vời.

0 0 374

- vừa được xem lúc

Phần 1: Giới thiệu về Kubernetes

Kubernetes là gì. Trang chủ: https://kubernetes.io/. Ai cần Kubernetes.

0 0 80

- vừa được xem lúc

Docker: Chưa biết gì đến biết dùng (Phần 1- Lịch sử)

1. Vì sao nên sử dụng. . .

0 0 89

- vừa được xem lúc

Docker - những kiến thức cơ bản phần 1

Giới thiệu. Nếu bạn đang làm ở một công ty công nghệ thông tin, chắc rằng bạn đã được nghe nói về Docker.

0 0 65

- vừa được xem lúc

Docker: Chưa biết gì đến biết dùng (Phần 2 - Dockerfile)

1. Mở đầu.

0 0 53

- vừa được xem lúc

Docker: Chưa biết gì đến biết dùng (Phần 3: Docker-compose)

1. Mở đầu. . .

0 0 106