Začetna konfiguracija varnega strežnika za Ubuntu 18.04

Uvod

V tej vadnici se boste naučili, kako konfigurirati osnovno raven varnosti na povsem novem virtualnem stroju Vultr VC2 z operacijskim sistemom Ubuntu 18.04.

Predpogoji

  • Račun Vultr, ustvarite ga lahko tukaj
  • Nov VM Ubuntu 18.04 Vultr

Ustvarite in spremenite uporabnika

Prva stvar, ki jo bomo naredili, je ustvariti našega novega uporabnika, ki ga bomo uporabljali za prijavo v VM:

adduser porthorian

Opomba: Priporočljivo je, da uporabite edinstveno uporabniško ime, ki ga bo težko uganiti. Večina botov bo privzeto poskusila root, admin, moderator, in podobno.

Tukaj boste pozvani k vnosu gesla. To je zelo priporočljivo, da uporabljate močna alfa numerično geslo. Po tem sledite navodilom na zaslonu in ko vas vpraša, ali so informacije pravilne, samo pritisnite Y.

Ko bo ta novi uporabnik dodan, bomo temu uporabniku morali dati dovoljenja sudo, da bomo lahko izvajali ukaze uporabnika v imenu korenskega uporabnika:

usermod -aG sudo porthorian

Ko svojemu uporabniku daste dovoljenja sudo, preklopite na novega uporabnika:

su - porthorian

Ustvarite in konfigurirajte ključ SSH

Če želite ustvariti ključ SSH, sledite tem dokumentu .

Ko ustvarite nov ključ SSH, kopirajte svoj javni ključ. Izgledalo bi takole:

ssh-rsa AAAAB3NzaC1yc2EAAAABJQAAAQEAmB3uRWxAAELNJ8oGBCBmZx7S11vnAp0RG8rdKf6CLdvT7NMbKF55F8Wf0hFPewEryplaH54ibdmaTuheJVKy1lUhHnVi0AcBpkhJiiOQdEtvbYKT/eIkQl/Qm92Gz6aL3lJ0UknO4gO0LzgqI2vYX0b9LHMF+ZvApEDahLCna6RKo3/lffnANUKfExE+dVwOcJwATL3Ld5IkSatm7zBqbJAim0wj/JQ5ejzkL+aYd3YawpW3qf+WsY3HGbK2TIJt3LsiZJ3M7giZo/fVIZCJqsIOyO9NUOEx5/+KE8IniGb7gdRYgquAEJr89poDCNz/8CBODi9z3ukiE1+UnVlhfQ== rsa-key-20190408

Konfigurirajte svoj uporabniški imenik

Pomaknite se do domačega imenika uporabnikov, če še niste v njem:

cd $HOME

$HOMEje spremenljivka okolja za domači imenik vaših uporabnikov. To se samodejno nastavi, ko je nov uporabnik ustvarjen.

Medtem ko je v našem domačem imeniku, bomo vanj postavili še en imenik. Ta imenik bo skrit pred drugimi uporabniki na napravi, razen root in uporabnikom, ki je lastnik imenika. Ustvarite nov imenik in omejite njegova dovoljenja z naslednjimi ukazi:

mkdir ~/.ssh
chmod 700 ~/.ssh

Zdaj se bomo, da odprete datoteko v .sshimenovano authorized_keys. To je univerzalna datoteka, ki jo išče OpenSSH. /etc/ssh/sshd_configČe je potrebno, lahko spremenite ime tega v konfiguraciji OpenSSH .

Za ustvarjanje datoteke uporabite svoj najljubši urejevalnik. Ta vadnica bo uporabljala nano:

nano ~/.ssh/authorized_keys

Kopirajte in prilepite svoj ključ ssh v authorized_keysdatoteko, ki smo jo odprli. Ko je javni ključ notri, lahko datoteko shranite s pritiskom na CTRL+ O.

Prepričajte se, da je prikazana ustrezna pot datoteke:

/home/porthorian/.ssh/authorized_keys

Če je prava pot do datoteke, samo pritisnite ENTER, v nasprotnem primeru naredite potrebne spremembe, da se ujemajo z zgornjim primerom. Nato zapustite datoteko s CTRL+ X.

Zdaj bomo omejili dostop do datoteke:

chmod 600 ~/.ssh/authorized_keys

