So stellen Sie Ghost unter Fedora 25 bereit

Ghost ist eine Open-Source-Blogging-Plattform, die seit ihrer Veröffentlichung im Jahr 2013 bei Entwicklern und normalen Benutzern immer beliebter wird. Der Fokus liegt auf Inhalten und Bloggen . Das Attraktivste an Ghost ist das einfache, saubere und reaktionsschnelle Design. Sie können Ihre Blog-Beiträge von einem Mobiltelefon aus schreiben. Inhalte für Ghost werden in der Markdown-Sprache geschrieben. Ghost eignet sich perfekt für Einzelpersonen oder kleine Gruppen von Schriftstellern.

In diesem Handbuch werden wir ein sicheres Ghost-Blog auf einem Fedora 25 VPS mit Let's Encrypt , Certbot , Node.js , Nginx und PM2 einrichten und bereitstellen .

Bedarf

  • Fedora 25-Serverinstanz mit mindestens 1 GB RAM .
  • Sie müssen wahrscheinlich Port 2368 mit öffnen semanage port -a -t http_port_t -p tcp 2368.

Verschlüsseln wir

Stellen Sie vor Beginn dieses Schritts sicher, dass Sie DNS- Einträge für Ihre Domain festgelegt haben.

Wir werden Let's Encrypt CA und den Certbot-Client von EFF verwenden, um das TLS-Zertifikat für unser Ghost-Blog zu erhalten. Vergessen Sie nicht, alle Instanzen von example.comdurch Ihren Domainnamen zu ersetzen .

  1. System aktualisieren:

    dnf check-update || dnf upgrade -y
    
  2. Installieren Sie die benötigten Tools:

    dnf install @development-tools -y
    
  3. Installieren Sie Certbot (auch bekannt als Let's Encrypt-Client):

    dnf install certbot -y
    
  4. Überprüfen Sie die Certbot-Version:

    certbot --version
    # certbot 0.12.0
    
  5. Erhalten Sie ein Zertifikat im Standalone-Modus:

    certbot certonly --standalone --domains example.com,www.example.com --email john.doe@example.com --agree-tos --rsa-key-size 2048
    

Nachdem Sie die vorherigen Schritte ausgeführt haben, befinden sich Ihr Zertifikat und Ihr privater Schlüssel im /etc/letsencrypt/live/example.comVerzeichnis.

Installieren Sie NodeJS

Ghost unterstützt derzeit nur die Knotenversionen 0.12.x , 4.2+ und 6.9+ .

Wir werden die unterstützte Version für Ghost installieren, die v6 Boron LTSzum Zeitpunkt dieses Schreibens verfügbar ist .

  1. Laden Sie die neueste LTS- Version von Node.js herunter und installieren Sie sie :

    dnf install nodejs -y
    
  2. Überprüfen Sie die Knoten- und NPM-Version:

    node -v && npm -v
    # v6.10.2
    # 3.10.10
    

Installieren Sie Nginx

  1. Laden Sie Nginx herunter und installieren Sie es:

    dnf install nginx -y
    
  2. Überprüfen Sie die Nginx-Version:

    nginx -v
    # nginx version: nginx/1.10.2
    
  3. Starten und Aktivieren des Nginx-Dienstes:

    systemctl start nginx.service && systemctl enable nginx.service
    
  4. Konfigurieren Sie Nginx als Reverse-Proxy:

    vi /etc/nginx/conf.d/ghost.conf
    
  5. Fügen Sie Folgendes ein /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;
      }
    
    }
    
  6. Überprüfen Sie die Nginx-Syntax:

    nginx -t
    
  7. Nginx-Konfiguration neu laden:

    systemctl reload nginx.service
    

Installieren Sie Ghost

Wenn Sie mehrere Ghost-Blogs auf demselben VPS hosten möchten, muss jede Ghost-Instanz auf einem separaten Port ausgeführt werden.

  1. webrootVerzeichnis erstellen :

    mkdir -p /var/www/
    
  2. Erstellen Sie einen neuen Ghost-Benutzer:

    useradd -c "Ghost Application" ghost 
    
  3. Laden Sie Ghost herunter:

    curl -L https://github.com/TryGhost/Ghost/releases/download/0.11.8/Ghost-0.11.8.zip -o ghost.zip
    
  4. Ghost entpacken:

    unzip -uo ghost.zip -d /var/www/ghost
    rm -f ghost.zip
    
  5. Navigieren Sie zu Webroot:

    cd /var/www/ghost
    
  6. Ändern Sie den Besitz des Webroot-Verzeichnisses:

    chown -R ghost:ghost .
    
  7. Zum neuen Ghost-Benutzer wechseln:

    su - ghost
    
  8. Navigieren Sie zu Webroot:

    cd /var/www/ghost
    
  9. Ghost installieren:

    npm install --production
    
  10. Konfigurieren Sie Ghost durch Ändern urlund mailEigenschaften des productionObjekts in der config.jsDatei:

    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: ''
                }
              }
        },
            . . .
            . . .
        },
    }
    . . .
    . . .        
    

    HINWEIS : Sie sollten auch konfigurieren mail. Informationen dazu finden Sie in der offiziellen Ghost-Dokumentation .

  11. Ghost starten:

    npm start --production
    

    Ghost wird jetzt ausgeführt. Sowohl das Blog-Front-End als auch die Admin-Oberfläche sind mit HTTPS gesichert und HTTP / 2 funktioniert ebenfalls. Sie können Ihren Browser öffnen und die Website unter besuchen https://example.com. Vergessen Sie nicht, durch example.comIhren Domainnamen zu ersetzen .

  12. Beenden Sie den Ghost-Prozess, indem Sie CTRL+ drücken Cund vom Ghost-Benutzer zum Root-Benutzer zurückkehren:

    exit
    

