CentOS 7にPhoenix Frameworkをインストールする方法

フェニックスは、新しいElixirベースのWeb開発フレームワークです。高い開発生産性、豊富な機能、強力なランタイムパフォーマンスを提供するように設計されています。

このチュートリアルでは、開発目的でVultr CentOS 7サーバーインスタンスにフェニックスをインストールする方法を示します。

前提条件

先に進む前に、次のことを前提としています。

  • 新しいVultr CentOS 7サーバーインスタンスをデプロイしました。
  • 非CentOSのsudoユーザーとしてこのCentOS 7システムにログインしました。

ステップ1:システムを更新する

sudo yum install epel-release
sudo yum update
sudo reboot

ステップ2:Erlangをインストールする

まず、システムにErlangをインストールする必要があります。フェニックスはElixirプログラミング言語で記述されたフレームワークであり、Elixirベースのアプリケーションは、実行する前にErlangバイトコードにコンパイルする必要があります。

cd ~
wget http://packages.erlang-solutions.com/erlang-solutions-1.0-1.noarch.rpm
sudo rpm -Uvh erlang-solutions-1.0-1.noarch.rpm
sudo yum install erlang

Erlangのインストールを確認するには:

erl

このコマンドを実行すると、Erlangシェルが表示されます。Erlangシェルを起動すると、次の出力が表示されます。

Erlang/OTP 18 [erts-7.3] [source-d2a6d81] [64-bit] [async-threads:10] [hipe] [kernel-poll:false]

Eshell V7.3  (abort with ^G)
1>

Ctrl+CErlangシェルを終了するには、2回押します。

ステップ3:Elixirをインストールする

CentOS 7システムのYUMリポジトリにあるElixirのバージョンはかなり古いため、コンパイル済みの公式Elixirアーカイブを使用して、最新バージョンのElixirをインストールする必要があります。

最新のElixirプリコンパイル済みアーカイブをダウンロードして解凍します。

cd /usr/bin
sudo mkdir elixir
cd /usr/bin/elixir
sudo wget https://github.com/elixir-lang/elixir/releases/download/v1.2.5/Precompiled.zip
sudo yum install unzip
sudo unzip Precompiled.zip

Elixirがシステムにインストールされました。次のように、Elixir関連の各コマンドのパスを指定することにより、Elixirコマンドを実行できます。

/usr/bin/elixir/bin/elixir -v

このコマンドは、システム上のElixirのバージョンを教えてくれます。

便宜上、PATH環境変数にElixirのビンパスを(インストールするnode.jsのビンパスとともに)追加できます。

sudo vi /etc/profile

ファイルの最後に次の行を追加します。

export PATH="$PATH:/usr/bin/elixir/bin:/usr/bin/node-v6.1.0-linux-x64/bin"

保存して終了:

:wq

プロファイルをリロードします。

source /etc/profile

今後は、次のように完全なパスを指定せずにElixir関連のコマンドを実行できます。

elixir -v

次に、mix同じ方法でコマンドを実行して、Hexパッケージマネージャーをインストールします。

cd ~
mix local.hex

Yインストールプロセス中に応答します。

手順4:Phoenixをインストールする

次のコマンドを使用して、Phoenixをインストールします。

mix archive.install https://github.com/phoenixframework/archives/raw/master/phoenix_new.ez

Yインストールプロセス中に応答します。

ステップ5:Node.jsをインストールする(オプション)

Phoenixのデフォルトのビルドツールであるbrunch.ioを使用して静的アセット(javascript、cssなど)をコンパイルするには、Node.js(> = 5.0.0)をインストールする必要があります。

cd ~
wget https://nodejs.org/dist/v6.1.0/node-v6.1.0-linux-x64.tar.xz
sudo yum install xz
xz -d node-v6.1.0-linux-x64.tar.xz
tar -xvf node-v6.1.0-linux-x64.tar
sudo mv ~/node-v6.1.0-linux-x64 /usr/bin/

Node.jsパスは、手順3でPATH環境変数に追加されたことを思い出してください。次のコマンドを使用して、Node.jsのインストールをテストできます。

node -v

ステップ6:PostgreSQLをインストールする

デフォルトでは、PhoenixはPostgreSQLを使用してアプリケーションを構成します。CentOS 7では、YUMを使用してPostgreSQLをインストールできます。

sudo yum install -y postgresql-server
sudo postgresql-setup initdb

postgresqlサービスを開始します。

sudo systemctl start postgresql.service
sudo systemctl enable postgresql.service

デフォルトのPostgreSQLユーザー「postgres」のパスワードを設定します。

sudo -u postgres psql

