傅令江的光影色彩世界
留住记忆的点滴
  • 首页
  • 文学
    • 诗词鉴赏
    • 美文共读
    • 原创
  • 编程
    • php
    • asp
    • .net
    • VB
    • C/C++
    • 易语言
    • js
    • 其他
    • 逆向
  • 运维
    • windows
    • linux
  • 光影色彩
    • 电影
    • 音乐
  • 科技
    • 互联网
    • 手机
  • 生活
    • 情感
  • 微语
11月142014

CENTOS 6.3 OOMing (running out of memory) 问题解决

作者:令狐江   发布:2014-11-14 22:02   分类:linux   阅读:3618次   评论:0条  

最近几天工作室有一台服务器经常在流量不算很大的情况下,内存迅速降低到服务器宕机,几年的服务器维护经验告诉自己这个服务器配置是足以胜任目前的网站流量的,那么一定是服务器某个配置导致的问题,因为服务器的结构是LANMP,一般来说apache是内存消耗大户,所以大致判断的结论是apache的配置导致的内存消耗过大。

在处理此次OOMing的过程当中有个插曲,简单交代一下,每次内存快消耗完毕的时候,刚好发现了,就会通过SSH登录服务器,然后运行 service httpd reload 命令以释放apache所消耗的内存,以往执行这个操作基本都可以成功的释放内存出来,但此次执行完这个操作以后,服务器内存的确完全的释放出来了,但是发现网站仍旧无法打开,而且查看服务器负载会发现,负载逐步下降直至0,于是意识到很可能apache压根就没启动起来,因为结合了WDCP后台来可视化重启web,因此是否重启出错也是看不到的,于是进入ssh,重新执行service httpd reload,果然发现apache重启失败了,提示:

# service httpd restart
Stopping httpd:                                            [FAILED]
Starting httpd: (98)Address already in use: make_sock: could not bind to address [::]:88
(98)Address already in use: make_sock: could not bind to address 0.0.0.0:88
no listening sockets available, shutting down
Unable to open logs
[FAILED]
由此发现应该是发生OOMing以后,内存耗光了导致端口被占用,无法重启apache了,于是执行以下命令查看当前占用了88端口的进程是哪个进程:

# netstat -ltnp | grep ‘:88′
tcp 0 0 :::88 :::* LISTEN 3697/httpd
由上边可以看出占用88端口的是3697/httpd,因此执行以下命令杀死这个进程,然后再次重启apache就可以了:

# kill -9 3697
# service httpd restart
至此服务器避免了重启操作,恢复了网站的访问,当然目前这些操作仅仅是治标并没有治本,问题的根源基本可以肯定是apache的参数过高导致了资源消耗过大导致了OOMing的发生,当然仅仅是猜测是不够的,我们可以执行以下命令来查看服务器消耗的内存倒序排列结果:

ps -eo pmem,pcpu,rss,vsize,args | sort -k 1 -r | less
返回结果前几条显示如下:

%MEM %CPU RSS VSZ COMMAND
2.8 2.2 116452 250928 /www/wdlinux/apache/bin/httpd
2.8 2.0 115908 250852 /www/wdlinux/apache/bin/httpd
2.8 2.0 115896 250424 /www/wdlinux/apache/bin/httpd
2.8 2.0 115716 249840 /www/wdlinux/apache/bin/httpd
2.8 1.9 115924 250492 /www/wdlinux/apache/bin/httpd
2.8 1.9 115608 250528 /www/wdlinux/apache/bin/httpd
2.8 1.9 115048 249924 /www/wdlinux/apache/bin/httpd
2.8 1.8 116064 250708 /www/wdlinux/apache/bin/httpd
2.8 1.7 115692 250452 /www/wdlinux/apache/bin/httpd
2.6 2.4 108056 235816 /www/wdlinux/apache/bin/httpd
2.3 2.3 93288 220308 /www/wdlinux/apache/bin/httpd
2.2 2.5 90592 217728 /www/wdlinux/apache/bin/httpd
2.2 2.5 90176 217592 /www/wdlinux/apache/bin/httpd
2.2 2.5 89696 215480 /www/wdlinux/apache/bin/httpd
2.2 2.4 91356 217468 /www/wdlinux/apache/bin/httpd
2.2 2.4 90688 217860 /www/wdlinux/apache/bin/httpd
2.2 2.4 90580 217816 /www/wdlinux/apache/bin/httpd
2.2 2.4 89836 217052 /www/wdlinux/apache/bin/httpd
2.2 2.3 92568 218576 /www/wdlinux/apache/bin/httpd
2.2 2.3 90136 217564 /www/wdlinux/apache/bin/httpd
2.2 2.2 90152 217340 /www/wdlinux/apache/bin/httpd
2.2 2.2 89860 216832 /www/wdlinux/apache/bin/httpd
2.2 2.2 89428 216956 /www/wdlinux/apache/bin/httpd
2.2 2.0 89532 215652 /www/wdlinux/apache/bin/httpd
2.2 1.9 90712 217564 /www/wdlinux/apache/bin/httpd
然后执行以下命令,查看系统目前一共有多少个apache的进程在运行:

