首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

MySQL 不停机不锁主从搭建

MySQL主从搭建分几种场景 无业务数据,初始化搭建 有业务数据,临时扩展 初始化的搭建很简单,不涉及数据业务,所以锁、停机等都不影响,但是更多时候是业务到一定阶段,才会涉及到横向扩展,需要做主从,...读写分离等来提升服务性能 这个时候,数据业务不能中断,又需要快速进行扩展提升性能,只能在不停机、不停服务的情况下扩展,就需要用到下面介绍的这种方法来做数据库主从 当然还是有前提条件,如果你原本MySQL...连binlog及server_id都这种基础配置都没做,那也谈不上不停机配置主从 原理 不停机实现主从搭建的关键点就是以下两个参数: --single-transaction --master-data...TRANSACTION 语句,开启单一事务,此时加锁,仅仅是为了获取准确的master-data中的binlogfile和pos信息,在开启事务后,锁已经释放了,所以对业务影响很小 通过以上两个参数,可以在不长时间锁的情况下获取准确的...to master_host='ip',master_user='slave',master_port=port,master_password='password',master_log_file='mysql-bin.file

2.7K10
您找到你想要的搜索结果了吗?
是的
没有找到

MySql之自动同步结构

MySql之自动同步结构 开发痛点 在开发过程中,由于频繁的修改数据库的字段,导致rd和qa环境的数据库经常不一致。 而由于这些修改数据库的操作可能由多个rd操作,很难一次性收集全。...解决之道 于是笔者就写了一个能够自动比较两个数据库的结构,并生成alter语句的程序。同时还可以进行配置从而自动这行这些alter语句。...详情见github 原理 同步新增的 如果rd环境新增的,而qa环境没有,此程序可以直接输出create table语句。原理如下: ?...用到的sql主要有: show table from rd_db; show create table added_table_name; 同步结构 如果rd结构有改动,而qa环境没有,此程序可以直接输出...EXTRA from information_schema.columns where TABLE_SCHEMA='rd_db' and TABLE_NAME = 'rd_table'; 比较结构的代码

4.8K30

mysql查看表的数据结构_mysql查找结构

MySQL 查看表结构 mysql查看表结构命令,如下: desc 名; show columns from 名; describe 名; show create table 名; use information_s...… mysql查看表结构命令 mysql查看表结构命令 mysql查看表结构命令,如下: desc 名;show columns from 名;describe 名;show create table...名; use inf … mysql查看表结构,字段等命令 mysql查看表结构命令,如下: desc 名; show columns from 名; describe 名; show create...’\G; mysql> show table status like ‘x’\G; . row … mysql 查看表结构方法 留给自己备查: mysql 导出为 csv 文件时如果直接使用导出命令是无法导出结构的..., 因此我们需要能够查询结构的方法: 方法如下: 1.desc(描述)命令 desc tablename;de … MySQL查看表结构及查看建表语句 查看表结构:desc mysql> use

5.7K20

亿级大如何修改结构MySQL

二、深入讨论 那我们大该如何修改结构呢?网络搜索了一圈,基本都围绕了两种方法进行:第一种是在用户访问量少的时间段,进行结构修改。第二种是采用copy替换原的方法。...三、原直接修改 对于用户访问量少的时间段进行结构修改或者类似12306这种,凌晨11点-6点进行数据维护,直接停服修改结构。...ALTER TABLE 但是如果业务迭代比较快,或者改动结构比较频繁的,系统又不允许停服(大多数系统都不允许停服),这个时候修改结构就很痛苦了,一方面是开发人员需要经常性加班,而是如果改动是核心,...4.3 切换数据丢失问题 切换名这一步,数据库层面做不了限制,首先MYSQL不支持在锁住的情况下,再去修改名。...五、总结 直接修改结构既然有这么多问题,那为什么大多数企业都选择直接修改结构呢,而不是copy替换原的形式呢。

4.7K10

快速修改MySQL某张结构

