Cara menggunakan Docker untuk pengembangan mendatar dan pengimbangan beban kontena
Pengenalan:
Dengan pembangunan berterusan teknologi pengkomputeran awan, teknologi kontena kini telah menjadi salah satu cara arus perdana untuk membina, menggunakan dan mengurus aplikasi. Sebagai platform kontena paling popular pada masa ini, Docker bukan sahaja menyediakan kaedah pembungkusan dan penggunaan aplikasi yang mudah, tetapi juga menyokong pengembangan mendatar dan pengimbangan beban kontena. Artikel ini akan memperkenalkan secara terperinci cara menggunakan Docker untuk pengembangan mendatar dan pengimbangan beban bekas, dan memberikan contoh kod khusus.
1. Peluasan mendatar kontena Docker
Peluasan mendatar kontena merujuk kepada meningkatkan keupayaan pemprosesan dan kesesuaian aplikasi dengan menambah bilangan kontena. Docker menyediakan pelbagai cara untuk mencapai pengembangan mendatar bekas Dua cara biasa diperkenalkan di bawah.
version: '3' services: web: build: . ports: - "80:80" depends_on: - db db: image: mysql:5.7 environment: - MYSQL_ROOT_PASSWORD=root
Katakan kita ingin mengembangkan bilangan bekas aplikasi web daripada 1 kepada 3, kita hanya perlu menukar web dalam fail di atas Cuma tukar atribut replika perkhidmatan kepada 3:
version: '3' services: web: build: . ports: - "80:80" depends_on: - db replicas: 3 db: image: mysql:5.7 environment: - MYSQL_ROOT_PASSWORD=root
Kemudian gunakan arahan berikut untuk memulakan dan mengurus bekas:
$ docker-compose up -d
Docker Compose secara automatik akan membantu kami mencipta dan mengurus 3 bekas aplikasi web, dengan itu mencapai mendatar pengembangan bekas.
version: '3' services: web: image: nginx:latest deploy: replicas: 3 restart_policy: condition: on-failure
Dengan menggunakan arahan yang disediakan oleh Docker Swarm, anda boleh membuat dan mengurus bekas dengan cepat dan mencapai pengembangan mendatar bekas:
$ docker stack deploy -c docker-compose.yml myapp
Gunakan arahan di atas untuk menukar fail konfigurasi yang ditakrifkan di atas Perkhidmatan web dicipta sebagai perkhidmatan bernama myapp, yang mengandungi 3 bekas. Docker Swarm secara automatik akan mencipta dan mengurus ketiga-tiga bekas ini pada nod berbeza dalam kelompok, mencapai pengembangan mendatar bekas.
2. Pengimbangan beban kontena Docker
Pengimbangan beban merujuk kepada pengagihan permintaan secara sekata antara berbilang bekas untuk meningkatkan kuasa pemprosesan dan ketersediaan aplikasi. Docker menyediakan pelbagai cara untuk mencapai pengimbangan beban bekas Dua kaedah yang biasa digunakan diperkenalkan di bawah.
version: '3' services: web1: build: . ports: - "8080:80" web2: build: . ports: - "8081:80"
Melalui konfigurasi di atas, permintaan aplikasi web akan diagihkan sama rata ke bekas web1 dan web2.
http { upstream backend { server web1:80; server web2:80; } server { listen 80; location / { proxy_pass http://backend; } } }
Dalam konfigurasi di atas, kami menentukan gugusan pengimbangan beban bernama backend, yang mengandungi dua bekas: web1 dan web2. Nginx akan mengedarkan permintaan secara sama rata kepada dua bekas mengikut konfigurasi.
Kesimpulan:
Melalui pengenalan artikel ini, kita dapat melihat bahawa Docker menyediakan pelbagai fungsi dan alatan untuk mencapai pengembangan mendatar dan pengimbangan beban kontena. Sama ada menggunakan Docker Compose atau Docker Swarm, anda boleh mencapai pengembangan mendatar bekas dengan mudah. Pengimbangan beban kontena juga boleh dicapai dengan menggunakan pengimbang beban terbina dalam Docker atau alat orkestrasi kontena pihak ketiga. Penggunaan fungsi dan alatan ini memudahkan untuk membina dan mengurus aplikasi kontena, meningkatkan prestasi dan ketersediaan aplikasi.
Rujukan:
Atas ialah kandungan terperinci Cara menggunakan Docker untuk pengembangan mendatar dan pengimbangan beban bekas. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!