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 johndoe
jako przykładowy użytkownik i example.com
przykładowa domena. Wymień je według swoich imion.
A
/ AAAA
recordsSprawdź wersję Ubuntu.
lsb_release -ds
# Ubuntu 18.04 LTS
Utwórz nowe non-root
konto użytkownika z sudo
dostępem i przejdź do niego.
adduser johndoe --gecos "John Doe"
usermod -aG sudo johndoe
su - johndoe
UWAGA : Zamień na johndoe
swoją 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 [email protected]
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 [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
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_ecc
Pobierz 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_brotli
z 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_brotli
jako 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/modules
a zobaczysz ngx_http_brotli_filter_module.so
i ngx_http_brotli_static_module.so
.
ls /etc/nginx/modules
Ustaw uprawnienia 644
dla wszystkich .so
plików.
sudo chmod 644 /etc/nginx/modules/*.so
Jesteśmy gotowi skonfigurować obsługę Brotli w Nginx.
Uruchom sudo vim /etc/nginx/nginx.conf
i 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.com
i utwórz index.html
z 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: br
w 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…
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ą
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.
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.