Zainstaluj certyfikaty Wildcard From Lets Encrypt w Nginx na Ubuntu 19.04

W marcu 2018 Let's Encrypt dodał obsługę certyfikatów wieloznacznych. Certyfikaty wieloznaczne pozwalają zabezpieczyć wszystkie subdomeny pierwszego poziomu domeny za pomocą jednego certyfikatu. Certyfikaty wieloznaczne można uzyskać tylko poprzez ACMEv2, który jest zaktualizowaną wersją protokołu ACME. Aby użyć ACMEv2 do certyfikatów wieloznacznych lub innych niż symbole wieloznaczne, potrzebujesz klienta, który został zaktualizowany do obsługi ACMEv2. Jednym z takich klientów jest acme.sh, który jest klientem protokołu ACME / ACMEv2 napisanym wyłącznie w języku Shell (powłoka Unix) bez żadnych zależności. Ponadto domeny wieloznaczne muszą być sprawdzane przy użyciu typu wyzwania DNS-01. Oznacza to, że musisz zmodyfikować rekordy DNS TXT, aby udowodnić kontrolę nad domeną w celu uzyskania certyfikatu wieloznacznego.

W tym przewodniku wyjaśniamy, jak uzyskać i wdrożyć bezpłatne certyfikaty wieloznaczne z Let's Encrypt na Ubuntu 19.04 za pomocą acme.shklienta, narzędzia Lexicon do automatycznej manipulacji rekordami DNS poprzez wykorzystanie interfejsu API Vultr i wdrażania certyfikatów na serwerze internetowym Nginx.

Wymagania

  • Świeżo wdrożony serwer chmurowy Ubuntu 19.04 Vultr.
  • Masz zarejestrowaną nazwę domeny. Ten przewodnik wykorzystuje example.comjako przykładową domenę.
  • Upewnij się, że ustawiłeś rekordy A / AAAA i CNAME dla swojej w pełni kwalifikowanej nazwy domeny (FQDN). Możesz zapoznać się z samouczkiem Wprowadzenie do Vultr DNS, jeśli chcesz zapoznać się z koncepcjami DNS.
  • Dostęp do interfejsu API Vultr włączony w panelu sterowania konta Vultr.

Zanim zaczniesz

Sprawdź wersję Ubuntu.

lsb_release -ds
# Ubuntu 19.04

Utwórz nowe konto użytkownika z sudodostępem i preferowaną nazwą użytkownika i przełącz się na to. Używamy johndoe.

adduser johndoe --gecos "John Doe"
usermod -aG sudo johndoe
su - johndoe

UWAGA : Zamień na johndoeswoją nazwę użytkownika.

Ustaw strefę czasową.

sudo dpkg-reconfigure tzdata

Upewnij się, że Twój system Ubuntu jest aktualny.

sudo apt update && sudo apt upgrade -y

Zainstaluj niezbędne pakiety.

sudo apt install -y git wget curl socat

Zainstaluj Nginx

Zainstaluj serwer WWW Nginx.

sudo apt install -y nginx

Sprawdź wersję.

sudo nginx -v
# nginx version: nginx/1.15.9 (Ubuntu)

Zainstaluj Python i Lexicon

Pierwszym krokiem w procesie uzyskiwania certyfikatów wieloznacznych z Let's Encrypt przy użyciu acme.sh i Vultr API jest zainstalowanie Pythona i Leksykonu . Leksykon to pakiet języka Python, który zapewnia sposób manipulowania rekordami DNS wielu dostawców DNS w znormalizowany sposób.

Zainstaluj Python, jeśli nie jest jeszcze zainstalowany w twoim systemie.

sudo apt install -y python3

Potwierdź instalację, weryfikując wersję.

python3 --version
# Python 3.7.3

Zainstaluj narzędzie Leksykon. Leksykon to narzędzie w języku Python, które pozwala w standardowy sposób manipulować rekordami DNS różnych dostawców DNS.

sudo apt install -y lexicon

Sprawdź wersję Leksykonu.

lexicon --version
# lexicon 3.0.8

Zainstaluj acme.shklienta

Acme.shto klient protokołu ACME napisany wyłącznie w języku Shell (powłoka Unix), który automatyzuje proces uzyskiwania podpisanego certyfikatu za pomocą Let's Encrypt. Obsługuje ACME v1 i ACME v2, a co najważniejsze obsługuje certyfikaty wieloznaczne ACME v2. W tej sekcji instalujemy skrypt Acme.sh.

