著者は、 Write for DOnations プログラムの一環として、 FreeBSDFoundationを選択して寄付を受け取りました。

序章

過去数年間、 Docker は、一時的なコンテナーでのアプリケーションの実行とデプロイを簡素化する方法のおかげで、アプリケーションをデプロイするために頻繁に使用されるソリューションになりました。 たとえば、 PHP Nginx MySQL 、および Laravel フレームワークでLEMPアプリケーションスタックを使用する場合、Dockerはセットアッププロセス。

Docker Compose は、開発者がアプリケーションサービス、ネットワーク、ボリュームなどのインフラストラクチャを1つのファイルで定義できるようにすることで、開発プロセスをさらに簡素化しました。 Docker Composeは、複数を実行する代わりの効率的な方法を提供します docker container createdocker container run コマンド。

このチュートリアルでは、Laravelフレームワークを使用してWebアプリケーションを構築します。NginxをWebサーバー、MySQLをデータベースとして、すべてDockerコンテナー内に配置します。 スタック構成全体を docker-compose ファイル、およびPHP、MySQL、およびNginxの構成ファイル。

前提条件

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

  • 1台のUbuntu18.04サーバー、およびroot以外のユーザー sudo 特権。 Ubuntu 18.04を使用したサーバーの初期設定チュートリアルに従って、これを設定します。
  • Ubuntu18.04にDockerをインストールして使用する方法の手順1と2に従ってDockerをインストールしました。
  • Ubuntu 18.04にDockerComposeをインストールする方法のステップ1に従って、DockerComposeをインストールしました。

ステップ1—Laravelのダウンロードと依存関係のインストール

最初のステップとして、最新バージョンのLaravelを入手し、PHPのアプリケーションレベルのパッケージマネージャーであるComposerを含むプロジェクトの依存関係をインストールします。 Composerをグローバルにインストールする必要がないように、Dockerを使用してこれらの依存関係をインストールします。

まず、ホームディレクトリにいることを確認し、最新のLaravelリリースをというディレクトリに複製します。 laravel-app:

  1. cd ~
  2. git clone https://github.com/laravel/laravel.git laravel-app

に移動します laravel-app ディレクトリ:

  1. cd ~/laravel-app

次に、Dockerの composer image を使用して、Laravelプロジェクトに必要なディレクトリをマウントし、Composerをグローバルにインストールするオーバーヘッドを回避します。

  1. docker run --rm -v $(pwd):/app composer install

を使用して -v--rm フラグ docker run 削除される前に現在のディレクトリにバインドマウントされるエフェメラルコンテナを作成します。 これはあなたの内容をコピーします ~/laravel-app コンテナへのディレクトリと、 vendor Composerがコンテナ内に作成するフォルダは、現在のディレクトリにコピーされます。

最後のステップとして、プロジェクトディレクトリに権限を設定して、root以外のユーザーが所有するようにします。

  1. sudo chown -R $USER:$USER ~/laravel-app

これは、ステップ4でアプリケーションイメージのDockerfileを作成するときに重要になります。これにより、アプリケーションコードを操作し、root以外のユーザーとしてコンテナー内のプロセスを実行できるようになります。

アプリケーションコードを配置したら、DockerComposeを使用したサービスの定義に進むことができます。

ステップ2—Docker作成ファイルの作成

Docker Composeを使用してアプリケーションを構築すると、インフラストラクチャのセットアップとバージョン管理のプロセスが簡素化されます。 Laravelアプリケーションをセットアップするために、 docker-compose Webサーバー、データベース、およびアプリケーションサービスを定義するファイル。

ファイルを開きます。

  1. nano ~/laravel-app/docker-compose.yml

の中に docker-compose ファイルでは、次の3つのサービスを定義します。 app, webserver、 と db. 次のコードをファイルに追加します。必ずrootパスワードを置き換えてください。 MYSQL_ROOT_PASSWORD環境変数として定義されています db 選択した強力なパスワードを使用したサービス:

