Hur man installerar BigTree CMS på en Fedora 26 LAMP VPS
Använder du ett annat system? BigTree CMS 4.2 är ett snabbt och lätt, gratis och öppen källkod, företagsklassat innehållshanteringssystem (CMS) med omfattande
NodeBB är ett Node.js-baserat forum. 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 NodeBB-installationsprocessen på en ny Fedora 28 Vultr-instans som använder 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 Fedora-versionen.
cat /etc/fedora-release
# Fedora release 28 (Twenty Eight)
Skapa ett nytt icke- rootanvändarkonto med sudo
åtkomst och byt till det.
useradd -c "John Doe" johndoe && passwd johndoe
usermod -aG wheel johndoe
su - johndoe
OBS : Ersätt johndoe
med ditt användarnamn.
Ställ in tidszonen.
timedatectl list-timezones
sudo timedatectl set-timezone 'Region/City'
Se till att ditt system är uppdaterat.
sudo dnf check-upgrade || sudo dnf upgrade -y
Installera nödvändiga paket.
sudo dnf install -y git wget vim gcc-c++ make
För enkelhets skull, inaktivera SELinux och brandvägg.
sudo setenforce 0
sudo systemctl stop firewalld
sudo systemctl disable firewalld
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.
sudo dnf install -y nodejs
Verifiera installationen av Node.js och npm.
node -v && npm -v
# v8.11.3
# 5.6.0
MongoDB är standarddatabasen för NodeBB.
Installera MongoDB.
sudo dnf install -y mongodb mongodb-server
Kontrollera versionen.
mongo --version | head -n 1 && mongod --version | head -n 1
# MongoDB shell version v3.6.3
# db version v3.6.3
Aktivera och starta MongoDB-tjänsten.
sudo systemctl enable mongod.service
sudo systemctl start mongod.service
Skapa en MongoDB-databas och användare för NodeBB.
Anslut först till MongoDB-servern.
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 verifiera att den administrativa användaren som skapats tidigare kan ansluta.
sudo systemctl restart mongod.service
mongo -u admin -p your_password --authenticationDatabase=admin
Installera Nginx.
sudo dnf install -y nginx
Kontrollera versionen.
sudo nginx -v
# nginx version: nginx/1.12.1
Aktivera och starta Nginx.
sudo systemctl enable nginx.service
sudo systemctl start nginx.service
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 på port 80
eller 443
( om SSL används ) kommer att vidarebefordras till port 4567
.
Kör sudo vim /etc/nginx/conf.d/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 konfigurationen ovan uppdaterar du server_name
direktivet med din domän/värdnamn.
Kontrollera konfigurationen.
sudo nginx -t
Ladda om Nginx.
sudo systemctl reload nginx.service
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 ~
source ~/.bashrc
Kontrollera versionen.
/etc/letsencrypt/acme.sh --version
# v2.7.9
Skaffa RSA- och ECDSA-certifikat för forum.example.com
domänen/värdnamnet.
# 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
Efter att ha kört kommandona ovan kommer dina certifikat och nycklar att finnas i följande kataloger:
/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 /etc/nginx/conf.d/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 systemctl reload nginx.service
Skapa en rotkatalog för dokument.
sudo mkdir -p /var/www/nodebb
Ändra ägande av /var/www/nodebb
katalogen till johndoe
.
sudo chown -R johndoe:johndoe /var/www/nodebb
Navigera till dokumentets rotmapp.
cd /var/www/nodebb
Klona den senaste NodeBB i dokumentets rotmapp.
git clone -b v1.10.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 ditt forum i din 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 den är igång, stoppa NodeBB.
./nodebb stop
Skapa en ny nodebb
användare.
sudo useradd nodebb
Ändra äganderätten till /var/www/nodebb
katalogen till nodebb
användare.
sudo chown -R nodebb:nodebb /var/www/nodebb
Skapa nodebb.service
systemd-enhetens konfigurationsfil. Denna enhetsfil kommer att hantera start av NodeBB-deamonen. Kör sudo vim /etc/systemd/system/nodebb.service
och fyll filen med följande innehåll.
[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
OBS: Ställ in användarnamn och katalogsökvägar enligt dina valda namn.
Aktivera nodebb.service
vid omstart och starta omedelbart nodebb.service
.
sudo systemctl enable nodebb.service
sudo systemctl start nodebb.service
Kontrollera nodebb.service
status.
sudo systemctl status nodebb.service
sudo systemctl is-enabled nodebb.service
Det är allt. Din NodeBB-instans är nu igång.
Använder du ett annat system? BigTree CMS 4.2 är ett snabbt och lätt, gratis och öppen källkod, företagsklassat innehållshanteringssystem (CMS) med omfattande
Använder du ett annat system? Koel är en enkel webbaserad app för personlig ljudströmning skriven i Vue på klientsidan och Laravel på serversidan. Koe
Använder du ett annat system? Grav är ett platt-fil-CMS med öppen källkod skrivet i PHP. Grav källkod är offentligt värd på GitHub. Den här guiden visar dig hur t
Använder du ett annat system? Akaunting är en gratis, öppen källkod och bokföringsprogram online designad för småföretag och frilansare. Det är byggt vettigt
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? InvoicePlane är en gratis faktureringsprogram med öppen källkod. Dess källkod kan hittas på detta Github-förråd. Denna guide
Använder du ett annat system? I den här handledningen kommer jag att guida dig genom att ställa in en Minecraft-server på en högpresterande SSD VPS på Vultr. Du kommer att lära dig ho
Använder du ett annat system? NGINX kan användas som en HTTP/HTTPS-server, omvänd proxyserver, e-postproxyserver, lastbalanserare, TLS-terminator eller cachin
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? Subrion 4.1 CMS är ett kraftfullt och flexibelt innehållshanteringssystem (CMS) med öppen källkod som ger ett intuitivt och tydligt innehåll
Använder du ett annat system? TaskWarrior är ett tidshanteringsverktyg med öppen källkod som är en förbättring av Todo.txt-applikationen och dess kloner. På grund av th
Använder du ett annat system? CMS Made Simple 2.2 är ett flexibelt och utbyggbart, gratis och open source Content Management System (CMS) intelligent designat för att
Använder du ett annat system? Inledning Bro är en nätverkstrafikanalysator med öppen källkod. Det är i första hand en säkerhetsmonitor som inspekterar all trafik på en lina
Använder du ett annat system? X-Cart är en extremt flexibel e-handelsplattform med öppen källkod med massor av funktioner och integrationer. X-Cart källkod är värd
Använder du ett annat system? Matomo (tidigare Piwik) är en analysplattform med öppen källkod, ett öppet alternativ till Google Analytics. Matomo källa är värd o
Använder du ett annat system? MyBB är ett gratis och öppen källkod, intuitivt och utbyggbart forumprogram. MyBB-källkoden finns på GitHub. Denna guide kommer att sho
Använder du ett annat system? Inledning TaskBoard är ett gratis och öppen källkodsverktyg som kan användas för att hålla reda på saker som behöver göras. Det ger
Använder du ett annat system? LimeSurvey är ett undersökningsprogram med öppen källkod skrivet i PHP. LimeSurvey-källkoden finns på GitHub. Denna guide kommer att visa dig
Använder du ett annat system? Backdrop CMS 1.8.0 är ett enkelt och flexibelt, mobilvänligt, gratis och open source Content Management System (CMS) som låter oss
Använder du ett annat system? Craft CMS är ett open source CMS skrivet i PHP. Craft CMS-källkod finns på GitHub. Den här guiden visar hur du installerar
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