Krav
La oss kryptere
Installer NodeJS
Installer Nginx
Installer Ghost
Installer PM2
Konklusjon
Ghost er en bloggplattform med åpen kildekode som har blitt mer populær blant utviklere og vanlige brukere siden utgivelsen i 2013. Det setter fokus på innhold og blogging . Det mest attraktive med Ghost er dens enkle, rene og responsive design. Du kan skrive blogginnleggene dine fra en mobiltelefon. Innhold for Ghost er skrevet med Markdown-språket. Ghost passer perfekt for enkeltpersoner eller små grupper av forfattere.
I denne guiden skal vi sette opp og distribuere en sikker Ghost-blogg på en Fedora 25 VPS ved å bruke Let's Encrypt , Certbot , Node.js , Nginx og PM2 .
Krav
- Fedora 25 serverforekomst med minimum 1 GB RAM .
- Du må sannsynligvis åpne port 2368 med
semanage port -a -t http_port_t -p tcp 2368.
La oss kryptere
Før du starter dette trinnet, sørg for at du har satt DNS- poster for domenet ditt.
Vi skal bruke Let's Encrypt CA og EFFs Certbot-klient for å få TLS-sertifikat for Ghost-bloggen vår. Ikke glem å erstatte alle forekomster av example.commed ditt domenenavn.
Oppdateringssystem:
dnf check-update || dnf upgrade -y
Installer nødvendige verktøy:
dnf install @development-tools -y
Installer Certbot (aka Let's Encrypt-klient):
dnf install certbot -y
Sjekk Certbot-versjonen:
certbot --version
# certbot 0.12.0
Skaff et sertifikat ved å bruke frittstående"-modus:
certbot certonly --standalone --domains example.com,www.example.com --email john.doe@example.com --agree-tos --rsa-key-size 2048
Etter å ha gått gjennom tidligere trinn, vil sertifikatet og den private nøkkelen din være i /etc/letsencrypt/live/example.comkatalogen.
Installer NodeJS
Ghost currently supports Node versions 0.12.x, 4.2+, and 6.9+ only.
Vi kommer til å installere støttet versjon for Ghost som er v6 Boron LTSi skrivende stund.
Last ned og installer den nyeste LTS- versjonen av Node.js:
dnf install nodejs -y
Sjekk node- og NPM-versjon:
node -v && npm -v
# v6.10.2
# 3.10.10
Installer Nginx
Last ned og installer Nginx:
dnf install nginx -y
Sjekk Nginx-versjonen:
nginx -v
# nginx version: nginx/1.10.2
Start og aktiver Nginx-tjenesten:
systemctl start nginx.service && systemctl enable nginx.service
Konfigurer Nginx som en omvendt proxy:
vi /etc/nginx/conf.d/ghost.conf
Lim inn følgende i /etc/nginx/conf.d/ghost.conf:
server {
listen 80;
listen [::]:80;
listen 443 ssl http2;
listen [::]:443 ssl http2;
server_name example.com www.example.com;
ssl_certificate /etc/letsencrypt/live/example.com/fullchain.pem;
ssl_certificate_key /etc/letsencrypt/live/example.com/privkey.pem;
ssl_protocols TLSv1 TLSv1.1 TLSv1.2;
location / {
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header Host $http_host;
proxy_set_header X-Forwarded-Proto $scheme;
proxy_pass http://127.0.0.1:2368;
}
}
Sjekk Nginx-syntaks:
nginx -t
Last inn Nginx-konfigurasjonen på nytt:
systemctl reload nginx.service
Installer Ghost
Hvis du vil være vert for flere Ghost-blogger på samme VPS , må hver Ghost-forekomst kjøres på en egen port.
Lag webrootkatalog:
mkdir -p /var/www/
Opprett en ny spøkelsesbruker:
useradd -c "Ghost Application" ghost
Last ned Ghost:
curl -L https://github.com/TryGhost/Ghost/releases/download/0.11.8/Ghost-0.11.8.zip -o ghost.zip
Pakk ut Ghost:
unzip -uo ghost.zip -d /var/www/ghost
rm -f ghost.zip
Naviger til webroot:
cd /var/www/ghost
Endre eierskapet til webroot-katalogen:
chown -R ghost:ghost .
Bytt til ny spøkelsesbruker:
su - ghost
Naviger til webroot:
cd /var/www/ghost
Installer Ghost:
npm install --production
Konfigurer Ghost ved å endre urlog mailegenskapen til productionobjektet inne i config.jsfilen:
cp config.example.js config.js
vi config.js
var path = require('path'),
config;
config = {
// ### Production
// When running Ghost in the wild, use the production environment.
// Configure your URL and mail settings here
production: {
url: 'https://example.com',
mail: {
options: {
service: '',
auth: {
user: '',
pass: ''
}
}
},
. . .
. . .
},
}
. . .
. . .
NOTE: You should configure mail also. Consult the official Ghost documentation on how to do that.
Start Ghost:
npm start --production
Ghost vil nå kjøre. Både blogggrensesnitt og administrasjonsgrensesnitt er sikret med HTTPS og HTTP/2 fungerer også. Du kan åpne nettleseren og besøke nettstedet på https://example.com. Ikke glem å erstatte example.commed ditt domenenavn.
Slå av Ghost-prosessen ved å trykke på CTRL+ Cog gå ut fra Ghost-bruker tilbake til root-bruker:
exit
Installer PM2
Hvis du lukker terminaløkten med VPS-en din, vil bloggen din også gå ned. Det er ikke bra. For å unngå dette kommer vi til å bruke PM2- prosessbehandleren. Det vil holde bloggen vår oppe 24/7.
Installer den siste stabile versjonen av PM2 prosessbehandler:
npm install -g pm2@latest
Sjekk PM2-versjonen:
pm2 -v
# 2.4.6
Bytt til spøkelsesbruker igjen:
su - ghost
Sett NODE_ENVmiljøvariabel til produksjon:
echo "export NODE_ENV=production" >> ~/.bashrc && source ~/.bashrc
Start (demoniser) Ghost-applikasjonen med PM2:
pm2 start /var/www/ghost/index.js --name "Ghost Blog"
Naviger til https://example.com/ghost/og opprett Ghost admin-bruker. Gjør dette så snart som mulig.
Konklusjon
Det er det. Vi har nå en fullt funksjonell Ghost-blogg. Hvis du vil endre standard Ghost-tema kalt Casper til et tilpasset, kan du bare laste ned og pakke ut temaet i /var/www/ghost/content/themesmappen og velge det via Ghost-administrasjonsgrensesnittet, som ligger på https://example.com/ghost.