


Haproxy di Ubuntu: mengimbangi beban dan failover untuk infrastruktur yang berdaya tahan
Mar 05, 2025 am 09:06 AM
Pengenalan
Dalam persekitaran digital pantas hari ini, memastikan ketersediaan dan prestasi aplikasi adalah kritikal. Infrastruktur moden memerlukan penyelesaian yang kuat untuk memperuntukkan trafik dengan cekap, mengekalkan ketersediaan perkhidmatan walaupun dalam kes kegagalan pelayan.Haproxy sebagai standard sebenar untuk mengimbangi beban dan failover yang berprestasi tinggi, ia muncul.
Artikel ini meneroka sinergi antara Haproxy dan Ubuntu, salah satu pengagihan Linux yang paling popular. Dari pemasangan ke konfigurasi lanjutan, kami akan menyelam bagaimana HAPROXY dapat mengubah infrastruktur anda dengan keupayaan mengimbangi beban dan failover.
Penjelasan terperinci mengenai pengimbangan beban
mengimbangi beban adalah proses memperuntukkan trafik rangkaian masuk ke beberapa pelayan. Dengan mengimbangi beban, ia memastikan bahawa tidak ada pelayan tunggal yang terharu, dengan itu meningkatkan prestasi, kebolehpercayaan, dan toleransi kesalahan.
Kelebihan utama:
- Skalabilitas: Latihan lalu lintas yang semakin meningkat dengan menambahkan lebih banyak pelayan.
- Kebolehpercayaan: Mudah kesan kegagalan pelayan dengan mengarahkan trafik ke pelayan biasa.
- Prestasi: Kurangkan latensi dengan mengedarkan beban kerja sama rata.
Jenis pengimbangan beban:
- Lapisan 4 (Lapisan Pengangkutan): Mengedarkan lalu lintas mengikut maklumat IP dan pelabuhan.
- Lapisan 7 (Lapisan Aplikasi): Buat keputusan penghalaan berdasarkan data peringkat aplikasi (seperti tajuk HTTP).
Konsep failover
Failover memastikan kesinambungan dengan secara automatik mengalihkan trafik ke sumber sandaran sekiranya berlaku kegagalan sumber utama. Ia adalah asas kepada persediaanyang tinggi (HA) .
dengan haproxy, failover adalah lancar:
- Jika pelayan backend tidak tersedia, Haproxy akan mengesannya melalui pemeriksaan kesihatan.
- lalu lintas akan dialihkan ke pelayan lain yang tersedia, dengan itu mengekalkan perkhidmatan yang tidak terganggu.
Tetapkan Haproxy di Ubuntu
Mari mulakan dengan memasang dan mengkonfigurasi Haproxy di Ubuntu.
Prasyarat:
- pelayan Ubuntu (disyorkan untuk menggunakan 20.04 atau lebih tinggi).
- Pelbagai pelayan backend untuk menguji pengimbangan beban.
- Kemahiran baris perintah Linux asas.
Langkah 1: Pasang Haproxy
- Kemas kini sistem anda:
-
sudo apt update && sudo apt upgrade -y
Memasang Haproxy: -
sudo apt install haproxy -y
Sahkan pemasangan: -
haproxy -v
Langkah 2: Konfigurasikan Haproxy
EDIT Fail konfigurasi: /etc/haproxy/haproxy.cfg
<code>global log /dev/log local0 log /dev/log local1 notice maxconn 2048 daemon defaults log global option httplog option dontlognull timeout connect 5000ms timeout client 50000ms timeout server 50000ms frontend http_front bind *:80 default_backend http_back backend http_back balance roundrobin server server1 192.168.1.101:80 check server server2 192.168.1.102:80 check</code>
- mulakan semula haproxy untuk memohon perubahan:
sudo systemctl restart haproxy
- ujian dengan mengakses alamat IP pelayan. Haproxy akan memperuntukkan permintaan antara backends.
Konfigurasi lanjutan
algoritma mengimbangi beban:
- Poll: secara berurutan memperuntukkan permintaan.
- Bilangan sambungan: diarahkan ke pelayan dengan sambungan yang paling aktif.
- Sumber: Pastikan pelanggan sentiasa diarahkan ke pelayan yang sama.
Kemas kini arahan balance
di backend sewajarnya.
Pemeriksaan Kesihatan: Pemeriksaan kesihatan memastikan lalu lintas dihantar ke pelayan biasa sahaja. check
Arahan melakukan pemeriksaan kesihatan biasa.
penamatan SSL: Untuk melindungi lalu lintas, konfigurasikan HAPROXY untuk mengendalikan penamatan SSL.
- Dapatkan sijil SSL.
- Kemas kini Konfigurasi untuk menggunakan https:
frontend https_front bind *:443 ssl crt /etc/haproxy/certs/example.pem default_backend http_back
Trafik penapis menggunakan ACL:
<code>frontend http_front acl is_api path_beg /api use_backend api_back if is_api</code>Dayakan ketersediaan tinggi
vrrp dengan terus:
Untuk membolehkan failover, mengintegrasikan terus dengan haproxy.
Memasang Keepalived:-
sudo apt install keepalived -y
konfigurasi disimpan (): -
/etc/keepalived/keepalived.conf
<code>vrrp_instance VI_1 { state MASTER interface eth0 virtual_router_id 51 priority 100 advert_int 1 authentication { auth_type PASS auth_pass mypassword } virtual_ipaddress { 192.168.1.100 } }</code>
-
sudo systemctl restart keepalived
Keepalived memastikan bahawa pelayan sekunder mengambil alih dengan lancar apabila pelayan utama gagal.
Pemantauan dan penalaan prestasi
Panel Statistik Haproxy: Dayakan panel untuk pemantauan masa nyata:
mengaksesnya dalam .
<code>listen stats bind *:8404 stats enable stats uri /stats stats auth admin:password</code>
Kemahiran Pengoptimuman: http://<server-ip>:8404/stats</server-ip>
Laraskan tetapan dan .
- Gunakan mampatan gzip untuk trafik HTTP.
-
maxconn
memantau pengecualian dalam log.timeout
- Kes pengguna dan senario sebenar
microservices: Menetapkan permintaan API kepada pelbagai perkhidmatan.
- Aplikasi Web: Mengendalikan pancang lalu lintas dengan memperluaskan pelayan backend.
- Pengimbangan beban pangkalan data: Mengoptimumkan operasi membaca dan menulis.
- Penyelesaian masalah Soalan Lazim
Masalah Sambungan:
Periksa peraturan firewall. Sahkan pemeriksaan kesihatan pelayan.
- Bottleneck prestasi:
Tambahkan ULIMIT deskriptor fail. Mengoptimumkan konfigurasi pelayan backend.
- Penyelenggaraan:
- Sentiasa sandaran sandaran.
- Gunakan kemas kini semasa trafik yang rendah.
Kesimpulan
Dengan menggabungkan Haproxy dan Ubuntu, anda mendapat kombinasi yang kuat untuk menguruskan lalu lintas dan memastikan uptime. Dengan langkah -langkah di atas, anda boleh membina infrastruktur yang berdaya tahan yang boleh mengendalikan beban tinggi dan kegagalan pelayan.
mula mencuba HAPROXY SEKARANG dan buka kunci potensi penuh keupayaan sistem Ubuntu.
Atas ialah kandungan terperinci Haproxy di Ubuntu: mengimbangi beban dan failover untuk infrastruktur yang berdaya tahan. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Alat AI Hot

