iis服务器助手广告广告
返回顶部
首页 > 资讯 > 数据库 > 干货丨分布式数据库DDM Sidecar模式负载均衡
  • 833
分享到

干货丨分布式数据库DDM Sidecar模式负载均衡

摘要

简介 01 分布式数据库中间件 DDM 分布式数据库中间件(Distributed Database Middleware)是解决数据库容量、性能瓶颈和分布式扩展问题的中间件服务,提供分库分表、读写分离、弹性扩容等能力,应对海量数据的高并


	干货丨分布式数据库DDM Sidecar模式负载均衡
[数据库教程]

技术图片

简介

01

分布式数据库中间件 DDM

分布式数据库中间件(Distributed Database Middleware)是解决数据库容量、性能瓶颈和分布式扩展问题的中间件服务,提供分库分表、读写分离、弹性扩容等能力,应对海量数据的高并发访问场景,有效提升数据库读写性能。

02

Mysql Router

mysql-router是mysql官方的轻量级的中间件,用于取代MySQL Proxy应用程序像访问MySQL一样访问MySQL Router,由MySQL Router将数据转发给后端的DDM节点,实现Sidecar模式负载均衡

Sidecar模式是一种从应用程序本身剥离应用程序功能作为单独进程的方法。此模式允许我们向应用无侵入添加多种功能,从而无需向应用程序添加其他配置代码。建议MySQL Router与应用程序部署在同一台机器做Sidecar模式负载均衡,相对于服务端形式的负载均衡,Sidecar模式实现负载均衡可以缩短调用链路,减少服务端中心节点的压力,去中心化,使用更加可靠更加高效。

部署Mysql-Router服务


# 解压安装程序文件

tar -xzvf mysql-router-8.0.11-linux-glibc2.12-x86-64bit.tar.gz

# 重命名安装文件夹

mv mysql-router-8.0.11-linux-glibc2.12-x86-64bit /usr/local/mysqlrouter

# 创建日志和配置相关文件存放目录

cd /usr/local/mysqlrouter

mkdir logs

mkdir etc

# 利用模板文件创建配置文件

cp /usr/local/mysqlrouter/share/doc/mysqlrouter/sample_mysqlrouter.conf ./etc/mysqlrouter.conf

# 启动 mysql router

/usr/local/mysqlrouter/bin/mysqlrouter -c /usr/local/mysqlrouter/etc/mysqlrouter.conf &

配置文件详解

首先,获取DDM连接串,如下图所示:

技术图片

下面详细介绍mysql-router三种配置方式:

01

作为中心代理节使用

mysql-router绑定IP不限制,即监听所有ip,任意节点都可以访问,作为数据库访问代理,轮询DDM各个节点。其中,destinations为上文获得的DDM连接串。

vi /usr/local/mysqlrouter/etc/mysqlrouter.conf


[DEFAULT]

logging_folder = /usr/local/mysqlrouter/log/

plugin_folder = /usr/local/mysqlrouter/lib/mysqlrouter/

config_folder = /usr/local/mysqlrouter/etc/

runtime_folder = /usr/local/mysqlrouter/run/

[logger]

level = INFO

# 负载均衡配置

[routing:balancing]

# 绑定的IP地址

bind_address=0.0.0.0

# 监听的端口

bind_port = 7002

# 连接超时时间(秒)

connect_timeout = 3

# 最大连接数

max_connections = 100

# 后端服务器地址.默认读进行轮询

destinations = 192.168.4.235:5066,192.168.4.231:5066

# 路由策略

routing_strategy=round-robin

[keepalive]

interval = 60

连接示例:


[root@xxx ]# ./mysql -uddmtest -h128.11.2.2 -P7002 -p

Enter password:

mysql>

128.11.2.2为Mysql Router所在IP。

02

作为本地数据库代理使用

mysql-router绑定本地地址127.0.0.1,作为本地数据库访问代理,仅允许当前节点访问数据库。其要求需要访问数据库的应用与router部署在同一节点,更安全可靠。

vi /usr/local/mysqlrouter/etc/mysqlrouter.conf


[DEFAULT]

logging_folder = /usr/local/mysqlrouter/log/

plugin_folder = /usr/local/mysqlrouter/lib/mysqlrouter/

config_folder = /usr/local/mysqlrouter/etc/

runtime_folder = /usr/local/mysqlrouter/run/

[logger]

level = INFO

# 负载均衡配置

[routing:balancing]

# 绑定的IP地址

bind_address=127.0.0.1

# 监听的端口

bind_port = 7002

# 连接超时时间(秒)

connect_timeout = 3

# 最大连接数

max_connections = 100

# 后端服务器地址.默认读进行轮询

destinations = 192.168.4.235:5066,192.168.4.231:5066

