Sett opp Cacti på Debian Jessie
Introduksjon Cacti er et åpen kildekode overvåkings- og grafverktøy som er fullt basert på RRD-data. Gjennom Cacti kan du overvåke nesten alle typer enheter
Introduksjon
Nginx er en åpen kildekode-webserverprogramvare designet med høy samtidighet i tankene, som kan brukes som en HTTP/HTTPS-server, omvendt proxy-server, e-postproxy-server, programvarebelastningsbalanser, TLS-terminator, caching-server og mer!
Det er en svært modulær programvare. Selv noen av de tilsynelatende "innebygde" delene av programvaren, som GZIP eller SSL, er faktisk laget som moduler som kan aktiveres og deaktiveres i løpet av byggetiden.
Den har kjernemoduler (innfødte) og tredjeparts (eksterne) moduler laget av fellesskapet. Akkurat nå er det over hundre tredjepartsmoduler som vi kan bruke.
Skrevet i C, det er en rask og lett programvare.
Å installere Nginx fra kildekoden er relativt enkelt - last ned den nyeste versjonen av Nginx-kildekoden, konfigurer, bygg og installer den.
Du må velge om du vil laste ned hovedlinjen eller en stabil versjon, men å bygge dem er det samme.
I denne veiledningen vil vi kompilere en hovedversjon av Nginx på Debian 10 (buster). Vi vil bruke alle tilgjengelige moduler i åpen kildekode-versjonen av Nginx.
Hvorfor kompilere og installere Nginx fra kilden
Du spør sannsynligvis hvorfor man kompilerer Nginx fra en kilde når du kan bruke forberedte pakker. Her er noen grunner til at du kanskje vil kompilere spesifikk programvare selv:
Stabil vs. hovedlinjeversjon
Nginx Open Source er tilgjengelig i to versjoner:
Kjernemoduler kontra tredjepartsmoduler
Nginx har to typer moduler som du kan bruke: kjernemoduler og tredjepartsmoduler.
Kjerne Nginx-utviklerne bygger kjernemoduler, og de er en del av selve programvaren.
Fellesskapet bygger tredjepartsmoduler, og du kan bruke dem til å utvide funksjonaliteten. Det er mange nyttige tredjepartsmoduler.
Statiske moduler vs. dynamiske moduler
Statiske moduler finnes i Nginx fra den aller første versjonen. Dynamiske moduler ble introdusert med Nginx 1.9.11+ i februar 2016.
Med statiske moduler fikseres et sett med moduler som utgjør en Nginx-binær ved kompilering av ./configure
skriptet. Statiske moduler bruk --with-foo_bar_module
eller --add-module=PATH
syntaks.
For å kompilere en kjernemodul (standard) som dynamisk legger vi til =dynamic
for eksempel --with-http_image_filter_module=dynamic
.
For å kompilere en tredjepartsmodul som dynamisk bruker vi --add-dynamic-module=/path/to/module
syntaks, og deretter laster vi dem ved å bruke load_module
direktivet i den globale konteksten til nginx.conf
filen.
Krav for å bygge Nginx fra kilden
Sammenlignet med annen UNIX/Linux-programvare er Nginx ganske lett og har ikke mange bibliotekavhengigheter. Standard byggekonfigurasjon avhenger av kun 3 biblioteker som skal installeres: OpenSSL/LibreSSL/BoringSSL, Zlib og PCRE.
1.0.2
- 1.1.1
eller LibreSSL- bibliotek eller BoringSSL- bibliotek1.1.3
-1.2.11
4.4
-8.43
MERK : Nginx kan også kompileres mot LibreSSL og BoringSSL kryptobiblioteker i stedet for OpenSSL.
Før du begynner
Sjekk Debian-versjonen.
lsb_release -ds # Debian GNU/Linux 10 (buster)
Opprett en vanlig bruker med sudo
tilgang.
adduser johndoe --gecos "John Doe" usermod -aG sudo johndoe
MERK : Erstatt johndoe
med brukernavnet ditt .
Bytt til en ny bruker.
su - johndoe
Sett opp tidssonen.
sudo dpkg-reconfigure tzdata
Oppdater operativsystemets programvare.
sudo apt update && sudo apt upgrade -y
Installer de nødvendige pakkene.
sudo apt install -y software-properties-common ufw
Bygg Nginx fra kilden
Nginx er et program skrevet i C, så du må først installere et kompilatorverktøy. Installere build-essential
, git
og tree
.
sudo apt install -y build-essential git tree
Last ned den siste hovedversjonen av Nginx-kildekoden og pakk ut kildekodearkivet. Nginx-kildekoden distribueres som et komprimert arkiv, som de fleste Unix- og Linux-programvare.
wget https://nginx.org/download/nginx-1.17.2.tar.gz && tar zxvf nginx-1.17.2.tar.gz
Last ned de obligatoriske Nginx-avhengighetenes kildekode og pakk den ut.
# PCRE version 8.43 wget https://ftp.pcre.org/pub/pcre/pcre-8.43.tar.gz && tar xzvf pcre-8.43.tar.gz # zlib version 1.2.11 wget https://www.zlib.net/zlib-1.2.11.tar.gz && tar xzvf zlib-1.2.11.tar.gz # OpenSSL version 1.1.1c wget https://www.openssl.org/source/openssl-1.1.1c.tar.gz && tar xzvf openssl-1.1.1c.tar.gz
Installer valgfrie Nginx-avhengigheter.
sudo apt install -y perl libperl-dev libgd3 libgd-dev libgeoip1 libgeoip-dev geoip-bin libxml2 libxml2-dev libxslt1.1 libxslt1-dev
Rydd opp i alle .tar.gz
filer. Vi trenger dem ikke lenger.
rm -rf *.tar.gz
Gå inn i Nginx-kildekatalogen.
cd ~/nginx-1.17.2
For god mål liste kataloger og filer som komponerer Nginx kildekode med tree
.
tree -L 2 .
Kopier manualsiden til /usr/share/man/man8/
.
sudo cp ~/nginx-1.17.2/man/nginx.8 /usr/share/man/man8 sudo gzip /usr/share/man/man8/nginx.8 ls /usr/share/man/man8/ | grep nginx.8.gz # Check that man page for Nginx is working man nginx
For hjelp kan du se en fullstendig liste over oppdaterte Nginx kompileringstidsalternativer ved å kjøre følgende.
./configure --help # To see want core modules can be built as dynamic run: ./configure --help | grep -F =dynamic
Konfigurer, kompiler og installer Nginx.
./configure --prefix=/etc/nginx \ --sbin-path=/usr/sbin/nginx \ --modules-path=/usr/lib/nginx/modules \ --conf-path=/etc/nginx/nginx.conf \ --error-log-path=/var/log/nginx/error.log \ --pid-path=/var/run/nginx.pid \ --lock-path=/var/run/nginx.lock \ --user=nginx \ --group=nginx \ --build=Debian \ --builddir=nginx-1.17.2 \ --with-select_module \ --with-poll_module \ --with-threads \ --with-file-aio \ --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_auth_request_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-perl_modules_path=/usr/share/perl/5.26.1 \ --with-perl=/usr/bin/perl \ --http-log-path=/var/log/nginx/access.log \ --http-client-body-temp-path=/var/cache/nginx/client_temp \ --http-proxy-temp-path=/var/cache/nginx/proxy_temp \ --http-fastcgi-temp-path=/var/cache/nginx/fastcgi_temp \ --http-uwsgi-temp-path=/var/cache/nginx/uwsgi_temp \ --http-scgi-temp-path=/var/cache/nginx/scgi_temp \ --with-mail=dynamic \ --with-mail_ssl_module \ --with-stream=dynamic \ --with-stream_ssl_module \ --with-stream_realip_module \ --with-stream_geoip_module=dynamic \ --with-stream_ssl_preread_module \ --with-compat \ --with-pcre=../pcre-8.43 \ --with-pcre-jit \ --with-zlib=../zlib-1.2.11 \ --with-openssl=../openssl-1.1.1c \ --with-openssl-opt=no-nextprotoneg \ --with-debug make sudo make install
Etter kompileringen, naviger til hjemmekatalogen ( ~
).
cd ~
Symbolkobling /usr/lib/nginx/modules
til /etc/nginx/modules
. Dette er et standardsted for Nginx-moduler.
sudo ln -s /usr/lib/nginx/modules /etc/nginx/modules
Skriv ut Nginx-versjonen, kompilatorversjonen og konfigurer skriptparametere.
sudo nginx -V # nginx version: nginx/1.17.2 (Debian) # built by gcc 8.3.0 (Debian 8.3.0-6) # built with OpenSSL 1.1.1c 28 May 2019 # TLS SNI support enabled # configure arguments: --prefix=/etc/nginx --sbin-path=/usr/sbin/nginx --modules-path=/usr/lib/nginx/modules . . . # . . . # . . .
Opprett en Nginx-systemgruppe og bruker.
sudo adduser --system --home /nonexistent --shell /bin/false --no-create-home --disabled-login --disabled-password --gecos "nginx user" --group nginx # Check that user and group are created sudo tail -n 1 /etc/passwd /etc/group /etc/shadow
Sjekk Nginx-syntaks og potensielle feil.
sudo nginx -t # Will throw this error -> nginx: [emerg] mkdir() "/var/cache/nginx/client_temp" failed (2: No such file or directory) # Create NGINX cache directories and set proper permissions sudo mkdir -p /var/cache/nginx/client_temp /var/cache/nginx/fastcgi_temp /var/cache/nginx/proxy_temp /var/cache/nginx/scgi_temp /var/cache/nginx/uwsgi_temp sudo chmod 700 /var/cache/nginx/* sudo chown nginx:root /var/cache/nginx/* # Re-check syntax and potential errors. sudo nginx -t
Opprett en Nginx systemd enhetsfil.
sudo vim /etc/systemd/system/nginx.service
Fyll /etc/systemd/system/nginx.service
filen med følgende innhold.
[Unit] Description=nginx - high performance web server Documentation=https://nginx.org/en/docs/ After=network-online.target remote-fs.target nss-lookup.target Wants=network-online.target [Service] Type=forking PIDFile=/var/run/nginx.pid ExecStartPre=/usr/sbin/nginx -t -c /etc/nginx/nginx.conf ExecStart=/usr/sbin/nginx -c /etc/nginx/nginx.conf ExecReload=/bin/kill -s HUP $MAINPID ExecStop=/bin/kill -s TERM $MAINPID [Install] WantedBy=multi-user.target
Aktiver Nginx for å starte ved oppstart og start Nginx umiddelbart.
sudo systemctl enable nginx.service sudo systemctl start nginx.service
Sjekk om Nginx vil starte automatisk etter en omstart.
sudo systemctl is-enabled nginx.service # enabled
Sjekk statusen.
sudo systemctl status nginx.service
MERK : Du kan bekrefte at Nginx kjører ved å gå til nettstedets domene eller IP-adresse i en nettleser. Du vil se Nginx-velkomstsiden. Det er en indikator på at Nginx er oppe og kjører på din VPS.
Opprett en UFW Nginx-applikasjonsprofil.
sudo vim /etc/ufw/applications.d/nginx
Kopier/lim inn følgende innhold i /etc/ufw/applications.d/nginx
filen.
[Nginx HTTP] title=Web Server (Nginx, HTTP) description=Small, but very powerful and efficient web server ports=80/tcp [Nginx HTTPS] title=Web Server (Nginx, HTTPS) description=Small, but very powerful and efficient web server ports=443/tcp [Nginx Full] title=Web Server (Nginx, HTTP + HTTPS) description=Small, but very powerful and efficient web server ports=80,443/tcp
Bekreft at UFW-applikasjonsprofiler er opprettet og gjenkjent.
sudo ufw app list # Available applications: # Nginx Full # Nginx HTTP # Nginx HTTPS # OpenSSH
Nginx genererer som standard sikkerhetskopifiler .default
i /etc/nginx
. Fjern .default
filer fra /etc/nginx
katalogen.
sudo rm /etc/nginx/*.default
Plasser syntaksutheving av Nginx-konfigurasjon for Vim-redigering i ~/.vim
.
# For regular non-root user mkdir ~/.vim/ cp -r ~/nginx-1.17.2/contrib/vim/* ~/.vim/ # For root user sudo mkdir /root/.vim/ sudo cp -r ~/nginx-1.17.2/contrib/vim/* /root/.vim/
MERK : Ved å gjøre trinnet ovenfor vil du få en fin syntaksutheving når du redigerer Nginx-konfigurasjonsfiler i Vim editor.
Lag conf.d
, snippets
, sites-available
og sites-enabled
kataloger i /etc/nginx
.
sudo mkdir /etc/nginx/{conf.d,snippets,sites-available,sites-enabled}
Endre tillatelser og gruppeeierskap for Nginx-loggfiler.
sudo chmod 640 /var/log/nginx/* sudo chown nginx:adm /var/log/nginx/access.log /var/log/nginx/error.log
Opprett en loggrotasjonskonfigurasjon for Nginx.
sudo vim /etc/logrotate.d/nginx
Fyll filen med følgende tekst, lagre og avslutt.
/var/log/nginx/*.log { daily missingok rotate 52 compress delaycompress notifempty create 640 nginx adm sharedscripts postrotate if [ -f /var/run/nginx.pid ]; then kill -USR1 `cat /var/run/nginx.pid` fi endscript }
Fjern alle nedlastede filer fra hjemmekatalogen.
cd ~ rm -rf nginx-1.17.2/ openssl-1.1.1c/ pcre-8.43/ zlib-1.2.11/
Sammendrag
Det er det. Nå har du den nyeste versjonen av Nginx installert. Den er kompilert statisk mot noen viktige biblioteker som OpenSSL. Ofte er den systemleverte versjonen av OpenSSL utdatert. Ved å bruke denne metoden for å installere med en nyere versjon av OpenSSL, kan du dra nytte av moderne chiffer som CHACHA20_POLY1305
og protokoller som TLS 1.3 som er tilgjengelige i OpenSSL 1.1.1
. Dessuten, ved å kompilere din egen binærfil, kan du skreddersy hvilken funksjonalitet din Nginx vil gi, noe som er mye mer fleksibelt enn å installere en forhåndsbygd binær.
Introduksjon Cacti er et åpen kildekode overvåkings- og grafverktøy som er fullt basert på RRD-data. Gjennom Cacti kan du overvåke nesten alle typer enheter
Bruker du et annet system? Denne opplæringen viser deg hvordan du installerer gruppevaren iRedMail på en ny installasjon av Debian Wheezy. Du bør bruke en serve
Bruker du et annet system? Hvis du kjøper en Debian-server, bør du alltid ha de nyeste sikkerhetsoppdateringene og oppdateringene, enten du sover eller ikke
Denne opplæringen forklarer hvordan du setter opp en DNS-server ved å bruke Bind9 på Debian eller Ubuntu. Bytt ut ditt-domenenavn.com gjennom hele artikkelen. På th
I denne artikkelen vil vi se hvordan du kompilerer og installerer Nginx mainline fra de offisielle kildene til Nginx med PageSpeed-modulen, som lar deg t
Bruker du et annet system? Introduksjon Kanboard er et gratis og åpen kildekodeprogram for prosjektledelse som er designet for å forenkle og visualisere
Bruker du et annet system? Gitea er et alternativt åpen kildekode, selvdrevet versjonskontrollsystem drevet av Git. Gitea er skrevet på Golang og er
Introduksjon Lynis er et gratis systemrevisjonsverktøy med åpen kildekode som brukes av mange systemadministratorer for å verifisere integriteten og herde systemene deres. Jeg
Bruker du et annet system? Thelia er et åpen kildekodeverktøy for å lage e-business-nettsteder og administrere nettinnhold skrevet i PHP. Thelia kildekode i
Hva du trenger En Vultr VPS med minst 1 GB RAM. SSH-tilgang (med root/administratorrettigheter). Trinn 1: Installere BungeeCord Først
Golang er et programmeringsspråk utviklet av Google. Takket være sin allsidighet, enkelhet og pålitelighet har Golang blitt en av de mest populære
Hvis du har glemt MySQL root-passordet ditt, kan du tilbakestille det ved å følge trinnene i denne artikkelen. Prosessen er ganske enkel og fungerer på disse
Det er tider når vi trenger å dele filer som må være synlige for Windows-klienter. Siden Fuse-baserte systemer bare fungerer på Linux, bør du introdusere
I denne veiledningen skal vi sette opp en Counter Strike: Source-spillserver på Debian 7. Disse kommandoene ble testet på Debian 7, men de bør også fungere o
I denne veiledningen lærer du hvordan du setter opp en Unturned 2.2.5-server på en Vultr VPS som kjører Debian 8. Merk: Dette er en redigert versjon av Unturned som ikke
I denne opplæringen lærer du hvordan du installerer Cachet på Debian 8. Cachet er et kraftig åpen kildekode-statussidesystem. Installasjon Denne opplæringen er i gang
Introduksjon I denne artikkelen kan du gå gjennom hvordan du sikkerhetskopierer flere MySQL- eller MariaDB-databaser som sitter på samme maskin ved hjelp av et tilpasset bash-skript
Denne artikkelen vil lære deg hvordan du setter opp et chroot-fengsel på Debian. Jeg antar at du bruker Debian 7.x. Hvis du kjører Debian 6 eller 8, kan dette fungere, men
Bruker du et annet system? Reader Self 3.5 er en enkel og fleksibel, gratis og åpen kildekode, selvhostet RSS-leser og Google Reader-alternativ. Leser Sel
Bruker du et annet system? Backdrop CMS 1.8.0 er et enkelt og fleksibelt, mobilvennlig, gratis og åpen kildekode Content Management System (CMS) som lar oss
Kunstig intelligens er ikke i fremtiden, det er her akkurat i nåtiden I denne bloggen Les hvordan kunstig intelligens-applikasjoner har påvirket ulike sektorer.
Er du også et offer for DDOS-angrep og forvirret over forebyggingsmetodene? Les denne artikkelen for å løse spørsmålene dine.
Du har kanskje hørt at hackere tjener mye penger, men har du noen gang lurt på hvordan tjener de den slags penger? la oss diskutere.
Vil du se revolusjonerende oppfinnelser fra Google og hvordan disse oppfinnelsene forandret livet til alle mennesker i dag? Les deretter til bloggen for å se oppfinnelser fra Google.
Konseptet med selvkjørende biler som skal ut på veiene ved hjelp av kunstig intelligens er en drøm vi har hatt en stund nå. Men til tross for flere løfter, er de ingen steder å se. Les denne bloggen for å lære mer...
Ettersom vitenskapen utvikler seg raskt og tar over mye av innsatsen vår, øker også risikoen for å utsette oss for en uforklarlig singularitet. Les hva singularitet kan bety for oss.
Lagringsmetodene for dataene har vært i utvikling kan være siden fødselen av dataene. Denne bloggen dekker utviklingen av datalagring på grunnlag av en infografikk.
Les bloggen for å kjenne ulike lag i Big Data Architecture og deres funksjoner på den enkleste måten.
I denne digitaldrevne verden har smarthusenheter blitt en avgjørende del av livet. Her er noen fantastiske fordeler med smarthusenheter om hvordan de gjør livet vårt verdt å leve og enklere.
Nylig lanserte Apple macOS Catalina 10.15.4 en tilleggsoppdatering for å fikse problemer, men det ser ut til at oppdateringen forårsaker flere problemer som fører til muring av mac-maskiner. Les denne artikkelen for å lære mer