redis中,msyql数据库读写分离搭建

news2024/12/28 1:20:49
一.mysql读写分离:缓解主服务器的压力

	1.概念:主服务器写数据,从服务器读数据
	2.实现方法:
		客户端分离: 开发手动分离地址
		服务端分离: 数据库与应用之间加一个中间件,分离读写请求
			    mysql-proxy,mysql-route,maxscale
			    amoeba,cobar,mycat2
			    atlas,kingshard,vitees
	3.mycat配置方法:
		冷配置:直接改配置文件
		热配置:命令配置
	    
	4.操作步骤
		
		主从-->users-->datasources-->cluster-->主备配置读写分离-->shecma配置逻辑库
		1.搭建主从服务器56,57
			
		2.安装授权mycat,安装mysql(原型库,存储mycat运行的数据)
		 mycat2-1.21-release-jar-with-dependencies.jar :运行依赖包
		 mycat2-install-template-1.21.zip:软件包

		 yum -y install java-1.8.0-openjdk.x86_64
		 cp mycat2-1.21-release-jar-with-dependencies.jar  /usr/local/mycat/lib/
		
		 chmod +x /usr/local/mycat/bin/*
		 chmod -R 777 /usr/local/mycat
		3.定义客户端连接mycat服务使用的用户及密码
			/usr/local/mycat/conf/users/root.user.json
			{
		        "dialect":"mysql",
		        "ip":null,
		        "password":"654321", 密码
		        "transactionType":"proxy",
		        "username":"mycat" 用户名
			}

		4.配置本机用户和datasources数据源地址,mycat机器的mysql创建plj用户并授权
			/usr/local/mycat/conf/datasources/prototypeDs.data
			{
		       ....
		        "password":"123456", 密码
		        "type":"JDBC",
		       	....
		        "user":"plj", 用户名
		        "weight":0
			}
			----
			mysql> create user plj@"%" identified by "123456";  //创建plj用户
			mysql> grant all on *.* to plj@"%" ;   //授予权限
		
		5.启动mycat服务并登录(8066)
			/usr/lcoal/mycat/bin/mycat start

			mysql -h127.0.0.1 -P8066 -umycat -p654321

		6.mycat下,配置主从的用户数据源地址,mysql56,主机器上创建主从数据源的用户并授权

			/*+ mycat: createdatasource{
			"name":"whost56", #master角色主机名
			"url":"jdbc:mysql://192.168.88.56:3306",
			"user":"plja",
			"password":"123456"
			} */;
		
			/*+ mycat: createdatasource{
			"name":"rhost57", #slave角色主机名
			"url":"jdbc:mysql://192.168.88.57:3306",
			"user":"plja",
			"password":"123456"
			} */;
			----
			mysql> create user plja@"%" identified by "123456";  //创建plj用户
			mysql> grant all on *.* to plja@"%" ;   //授予权限

		热配置,用户/数据源/集群/逻辑库相关命令

		/*+ mycat: showusers{} / showdatasources{} / showschemas{} */;

		/*+ mycat: createuser{"name":"xx","password":"xx"...} / createdatasource{"name":"xx"}  / createschema{"name":"xx"}*/;

	 	/*+ mycat: dropuser{"name":"xx"} /dropdatasource{"name":"xx"} /dropschema{"name":"xx"}*/;
		
		---集群
		/*+ mycat: showclusters{} */;
		/*! mycat: createcluster{"name":"xx"...} */;
		/*! mycat: dropcluster{"name":"xx"...} */;

	
		7.mycat下,主从服务器加入集群
			mysql -h127.0.0.1 -P8066 -umycat -p654321

			/*! mycat:createcluster{
			"name":"rwcluster",
			"masters":["whost56"], #master角色主机名
			"replicas":["rhost57"] #slave角色主机名
			}*/ ;
			

		8.调整配置文件修改主从的读写操作(之前配置的name=这里的配置文件名称)
			vim /usr/local/mycat/conf/datasources/whost56.datasource.json
				"instanceType":"WRITE"  #分配写
			vim /usr/local/mycat/conf/datasources/rhost57.datasource.json 
				"instanceType":"READ"   #分配读
			vim /usr/local/mycat/conf/clusters/rwcluster.cluster.json 
				"instanceType":"BALANCE_ALL_READ" 

			BALANCE_ALL:获取集群中所有数据源
			BALANCE_ALL_READ:读请求都会被均衡地分配到所有的从库
			BALANCE_READ_WRITE:获取集群中允许读写的数据,单允许读的数据优先
			BALANCE_NONE:获取集群中允许写的数据
	
			重启服务 /usr/local/mycat/bin/mycat restart

		9.登录mycat,创建testdb库,生成testdb.schema.json文件,修改配置文件,逻辑库关联集群真实库
			mysql -h127.0.0.1 -P8066 -umycat -p654321
			create database testdb;

			vim /usr/local/mycat/conf/schemas/testdb.schema.json
			       "schemaName":"testdb",
        			"targetName":"rwcluster", #集群名称

		10.登录mycat,创建表,写记录测试,完成数据的读写分离
			mysql -h127.0.0.1 -P8066 -umycat -p654321
			create table testdb.user(name char(10),password char(10));
			insert into  testdb.user values("yaya","123456");

