Rumah pembangunan bahagian belakang tutorial php Bagaimana untuk mengkonfigurasi pelayan proksi Nginx dan mendayakan SSL menggunakan bekas Docker?

Bagaimana untuk mengkonfigurasi pelayan proksi Nginx dan mendayakan SSL menggunakan bekas Docker?

Sep 05, 2023 pm 04:45 PM
docker nginx ssl

Bagaimana untuk mengkonfigurasi pelayan proksi Nginx dan mendayakan SSL menggunakan bekas Docker?

Bagaimana untuk mengkonfigurasi pelayan proksi Nginx dan mendayakan SSL menggunakan bekas Docker?

Dalam persekitaran rangkaian hari ini, keselamatan telah menjadi isu yang tidak boleh diabaikan. Untuk melindungi penghantaran data yang selamat, mendayakan sijil SSL telah menjadi langkah yang perlu. Menggunakan bekas Docker untuk mengkonfigurasi pelayan proksi Nginx telah menjadi trend. Dalam artikel ini, kami akan menerangkan cara menggunakan bekas Docker untuk mengkonfigurasi pelayan proksi Nginx dan mendayakan SSL.

Langkah 1: Pasang Docker
Mula-mula, kita perlu memasang Docker. Anda boleh memasangnya dengan merujuk kepada panduan pemasangan rasmi Docker bergantung pada sistem pengendalian anda.

Langkah 2: Buat fail konfigurasi Nginx
Sebelum mengkonfigurasi pelayan proksi Nginx, kami perlu mencipta fail konfigurasi untuk menentukan peraturan proksi kami. Cipta fail bernama nginx.conf dan tampalkan kandungan berikut ke dalamnya: nginx.conf的文件,并将以下内容粘贴进去:

worker_processes auto;

events {
  worker_connections 1024;
}

http {
  server {
    listen 80;
    server_name example.com;
    
    location / {
      proxy_pass http://backend;
      proxy_set_header Host $host;
    }
  }
}
Salin selepas log masuk

上面的配置文件指定了Nginx代理服务器监听80端口,并将所有的请求代理到名为backend的后端服务器。

步骤3:创建Docker镜像
接下来,我们需要创建一个Docker镜像来运行Nginx代理服务器。在命令行中,执行以下命令:

docker build -t nginx-proxy .
Salin selepas log masuk

该命令将读取当前目录下的Dockerfile文件,并根据其中的指令自动构建一个Docker镜像,命名为nginx-proxy

步骤4:运行Docker容器
在Docker Hub上有一个名为jwilder/nginx-proxy的官方Nginx代理服务器镜像。我们可以使用该镜像来运行一个Nginx代理服务器容器。

在命令行中,执行以下命令:

docker run -d -p 80:80 -p 443:443 -v /var/run/docker.sock:/tmp/docker.sock:ro --name nginx-proxy nginx-proxy
Salin selepas log masuk

该命令将创建一个名为nginx-proxy的Docker容器,并将主机的80端口映射到容器的80端口,443端口映射到容器的443端口。-v /var/run/docker.sock:/tmp/docker.sock:ro这个选项是为了让Docker容器能够读取主机上的Docker套接字文件。

步骤5:配置SSL证书
为了启用SSL,我们需要为我们的代理服务器配置SSL证书。我们可以使用Let's Encrypt提供的免费SSL证书。

在命令行中,执行以下命令:

docker run -d -p 80:80 -p 443:443 --name nginx-proxy nginx-proxy
Salin selepas log masuk

该命令将重新创建一个名为nginx-proxy的Docker容器,并将主机的80端口映射到容器的80端口,443端口映射到容器的443端口。

然后,执行以下命令来生成SSL证书:

docker exec nginx-proxy /app/certbot-setup.sh
Salin selepas log masuk

该脚本将自动安装certbot客户端,并请求Let's Encrypt服务器生成SSL证书。

步骤6:配置代理规则
最后,我们需要配置我们的代理规则。我们可以使用Docker的环境变量来定义我们的代理规则。

