Hur man installerar Tiny Tiny RSS Reader på en FreeBSD 11 FAMP VPS
Använder du ett annat system? Tiny Tiny RSS Reader är en gratis och öppen källkod, webbaserat nyhetsflöde (RSS/Atom) läsare och aggregator, utformad för att
NodeBB är en Node.js-baserad forummjukvara. Den använder webbsockets för omedelbar interaktion och realtidsmeddelanden. NodeBB-källkoden är offentligt värd på Github . Den här guiden leder dig genom installationsprocessen för NodeBB på en ny FreeBSD 12 Vultr-instans, genom att använda Node.js, MongoDB som en databas, Nginx som en omvänd proxy och Acme.sh för SSL-certifikat.
NodeBB kräver att följande programvara är installerad:
A
/ AAAA
poster inställdaKontrollera FreeBSD-versionen.
uname -ro
# FreeBSD 12.0-RELEASE
Se till att ditt FreeBSD-system är uppdaterat.
freebsd-update fetch install
pkg update && pkg upgrade -y
Installera nödvändiga paket om de inte finns på ditt system.
pkg install -y sudo vim unzip wget git bash socat gcc8 pkgconf vips
Skapa ett nytt användarkonto med ditt föredragna användarnamn (vi kommer att använda 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!
Kör visudo
kommandot och avkommentera %wheel ALL=(ALL) ALL
raden för att tillåta medlemmar i wheel
gruppen att utföra vilket kommando som helst.
visudo
# Uncomment by removing hash (#) sign
# %wheel ALL=(ALL) ALL
Byt nu till din nyskapade användare med su
.
su - johndoe
OBS: Ersätt johndoe
med ditt användarnamn.
Ställ in tidszonen.
sudo tzsetup
NodeBB drivs av Node.js, och därför måste den installeras. Installation av den aktuella LTS-versionen av Node.js rekommenderas.
Installera Node.js och npm.
sudo pkg install -y node10 npm-node10
Kontrollera versionerna.
node -v && npm -v
# v10.15.3
# 6.9.0
MongoDB är standarddatabasen för NodeBB.
Installera MongoDB.
sudo pkg install -y mongodb40
Kontrollera versionen.
mongo --version | head -n 1 && mongod --version | head -n 1
# MongoDB shell version v4.0.6
# db version v4.0.6
Aktivera och starta MongoDB.
sudo sysrc mongod_enable=yes
sudo service mongod start
Skapa en databas och användare för NodeBB.
Anslut till MongoDB först.
mongo
Byt till den inbyggda admin
databasen.
> use admin
Skapa en administrativ användare.
> db.createUser( { user: "admin", pwd: "<Enter a secure password>", roles: [ { role: "readWriteAnyDatabase", db: "admin" }, { role: "userAdminAnyDatabase", db: "admin" } ] } )
OBS: Byt ut platshållaren <Enter a secure password>
med ditt eget valda lösenord.
Lägg till en ny databas som heter nodebb
.
> use nodebb
Databasen kommer att skapas och sammanhanget växlas till nodebb
. Skapa sedan nodebb
användaren med lämpliga privilegier.
> db.createUser( { user: "nodebb", pwd: "<Enter a secure password>", roles: [ { role: "readWrite", db: "nodebb" }, { role: "clusterMonitor", db: "admin" } ] } )
OBS: Återigen, ersätt platshållaren <Enter a secure password>
med ditt eget valda lösenord.
Gå ur Mongo-skalet.
> quit()
Starta om MongoDB och se till att den administrativa användaren som skapats tidigare kan ansluta.
sudo service mongod restart
mongo -u admin -p your_password --authenticationDatabase=admin
Installera Nginx.
sudo pkg install -y nginx
Kontrollera versionen.
nginx -v
# nginx version: nginx/1.14.2
Aktivera och starta Nginx.
sudo sysrc nginx_enable=yes
sudo service nginx start
NodeBB körs som standard på port 4567
. För att undvika att skriva http://example.com:4567
kommer vi att konfigurera Nginx som en omvänd proxy för NodeBB-applikationen. Varje begäran om port 80
eller 443
, om SSL används, kommer att vidarebefordras till port 4567
.
Kör sudo vim /usr/local/etc/nginx/nodebb.conf
och fyll i den med den grundläggande omvända proxykonfigurationen nedan.
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";
}
}
I ovanstående konfiguration uppdaterar du server_name
direktivet med din domän/värdnamn.
Spara filen och avsluta med :+ W+ Q.
Nu måste vi inkludera nodebb.conf
i huvudfilen nginx.conf
.
Kör sudo vim /usr/local/etc/nginx/nginx.conf
och lägg till följande rad i http {}
blocket.
include nodebb.conf;
Kontrollera konfigurationen.
sudo nginx -t
Ladda om Nginx.
sudo service nginx reload
Att säkra ditt forum med HTTPS är inte nödvändigt, men det kommer att säkra din webbplats trafik. Acme.sh är ett rent unix-skalprogramvara för att erhålla SSL-certifikat från Let's Encrypt med noll beroenden.
Ladda ner och installera 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 ~
Kontrollera versionen.
/etc/letsencrypt/acme.sh --version
# v2.8.1
Skaffa RSA- och ECDSA-certifikat för 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
När du har kört ovanstående kommandon kommer dina certifikat och nycklar att finnas i:
/etc/letsencrypt/forum.example.com
./etc/letsencrypt/forum.example.com_ecc
.Efter att ha erhållit certifikat från Let's Encrypt måste vi konfigurera Nginx för att använda dem.
Kör sudo vim /usr/local/etc/nginx/nodebb.conf
igen och konfigurera Nginx som en HTTPS omvänd proxy.
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";
}
}
Kontrollera konfigurationen.
sudo nginx -t
Ladda om Nginx.
sudo service nginx reload
Skapa en rotkatalog för dokument.
sudo mkdir -p /usr/local/www/nodebb
Ändra ägande av /usr/local/www/nodebb
katalogen till johndoe
.
sudo chown -R johndoe:johndoe /usr/local/www/nodebb
Navigera till dokumentets rotmapp.
cd /usr/local/www/nodebb
Klona den senaste NodeBB i dokumentets rotmapp.
git clone -b v1.11.x https://github.com/NodeBB/NodeBB.git .
Kör kommandot NodeBB setup och svara på varje fråga när du uppmanas.
./nodebb setup
Efter att NodeBB-installationen är klar, kör för ./nodebb start
att manuellt starta din NodeBB-server.
./nodebb start
Efter detta kommando kommer du att kunna komma åt din NodeBB-foruminstans i en webbläsare.
När den startas via ./nodebb start
, kommer NodeBB inte att starta automatiskt igen när systemet startar om. För att undvika det måste vi ställa in NodeBB som en systemtjänst.
Om du kör, stoppa NodeBB.
./nodebb stop
Installera PM2 globalt.
sudo npm install pm2 -g
Kontrollera versionen.
pm2 -v
# 3.5.0
Navigera till NodeBB-dokumentroten.
cd /usr/local/www/nodebb
Starta NodeBB via PM2.
pm2 start app.js
Lista NodeBB-processen.
pm2 ls
Upptäck det tillgängliga init-systemet.
pm2 startup
Kopiera och klistra in utgången av detta kommando i CLI för att ställa in din startkrok.
Spara din processlista.
pm2 save
Det är allt. Din NodeBB-instans är nu igång.
Använder du ett annat system? Tiny Tiny RSS Reader är en gratis och öppen källkod, webbaserat nyhetsflöde (RSS/Atom) läsare och aggregator, utformad för att
Använder du ett annat system? Wiki.js är en gratis och öppen källkod, modern wiki-app byggd på Node.js, MongoDB, Git och Markdown. Wiki.js källkod är offentlig
Använder du ett annat system? Pagekit 1.0 CMS är ett vackert, modulärt, utbyggbart och lätt, gratis och öppen källkod Content Management System (CMS) med
Använder du ett annat system? MODX Revolution är ett snabbt, flexibelt, skalbart, öppen källkod, Enterprise-grade Content Management System (CMS) skrivet i PHP. Det jag
Den här artikeln leder dig genom att ställa in OpenBSD 5.5 (64-bitars) på KVM med en Vultr VPS. Steg 1. Logga in på Vultr kontrollpanelen. Steg 2. Klicka på DEPLOY
Använder du ett annat system? osTicket är ett biljettsystem för kundsupport med öppen källkod. osTicket källkod är offentligt värd på Github. I denna handledning
Använder du ett annat system? Flarum är en gratis och öppen källkod nästa generations forummjukvara som gör diskussioner online roliga. Flarum källkod är värd o
Använder du ett annat system? TLS 1.3 är en version av TLS-protokollet (Transport Layer Security) som publicerades 2018 som en föreslagen standard i RFC 8446
Inledning WordPress är det dominerande innehållshanteringssystemet på internet. Det driver allt från bloggar till komplexa webbplatser med dynamiskt innehåll
Använder du ett annat system? Subrion 4.1 CMS är ett kraftfullt och flexibelt innehållshanteringssystem (CMS) med öppen källkod som ger ett intuitivt och tydligt innehåll
Denna handledning visar dig hur du konfigurerar en DNS-tjänst som är lätt att underhålla, lätt att konfigurera och som i allmänhet är säkrare än den klassiska BIN
En FEMP-stack, som är jämförbar med en LEMP-stack på Linux, är en samling programvara med öppen källkod som vanligtvis installeras tillsammans för att möjliggöra en FreeBS
MongoDB är en NoSQL-databas i världsklass som ofta används i nyare webbapplikationer. Det ger högpresterande frågor, skärning och replikering
Använder du ett annat system? Monica är ett personligt relationshanteringssystem med öppen källkod. Se det som ett CRM (ett populärt verktyg som används av säljteam i th
Introduktion Denna handledning visar OpenBSD som en e-handelslösning som använder PrestaShop och Apache. Apache krävs eftersom PrestaShop har komplex UR
Använder du ett annat system? Fork är ett CMS med öppen källkod skrivet i PHP. Forks källkod finns på GitHub. Den här guiden visar hur du installerar Fork CM
Använder du ett annat system? Directus 6.4 CMS är ett kraftfullt och flexibelt, gratis och öppen källkod Headless Content Management System (CMS) som tillhandahåller utvecklare
VPS-servrar riktas ofta mot inkräktare. En vanlig typ av attack dyker upp i systemloggar som hundratals obehöriga ssh-inloggningsförsök. Installation
Inledning OpenBSD 5.6 introducerade en ny demon som heter httpd, som stöder CGI (via FastCGI) och TLS. Inget ytterligare arbete behövs för att installera den nya http
Denna handledning kommer att visa dig hur du installerar groupware iRedMail på en ny installation av FreeBSD 10. Du bör använda en server med minst en gigabyte o
Artificiell intelligens är inte i framtiden, det är här i nuet I den här bloggen Läs hur Artificiell intelligens-applikationer har påverkat olika sektorer.
Är du också ett offer för DDOS-attacker och förvirrad över de förebyggande metoderna? Läs den här artikeln för att lösa dina frågor.
Du kanske har hört att hackare tjänar mycket pengar, men har du någonsin undrat hur de tjänar den typen av pengar? låt oss diskutera.
Vill du se revolutionerande uppfinningar av Google och hur dessa uppfinningar förändrade livet för varje människa idag? Läs sedan till bloggen för att se uppfinningar av Google.
Konceptet med att självkörande bilar ska ut på vägarna med hjälp av artificiell intelligens är en dröm vi har ett tag nu. Men trots flera löften finns de ingenstans att se. Läs den här bloggen för att lära dig mer...
När vetenskapen utvecklas i snabb takt och tar över en hel del av våra ansträngningar, ökar också riskerna för att utsätta oss för en oförklarlig singularitet. Läs, vad singularitet kan betyda för oss.
Lagringsmetoderna för data har utvecklats kan vara sedan födelsen av data. Den här bloggen tar upp utvecklingen av datalagring på basis av en infografik.
Läs bloggen för att känna till olika lager i Big Data Architecture och deras funktionaliteter på enklaste sätt.
I denna digitala värld har smarta hemenheter blivit en avgörande del av livet. Här är några fantastiska fördelar med smarta hemenheter om hur de gör vårt liv värt att leva och enklare.
Nyligen släppte Apple macOS Catalina 10.15.4, en tilläggsuppdatering för att åtgärda problem, men det verkar som om uppdateringen orsakar fler problem som leder till att mac-datorer blir murade. Läs den här artikeln för att lära dig mer