10 najpogosteje uporabljenih ukazov Nginx, ki jih mora poznati vsak uporabnik Linuxa


Nginx (izgovorjen Engine x) je brezplačen, odprtokodni, visoko zmogljiv, prilagodljiv, zanesljiv, vsestranski in priljubljen strežnik HTTP in povratni strežnik proxy, poštni proxy strežnik in splošni strežnik proxy TCP/UDP.

Nginx je znan po svoji preprosti konfiguraciji in nizki porabi virov zaradi visoke zmogljivosti, zato se uporablja za napajanje več spletnih mest z velikim prometom, kot so GitHub, SoundCloud, Dropbox, Netflix, WordPress in številna druga.

V tem priročniku bomo razložili nekaj najpogosteje uporabljenih ukazov za upravljanje storitev Nginx, ki jih morate kot razvijalec ali sistemski skrbnik imeti pri roki. Prikazali bomo ukaze za Systemd in SysVinit.

Vsi naslednji seznami priljubljenih ukazov Nginx morajo biti izvedeni kot root ali sudo uporabniki in bi morali delovati na kateri koli sodobni distribuciji Linuxa, kot so CentOS, RHEL, Debian, Ubuntu in Fedora.

Namestite strežnik Nginx

Če želite namestiti spletni strežnik Nginx, uporabite privzetega upravitelja distribucijskih paketov, kot je prikazano.

$ sudo yum install epel-release && yum install nginx   [On CentOS/RHEL]
$ sudo dnf install nginx                               [On Debian/Ubuntu]
$ sudo apt install nginx                               [On Fedora]

Preverite različico Nginx

Če želite preveriti različico spletnega strežnika Nginx, nameščenega v sistemu Linux, zaženite naslednji ukaz.

$ nginx -v

nginx version: nginx/1.12.2

Zgornji ukaz preprosto prikaže številko različice. Če si želite ogledati različico in konfigurirati možnosti, uporabite zastavico -V , kot je prikazano.

$ nginx -V
nginx version: nginx/1.12.2
built by gcc 4.8.5 20150623 (Red Hat 4.8.5-16) (GCC) 
built with OpenSSL 1.0.2k-fips  26 Jan 2017
TLS SNI support enabled
configure arguments: --prefix=/usr/share/nginx --sbin-path=/usr/sbin/nginx --modules-path=/usr/lib64/nginx/modules --conf-path=/etc/nginx/nginx.conf --error-log-path=/var/log/nginx/error.log --http-log-path=/var/log/nginx/access.log --http-client-body-temp-path=/var/lib/nginx/tmp/client_body --http-proxy-temp-path=/var/lib/nginx/tmp/proxy --http-fastcgi-temp-path=/var/lib/nginx/tmp/fastcgi --http-uwsgi-temp-path=/var/lib/nginx/tmp/uwsgi --http-scgi-temp-path=/var/lib/nginx/tmp/scgi --pid-path=/run/nginx.pid --lock-path=/run/lock/subsys/nginx --user=nginx --group=nginx --with-file-aio --with-ipv6 --with-http_auth_request_module --with-http_ssl_module --with-http_v2_module --with-http_realip_module --with-http_addition_module --with-http_xslt_module=dynamic --with-http_image_filter_module=dynamic --with-http_geoip_module=dynamic --with-http_sub_module --with-http_dav_module --with-http_flv_module --with-http_mp4_module --with-http_gunzip_module --with-http_gzip_static_module --with-http_random_index_module --with-http_secure_link_module --with-http_degradation_module --with-http_slice_module --with-http_stub_status_module --with-http_perl_module=dynamic --with-mail=dynamic --with-mail_ssl_module --with-pcre --with-pcre-jit --with-stream=dynamic --with-stream_ssl_module --with-google_perftools_module --with-debug --with-cc-opt='-O2 -g -pipe -Wall -Wp,-D_FORTIFY_SOURCE=2 -fexceptions -fstack-protector-strong --param=ssp-buffer-size=4 -grecord-gcc-switches -specs=/usr/lib/rpm/redhat/redhat-hardened-cc1 -m64 -mtune=generic' --with-ld-opt='-Wl,-z,relro -specs=/usr/lib/rpm/redhat/redhat-hardened-ld -Wl,-E'

Preverite nastavitveno skladnjo Nginx

Preden dejansko zaženete storitev Nginx, lahko preverite, ali je njena konfiguracijska sintaksa pravilna. To je še posebej uporabno, če ste spremenili ali dodali novo konfiguracijo obstoječi konfiguracijski strukturi.

Če želite preizkusiti konfiguracijo Nginx, zaženite naslednji ukaz.

$ sudo nginx -t

nginx: the configuration file /etc/nginx/nginx.conf syntax is ok
nginx: configuration file /etc/nginx/nginx.conf test is successful

Konfiguracijo Nginx lahko preizkusite, jo izpustite in zaprete z zastavico -T , kot je prikazano.

$ sudo nginx -T
nginx: the configuration file /etc/nginx/nginx.conf syntax is ok
nginx: configuration file /etc/nginx/nginx.conf test is successful
# configuration file /etc/nginx/nginx.conf:
# For more information on configuration, see:
#   * Official English Documentation: http://nginx.org/en/docs/
#   * Official Russian Documentation: http://nginx.org/ru/docs/

user nginx;
worker_processes auto;
error_log /var/log/nginx/error.log;
pid /run/nginx.pid;

