Nginx或PHP FPM忽略php.ini中的memory_limit

时间:2013-04-12 03:37:50

标签: nginx php

服务器信息:Ubuntu Server,Nginx,PHP FPM

我在/etc/php5/fpm/php.ini中的

memory_limit = 512M/etc/php5/fpm/php-fpm.conf我有:php_admin_value[memory_limit] = 512M

php_value[memory_limit] = 512M

我的phpinfo看起来像:

PHP Version 5.3.10-1ubuntu3.6

系统构建日期

Linux snserver 3.2.0-40-generic#64-Ubuntu SMP Mon Mar 25 21:22:10 UTC 2013 x86_64 Mar 11 2013 14:34:24

服务器API

FPM/FastCGI

虚拟目录支持

禁用

配置文件(php.ini)路径

/etc/php5/fpm 

已加载的配置文件

/etc/php5/fpm/php.ini

扫描此目录以获取其他.ini文件 /etc/php5/fpm/conf.d

解析了其他.ini个文件

/etc/php5/fpm/conf.d/curl.ini, /etc/php5/fpm/conf.d/gd.ini, /etc/php5/fpm/conf.d/mcrypt.ini, /etc/php5/fpm/conf.d/memcache.ini, /etc/php5/fpm/conf.d/mysql.ini, /etc/php5/fpm/conf.d/mysqli.ini, /etc/php5/fpm/conf.d/pdo.ini, /etc/php5/fpm/conf.d/pdo_mysql.ini ...

此服务器受Suhosin Patch 0.9.10保护 版权所有(c)2006-2007 Hardened-PHP Project Copyright(c)2007-2009 SektionEins GmbH

该程序使用Zend脚本语言引擎: Zend Engine v2.3.0,版权所有(c)1998-2012 Zend Technologies     与Xdebug v2.2.2,版权所有(c)2002-2013,作者Derick Rethans

...

memory_limit的

128M

的upload_max_filesize

20M

/etc/nginx/nginx.conf中的

    user www-data;

worker_processes 2;

pid /var/run/nginx.pid;

events {
    worker_connections 768;
    # multi_accept on;
}

http {
    client_max_body_size 20M;

    ##

    # Basic Settings

    ##
    fastcgi_buffers 16 16k;

    fastcgi_buffer_size 32k;

    proxy_buffers 4 512k;

    proxy_buffer_size 256k;

    proxy_busy_buffers_size 512k;

    fastcgi_read_timeout 3600;

    sendfile on;

    tcp_nopush on;

    tcp_nodelay on;

    keepalive_timeout 300;

    keepalive_requests 50;

    #ssl_ciphers HIGH:!aNULL:!MD5:!kEDH;

        #ssl_prefer_server_ciphers on;

        #ssl_protocols TLSv1;

        #ssl_session_cache shared:SSL:10m;

        #ssl_session_timeout 10m;

    types_hash_max_size 2048;

    # server_tokens off;

    # server_names_hash_bucket_size 64;

    # server_name_in_redirect off;

    include /etc/nginx/mime.types;

    default_type application/octet-stream;

    ##
    # Logging Settings
    ##

    access_log /var/log/nginx/access.log;

    error_log /var/log/nginx/error.log;

    ##
    # Gzip Settings
    ##

    gzip on;
    gzip_disable "msie6";

    # gzip_vary on;
    # gzip_proxied any;
    # gzip_comp_level 6;
    # gzip_buffers 16 8k;
    # gzip_http_version 1.1;
    # gzip_types text/plain text/css application/json application/x-javascript text/xml application/xml application/xml+rss text/javascript;

    ##
    # nginx-naxsi config
    ##
    # Uncomment it if you installed nginx-naxsi
    ##

    #include /etc/nginx/naxsi_core.rules;

    ##
    # nginx-passenger config
    ##
    # Uncomment it if you installed nginx-passenger
    ##

    #passenger_root /usr;
    #passenger_ruby /usr/bin/ruby;

    ##
    # Virtual Host Configs
    ##

    include /etc/nginx/conf.d/*.conf;
    include /etc/nginx/sites-enabled/*;
}

问题是,当我更改upload_max_filesize尺寸时,phpinfo会显示新值,但是当我更改memory_limit时,则没有任何变化。 我想在某处memory_limit被覆盖了。但我找不到它。 任何人都可以帮助我吗?

7 个答案:

答案 0 :(得分:22)

/etc/php5/fpm/php-fpm.conf我有php_admin_value[memory_limit] = 512M

这适合我。

答案 1 :(得分:10)

问题可能在 fpm 过程重复,即使你更改你的/etc/php5/fpm/php.ini也没有效果。

  • 用(ubuntu)停止php5-fpm:sudo service php5-fpm stop
  • 检查没有更多的fpm进程:sudo ps ax | grep fpm
  • 如果有任何杀死它:sudo kill -9 pid
  • 确保你杀死所有fpm进程
  • restart:sudo service php5-fpm restart

答案 2 :(得分:7)

你可以将Nginx从图片中删除,它只是传递请求,它是在php-fpm中运行你的php代码。

你可以查看你的suhosin设置,suhosin.memory_limit。

当你看到你的phpinfo输出时,应该有2列,master和local为memory_limit,这些列显示了什么?

128M是php 5.3中memory_limit的默认值

答案 3 :(得分:4)

仅供参考,

您还应该检查/ etc / php5 / fpm / pool.d 以查找任何文件。

我发现,无论我在/etc/php5/fpm/php-fpm.conf上写了什么,它都会被/etc/php5/fpm/pool.d/www.conf覆盖!

所以,如果上述答案都不适合你,你应该检查一下(我刚刚失去半小时)。

答案 4 :(得分:2)

对我而言,它也忽略了php.ini,我不得不做以下事情:

vim /etc/php-fpm.d/www.conf

php_admin_value[memory_limit] = 10000M ;128M

然后重启php-fpm:

service php-fpm restart

答案 5 :(得分:1)

现在也遇到过这种情况,并希望在DigitalOcean Droplet中增加服务器的内存

总结一下,这就是我做的事情

mysql_stmt_init()

您不需要重新启动nginx,只需重新启动 php 即可。

答案 6 :(得分:0)

好吧,这很愚蠢,但是我将memory_limit设置为2GB,这是无法理解的。当我将其更改为2000M时,它起作用了!