PostgreSQLシェル(プロンプトがに変わった後postgres=#)で、「postgres」のパスワードを設定します。

\password postgres

パスワードをpostgres2回入力します。これは、Phoenixが推奨するパスワードです。

最後に、次のコマンドを使用してPostgreSQLシェルを終了します。

\q

データベースのユーザー認証方法を設定します。

sudo vi /var/lib/pgsql/data/pg_hba.conf

次のセクションを見つけます。

# IPv4 local connections:
host    all             all             127.0.0.1/32            ident
# IPv6 local connections:
host    all             all             ::1/128                ident

IPv4ローカル接続の認証方法をmd5に変更します。

# IPv4 local connections:
host    all             all             127.0.0.1/32            md5
# IPv6 local connections:
host    all             all             ::1/128                 md5

保存して終了:

:wq

postgresqlサービスを再起動します。

sudo systemctl restart postgresql.service

ステップ7:inotify-toolsをインストールする

次のコマンドを使用して、必要なコンポーネント「inotify-tools」をインストールします。

sudo yum install inotify-tools

ステップ8:Phoenixアプリケーションを作成する

ディレクトリにPhoenixアプリケーションを作成するとします~/phoenix_project_1

mix phoenix.new ~/phoenix_project_1

Yプロセス中に応答して、依存関係を取得してインストールします。

このコマンドは、アプリケーションディレクトリ~/phoenix_project_1を作成します。ディレクトリに移動し、データベースを作成します。

cd ~/phoenix_project_1
mix ecto.create

Y最初のデータベース作成時に「鉄筋」をインストールするための回答。

次のコマンドでアプリケーションを起動します。

mix phoenix.server

現在のSSH接続を維持したまま、別のSSH接続を開始し、ファイアウォールルールを変更して、アプリケーションへのアクセスを許可します。

sudo firewall-cmd --zone=public --permanent --add-port=4000/tcp
sudo firewall-cmd --reload

最後に、Webブラウザを使用して、次の場所からアプリケーションにアクセスします。

http://[your-server-IP]:4000

これでチュートリアルは終了です。フェニックスへようこそ!



Leave a Comment

CentOS 7にApacheをインストールする方法

CentOS 7にApacheをインストールする方法

CentOS 7サーバーにApache 2.4をインストールする方法を説明します。安定したウェブサーバーを構築するための前提条件と手順を解説します。

FreeBSD 11.1にBlacklistdをインストールする方法

FreeBSD 11.1にBlacklistdをインストールする方法

FreeBSD 11.1におけるBlacklistdのインストール方法について詳しく解説します。この方法を通じて、強力なセキュリティ対策を実装できます。

Windows Serverのサーバーマネージャーを使用した複数サーバーの管理

Windows Serverのサーバーマネージャーを使用した複数サーバーの管理

サーバーマネージャーを使用して、Windows Serverの管理が向上します。セキュリティリスクを軽減し、効率的な管理を実現します。

CentOS 7にSeafileサーバーをインストールする方法

CentOS 7にSeafileサーバーをインストールする方法

CentOS 7にSeafileサーバーをインストールする方法。Seafile(コミュニティバージョン)は、ownCloudに似た無料のオープンソースファイル同期および共有ソリューションです。

DebianでSnortを設定する方法

DebianでSnortを設定する方法

Snortは無料のネットワーク侵入検知システムです。最新の方法で、SnortをDebianにインストールし、設定する手順を紹介します。ネットワークのセキュリティを強化しましょう。

CentOS 7にGraylogサーバーをインストールする方法

CentOS 7にGraylogサーバーをインストールする方法

CentOS 7にGraylogサーバーをインストールし、ログ管理を行う方法を学びます。

WindowsでhMailServerを使用してメールサーバーを構築する

WindowsでhMailServerを使用してメールサーバーを構築する

WindowsサーバーでWebサイトを実行している場合、電子メールも受信できるようにするためにhMailServerを使用する方法を解説します。

Ubuntu 19.04にFiveMサーバーをインストールする方法

Ubuntu 19.04にFiveMサーバーをインストールする方法

FiveMサーバーをUbuntu 19.04にインストールするための詳細なガイド。必要条件からインストール、起動、トラブルシューティングまで、すべてのステップを含みます。

WsgiDAVを使用してDebian 10にWebDAVをデプロイする

WsgiDAVを使用してDebian 10にWebDAVをデプロイする

Debian 10にWebDAVをデプロイする方法を学び、WsgiDAVとSSL証明書で安全な接続を実現しましょう。

ヘルスケア2021における人工知能の影響

ヘルスケア2021における人工知能の影響

ヘルスケアにおけるAIは、過去数十年から大きな飛躍を遂げました。したがって、ヘルスケアにおけるAIの未来は、日々成長を続けています。