# Load dynamic modules. See /usr/share/nginx/README.dynamic.
include /usr/share/nginx/modules/*.conf;

events {
    worker_connections 1024;
}

http {
    log_format  main  '$remote_addr - $remote_user [$time_local] "$request" '
                      '$status $body_bytes_sent "$http_referer" '
                      '"$http_user_agent" "$http_x_forwarded_for"';

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

    sendfile            on;
    tcp_nopush          on;
    tcp_nodelay         on;
    keepalive_timeout   65;
    types_hash_max_size 2048;

    include             /etc/nginx/mime.types;
    default_type        application/octet-stream;

    # Load modular configuration files from the /etc/nginx/conf.d directory.
    # See http://nginx.org/en/docs/ngx_core_module.html#include
    # for more information.
    include /etc/nginx/conf.d/*.conf;

    server {
        listen       80 default_server;
        listen       [::]:80 default_server;
        server_name  _;
        root         /usr/share/nginx/html;

        # Load configuration files for the default server block.
        include /etc/nginx/default.d/*.conf;

        location / {
        }

        error_page 404 /404.html;
            location = /40x.html {
        }

        error_page 500 502 503 504 /50x.html;
            location = /50x.html {
        }
    }

....

Zaženite storitev Nginx

Če želite zagnati storitev Nginx, zaženite naslednji ukaz. Upoštevajte, da lahko ta postopek ne uspe, če konfiguracijska sintaksa ni v redu.

$ sudo systemctl start nginx #systemd
OR
$ sudo service nginx start   #sysvinit

Omogoči storitev Nginx

Prejšnji ukaz začasno zažene storitev, če želite omogočiti samodejni zagon ob zagonu, zaženite naslednji ukaz.

$ sudo systemctl enable nginx #systemd
OR
$ sudo service nginx enable   #sysv init

Znova zaženite storitev Nginx

Če želite znova zagnati storitev Nginx, dejanje, ki se ustavi in nato zažene storitev.

$ sudo systemctl restart nginx #systemd
OR
$ sudo service nginx restart   #sysv init

Oglejte si stanje storitve Nginx

Stanje storitve Nginx lahko preverite na naslednji način. Ta ukaz prikazuje informacije o stanju časa izvajanja storitve.

$ sudo systemctl status nginx #systemd
OR
$ sudo service nginx status   #sysvinit
Created symlink from /etc/systemd/system/multi-user.target.wants/nginx.service to /usr/lib/systemd/system/nginx.service.
 systemctl status nginx
● nginx.service - The nginx HTTP and reverse proxy server
   Loaded: loaded (/usr/lib/systemd/system/nginx.service; enabled; vendor preset: disabled)
   Active: active (running) since Tue 2019-03-05 05:27:15 EST; 2min 59s ago
 Main PID: 31515 (nginx)
   CGroup: /system.slice/nginx.service
           ├─31515 nginx: master process /usr/sbin/nginx
           └─31516 nginx: worker process

Mar 05 05:27:15 linux-console.net systemd[1]: Starting The nginx HTTP and reverse proxy server...
Mar 05 05:27:15 linux-console.net nginx[31509]: nginx: the configuration file /etc/nginx/nginx.conf syntax is ok
Mar 05 05:27:15 linux-console.net nginx[31509]: nginx: configuration file /etc/nginx/nginx.conf test is successful
Mar 05 05:27:15 linux-console.net systemd[1]: Failed to read PID from file /run/nginx.pid: Invalid argument
Mar 05 05:27:15 linux-console.net systemd[1]: Started The nginx HTTP and reverse proxy server.

Znova naložite storitev Nginx

Če želite Nginxu naročiti, naj znova naloži svojo konfiguracijo, uporabite naslednji ukaz.

$ sudo systemctl reload nginx #systemd
OR
$ sudo service nginx reload   #sysvinit

Ustavite storitev Nginx

Če želite iz katerega koli razloga ustaviti storitev Nginx, uporabite naslednji ukaz.

$ sudo systemctl stop nginx #systemd
OR
$ sudo service nginx stop   #sysvinit

Pokaži pomoč za ukaz Nginx

Če želite dobiti preprost referenčni vodnik za vse ukaze in možnosti Nginx, uporabite naslednji ukaz.

$ systemctl -h nginx
systemctl [OPTIONS...] {COMMAND} ...

Query or send control commands to the systemd manager.

  -h --help           Show this help
     --version        Show package version
     --system         Connect to system manager
  -H --host=[[email ]HOST
                      Operate on remote host
  -M --machine=CONTAINER
                      Operate on local container
  -t --type=TYPE      List units of a particular type
     --state=STATE    List units with particular LOAD or SUB or ACTIVE state
  -p --property=NAME  Show only properties by this name
  -a --all            Show all loaded units/properties, including dead/empty
                      ones. To list all units installed on the system, use
                      the 'list-unit-files' command instead.
  -l --full           Don't ellipsize unit names on output
  -r --recursive      Show unit list of host and local containers
     --reverse        Show reverse dependencies with 'list-dependencies'
     --job-mode=MODE  Specify how to deal with already queued jobs, when
                      queueing a new job
     --show-types     When showing sockets, explicitly show their type
  -i --ignore-inhibitors
...

Morda bi radi prebrali tudi te članke, povezane z Nginxom.

  1. Končni vodnik za varovanje, utrjevanje in izboljšanje delovanja spletnega strežnika Nginx
  2. Ojačanje - enostavno spremljanje NGINX
  3. ngxtop - Nadzirajte datoteke dnevnika Nginx v realnem času v Linuxu
  4. Kako namestiti Nginx z navideznimi gostitelji in potrdilom SSL
  5. Kako skriti različico strežnika Nginx v Linuxu

To je vse za zdaj! V tem priročniku smo razložili nekatere najpogosteje uporabljene ukaze za upravljanje storitev Nginx, ki jih morate poznati, vključno z zagonom, omogočanjem, ponovnim zagonom in ustavitvijo Nginxa. Če imate dodatke ali vprašanja, uporabite spodnji obrazec za povratne informacije.