位置: 编程技术 - 正文

MySQL数据库InnoDB引擎主从复制同步经验总结(MYSQL数据库使用教程)

编辑:rootadmin

推荐整理分享MySQL数据库InnoDB引擎主从复制同步经验总结(MYSQL数据库使用教程),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:MYSQL数据库使用教程,MYSQL数据库原理与应用贾晶教材答案,MYSQL数据库中,下列说法正确的是,MYSQL数据库原理及应用,MYSQL数据库原理与应用贾晶教材答案,MYSQL数据库原理与应用贾晶教材答案,MYSQL数据库中,下列说法正确的是,mysql数据库inner join慢,内容如对您有帮助,希望把文章链接给更多的朋友!

近期将公司的MySQL架构升级了,由原先的一主多从换成了DRBD+Heartbeat双主多从,正好手上有一个电子商务网站新项目也要上线了,用的是DRBD+Heartbeat双主一从,由于此过程还是有别于以前的MyISAM引擎的,所以这里也将其心得归纳总结了一下:

1)MySQL的replication过程是一个异步同步的过程,并非完全的主从同步,所以同步的过程中是有延迟的,如果做了读写分离的业务的话,建议也要监控此延迟时间;

2)MySQL的master与slave机器记得server-id要保持不一致,如果一样的话,replication过程中会出现如下报错:

这个问题很好处理,即将slave机的server-id修改成跟master机器不一致即可。

3)我以前的一个误区就是,slave机器是用自己的二进制日志来完成replication过程的,其实不是这样的,根据复制的工作原理:slave服务器是copy主服务器的二进制日志到自己的中继日志,即relay-log日志(即centos3-relay-bin.这种名字的)中,然后再把更新应用用到自己的数据库上,所以slave机器是不需要开启二进制日志的,这样过程一样会成功的;除非是准备做主主架构,这才需要slave机器开启二进制日志,这个问题一直在导着我,我以一直以为slave机器搭建replication环境时是一定要开启二进制的

4)在master机器上授权时,尽量只给某一个或某几个固定机器权限,让它们只有replication slav,replication client权限,尽量不要给grant权限;另外,虽然数据库我们一般是通过内网操作,但越是在在内网对MySQL数据库进行授权操作,越是要注意安全;

MySQL数据库InnoDB引擎主从复制同步经验总结(MYSQL数据库使用教程)

5)replication搭建过程按照正常流程走的话,一般很容易实施成功,如果出错的话,多检查下网络环境、权限问题,一般来说整个搭建过程应该还是会比较顺利的。

在数据库设计初期,我已经将此电子商务的数据库引擎定义为InnoDB,除了数据库中原有的系统表之外,其它表全部由MyISAM转成了InnoDB,原因有二:

1)电子商务业务会涉及到交易付款,在这种基本OLTP的应用中,InnoDB应该作为核心应用表的首选存储引擎;2)DRBD系统重启时的过程会比较缓慢,会频繁的读表,如果表引擎为MyISAM的话极有可能出现损坏情况,为了造成不必要的问题,我将数据库的表引擎由MyISAM均转成了InnoDB引擎的表。

DRBD+Heartbeat+MySQL参考以前的工作文档,搭建的比较顺利,就是在搭建replication环境时遇到了报错,详细过程如下:初期参考MySQL手册操作,取master机器的快照备份,用的是--single-transaction选项,然后同步过程频繁报错,报错日志如下:

后来改变思路,用--master-data选项来取主master快照备份,命令如下所示:

附注:--master-data的用法为:通过此参数来备份SQL文件时会建议一个slavereplication,当其值为1时,SQL文件中会记录change master语句;当其值为2时,change master会被写成SQL注释,--master-data在没有使用--single-transaction选项的情况下会自动使用lock-all-tables选项(即这二代选项不要搭配使用)。如何查找SQL中的的LOG_FILE及LOG_POS呢?我们可以用如下命令(请注意change单词要写成大写的),如下所示:命令显示结果如下:

接下来的replication过程就不详细说明了,同步完成后我们经过相当长时间的观察,再也没报错了,如下所示:

工作中InnoDB引擎数据库主从复制同步心得以前的项目也比较多的牵涉到InnoDB数据库的备份及replication,较多的一个做法是停库进行replication,虽然也是解决问题的一种思路,但毕竟属于停机维护,在一些特殊应用场景中是不允许的,我们应该多尝试采用mysqldump这种逻辑备份方式来取master主机快照。