〜/ laravel-app / docker-compose.yml
version: '3'
services:
  
  #PHP Service
  app:
    build:
      context: .
      dockerfile: Dockerfile
    image: digitalocean.com/php
    container_name: app
    restart: unless-stopped
    tty: true
    environment:
      SERVICE_NAME: app
      SERVICE_TAGS: dev
    working_dir: /var/www
    networks:
      - app-network

  #Nginx Service
  webserver:
    image: nginx:alpine
    container_name: webserver
    restart: unless-stopped
    tty: true
    ports:
      - "80:80"
      - "443:443"
    networks:
      - app-network

  #MySQL Service
  db:
    image: mysql:5.7.22
    container_name: db
    restart: unless-stopped
    tty: true
    ports:
      - "3306:3306"
    environment:
      MYSQL_DATABASE: laravel
      MYSQL_ROOT_PASSWORD: your_mysql_root_password
      SERVICE_TAGS: dev
      SERVICE_NAME: mysql
    networks:
      - app-network

#Docker Networks
networks:
  app-network:
    driver: bridge

ここで定義されるサービスは次のとおりです。

  • app:このサービス定義にはLaravelアプリケーションが含まれており、カスタムDockerイメージを実行します。 digitalocean.com/php、ステップ4で定義します。 また、 working_dir コンテナに /var/www.
  • webserver:このサービス定義は、Dockerから nginx:alpine image をプルし、ポートを公開します 80443.
  • db:このサービス定義は、Dockerから mysql:5.7.22 image をプルし、次のデータベースを含むいくつかの環境変数を定義します。 laravel アプリケーションの場合はrootパスワード、データベースの場合はrootパスワード。 データベースには自由に名前を付けることができ、置き換える必要があります your_mysql_root_password あなた自身の強力なパスワードで。 このサービス定義はポートもマップします 3306 ホストからポートへ 3306 コンテナに。

container_name プロパティは、サービスの名前に対応するコンテナの名前を定義します。 このプロパティを定義しない場合、Dockerは、歴史的に有名な人物の名前とアンダースコアで区切られたランダムな単語を組み合わせて、各コンテナーに名前を割り当てます。

コンテナ間の通信を容易にするために、サービスはと呼ばれるブリッジネットワークに接続されます app-network. ブリッジネットワークは、同じブリッジネットワークに接続されたコンテナが相互に通信できるようにするソフトウェアブリッジを使用します。 ブリッジドライバーは、ホストマシンにルールを自動的にインストールして、異なるブリッジネットワーク上のコンテナーが相互に直接通信できないようにします。 これにより、アプリケーションのセキュリティレベルが向上し、関連するサービスのみが相互に通信できるようになります。 また、関連する機能に接続する複数のネットワークとサービスを定義できることも意味します。フロントエンドアプリケーションサービスは、 frontend たとえば、ネットワーク、およびバックエンドサービスは backend 通信網。

アプリケーションデータを永続化するために、ボリュームを追加し、マウントをサービス定義にバインドする方法を見てみましょう。

ステップ3—データの永続化

Dockerには、データを永続化するための強力で便利な機能があります。 このアプリケーションでは、ボリュームバインドマウントを使用して、データベース、アプリケーション、および構成ファイルを永続化します。 ボリュームは、コンテナのライフサイクルを超えたバックアップと永続性の柔軟性を提供し、バインドマウントは、開発中のコード変更を容易にし、ホストファイルまたはディレクトリへの変更をコンテナですぐに利用できるようにします。 私たちのセットアップは両方を利用します。

警告:バインドマウントを使用すると、重要なシステムファイルまたはディレクトリの作成、変更、削除など、コンテナで実行されているプロセスを通じてホストファイルシステムを変更できます。 これはセキュリティに影響を与える強力な機能であり、ホストシステム上のDocker以外のプロセスに影響を与える可能性があります。 バインドマウントは注意して使用してください。

の中に docker-compose ファイル、と呼ばれるボリュームを定義します dbdatadb MySQLデータベースを永続化するためのサービス定義:

〜/ laravel-app / docker-compose.yml
...
#MySQL Service
db:
  ...
    volumes:
      - dbdata:/var/lib/mysql
    networks:
      - app-network
  ...

名前付きボリューム dbdata の内容を保持します /var/lib/mysql コンテナ内に存在するフォルダ。 これにより、停止して再起動できます db データを失うことなくサービス。

ファイルの下部に、の定義を追加します dbdata 音量:

