How to Install Tiny Tiny RSS Reader on a FreeBSD 11 FAMP VPS
Using a Different System? Tiny Tiny RSS Reader is a free and open source self-hosted web-based news feed (RSS/Atom) reader and aggregator, designed to allo
NodeBB je programska oprema za 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 FreeBSD 12 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 FreeBSD.
uname -ro
# FreeBSD 12.0-RELEASE
Prepričajte se, da je vaš sistem FreeBSD posodobljen.
freebsd-update fetch install
pkg update && pkg upgrade -y
Namestite potrebne pakete, če niso prisotni v vašem sistemu.
pkg install -y sudo vim unzip wget git bash socat gcc8 pkgconf vips
Ustvarite nov uporabniški račun s svojim želenim uporabniškim imenom (uporabili bomo johndoe
).
adduser
# Username: johndoe
# Full name: John Doe
# Uid (Leave empty for default): <Enter>
# Login group [johndoe]: <Enter>
# Login group is johndoe. Invite johndoe into other groups? []: wheel
# Login class [default]: <Enter>
# Shell (sh csh tcsh nologin) [sh]: bash
# Home directory [/home/johndoe]: <Enter>
# Home directory permissions (Leave empty for default): <Enter>
# Use password-based authentication? [yes]: <Enter>
# Use an empty password? (yes/no) [no]: <Enter>
# Use a random password? (yes/no) [no]: <Enter>
# Enter password: your_secure_password
# Enter password again: your_secure_password
# Lock out the account after creation? [no]: <Enter>
# OK? (yes/no): yes
# Add another user? (yes/no): no
# Goodbye!
Zaženite visudo
ukaz in razkomentirajte %wheel ALL=(ALL) ALL
vrstico, da omogočite članom wheel
skupine, da izvedejo kateri koli ukaz.
visudo
# Uncomment by removing hash (#) sign
# %wheel ALL=(ALL) ALL
Zdaj preklopite na novo ustvarjenega uporabnika z su
.
su - johndoe
OPOMBA: Zamenjajte johndoe
z vašim uporabniškim imenom.
Nastavite časovni pas.
sudo tzsetup
NodeBB poganja Node.js, zato ga je treba namestiti. Priporočljiva je namestitev trenutne LTS različice Node.js.
Namestite Node.js in npm.
sudo pkg install -y node10 npm-node10
Preverite različice.
node -v && npm -v
# v10.15.3
# 6.9.0
MongoDB je privzeta baza podatkov za NodeBB.
Namestite MongoDB.
sudo pkg install -y mongodb40
Preverite različico.
mongo --version | head -n 1 && mongod --version | head -n 1
# MongoDB shell version v4.0.6
# db version v4.0.6
Omogočite in zaženite MongoDB.
sudo sysrc mongod_enable=yes
sudo service mongod start
Ustvarite bazo podatkov in uporabnika za NodeBB.
Najprej se povežite 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 zagotovite, da se lahko prej ustvarjeni skrbniški uporabnik poveže.
sudo service mongod restart
mongo -u admin -p your_password --authenticationDatabase=admin
Namestite Nginx.
sudo pkg install -y nginx
Preverite različico.
nginx -v
# nginx version: nginx/1.14.2
Omogočite in zaženite Nginx.
sudo sysrc nginx_enable=yes
sudo service nginx start
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 /usr/local/etc/nginx/nodebb.conf
in ga napolnite s spodnjo osnovno konfiguracijo povratnega proxyja.
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.
Shranite datoteko in zapustite s :+ W+ Q.
Zdaj moramo vključiti nodebb.conf
v glavno nginx.conf
datoteko.
Zaženite sudo vim /usr/local/etc/nginx/nginx.conf
in dodajte naslednjo vrstico v http {}
blok.
include nodebb.conf;
Preverite konfiguracijo.
sudo nginx -t
Ponovno naložite Nginx.
sudo service nginx reload
Zaščita vašega foruma s HTTPS ni potrebna, vendar bo zavarovala promet na vašem spletnem mestu. Acme.sh je čista unix programska oprema 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 ~
Preverite različico.
/etc/letsencrypt/acme.sh --version
# v2.8.1
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 service nginx reload" --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 service nginx reload" --keylength ec-256
Po zagonu zgornjih ukazov bodo vaši certifikati in ključi v:
/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 /usr/local/etc/nginx/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 service nginx reload
Ustvarite korenski imenik dokumenta.
sudo mkdir -p /usr/local/www/nodebb
Spremenite lastništvo /usr/local/www/nodebb
imenika v johndoe
.
sudo chown -R johndoe:johndoe /usr/local/www/nodebb
Pomaknite se do korenske mape dokumenta.
cd /usr/local/www/nodebb
Klonirajte najnovejši NodeBB v korensko mapo dokumenta.
git clone -b v1.11.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 svojega primerka foruma NodeBB.
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
Namestite PM2 globalno.
sudo npm install pm2 -g
Preverite različico.
pm2 -v
# 3.5.0
Pomaknite se do korena dokumenta NodeBB.
cd /usr/local/www/nodebb
Zaženite NodeBB prek PM2.
pm2 start app.js
Navedite postopek NodeBB.
pm2 ls
Odkrijte razpoložljiv init sistem.
pm2 startup
Kopirajte in prilepite izhod tega ukaza v CLI, da nastavite zagonski kavelj.
Shranite svoj seznam procesov.
pm2 save
To je to. Vaš primerek NodeBB je zdaj pripravljen in deluje.
Using a Different System? Tiny Tiny RSS Reader is a free and open source self-hosted web-based news feed (RSS/Atom) reader and aggregator, designed to allo
Uporaba drugega sistema? Wiki.js je brezplačna odprtokodna sodobna wiki aplikacija, zgrajena na Node.js, MongoDB, Git in Markdown. Izvorna koda Wiki.js je javna
Uporaba drugega sistema? Pagekit 1.0 CMS je lep, modularen, razširljiv in lahek, brezplačen in odprtokoden sistem za upravljanje vsebine (CMS) z
Uporaba drugega sistema? MODX Revolution je hiter, prilagodljiv, razširljiv, odprtokoden sistem za upravljanje vsebin (CMS) za podjetja, napisan v PHP. To i
Ta članek vas vodi skozi nastavitev OpenBSD 5.5 (64-bit) na KVM z Vultr VPS. 1. korak. Prijavite se v nadzorno ploščo Vultr. 2. korak. Kliknite RAZPOSTAVI
Uporaba drugega sistema? osTicket je odprtokodni sistem za izdajo vstopnic za podporo strankam. Izvorna koda osTicket je javno gostovana na Githubu. V tej vadnici
Uporaba drugega sistema? Flarum je brezplačna in odprtokodna programska oprema za forume naslednje generacije, ki naredi spletno razpravo zabavno. Izvorna koda Flarum gostuje o
Uporaba drugega sistema? TLS 1.3 je različica protokola Transport Layer Security (TLS), ki je bil objavljen leta 2018 kot predlagani standard v RFC 8446
Uvod WordPress je prevladujoči sistem za upravljanje vsebin na internetu. Poganja vse, od blogov do zapletenih spletnih mest z dinamično vsebino
Uporaba drugega sistema? Subrion 4.1 CMS je zmogljiv in prilagodljiv odprtokodni sistem za upravljanje vsebine (CMS), ki prinaša intuitivno in jasno vsebino.
Ta vadnica vam bo pokazala, kako konfigurirati storitev DNS, ki je enostavna za vzdrževanje, enostavna za konfiguriranje in ki je na splošno bolj varna kot klasični BIN
Sklad FEMP, ki je primerljiv s skladom LEMP v Linuxu, je zbirka odprtokodne programske opreme, ki je običajno nameščena skupaj, da omogoči FreeBS
MongoDB je vrhunska baza podatkov NoSQL, ki se pogosto uporablja v novejših spletnih aplikacijah. Zagotavlja visoko zmogljive poizvedbe, razdeljevanje in podvajanje
Uporaba drugega sistema? Monica je odprtokodni sistem za upravljanje osebnih odnosov. Pomislite na to kot na CRM (priljubljeno orodje, ki ga uporabljajo prodajne ekipe v th
Uvod Ta vadnica prikazuje OpenBSD kot rešitev za e-trgovino z uporabo PrestaShop in Apache. Apache je potreben, ker ima PrestaShop zapleten UR
Uporaba drugega sistema? Fork je odprtokodni CMS, napisan v PHP. Izvorna koda Forks gostuje na GitHubu. Ta priročnik vam bo pokazal, kako namestiti Fork CM
Uporaba drugega sistema? Directus 6.4 CMS je zmogljiv in prilagodljiv, brezplačen in odprtokoden Headless Content Management System (CMS), ki omogoča razvijalcem
VPS strežniki so pogosto tarča vsiljivcev. Pogosta vrsta napada se prikaže v sistemskih dnevnikih kot na stotine nepooblaščenih poskusov prijave ssh. Postavitev
Uvod OpenBSD 5.6 je predstavil nov demon, imenovan httpd, ki podpira CGI (prek FastCGI) in TLS. Za namestitev novega http ni potrebno dodatno delo
Ta vadnica vam bo pokazala, kako namestiti skupinsko programsko opremo iRedMail na novo namestitev FreeBSD 10. Uporabiti morate strežnik z vsaj enim gigabajtom o
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č