10 dažniausiai naudojamų „Nginx“ komandų, kurias privalo žinoti kiekvienas „Linux“ vartotojas
„Nginx“ (tariamas „Engine x“) yra nemokamas, atviro kodo, didelio našumo, keičiamo dydžio, patikimas, visapusiškas ir populiarus HTTP ir atvirkštinis tarpinis serveris, pašto tarpinis serveris ir bendrasis TCP/UDP tarpinis serveris.
„Nginx“ yra gerai žinomas dėl savo paprastos konfigūracijos ir dėl mažo išteklių sunaudojimo dėl didelio našumo, jis naudojamas kelioms didelio srauto interneto svetainėms, tokioms kaip „GitHub“, „SoundCloud“, „Dropbox“, „Netflix“, „WordPress“ ir daugeliui kitų, valdyti.
Šiame vadove paaiškinsime keletą dažniausiai naudojamų „Nginx“ paslaugų valdymo komandų, kurias kaip kūrėjas ar sistemos administratorius turėtumėte laikyti ranka. Parodysime komandas tiek „Systemd“, tiek „SysVinit“.
Visi šie populiariausių „Nginx“ komandų sąrašai turi būti vykdomi kaip root arba sudo vartotojai ir turėtų veikti bet kuriame šiuolaikiniame „Linux“ paskirstyme, pvz., „CentOS“, „RHEL“, „Debian“, „Ubuntu“ ir „Fedora“.
Įdiekite „Nginx Server“
Norėdami įdiegti „Nginx“ žiniatinklio serverį, naudokite numatytąjį paskirstymo paketų tvarkyklę, kaip parodyta.
$ sudo yum install epel-release && yum install nginx [On CentOS/RHEL] $ sudo dnf install nginx [On Debian/Ubuntu] $ sudo apt install nginx [On Fedora]
Patikrinkite „Nginx“ versiją
Norėdami patikrinti „Linux“ sistemoje įdiegto „Nginx“ žiniatinklio serverio versiją, vykdykite šią komandą.
$ nginx -v nginx version: nginx/1.12.2
Pirmiau nurodyta komanda tiesiog parodo versijos numerį. Jei norite peržiūrėti versiją ir konfigūruoti parinktis, naudokite vėliavą -V
, kaip parodyta.
$ 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'
Patikrinkite „Nginx“ konfigūracijos sintaksę
Prieš pradėdami „Nginx“ paslaugą, galite patikrinti, ar jos konfigūravimo sintaksė yra teisinga. Tai ypač naudinga, jei pakeitėte esamą konfigūracijos struktūrą arba pridėjote naują konfigūraciją.
Norėdami išbandyti „Nginx“ konfigūraciją, vykdykite šią komandą.
$ sudo nginx -t nginx: the configuration file /etc/nginx/nginx.conf syntax is ok nginx: configuration file /etc/nginx/nginx.conf test is successful
Galite išbandyti „Nginx“ konfigūraciją, išmesti ją ir išeiti naudodamiesi vėliava -T
, kaip parodyta.
$ 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 { } } ....
Paleiskite „Nginx“ paslaugą
Norėdami paleisti „Nginx“ paslaugą, vykdykite šią komandą. Atminkite, kad šis procesas gali nepavykti, jei konfigūracijos sintaksė nėra tinkama.
$ sudo systemctl start nginx #systemd OR $ sudo service nginx start #sysvinit
Įgalinti „Nginx“ paslaugą
Ankstesnė komanda paleidžia paslaugą tik tuo metu, kad įjungtumėte automatinį paleidimą įkrovos metu, vykdykite šią komandą.
$ sudo systemctl enable nginx #systemd OR $ sudo service nginx enable #sysv init
Iš naujo paleiskite „Nginx“ paslaugą
Norėdami iš naujo paleisti „Nginx“ paslaugą, veiksmas bus sustabdytas ir paleistas.
$ sudo systemctl restart nginx #systemd OR $ sudo service nginx restart #sysv init
Peržiūrėkite „Nginx“ paslaugos būseną
„Nginx“ paslaugos būseną galite patikrinti taip. Ši komanda rodo paslaugos vykdymo laiko būsenos informaciją.
$ 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.
Perkraukite „Nginx“ paslaugą
Norėdami pasakyti „Nginx“ iš naujo įkelti savo konfigūraciją, naudokite šią komandą.
$ sudo systemctl reload nginx #systemd OR $ sudo service nginx reload #sysvinit
Sustabdyti „Nginx“ tarnybą
Jei norite sustabdyti „Nginx“ paslaugą dėl vienos ar kitos priežasties, naudokite šią komandą.
$ sudo systemctl stop nginx #systemd OR $ sudo service nginx stop #sysvinit
Rodyti „Nginx“ komandų žinyną
Norėdami gauti paprastą visų „Nginx“ komandų ir parinkčių vadovą, naudokite šią komandą.
$ 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 ...
Taip pat galbūt norėtumėte perskaityti šiuos su „Nginx“ susijusius straipsnius.
- Pagrindinis „Nginx“ tinklo serverio saugos, grūdinimo ir našumo gerinimo vadovas
- Sustiprinti - lengva atlikti „NGINX“ stebėjimą
- ngxtop - Stebėkite „Nginx“ žurnalo failus realiuoju laiku sistemoje „Linux“
- Kaip įdiegti „Nginx“ su virtualiais kompiuteriais ir SSL sertifikatu
- Kaip paslėpti „Nginx“ serverio versiją sistemoje „Linux“
Tai kol kas viskas! Šiame vadove paaiškinome keletą dažniausiai naudojamų „Nginx“ paslaugų valdymo komandų, kurias turėtumėte žinoti, įskaitant „Nginx“ paleidimą, įgalinimą, iš naujo paleidimą ir sustabdymą. Jei turite kokių nors papildymų ar klausimų, naudokite toliau pateiktą atsiliepimų formą.