〜/ laravel-app / docker-compose.yml
...
#Volumes
volumes:
  dbdata:
    driver: local

この定義を設定すると、サービス全体でこのボリュームを使用できるようになります。

次に、バインドマウントをに追加します db 手順7で作成するMySQL構成ファイルのサービス:

〜/ laravel-app / docker-compose.yml
...
#MySQL Service
db:
  ...
    volumes:
      - dbdata:/var/lib/mysql
      - ./mysql/my.cnf:/etc/mysql/my.cnf
  ...

このバインドマウントバインド ~/laravel-app/mysql/my.cnf/etc/mysql/my.cnf コンテナ内。

次に、バインドマウントをに追加します webserver サービス。 2つあります。1つはアプリケーションコード用で、もう1つはステップ6で作成するNginx構成定義用です。

〜/ laravel-app / docker-compose.yml
#Nginx Service
webserver:
  ...
  volumes:
      - ./:/var/www
      - ./nginx/conf.d/:/etc/nginx/conf.d/
  networks:
      - app-network

最初のバインドマウントは、アプリケーションコードをバインドします ~/laravel-app ディレクトリへの /var/www コンテナ内のディレクトリ。 追加する構成ファイル ~/laravel-app/nginx/conf.d/ にマウントされます /etc/nginx/conf.d/ コンテナ内で、必要に応じて構成ディレクトリの内容を追加または変更できます。

最後に、次のバインドマウントをに追加します app アプリケーションコードと構成ファイルのサービス:

〜/ laravel-app / docker-compose.yml
#PHP Service
app:
  ...
  volumes:
       - ./:/var/www
       - ./php/local.ini:/usr/local/etc/php/conf.d/local.ini
  networks:
      - app-network

The app サービスはバインドマウントです ~/laravel-app アプリケーションコードを含むフォルダを /var/www コンテナ内のフォルダ。 これにより、ローカルアプリケーションディレクトリに加えられた変更がコンテナ内に即座に反映されるため、開発プロセスがスピードアップします。 PHP構成ファイルもバインドしています。 ~/laravel-app/php/local.ini、 に /usr/local/etc/php/conf.d/local.ini コンテナ内。 手順5でローカルPHP構成ファイルを作成します。

君の docker-compose ファイルは次のようになります。

〜/ laravel-app / docker-compose.yml
version: '3'
services:
  
  #PHP Service
  app:
    build:
      context: .
      dockerfile: Dockerfile
    image: digitalocean.com/php
    container_name: app
    restart: unless-stopped
    tty: true
    environment:
      SERVICE_NAME: app
      SERVICE_TAGS: dev
    working_dir: /var/www
    volumes:
      - ./:/var/www
      - ./php/local.ini:/usr/local/etc/php/conf.d/local.ini
    networks:
      - app-network

  #Nginx Service
  webserver:
    image: nginx:alpine
    container_name: webserver
    restart: unless-stopped
    tty: true
    ports:
      - "80:80"
      - "443:443"
    volumes:
      - ./:/var/www
      - ./nginx/conf.d/:/etc/nginx/conf.d/
    networks:
      - app-network

  #MySQL Service
  db:
    image: mysql:5.7.22
    container_name: db
    restart: unless-stopped
    tty: true
    ports:
      - "3306:3306"
    environment:
      MYSQL_DATABASE: laravel
      MYSQL_ROOT_PASSWORD: your_mysql_root_password
      SERVICE_TAGS: dev
      SERVICE_NAME: mysql
    volumes:
      - dbdata:/var/lib/mysql/
      - ./mysql/my.cnf:/etc/mysql/my.cnf
    networks:
      - app-network

#Docker Networks
networks:
  app-network:
    driver: bridge
#Volumes
volumes:
  dbdata:
    driver: local

ファイルを保存し、変更が完了したらエディターを終了します。

あなたと docker-compose ファイルが書き込まれると、アプリケーションのカスタムイメージを作成できるようになります。

ステップ4—Dockerfileを作成する

Dockerを使用すると、Dockerfileを使用して個々のコンテナー内の環境を指定できます。 Dockerfileを使用すると、アプリケーションに必要なソフトウェアをインストールし、要件に基づいて設定を構成するために使用できるカスタムイメージを作成できます。 作成したカスタムイメージをDockerHubまたは任意のプライベートレジストリにプッシュできます。