2.mysql读写分离:缓解主服务器的压力

    1.概念:主服务器写数据,从服务器读数据
    2.实现方法:
        客户端分离: 开发手动分离地址
        服务端分离: 数据库与应用之间加一个中间件,分离读写请求
                mysql-proxy,mysql-route,maxscale
                amoeba,cobar,mycat2
                atlas,kingshard,vitees
    3.mycat配置方法:
        冷配置:直接改配置文件
        热配置:命令配置
        
    4.操作步骤
        
        主从-->users-->datasources-->cluster-->主备配置读写分离-->shecma配置逻辑库
        1.搭建主从服务器56,57
            
        2.安装授权mycat,安装mysql(原型库,存储mycat运行的数据)
         mycat2-1.21-release-jar-with-dependencies.jar :运行依赖包
         mycat2-install-template-1.21.zip:软件包

         yum -y install java-1.8.0-openjdk.x86_64
         cp mycat2-1.21-release-jar-with-dependencies.jar  /usr/local/mycat/lib/
        
         chmod +x /usr/local/mycat/bin/*
         chmod -R 777 /usr/local/mycat
        3.定义客户端连接mycat服务使用的用户及密码
            /usr/local/mycat/conf/users/root.user.json
            {
                "dialect":"mysql",
                "ip":null,
                "password":"654321", 密码
                "transactionType":"proxy",
                "username":"mycat" 用户名
            }

        4.配置本机用户和datasources数据源地址,mycat机器的mysql创建plj用户并授权
            /usr/local/mycat/conf/datasources/prototypeDs.data
            {
               ....
                "password":"123456", 密码
                "type":"JDBC",
                   ....
                "user":"plj", 用户名
                "weight":0
            }
            ----
            mysql> create user plj@"%" identified by "123456";  //创建plj用户
            mysql> grant all on *.* to plj@"%" ;   //授予权限
        
        5.启动mycat服务并登录(8066)
            /usr/lcoal/mycat/bin/mycat start

            mysql -h127.0.0.1 -P8066 -umycat -p654321

        6.mycat下,配置主从的用户数据源地址,mysql56,主机器上创建主从数据源的用户并授权

            /*+ mycat: createdatasource{
            "name":"whost56", #master角色主机名
            "url":"jdbc:mysql://192.168.88.56:3306",
            "user":"plja",
            "password":"123456"
            } */;
        
            /*+ mycat: createdatasource{
            "name":"rhost57", #slave角色主机名
            "url":"jdbc:mysql://192.168.88.57:3306",
            "user":"plja",
            "password":"123456"
            } */;
            ----
            mysql> create user plja@"%" identified by "123456";  //创建plj用户
            mysql> grant all on *.* to plja@"%" ;   //授予权限

        热配置,用户/数据源/集群/逻辑库相关命令

        /*+ mycat: showusers{} / showdatasources{} / showschemas{} */;

        /*+ mycat: createuser{"name":"xx","password":"xx"...} / createdatasource{"name":"xx"}  / createschema{"name":"xx"}*/;

         /*+ mycat: dropuser{"name":"xx"} /dropdatasource{"name":"xx"} /dropschema{"name":"xx"}*/;
        
        ---集群
        /*+ mycat: showclusters{} */;
        /*! mycat: createcluster{"name":"xx"...} */;
        /*! mycat: dropcluster{"name":"xx"...} */;

    
        7.mycat下,主从服务器加入集群
            mysql -h127.0.0.1 -P8066 -umycat -p654321

            /*! mycat:createcluster{
            "name":"rwcluster",
            "masters":["whost56"], #master角色主机名
            "replicas":["rhost57"] #slave角色主机名
            }*/ ;
            

        8.调整配置文件修改主从的读写操作(之前配置的name=这里的配置文件名称)
            vim /usr/local/mycat/conf/datasources/whost56.datasource.json
                "instanceType":"WRITE"  #分配写
            vim /usr/local/mycat/conf/datasources/rhost57.datasource.json 
                "instanceType":"READ"   #分配读
            vim /usr/local/mycat/conf/clusters/rwcluster.cluster.json 
                "instanceType":"BALANCE_ALL_READ" 

            BALANCE_ALL:获取集群中所有数据源
            BALANCE_ALL_READ:读请求都会被均衡地分配到所有的从库
            BALANCE_READ_WRITE:获取集群中允许读写的数据,单允许读的数据优先
            BALANCE_NONE:获取集群中允许写的数据
    
            重启服务 /usr/local/mycat/bin/mycat restart

        9.登录mycat,创建testdb库,生成testdb.schema.json文件,修改配置文件,逻辑库关联集群真实库
            mysql -h127.0.0.1 -P8066 -umycat -p654321
            create database testdb;

            vim /usr/local/mycat/conf/schemas/testdb.schema.json
                   "schemaName":"testdb",
                    "targetName":"rwcluster", #集群名称

        10.登录mycat,创建表,写记录测试,完成数据的读写分离
            mysql -h127.0.0.1 -P8066 -umycat -p654321
            create table testdb.user(name char(10),password char(10));
            insert into  testdb.user values("yaya","123456");
 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2266678.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Docker-构建自己的Web-Linux系统-镜像webtop:ubuntu-kde

