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.
NGINX może być używany jako serwer HTTP / HTTPS, serwer odwrotnego proxy, serwer proxy poczty, moduł równoważenia obciążenia, terminator TLS lub serwer buforowania. Z założenia jest dość modułowy. Ma natywne moduły i moduły innych firm utworzone przez społeczność. Napisane w języku programowania C jest to bardzo szybkie i lekkie oprogramowanie.
UWAGA : NGINX ma dwa strumienie wersji, które działają równolegle - stabilny i główny . Obie wersje mogą być używane na serwerze produkcyjnym. Zaleca się stosowanie wersji głównej podczas produkcji.
Instalacja NGINX z kodu źródłowego jest stosunkowo „łatwa” - pobierz najnowszą wersję kodu źródłowego NGINX, skonfiguruj, skompiluj i zainstaluj.
W tym samouczku użyję wersji głównej , czyli 1.13.2 w momencie pisania. Zaktualizuj odpowiednio numery wersji, gdy będą dostępne nowsze wersje.
Obowiązkowe wymagania:
Wymagania opcjonalne:
Zanim zaczniesz
sudodostępem .Przejdź do nowego użytkownika:
su - <username>
Zaktualizuj system:
sudo yum check-update || sudo yum update -y
Zainstaluj „Narzędzia programistyczne” i edytor Vima:
sudo yum groupinstall -y 'Development Tools' && sudo yum install -y vim
Zainstaluj dodatkowe pakiety dla Enterprise Linux (EPEL):
sudo yum install -y epel-release
Pobierz i zainstaluj opcjonalne zależności NGINX:
sudo yum install -y perl perl-devel perl-ExtUtils-Embed libxslt libxslt-devel libxml2 libxml2-devel gd gd-devel GeoIP GeoIP-devel
Pobierz najnowszą główną wersję kodu źródłowego NGINX i wypakuj go:
wget https://nginx.org/download/nginx-1.13.2.tar.gz && tar zxvf nginx-1.13.2.tar.gz
Pobierz kod źródłowy zależności NGINX i wyodrębnij je:
# PCRE version 8.40
wget https://ftp.pcre.org/pub/pcre/pcre-8.40.tar.gz && tar xzvf pcre-8.40.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.0f
wget https://www.openssl.org/source/openssl-1.1.0f.tar.gz && tar xzvf openssl-1.1.0f.tar.gz
Usuń wszystkie .tar.gzpliki. Nie potrzebujemy ich już:
rm -rf *.tar.gz
Przejdź do katalogu źródłowego NGINX:
cd ~/nginx-1.13.2
Dla dokładności wymień pliki i katalogi kodu źródłowego nginx:
ls
# auto CHANGES CHANGES.ru conf configure contrib html LICENSE man README src
Skopiuj stronę podręcznika NGINX do /usr/share/man/man8:
sudo cp ~/nginx-1.13.2/man/nginx.8 /usr/share/man/man8
sudo gzip /usr/share/man/man8/nginx.8
# Check that Man page for NGINX is working
man nginx
Aby uzyskać pomoc, możesz wyświetlić listę dostępnych przełączników konfiguracji, uruchamiając:
./configure --help
# To see want core modules can be build as dynamic run:
./configure --help | grep -F =dynamic
Skonfiguruj, skompiluj i zainstaluj NGINX:
./configure --prefix=/etc/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 \
--pid-path=/var/run/nginx.pid \
--lock-path=/var/run/nginx.lock \
--user=nginx \
--group=nginx \
--build=CentOS \
--builddir=nginx-1.13.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 \
--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.40 \
--with-pcre-jit \
--with-zlib=../zlib-1.2.11 \
--with-openssl=../openssl-1.1.0f \
--with-openssl-opt=no-nextprotoneg \
--with-debug
make
sudo make install
Dowiązanie symboliczne /usr/lib64/nginx/modulesdo /etc/nginx/moduleskatalogu, aby można było ładować moduły dynamiczne w konfiguracji nginx w następujący sposób load_module modules/ngx_foo_module.so;:
sudo ln -s /usr/lib64/nginx/modules /etc/nginx/modules
Wydrukuj wersję NGINX, wersję kompilatora i skonfiguruj parametry skryptu:
sudo nginx -V
# nginx version: nginx/1.13.2 (CentOS)
# built by gcc 4.8.5 20150623 (Red Hat 4.8.5-11) (GCC)
# built with OpenSSL 1.1.0f 25 May 2017
# TLS SNI support enabled
# configure arguments: --prefix=/etc/nginx --sbin-path=/usr/sbin/nginx . . .
# . . .
# . . .
Utwórz użytkownika i grupę systemu NGINX:
sudo useradd --system --home /var/cache/nginx --shell /sbin/nologin --comment "nginx user" --user-group nginx
Sprawdź składnię i potencjalne błędy:
sudo nginx -t
# Will throw this error: nginx: [emerg] mkdir() "/var/cache/nginx/client_temp" failed (2: No such file or directory)
# Just create directory
sudo mkdir -p /var/cache/nginx && sudo nginx -t
Utwórz plik jednostki systemowej dla nginx:
sudo vim /usr/lib/systemd/system/nginx.service
Skopiuj / wklej następującą treść:
UWAGA : Lokalizacja pliku PID i pliku binarnego NGINX może się różnić w zależności od sposobu kompilacji NGINX.
[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
Uruchom i włącz usługę NGINX:
sudo systemctl start nginx.service && sudo systemctl enable nginx.service
Sprawdź, czy NGINX uruchomi się po ponownym uruchomieniu:
sudo systemctl is-enabled nginx.service
# enabled
Sprawdź, czy NGINX działa:
sudo systemctl status nginx.service
ps aux | grep nginx
curl -I 127.0.0.1
Uruchom ponownie VPS, aby sprawdzić, czy NGINX uruchamia się automatycznie:
sudo shutdown -r now
Usuń archaiczne pliki z /etc/nginxkatalogu:
sudo rm /etc/nginx/koi-utf /etc/nginx/koi-win /etc/nginx/win-utf
Umieść wyróżnianie składni konfiguracji NGINX dla vimw ~/.vim/. Otrzymasz ładne podświetlanie składni podczas edycji pliku konfiguracyjnego NGINX:
mkdir ~/.vim/
cp -r ~/nginx-1.13.2/contrib/vim/* ~/.vim/
Usuń wszystkie .defaultpliki kopii zapasowej z /etc/nginx/:
sudo rm /etc/nginx/*.default
Otóż to. Masz teraz zainstalowaną najnowszą wersję NGINX. Jest kompilowany statycznie z niektórymi ważnymi bibliotekami, takimi jak OpenSSL. Często systemowa wersja OpenSSL jest nieaktualna. Korzystając z tej metody instalacji z nowszą wersją OpenSSL, możesz skorzystać z nowych szyfrów, takich jak CHACHA20_POLY1305i protokołów, takich jak TLS 1.3, które będą dostępne w OpenSSL 1.1.1(które nie zostało wydane w momencie pisania).
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.