Zapustite našega ustvarjenega uporabnika in se vrnite na korenskega uporabnika:

exit

Onemogočanje preverjanja pristnosti z geslom

Zdaj lahko onemogočimo preverjanje pristnosti gesla na strežniku, tako da bo za prijavo potreben ključ ssh. Pomembno je omeniti, da če onemogočite preverjanje pristnosti gesla in javni ključ ni bil pravilno nameščen, se boste zaklenili iz svojega strežnika. Priporočljivo je, da najprej preizkusite ključ, preden se sploh odjavite iz korenskega uporabnika.

Trenutno smo prijavljeni v našega root uporabnika, zato bomo uredili sshd_config:

nano /etc/ssh/sshd_config

Iskali bomo 3 vrednosti, da se prepričamo, ali je OpenSSH pravilno konfiguriran.

  • PasswordAuthentication
  • PubkeyAuthentication
  • ChallengeResponseAuthentication

Te vrednosti lahko poiščemo s pritiskom na CTRL+ W.

Vrednosti je treba nastaviti na naslednje:

PasswordAuthentication  no
ChallengeResponseAuthentication  no
PubkeyAuthentication  yes

Če so vrednosti komentirane, odstranite #na začetku vrstice in se prepričajte, da so vrednosti teh spremenljivk, kot je prikazano zgoraj. Ko ste spremenili tiste spremenljivke, shranite in zaprite urejevalnik, s CTRL+ O, ENTERin na koncu CTRL+ X.

Zdaj bomo znova naložili sshdz naslednjim ukazom:

systemctl reload sshd

Zdaj lahko preizkusimo prijavo. Prepričajte se, da se še niste odjavili iz korenske seje, in odprite novo okno ssh ter se povežite s svojim ključem ssh, ki je povezan s povezavo.

V PuTTY je to pod Connection-> SSH-> Auth.

Prebrskajte in poiščite svoj zasebni ključ za preverjanje pristnosti, saj bi ga morali shraniti pri ustvarjanju ključa ssh.

Povežite se s strežnikom z zasebnim ključem kot avtentikacijo. Zdaj boste prijavljeni v svoj virtualni stroj Vultr VC2.

Opomba: Če ste med generiranjem ključa ssh dodali geslo, boste pozvani k njemu. To se popolnoma razlikuje od gesla vašega dejanskega uporabnika na virtualnem stroju.

Nastavite osnovni požarni zid

Konfigurirajte UFW

Najprej bomo začeli z namestitvijo UFW, če še ni na virtualnem stroju. Dober način za preverjanje je z naslednjim ukazom:

sudo ufw status

Če je nameščen UFW, bo izpisal Status:inactive. Če ni nameščen, boste dobili navodila, da to storite.

Namestimo ga lahko s tem ukazom:

sudo apt-get install ufw -y

Zdaj bomo dovolili vrata SSH 22v našem požarnem zidu:

sudo ufw allow 22

Druga možnost je, da dovolite OpenSSH:

sudo ufw allow OpenSSH

Vsak od zgornjih ukazov bo deloval.

Zdaj, ko smo dovolili vrata prek našega požarnega zidu, lahko omogočimo UFW:

sudo ufw enable

Vprašali vas bodo, ali ste prepričani, da želite izvesti to operacijo. Vnos, ki ymu sledi, ENTERbo omogočil požarni zid:

porthorian@MEANStack:~$ sudo ufw enable
Command may disrupt existing ssh connections. Proceed with operation? y

Opomba: Če niste dovolili OpenSSH ali vrat 22, se boste zaklenili iz svojega virtualnega stroja. Preden omogočite UFW, se prepričajte, da je eden od teh dovoljen.

Ko je požarni zid omogočen, boste še vedno povezani s svojim primerkom. Zdaj bomo dvakrat preverili naš požarni zid z istim ukazom kot prej:

sudo ufw status

Videli boste nekaj podobnega naslednjemu izhodu:

porthorian@MEANStack:~$ sudo ufw status
Status: active

To                         Action      From
--                         ------      ----
22                         ALLOW       Anywhere
22 (v6)                    ALLOW       Anywhere (v6)

Konfiguriranje požarnega zidu Vultr

Za dodatno zaščito našega strežnika bomo uporabili požarni zid Vultr. Prijavite se v svoj račun . Ko ste prijavljeni, se boste pomaknili na zavihek požarnega zidu, ki se nahaja na vrhu zaslona:

