Ubuntu 14.04でGhostとNginxを使用してブログを作成する方法

前書き

Ghostは、軽量(〜7.5MB)のオープンソースのブログプラットフォームであり、非常に使いやすいです。 Ghostは完全にカスタマイズ可能です。 インターネット上のGhostには、無料のテーマと有料のテーマがあります。

このチュートリアルでは、Ubuntu 14.04システムでGhostをセットアップして実行する手順を説明します。 また、Nginxをプロキシポートにインストールし、ノードパッケージであるforeverをインストールして、Ghostをバックグラウンドで実行し続けます。

前提条件

サーバーがGhostを実行するための最小サイズ要件はありません。 作成するドロップレットのサイズを決定する際に、ブログで取得する訪問者の数と共有するコンテンツの量を検討します。 このチュートリアルは、Ubuntu 14.04を実行する最小サイズのDigitalOcean Dropletでテストされました。

始める前に、次のものが必要です。

  • Ubuntu 14.04ドロップレット

  • ドロップレットのIPアドレスを指す登録済みドメイン名

  • sudo特権を持つ非rootユーザー

This tutorialは、ドロップレットを指すようにドメイン名を設定するのに役立ちます。

このチュートリアルのすべてのコマンドは、非rootユーザーとして実行する必要があります。 コマンドにルートアクセスが必要な場合は、その前にsudoが付きます。 Initial Server Setup with Ubuntu 14.04は、ユーザーを追加してsudoアクセスを許可する方法を説明しています。

[[step-1 -—- install-node-js-and-npm]] ==ステップ1—Node.jsとNpmをインストールします

ローカルパッケージインデックスを更新し、zipおよびwgetパッケージをインストールする必要があります。 このチュートリアルの後半でそれらを使用します。

sudo apt-get update
sudo apt-get install zip wget

GhostにはNode.js v0.10.x(最新の安定版)が必要です。 v0.12.xなどの不安定なバージョンのNodeは、notでサポートされています。 Node.js v0.10.36 and npm v2.5.0 are recommended by Ghost.org.

this tutorialからPPAメソッドを使用してNode.jsをインストールします。

Node.jsをインストールしたら、次を実行してインストールされたバージョンを確認します。

node -v

出力は次のようになります。

v0.10.38

npmがインストールされているかどうかを確認します。

npm -v

npmがインストールされている場合、インストールされているバージョンを出力する必要があります。

1.4.28

npmがインストールされていないというエラーが出力された場合、次のコマンドでインストールします。

sudo apt-get install npm

次のコマンドを実行して、npmをバージョン2.5.0に更新します。

sudo npm install [email protected] -g

インストールされているnpmのバージョンを確認します。

npm -v

出力は次のようになります。

2.5.0

[[step-2 -—- install-ghost]] ==ステップ2—Ghostをインストールします

次に、Ghostをインストールする必要があります。 Ghost.org recommends to install Ghost in var/www/ghost, so that is where we will install it.

まず、ディレクトリ/var/www/を作成してから、GhostのGitHubリポジトリから最新バージョンのGhostをダウンロードします。

sudo mkdir -p /var/www/
cd /var/www/
sudo wget https://ghost.org/zip/ghost-latest.zip

Ghostの最新バージョンを入手したので、それを解凍する必要があります。 また、ディレクトリを/var/www/ghost/に変更します。

sudo unzip -d ghost ghost-latest.zip
cd ghost/

これで、Ghost依存関係とノードモジュールをインストールできます(運用依存関係のみ)。

sudo npm install --production

これが完了すると、Ghostがインストールされます。 Ghostを起動する前にセットアップする必要があります。

[[step-3-— setup-up-ghost]] ==ステップ3—Ghostの設定

Ghostの構成ファイルは/var/www/ghost/config.jsに配置する必要があります。 ただし、Ghostではそのようなファイルはインストールされません。 代わりに、インストールにはconfig.example.jsが含まれます。

サンプル構成ファイルを適切な場所にコピーします。 変更を元に戻す必要がある場合に備えて、元の構成ファイルのコピーを保持するために、移動ではなくコピーを行ってください。

sudo cp config.example.js config.js

productionセクションにあるURLとメールの設定は、変更が必要な情報の重要な領域です。 URLは必須です。 それ以外の場合、リンクをクリックするとデフォルトのhttp://my-ghost-blog.comページに移動します。 Ghostはメール設定なしでも機能しますが、追加することをお勧めします。 この記事を書いている時点で、Ghostは、ユーザーがアカウントのパスワードを忘れた場合にのみ機能するメールを必要とするため、メールを設定しなくてもそれほど害はありません。

ファイルを編集用に開きます。

sudo nano config.js

urlの値をドメインに変更する必要があります(または、今すぐドメインを使用したくない場合は、サーバーのIPアドレスを使用できます)。 この値はURLの形式である必要があります。 たとえば、http://example.com/またはhttp://45.55.76.126/です。 この値が正しくフォーマットされていないと、Ghostは起動しません。

また、serverセクションのhostの値を0.0.0.0に変更します。

以下に、変更する必要がある値を赤で示します。

/var/www/ghost/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: 'http://my-ghost-blog.com',
        mail: {
            // Your mail settings
        },
        database: {
            client: 'sqlite3',
            connection: {
                filename: path.join(__dirname, '/content/data/ghost.db')
            },
            debug: false
        },

        server: {
            // Host to be passed to node's `net.Server#listen()`
            host: '127.0.0.1',
            // Port to be passed to node's `net.Server#listen()`, for iisnode s$
            port: '2368'
        }
    },