介绍 安装自己的linux-server,可以作为学习使用,web方式访问,基于ubuntu构建开源项目 https://github.com/linuxserver/docker-webtop安装 docker run -d -p 1336:3000 -e PASSWORD123456 --name webtop lscr.io/linuxserver/webtop:ubuntu-kde登录 …

spring专题笔记(六):bean的自动装配(自动化注入)-根据名字进行自动装配、根据类型进行自动装配。代码演示,通俗易懂。

目录 一、根据名字进行自动装配--byName 二、根据类型进行自动装配 byType 本文章主要是介绍spring的自动装配机制, 用代码演示spring如何根据名字进行自动装配、如何根据类型进行自动装配。代码演示,通俗易懂。 一、根据名字进行自动装配--byName Us…

深入探讨 Go 中的高级表单验证与翻译:Gin 与 Validator 的实践之道20241223

深入探讨 Go 中的高级表单验证与翻译:Gin 与 Validator 的实践之道 在现代后端开发中,表单验证是保证数据完整性和服务稳定性的核心环节。如何优雅、高效地实现表单验证,同时提供人性化的错误提示,是每位开发者的必修课。在本文中…

UE5 渲染管线 学习笔记

兰伯特 SSS为散射的意思 带Bias的可以根据距离自动切换mip的卷积值 而带Level的值mipmaps的定值 #define A8_SAMPLE_MASK .a 这样应该就很好理解了 这个只采样a通道 带Level的参考上面的 朝左上和右下进行模糊 带Bias参考上面 随机数 4D 3D 2D 1D HLSL内置UV HLSL内置鼠标坐…

【Kubernetes 指南】基础入门——Kubernetes 基本概念(二)

目录 二、Pod 1、Pod 简介 2、Pod 图示 3、nginx 容器 二、Pod 1、Pod 简介 - Kubernetes 使用 Pod 来管理容器,每个 Pod 可以包含一个或多个紧密关联的容器。 - Pod 是一组紧密关联的容器集合,它们共享 PID、IPC、Network 和 UTS namespace&#…

基于高德地图js api实现掩膜效果 中间矢量 周围卫星图

<!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"><meta name"viewport" content"widthdevice-width, initial-scale1.0"><title>管网服务</title><style>html,body,#ma…

【EI会议征稿】人工智能与遥感应用国际会议 (AIRSA 2025)

第一届人工智能与遥感应用国际学术会议&#xff08;AIRSA 2025&#xff09;将于2025年3月14-17日在中国长沙召开。会议聚焦人工智能与遥感技术应用&#xff0c;旨在为参会专家、学者和相关研究人员提供一个共享科研成果&#xff0c;拓宽研究思路&#xff0c;探索前沿技术&#…

Java圣诞树

目录 写在前面 技术需求 程序设计 代码分析 一、代码结构与主要功能概述 二、代码功能分解与分析 1. 类与常量定义 2. 绘制树的主逻辑 3. 彩色球的绘制 4. 动态效果的实现 5. 窗口初始化 三、关键特性与优点 四、总结 写在后面 写在前面 Java语言绘制精美圣诞树…

java web项目软件自动生成使用初体验-帅帅软件生成平台ASoft

软件默认 登陆账号 admin 密码 123456 一、软件使用简介说 AI软件自动生成越来越成熟&#xff0c;但AI生成的软件代码只是片段化的&#xff0c;不成体系。有没有一款可以10-30分钟自动生成JAVA WEB休系的软件&#xff1f;我也找了好久&#xff0c;终于找到了&#xff0c;开发…

