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, potpuno opremljen i popularan HTTP i reverzni proxy server, mail proxy server i generički TCP/ UDP proxy server.
Nginx je dobro poznat po svojoj jednostavnoj konfiguraciji i maloj potrošnji resursa zbog svojih visokih performansi, koristi se za napajanje nekoliko web lokacija s velikim prometom, kao što je GitHub , SoundCloud, Dropbox, Netflix, WordPress i mnogi drugi.
Pročitajte također: 3 korisna haka koja svaki korisnik Linuxa mora znati
U ovom vodiču ćemo objasniti neke od najčešće korišćenih naredbi za upravljanje Nginx servisom koje biste, kao programer ili administrator sistema, trebali držati na dohvat ruke. Prikazaćemo komande za Systemd i SysVinit.
Sve ove sljedeće liste Nginx popularnih naredbi moraju se izvršiti kao root ili sudo korisnik i trebale bi raditi na bilo kojoj modernoj Linux distribuciji kao što je CentOS , RHEL, Debian, Ubuntu i Fedora.
Instalirajte Nginx server
Da instalirate Nginx web server, koristite svoj zadani upravitelj paketa za distribuciju 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 verziju Nginxa
Da biste provjerili verziju Nginx web servera instaliranog na vašem Linux sistemu, pokrenite sljedeću naredbu.
nginx -v
nginx version: nginx/1.12.2
Gornja naredba jednostavno prikazuje broj verzije. Ako želite da vidite verziju i konfigurišete 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 sintaksu Nginx konfiguracije
Prije nego što zapravo pokrenete uslugu Nginx, možete provjeriti da li je njena konfiguracijska sintaksa ispravna. Ovo je posebno korisno ako ste napravili promjene ili dodali novu konfiguraciju postojećoj strukturi konfiguracije.
Da testirate Nginx konfiguraciju, 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 Nginx konfiguraciju, izbaciti je i izaći koristeći -T
zastavicu 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 Nginx uslugu
Da pokrenete uslugu Nginx, pokrenite sljedeću naredbu. Imajte na umu da ovaj proces može propasti ako sintaksa konfiguracije nije OK.
sudo systemctl start nginx #systemd
OR
sudo service nginx start #sysvinit
Omogućite Nginx uslugu
Prethodna naredba samo pokreće uslugu u međuvremenu, da biste omogućili njeno automatsko pokretanje u vrijeme pokretanja, pokrenite sljedeću naredbu.
sudo systemctl enable nginx #systemd
OR
sudo service nginx enable #sysv init
Ponovo pokrenite Nginx uslugu
Da ponovo pokrenete uslugu Nginx, radnju koja će se zaustaviti, a zatim pokrenuti uslugu.
sudo systemctl restart nginx #systemd
OR
sudo service nginx restart #sysv init
Pogledajte status Nginx usluge
Status usluge Nginx možete provjeriti na sljedeći način. Ova naredba prikazuje informacije o statusu vremena izvršavanja usluge.
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.
Ponovo učitajte Nginx uslugu
Da kažete Nginxu da ponovo učita svoju konfiguraciju, koristite sljedeću naredbu.
sudo systemctl reload nginx #systemd
OR
sudo service nginx reload #sysvinit
Zaustavite Nginx uslugu
Ako želite da zaustavite uslugu Nginx iz jednog ili drugog razloga, koristite sljedeću naredbu.
sudo systemctl stop nginx #systemd
OR
sudo service nginx stop #sysvinit
Prikaži pomoć za Nginx komandu
Da dobijete jednostavan referentni vodič za sve Nginx komande 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
...
Možda biste željeli pročitati i ove sljedeće članke vezane za Nginx.
- Ultimativni vodič za osiguranje, ojačanje i poboljšanje performansi Nginx web servera
- Amplify – NGINX nadgledanje postalo jednostavno
- ngxtop – Nadgledanje Nginx log fajlova u realnom vremenu u Linuxu
- Kako instalirati Nginx s virtualnim hostovima i SSL certifikatom
- Kako sakriti verziju Nginx servera u Linuxu
To je sve za sada! U ovom vodiču smo objasnili neke od najčešće korištenih naredbi za upravljanje Nginx uslugama koje biste trebali znati, uključujući pokretanje, omogućavanje, ponovno pokretanje i zaustavljanje Nginxa. Ako imate bilo kakvih dodataka ili pitanja koja trebate postaviti, koristite obrazac za povratne informacije u nastavku.