MySQL数据库如何开启远程连接(多备份) 开启MySQL的远程登陆帐号需要注意下面3点:1、确定服务器上的防火墙没有阻止端口。MySQL默认的端口是,需要确定防火墙没有阻止端口,否则

如何备份MySQL数据库 在MySQL中进行数据备份的方法有两种:1.mysqlhotcopy这个命令会在拷贝文件之前会把表锁住,并把数据同步到数据文件中,以避免拷贝到不完整的数据文件

Linux下自动备份MySQL的方法 Linux下可以利用crontab系统每天定时备份MySQL数据库,以下是详细步骤:1、创建保存备份文件的路径/mysqldata#mkdir/mysqldata2、创建/usr/sbin/bakmysql文件#vi/usr/sbi

标签: MYSQL数据库使用教程

本文链接地址:https://www.jiuchutong.com/biancheng/321356.html 转载请保留说明!

上一篇:MySQL编程中的6个实用技巧(mysql编程一般步骤)

下一篇:MySQL数据库如何开启远程连接(多备份)(mysql怎样)

  • 什么是税目税基税率,简答题
  • 附加税税负
  • 表见代理通俗
  • 什么记在借方
  • 装卸搬运的设备有哪些类型
  • 企业年报股东及出资信息要怎么填写
  • 工会筹备金和工会经费一样吗
  • 计提坏账又收回
  • 慰问金计入什么明细科目
  • 房地产开发企业预收款预缴增值税
  • 预收款结转收入怎么算
  • 单位支付给职工的一次性补助金怎么入账
  • 房屋出租需要缴纳个人所得税吗
  • 抵债资产账务处理2021年
  • 个税中的住房租金扣除什么意思
  • 结转安装费用的会计分录
  • 成本暂估跨年度要怎么处理?
  • 社保扣除当月工资还是上个月
  • 单位车转到个人名下要什么材料
  • 固定资产报废税费怎么处理
  • 快递费税率为什么是9
  • 个人车卖给公司可以抵税吗
  • 发放活动奖金支出怎么入账
  • 汇兑差额会计处理
  • 转正工资和试用工资区别
  • 正回购和逆回购的区别
  • 分支机构增值税汇总纳税怎么申报?
  • 如何制作macos bigsur的启动盘
  • 公司减少注册资本时,应当自作出减少
  • 个人汇算清缴已经做了公司怎么改申报
  • 债权转增资本的条件
  • 禁止input标签输入
  • lean in桑德伯格
  • php做登录界面连接数据库
  • php查找字符串中的某个字符
  • 哪些免征增值税
  • 企业所得税营业外收入
  • 如何根据科目余额表编制财务报表
  • 常见浏览器兼容软件
  • 作为大学生你能为国家安全贡献哪些力量论文
  • 财产赔偿账务处理办法
  • 公司与公司往来账表格怎么制作
  • 一个小柜的货代费用
  • 企业收到发票后怎么入账
  • 个人提供劳务需要开发票吗
  • 小规模个体户国税怎么算
  • 三个数排序c语言程序从大到小
  • SQLite教程(十):内存数据库和临时数据库
  • 固定资产报废处置的请示
  • 存货盘亏需要进项转出吗
  • 交易性金融资产入账价值怎么计算
  • 原材料属于固定资本还是流动资本
  • 发放股票股利的意义包括
  • 商场联营扣点的合作方式
  • 资固定资产清理
  • 营利性养老院都交哪些税
  • 混合销售行为的概念
  • 什么是投资性房地产具体包括哪些内容
  • winx64下mysql5.7.19的基本安装流程(详细)
  • winXP系统还能用吗
  • win7如何共享文件夹给另一台电脑使用
  • vm虚拟机中的网络设置怎么添加
  • vc运行程序
  • linux中less和more
  • centos配置kdump
  • 服务器双系统怎么安装
  • cocos2dx怎么安装
  • js跨域8种解决方案
  • perl 比较符
  • js实现组件功能
  • 自定义仪表盘的价值
  • 手把手教你学python
  • jquery中的eq是什么
  • 深入理解python递归
  • python异常处理的关键词
  • 微博html代码
  • 辽宁省社保系统操作
  • 实际金额与报关金额不符
  • 求资金占用利息的公式
  • 强化管理定义
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设