Začetna konfiguracija varnega strežnika za Ubuntu 18.04

Zdaj bomo dodali novo skupino požarnih zidov. To nam bo omogočilo, da določimo, katera vrata lahko celo dosežejo naš požarni zid UFW, kar nam zagotavlja dvojno plast varnosti:

Začetna konfiguracija varnega strežnika za Ubuntu 18.04

Vultr vas bo zdaj vprašal, kako boste poimenovali požarni zid z uporabo polja »Opis«. Prepričajte se, da ste opisali, kaj bodo počeli strežniki v tej skupini požarnih zidov, za lažje upravljanje v prihodnosti. Zaradi te vadnice ga bomo poimenovali test. Če želite, lahko opis vedno spremenite pozneje.

Najprej bomo morali pridobiti naš IP naslov. Razlog, zakaj to počnemo neposredno, je, da če vaš naslov IP ni statičen in se nenehno spreminja, se lahko preprosto prijavite v svoj račun Vultr in spremenite naslov IP.

Tudi zato nismo zahtevali naslova IP na požarnem zidu UFW. Poleg tega omejuje uporabo požarnega zidu vašega virtualnega stroja, da ne bi filtriral vseh drugih vrat, in dovoli požarnemu zidu Vultr, da to upravlja. To omejuje obremenitev celotnega filtriranja prometa na vašem primerku.

Uporabite Vultrovo omrežno ogledalo, da poiščete svoj IP naslov.

Zdaj, ko imamo svoj naslov IP, bomo našemu na novo ustvarjenemu požarnemu zidu dodali pravilo IPV4:

Začetna konfiguracija varnega strežnika za Ubuntu 18.04

Ko vnesete naslov IP, kliknite +simbol, da dodate svoj IP naslov v požarni zid.

Vaša skupina požarnega zidu bo videti takole:

Začetna konfiguracija varnega strežnika za Ubuntu 18.04

Zdaj, ko imamo naš IP pravilno vezan v skupini požarnega zidu, moramo povezati naš primerek Vultr. Na levi strani boste videli zavihek z napisom "Povezani primerki":

Začetna konfiguracija varnega strežnika za Ubuntu 18.04

Ko ste na strani, boste videli spustni meni s seznamom primerov vašega strežnika:

Začetna konfiguracija varnega strežnika za Ubuntu 18.04

Kliknite spustni meni in izberite svoj primer. Nato, ko ste pripravljeni dodati primerek v skupino požarnega zidu, kliknite +simbol.

Čestitamo, uspešno ste zavarovali svoj virtualni stroj Vultr VC2. To vam daje dobro osnovo za zelo osnovno varnostno plast, ne da bi vas skrbelo, da bi nekdo poskušal grobo vsiliti vaš primer.


Namestite Plesk na CentOS 7

Namestite Plesk na CentOS 7

Uporaba drugega sistema? Plesk je lastniška nadzorna plošča spletnega gostitelja, ki uporabnikom omogoča upravljanje svojih osebnih in/ali strank spletnih mest, baz podatkov

Namestite Lets Encrypt SSL v aplikacijo WordPress z enim klikom

Namestite Lets Encrypt SSL v aplikacijo WordPress z enim klikom

Uvod Lets Encrypt je storitev overitelja potrdil, ki ponuja brezplačna potrdila TLS/SSL. Certbot poenostavlja postopek namestitve,

Ustvarjanje bloga Jekyll v Ubuntu 16.04

Ustvarjanje bloga Jekyll v Ubuntu 16.04

Uporaba drugega sistema? Jekyll je odlična alternativa WordPressu za bloganje ali deljenje vsebine. Ne zahteva nobenih baz podatkov in je zelo enostaven i

Kako nastaviti nenadzorovane nadgradnje na Debian 9 (raztegni)

Kako nastaviti nenadzorovane nadgradnje na Debian 9 (raztegni)

Uporaba drugega sistema? Če kupite strežnik Debian, morate vedno imeti najnovejše varnostne popravke in posodobitve, ne glede na to, ali spite ali ne

Kako namestiti in konfigurirati PHP 7.0 ali PHP 7.1 na Ubuntu 16.04

Kako namestiti in konfigurirati PHP 7.0 ali PHP 7.1 na Ubuntu 16.04

