自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

如何使用Nginx實現(xiàn)MySQL數(shù)據(jù)庫的負載均衡?看完我懂了??!

數(shù)據(jù)庫 MySQL
作者個人研發(fā)的在高并發(fā)場景下,提供的簡單、穩(wěn)定、可擴展的延遲消息隊列框架,具有精準的定時任務(wù)和延遲隊列處理功能。

 作者個人研發(fā)的在高并發(fā)場景下,提供的簡單、穩(wěn)定、可擴展的延遲消息隊列框架,具有精準的定時任務(wù)和延遲隊列處理功能。自開源半年多以來,已成功為十幾家中小型企業(yè)提供了精準定時調(diào)度方案,經(jīng)受住了生產(chǎn)環(huán)境的考驗。為使更多童鞋受益,現(xiàn)給出開源框架地址:https://github.com/sunshinelyz/mykit-delay

[[334224]]

寫在前面

Nginx能夠?qū)崿F(xiàn)HTTP、HTTPS協(xié)議的負載均衡,也能夠?qū)崿F(xiàn)TCP協(xié)議的負載均衡。那么,問題來了,可不可以通過Nginx實現(xiàn)MySQL數(shù)據(jù)庫的負載均衡呢?答案是:可以。接下來,就讓我們一起探討下如何使用Nginx實現(xiàn)MySQL的負載均衡。

前提條件

注意:使用Nginx實現(xiàn)MySQL數(shù)據(jù)庫的負載均衡,前提是要搭建MySQL的主主復(fù)制環(huán)境,關(guān)于MySQL主主復(fù)制環(huán)境的搭建,后續(xù)會在MySQL專題為大家詳細闡述。這里,我們假設(shè)已經(jīng)搭建好MySQL的主主復(fù)制環(huán)境,MySQL服務(wù)器的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)關(guān)于模塊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負載均衡官方配置樣例如下所示。

  1. worker_processes auto; 
  2. error_log /var/log/nginx/error.log info; 
  3.  
  4. events { 
  5.     worker_connections  1024; 
  6.  
  7. stream { 
  8.     upstream backend { 
  9.         hash $remote_addr consistent; 
  10.  
  11.         server backend1.example.com:12345 weight=5; 
  12.         server 127.0.0.1:12345            max_fails=3 fail_timeout=30s; 
  13.         server unix:/tmp/backend3; 
  14.     } 
  15.  
  16.     upstream dns { 
  17.        server 192.168.0.1:53535; 
  18.        server dns.example.com:53; 
  19.     } 
  20.  
  21.     server { 
  22.         listen 12345; 
  23.         proxy_connect_timeout 1s; 
  24.         proxy_timeout 3s; 
  25.         proxy_pass backend; 
  26.     } 
  27.  
  28.     server { 
  29.         listen 127.0.0.1:53 udp; 
  30.         proxy_responses 1; 
  31.         proxy_timeout 20s; 
  32.         proxy_pass dns; 
  33.     } 
  34.  
  35.     server { 
  36.         listen [::1]:12345; 
  37.         proxy_pass unix:/tmp/stream.socket; 
  38.     } 

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

  1. user  nginx; 
  2. #user root; 
  3. worker_processes  1; 
  4. error_log  /var/log/nginx/error.log warn; 
  5. pid        /var/run/nginx.pid; 
  6. events { 
  7.     worker_connections  1024; 
  8. http { 
  9.     include       /etc/nginx/mime.types; 
  10.     default_type  application/octet-stream; 
  11.     log_format  main  '$remote_addr - $remote_user [$time_local] "$request" ' 
  12.                       '$status $body_bytes_sent "$http_referer" ' 
  13.                       '"$http_user_agent" "$http_x_forwarded_for"'
  14.     access_log  /var/log/nginx/access.log  main; 
  15.     sendfile        on
  16.     #tcp_nopush     on
  17.     keepalive_timeout  65; 
  18.     #gzip  on
  19.     include /etc/nginx/conf.d/*.conf; 
  20.  
  21. stream{ 
  22.     upstream mysql{ 
  23.         server 192.168.1.101:3306 weight=1; 
  24.         server 192.168.1.102:3306 weight=1; 
  25.     } 
  26.  
  27.     server{ 
  28.         listen 3306; 
  29.         server_name 192.168.1.100; 
  30.         proxy_pass mysql; 
  31.     } 

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

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

此時,Nginx會將訪問MySQL的請求路由到IP地址為192.168.1.101和192.168.1.102的MySQL上。

本文轉(zhuǎn)載自微信公眾號「冰河技術(shù)」,可以通過以下二維碼關(guān)注。轉(zhuǎn)載本文請聯(lián)系冰河技術(shù)公眾號。 

 

責(zé)任編輯:武曉燕 來源: 冰河技術(shù)
相關(guān)推薦

2012-10-19 10:21:07

數(shù)據(jù)庫負載均衡mssqlserver

2018-06-26 16:31:45

2020-07-16 07:50:53

Nginx模塊動態(tài)

2011-08-05 15:28:47

MySQL數(shù)據(jù)庫集群負載均衡

2010-05-07 13:14:22

數(shù)據(jù)庫負載均衡

2010-05-10 18:05:09

2020-08-10 07:52:30

MySQL數(shù)據(jù)庫

2020-01-14 09:40:00

Nginx負載均衡正向代理

2010-05-07 13:09:06

2013-08-27 13:48:12

Nginx stickNginx負載均衡

2011-01-07 11:14:17

Nginx負載均衡負載均衡

2010-03-24 10:35:02

Nginx負載均衡器

2010-04-22 13:03:20

負載均衡功能

2010-04-21 17:16:15

2010-05-17 14:00:07

MySql數(shù)據(jù)庫

2018-02-01 10:31:12

Nginx負載均衡軟件

2020-04-20 20:27:59

Nginx動靜分離負載均衡

2012-05-29 18:05:00

2010-04-21 16:57:18

數(shù)據(jù)庫負載均衡

2025-02-08 12:05:44

MySQLMyISAMInnoDB
點贊
收藏

51CTO技術(shù)棧公眾號