在命令行中,执行以下命令:

docker run -d -p 80:80 -p 443:443 -e "VIRTUAL_HOST=example.com" -e "LETSENCRYPT_HOST=example.com" --name backend your-backend
Salin selepas log masuk

该命令将创建一个名为backend的Docker容器,并将主机的80端口映射到容器的80端口,443端口映射到容器的443端口。-e "VIRTUAL_HOST=example.com" -e "LETSENCRYPT_HOST=example.com"rrreee

Fail konfigurasi di atas menyatakan bahawa pelayan proksi Nginx mendengar pada port 80 dan memproksi semua permintaan kepada pelayan bernama pelayan hujung belakang.

Langkah 3: Cipta Imej Docker

Seterusnya, kita perlu mencipta imej Docker untuk menjalankan pelayan proksi Nginx. Dalam baris arahan, laksanakan arahan berikut:

rrreee🎜Arahan ini akan membaca fail Dockerfile dalam direktori semasa dan secara automatik membina imej Docker mengikut arahan di dalamnya, bernama nginx- proksi . 🎜🎜Langkah 4: Jalankan bekas Docker 🎜Terdapat imej pelayan proksi Nginx rasmi yang dipanggil jwilder/nginx-proxy pada Docker Hub. Kita boleh menggunakan imej ini untuk menjalankan bekas pelayan proksi Nginx. 🎜🎜Dalam baris arahan, laksanakan arahan berikut: 🎜rrreee🎜Arahan ini akan mencipta bekas Docker bernama nginx-proxy dan memetakan port 80 hos ke port 80 kontena, 443 port Peta ke port 443 daripada bekas itu. -v /var/run/docker.sock:/tmp/docker.sock:ro Pilihan ini adalah untuk membolehkan bekas Docker membaca fail soket Docker pada hos. 🎜🎜Langkah 5: Konfigurasikan Sijil SSL🎜Untuk mendayakan SSL, kami perlu mengkonfigurasi sijil SSL untuk pelayan proksi kami. Kami boleh menggunakan sijil SSL percuma yang disediakan oleh Let's Encrypt. 🎜🎜Dalam baris arahan, laksanakan arahan berikut: 🎜rrreee🎜Arahan ini akan mencipta semula bekas Docker bernama nginx-proxy dan memetakan port 80 hos ke port 80 bekas, 443 Port dipetakan ke port 443 kontena. 🎜🎜Kemudian, laksanakan arahan berikut untuk menjana sijil SSL: 🎜rrreee🎜Skrip akan memasang klien certbot secara automatik dan meminta pelayan Let's Encrypt untuk menjana sijil SSL. 🎜🎜Langkah 6: Konfigurasikan Peraturan Proksi🎜Akhir sekali, kami perlu mengkonfigurasi peraturan proksi kami. Kami boleh menggunakan pembolehubah persekitaran Docker untuk menentukan peraturan proksi kami. 🎜🎜Dalam baris arahan, laksanakan arahan berikut: 🎜rrreee🎜Arahan ini akan mencipta bekas Docker bernama backend dan memetakan port 80 hos ke port 80 kontena dan port 443 ke The 443 pelabuhan kontena. -e "VIRTUAL_HOST=example.com" -e "LETSENCRYPT_HOST=example.com"Dua pilihan ini akan mengkonfigurasi peraturan proksi kami. 🎜🎜Selepas melengkapkan langkah di atas, pelayan proksi Nginx kami boleh melakukan proksi selamat melalui SSL. Anda boleh menyesuaikan lebih banyak peraturan proksi dan menambah lebih banyak bekas untuk memenuhi keperluan anda. 🎜🎜Semoga artikel ini bermanfaat untuk anda. Jika anda mempunyai sebarang soalan, sila tinggalkan komen di bawah dan saya akan cuba menjawabnya. Terima kasih kerana membaca! 🎜

Atas ialah kandungan terperinci Bagaimana untuk mengkonfigurasi pelayan proksi Nginx dan mendayakan SSL menggunakan bekas Docker?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

