位置: 编程技术 - 正文

Mysql数据库性能优化三(分表、增量备份、还原)(mysql数据库性能监控)

编辑:rootadmin

推荐整理分享Mysql数据库性能优化三(分表、增量备份、还原)(mysql数据库性能监控),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:mysql数据库性能监控工具,MySQL数据库性能诊断产品DBdoctor介绍,MySQL数据库性能监控及调优,mysql数据库性能优化方法,mysql数据库性能指标,MySQL数据库性能诊断产品DBdoctor介绍,MySQL数据库性能优化,mysql数据库性能调优,内容如对您有帮助,希望把文章链接给更多的朋友!

接上篇Mysql数据库性能优化二

对表进行水平划分

如果一个表的记录数太多了,比如上千万条,而且需要经常检索,那么我们就有必要化整为零了。如果我拆成个表,那么每个表只有万条记录。当然这需要数据在逻辑上可以划分。一个好的划分依据,有利于程序的简单实现,也可以充分利用水平分表的优势。比如系统界面上只提供按月查询的功能,那么把表按月拆分成个,每个查询只查询一个表就够了。如果非要按照地域来分,即使把表拆的再小,查询还是要联合所有表来查,还不如不拆了。所以一个好的拆分依据是 最重要的。关键字:UNION

例:

订单表根据订单产生时间来分表(一年一张) 学生情况表 查询电话费,近三个月的数据放入一张表,一年内的放入到另一张表

对表进行垂直划分

有些表记录数并不多,可能也就2、3万条,但是字段却很长,表占用空间很大,检索表时需要执行大量I/O,严重降低了性能。这个时候需要把大的字段拆分到另一个表,并且该表与原表是一对一的关系。 (JOIN)

【试题内容】、【答案信息】两个表,最初是作为几个字段添加到【试题信息】里的,可以看到试题内容和答案这两个字段很长,在表里有3万记录时,表已经占 了1G的空间,在列试题列表时非常慢。经过分析,发现系统很多时候是根据【册】、【单元】、类型、类别、难易程度等查询条件,分页显示试题详细内容。而每 次检索都是这几个表做join,每次要扫描一遍1G的表。我们完全可以把内容和答案拆分成另一个表,只有显示详细内容的时候才读这个大表,由此 就产生了【试题内容】、【答案信息】两个表。

选择适当的字段类型,特别是主键

选择字段的一般原则是保小不保大,能用占用字节小的字段就不用大字段。比如主键, 建议使用自增类型,这样省空间,空间就是效率!按4个字节和按个字节定位一条记录,谁快谁慢太明显了。涉及到几个表做join时,效果就更明显了。

建议使用一个不含业务逻辑的id做主角如s。例:

文件、图片等大文件用文件系统存储

数据库只存储路径。图片和文件存放在文件系统,甚至单独放在一台服务器(图床 / 视频服务器 ).

数据库参数配置

最重要的参数就是内存,我们主要用的innodb引擎,所以下面两个参数调的很大

对于myisam,需要调整key_buffer_size,当然调整参数还是要看状态,用show status语句可以看到当前状态,以决定改调整哪些参数

在my.ini修改端口,默认存储引擎和最大连接数

合理的硬件资源和操作系统

如果你的机器内存超过4G,那么毋庸置疑应当采用位操作系统和位mysql 5.5. or mysql5.6

读写分离

如果数据库压力很大,一台机器支撑不了,那么可以用mysql复制实现多台机器同步,将数据库的压力分散。

Master  Slave1  Slave2  Slave3

主库master用来写入,slave1—slave3都用来做select,每个数据库分担的压力小了很多。要实现这种方式,需要程序特别设计,写都操作master,读都操作slave,给程序开发带来了额外负担。当然目前已经有中间件来实现这个代理,对程 序来读写哪些数据库是透明的。官方有个mysql-proxy,但是还是alpha版本的。新浪有个amobe for mysql,也可达到这个目的,结构如下

定时完成数据库的备份

项目实际需求,请完成定时备份某个数据库,或者定时备份数据库的某些表的操作

windows 下每隔1小时,备份一次数据newsdb

windows 每天晚上2: 备份 newsdb 下 某一张表

cmd> mysqldump ?u root ?p密码 数据库名 > 把数据库放入到某个目录

案例,备份 mydb 库的所有表

进入mysqldump所在的目录

cmd> mysqldump ?u root ?phsp shop> d:/shop.log [把shop数据库的所有表全部导出]

cmd> mysqldump ?u root ?phsp shop temusers emp > d:/shop2.log [shop数据库的 temusers和emp导出]

Mysql数据库性能优化三(分表、增量备份、还原)(mysql数据库性能监控)

如何恢复数据的表

进入的mysql操作界面

mysql>source 备份文件的全路径

定时备份:(把命令写入到my.bat 问中)

windows 如何定时备份 (每天凌晨2:)

使用windows自带的计划任务,定时执行批处理命令。

增量备份和还原

定义:mysql数据库会以二进制的形式,自动把用户对mysql数据库的操作,记录到文件,当用户希望恢复的时候,可以使用备份文件进行恢复。

增量备份会记录dml语句、创建表的语句,不会记录select。记录的东西包括:sql语句本身、操作时间,位置

进行增量备份的步骤和恢复