# 路由策略

routing_strategy=round-robin

[keepalive]

interval = 60

连接示例:


[root@xxx ]# ./mysql -uddmtest -h127.0.0.1 -P7002 -p

Enter password:

mysql>

mysql客户端与Mysql Router在同一节点。

03

作为本地数据库代理,使用Unix Sockets连接(推荐)

mysql-router不绑定ip和端口,只使用Unix sockets连接,这样可以不经过tcp协议转发数据,只走操作系统socket通道,更加高效。其同样要求需要访问数据库的应用与router部署在同一节点,但是安全可靠,且高效。

vi etc/mysqlrouter.conf


[DEFAULT]

logging_folder = /usr/local/mysqlrouter/log/

plugin_folder = /usr/local/mysqlrouter/lib/mysqlrouter/

config_folder = /usr/local/mysqlrouter/etc/

runtime_folder = /usr/local/mysqlrouter/run/

[logger]

level = INFO

# 负载均衡配置

[routing:balancing]

# 绑定的IP端口

socket = /tmp/mysqlrouter.sock

# 连接超时时间(秒)

connect_timeout = 3

# 最大连接数

max_connections = 100

# 后端服务器地址.默认读进行轮询

destinations = 192.168.4.235:5066,192.168.4.231:5066

# 路由策略

routing_strategy=round-robin

[keepalive]

interval = 60

其中,destinations为上文获得的DDM连接串

连接示例:


[root@xxx ]# ./mysql -uddmtest -p -S /tmp/mysqlrouter.sock

Enter password:

mysql>

mysql客户端与Mysql Router在同一节点。

干货丨分布式数据库DDM Sidecar模式负载均衡

原文地址:https://blog.51cto.com/15049785/2561534

您可能感兴趣的文档:

--结束END--

本文标题: 干货丨分布式数据库DDM Sidecar模式负载均衡