PHP in sorodni paketi so najpogosteje uporabljene komponente pri uvajanju spletnega strežnika. V tem članku se bomo naučili, kako nastaviti PHP 7.0 ali PHP 7.1 o

Kako namestiti Squid Proxy na CentOS

Kako namestiti Squid Proxy na CentOS

Squid je priljubljen brezplačen program za Linux, ki vam omogoča ustvarjanje spletnega proxyja za posredovanje. V tem priročniku boste videli, kako namestiti Squid na CentOS, da vas obrne

Kako namestiti Lighttpd (LLMP Stack) na CentOS 6

Kako namestiti Lighttpd (LLMP Stack) na CentOS 6

Uvod Lighttpd je razdelek Apache, katerega namen je biti veliko manj intenziven vir. Je lahek, od tod tudi njegovo ime, in je precej preprost za uporabo. Namestite

Tri brezplačne nadzorne plošče strežnika (hitra namestitev)

Tri brezplačne nadzorne plošče strežnika (hitra namestitev)

1. Virtualmin/Webmin Virtualmin je zmogljiva in prilagodljiva nadzorna plošča za spletno gostovanje za sisteme Linux in UNIX, ki temelji na dobro znani odprtokodni spletni bazi

Nastavitev aplikacije Yii na Ubuntu 14.04

Nastavitev aplikacije Yii na Ubuntu 14.04

Yii je okvir PHP, ki vam omogoča hitrejši in preprostejši razvoj aplikacij. Namestitev Yii na Ubuntu je enostavna, saj se boste naučili natančno

Uporaba zaslona v Ubuntu 14.04

Uporaba zaslona v Ubuntu 14.04

Screen je aplikacija, ki omogoča večkratno uporabo terminalskih sej v enem oknu. To vam omogoča simulacijo več terminalskih oken, kjer je ma

Nastavite svoj DNS strežnik na Debian/Ubuntu

Nastavite svoj DNS strežnik na Debian/Ubuntu

Ta vadnica pojasnjuje, kako nastaviti strežnik DNS z uporabo Bind9 v Debianu ali Ubuntuju. V celotnem članku ustrezno nadomestite your-domain-name.com. Ob th

Uporaba Logrotate za upravljanje dnevniških datotek

Uporaba Logrotate za upravljanje dnevniških datotek

Uvod Logrotate je pripomoček za Linux, ki poenostavlja upravljanje dnevniških datotek. Običajno se izvaja enkrat na dan prek opravila cron in upravlja bazo dnevnikov

Konfiguriranje statičnega omrežja in IPv6 na CentOS 7

Konfiguriranje statičnega omrežja in IPv6 na CentOS 7

VULTR je pred kratkim naredil spremembe na svoji strani in zdaj bi moralo vse delovati v redu iz škatle z omogočenim NetworkManagerjem. Če želite onemogočiti

Spreminjanje Icinga2 za uporabo modela Master/Client na CentOS 6 ali CentOS 7

Spreminjanje Icinga2 za uporabo modela Master/Client na CentOS 6 ali CentOS 7

Icinga2 je zmogljiv sistem za spremljanje in če se uporablja v modelu glavni-odjemalec, lahko nadomesti potrebo po nadzornih pregledih, ki temeljijo na NRPE. Glavni naročnik

Nastavite Red5 Media Server na Ubuntu 16.04

Nastavite Red5 Media Server na Ubuntu 16.04

Uporaba drugega sistema? Red5 je odprtokodni medijski strežnik, implementiran v Javi, ki vam omogoča zagon večuporabniških aplikacij Flash, kot je prenos v živo

Prevedite in namestite Nginx z modulom PageSpeed ​​na Debian 8

Prevedite in namestite Nginx z modulom PageSpeed ​​na Debian 8

V tem članku bomo videli, kako prevesti in namestiti Nginx mainline iz uradnih virov Nginxa z modulom PageSpeed, ki vam omogoča

Kako namestiti Apache Cassandra 3.11.x na Ubuntu 16.04 LTS

Kako namestiti Apache Cassandra 3.11.x na Ubuntu 16.04 LTS

Uporaba drugega sistema? Apache Cassandra je brezplačen in odprtokodni sistem za upravljanje baz podatkov NoSQL, ki je zasnovan tako, da zagotavlja razširljivost, visoko

Kako namestiti Apache Cassandra 3.11.x na CentOS 7