注意:mysql5.0及之前的版本是不支持增量备份的

1、配置my.ini文件或者my.conf,启用二进制备份。

打开my.ini文件,查找log-bin,进行配置:log-bin=G:Databasemysqlbinlogmylog

在G:Database目录下面新建目录mysqlbinlog

2、重启mysql服务

这个时候会在mysqlbinlog目录下面看到以下两个文件:

mylog.:日志备份文件。如果要查看这个日志文件里面的信息,我们可以使用mysqlbinlog程序查看,mysqlbinlog程序存放在mysql的bin目录下面(“C:Program FilesMySQLMySQL Server 5.6bin”)。

执行sql语句

UPDATE emp set ename='zouqj' where empno=;

开始——运行——cmd,mysqlbinlog 备份文件路径

C:Program FilesMySQLMySQL Server 5.6bin>mysqlbinlog G:Databasemysqlbinlogmylog.

mylog.index:日志索引文件,里面记录了所以的日志文件。(G:Databasemysqlbinlogmylog.)

3、假设现在问题来了,我这条update是误操作,如何进行恢复

在mysql日志中会记录每一次操作的时间和位置,所以我们既可以根据时间来恢复,也可以根据位置来恢复。

那么,我们现在马上可以从上图看出,这条语句产生的时间是"-- ::",位置是

按时间来恢复

我们可以选择在语句产生时间的前一秒

执行cmd命令:mysqlbinlog --stop-datetime="-- ::" G:Databasemysqlbinlogmylog. | mysql -uroot -p

这个时候我再执行SQL语句查看

SELECT * from emp where empno=;

结果变成了

按位置来恢复

执行cmd命令:mysqlbinlog --stop-position="" G:Databasemysqlbinlogmylog. | mysql -uroot -p

这个时候再执行SQL来查看结果,又变回来了。

标签: mysql数据库性能监控

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

上一篇:Sql Server中Substring函数的用法实例解析

下一篇:SQLServer获取临时表所有列名或是否存在指定列名的方法(sql查询使用临时表)

  • 购买汽车的印花税要计入汽车原值吗
  • 定额备用金与非定额备用金的会计分录
  • 差旅费抵税怎么算
  • 农产品一般纳税人开普票免税吗
  • 固定资产加速折旧税收优惠政策
  • 房租收入纳税义务
  • 怎么分清复利和年金
  • 外经证的项目范围
  • 未开票确认收入分录怎么做
  • 汇算清缴预提费用调整政策
  • 暂估费用发票没到会计分录怎么写?
  • 税收优惠退回的税金怎么入账
  • 购买原材料已付款怎么记账
  • 退税收入需要缴纳所得税吗
  • 预交电费有发票吗
  • 跨年度收入计算的增值税如何入账?
  • 开了增值税专用发票对方不付款可以申请冻结对方公帐嘛
  • 停车费属于不动产租赁服务税率
  • 委托代销中受托方账务处理
  • 评标费由谁支付
  • 代扣代征税款有哪些
  • 进料加工出口退税计算 计划分配率
  • win10新建文件夹快捷键ctrl加什么
  • 购买所有物品都是可以退货吗
  • linux -pv
  • Windows XP具有类似于Apple Aqua的秘密主题
  • php中split
  • 出售低值易耗品的账务处理
  • 收到政府补助如何开具发票
  • vue调整图标大小
  • 乌尤尼盐沼的演化过程
  • 工商银行电子回执单怎么查看
  • 企业所得税征前减免是什么意思
  • 专票退税是什么意思
  • 得物的成本结构是什么
  • js数组分组并排序
  • vue viewui
  • vue3.0启动命令
  • vuexy
  • 哪些公司不交五险一金
  • phpcms怎么样
  • 记账凭证错了
  • 怎么开电子专用增值税发票
  • 发票报销有时间期限吗
  • 合并报表存货的计税基础
  • 个税申报错误已经扣税款怎么处理
  • 税前扣除原则和扣除金额
  • 印花税签合同
  • 其他收益会计科目核算什么
  • 材料按计划成本计价下,外购材料结算
  • 小规模纳税人购进商品会计分录
  • 民间非盈利组织使用什么会计准则
  • 应付账款借方余额在资产负债表中怎么列示
  • 离职员工未休完的年假如何支付
  • 企业应交税金包括印花税吗
  • 场地租赁都需要交什么税
  • 未完工工程如何验收
  • 递延收益确认的递延所得税资产有期限吗
  • 其他应收款有没有备抵科目
  • 工程施工间接费用明细
  • 企业控股情况分析报告
  • 会计年初如何轻松工作
  • sql server dbcc
  • windows快速预览
  • windows8音频服务尚未启用 怎么解决
  • downloadplus.exe是什么进程 作用是什么 downloadplus进程是安全的吗
  • win8的ie打开马上闪退
  • win8怎么打开蓝牙设置
  • 内存 服务器
  • win7玩英雄联盟卡顿怎么解决
  • jquery fadein 源码
  • js canvas绘制图片
  • android studio string函数
  • jquery实现移动端
  • 安卓启动器修改
  • 建筑施工税务处理
  • 银行手续费所得税是否可以税前扣除
  • 河北税务云办税厅官方
  • 安徽地税局领导班子名单
  • 个人所得税必须企业代扣代缴吗
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设