|
|
51CTO旗下网站
|
|
移动端

如何使用Nginx实现MySQL数据库的负载均衡?看完我懂了!!

作者个人研发的在高并发场景下,提供的简单、稳定、可扩展的延迟消息队列框架,具有精准的定时任务和延迟队列处理功能。

作者:冰河团队 来源:冰河技术|2020-07-20 08:02

作者个人研发的在高并发场景下,提供的简单、稳定、可扩展的延迟消息队列框架,具有精准的定时任务和延迟队列处理功能。自开源半年多以来,已成功为十几家中小型企业提供了精准定时调度方案,经受住了生产环境的考验。为使更多童鞋受益,现给出开源框架地址:https://github.com/sunshinelyz/mykit-delay

写在前面

Nginx能够实现HTTP、HTTPS协议的负载均衡,也能够实现TCP协议的负载均衡。那么,问题来了,可不可以通过Nginx实现MySQL数据库的负载均衡呢?答案是:可以。接下来,就让我们一起探讨下如何使用Nginx实现MySQL的负载均衡。

前提条件

注意:使用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负载均衡官方配置样例如下所示。

  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实现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数据库。

  1. jdbc:mysql://192.168.1.100:3306/数据库名称 

此时,Nginx会将访问MySQL的请求路由到IP地址为192.168.1.101和192.168.1.102的MySQL上。

本文转载自微信公众号「冰河技术」,可以通过以下二维码关注。转载本文请联系冰河技术公众号。

【编辑推荐】

  1. MySQL死锁系列-常见加锁场景分析
  2. 数据库即服务的多种形态
  3. 开源 5 款超好用的数据库 GUI 带你玩转 MongoDB、Redis、SQL 数据库
  4. 百万级MySQL的数据量,该如何快速的完成数据迁移?
  5. 数据库怎么选择?
【责任编辑:武晓燕 TEL:(010)68476606】

点赞 0
分享:
大家都在看
猜你喜欢

订阅专栏+更多

大数据安全运维实战

大数据安全运维实战

CDH+Ambari
共20章 | 大数据陈浩

86人订阅学习

实操案例:Jenkins持续交付和持续部署

实操案例:Jenkins持续交付和持续部署

微服务架构下的自动化部署
共18章 | freshman411

176人订阅学习

思科交换网络安全指南

思科交换网络安全指南

安全才能无忧
共5章 | 思科小牛

108人订阅学习

订阅51CTO邮刊

点击这里查看样刊

订阅51CTO邮刊

51CTO服务号

51CTO官微