UWAGA: Zaleca się użycie rootużytkownika do instalacji acme.sh, chociaż nie wymaga root/ sudodostępu.

Przełącz się rootna zwykłego użytkownika, jeśli go utworzyłeś.

sudo su - root

Pobierz i zainstaluj acme.sh.

git clone https://github.com/Neilpang/acme.sh.git
cd acme.sh
./acme.sh --install --accountemail "[email protected]"
source ~/.bashrc
cd

Sprawdź wersję.

acme.sh --version
# v2.8.2

Uzyskaj certyfikaty wieloznaczne z Let's Encrypt

Aby uzyskać certyfikat wieloznaczny, możemy użyć tylko metody sprawdzania poprawności DNS. Używamy Lexicon i Vultr DNS API do manipulowania rekordami DNS TXT.

Uzyskaj certyfikaty wieloznaczne RSA i ECC dla swojej domeny.

# Configure your API key and username
export PROVIDER=vultr
export LEXICON_VULTR_USERNAME="[email protected]"
export LEXICON_VULTR_TOKEN="XXXXXXXXXXXXXXX"

# RSA 2048
acme.sh --issue --dns dns_lexicon -d example.com -d '*.example.com' --keylength 2048
# ECC 256
acme.sh --issue --dns dns_lexicon -d example.com -d '*.example.com' --keylength ec-256

UWAGA : Nie zapomnij zastąpić example.comswoją nazwą domeny i zastąpić wartości zastępcze Vultr API własnymi.

Po uruchomieniu poprzednich poleceń certyfikaty i klucze znajdują się w:

  • Dla RSA: ~/.acme.sh/example.comkatalog.
  • W przypadku ECC / ECDSA: ~/.acme.sh/example.com_ecckatalog.

UWAGA : Nie należy używać plików cert w ~/.acme.sh/folderze, są one wyłącznie do użytku wewnętrznego, struktura katalogów może ulec zmianie w przyszłości.

Aby wyświetlić listę swoich certyfikatów, możesz uruchomić:

acme.sh --list

Utwórz folder do przechowywania certyfikatów w produkcji. Korzystamy z /etc/letsencryptkatalogu.

sudo mkdir -p /etc/letsencrypt/example.com
sudo mkdir -p /etc/letsencrypt/example.com_ecc

Zainstaluj / skopiuj certyfikaty do użytku produkcyjnego na swoim serwerze.

# RSA
acme.sh --install-cert -d example.com \
        --cert-file /etc/letsencrypt/example.com/cert.pem \
        --key-file /etc/letsencrypt/example.com/private.key \
        --fullchain-file /etc/letsencrypt/example.com/fullchain.pem \
        --reloadcmd "sudo systemctl reload nginx.service"

# ECC/ECDSA
acme.sh --install-cert -d example.com --ecc \
        --cert-file /etc/letsencrypt/example.com_ecc/cert.pem \
        --key-file /etc/letsencrypt/example.com_ecc/private.key \
        --fullchain-file /etc/letsencrypt/example.com_ecc/fullchain.pem \
        --reloadcmd "sudo systemctl reload nginx.service"

Teraz, gdy udało nam się uzyskać certyfikaty wieloznaczne z Let's Encrypt, musimy skonfigurować serwer WWW Nginx. Wszystkie certyfikaty są odnawiane automatycznie co 60 dni.

Po uzyskaniu i zainstalowaniu certyfikatów w preferowanej lokalizacji możesz wylogować się z konta rootzwykłego sudoużytkownika i kontynuować zarządzanie serwerem, korzystając z niego, sudojeśli to konieczne.

exit

Skonfiguruj serwer WWW Nginx

Uruchom sudo vim /etc/nginx/sites-available/example.com.confi wypełnij plik następującą zawartością. Zastąp wszystkie wystąpienia example.comwłasną nazwą domeny.

server {

  listen 443 ssl http2;
  listen [::]:443 ssl http2;

  server_name example.com *.example.com;
  root /var/www/example.com;

  # RSA
  ssl_certificate /etc/letsencrypt/example.com/fullchain.pem;
  ssl_certificate_key /etc/letsencrypt/example.com/private.key;
  # ECDSA
  ssl_certificate /etc/letsencrypt/example.com_ecc/fullchain.pem;
  ssl_certificate_key /etc/letsencrypt/example.com_ecc/private.key;

}

Aktywuj nową example.com.confkonfigurację, łącząc plik z sites-enabledkatalogiem.

sudo ln -s /etc/nginx/sites-available/example.com.conf /etc/nginx/sites-enabled/

