当前位置: 移动技术网 > IT编程>数据库>Mysql > mysqld-nt: Out of memory (Needed 1677720 bytes)解决方法

mysqld-nt: Out of memory (Needed 1677720 bytes)解决方法

2017年12月12日  | 移动技术网IT编程  | 我要评论

天神右翼结局,轻资产,异界魔盗行

今天发现网站有点慢,发现mysql日志中提示mysqld-nt: out of memory (needed 1677720 bytes),经排查是由于最近调整了mysql的一些参数导致,以为内存大就不怕了,32位系统真心内容利用率很低,据说不超过4g,我们的32g内存真浪费了,以后还是使用win2008 r2或centos系统做服务器吧。废话不多说下面为大家分享下解决方法:

因为mysql版本不同可能配置略有区别,主要就是设置如下参数

key_buffer、key_buffer_size、read_buffer_size、sort_buffer_size记住了有这个参数的就改,没有也不要添加。修改后一般是降低,然后重启mysql服务即可。

核心提示:检查mysqld配置my.conf,着重看key_buffer_size, max_heap_table_size, tmp_table_size几个参数,推荐设置key_buffer_size值为max_heap_table_size的1/4.

因为服务器内存而大富余比较多,前些天把my.conf里的好几个参数调得相当大,1g甚至2g,但并不稳定,mysqld报出过几次out of memory (needed xxx bytes)这样的错误,分析原因时,想到是32位linux系统上的linux不支持pae,不能使用超过3g以上的内存,所以把改大的几个参数适当改小了点,最大也只有几百m的样子,但还是出现过几次out of memory错误。于是网上多方查询,后来受到公式

key_buffer_size + (read_buffer_size + sort_buffer_size)*max_connections

的启发,两次检查了key_buffer_size, max_heap_table_size, tmp_table_size几个参数,发现这三个值的设置是一样的,竟然都是512m!

于是改小key_buffer_size到128m,重启mysqld接下来5个小时的监测,没有再发生类似错误。

改了这几个参数后,还是有一条是out of memory ,继续检查,发现innodb_buffer_pool_size = 1512m,于是我改为1000m,再启mysql居然好了。

注:这台服务器一共了才3g内存:最终大至如下

key_buffer = 200m
key_buffer_size = 1294963200
#max_join_size = 4294967295
max_join_size = 1294967295
max_allowed_packet = 1m
#table_open_cache = 512
table_cache = 512
sort_buffer_size = 2294967295
read_buffer_size = 2147479552
#write_buffer_size = 4294967295
read_rnd_buffer_size = 4m
myisam_sort_buffer_size = 64m
thread_cache_size = 8
query_cache_size= 16m

php错误fatal error: out of memory (allocated 262144) (tried to allocate 19456 bytes

php运行一段时候后出现错误:

php错误fatal error: out of memory (allocated 262144) (tried to allocate 19456 bytes

意思是说:致命错误,超出内存,已经分配allocated 262144,尝试分配19456 字节。

解决方法是修改php.ini,加大memory_limit

刚刚着实吓我一跳,html可以正常访问,php不行,我还以为是受攻击呢。

后来看到www.blogguy.cn 上不去了fatal error: out of memory (allocated 262144) (tried to allocate 19456 bytes,知道是内存不足导致的,可是vps也连不上去,也看不到到底是谁在占内存,只能进网站后台重启vps,就不知道问题出在哪儿了。记录下来备案!

修改方法

修改php.ini

如下的区域

max_execution_time = 120 ; maximum execution time of each script, in seconds
max_input_time = 60 ; maximum amount of time each script may spend parsing request data
memory_limit = 64m ; maximum amount of memory a script may consume (64mb)

根据需要调整。

重启一下apache就可以了。

如对本文有疑问,请在下面进行留言讨论,广大热心网友会与你互动!! 点击进行留言回复

相关文章:

验证码:
移动技术网