快速修改MySQL某张结构--摘录自《MySQL管理之道》 ALTER TABLE 名 MODIFY 列名 数据类型; 这个命令可以修改结构 此外,也可以如下方法修改结构: 先创建一张,如下...decimal(9,1)); 如果要修改name列为varchar(10)的,可以这样操作:alter table t1 modify name varchar(7); 也可以如下操作: 1、查看表结构...把varchar设置为10: > create table t1_tmp (id int,     name varchar(10),     rmb decimal(9,1)); 3、替换.frm结构文件...> flush tables with read lock;   先锁住,放在被打开,以免数据丢失。  ...local/mariadb/var/test/t1_tmp.frm  /usr/local/mariadb/var/test/t1.frm 4、解除锁定 > unlock tables; 5、查看表结构

4.1K20

Mysql主从

前提: mysql主从的搭建前提有: 两台虚拟机 两台虚拟机上都装有mysql,并且版本一样,两边的mysql数据库文件一致,mysql的安装方式我在前面博客已经介绍过了。...环境: Host Role IP mysql-1 Master 192.168.30.106 mysql-2 Slave 192.168.30.107 搭建 在主从服务器上都创建一个用户 $ mysql..., mysql如何减少主从复制延迟: 如果延迟比较大,就先确认以下几个因素: 从库硬件比主库差,导致复制延迟 主从复制单线程,如果主库写并发太大,来不及传送到从库 就会导致延迟。...,如果连接建立失败,间隔多久后重试 通常配置以上2个参数可以减少网络问题导致的主从数据同步延迟 MySQL数据库主从同步延迟解决方案 最简单的减少slave同步延时的方案就是在架构上做优化,尽量让主库的...另外就是使用比主库更好的硬件设备作为slave 扩展 主从还能配合MySQL中proxy实现真正意义的读写分离,还能配合keepalived做主从切换高可用,还能配合mysqljump做异地备份,在从库定时物理备份

2.7K10

MySQL中的结构修改方法

阅读目录 目的 结构修改的基础语法 进阶操作 注意事项 目的 在日常的测试工作中,无论测试项目准备阶段还是测试执行阶段,团队成员经常会需要使用SQL语句进行测试数据的制作和准备,比较常用的就是增删查改等一些基础操作...,但偶尔也会涉及到修改结构的极端情况。...结构修改的基础语法 如有一张"tb_user_info"结构为: +--------+----------+------+-----+---------+-------+ | Field | Type...30) | YES | | NULL | | +--------+----------+------+-----+---------+-------+ 下面就先做一些基础的结构修改操作...drop default; 【字段无默认值的情况下,直接定义默认值即可】 alter table tb_user_info alter login_name set default 'BBB'; 修改

4.3K10

MySQL数据库:结构优化

由于MySQL数据库是基于行存储的数据库,而数据库IO操作的时候是以 page 的方式,也就是说,如果我们每行记录所占用的空间量减小,就会使每个 page 中可存放的数据行数增大,那么每次 IO 可访问的行数也就增多了...4、ENUM & SET: 对于状态字段,可以尝试使用 ENUM 来存放,因为可以极大的降低存储空间,而且即使需要增加新的类型,只要增加于末尾,修改结构也不需要重建数据。...二、结构设计: 上面几点的优化都是为了减少每条记录的存储空间大小,让每个数据库中能够存储更多的记录条数,以达到减少 IO 操作次数,提高缓存命中率。...当我们的中存在类似于 TEXT 或者是很大的 varchar 类型的大字段的时候,如果我们大部分访问这张的时候都不需要这个字段,我们可以将其拆分到另外的独立中,以减少常用数据所占用的存储空间。...虽然 MySQL null 类型和 Oracle 的 null 有差异,会进入索引中,但如果是一个组合索引,那么这个 null 类型的字段会极大影响整个索引的效率。

7K10

mysql主从复制周期_Mysql主从复制

Mysql主从复制 背景: Mysql可以实现主从复制,在学习了Mysql主从复制后,将一些如何主从复制过程记录下来,供以后复习使用。...准备: 在做Mysql主从复制前需要做一些准备工作: 1、同步时间 做主从的服务器的时间需要同步,不然会出问题。...主从复制: 步骤1、安装Mysql服务 yum install mysql-server mysql 如果是Centos7版本:yum install mariadb-server mariadb (7...的所有者和所属组为mysql;命令:chown mysql.mysql /app/bin_log 2)启动服务并添加主从复制需要的帐号 CentOS6:service mysqld start CentOS7...步骤4、测试 1)在主数据库服务器创建一个数据库 2)在从mysql从服务器查看是否生成创建的数据库 到此mysql主从复制已完成。

4.2K10
领券