私たちの Dockerfile 私たちの中に配置されます ~/laravel-app ディレクトリ。 ファイルを作成します。

  1. nano ~/laravel-app/Dockerfile

これ Dockerfile ベースイメージを設定し、Laravelアプリケーションイメージを構築するために必要なコマンドと手順を指定します。 次のコードをファイルに追加します。

〜/ laravel-app / php / Dockerfile
FROM php:7.2-fpm

# Copy composer.lock and composer.json
COPY composer.lock composer.json /var/www/

# Set working directory
WORKDIR /var/www

# Install dependencies
RUN apt-get update && apt-get install -y \
    build-essential \
    libpng-dev \
    libjpeg62-turbo-dev \
    libfreetype6-dev \
    locales \
    zip \
    jpegoptim optipng pngquant gifsicle \
    vim \
    unzip \
    git \
    curl

# Clear cache
RUN apt-get clean && rm -rf /var/lib/apt/lists/*

# Install extensions
RUN docker-php-ext-install pdo_mysql mbstring zip exif pcntl
RUN docker-php-ext-configure gd --with-gd --with-freetype-dir=/usr/include/ --with-jpeg-dir=/usr/include/ --with-png-dir=/usr/include/
RUN docker-php-ext-install gd

# Install composer
RUN curl -sS https://getcomposer.org/installer | php -- --install-dir=/usr/local/bin --filename=composer

# Add user for laravel application
RUN groupadd -g 1000 www
RUN useradd -u 1000 -ms /bin/bash -g www www

# Copy existing application directory contents
COPY . /var/www

# Copy existing application directory permissions
COPY --chown=www:www . /var/www

# Change current user to www
USER www

# Expose port 9000 and start php-fpm server
EXPOSE 9000
CMD ["php-fpm"]

まず、Dockerfileは、 php:7.2-fpmDockerイメージの上にイメージを作成します。 これは、PHPFastCGI実装PHP-FPMがインストールされているDebianベースのイメージです。 このファイルは、Laravelの前提条件パッケージもインストールします。 mcrypt, pdo_mysql, mbstring、 と imagickcomposer.

The RUN ディレクティブは、 www と呼ばれる専用のユーザーとグループの作成を含む、コンテナー内の設定を更新、インストール、および構成するためのコマンドを指定します。 The WORKDIR 命令は /var/www アプリケーションの作業ディレクトリとしてのディレクトリ。

権限が制限された専用のユーザーとグループを作成すると、デフォルトでrootとして実行されるDockerコンテナーを実行する際の固有の脆弱性が軽減されます。 このコンテナをrootとして実行する代わりに、wwwユーザーを作成しました。このユーザーは /var/www フォルダーのおかげで COPY で使用している命令 --chown アプリケーションフォルダの権限をコピーするためのフラグ。

最後に、 EXPOSE コマンドはコンテナ内のポートを公開し、 9000、 のために php-fpm サーバ。 CMD コンテナの作成後に実行するコマンドを指定します。 ここ、 CMD 指定します "php-fpm"、サーバーを起動します。

ファイルを保存し、変更が完了したらエディターを終了します。

これで、PHP構成の定義に進むことができます。

ステップ5—PHPの設定

これで、インフラストラクチャを docker-compose ファイルの場合、Nginxからの着信要求のPHPプロセッサとして機能するようにPHPサービスを構成できます。

PHPを構成するには、 local.ini 内部のファイル php フォルダ。 これは、バインドマウント先のファイルです /usr/local/etc/php/conf.d/local.ini 手順2のコンテナ内。 このファイルを作成すると、デフォルトを上書きできます php.ini PHPが起動時に読み取るファイル。

を作成します php ディレクトリ:

  1. mkdir ~/laravel-app/php

次に、 local.ini ファイル:

  1. nano ~/laravel-app/php/local.ini

PHPを構成する方法を示すために、アップロードされたファイルのサイズ制限を設定する次のコードを追加します。

〜/ laravel-app / php / local.ini
upload_max_filesize=40M
post_max_size=40M

The upload_max_filesizepost_max_size ディレクティブは、アップロードされたファイルの最大許容サイズを設定し、設定方法を示します php.ini あなたからの構成 local.ini ファイル。 オーバーライドするPHP固有の構成を local.ini ファイル。

ファイルを保存して、エディターを終了します。

あなたのPHPで local.ini ファイルを配置したら、Nginxの構成に進むことができます。

ステップ6—Nginxを構成する

PHPサービスを構成したら、動的コンテンツを提供するFastCGIサーバーとしてPHP-FPMを使用するようにNginxサービスを変更できます。 FastCGIサーバーは、対話型プログラムをWebサーバーとインターフェースするためのバイナリプロトコルに基づいています。 詳細については、NginxでのFastCGIプロキシの理解と実装に関するこの記事を参照してください。

Nginxを構成するには、 app.conf のサービス構成を含むファイル ~/laravel-app/nginx/conf.d/ フォルダ。

まず、を作成します nginx/conf.d/ ディレクトリ:

  1. mkdir -p ~/laravel-app/nginx/conf.d

次に、を作成します app.conf 構成ファイル:

  1. nano ~/laravel-app/nginx/conf.d/app.conf

次のコードをファイルに追加して、Nginx構成を指定します。

〜/ laravel-app / nginx / conf.d / app.conf
server {
    listen 80;
    index index.php index.html;
    error_log  /var/log/nginx/error.log;
    access_log /var/log/nginx/access.log;
    root /var/www/public;
    location ~ \.php$ {
        try_files $uri =404;
        fastcgi_split_path_info ^(.+\.php)(/.+)$;
        fastcgi_pass app:9000;
        fastcgi_index index.php;
        include fastcgi_params;
        fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
        fastcgi_param PATH_INFO $fastcgi_path_info;
    }
    location / {
        try_files $uri $uri/ /index.php?$query_string;
        gzip_static on;
    }
}

サーバーブロックは、次のディレクティブを使用してNginxWebサーバーの構成を定義します。

  • listen:このディレクティブは、サーバーが着信要求をリッスンするポートを定義します。
  • error_logaccess_log:これらのディレクティブは、ログを書き込むためのファイルを定義します。
  • root:このディレクティブはルートフォルダのパスを設定し、ローカルファイルシステム上の要求されたファイルへの完全なパスを形成します。

の中に php ロケーションブロック、 fastcgi_pass ディレクティブは、 app サービスはポートのTCPソケットでリッスンしています 9000. これにより、PHP-FPMサーバーはUnixソケットではなくネットワークを介してリッスンします。 UnixソケットはTCPソケットよりも速度がわずかに優れていますが、ネットワークプロトコルがないため、ネットワークスタックをスキップします。 ホストが1台のマシンにある場合、Unixソケットは理にかなっていますが、異なるホストでサービスを実行している場合、TCPソケットには分散サービスに接続できるという利点があります。 私たちの app コンテナは、私たちとは異なるホストで実行されています webserver コンテナであるTCPソケットは、この構成に最も適しています。

ファイルを保存し、変更が完了したらエディターを終了します。

手順2で作成したバインドマウントのおかげで、内部で行った変更はすべて nginx/conf.d/ フォルダは直接内部に反映されます webserver 容器。

次に、MySQLの設定を見てみましょう。

ステップ7—MySQLの構成

PHPとNginxを構成すると、MySQLがアプリケーションのデータベースとして機能できるようになります。

MySQLを構成するには、 my.cnf のファイル mysql フォルダ。 これは、バインドマウント先のファイルです /etc/mysql/my.cnf 手順2のコンテナ内。 このバインドマウントを使用すると、 my.cnf 必要に応じて設定します。

これがどのように機能するかを示すために、設定を追加します my.cnf 一般的なクエリログを有効にし、ログファイルを指定するファイル。

まず、を作成します mysql ディレクトリ:

  1. mkdir ~/laravel-app/mysql

次に、 my.cnf ファイル:

  1. nano ~/laravel-app/mysql/my.cnf

ファイルに次のコードを追加して、クエリログを有効にし、ログファイルの場所を設定します。

〜/ laravel-app / mysql / my.cnf
[mysqld]
general_log = 1
general_log_file = /var/lib/mysql/general.log

これ my.cnf ファイルはログを有効にし、 general_log として設定 1 一般的なログを許可します。 The general_log_file 設定は、ログが保存される場所を指定します。

ファイルを保存して、エディターを終了します。

次のステップは、コンテナを起動することです。

ステップ8—環境設定の変更とコンテナの実行

これで、すべてのサービスを定義しました。 docker-compose ファイルを作成し、これらのサービスの構成ファイルを作成すると、コンテナーを開始できます。 ただし、最後のステップとして、 .env.example Laravelがデフォルトで含むファイルとコピーに名前を付ける .env、これはLaravelが環境を定義することを期待しているファイルです:

  1. cp .env.example .env

これで、 .env 上のファイル app 設定に関する特定の詳細を含むコンテナ。

を使用してファイルを開く nano または選択したテキストエディタ:

  1. nano .env

指定するブロックを検索します DB_CONNECTION セットアップの詳細を反映するように更新します。 次のフィールドを変更します。

  • DB_HOST あなたになります db データベースコンテナ。
  • DB_DATABASE になります laravel データベース。
  • DB_USERNAME データベースに使用するユーザー名になります。 この場合、 laraveluser.
  • DB_PASSWORD このユーザーアカウントに使用する安全なパスワードになります。
/var/www/.env
DB_CONNECTION=mysql
DB_HOST=db
DB_PORT=3306
DB_DATABASE=laravel
DB_USERNAME=laraveluser
DB_PASSWORD=your_laravel_db_password

変更を保存して、エディターを終了します。

すべてのサービスが docker-compose ファイルの場合、1つのコマンドを発行して、すべてのコンテナーを起動し、ボリュームを作成し、ネットワークをセットアップして接続する必要があります。

  1. docker-compose up -d

あなたが走るとき docker-compose up 初めて、必要なすべてのDockerイメージがダウンロードされます。これには時間がかかる場合があります。 イメージがダウンロードされてローカルマシンに保存されると、Composeがコンテナを作成します。 The -d flagはプロセスをデーモン化し、コンテナーをバックグラウンドで実行します。

プロセスが完了したら、次のコマンドを使用して、実行中のすべてのコンテナーを一覧表示します。

  1. docker ps

次の出力とあなたの詳細が表示されます app, webserver、 と db コンテナ:

Output
CONTAINER ID NAMES IMAGE STATUS PORTS c31b7b3251e0 db mysql:5.7.22 Up 2 seconds 0.0.0.0:3306->3306/tcp ed5a69704580 app digitalocean.com/php Up 2 seconds 9000/tcp 5ce4ee31d7c0 webserver nginx:alpine Up 2 seconds 0.0.0.0:80->80/tcp, 0.0.0.0:443->443/tcp

The CONTAINER ID この出力には、各コンテナの一意の識別子がありますが、 NAMES それぞれに関連付けられているサービス名を一覧表示します。 これらの識別子の両方を使用して、コンテナにアクセスできます。 IMAGE 各コンテナのイメージ名を定義し、 STATUS コンテナの状態(実行中、再起動中、停止中)に関する情報を提供します。

これから使用します docker-compose exec Laravelアプリケーションのアプリケーションキーを設定します。 The docker-compose exec commandを使用すると、コンテナ内で特定のコマンドを実行できます。

次のコマンドはキーを生成し、それをあなたの .env ファイル、ユーザーセッションと暗号化されたデータの安全性を確保します。

  1. docker-compose exec app php artisan key:generate

これで、アプリケーションの実行に必要な環境設定ができました。 これらの設定をファイルにキャッシュして、アプリケーションの読み込み速度を上げるには、次のコマンドを実行します。

  1. docker-compose exec app php artisan config:cache

構成設定がにロードされます /var/www/bootstrap/cache/config.php コンテナに。

最後のステップとして、 http://your_server_ip ブラウザで。 Laravelアプリケーションの次のホームページが表示されます。

コンテナが実行され、構成情報が配置されたら、次のユーザー情報の構成に進むことができます。 laravel 上のデータベース db 容器。

ステップ9—MySQLのユーザーを作成する

デフォルトのMySQLインストールでは、 root 管理者アカウントのみが作成されます。このアカウントには、データベースサーバーに対する無制限の権限があります。 一般に、データベースを操作するときは、root管理者アカウントの使用を避けることをお勧めします。 代わりに、アプリケーションのLaravelデータベース専用のデータベースユーザーを作成しましょう。

新しいユーザーを作成するには、でインタラクティブなbashシェルを実行します db コンテナ docker-compose exec:

  1. docker-compose exec db bash

コンテナ内で、MySQL root管理者アカウントにログインします。

  1. mysql -u root -p

インストール中にMySQLrootアカウントに設定したパスワードの入力を求められます。 docker-compose ファイル。

と呼ばれるデータベースをチェックすることから始めます laravel、あなたがあなたの中で定義した docker-compose ファイル。 を実行します show databases 既存のデータベースをチェックするコマンド:

  1. show databases;

が表示されます laravel 出力にリストされているデータベース:

Output
+--------------------+ | Database | +--------------------+ | information_schema | | laravel | | mysql | | performance_schema | | sys | +--------------------+ 5 rows in set (0.00 sec)

次に、このデータベースへのアクセスを許可するユーザーアカウントを作成します。 ユーザー名は laraveluser、ただし、必要に応じてこれを別の名前に置き換えることができます。 ここでのユーザー名とパスワードが、で設定した詳細と一致していることを確認してください .env 前のステップのファイル:

  1. GRANT ALL ON laravel.* TO 'laraveluser'@'%' IDENTIFIED BY 'your_laravel_db_password';

MySQLサーバーに変更を通知するための特権をフラッシュします。

  1. FLUSH PRIVILEGES;

MySQLを終了します:

  1. EXIT;

最後に、コンテナを終了します。

  1. exit

Laravelアプリケーションデータベースのユーザーアカウントを構成し、データを移行してTinkerコンソールを操作する準備が整いました。

ステップ10—データの移行とTinkerコンソールの操作

アプリケーションを実行した状態で、データを移行して、 tinker コマンド。Laravelがプリロードされた状態でPsySHコンソールを開始します。 PsySHはPHP用のランタイム開発者コンソールおよびインタラクティブデバッガーであり、TinkerはLaravel専用のREPLです。 を使用して tinker コマンドを使用すると、インタラクティブシェルのコマンドラインからLaravelアプリケーションを操作できます。

まず、Laravelを実行してMySQLへの接続をテストします artisan migrate コマンド、作成します migrations コンテナ内からのデータベース内のテーブル:

  1. docker-compose exec app php artisan migrate

このコマンドは、デフォルトのLaravelテーブルを移行します。 移行を確認する出力は次のようになります。

Output
Migration table created successfully. Migrating: 2014_10_12_000000_create_users_table Migrated: 2014_10_12_000000_create_users_table Migrating: 2014_10_12_100000_create_password_resets_table Migrated: 2014_10_12_100000_create_password_resets_table

移行が完了したら、クエリを実行して、データベースに正しく接続されているかどうかを確認できます。 tinker 指図:

  1. docker-compose exec app php artisan tinker

移行したばかりのデータを取得して、MySQL接続をテストします。

  1. \DB::table('migrations')->get();

次のような出力が表示されます。

Output
=> Illuminate\Support\Collection {#2856 all: [ {#2862 +"id": 1, +"migration": "2014_10_12_000000_create_users_table", +"batch": 1, }, {#2865 +"id": 2, +"migration": "2014_10_12_100000_create_password_resets_table", +"batch": 1, }, ], }

使用できます tinker データベースと対話し、サービスとモデルを実験します。

Laravelアプリケーションを配置すると、さらなる開発と実験の準備が整います。

結論

これで、サーバー上でLEMPスタックアプリケーションが実行されました。これは、LaravelのウェルカムページにアクセスしてMySQLデータベースの移行を作成することでテストしました。

このインストールを簡単にするための鍵は、Docker Composeです。これにより、単一のコマンドで単一のファイルに定義されたDockerコンテナーのグループを作成できます。 Docker Composeを使用してCIを実行する方法について詳しく知りたい場合は、 Ubuntu16.04でDockerとDockerComposeを使用して継続的インテグレーションテスト環境を構成する方法を参照してください。 Laravelアプリケーションのデプロイプロセスを合理化したい場合は、 Ubuntu16.04にDeployerを使用してLaravelアプリケーションを自動的にデプロイする方法が関連リソースになります。