Skip to content

php,mysql, phpmyadmin, composer, xdebug, php_codesniffer

Notifications You must be signed in to change notification settings

OBookBook/php-docker-env

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

4 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

環境概要

  • Docker
  • PHP:8.2-apache
  • MySQL:8.0
  • phpMyAdmin:latest
  • VSCode
  • Xdebug
  • Composer
  • PHP_CodeSniffer

ディレクトリ構造とファイルの役割

プロジェクトのディレクトリ構造と各ファイルの役割は以下の通りです。

├── .vscode
│   └── launch.json # VSCodeデバッグ構成を定義するファイル(xdebug設定)
├── Dockerfile
├── README.md
├── composer.json # PHP_CodeSnifferの設定
├── docker-compose.yml # Dockerコンテナの設定とphp.iniのマウント
├── index.php
└── php.ini # Xdebugの設定

Dockerの設定

docker-compose.ymlを作成

docker-compose.ymlファイルを編集し、以下の項目を各自の環境に合わせて設定してください。セキュリティ上の注意を怠らないようにしてください。

version: "3.7"
services:
  db:
    image: mysql:8.0
    container_name: mysql
    restart: always
    environment:
      # ルートユーザのパスワードを各自で設定してください
      MYSQL_ROOT_PASSWORD: root_password_kimetene
      # データベース名を各自で設定してください
      MYSQL_DATABASE: db_local
      # データベース接続ユーザ名を各自で設定してください
      MYSQL_USER: db_user
      # データベース接続パスワードを各自で設定してください
      MYSQL_PASSWORD: db_password_kimetene
  php:
    build: ./
    container_name: php
    volumes:
      - ./php.ini:/usr/local/etc/php/php.ini
      - ./:/var/www/html
    ports:
      - 9080:80
    depends_on:
      - db
  phpmyadmin:
    image: phpmyadmin/phpmyadmin:latest
    container_name: phpmyadmin
    restart: always
    depends_on:
      - db
    ports:
      - 9090:80

Dockerfileを作成

Dockerfileを編集し、以下の内容に従って設定してください。

FROM php:8.2-apache

# xdebug 環境構築
RUN pecl install xdebug && \
  docker-php-ext-enable xdebug

# Docker 公式の Composer イメージ を使用
COPY --from=composer:latest /usr/bin/composer /usr/bin/composer

# Composer パッケージ管理する為の環境構築
RUN apt-get update && \
  apt-get install -y sudo git
# Composerの設定
RUN echo 'export PATH="$PATH:/root/.composer/vendor/bin"' >> /root/.bashrc
# Composerキャッシュのクリア
RUN composer global clear-cache

# php_codesniffer を使うための環境構築
RUN composer global require --no-interaction "squizlabs/php_codesniffer=*" && \
  composer require --dev --no-interaction squizlabs/php_codesniffer

Compoerの設定

composer.jsonを作成 (php_codesniffer)

composer.jsonファイルを編集して、必要なパッケージを追加してください。 PHP_CodeSnifferを使用します。

{
    "require-dev": {
        "squizlabs/php_codesniffer": "^3.7"
    }
}

xdebugの設定

php.iniを作成

php.iniファイルを作成してXdebugの設定を追加してください。

[xdebug]
xdebug.client_host = host.docker.internal
xdebug.mode = debug
xdebug.start_with_request = yes
xdebug.discover_client_host = 0
xdebug.remote_handler = "dbgp"
xdebug.client_port = 9003

VSCodeで拡張機能「PHP Debug」をインストール

PHP Debugで検索して、ダウンロードして下さい。

VSCodeで「launch.json」を作成

PHP DebugをインストールしたらVSCodeの左側にデバッグボタンが出現します。 ボタンを押下して、launch.jsonを作成して下さい。

launch.jsonでxdebugの設定

Dockerで作成する開発コンテナとxdebugを繋げてます。詳しい事はコメントの通りです。

    {
      "name": "Listen for Xdebug",
      "type": "php",
      "request": "launch",
      // php.iniファイルのxdebug.client_port = 9003 と同じPORTを指定して下さい!
      "port": 9003,
      // Xdebugが動かなかったら、PATHの設定を見直してみて下さい!
      "pathMappings": {
        "/var/www/html": "${workspaceRoot}"
        // "/var/www/html": "c:/Users/***/***/***/***/***/" 絶対バスで指定したら確実に動きます。
      }
    }

使い方

Dockerファイルがあるプロジェクトへ移動

  1. Dockerを起動し、コンテナを作成するコマンドです。
docker-compose up -d

Webサーバが正常に動いているか確認

本プロジェクトのトップページ(index.php)です。 2. 以下のURLでアクセスできます:http://localhost:9080/

phpMyAdminが正常に動いているか確認

3. 以下のURLでアクセスできます:http://localhost:9090/

Dockerコンテナにログイン

  1. Dockerコンテナに入るコマンドです。
docker container exec -it php bash

Composerでphp_codesnifferをダウンロード

  1. Composerを使用してパッケージをインストールするコマンドです。
composer install

静的解析(PHP_CodeSniffer)ツールの使用方法

  1. index.phpをPSR-12に従って静的解析するコマンドです。
./vendor/bin/phpcs --standard=PSR12 ./index.php

xdebugの使用方法

  1. VSCodeでデバッグ実行をする手順は以下の通りです。
  • index.php ファイルにブレークポイントを設定します。
  • VSCodeでデバッグ実行を開始します。
  • プラウザからindex.phpにアクセスします。:http://localhost:9080/

About

php,mysql, phpmyadmin, composer, xdebug, php_codesniffer

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published