Kako namestiti Apache Cassandra 3.11.x na CentOS 7

Uporaba drugega sistema? Apache Cassandra je brezplačen in odprtokodni sistem za upravljanje baz podatkov NoSQL, ki je zasnovan tako, da zagotavlja razširljivost, visoko

Kako namestiti Vanilla Forum na Ubuntu 16.04

Kako namestiti Vanilla Forum na Ubuntu 16.04

Uporaba drugega sistema? Vanilla forum je odprtokodna forumska aplikacija, napisana v PHP. Je popolnoma prilagodljiv, enostaven za uporabo in podpira zunanjost

Kako namestiti Kanboard na Ubuntu 18.04 LTS

Kako namestiti Kanboard na Ubuntu 18.04 LTS

Uporaba drugega sistema? Uvod Kanboard je brezplačen in odprtokodni program za vodenje projektov, ki je zasnovan za olajšanje in vizualizacijo

Vzpon strojev: aplikacije AI v resničnem svetu

Vzpon strojev: aplikacije AI v resničnem svetu

Umetna inteligenca ni v prihodnosti, tukaj je prav v sedanjosti. V tem blogu preberite, kako so aplikacije umetne inteligence vplivale na različne sektorje.

DDOS napadi: kratek pregled

DDOS napadi: kratek pregled

Ste tudi vi žrtev DDOS napadov in ste zmedeni glede načinov preprečevanja? Preberite ta članek, če želite rešiti svoja vprašanja.

Ste se kdaj vprašali, kako hekerji zaslužijo denar?

Ste se kdaj vprašali, kako hekerji zaslužijo denar?

Morda ste že slišali, da hekerji zaslužijo veliko denarja, a ste se kdaj vprašali, kako zaslužijo takšen denar? razpravljajmo.

Revolucionarni Googlovi izumi, ki vam bodo olajšali življenje.

Revolucionarni Googlovi izumi, ki vam bodo olajšali življenje.

Ali želite videti revolucionarne izume Googla in kako so ti izumi danes spremenili življenje vsakega človeka? Nato preberite v blogu in si oglejte Googlove izume.

Friday Essential: Kaj se je zgodilo z avtomobili, ki jih poganja umetna inteligenca?

Friday Essential: Kaj se je zgodilo z avtomobili, ki jih poganja umetna inteligenca?

Koncept samovozečih avtomobilov, ki zapeljejo na ceste s pomočjo umetne inteligence, so sanje, ki jih imamo že nekaj časa. A kljub številnim obljubam jih ni nikjer. Preberite ta blog, če želite izvedeti več…

Tehnološka singularnost: oddaljena prihodnost človeške civilizacije?

Tehnološka singularnost: oddaljena prihodnost človeške civilizacije?

Ker se znanost hitro razvija in prevzame veliko naših prizadevanj, se povečuje tudi tveganje, da se podvržemo nerazložljivi singularnosti. Preberite, kaj bi za nas lahko pomenila singularnost.

Razvoj shranjevanja podatkov – Infografika

Razvoj shranjevanja podatkov – Infografika

Metode shranjevanja podatkov so se lahko razvijale od rojstva podatkov. Ta blog pokriva razvoj shranjevanja podatkov na podlagi infografike.

Funkcionalnosti slojev referenčne arhitekture velikih podatkov

Funkcionalnosti slojev referenčne arhitekture velikih podatkov

Preberite blog, če želite na najpreprostejši način spoznati različne plasti v arhitekturi velikih podatkov in njihove funkcionalnosti.

6 neverjetnih prednosti pametnih naprav za dom v našem življenju

6 neverjetnih prednosti pametnih naprav za dom v našem življenju

V tem digitalno vodenem svetu so pametne naprave za dom postale ključni del življenja. Tukaj je nekaj neverjetnih prednosti pametnih naprav za dom o tem, kako naredijo naše življenje vredno življenja in poenostavijo.

Posodobitev dodatka macOS Catalina 10.15.4 povzroča več težav kot jih rešuje

Posodobitev dodatka macOS Catalina 10.15.4 povzroča več težav kot jih rešuje

Pred kratkim je Apple izdal macOS Catalina 10.15.4 dopolnilno posodobitev za odpravo težav, vendar se zdi, da posodobitev povzroča več težav, ki vodijo do opečenja računalnikov Mac. Preberite ta članek, če želite izvedeti več