Przetestuj konfigurację Nginx.

sudo nginx -t

Załaduj ponownie Nginx.

sudo systemctl reload nginx.service

Otóż ​​to. Wdrożyliśmy certyfikaty symboli zastępczych w Nginx, używając acme.sh, Lexicon i Vultr API. Certyfikaty wieloznaczne mogą być przydatne, gdy chcesz zabezpieczyć wiele subdomen pierwszego poziomu generowanych dynamicznie.



Leave a Comment

Konfigurowanie chroota w Debianie

Konfigurowanie chroota w Debianie

W tym artykule dowiesz się, jak skonfigurować więzienie chroot w Debianie. Zakładam, że używasz Debiana 7.x. Jeśli używasz Debiana 6 lub 8, może to działać, bu

Skonfiguruj Apache z samopodpisanym certyfikatem TLS / SSL w systemie Ubuntu 16.04

Skonfiguruj Apache z samopodpisanym certyfikatem TLS / SSL w systemie Ubuntu 16.04

SSL i jego następca TLS (Secure Sockets Layer / Transport Layer Security) dodają warstwę szyfrowania między klientem a serwerem. Bez thi

Jak włączyć TLS 1.3 w Apache na Debianie 10

Jak włączyć TLS 1.3 w Apache na Debianie 10

Używasz innego systemu? TLS 1.3 to wersja protokołu Transport Layer Security (TLS), która została opublikowana w 2018 roku jako proponowany standard w RFC 8446

Zabezpieczanie MongoDB

Zabezpieczanie MongoDB

MongoDB nie jest domyślnie bezpieczny. Jeśli instalujesz MongoDB i uruchamiasz go bez konfigurowania go do uwierzytelniania, będziesz miał zły czas

Jak dalej zabezpieczyć SSH za pomocą sekwencji przełączania portów na Ubuntu 18.04

Jak dalej zabezpieczyć SSH za pomocą sekwencji przełączania portów na Ubuntu 18.04

Używasz innego systemu? Wprowadzenie Oprócz zmiany domyślnego portu SSH i użycia pary kluczy do uwierzytelnienia, można użyć przełączania portów t

Jak włączyć TLS 1.3 w Apache na FreeBSD 12

Jak włączyć TLS 1.3 w Apache na FreeBSD 12

Używasz innego systemu? TLS 1.3 to wersja protokołu Transport Layer Security (TLS), która została opublikowana w 2018 roku jako proponowany standard w RFC 8446

Jak zainstalować rkhunter na Ubuntu

Jak zainstalować rkhunter na Ubuntu

Rkhunter to oprogramowanie, które znajduje rootkity na serwerze Linux. Rootkity są instalowane przez hakerów, aby zawsze mogli uzyskać dostęp do serwera. W tym dokumencie będziesz

Zapora ogniowa Vultr

Zapora ogniowa Vultr

Vultr oferuje internetowe zapory ogniowe, które można włączyć w celu ochrony jednego lub więcej wystąpień obliczeniowych. Posiadanie zestawu reguł zapory dla serwerów

Jak włączyć TLS 1.3 w Nginx na Ubuntu 18.04 LTS

Jak włączyć TLS 1.3 w Nginx na Ubuntu 18.04 LTS

Używasz innego systemu? TLS 1.3 to wersja protokołu Transport Layer Security (TLS), która została opublikowana w 2018 roku jako proponowany standard w RFC 8446

Utwórz interfejs HTML 5 RDP / SSH za pomocą Guacamole na Ubuntu 16.04 LTS

Utwórz interfejs HTML 5 RDP / SSH za pomocą Guacamole na Ubuntu 16.04 LTS

Wprowadzenie Celem tego samouczka jest pozbycie się publicznych SSH i publicznych połączeń RDP. Umieszczając to wszystko za bardzo wygodnym klientem HTML5

Jak zabezpieczyć vsFTPd za pomocą SSL / TLS

Jak zabezpieczyć vsFTPd za pomocą SSL / TLS

Bardzo bezpieczny demon FTP lub po prostu vsFTPd to lekki program z dużą możliwością dostosowywania. W tym samouczku zabezpieczymy wszystko

Skonfiguruj LetsEncrypt w systemie Linux

Skonfiguruj LetsEncrypt w systemie Linux

LetsEncrypt to urząd certyfikacji ze zautomatyzowanym klientem. Krótko mówiąc, oznacza to, że możesz zabezpieczyć swoje strony internetowe bez żadnych kosztów. Właśnie tak, możesz g

