Назад | Перейти на главную страницу

Как я могу увидеть, с какими флагами был скомпилирован Nginx?

Как я могу проверить, какие модули были добавлены в установку nginx?

nginx -V отобразит все настроенные модули. Нет явной команды включения / загрузки.

Дифференциальный однострочный:

2>&1 nginx -V | tr -- - '\n' | grep _module

Удобно для сравнения двух сред:

lsmodn="2>&1 nginx -V | tr -- - '\n' | grep _module"
diff -y <(ssh www-prd eval $lsmodn) <(ssh www-qa eval $lsmodn)

РЕДАКТИРОВАТЬ:

Спасибо, Роман Ньюаза, за то, что правильно указал, что это включает --without флаги компиляции модуля. Я не использую --without flags и просто сосредоточился на получении списка модулей, поэтому я этого не уловил; однострочник может быть изменен, чтобы помочь разнице в компиляции флагов между двумя установками, например:

2>&1 nginx -V | tr ' '  '\n'

что то же самое, что:

2>&1 nginx -V | xargs -n1

Может также пропустить это через sort чтобы нормализовать идиосинкразический порядок флагов компиляции и tr снова, чтобы разделить назначения на разные строки. Конечный результат:

lsmodn="2>&1 nginx -V | xargs -n1 | sort | tr = '\n'"
diff -y <(ssh www-prd eval $lsmodn) <(ssh www-qa eval $lsmodn)

Это работает, если sort ведет себя одинаково на обоих удаленных хостах (т. е. они оба GNU или BSD). Если вы сравниваете Linux с BSD (Mac OS X), просто переместите | sort | tr = '\n' кусок из lsmodn в локальную оболочку, где sort будет последовательным:

lsmodn="2>&1 nginx -V | xargs -n1"
diff -y <(ssh linux eval $lsmodn | sort | tr = '\n') <(ssh macosx eval $lsmodn  | sort | tr = '\n')

Мессье, но это работает.

  • В nginx -V команда (верхний регистр V) перечислит все модули, а также другие параметры времени компиляции:

    %nginx -V nginx version: nginx/1.2.2 built by gcc 4.2.1 20070719 TLS SNI support enabled configure arguments: --prefix=/var/www --conf-path=/etc/nginx/nginx.conf --sbin-path=/usr/sbin/nginx --pid-path=/var/run/nginx.pid --lock-path=/var/run/nginx.lock --http-log-path=logs/access.log --error-log-path=logs/error.log --http-client-body-temp-path=/var/www/cache/client_body_temp --http-proxy-temp-path=/var/www/cache/proxy_temp --http-fastcgi-temp-path=/var/www/cache/fastcgi_temp --http-scgi-temp-path=/var/www/cache/scgi_temp --http-uwsgi-temp-path=/var/www/cache/uwsgi_temp --user=www --group=www --with-http_gzip_static_module --with-http_ssl_module --with-http_stub_status_module --with-ipv6 --without-mail_pop3_module --without-mail_imap_module --without-mail_smtp_module %

    Обратите внимание, что в этом нет необходимости sudo для этой команды, поскольку полномочия суперпользователя понадобятся nginx только для открытия портов ниже IPPORT_RESERVED (например, порты ниже 1024) и / или определенные файлы журналов для записи.

    Однако в зависимости от вашего $PATH settings, вам может потребоваться указать полный путь - например, /usr/sbin/nginx -V, или действительно использовать sudo за наличие соответствующих /sbin/ каталог будет включен в $PATH.

  • Начиная с более новых выпусков nginx - поскольку nginx 1.9.11 (Февраль 2016) - добавлена ​​поддержка динамически загружаемых модулей, слишком - http://nginx.org/r/load_module - с помощью load_module директива.

nginx -V показывает не все модули, мне показывает около 20 модулей.

я использую strings /usr/sbin/nginx|grep _module|grep -v configure| sort в котором перечислены все 200+ модулей в моем nginx.

Я тоже пробовал objdump но похоже, что у nginx в моей установке двоичный файл был удален.