溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Nginx中怎么實現(xiàn)MySQL數(shù)據(jù)庫負載均衡

發(fā)布時間:2021-07-26 10:45:07 來源:億速云 閱讀:218 作者:Leah 欄目:數(shù)據(jù)庫

Nginx中怎么實現(xiàn)MySQL數(shù)據(jù)庫負載均衡,針對這個問題,這篇文章詳細介紹了相對應的分析和解答,希望可以幫助更多想解決這個問題的小伙伴找到更簡單易行的方法。

前提條件

注意:使用Nginx實現(xiàn)MySQL數(shù)據(jù)庫的負載均衡,前提是要搭建MySQL的主主復制環(huán)境,關于MySQL主主復制環(huán)境的搭建,后續(xù)會在MySQL專題為大家詳細闡述。這里,我們假設已經(jīng)搭建好MySQL的主主復制環(huán)境,MySQL服務器的IP和端口分別如下所示。

  • 192.168.1.101 3306

  • 192.168.1.102 3306

通過Nginx訪問MySQL的IP和端口如下所示。

  • 192.168.1.100 3306

Nginx實現(xiàn)MySQL負載均衡

nginx在版本1.9.0以后支持tcp的負載均衡,具體可以參照官網(wǎng)關于模塊ngx_stream_core_module的敘述,鏈接地址為:

http://nginx.org/en/docs/stream/ngx_stream_core_module.html#tcp_nodelay。

nginx從1.9.0后引入模塊ngx_stream_core_module,模塊是沒有編譯的,需要用到編譯,編譯時需添加--with-stream配置參數(shù),stream負載均衡官方配置樣例如下所示。

worker_processes auto; error_log /var/log/nginx/error.log info;  events {     worker_connections  1024; }  stream {     upstream backend {         hash $remote_addr consistent;          server backend1.example.com:12345 weight=5;         server 127.0.0.1:12345            max_fails=3 fail_timeout=30s;         server unix:/tmp/backend3;     }      upstream dns {        server 192.168.0.1:53535;        server dns.example.com:53;     }      server {         listen 12345;         proxy_connect_timeout 1s;         proxy_timeout 3s;         proxy_pass backend;     }      server {         listen 127.0.0.1:53 udp;         proxy_responses 1;         proxy_timeout 20s;         proxy_pass dns;     }      server {         listen [::1]:12345;         proxy_pass unix:/tmp/stream.socket;     } }

說到這里,使用Nginx實現(xiàn)MySQL的負載均衡就比較簡單了。我們可以參照上面官方的配置示例來配置MySQL的負載均衡。這里,我們可以將Nginx配置成如下所示。

user  nginx; #user root; worker_processes  1; error_log  /var/log/nginx/error.log warn; pid        /var/run/nginx.pid; events {     worker_connections  1024; } http {     include       /etc/nginx/mime.types;     default_type  application/octet-stream;     log_format  main  '$remote_addr - $remote_user [$time_local] "$request" '                       '$status $body_bytes_sent "$http_referer" '                       '"$http_user_agent" "$http_x_forwarded_for"';     access_log  /var/log/nginx/access.log  main;     sendfile        on;     #tcp_nopush     on;     keepalive_timeout  65;     #gzip  on;     include /etc/nginx/conf.d/*.conf; }  stream{     upstream mysql{         server 192.168.1.101:3306 weight=1;         server 192.168.1.102:3306 weight=1;     }      server{         listen 3306;         server_name 192.168.1.100;         proxy_pass mysql;     } }

配置完成后,我們就可以通過如下方式來訪問MySQL數(shù)據(jù)庫。

jdbc:mysql://192.168.1.100:3306/數(shù)據(jù)庫名稱

關于Nginx中怎么實現(xiàn)MySQL數(shù)據(jù)庫負載均衡問題的解答就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,如果你還有很多疑惑沒有解開,可以關注億速云行業(yè)資訊頻道了解更多相關知識。

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權內(nèi)容。

AI