Rumah Operasi dan penyelenggaraan operasi dan penyelenggaraan linux Cara menggunakan Docker untuk pengembangan mendatar dan pengimbangan beban bekas

Cara menggunakan Docker untuk pengembangan mendatar dan pengimbangan beban bekas

Nov 07, 2023 pm 03:26 PM
docker pengimbangan beban Pengembangan mendatar

Cara menggunakan Docker untuk pengembangan mendatar dan pengimbangan beban bekas

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.

  1. Gunakan Docker Compose untuk mencapai pengembangan mendatar kontena
    Docker Compose ialah alat yang dilancarkan secara rasmi oleh Docker Ia boleh menentukan konfigurasi dan hubungan berbilang bekas melalui fail YAML dan merealisasikan pengurusan kelompoknya. Dengan mengubah suai bilangan bekas dalam fail ini, pengembangan mendatar bekas boleh dicapai dengan mudah dan cepat. Berikut ialah contoh fail Docker Compose, yang mengandungi konfigurasi aplikasi web dan pangkalan data:

1

2

3

4

5

6

7

8

9

10

11

12

version: '3'

services:

  web:

    build: .

    ports:

      - "80:80"

    depends_on:

      - db

  db:

    image: mysql:5.7

    environment:

      - MYSQL_ROOT_PASSWORD=root

Salin selepas log masuk

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:

1

2

3

4

5

6

7

8

9

10

11

12

13

version: '3'

services:

  web:

    build: .

    ports:

      - "80:80"

    depends_on:

      - db

    replicas: 3

  db:

    image: mysql:5.7

    environment:

      - MYSQL_ROOT_PASSWORD=root

Salin selepas log masuk

Kemudian gunakan arahan berikut untuk memulakan dan mengurus bekas:

1

$ docker-compose up -d

Salin selepas log masuk

Docker Compose secara automatik akan membantu kami mencipta dan mengurus 3 bekas aplikasi web, dengan itu mencapai mendatar pengembangan bekas.

  1. Gunakan Docker Swarm untuk mencapai pengembangan mendatar kontena
    Docker Swarm ialah orkestrasi kontena dan alat pengurusan kelompok yang disediakan secara rasmi oleh Docker. Ia mencapai pengembangan mendatar kontena dengan menjadualkan dan mengurus bekas Docker pada berbilang nod. Berikut ialah contoh fail konfigurasi Docker Swarm:

1

2

3

4

5

6

7

8

version: '3'

services:

  web:

    image: nginx:latest

    deploy:

      replicas: 3

      restart_policy:

        condition: on-failure

Salin selepas log masuk

Dengan menggunakan arahan yang disediakan oleh Docker Swarm, anda boleh membuat dan mengurus bekas dengan cepat dan mencapai pengembangan mendatar bekas:

1

$ docker stack deploy -c docker-compose.yml myapp

Salin selepas log masuk

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.

  1. Gunakan pengimbang beban terbina dalam Docker
    Docker mempunyai pengimbang beban terbina dalam berdasarkan algoritma round-robin, yang secara automatik boleh mengedarkan permintaan secara sama rata kepada berbilang bekas. Hanya petakan berbilang bekas yang sama ke port yang sama untuk mencapai pengimbangan beban. Berikut ialah contoh fail Docker Compose, yang mengandungi konfigurasi dua aplikasi web:

1

2

3

4

5

6

7

8

9

10

version: '3'

services:

  web1:

    build: .

    ports:

      - "8080:80"

  web2:

    build: .

    ports:

      - "8081:80"

Salin selepas log masuk

Melalui konfigurasi di atas, permintaan aplikasi web akan diagihkan sama rata ke bekas web1 dan web2.

  1. Gunakan alat orkestra kontena pihak ketiga
    Selain pengimbang beban Docker sendiri, anda juga boleh menggunakan beberapa alatan orkestrasi kontena pihak ketiga untuk mencapai pengimbangan beban yang lebih berkuasa dan fleksibel. Sebagai contoh, anda boleh menggunakan Nginx sebagai pelayan proksi terbalik untuk mengedarkan permintaan kepada berbilang bekas. Berikut ialah contoh fail konfigurasi Nginx:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

http {

    upstream backend {

        server web1:80;

        server web2:80;

    }

     

    server {

        listen 80;

         

        location / {

            proxy_pass http://backend;

        }

    }

}

Salin selepas log masuk

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:

  • Dokumentasi rasmi Docker: https://docs.docker.com/
  • Docker Compose dokumentasi rasmi: https://docs.docker.com/compose/
  • Dokumentasi rasmi Docker Swarm: https: / /docs.docker.com/engine/swarm/

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!

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

Video Face Swap

Video Face Swap

Tukar muka dalam mana-mana video dengan mudah menggunakan alat tukar muka AI percuma kami!

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 keluar dari bekas dengan Docker Cara keluar dari bekas dengan Docker Apr 15, 2025 pm 12:15 PM

Empat cara untuk keluar dari Docker Container: Gunakan Ctrl D di terminal kontena masukkan perintah keluar di terminal kontena Gunakan Docker Stop & lt; container_name & gt; Perintah Gunakan Docker Kill & lt; container_name & gt; Perintah di terminal tuan rumah (keluar kuasa)

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 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 semula Docker Cara memulakan semula Docker Apr 15, 2025 pm 12:06 PM

Cara memulakan semula bekas Docker: Dapatkan ID Container (Docker PS); Hentikan bekas (Docker Stop & lt; container_id & gt;); Mulakan bekas (Docker Start & lt; container_id & gt;); Sahkan bahawa permulaan semula berjaya (Docker PS). Kaedah lain: Docker mengarang (Docker-Compose Restart) atau Docker API (lihat Dokumentasi Docker).

Cara Memulakan MySQL oleh Docker Cara Memulakan MySQL oleh Docker Apr 15, 2025 pm 12:09 PM

Proses memulakan MySQL di Docker terdiri daripada langkah -langkah berikut: Tarik imej MySQL untuk membuat dan memulakan bekas, tetapkan kata laluan pengguna root, dan memetakan sambungan pengesahan port Buat pangkalan data dan pengguna memberikan semua kebenaran ke pangkalan data

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 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".

Cara membuat bekas untuk Docker Cara membuat bekas untuk Docker Apr 15, 2025 pm 12:18 PM

Buat bekas di Docker: 1. Tarik Imej: Docker Pull [Nama Cermin] 2. Buat bekas: Docker Run [Options] [Mirror Name] [Command] 3. Mulailah bekas: Docker Start [Nama Container]

See all articles