Ответы:
nginx -V
перечислит все настроенные модули. Нет явной команды включения / загрузки.
sudo nginx -V
sudo
на Ubuntu 14.04
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
флаги и просто сосредоточился на получении списка модулей, поэтому я не уловил этого; однострочник может быть изменен, чтобы помочь разным флагам компиляции между двумя установками, например так:
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')
Мессье, но это работает.
2>&1 nginx -V | tr -- - '\n' | grep _module
Команда полностью неверна, так как в ней перечислены без- * опций, как установлено!
Команда 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
настроек, вам может потребоваться указать полный путь, например /usr/sbin/nginx -V
, или использовать его sudo
для включения соответствующего /sbin/
каталога в $PATH
.
Начиная с более новых выпусков nginx - начиная с nginx 1.9.11
(февраль 2016 г.) - теперь также поддерживаются динамически загружаемые модули - http://nginx.org/r/load_module - с помощью load_module
директивы.