Funkcjonalności warstw architektury referencyjnej Big Data
Przeczytaj blog, aby w najprostszy sposób poznać różne warstwy w architekturze Big Data i ich funkcjonalności.
Brotli (br) to nowy algorytm kompresji open source, opracowany przez Google jako alternatywa dla Gzip, Zopfli i Deflate. Jest formalnie zdefiniowany w Internet Engineering Task Force (IETF) jako RFC 7932 . Studium przypadku firmy Brotli przeprowadzone przez Google wykazało, że współczynniki kompresji są nawet o 26% mniejsze niż obecne metody przy mniejszym zużyciu procesora.
Nginx nie ma oficjalnego wsparcia, ale Google opracował moduł innej firmy o nazwie ngx_brotli , którego możemy użyć, aby dodać obsługę Nginx.
Ten przewodnik pokaże, jak dodać obsługę Brotli do Nginx na nowej instancji Ubuntu 18.04 LTS Vultr.
UWAGA: ten przewodnik będzie używany johndoejako przykładowy użytkownik i example.comprzykładowa domena. Wymień je według swoich imion.
A/ AAAArecordsSprawdź wersję Ubuntu.
lsb_release -ds
# Ubuntu 18.04 LTS
Utwórz nowe non-rootkonto użytkownika z sudodostępem i przejdź do niego.
adduser johndoe --gecos "John Doe"
usermod -aG sudo johndoe
su - johndoe
UWAGA : Zamień na johndoeswoją nazwę użytkownika .
Zaktualizuj oprogramowanie systemu operacyjnego.
sudo apt update && sudo apt upgrade -y
Ustaw strefę czasową.
sudo dpkg-reconfigure tzdata
Zainstaluj wymagane narzędzia i pakiety kompilacji.
sudo apt install -y build-essential git apt-transport-https socat
Brotli wymaga skonfigurowania i używania HTTPS. W tej części otrzymamy zaufany certyfikat od Let's Encrypt.
Pobierz i zainstaluj 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 your_email@example.com
cd ~
source ~/.bashrc
Sprawdź wersję.
acme.sh --version
# v2.8.0
Uzyskaj certyfikaty RSA i ECDSA dla example.com.
# RSA 2048
sudo /etc/letsencrypt/acme.sh --issue --standalone --home /etc/letsencrypt -d example.com --accountemail your_email@example.com --ocsp-must-staple --keylength 2048
# ECDSA/ECC P-256
sudo /etc/letsencrypt/acme.sh --issue --standalone --home /etc/letsencrypt -d example.com --accountemail your_email@example.com --ocsp-must-staple --keylength ec-256
Po uruchomieniu powyższych poleceń certyfikaty i klucze będą znajdować się w następujących lokalizacjach:
/etc/letsencrypt/example.com/etc/letsencrypt/example.com_eccPobierz i zainstaluj najnowszą główną wersję Nginx z oficjalnego repozytorium Nginx.
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
Sprawdź wersję.
sudo nginx -v
# nginx version: nginx/1.15.2
Włącz i uruchom Nginx.
sudo systemctl enable nginx.service
sudo systemctl start nginx.service
Po zainstalowaniu Nginx musimy zbudować moduł Brotli ( ngx_brotli) jako dynamiczny moduł Nginx. Od wersji 1.11.5 Nginx można kompilować poszczególne moduły dynamiczne bez kompilacji pełnego oprogramowania Nginx. W następnych kilku krokach zbudujemy moduł Brotli jako dynamiczny bez kompilacji pełnego Nginx.
Pobierz najnowszą wersję głównego kodu źródłowego Nginx i rozpakuj go.
wget https://nginx.org/download/nginx-1.15.2.tar.gz && tar zxvf nginx-1.15.2.tar.gz
UWAGA : Bardzo ważne jest, aby numery wersji pakietu Nginx i kodu źródłowego Nginx były zgodne. Jeśli zainstalowałeś Nginx 1.15.2 z oficjalnego repozytorium Nginx, musisz pobrać tę samą wersję kodu źródłowego , w tym przypadku 1.15.2.
Usuń nginx-1.15.2.tar.gz.
rm nginx-1.15.2.tar.gz
Klon ngx_brotliz GitHub.
git clone https://github.com/eustas/ngx_brotli.git
cd ngx_brotli && git submodule update --init && cd ~
Przejdź do katalogu kodu źródłowego Nginx.
cd ~/nginx-1.15.2
Pobierz wymagane biblioteki.
sudo apt install -y libpcre3 libpcre3-dev zlib1g zlib1g-dev openssl libssl-dev
Skompilować ngx_brotlijako moduł dynamiczny i skopiować go do katalogu dla standardowych modułów nginx, /etc/nginx/modules.
./configure --with-compat --add-dynamic-module=../ngx_brotli
make modules
sudo cp objs/*.so /etc/nginx/modules
Wyświetl listę plików, /etc/nginx/modulesa zobaczysz ngx_http_brotli_filter_module.soi ngx_http_brotli_static_module.so.
ls /etc/nginx/modules
Ustaw uprawnienia 644dla wszystkich .soplików.
sudo chmod 644 /etc/nginx/modules/*.so
Jesteśmy gotowi skonfigurować obsługę Brotli w Nginx.
Uruchom sudo vim /etc/nginx/nginx.confi dodaj następujące dwie dyrektywy u góry pliku, aby załadować nowe moduły Brotli.
load_module modules/ngx_http_brotli_filter_module.so;
load_module modules/ngx_http_brotli_static_module.so;
Przetestuj konfigurację.
sudo nginx -t
Utwórz katalog główny dokumentu example.comi utwórz index.htmlz zawartością.
sudo mkdir -p /var/www/example.com
sudo -s
echo "Hello from example.com" >> /var/www/example.com/index.html
exit
Utwórz wirtualny host dla example.com.
sudo vim /etc/nginx/conf.d/example.com.conf
Wypełnij go następującą konfiguracją.
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;
}
Przetestuj konfigurację.
sudo nginx -t
Załaduj ponownie Nginx.
sudo systemctl reload nginx.service
Odwiedź swoją witrynę w przeglądarce internetowej i otwórz kartę sieciową narzędzi programistycznych. Zobaczysz Content-Encoding: brw nagłówkach odpowiedzi. Jest to wskaźnik działania kompresji Brotli.

Włączyłeś kompresję Brotli na swoim serwerze internetowym.
Przeczytaj blog, aby w najprostszy sposób poznać różne warstwy w architekturze Big Data i ich funkcjonalności.
Chcesz zobaczyć rewolucyjne wynalazki Google i jak te wynalazki zmieniły życie każdego człowieka dzisiaj? Następnie czytaj na blogu, aby zobaczyć wynalazki Google.
13 komercyjnych narzędzi do ekstrakcji danych z Big Data
Whatsapp w końcu uruchomił aplikację Desktop dla użytkowników komputerów Mac i Windows. Teraz możesz łatwo uzyskać dostęp do Whatsapp z systemu Windows lub Mac. Dostępne dla Windows 8+ i Mac OS 10.9+
Energia jądrowa jest zawsze pogardzana, nigdy jej nie szanujemy z powodu przeszłych wydarzeń, ale nie zawsze jest zła. Przeczytaj post, aby dowiedzieć się więcej na ten temat.
Koncepcja autonomicznych samochodów, które wyjadą na drogi za pomocą sztucznej inteligencji, to marzenie, które mamy już od jakiegoś czasu. Ale pomimo kilku obietnic nigdzie ich nie widać. Przeczytaj ten blog, aby dowiedzieć się więcej…
Sztuczna inteligencja nie jest dla ludzi nową nazwą. Ponieważ sztuczna inteligencja jest włączona do każdego strumienia, jednym z nich jest opracowywanie narzędzi zwiększających ludzką wydajność i dokładność. Skorzystaj z tych niesamowitych narzędzi uczenia maszynowego i uprość swoje codzienne zadania.
Wzrasta liczba ataków ransomware, ale czy sztuczna inteligencja może pomóc w radzeniu sobie z najnowszym wirusem komputerowym? Czy AI jest odpowiedzią? Przeczytaj tutaj, wiedz, że sztuczna inteligencja jest zmorą lub zgubą
Zawsze potrzebujemy Big Data Analytics do efektywnego zarządzania danymi. W tym artykule omówiliśmy kilka technik analizy Big Data. Sprawdź ten artykuł.
Czy jesteś również ofiarą ataków DDOS i nie masz pewności co do metod zapobiegania? Przeczytaj ten artykuł, aby rozwiązać swoje pytania.