Undress AI Tool
Gambar buka pakaian secara percuma

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Clothoff.io
Penyingkiran pakaian AI

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

Artikel Panas

Alat panas

Notepad++7.3.1
Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina
Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1
Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6
Alat pembangunan web visual

SublimeText3 versi Mac
Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Topik panas

Adakah anda mencari perisian yang baik untuk menulis persamaan matematik? Jika ya, artikel ini menyediakan editor persamaan 5 teratas yang boleh anda pasang dengan mudah pada pengedaran Linux kegemaran anda. Selain itu serasi dengan pelbagai jenis matematik

Pentadbir Linux harus biasa dengan persekitaran baris arahan. Oleh kerana mod GUI (antara muka pengguna grafik) di pelayan Linux tidak biasanya dipasang.ssh mungkin protokol yang paling popular untuk membolehkan pentadbir Linux menguruskan pelayan

LXD digambarkan sebagai bekas generasi akan datang dan pengurus mesin maya yang menawarkan sistem Linux yang mendalam yang berjalan di dalam bekas atau sebagai mesin maya. Ia memberikan imej untuk bilangan pengagihan Linux yang sangat besar dengan sokongan

PPA adalah alat penting bagi pengguna Ubuntu untuk mengembangkan sumber perisian mereka. 1. Apabila mencari PPA, anda harus melawat Launchpad.net, mengesahkan PPA rasmi di laman web atau dokumen rasmi projek, dan membaca deskripsi dan komen pengguna untuk memastikan status keselamatan dan penyelenggaraannya; 2. Tambah PPA untuk menggunakan arahan terminal Sudoadd-apt-repositoryppa:/, dan kemudian jalankan sudoaptupdate untuk mengemas kini senarai pakej; 3. Menguruskan PPA untuk melihat senarai tambahan melalui arahan GREP, gunakan parameter -Remove untuk menghapuskan atau memadam fail .list secara manual untuk mengelakkan masalah yang disebabkan oleh ketidakserasian atau menghentikan kemas kini; 4. Gunakan PPA untuk menimbang keperluan dan mengutamakan situasi yang tidak disediakan oleh pegawai atau memerlukan versi baru perisian.

