前提條件
注意:使用Nginx實現MySQL數據庫的負載均衡,前提是要搭建MySQL的主主復制環境,關於MySQL主主復制環境的搭建,后續會在MySQL專題為大家詳細闡述。這里,我們假設已經搭建好MySQL的主主復制環境,MySQL服務器的IP和端口分別如下所示。
- 192.168.1.101 3306
- 192.168.1.102 3306
通過Nginx訪問MySQL的IP和端口如下所示。
- 192.168.1.100 3306
Nginx實現MySQL負載均衡
nginx在版本1.9.0以后支持tcp的負載均衡,具體可以參照官網關於模塊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配置參數,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實現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數據庫。
jdbc:mysql://192.168.1.100:3306/數據庫名稱
此時,Nginx會將訪問MySQL的請求路由到IP地址為192.168.1.101和192.168.1.102的MySQL上。
參考鏈接:https://www.cnblogs.com/binghe001/p/13340680.html