Installieren Sie PM2

Wenn Sie Ihre Terminalsitzung mit Ihrem VPS schließen , wird auch Ihr Blog ausgefallen. Das ist nicht gut. Um dies zu vermeiden, verwenden wir den PM2- Prozessmanager. Es wird unseren Blog rund um die Uhr auf dem Laufenden halten.

  1. Installieren Sie die neueste stabile Version von PM2 Process Manager:

    npm install -g pm2@latest
    
  2. Überprüfen Sie die PM2-Version:

    pm2 -v
    # 2.4.6
    
  3. Wechseln Sie erneut zum Ghost-Benutzer:

    su - ghost
    
  4. Set - NODE_ENVUmgebungsvariable auf die Produktion:

    echo "export NODE_ENV=production" >> ~/.bashrc && source ~/.bashrc
    
  5. Starten (Daemonisieren) der Ghost-Anwendung mit PM2:

    pm2 start /var/www/ghost/index.js --name "Ghost Blog"
    
  6. Navigieren Sie zu https://example.com/ghost/Ghost Admin User und erstellen Sie ihn. Tun Sie dies so schnell wie möglich.

Fazit

Das ist es. Wir haben jetzt einen voll funktionsfähigen Ghost-Blog. Wenn Sie das Standard-Ghost- Design mit dem Namen Casper in ein benutzerdefiniertes ändern möchten , können Sie das Design einfach herunterladen, in den /var/www/ghost/content/themesOrdner entpacken und über die Ghost-Administrationsoberfläche unter auswählen https://example.com/ghost.

Einen Kommentar hinterlassen

Kann KI mit zunehmender Anzahl von Ransomware-Angriffen kämpfen?

Kann KI mit zunehmender Anzahl von Ransomware-Angriffen kämpfen?

Ransomware-Angriffe nehmen zu, aber kann KI helfen, den neuesten Computervirus zu bekämpfen? Ist KI die Antwort? Lesen Sie hier, ob KI boone oder bane ist

ReactOS: Ist das die Zukunft von Windows?

ReactOS: Ist das die Zukunft von Windows?

ReactOS, ein quelloffenes und kostenloses Betriebssystem, ist hier mit der neuesten Version. Kann es den Anforderungen moderner Windows-Benutzer genügen und Microsoft zu Fall bringen? Lassen Sie uns mehr über dieses alte, aber neuere Betriebssystem erfahren.

Bleiben Sie in Verbindung über die WhatsApp Desktop App 24*7

Bleiben Sie in Verbindung über die WhatsApp Desktop App 24*7

Whatsapp hat endlich die Desktop-App für Mac- und Windows-Benutzer auf den Markt gebracht. Jetzt können Sie ganz einfach von Windows oder Mac auf WhatsApp zugreifen. Verfügbar für Windows 8+ und Mac OS 10.9+

Wie kann KI die Prozessautomatisierung auf die nächste Stufe heben?

Wie kann KI die Prozessautomatisierung auf die nächste Stufe heben?

Lesen Sie dies, um zu erfahren, wie Künstliche Intelligenz bei kleinen Unternehmen beliebt wird und wie sie die Wahrscheinlichkeit erhöht, sie wachsen zu lassen und ihren Konkurrenten einen Vorsprung zu verschaffen.

macOS Catalina 10.15.4 Supplement Update verursacht mehr Probleme als sie zu lösen

macOS Catalina 10.15.4 Supplement Update verursacht mehr Probleme als sie zu lösen

Vor kurzem hat Apple macOS Catalina 10.15.4 als Ergänzungsupdate veröffentlicht, um Probleme zu beheben, aber es scheint, dass das Update mehr Probleme verursacht, die zum Bricking von Mac-Computern führen. Lesen Sie diesen Artikel, um mehr zu erfahren

13 Tools zur kommerziellen Datenextraktion von Big Data

13 Tools zur kommerziellen Datenextraktion von Big Data

13 Tools zur kommerziellen Datenextraktion von Big Data

Was ist ein Journaling-Dateisystem und wie funktioniert es?

Was ist ein Journaling-Dateisystem und wie funktioniert es?

Unser Computer speichert alle Daten in einer organisierten Weise, die als Journaling-Dateisystem bekannt ist. Es ist eine effiziente Methode, die es dem Computer ermöglicht, Dateien zu suchen und anzuzeigen, sobald Sie auf die Suche klicken.https://wethegeek.com/?p=94116&preview=true

Technologische Singularität: Eine ferne Zukunft der menschlichen Zivilisation?

Technologische Singularität: Eine ferne Zukunft der menschlichen Zivilisation?

Da sich die Wissenschaft schnell weiterentwickelt und einen Großteil unserer Bemühungen übernimmt, steigt auch das Risiko, uns einer unerklärlichen Singularität auszusetzen. Lesen Sie, was Singularität für uns bedeuten könnte.

Ein Einblick in 26 Big-Data-Analysetechniken: Teil 1

Ein Einblick in 26 Big-Data-Analysetechniken: Teil 1

Ein Einblick in 26 Big-Data-Analysetechniken: Teil 1

Der Einfluss künstlicher Intelligenz im Gesundheitswesen 2021

Der Einfluss künstlicher Intelligenz im Gesundheitswesen 2021

KI im Gesundheitswesen hat in den letzten Jahrzehnten große Fortschritte gemacht. Somit wächst die Zukunft der KI im Gesundheitswesen immer noch von Tag zu Tag.