Memory usage with aio

Maxim Dounin mdounin на mdounin.ru
Пн Мар 14 13:26:57 MSK 2011


Hello!

On Sun, Mar 13, 2011 at 12:57:38AM +0200, Андрей Василишин wrote:

> Всем привет!
> 
> Заметил, что после включения aio нгинкс стал больше потреблять
> памяти при тех же нагрузках.
> 
> 
> Нгикс до аио:
> nginx -V
> nginx version: nginx/0.8.53
> TLS SNI support enabled
> configure arguments: --conf-path=/etc/nginx/nginx.conf
> --error-log-path=/var/log/nginx/error.log
> --http-client-body-temp-path=/var/lib/nginx/body
> --http-fastcgi-temp-path=/var/lib/nginx/fastcgi
> --http-log-path=/var/log/nginx/access.log
> --http-proxy-temp-path=/var/lib/nginx/proxy
> --http-scgi-temp-path=/var/lib/nginx/scgi
> --http-uwsgi-temp-path=/var/lib/nginx/uwsgi
> --lock-path=/var/lock/nginx.lock --pid-path=/var/run/nginx.pid
> --with-debug --with-http_dav_module --with-http_flv_module
> --with-http_geoip_module --with-http_gzip_static_module
> --with-http_image_filter_module --with-http_realip_module
> --with-http_stub_status_module --with-http_ssl_module
> --with-http_sub_module --with-http_xslt_module --with-ipv6
> --with-sha1=/usr/include/openssl --with-md5=/usr/include/openssl

Just a side note: это пути к исходникам, а не к заголовкам.

> --with-mail --with-mail_ssl_module
> --add-module=/tmp/buildd/nginx-0.8.53/modules/nginx-upstream-fair
> --add-module=/tmp/buildd/nginx-0.8.53/modules/nginx-echo
> 
> 
>         location /flv {
>                  root   /var/www/;
>                  try_files  /XXXXX$uri
>                             /YYYYY$uri
> 
>                             =404;
>                  internal;
>                  flv;
>                  output_buffers  1 1m;
> #                 aio on;
> #                 directio  4m;
> #                 set $limit_rate        256k;
> 
>          }
> 
> Нгинкс с аио:
> 
> # nginx -V
> nginx version: nginx/0.8.54
> TLS SNI support enabled
> configure arguments: --conf-path=/etc/nginx/nginx.conf
> --error-log-path=/var/log/nginx/error.log
> --http-client-body-temp-path=/var/lib/nginx/body
> --http-fastcgi-temp-path=/var/lib/nginx/fastcgi
> --http-log-path=/var/log/nginx/access.log
> --http-proxy-temp-path=/var/lib/nginx/proxy
> --http-scgi-temp-path=/var/lib/nginx/scgi
> --http-uwsgi-temp-path=/var/lib/nginx/uwsgi
> --lock-path=/var/lock/nginx.lock --pid-path=/var/run/nginx.pid
> --with-debug --with-file-aio --with-http_addition_module
> --with-http_dav_module --with-http_flv_module
> --with-http_geoip_module --with-http_gzip_static_module
> --with-http_image_filter_module --with-http_perl_module
> --with-http_random_index_module --with-http_realip_module
> --with-http_secure_link_module --with-http_stub_status_module
> --with-http_ssl_module --with-http_sub_module
> --with-http_xslt_module --with-ipv6 --with-sha1=/usr/include/openssl
> --with-md5=/usr/include/openssl --with-mail --with-mail_ssl_module --add-module=/build/buildd/nginx-0.8.54/debian/modules/nginx-development-kit --add-module=/build/buildd/nginx-0.8.54/debian/modules/nginx-upstream-fair
> --add-module=/build/buildd/nginx-0.8.54/debian/modules/nginx-echo
> --add-module=/build/buildd/nginx-0.8.54/debian/modules/nginx-lua --add-module=/build/buildd/nginx-0.8.54/debian/modules/nginx-push-0.692
> 
>         location /flv {
>                  root   /var/www/;
>                  try_files  /XXXXX$uri
>                             /YYYYY$uri
> 
>                             =404;
>                  internal;
>                  flv;
>                  output_buffers  1 1m;
>                  aio on;
>                  directio  4m;
> #                 set $limit_rate        256k;
> 
>          }
> 
> 
> В конфиге по сути добавилось 2 строчки:
>                  aio on;
>                  directio  4m;
> 
> Модулей кроме flv и proxy в конфиге никаких
> больше не использую.
>  По графикам видно, после пробела, когда было включено аио при тех
> же нагрузках стало больше потребляться памяти, почему?

На графиках мне видится плавно выросшая полка в ~ 4G.  Особенно 
она подозрительна в периоды минимальной нагрузки.  Теоретически 
конечно можно допустить, что в отсутствии необходимости (из-за 
directio) у приложений не забирают освобождённую память обратно в 
систему, но мне такое объяснение представляется сомнительным.

Для начала я бы раскомпилировал обратно сторонние модули.

Если картина сохранится - внимательно смотреть на предмет утечек 
сокетов.  В первую очередь - проверить наличие alert'ов в 
error_log, в частности - при выполнении reload'а.  Если найдутся, 
то действовать как описано тут:

http://wiki.nginx.org/Debugging#Socket_leaks

Maxim Dounin



Подробная информация о списке рассылки nginx-ru