Opsæt Cacti på Debian Jessie
Introduktion Cacti er et open source overvågnings- og grafværktøj, som er fuldt baseret på RRD-data. Gennem Cacti kan du overvåge næsten enhver type enhed
Brotli (br) er en ny open source-komprimeringsalgoritme, udviklet af Google som et alternativ til Gzip, Zopfli og Deflate. Det er formelt defineret i Internet Engineering Task Force (IETF) som RFC 7932 . Googles casestudie om Brotli har vist kompressionsforhold på op til 26 % mindre end nuværende metoder med mindre CPU-forbrug.
Nginx har ikke officiel support, men der er et tredjepartsmodul udviklet af Google kaldet ngx_brotli, som vi kan bruge til at tilføje support til Nginx.
Denne vejledning viser dig, hvordan du tilføjer Brotli-understøttelse til Nginx på en ny Ubuntu 18.04 LTS Vultr-instans.
BEMÆRK: Denne vejledning bruges johndoe
som eksempelbruger og example.com
eksempeldomæne. Udskift dem i henhold til dine navne.
A
/ AAAA
records opsatTjek Ubuntu-versionen.
lsb_release -ds
# Ubuntu 18.04 LTS
Opret en ny non-root
brugerkonto med sudo
adgang og skift til den.
adduser johndoe --gecos "John Doe"
usermod -aG sudo johndoe
su - johndoe
BEMÆRK : Erstat johndoe
med dit brugernavn .
Opdater dit operativsystems software.
sudo apt update && sudo apt upgrade -y
Indstil tidszonen.
sudo dpkg-reconfigure tzdata
Installer nødvendige byggeværktøjer og pakker.
sudo apt install -y build-essential git apt-transport-https socat
Brotli kræver, at du opsætter og bruger HTTPS. I denne del får vi et betroet certifikat fra Let's Encrypt.
Download og installer Acme.sh.
sudo mkdir /etc/letsencrypt
git clone https://github.com/Neilpang/acme.sh.git
cd acme.sh
sudo ./acme.sh --install --home /etc/letsencrypt --accountemail [email protected]
cd ~
source ~/.bashrc
Tjek versionen.
acme.sh --version
# v2.8.0
Få RSA- og ECDSA-certifikater for example.com
.
# RSA 2048
sudo /etc/letsencrypt/acme.sh --issue --standalone --home /etc/letsencrypt -d example.com --accountemail [email protected] --ocsp-must-staple --keylength 2048
# ECDSA/ECC P-256
sudo /etc/letsencrypt/acme.sh --issue --standalone --home /etc/letsencrypt -d example.com --accountemail [email protected] --ocsp-must-staple --keylength ec-256
Efter at have kørt kommandoerne ovenfor, vil dine certifikater og nøgler være på følgende steder:
/etc/letsencrypt/example.com
/etc/letsencrypt/example.com_ecc
Download og installer den seneste mainline Nginx fra den officielle Nginx-repo.
wget https://nginx.org/keys/nginx_signing.key
sudo apt-key add nginx_signing.key
rm nginx_signing.key
sudo -s
printf "deb https://nginx.org/packages/mainline/ubuntu/ `lsb_release -sc` nginx \ndeb-src https://nginx.org/packages/mainline/ubuntu/ `lsb_release -sc` nginx \n" >> /etc/apt/sources.list.d/nginx_mainline.list
exit
sudo apt update
sudo apt install -y nginx nginx-module-geoip nginx-module-image-filter nginx-module-njs nginx-module-perl nginx-module-xslt
Tjek versionen.
sudo nginx -v
# nginx version: nginx/1.15.2
Aktiver og start Nginx.
sudo systemctl enable nginx.service
sudo systemctl start nginx.service
Efter at have installeret Nginx, skal vi bygge Brotli-modulet ( ngx_brotli
) som et dynamisk Nginx-modul. Fra Nginx version 1.11.5 er det muligt at kompilere individuelle dynamiske moduler uden at kompilere hele Nginx-softwaren. I de næste par trin vil vi bygge Brotli-modulet som dynamisk uden at kompilere hele Nginx.
Download den seneste version af mainline Nginx-kildekoden og udpak den.
wget https://nginx.org/download/nginx-1.15.2.tar.gz && tar zxvf nginx-1.15.2.tar.gz
BEMÆRK : Det er meget vigtigt, at versionsnumrene på Nginx-pakken og Nginx-kildekoden stemmer overens. Hvis du installerede Nginx 1.15.2 fra det officielle Nginx-lager, skal du downloade den samme version af kildekoden , 1.15.2 i dette tilfælde.
Fjern nginx-1.15.2.tar.gz
.
rm nginx-1.15.2.tar.gz
Klon ngx_brotli
fra GitHub.
git clone https://github.com/eustas/ngx_brotli.git
cd ngx_brotli && git submodule update --init && cd ~
Naviger til Nginx-kildekodebiblioteket.
cd ~/nginx-1.15.2
Download nødvendige biblioteker.
sudo apt install -y libpcre3 libpcre3-dev zlib1g zlib1g-dev openssl libssl-dev
Kompiler ngx_brotli
som et dynamisk modul og kopier det til standardbiblioteket for Nginx-moduler, /etc/nginx/modules
.
./configure --with-compat --add-dynamic-module=../ngx_brotli
make modules
sudo cp objs/*.so /etc/nginx/modules
List filer i, /etc/nginx/modules
og du vil se ngx_http_brotli_filter_module.so
og ngx_http_brotli_static_module.so
.
ls /etc/nginx/modules
Indstil tilladelser til 644
for alle .so
filer.
sudo chmod 644 /etc/nginx/modules/*.so
Vi er klar til at konfigurere Brotli-support i Nginx.
Kør sudo vim /etc/nginx/nginx.conf
og tilføj følgende to direktiver øverst i filen for at indlæse nye Brotli-moduler.
load_module modules/ngx_http_brotli_filter_module.so;
load_module modules/ngx_http_brotli_static_module.so;
Test konfigurationen.
sudo nginx -t
Opret en dokumentrodmappe til example.com
og opret index.html
med noget indhold i det.
sudo mkdir -p /var/www/example.com
sudo -s
echo "Hello from example.com" >> /var/www/example.com/index.html
exit
Opret en virtuel vært for example.com
.
sudo vim /etc/nginx/conf.d/example.com.conf
Udfyld den med følgende konfiguration.
server {
listen 80;
server_name example.com; # Replace with your domain name
return 301 https://$server_name$request_uri;
}
server {
listen 443 ssl http2;
server_name example.com; # Replace with your domain name
root /var/www/example.com; # Replace with your document root
# RSA
ssl_certificate /etc/letsencrypt/example.com/fullchain.cer;
ssl_certificate_key /etc/letsencrypt/example.com/example.com.key;
# ECDSA
ssl_certificate /etc/letsencrypt/example.com_ecc/fullchain.cer;
ssl_certificate_key /etc/letsencrypt/example.com_ecc/example.com.key;
brotli on;
brotli_static on;
brotli_types text/plain text/css text/javascript application/javascript text/xml application/xml image/svg+xml application/json;
}
Test konfigurationen.
sudo nginx -t
Genindlæs Nginx.
sudo systemctl reload nginx.service
Besøg dit websted i din webbrowser, og åbn netværksfanen med udviklerværktøjer. Du vil se Content-Encoding: br
i svaroverskrifterne. Det er indikatoren for, at Brotli-komprimering virker.
Du har aktiveret Brotli-komprimering på din webserver.
Introduktion Cacti er et open source overvågnings- og grafværktøj, som er fuldt baseret på RRD-data. Gennem Cacti kan du overvåge næsten enhver type enhed
Introduktion Lets Encrypt er en certifikatmyndighedstjeneste, der tilbyder gratis TLS/SSL-certifikater. Installationsprocessen forenkles af Certbot,
Bruger du et andet system? Denne vejledning viser dig, hvordan du installerer groupware iRedMail på en ny installation af Debian Wheezy. Du bør bruge en serve
Introduktion Lighttpd er en forgrening af Apache, der sigter mod at være meget mindre ressourcekrævende. Den er let, deraf navnet, og den er ret enkel at bruge. Installer
1. Virtualmin/Webmin Virtualmin er et kraftfuldt og fleksibelt webhotel kontrolpanel til Linux og UNIX systemer baseret på den velkendte Open Source web-base
Yii er en PHP-ramme, der giver dig mulighed for at udvikle applikationer hurtigere og nemmere. Installation af Yii på Ubuntu er ligetil, da du vil lære nøjagtigt
Screen er et program, der tillader flere terminalsessioner inden for et vindue. Dette giver dig mulighed for at simulere flere terminalvinduer, hvor det ma
Introduktion Logrotate er et Linux-værktøj, der forenkler administrationen af logfiler. Det kører typisk en gang om dagen via et cron-job og administrerer logbasen
VULTR har for nylig foretaget ændringer i deres ende, og alt skulle nu fungere fint ud af boksen med NetworkManager aktiveret. Skulle du ønske at deaktivere
Icinga2 er et kraftfuldt overvågningssystem, og når det bruges i en master-klient-model, kan det erstatte behovet for NRPE-baserede overvågningstjek. Mester-klienten
I denne artikel vil vi se, hvordan du kompilerer og installerer Nginx mainline fra de officielle kilder til Nginx med PageSpeed-modulet, som giver dig mulighed for at
Bruger du et andet system? Apache Cassandra er et gratis og open source NoSQL-databasestyringssystem, der er designet til at give skalerbarhed, høj
Bruger du et andet system? Introduktion Kanboard er et gratis og open source projektstyringssoftwareprogram, som er designet til at lette og visualisere
Bruger du et andet system? Introduktion Kanboard er et gratis og open source projektstyringssoftwareprogram, som er designet til at lette og visualisere
Bruger du et andet system? Gitea er et alternativt open source, selvhostet versionskontrolsystem drevet af Git. Gitea er skrevet på Golang og er
Bruger du et andet system? Gitea er et alternativt open source, selv-hostet versionskontrolsystem drevet af git. Gitea er skrevet på Golang og er
Bruger du et andet system? Thelia er et open source-værktøj til at skabe e-business-websteder og administrere onlineindhold skrevet i PHP. Thelia kildekode i
Hvad er Dirty Cow (CVE-2016-5195)? Dirty Cow-sårbarheden udnyttes gennem, hvordan Linux behandler kode. Det giver en uprivilegeret bruger mulighed for at gai
Det kan være farligt at have kun én bruger, som er root. Så lad os ordne det. Vultr giver os friheden til at gøre som vi vil med vores brugere og vores servere
Adminer er et letvægtsalternativ til phpMyAdmin. Til sammenligning er dens samlede pakkestørrelse 400KB mod 4,2 MB phpMyAdmin. I modsætning til phpMyAdmin, som
Kunstig intelligens er ikke i fremtiden, det er her lige i nuet I denne blog Læs, hvordan kunstig intelligens-applikationer har påvirket forskellige sektorer.
Er du også et offer for DDOS-angreb og forvirret over forebyggelsesmetoderne? Læs denne artikel for at løse dine spørgsmål.
Du har måske hørt, at hackere tjener mange penge, men har du nogensinde spekuleret på, hvordan tjener de den slags penge? lad os diskutere.
Vil du se revolutionerende opfindelser fra Google, og hvordan disse opfindelser ændrede livet for ethvert menneske i dag? Læs derefter til bloggen for at se opfindelser fra Google.
Konceptet med selvkørende biler til at køre på vejene ved hjælp af kunstig intelligens er en drøm, vi har haft i et stykke tid nu. Men på trods af flere løfter er de ingen steder at se. Læs denne blog for at lære mere...
Efterhånden som videnskaben udvikler sig i et hurtigt tempo og overtager en stor del af vores indsats, stiger risikoen for at udsætte os selv for en uforklarlig Singularitet. Læs, hvad singularitet kunne betyde for os.
Opbevaringsmetoderne for dataene har været under udvikling, kan være siden fødslen af dataene. Denne blog dækker udviklingen af datalagring på basis af en infografik.
Læs bloggen for at kende forskellige lag i Big Data-arkitekturen og deres funktionaliteter på den enkleste måde.
I denne digitalt drevne verden er smarte hjemmeenheder blevet en afgørende del af livet. Her er et par fantastiske fordele ved smarte hjemmeenheder om, hvordan de gør vores liv værd at leve og enklere.
For nylig udgav Apple macOS Catalina 10.15.4 en supplerende opdatering for at løse problemer, men det ser ud til, at opdateringen forårsager flere problemer, hvilket fører til mursten af mac-maskiner. Læs denne artikel for at lære mere