10 najčešće korištenih Nginx naredbi koje svaki korisnik Linuxa mora znati
Nginx (izgovara se Engine x) je besplatan, otvorenog koda, visokih performansi, skalabilan, pouzdan, pun značajki i popularan HTTP i obrnuti proxy poslužitelj, proxy poslužitelj e-pošte i generički TCP/ UDP proxy poslužitelj.
Nginx dobro je poznat po svojoj jednostavnoj konfiguraciji i maloj potrošnji resursa zbog svojih visokih performansi, a koristi se za pokretanje nekoliko web stranica s velikim prometom, kao što je GitHub , SoundCloud, Dropbox, Netflix, WordPress i mnogi drugi.
Pročitajte također: 3 korisna hacka koja svaki korisnik Linuxa mora znati
U ovom ćemo vodiču objasniti neke od najčešće korištenih naredbi za upravljanje uslugama Nginxa koje biste, kao programer ili administrator sustava, trebali imati na dohvat ruke. Prikazat ćemo naredbe za Systemd i SysVinit.
Svi ovi sljedeći popisi Nginx popularnih naredbi moraju se izvoditi kao root ili sudo korisnik i trebaju raditi na bilo kojoj modernoj distribuciji Linuxa kao što je CentOS , RHEL, Debian, Ubuntu i Fedora.
Instalirajte Nginx poslužitelj
Da biste instalirali web poslužitelj Nginx, upotrijebite zadani upravitelj paketa distribucije kao što je prikazano.
sudo yum install epel-release && yum install nginx [On CentOS/RHEL]
sudo dnf install nginx [On Fedora]
sudo apt install nginx [On Debian/Ubuntu]
Provjerite Nginx verziju
Da biste provjerili verziju Nginx web poslužitelja instaliranu na vašem Linux sustavu, pokrenite sljedeću naredbu.
nginx -v
nginx version: nginx/1.12.2
Gornja naredba jednostavno prikazuje broj verzije. Ako želite vidjeti verziju i konfigurirati opcije, koristite oznaku -V
kao što 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'
Provjerite Nginx konfiguracijsku sintaksu
Prije nego što stvarno pokrenete uslugu Nginx, možete provjeriti je li njezina konfiguracijska sintaksa ispravna. Ovo je posebno korisno ako ste napravili promjene ili dodali novu konfiguraciju postojećoj strukturi konfiguracije.
Za testiranje Nginx konfiguracije, pokrenite sljedeću naredbu.
sudo nginx -t
nginx: the configuration file /etc/nginx/nginx.conf syntax is ok
nginx: configuration file /etc/nginx/nginx.conf test is successful
Možete testirati konfiguraciju Nginx, ispisati je i izaći pomoću oznake -T
kao što 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 {
}
}
....
Pokrenite uslugu Nginx
Za pokretanje usluge Nginx pokrenite sljedeću naredbu. Imajte na umu da ovaj proces možda neće uspjeti ako sintaksa konfiguracije nije OK.
sudo systemctl start nginx #systemd
OR
sudo service nginx start #sysvinit
Omogući uslugu Nginx
Prethodna naredba pokreće uslugu samo u međuvremenu, da biste omogućili njezino automatsko pokretanje tijekom pokretanja, pokrenite sljedeću naredbu.
sudo systemctl enable nginx #systemd
OR
sudo service nginx enable #sysv init
Ponovno pokrenite uslugu Nginx
Za ponovno pokretanje usluge Nginx, radnja koja će zaustaviti i zatim pokrenuti uslugu.
sudo systemctl restart nginx #systemd
OR
sudo service nginx restart #sysv init
Pogledajte status usluge Nginx
Status usluge Nginx možete provjeriti na sljedeći način. Ova naredba prikazuje informacije o statusu usluge u vremenu izvođenja.
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.
[root@tecmint ~]# 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.
Ponovno učitajte uslugu Nginx
Da biste rekli Nginx-u da ponovno učita svoju konfiguraciju, koristite sljedeću naredbu.
sudo systemctl reload nginx #systemd
OR
sudo service nginx reload #sysvinit
Zaustavite uslugu Nginx
Ako želite zaustaviti uslugu Nginx iz jednog ili drugog razloga, upotrijebite sljedeću naredbu.
sudo systemctl stop nginx #systemd
OR
sudo service nginx stop #sysvinit
Prikaži pomoć za Nginx naredbe
Da biste dobili jednostavan referentni vodič za sve Nginx naredbe i opcije, koristite sljedeću naredbu.
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=[USER@]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
...
Također biste mogli pročitati sljedeće članke vezane uz Nginx.
- Vrhunski vodič za osiguranje, jačanje i poboljšanje performansi Nginx web poslužitelja
- Pojačajte – NGINX praćenje postalo jednostavno
- ngxtop – Pratite Nginx log datoteke u stvarnom vremenu u Linuxu
- Kako instalirati Nginx s virtualnim hostovima i SSL certifikatom
- Kako sakriti verziju Nginx poslužitelja u Linuxu
To je sve za sada! U ovom smo vodiču objasnili neke od najčešće korištenih naredbi za upravljanje uslugom Nginx koje biste trebali znati, uključujući pokretanje, omogućavanje, ponovno pokretanje i zaustavljanje Nginxa. Ako imate dodatnih pitanja ili pitanja, upotrijebite obrazac za povratne informacije u nastavku.