Nginx可以實現HTTP、HTTPS協議的負載均衡,也可以實現TCP協議的負載均衡。那麼,問題來了,可不能夠經過Nginx實現MySQL數據庫的負載均衡呢?答案是:能夠。接下來,就讓咱們一塊兒探討下如何使用Nginx實現MySQL的負載均衡。html
注意:使用Nginx實現MySQL數據庫的負載均衡,前提是要搭建MySQL的主主複製環境,關於MySQL主主複製環境的搭建,後續會在MySQL專題爲你們詳細闡述。這裏,咱們假設已經搭建好MySQL的主主複製環境,MySQL服務器的IP和端口分別以下所示。node
經過Nginx訪問MySQL的IP和端口以下所示。mysql
nginx在版本1.9.0之後支持tcp的負載均衡,具體能夠參照官網關於模塊ngx_stream_core_module的敘述,連接地址爲:nginx.org/en/docs/str…nginx
nginx從1.9.0後引入模塊ngx_stream_core_module,模塊是沒有編譯的,須要用到編譯,編譯時需添加--with-stream配置參數,stream負載均衡官方配置樣例以下所示。sql
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數據庫。bash
jdbc:mysql://192.168.1.100:3306/數據庫名稱
複製代碼
此時,Nginx會將訪問MySQL的請求路由到IP地址爲192.168.1.101和192.168.1.102的MySQL上。服務器
好了,今天就聊到這兒吧!別忘了點個贊,給個在看和轉發,讓更多的人看到,一塊兒學習,一塊兒進步!!微信
若是你以爲冰河寫的還不錯,請微信搜索並關注「 冰河技術 」微信公衆號,跟冰河學習高併發、分佈式、微服務、大數據、互聯網和雲原生技術,「 冰河技術 」微信公衆號更新了大量技術專題,每一篇技術文章乾貨滿滿!很多讀者已經經過閱讀「 冰河技術 」微信公衆號文章,成功跳槽到大廠;也有很多讀者實現了技術上的飛躍,成爲公司的技術骨幹!若是你也想像他們同樣提高本身的能力,實現技術能力的飛躍,進大廠,升職加薪,那就關注「 冰河技術 」微信公衆號吧,天天更新超硬核技術乾貨,讓你對如何提高技術能力再也不迷茫!併發