(...)

ファイルを保存し、CTRL+XY、最後にENTERを押してnanoテキストエディタを終了します。

まだ/var/www/ghostディレクトリにいる間に、次のコマンドでGhostを起動します。

sudo npm start --production

出力は次のようになります。

> [email protected] start /var/www/ghost
> node index

Migrations: Database initialisation required for version 003
Migrations: Creating tables...
Migrations: Creating table: posts

[...]

すべてがうまくいけば、ポート2368を使用してブログにアクセスできるはずです:http://your_domain._name:2368(またはhttp://your_servers_ip:2368)。

ターミナルでCTRL+Cを押して、Ghostインスタンスをシャットダウンします。

[.note]#Note:Ghostはさらにカスタマイズできます。 Ghost.orgは、各構成オプションについて詳しく説明しています。

[[step-4-— install-nginx]] ==ステップ4—Nginxをインストールします

次のステップは、Nginxをインストールすることです。 基本的に、ポート80の接続がGhostが実行されているポートに接続できるようにします。 簡単に言うと、:2368を追加せずにGhostブログにアクセスできます。

次のコマンドでインストールしてください。

sudo apt-get install nginx

次に、ディレクトリを/etc/nginxに変更し、/etc/nginx/sites-enabledのデフォルトファイルを削除して、Nginxを構成する必要があります。

cd /etc/nginx/
sudo rm sites-enabled/default

ghostという名前の新しいファイルを/etc/nginx/sites-available/に作成し、nanoで開いて編集します。

sudo touch /etc/nginx/sites-available/ghost
sudo nano /etc/nginx/sites-available/ghost

次のコードをファイルに貼り付け、highlighted code in redをドメイン名に変更します。ドメインを今すぐ追加しない場合は、サーバーのIPアドレスに変更します。

server {
    listen 80;
    server_name your_domain.tld;
    location / {
        proxy_set_header   X-Real-IP $remote_addr;
        proxy_set_header   Host      $http_host;
        proxy_pass         http://127.0.0.1:2368;
    }
}

ここで、構成をsites-enabledでシンボリックリンクします。

sudo ln -s /etc/nginx/sites-available/ghost /etc/nginx/sites-enabled/ghost

Nginxを再起動します。

sudo service nginx restart

次に、新しいユーザーを作成します。 このユーザーには、ディレクトリ/var/www/ghostで何かを実行する権限のみが付与されます。 これはセキュリティ対策です。 Ghostが危険にさらされた場合、システムは安全になります。 これは、次のコマンドを実行することで実行できます。

sudo adduser --shell /bin/bash --gecos 'Ghost application' ghost

特権を付与します。

sudo chown -R ghost:ghost /var/www/ghost/

これで、ghostユーザーとしてログインできます。

su - ghost

次に、Ghostを起動する必要があります。

cd /var/www/ghost
npm start --production

ポート80でhttp://<your_server_ip>/またはhttp://<your_domain_name>/としてブログにアクセスできるはずです。

[[step-5 --- keep-ghost-running-with-forever]] ==ステップ5—ゴーストをforeverで実行し続ける

次のステップは、Ghostをバックグラウンドで実行し続けることです。 foreverは、Ghostをバックグラウンドで起動し、Ghostが稼働していることを確認するために使用できるノードモジュールです。 Ghostがクラッシュした場合、永久にGhostの別のインスタンスが自動的に起動します。

Ghostディレクトリ内から次のコマンドを使用してforeverをインストールします。 /var/www/ghost。 ただし、コマンドを実行する前に、ghostユーザーからログアウトし、root以外のユーザーにログインしてください。

exit
sudo npm install -g forever

ghostユーザーとしてGhostを起動します。 また、Ghostディレクトリから実行する必要があります。

su - ghost
cd /var/www/ghost
forever start index.js

出力は次のようになります。

warn:    --minUptime not set. Defaulting to: 1000ms
warn:    --spinSleepTime not set. Your script will exit if it does not stay up for at least 1000ms
info:    Forever processing file: index.js

デフォルトでは、開発環境にロードされます。 これは、次のコマンドを実行して変更できます。

NODE_ENV=production forever start index.js

foreverは、Ghostディレクトリからこれを実行することで停止できます。

forever stop index.js

考えられるエラー

次のエラーメッセージの場合:

Error: SQLITE_READONLY: attempt to write a readonly database

foreverrootユーザーとして開始します(現在のユーザーをログアウトするには、exitと入力します)。

sudo forever start index.js

最後のコマンドで「永久に」見つからないという場合は、コマンドへのフルパスを使用します。

sudo /usr/local/bin/forever start index.js

次のエラーが表示される場合:

error:   Cannot start forever
error:   script /home/ghost/index.js does not exist.

/var/www/ghostディレクトリにいません。 このディレクトリに移動して、コマンドを再実行してください。

結論

おめでとうございます。 Ghostをインストールし、Nginxでポートをプロキシする方法を学習しました。 また、foreverノードパッケージを使用してタスクを実行し続ける方法も学習しました。

Ghostでできることは他にもたくさんあります。 たとえば、パスワードで保護されたブログは最新の機能の1つです。

Ghostの他のDigitalOceanチュートリアルをご覧ください。

詳細については、次も参照してください。

Related