闲谭Scala(2)--安装与环境配置

1. 概述 Java开发环境安装&#xff0c;需要两步&#xff0c;第一安装JDK&#xff0c;第二配置环境变量。 Scala的话&#xff0c;也是两步&#xff0c;第一安装Scale环境&#xff0c;第二配置环境变量。 需要注意的是&#xff0c;配置环境变量&#xff0c;主要是想让windows操…

NodeRed使用心得,实现增删改查等

使用场景介绍 在VUE中使用nodeRed实现对节点的 增删改查等功能&#xff0c;且储存成功之后下点击时启动对应流程 安装与配置 1.安装NodeRed npm install -g --unsafe-perm node-red 安装完成后&#xff0c;你可以通过运行以下命令来启动Node-RED node-red-start2. 配置文件 N…

升级鸿蒙Next,小记

写在前面 这个小记是想记录一下Next系统不断完善的过程&#xff0c;给想升级还没升级的同志们一些提醒。虽然这个系统还有这样那样的一些问题&#xff0c;但是我觉得升级之后很完美 续航时间明显变长了&#xff0c;充电&#xff0c;玩游戏以前会发热&#xff0c;现在完全不会…

Android Studio | 连接手机设备后,启动App时出现:Waiting For DebuggerApplication (App名)...

在这种情况下&#xff0c;打开目录文件&#xff0c;出现 Is:/storage/emulated/: Permission denied 问题分析&#xff1a; 以上两种情况表明应用程序试图访问Android设备的存储空间中的/storage/emulated/目录&#xff0c;但是没有足够的权限去执行这个操作。 解决办法&…

如何卸载和升级 Angular-CLI ?

Angular-CLI 是开发人员使用 Angular 的必备工具。然而&#xff0c;随着频繁的更新和新版本的出现&#xff0c;了解如何有效地卸载和升级 Angular-CLI 对开发人员来说至关重要。本指南提供了一个全面的、循序渐进的方法来帮助您顺利过渡到最新版本。 必备条件 确保您的系统上…

jangow靶机

打开靶机&#xff0c;打开kali&#xff0c;有的人会发现扫不到靶机的ip 在网上搜索了半天&#xff0c;发现是靶机的网卡配置有问题 重启靶机&#xff0c;选第二个 进去后再选第二个&#xff0c;按e 找到ro这一行 把ro后面这一行的内容都替换成ro rw signin init/bin/bash ctr…

[c++进阶(三)]单例模式及特殊类的设计

1.前言 在实际场景中,总会遇见一些特殊情况,比如设计一个类,只能在堆上开辟空间, 或者是设计一个类只能实例化一个对象。那么我们应该如何编写代码呢&#xff1f;本篇将会详细的介绍 本章重点&#xff1a; 本篇文章着重讲解如何设计一些特殊 的类,包括不能被拷贝,只能在栈/堆上…

CSharp: Oracle Stored Procedure query table

存储过程查询postgreSQL,Oracle 和sql server,Mysql 有区别。程序调用也是有区别。 oracle sql script: CREATE OR REPLACE PROCEDURE procSelectSchool(paramSchoolId IN char,p_cursor OUT SYS_REFCURSOR ) AS BEGINOPEN p_cursor FORSELECT *FROM SchoolWHERE SchoolId p…

macos 隐藏、加密磁盘、文件

磁盘加密 打开磁盘工具 点击添加 设置加密参数 设置密码 查看文件 不用的时候右键卸载即可使用的时候装载磁盘&#xff0c;并输入密码即可 修改密码 解密 加密&#xff0c;输入密码即可 禁止开机自动挂载此加密磁盘 如果不禁止自动挂载磁盘&#xff0c;开机后会弹出输入…

cesium入门学习一

1.学习目的 作为网页显示&#xff0c;我只要实现了cesium网页显示&#xff0c;就可以到时候通过qt的webview显示html界面&#xff0c;来显示地图&#xff0c;js对于学过c的人而言&#xff0c;没啥难度&#xff0c;不过是换一种语法&#xff0c;而且cesium的教程相对于osgeart…

dify的ChatFlow自定义上传图片并通过HTTP请求到SpringBoot后端

前情提要 交互场景&#xff1a;dify的ChatFlow上传文件(本示例是单张图片)&#xff0c;通过HTTP请求至SpringBoot后端dify版本&#xff1a;0.13.2python版本&#xff1a;3.12.7 1. 自定义上传变量 在【开始】节点自定义变量单文件上传变量file 2. 下接HTTP请求节点 BODY要…