Apabila kami mempunyai lebih banyak projek, pergi ke pelayan secara manual untuk mengubah suai konfigurasi nginx sangat menyusahkan dan mungkin menjadi salah. Kami boleh melaksanakan penyelesaian melalui nginx+confd+配置中心
untuk mengelakkan ralat dan mengurangkan proses yang menyusahkan.
Pertama, muatkan terus fail docker nginx+confd
FROM nginx:1.21.6 # 拷贝confd二进制可执行文件 https://github.com/kelseyhightower/confd/releases/tag/v0.16.0 COPY ./confd-0.16.0-linux-amd64 /usr/local/bin/confd # 拷贝wait-for脚本 https://github.com/Eficode/wait-for COPY ./wait-for / # 安装nc支持wait-for脚本 RUN apt-get update \ && DEBIAN_FRONTEND=noninteractive apt-get install -y \ net-tools \ && apt-get clean \ && rm -rf /var/lib/apt/lists/* RUN apt-get update \ && DEBIAN_FRONTEND=noninteractive apt-get install -y \ netcat \ && apt-get clean \ && rm -rf /var/lib/apt/lists/* # 创建配置文件目录 RUN mkdir -p /etc/confd/conf.d \ # 给可执行权限 && chmod +x /usr/local/bin/confd \ && chmod 777 /wait-for \ # 使用脚本启动多进程 && echo "#!/bin/bash" >> start.sh \ && echo "nohup /usr/local/bin/confd -config-file /etc/confd/conf/confd.toml &" >> start.sh \ && echo "nginx -g 'daemon off;'" >> start.sh \ && chmod 664 ./start.sh CMD ["bash", "start.sh"]
Jika anda tidak mahu menjananya sendiri, anda boleh menggunakan:
https:/ /hub.docker.com/repository/docker /lablelan/nginx-confd
Docker-compose digunakan di sini untuk menunjukkan cara menggunakan nginx+confd+etcd+etcdkeeper untuk mengubah suai konfigurasi nginx secara grafik
version: '2' networks: app-tier: driver: bridge ipam: driver: default config: - subnet: 172.22.0.0/16 services: Etcd: image: 'bitnami/etcd:3.5.2' environment: - ALLOW_NONE_AUTHENTICATION=yes - ETCD_ADVERTISE_CLIENT_URLS=http://etcd:2379 ports: - 2379:2379 - 2380:2380 networks: app-tier: ipv4_address: 172.22.0.2 EtcdKeeper: image: 'deltaprojects/etcdkeeper:latest' - 8000:8080 ipv4_address: 172.22.0.3 Nginx: image: 'lablelan/nginx-confd' command: sh -c '/wait-for Etcd:2379 -- bash start.sh' depends_on: - Etcd volumes: - "./confd.toml:/etc/confd/conf/confd.toml" - "./nginx.tmpl:/etc/confd/templates/nginx.tmpl" - "./myapp-nginx.toml:/etc/confd/conf.d/myapp-nginx.toml" - "./nginx.conf:/etc/nginx/nginx.conf" - "./conf.d:/etc/nginx/conf.d" - 80:80 ipv4_address: 172.22.0.4
Selepas permulaan, ia akan dibuat melalui etcdkeeper Atau mengemas kini /myapp/services/web/www/1 akan menjana konfigurasi nginx secara dinamik (port 80 forwards port 8080) dan berkuat kuasa secara automatik. IP yang dikonfigurasikan di sini ialah IP intranet dan tidak menggunakan 127.0.0.1, kerana perkhidmatan itu tidak berjalan pada bekas nginx (perhatikan bahawa hos tempatan saya untuk www.lablelan.com ditetapkan kepada 127.0.0.1)
Perkhidmatan yang dijalankan pada port 8080 di sini ialah perkhidmatan demo yang mudah (nodejs Jika anda memerlukannya, anda boleh mendapatkannya dari gitee
https://). gitee.com/lablelan/amis-demo
Selepas mengkonfigurasi etcd, kita dapat melihat bahawa mengakses http://www.lablelan.com/select telah berjaya dikembalikan
Ini mungkin tidak berlaku. Ini tidak menggambarkan kepraktisan penyelesaian ini. Malah, kami boleh merealisasikan fungsi penemuan perkhidmatan dengan mendaftarkan maklumat perkhidmatan semasa ke etcd dalam kod perniagaan, supaya nginx. konfigurasi boleh dijana secara dinamik untuk mengelakkan pengubahsuaian manual konfigurasi nginx dan mengurangkan ralat.
Atas ialah kandungan terperinci Bagaimana untuk menjana konfigurasi secara dinamik melalui nginx+confd dalam docker. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!