Jak zainstalować narzędzie OpenVAS Vulnerability Scanner na Ubuntu 16.04

Jak zainstalować narzędzie OpenVAS Vulnerability Scanner na Ubuntu 16.04

Wprowadzenie OpenVAS to pakiet open source, którego można używać do skanowania w poszukiwaniu luk i zarządzania nimi. Oznacza Open Vulnerabilit

Modyfikacja Icinga2 w celu użycia modelu głównego / klienta w CentOS 6 lub CentOS 7

Modyfikacja Icinga2 w celu użycia modelu głównego / klienta w CentOS 6 lub CentOS 7

Icinga2 to potężny system monitorowania, a stosowany w modelu master-client może zastąpić potrzebę sprawdzania monitorowania opartego na NRPE. Master-Clien

Jak wyłączyć SELinux na CentOS 7

Jak wyłączyć SELinux na CentOS 7

SELinux, skrót od Security-Enhanced Linux, jest ulepszeniem bezpieczeństwa systemu operacyjnego Linux. Jest to system etykietowania, który blokuje wiele syste

Zainstaluj i skonfiguruj CentOS 7, aby zdalnie odblokować LVM na szyfrowaniu dysku LUKS za pomocą SSH

Zainstaluj i skonfiguruj CentOS 7, aby zdalnie odblokować LVM na szyfrowaniu dysku LUKS za pomocą SSH

LUKS (Linux Unified Key Setup) to jeden z różnych formatów szyfrowania dysku dostępnych dla Linuksa, który jest niezależny od platformy. Ten samouczek zapewni Ci dowcip

Jak zainstalować Ntopng na Ubuntu 16.04

Jak zainstalować Ntopng na Ubuntu 16.04

Wprowadzenie Ntopng to narzędzie typu open source służące do monitorowania różnych protokołów sieciowych na serwerach. Jest to wersja nowej generacji origina

Lets Encrypt: Migrating From TLS-SNI-01

Lets Encrypt: Migrating From TLS-SNI-01

Lets Encrypt to bezpłatna usługa, która generuje certyfikaty w celu zabezpieczenia Twojej witryny. Obsługuje generowanie różnych typów certyfikatów, w tym

Zabezpieczanie serwera Apache na CentOS 6

Zabezpieczanie serwera Apache na CentOS 6

Podczas zabezpieczania serwera łatwo jest korzystać ze skrótów, ale ryzykujesz utratę danych w przypadku, gdy osoba atakująca uzyska dostęp do konta root na dowolnym serwerze. Przeddzień

Port puka do Debiana

Port puka do Debiana

Używasz innego systemu? Do tej pory prawdopodobnie zmieniłeś domyślny port SSH. Mimo to hakerzy mogą z łatwością skanować zakresy portów, aby odkryć ten port - ale dowcip

Funkcjonalności warstw architektury referencyjnej Big Data

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.

Rewolucyjne wynalazki Google, które ułatwią Twoje życie.

Rewolucyjne wynalazki Google, które ułatwią Twoje życie.

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

13 komercyjnych narzędzi do ekstrakcji danych z Big Data

13 komercyjnych narzędzi do ekstrakcji danych z Big Data

Pozostań w kontakcie dzięki aplikacji WhatsApp na komputer 24*7

Pozostań w kontakcie dzięki aplikacji WhatsApp na komputer 24*7

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+

5 przykładów, które dowodzą, że energetyka jądrowa nie zawsze jest zła

5 przykładów, które dowodzą, że energetyka jądrowa nie zawsze jest zła

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.

Friday Essential: Co się stało z samochodami sterowanymi przez sztuczną inteligencję?

Friday Essential: Co się stało z samochodami sterowanymi przez sztuczną inteligencję?

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…

Czy AI może walczyć z rosnącą liczbą ataków ransomware?

Czy AI może walczyć z rosnącą liczbą ataków ransomware?

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ą

5 przydatnych narzędzi sztucznej inteligencji, które uproszczą Twoje życie

5 przydatnych narzędzi sztucznej inteligencji, które uproszczą Twoje życie

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.

Wgląd w 26 technik analizy Big Data: część 2

Wgląd w 26 technik analizy Big Data: część 2

Zawsze potrzebujemy Big Data Analytics do efektywnego zarządzania danymi. W tym artykule omówiliśmy kilka technik analizy Big Data. Sprawdź ten artykuł.

Ataki DDOS: krótki przegląd

Ataki DDOS: krótki przegląd

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.