位置: 编程技术 - 正文

MySQL OOM 系列三 摆脱MySQL被Kill的厄运(mysqlw3school)

发布时间:2024-02-26

推荐整理分享MySQL OOM 系列三 摆脱MySQL被Kill的厄运(mysqlw3school),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:mysql三大,mysqlw3school,mysqlor,mysqlw3c,mysql 3nf,mysqlw3c,mysql omm,mysql 3,内容如对您有帮助,希望把文章链接给更多的朋友!

前面两章,我们分析了Linux内存分配的策略以及Linux通过使用 OOM_Killer的机制解决了“超售”引起的风险,MySQL同其他的应用程序一样,在操作系统允许的范围内也是可以超售的,一般人理解,Innodb_buffer_pool必须小于实际物理内存,否则MySQL会启动失败。其实这是一个误区,这个不是MySQL层控制的,这个是操作系统(OS)层控制的,就是前面提到的/proc/sys/overcommit_memory控制OS是否允许“超售”。如果允许“超售”,则Innodb_buffer_pool可以远远超过实际的内存空间大小,但是这部分空间是没有使用的。我们可以做个小实验,见下图:

MySQL OOM 系列三 摆脱MySQL被Kill的厄运(mysqlw3school)

MySQL的Innodb_buffer_pool开了5G,但实际内存只有3G。讲了这么多,现在言归正传,回到我们最早提到的RDS实例被OS Kill掉的问题上来,前面我们也提到了,一旦实例可用内存不足,MySQL一般都会成为OOM_Killer的首选目标。这里就涉及到两个问题:

1.为什么会内存不足?2.如何让MySQL摆脱被Kill的厄运?首先我们来看一下第一个问题。内存不足这个问题产生原因很多,但是主要就两个方面,第一个是MySQL自身内存的规划有问题。第二个就是一般部署MySQL的服务器,都会部署很多的监控或者定时任务脚本,而这些脚本往往缺少必要的内存限制,导致在高峰期的时候占用大量的内存,导致触发Linux OOM_Killer机制,MySQL就无辜牺牲了。那如何才能让MySQL摆脱被Kill的厄运呢? MySQL被Kill的根源在于Linux超售的内存分配机制,前面也提到了,只要存在这种超售的机制,就不可能完全避免某一个应用程序被Kill的风险。那要使得MySQL一定不会被Kill掉,只能禁止操作系统超出实际内存空间的分配内存。但是前面我们也提过,对于部署了MySQL的服务器,我们不建议这么做,因为MySQL的很多内存都是刚开始申请了,并不是立即使用的,OS一旦禁止超售,这不仅对MySQL自身内存规划提出更苛刻的要求,同时也存在内存无法充分利用的问题。同时,MySQL的每个连接的私有内存是动态分配的,如果分配不到,就会直接导致服务器Crash,这样也会增加MySQL Crash的风险。既然受限于操作系统,无法完全做到避免被Kill,那只能尽量降低MySQL被Kill的几率。我觉得至少可以做下面3个事情:

1)合理的规划MySQL的内存使用。2)调整OOM_adj参数,将MySQL被OOM_Killer锁定的优先级降低。3)加强内存的监控和报警,一旦报警,DBA应该迅速介入,Kill掉一些占用较多内存的连接。

MySQL Slave 触发 oom-killer解决方法 最近经常有收到MySQL实例类似内存不足的报警信息,登陆到服务器上一看发现MySQL吃掉了%的内存,God!有时候没有及时处理,内核就会自己帮我们重启

Slave memory leak and trigger oom-killer BugDescriptionWehavethisproblem:wehavesetinnodb_buffer_pool=GBonbothmasterandslave,masterofferusuallyworkload,butslavewithnothingworkloadexcepttheseslavethreads,Butwiththememoryconsumptionisincreasi

MySQL 5.6 & 5.7最优配置文件模板(my.ini) Inside君整理了一份最新基于MySQL5.6和5.7的配置文件模板,基本上可以说覆盖%的调优选项,用户只需根据自己的服务器配置稍作修改即可,如InnoDB缓冲池

标签: mysqlw3school

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

上一篇:MySQL OOM 系统二 OOM Killer(mysql osc)

下一篇:MySQL Slave 触发 oom-killer解决方法(mysql触发事件)

  • 小规模纳税人合理避税
  • 交易性金融资产属于什么科目
  • 个体工商户可以开发票吗
  • 小规模增值税附加税税率
  • 定额发票上可以盖章吗
  • 如何调整所得税费用
  • 离退休人员的返乡政策
  • 进出口代理公司哪家好
  • 政府给的专款专用发票
  • 注册地在境外的公司需要纳税么
  • 公司换法人公司账户怎么办
  • 银行承兑汇票置换业务自签发之日起新票的最长期限为
  • 本地开的住宿费可以退吗
  • 携税宝报税操作流程
  • 预缴的企业所得税可以税前扣除吗
  • 银行承兑汇票加工费合同
  • 企业上市过程中遇到的困难
  • 增值税普通发票红冲之后还能查询吗
  • 预收账款预提费用
  • 减值 计提
  • 上期认证的发票本期能抵扣吗
  • 待摊费用属于什么费用
  • 滴滴开票是专票还是普票
  • 带息负债融资成本率意义
  • win7系统中回收站的内容清空后还能恢复吗
  • 展位费一般多少钱
  • 马拉喀什的历史背景
  • php网页编程
  • uniapp使用高德地图直接进行导航
  • 爱心代码图
  • tailf命令 查看100行
  • c语言二级指针详解
  • php数据库网址
  • 增值税发票打印出格了能用吗
  • 企业为什么要开银行承兑汇票
  • 印花税应计入哪些费用
  • python2.7 协程
  • db2 -x
  • 高铁票的电子发票
  • 政府会计应付职工薪酬明细科目
  • 购车增值税可以不交吗
  • 公司从一个帐户里扣税吗
  • 盈余公积的会计科目
  • 固定资产一次性扣除政策
  • 商品互换概念
  • 注销时其他应付款怎么冲平
  • 政府资助专项资金是什么
  • 小规模纳税人减按1%怎么计算
  • 了解出口业务操作流程
  • 预收工程款怎么做账
  • 行政单位收到的待报解预算收入怎么做账
  • 税率调整后税差怎么算
  • 公司买车车辆购置税怎么交钱
  • 高新技术企业福利
  • 体检收据可以入档案吗
  • 赠送货物金额为多少
  • 收到银联商务客户短信
  • mysql数据库5.7.27安装
  • win2003安装加载阵列卡驱动
  • win7显示无线网络未连接
  • freebsd 升级
  • 硬盘 bios
  • issch.exe
  • win7精简版安装net4.0
  • vmware 安装教程
  • win10怎么把中文系统改成英文
  • win7打开文件提示用户没有访问权限怎么办
  • win8如何进行系统还原
  • opengl基础知识
  • shell监控进程
  • 批处理自动确定
  • python汉字字符
  • Unity3D游戏开发标准教程
  • python中运算符/和//的区别
  • django教程推荐
  • 河北省税务局云平台运维
  • 税务检查的三种常用方法
  • 四川增值税发票图片
  • 税务局的纳税服务中心是干什么的
  • 税务局的局长是什么级别
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号