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
NodeBB je forum, ki temelji na Node.js. Uporablja spletne vtičnice za takojšnje interakcije in obvestila v realnem času. Izvorna koda NodeBB je javno gostovana na Githubu . Ta vodnik vas bo vodil skozi postopek namestitve NodeBB na novem primerku Debian 9 Vultr z uporabo Node.js, MongoDB kot baze podatkov, Nginx kot povratnega proxyja in Acme.sh za potrdila SSL.
NodeBB zahteva, da je nameščena naslednja programska oprema:
A
/ AAAA
nastavljenimi zapisiPreverite različico Debiana.
lsb_release -ds
# Debian GNU/Linux 9.4 (stretch)
Prepričajte se, da je vaš sistem posodobljen.
apt update && apt upgrade -y
Namestite potrebne pakete.
apt install -y sudo dirmngr git build-essential apt-transport-https
Ustvarite nov non-root
uporabniški račun z sudo
dostopom in preklopite nanj.
adduser johndoe --gecos "John Doe"
usermod -aG sudo johndoe
su - johndoe
OPOMBA : Zamenjajte johndoe
s svojim uporabniškim imenom.
Nastavite časovni pas.
sudo dpkg-reconfigure tzdata
NodeBB poganja Node.js, zato ga je treba namestiti. Priporočljiva je namestitev trenutne LTS različice Node.js.
Namestite Node.js iz repozitorija NodeSource.
curl -sL https://deb.nodesource.com/setup_10.x | sudo -E bash -
sudo apt install -y nodejs
Preverite namestitev Node.js in npm.
node -v && npm -v
# v10.15.0
# 5.6.0
MongoDB je privzeta baza podatkov za NodeBB.
Namestite MongoDB iz uradnega repozitorija MongoDB.
sudo apt-key adv --keyserver hkp://keyserver.ubuntu.com:80 --recv 9DA31620334BD75D9DCB49F368818C72E52529D4
echo "deb https://repo.mongodb.org/apt/debian stretch/mongodb-org/4.0 main" | sudo tee /etc/apt/sources.list.d/mongodb-org-4.0.list
sudo apt update
sudo apt install -y mongodb-org
Preverite različico.
mongo --version | head -n 1 && mongod --version | head -n 1
# MongoDB shell version v4.00
# db version v4.0.0
Zaženite in omogočite MongoDB.
sudo systemctl start mongod.service
sudo systemctl enable mongod.service
Ustvarite bazo podatkov MongoDB in uporabnika za NodeBB.
Povežite se z MongoDB.
mongo
Preklopite na vgrajeno admin
bazo podatkov.
> use admin
Ustvarite skrbniškega uporabnika.
> db.createUser( { user: "admin", pwd: "<Enter a secure password>", roles: [ { role: "readWriteAnyDatabase", db: "admin" }, { role: "userAdminAnyDatabase", db: "admin" } ] } )
OPOMBA: Zamenjaj nadomestnega mesta <Enter a secure password>
s svojim izbranim geslom.
Dodajte novo bazo podatkov z imenom nodebb
.
> use nodebb
Baza podatkov bo ustvarjena in kontekst preklopljen na nodebb
. Nato ustvarite nodebb
uporabnika z ustreznimi privilegiji.
> db.createUser( { user: "nodebb", pwd: "<Enter a secure password>", roles: [ { role: "readWrite", db: "nodebb" }, { role: "clusterMonitor", db: "admin" } ] } )
OPOMBA: Ponovno zamenjajte označbo mesta <Enter a secure password>
s svojim izbranim geslom.
Zapustite lupino Mongo.
> quit()
Znova zaženite MongoDB in preverite, ali se lahko prej ustvarjeni skrbniški uporabnik poveže.
sudo systemctl restart mongod.service
mongo -u admin -p your_password --authenticationDatabase=admin
Namestite najnovejšo glavno različico Nginxa iz uradnega skladišča Nginxa.
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/debian/ $(lsb_release -sc) nginx\ndeb-src https://nginx.org/packages/mainline/debian/ $(lsb_release -sc) nginx\n" >> /etc/apt/sources.list.d/nginx_mainline.list
exit
sudo apt update
sudo apt install -y nginx
Preverite različico.
sudo nginx -v
# nginx version: nginx/1.15.0
Omogočite in zaženite Nginx.
sudo systemctl enable nginx.service
sudo systemctl start nginx.service
NodeBB privzeto deluje na vratih 4567
. Da bi se izognili tipkanju http://example.com:4567
, bomo Nginx konfigurirali kot povratni proxy za aplikacijo NodeBB. Vsaka zahteva za vrata 80
ali 443
(če je uporabljen SSL) bo posredovana na vrata 4567
.
Zaženite ga sudo vim /etc/nginx/conf.d/nodebb.conf
in ga zapolnite z osnovno konfiguracijo povratnega proxyja, prikazano spodaj.
server {
listen [::]:80;
listen 80;
server_name forum.example.com;
root /usr/share/nginx/html;
client_max_body_size 50M;
location /.well-known/acme-challenge/ {
allow all;
}
location / {
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header X-Forwarded-Proto $scheme;
proxy_set_header Host $http_host;
proxy_hide_header X-Powered-By;
proxy_set_header X-Nginx-Proxy true;
proxy_pass http://127.0.0.1:4567;
proxy_redirect off;
# Socket.IO Support
proxy_http_version 1.1;
proxy_set_header Upgrade $http_upgrade;
proxy_set_header Connection "upgrade";
}
}
V zgornji konfiguraciji posodobite server_name
direktivo s svojo domeno/imenom gostitelja.
Preverite konfiguracijo.
sudo nginx -t
Ponovno naložite Nginx.
sudo systemctl reload nginx.service
Zaščita vašega foruma s HTTPS ni potrebna, vendar bo zavarovala promet na vašem spletnem mestu. Acme.sh je čista programska oprema Unixove lupine za pridobivanje SSL certifikatov iz Let's Encrypt z nič odvisnostmi.
Prenesite in namestite 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
Preverite različico.
acme.sh --version
# v2.7.9
Pridobite certifikate RSA in ECDSA za forum.example.com
.
# RSA 2048
sudo /etc/letsencrypt/acme.sh --issue --home /etc/letsencrypt -d forum.example.com --webroot /usr/share/nginx/html --reloadcmd "sudo systemctl reload nginx.service" --accountemail [email protected] --ocsp-must-staple --keylength 2048
# ECDSA/ECC P-256
sudo /etc/letsencrypt/acme.sh --issue --home /etc/letsencrypt -d forum.example.com --webroot /usr/share/nginx/html --reloadcmd "sudo systemctl reload nginx.service" --accountemail [email protected] --ocsp-must-staple --keylength ec-256
Po zagonu zgornjih ukazov bodo vaši certifikati in ključi v naslednjih imenikih:
/etc/letsencrypt/forum.example.com
/etc/letsencrypt/forum.example.com_ecc
Po pridobitvi potrdil od Let's Encrypt moramo Nginx konfigurirati za njihovo uporabo.
Zaženite sudo vim /etc/nginx/conf.d/nodebb.conf
znova in konfigurirajte Nginx kot povratni proxy HTTPS.
server {
listen [::]:443 ssl http2;
listen 443 ssl http2;
listen [::]:80;
listen 80;
server_name forum.example.com;
root /usr/share/nginx/html;
client_max_body_size 50M;
location /.well-known/acme-challenge/ {
allow all;
}
# RSA
ssl_certificate /etc/letsencrypt/forum.example.com/fullchain.cer;
ssl_certificate_key /etc/letsencrypt/forum.example.com/forum.example.com.key;
# ECDSA
ssl_certificate /etc/letsencrypt/forum.example.com_ecc/fullchain.cer;
ssl_certificate_key /etc/letsencrypt/forum.example.com_ecc/forum.example.com.key;
location / {
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header X-Forwarded-Proto $scheme;
proxy_set_header Host $http_host;
proxy_set_header X-NginX-Proxy true;
proxy_pass http://127.0.0.1:4567;
proxy_redirect off;
# Socket.IO Support
proxy_http_version 1.1;
proxy_set_header Upgrade $http_upgrade;
proxy_set_header Connection "upgrade";
}
}
Preverite konfiguracijo.
sudo nginx -t
Ponovno naložite Nginx.
sudo systemctl reload nginx.service
Ustvarite korenski imenik dokumenta.
sudo mkdir -p /var/www/nodebb
Spremenite lastništvo /var/www/nodebb
imenika v johndoe
.
sudo chown -R johndoe:johndoe /var/www/nodebb
Pomaknite se do korenske mape dokumenta.
cd /var/www/nodebb
Klonirajte najnovejši NodeBB v korensko mapo dokumenta.
git clone -b v1.10.x https://github.com/NodeBB/NodeBB.git .
Zaženite ukaz za namestitev NodeBB in odgovorite na vsako vprašanje, ko ste pozvani.
./nodebb setup
Ko je namestitev NodeBB končana, zaženite ./nodebb start
ročni zagon strežnika NodeBB.
./nodebb start
Po tem ukazu boste lahko v spletnem brskalniku dostopali do foruma.
Ko se zažene prek ./nodebb start
, se NodeBB ne bo samodejno znova zagnal, ko se sistem znova zažene. Da bi se temu izognili, bomo morali NodeBB nastaviti kot sistemsko storitev.
Če se izvaja, ustavite NodeBB.
./nodebb stop
Ustvarite novega nodebb
uporabnika:
sudo adduser nodebb
Spremenite lastništvo /var/www/nodebb
imenika v nodebb
.
sudo chown -R nodebb:nodebb /var/www/nodebb
Ustvarite nodebb.service
konfiguracijsko datoteko enote systemd. Ta datoteka enote bo obravnavala zagon NodeBB deamon. Zaženite sudo vim /etc/systemd/system/nodebb.service
in napolnite datoteko z naslednjo vsebino:
[Unit]
Description=NodeBB
Documentation=https://docs.nodebb.org
After=system.slice multi-user.target mongod.service
[Service]
Type=forking
User=nodebb
StandardOutput=syslog
StandardError=syslog
SyslogIdentifier=nodebb
Environment=NODE_ENV=production
WorkingDirectory=/var/www/nodebb
PIDFile=/var/www/nodebb/pidfile
ExecStart=/usr/bin/env node loader.js
Restart=always
[Install]
WantedBy=multi-user.target
OPOMBA: Nastavite uporabniško ime in poti imenika glede na izbrana imena.
Omogoči nodebb.service
ob ponovnem zagonu in takoj zaženi nodebb.service
.
sudo systemctl enable nodebb.service
sudo systemctl start nodebb.service
Preverite nodebb.service
stanje.
sudo systemctl status nodebb.service
sudo systemctl is-enabled nodebb.service
To je to. Vaš primerek NodeBB je zdaj pripravljen in deluje.
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
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
V tem članku bomo videli, kako prevesti in namestiti Nginx mainline iz uradnih virov Nginxa z modulom PageSpeed, ki vam omogoča
Uporaba drugega sistema? Uvod Kanboard je brezplačen in odprtokodni program za vodenje projektov, ki je zasnovan za olajšanje in vizualizacijo
Uporaba drugega sistema? Gitea je alternativni odprtokodni sistem za nadzor različic, ki ga poganja Git. Gitea je napisana v Golangu in je
Uvod Lynis je brezplačno, odprtokodno orodje za revizijo sistema, ki ga uporabljajo številni sistemski skrbniki za preverjanje integritete in utrjevanje svojih sistemov. jaz
Uporaba drugega sistema? Thelia je odprtokodno orodje za ustvarjanje spletnih strani e-poslovanja in upravljanje spletnih vsebin, napisanih v PHP. Izvorna koda Thelia i
Kaj potrebujete Vultr VPS z vsaj 1 GB RAM-a. SSH dostop (z root/administrativnimi pravicami). 1. korak: Namestitev BungeeCord Najprej najprej
Golang je programski jezik, ki ga je razvil Google. Zahvaljujoč svoji vsestranskosti, preprostosti in zanesljivosti je Golang postal eden najbolj priljubljenih
Če ste pozabili korensko geslo MySQL, ga lahko ponastavite tako, da sledite korakom v tem članku. Postopek je precej preprost in deluje na njih
V tem priročniku bomo postavili strežnik iger Counter Strike: Source na Debian 7. Ti ukazi so bili preizkušeni v Debianu 7, vendar bi morali delovati tudi o
V tem priročniku se boste naučili, kako nastaviti strežnik Unturned 2.2.5 na Vultr VPS z Debianom 8. Opomba: To je urejena različica Unturned, ki ne
V tej vadnici se boste naučili, kako namestiti Cachet v Debian 8. Cachet je zmogljiv odprtokodni sistem strani s stanjem. Namestitev Ta vadnica se nadaljuje
Uvod V tem zapisu si oglejte, kako varnostno kopirati več baz podatkov MySQL ali MariaDB, ki se nahajajo na istem računalniku z uporabo bash skripta po meri.
Ta članek vas bo naučil, kako nastaviti chroot jail v Debianu. Predvidevam, da uporabljate Debian 7.x. Če uporabljate Debian 6 ali 8, bo to morda delovalo, bu
Using a Different System? Reader Self 3.5 is a simple and flexible, free and open source, self-hosted RSS reader and Google Reader alternative. Reader Sel
Uporaba drugega sistema? Backdrop CMS 1.8.0 je preprost in prilagodljiv, mobilnim prijazen, brezplačen in odprtokoden sistem za upravljanje vsebine (CMS), ki nam omogoča
V tej vadnici bomo namestili SteamCMD. SteamCMD lahko uporabite za prenos in namestitev številnih strežnikov za igre Steam, kot je Counter-Strike: Global Offensiv
Kot morda veste, se skladišča Debian posodabljajo zelo počasi. V času pisanja sta izdani različici Pythona na 2.7.12 in 3.5.2, vendar v skladišču Debian 8
Samba je odprtokodna rešitev, ki uporabnikom omogoča hitro in varno nastavitev skupne rabe datotek in tiska. V tem članku bom obravnaval, kako nastaviti Samba wit
Umetna inteligenca ni v prihodnosti, tukaj je prav v sedanjosti. V tem blogu preberite, kako so aplikacije umetne inteligence vplivale na različne sektorje.
Ste tudi vi žrtev DDOS napadov in ste zmedeni glede načinov preprečevanja? Preberite ta članek, če želite rešiti svoja vprašanja.
Morda ste že slišali, da hekerji zaslužijo veliko denarja, a ste se kdaj vprašali, kako zaslužijo takšen denar? razpravljajmo.
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.
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č…
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.
Metode shranjevanja podatkov so se lahko razvijale od rojstva podatkov. Ta blog pokriva razvoj shranjevanja podatkov na podlagi infografike.
Preberite blog, če želite na najpreprostejši način spoznati različne plasti v arhitekturi velikih podatkov in njihove funkcionalnosti.
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.
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č