本文链接: https://www.lsjlt.com/news/8011.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • 负载均衡与分布式的区别
    负载均衡与分布式的区别:1、负载均衡与分布式的集群处理维度不同;2、分布式管控所有节点的执行过程,而负载均衡则不对节点进行管控;3、分布式中节点是相互依存的,而负载均衡中各节点之间是平等独立的;4、分布式某节点宕机会直接影响全部程序运行,而...
    99+
    2024-04-02
  • 分布式系统负载均衡案例分析
    这篇文章主要介绍“分布式系统负载均衡案例分析”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“分布式系统负载均衡案例分析”文章能帮助大家解决问题。什么是负载均衡?记得第一次接触 Nginx 是在实验室,...
    99+
    2023-06-27
  • HBase如何处理数据的分布式存储和负载均衡
    在HBase中,数据的分布式存储和负载均衡是由HBase中的HMaster和RegionServer来实现的。 HBase集群中有一...
    99+
    2024-03-11
    HBase
  • PHP开发缓存的分布式与负载均衡
    随着互联网的不断发展,网站的访问量越来越大,为了保证网站的可用性和性能,缓存、分布式和负载均衡成为了必不可少的技术。在PHP开发中,如何实现缓存的分布式和负载均衡是一大挑战。在本文中,将介绍基于Redis和Memcached的分布式缓存和基...
    99+
    2023-11-07
    缓存 分布式 PHP开发
  • Golang 函数在分布式系统中的负载均衡技术
    go 函数在分布式系统中可以采用多种负载均衡技术:轮询负载均衡加权轮询哈希负载均衡一致性哈希 Golang 函数在分布式系统中的负载均衡技术 在分布式系统中,将流量均匀分布在多个实例上...
    99+
    2024-04-20
    分布式系统 负载均衡 git golang
  • web分布式系统的负载均衡怎么实现
    本篇内容介绍了“web分布式系统的负载均衡怎么实现”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!一、「负载均衡」是什么  &nbs...
    99+
    2023-06-02
  • MongoDB的分布式架构与负载均衡怎么配置
    MongoDB是一个支持分布式架构的数据库系统,它可以通过配置副本集和分片集群来实现数据的分布存储和负载均衡。 在MongoDB中,...
    99+
    2024-05-07
    MongoDB
  • HBase如何处理数据的分布和负载均衡
    HBase处理数据的分布和负载均衡主要通过以下方式: 分布式存储:HBase采用分布式存储的方式来存储数据,数据被分散存储在多个...
    99+
    2024-04-09
    HBase
  • Java关键字是如何实现分布式负载均衡的?
    随着互联网的发展,分布式系统已成为现代软件开发的重要组成部分。在分布式系统中,负载均衡是一个至关重要的问题。Java关键字是如何实现分布式负载均衡的呢?本文将介绍Java关键字在分布式负载均衡中的应用以及演示代码。 一、Java关键字在分...
    99+
    2023-09-03
    关键字 分布式 load
  • 分布式系统中Java语言如何实现负载均衡?
    随着互联网技术的发展,分布式系统越来越普及。在分布式系统中,负载均衡是一个非常关键的问题。负载均衡能够提高系统的可靠性和性能,保证系统的稳定运行。那么在Java语言中,如何实现负载均衡呢? 一、什么是负载均衡? 负载均衡是将工作负载分配给...
    99+
    2023-10-09
    分布式 关键字 numy
  • Java分布式系统中接口的负载均衡,你了解吗?
    随着互联网的发展,分布式系统已经成为了企业级系统的标配。分布式系统中,接口的负载均衡是一个非常关键的问题。在本文中,我们将深入探讨Java分布式系统中接口的负载均衡问题,并提供一些实用的演示代码。 什么是负载均衡? 负载均衡是指在分布式系...
    99+
    2023-08-29
    分布式 接口 实时
  • 分布式系统关注点——「负载均衡」到底该如何实施?
    本文长度为3032字,预计读完需1.1MB流量,建议阅读8分钟。         前面两篇《分布式系统关注点——初识「高可用」》、《分布式系统关注点——仅需这一篇,吃透「负载均衡」妥妥的》看...
    99+
    2023-06-05
  • 如何在PHP开发中处理分布式系统和负载均衡?
    如何在PHP开发中处理分布式系统和负载均衡?随着互联网技术的快速发展,分布式系统和负载均衡已经成为了处理高并发和大流量的重要手段。在PHP开发中,如何合理地处理分布式系统和负载均衡,提高系统的稳定性和性能成为了一个值得研究的问题。本文将针对...
    99+
    2023-11-04
    PHP 分布式系统 负载均衡
  • 如何在 Python 中实现分布式路径搜索的负载均衡?
    在计算机科学领域,路径搜索是一个常见的问题。在实际应用中,路径搜索往往需要处理大量的数据和计算,这会导致单台计算机的性能不足以满足需求。因此,分布式计算成为了一种解决方案。本文将介绍如何在 Python 中实现分布式路径搜索的负载均衡。 ...
    99+
    2023-10-24
    分布式 面试 path
  • Go语言的分布式文件负载均衡方案,你知道吗?
    分布式系统中的负载均衡是一个非常重要的问题。在分布式文件系统中,负载均衡尤其重要。如果在分布式文件系统中没有好的负载均衡方案,就会导致一些节点的负载过重,而其他节点却处于闲置状态。这不仅浪费了资源,而且可能会导致系统的崩溃。在Go语言中,...
    99+
    2023-08-18
    分布式 load 文件
  • 分布式系统中,Java关键字如何协助实现负载均衡?
    分布式系统中,负载均衡是一个非常重要的概念,它指的是将多个请求平均分配到不同的服务器上,以实现更高效的资源利用和更好的用户体验。而在实现负载均衡时,Java关键字也发挥了重要的作用。本文将详细讨论Java关键字在分布式系统中如何协助实现负载...
    99+
    2023-09-03
    关键字 分布式 load
  • 快速入门:使用Go语言实现分布式文件负载均衡
    随着互联网的发展,我们越来越依赖于网络传输文件。然而,当文件数量和文件大小增加时,传输速度就会变慢。为了解决这个问题,我们可以使用分布式文件负载均衡技术。 在本篇文章中,我们将介绍如何使用Go语言实现分布式文件负载均衡。我们将使用Go语言...
    99+
    2023-08-18
    分布式 load 文件
  • kubernetes V1.6.4 分布式集群的部署及如何进行service负载均衡
    kubernetes V1.6.4 分布式集群的部署及如何进行service负载均衡,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。1,kubernetes的基本...
    99+
    2023-06-19
  • 分布式系统中的负载均衡,Go语言有哪些实现方案?
    随着分布式系统的普及,负载均衡技术也变得越来越重要。负载均衡的目的是将请求分配到多个服务器上,以提高系统的可用性、可靠性和性能。而Go语言的高并发和轻量级特性,使得它成为了分布式系统中负载均衡的首选语言之一。本文将介绍Go语言中的负载均衡...
    99+
    2023-09-04
    分布式 http leetcode
  • 如何使用Go语言实现高效的分布式文件负载均衡?
    在分布式系统中,负载均衡是一个非常重要的问题。在处理大量数据和请求时,负载均衡可以帮助我们提高系统的性能和可靠性。Go语言是一种高效的编程语言,它可以帮助我们实现高效的分布式文件负载均衡。在本文中,我们将介绍如何使用Go语言实现高效的分布式...
    99+
    2023-08-18
    分布式 load 文件
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作