ps -ef|grep httpd|wc -l
根据返回的数据由此足以断定此次内存耗光的罪魁祸首就是apache进程太多导致的,于是重点着眼于apache的参数设定,最终测试下来的结论是MaxClients的正确设定,默认apache的MaxClients值普遍偏大,根据自己网站的流量来设定一个适合自己网站的正确的MaxClients值,保存,重启apache以后,一切正常了。




本文固定链接: https://www.fulingjiang.cn/linux/92.html

blogger
该日志由 令狐江 于2014-11-14 22:02 Friday发表在 linux 分类下。
版权所有:《傅令江的光影色彩世界》 → 《CENTOS 6.3 OOMing (running out of memory) 问题解决》;
除特别标注,本博客所有文章均为原创. 互联分享,尊重版权,转载请以链接形式标明本文地址;
本文标签:
上一篇::阿里云服务器文件 swap 无法开机自动加载
下一篇:增加/删除 SWAP分区空间的方法

热门文章

  • 兄弟二周年祭

相关文章

  • 为你宝塔面板一键开启HTTPS登陆+自动续期(面板+站点)
  • 一键解决BT宝塔面板的强制登陆限制要求教程
  • 在CentOS上安装部署MooseFS分布式文件系统
  • nginx任意反向代理配置(支持github,ip138,google) 这个是纯NGINX的任意反向代理
  • Linux文件分割与合并:split & cat
取消回复

发表评论

亲,头像对么?

提交中,请稍候……


木有头像就木JJ啦!还木有头像吗?点这里申请属于你的个性Gravatar头像吧!


  • 日历

  • 存档

    • 2024年10月(1)
    • 2023年2月(1)
    • 2022年11月(1)
    • 2022年10月(10)
    • 2022年9月(13)
    • 2022年8月(2)
    • 2022年7月(14)
    • 2022年6月(2)
    • 2022年5月(8)
    • 2022年4月(7)
    • 2022年3月(13)
    • 2022年2月(2)
    • 2022年1月(9)
    • 2021年12月(2)
    • 2021年11月(4)
    • 2021年10月(2)
    • 2021年9月(6)
    • 2021年7月(4)
    • 2021年6月(3)
    • 2021年5月(3)
    • 2021年4月(11)
    • 2021年3月(13)
    • 2021年2月(2)
    • 2021年1月(1)
    • 2020年12月(1)
    • 2020年4月(5)
    • 2019年9月(1)
    • 2019年8月(1)
    • 2019年5月(3)
    • 2018年3月(1)
    • 2017年10月(1)
    • 2016年7月(1)
    • 2016年4月(1)
    • 2015年12月(1)
    • 2015年11月(3)
    • 2015年9月(1)
    • 2015年8月(10)
    • 2015年7月(1)
    • 2015年6月(1)
    • 2015年4月(1)
    • 2015年3月(3)
    • 2015年2月(8)
    • 2015年1月(4)
    • 2014年12月(1)
    • 2014年11月(27)
    • 2014年10月(13)
    • 2014年9月(14)
    • 2014年8月(26)
    • 2014年7月(21)
  • 最新评论

    • 令狐江:
      喜欢这首歌是因为可以引起共鸣!
  • 链接

    • 演讲稿网
    • Recollect
    • 演讲稿
    • 祁阳人生活网
    • 我爱演讲稿网
  • 搜索

  • 标签

      函数 自定义方法 SEO 分页 分页函数 分页方法 nginx重新的一些规则
  • 分类

    • 文学(0)
    • 编程(0)
    • 运维(0)
    • 光影色彩(0)
    • 科技(0)
    • 生活(0)
    • 诗词鉴赏(3)
    • 美文共读(1)
    • 原创(10)
    • php(111)
    • asp(1)
    • .net(0)
    • VB(0)
    • C/C++(0)
    • 易语言(0)
    • js(8)
    • 其他(9)
    • 逆向(2)
    • windows(11)
    • linux(121)
    • 电影(0)
    • 音乐(1)
    • 互联网(4)
    • 手机(0)
    • 情感(2)
  • 最新文章热门文章随机文章

    • 兄弟二周年祭
    • openai给的ionCube 解密代码,应该是老版本可以这样
    • WordPress – 5秒盾防CC(PHP通用代码)
    • 我高中最好的朋友今天猝死了-伤心得不行
    • Linux系统中 systemd-journaldCPU占用异常的解决方法
    • SVN Skipped 'xxx' -- Node remains in conflict 错误的解决办法
    • 解决Linux读写nfs共享盘速度慢的问题
    • php 获取302跳转后的地址
    • 让vsftp显示隐藏文件的办法,比如显示 .htaccess
    • 添加自签名https证书到centos系统信任的问题
    • 使用Snoopy来获取某网页的所有链接
    • PHP获取页面的JS和CSS的总数和文件
    • php采集文章过滤版权信息
    • 提取google搜索数据,遭遇屏蔽的解决办法用php_Curl获取Cookie!
    • php smtp发送邮件类,带使用示例
Copyright © 2001-2025 傅令江的光影色彩世界. Powered by www.fulingjiang.cn ICP备案:京ICP备14015190号-5