位置: 编程技术 - 正文

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

编辑:rootadmin

推荐整理分享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触发事件)

  • 申报个体经营所得税时营业外收入怎么填
  • 销售货物的运费计入成本吗
  • 增值税加计扣除是什么意思啊
  • 增值税认证勾选平台
  • 流动负债占比低于50%,是什么结构类型
  • 个税申报系统跟工资表累计扣除数不一致怎么办
  • 取得增值税专用发票要算税吗
  • 行政事业单位资产管理工作总结
  • 员工个人无息借款违法吗
  • 工会应付下级经费
  • 积分兑换礼品需要缴纳个人所得税吗
  • 企业如何进行利润分配的会记处理
  • 170平方的房子装修费用
  • 以物易物差价印花税
  • 进项较大航天信息怎么填
  • 企业认缴出资怎么做账
  • 视同销售可以抵扣销项税吗?
  • 装卸收入的增值税税率是多少
  • 房地产开发公司取名
  • 所得税费用什么时候结转到本年利润
  • 业主委员会的收益
  • 境内企业技术转让 增值税
  • 关联企业间融资方式
  • 补充医疗保险报销流程
  • 政府专项拨款账务处理
  • 结转本月销售成本的会计分录
  • 出口业务怎么做分录
  • 经营性租赁 会计准则
  • php匹配邮箱
  • pull-hi
  • js控件的监听事件怎么使用
  • islp2sta.exe - islp2sta是什么进程 有什么作用
  • 宾馆一次性用品有哪些
  • 往来账款如何做账务处理
  • 金融企业计提资产减值准备是根据会计核算的
  • php ucwords() 函数将字符串中每个单词的首字符转换为大写(实现代码)
  • 关于php文件的自动播放
  • telnet 执行命令
  • 增值税纳税申报操作流程
  • lvm 创建
  • 进项税额转出有什么好处
  • 不动产固定资产清理
  • 工业企业成本核算的一般程序
  • 科目汇总表一张不够怎么写下一页
  • 投资别人公司的注意事项
  • c语言fgets函数用法stdin
  • phpcms验证码不显示
  • 开发支出在资产负债表填哪一栏
  • 个体工商户具体工作内容怎么写
  • 新准则制度体系的核心变化
  • 银行贷款印花税是什么意思
  • 个税的缴纳期数是什么
  • 企业银行基本户和一般户的区别
  • 买理财产品的风险
  • 长期股权投资的账务处理
  • 临时工工资计入什么费用
  • 房产契税什么时候退税
  • 包装物是指什么
  • 应付账款的主要风险点
  • 装修公司购买材料,工程施工账务处理会计分录
  • 培训费发票是否可以抵扣
  • Win10 Build 17035自制64位中国版十合一ISO镜像下载地址
  • windows vista怎么样
  • centos7 cp命令
  • windows七如何连接网络
  • windows任务管理器打不开
  • 如何安装windowsxp
  • linux系统获取dhcp地址
  • netsurf.exe - netsurf是什么进程 有什么用
  • win7唤醒后屏幕黑屏
  • css百分比进度条
  • 运行javascript
  • 调度器在操作系统中的作用
  • 用jquery
  • python给批量图片添加文字
  • 个体户需要报个税的综合所得吗
  • 广西税务怎么交城乡养老保险
  • 辽宁社保网上申报流程图
  • 新疆地方税务局举报电话
  • 纳税申报逾期怎样补报?
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设