Gogo adalah alat yang luar biasa untuk menanda direktori di dalam shell Linux anda. Ia membantu anda membuat pintasan untuk laluan panjang dan kompleks di Linux. Dengan cara ini, anda tidak lagi perlu menaip atau menghafal laluan panjang pada linux.for contohnya, jika ada direktori

Bagaimana dengan cepat menjana fail ujian saiz yang ditentukan? Ia boleh dicapai menggunakan alat baris arahan atau perisian grafik. Pada Windows, anda boleh menggunakan saiz nama fail fsutilfileCreatenew untuk menghasilkan fail dengan bait yang ditentukan; MACOS/Linux boleh menggunakan ddif =/dev/sifar = filebs = 1mcount = 100 untuk menjana fail data sebenar, atau gunakan fail truncate-s100m untuk membuat fail jarang. Jika anda tidak biasa dengan baris arahan, anda boleh memilih fsutilgui, dummyfilegenerator dan perisian alat lain. Nota termasuk: Perhatikan batasan sistem fail (seperti had atas saiz fail FAT32), elakkan menimpa fail sedia ada, dan beberapa program mungkin

Kunci untuk memasang sistem dwi di Linux dan Windows adalah pembahagian dan tetapan boot. 1. Penyediaan termasuk sandaran data dan memampatkan partisi sedia ada untuk membuat ruang; 2. Gunakan Ventoy atau Rufus untuk membuat cakera USB Boot Linux, cadangkan Ubuntu; 3. Pilih "wujud bersama dengan sistem lain" atau partition secara manual semasa pemasangan ( /sekurang -kurangnya 20GB, /ruang tinggal ruang, swap pilihan); 4. Semak pemasangan pemandu pihak ketiga untuk mengelakkan masalah perkakasan; 5. Jika anda tidak memasukkan menu boot grub selepas pemasangan, anda boleh menggunakan pembaikan boot untuk membaiki boot atau menyesuaikan urutan permulaan BIOS. Selagi langkah -langkahnya jelas dan operasi dilakukan dengan betul, keseluruhan proses tidak rumit.

Pengurus Versi Node (NVM) adalah skrip bash mudah yang membantu menguruskan pelbagai versi Node.js pada sistem Linux anda. Ia membolehkan anda memasang pelbagai versi node.js, melihat versi yang tersedia untuk pemasangan, dan periksa sudah dipasang versi.nv