AI Hentai Generator

AI Hentai Generator

Menjana ai hentai secara percuma.

Alat panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Cara mengemas kini imej Docker Cara mengemas kini imej Docker Apr 15, 2025 pm 12:03 PM

Langkah -langkah untuk mengemas kini imej Docker adalah seperti berikut: Tarik tag imej terkini imej baru memadam imej lama untuk tag tertentu (pilihan) mulakan semula bekas (jika diperlukan)

Cara membuat cermin di Docker Cara membuat cermin di Docker Apr 15, 2025 am 11:27 AM

Langkah -langkah untuk membuat imej Docker: Tulis Dockerfile yang mengandungi arahan membina. Bina imej di terminal, menggunakan arahan membina Docker. Tag imej dan tetapkan nama dan tag menggunakan arahan tag docker.

Cara menggunakan desktop docker Cara menggunakan desktop docker Apr 15, 2025 am 11:45 AM

Bagaimana cara menggunakan desktop Docker? Docktop Docktop adalah alat untuk menjalankan bekas Docker pada mesin tempatan. Langkah -langkah untuk digunakan termasuk: 1. Pasang desktop Docker; 2. Mulakan desktop Docker; 3. Buat imej Docker (menggunakan Dockerfile); 4. Membina imej Docker (menggunakan Docker Build); 5. Jalankan bekas Docker (menggunakan Docker Run).

Cara Membaca Versi Docker Cara Membaca Versi Docker Apr 15, 2025 am 11:51 AM

Untuk mendapatkan versi Docker, anda boleh melakukan langkah -langkah berikut: Jalankan arahan Docker "Docker -version" untuk melihat versi klien dan pelayan. Untuk MAC atau Windows, anda juga boleh melihat maklumat versi melalui tab versi Docktop GUI atau menu desktop Docker.

Cara memeriksa nama bekas Docker Cara memeriksa nama bekas Docker Apr 15, 2025 pm 12:21 PM

Anda boleh menanyakan nama kontena Docker dengan mengikuti langkah -langkah: Senaraikan semua bekas (Docker PS). Tapis senarai kontena (menggunakan arahan grep). Mendapat nama kontena (terletak di lajur "Nama").

Cara Menyelamatkan Gambar Docker Cara Menyelamatkan Gambar Docker Apr 15, 2025 am 11:54 AM

Untuk menyimpan imej di Docker, anda boleh menggunakan arahan Docker Commit untuk membuat imej baru, yang mengandungi keadaan semasa bekas yang ditentukan, Sintaks: Docker Commit [Options] Nama Imej Container ID. Untuk menyimpan imej ke repositori, anda boleh menggunakan arahan PUSH Docker, Sintaks: Docker Push Nama Imej [: TAG]. Untuk mengimport imej yang disimpan, anda boleh menggunakan arahan tarik docker, sintaks: docker tarik nama imej [: tag].

Cara menyalin fail di Docker ke luar Cara menyalin fail di Docker ke luar Apr 15, 2025 pm 12:12 PM

Kaedah untuk menyalin fail ke tuan rumah luaran di Docker: Gunakan arahan CP Docker: Jalankan Docker CP [Options] & lt; Container Path & GT; & lt; PATH HOST & GT;. Menggunakan jumlah data: Buat direktori pada tuan rumah, dan gunakan parameter -V parameter untuk memasang direktori ke dalam bekas apabila membuat bekas untuk mencapai penyegerakan fail bidirectional.

Cara Memulakan Bekas oleh Docker Cara Memulakan Bekas oleh Docker Apr 15, 2025 pm 12:27 PM

Docker Container Startup Langkah: Tarik Imej Bekas: Run "Docker Pull [Mirror Name]". Buat bekas: Gunakan "Docker Buat [Pilihan] [Nama Mirror] [Perintah dan Parameter]". Mulakan bekas: Jalankan "Docker Start [Nama Container atau ID]". Semak Status Kontena: Sahkan bahawa bekas sedang berjalan dengan "Docker PS".

See all articles