目次 †概要 †急ぎで PHP5.6、Apache2.4、MySQL5.7 の環境が必要になり、環境構築を行ったので、作業メモ。 バージョンに縛りがなければ既に存在するLAMP の dockerイメージを使用する方が早いが、
Dockerfile †# # PHP5.6、Apache2.4、MySQL5.7 # FROM centos:centos7 USER root # whichコマンドインストール RUN yum install -y which # Apacheインストール RUN yum install -y httpd # PHP5.6インストール用にリポジトリ追加(EPEL,Remi) RUN yum install -y epel-release RUN rpm -Uvh http://rpms.famillecollet.com/enterprise/remi-release-7.rpm # PHP5.6インストール RUN yum install -y --enablerepo=remi,remi-php56 php php-devel php-mbstring php-pdo php-gd php-xml php-mcrypt php-mysql # MariaDBを削除 RUN yum remove mariadb-libs RUN rm -rf /var/lib/mysql # MySQLをインストール RUN rpm -ivh http://dev.mysql.com/get/mysql57-community-release-el7-8.noarch.rpm \ && yum install -y mysql-community-server # MySQLの自動起動の設定 CMD ["systemctl", "enable", "mysqld.service"] # Apacheの自動起動設定 CMD ["systemctl", "enable", "httpd"] # 各種プロセスの起動 CMD ["/sbin/init"] ビルド †docker build ./ -t mylamp:latest 残りの初期設定 †コンテナの起動&ログイン †ここからはコンテナにログインして手動で行った。 CONTAINER_ID=`docker run -d --privileged mylamp:latest /sbin/init` \ && docker exec -it $CONTAINER_ID /bin/bash \ && docker stop $CONTAINER_ID \ && docker commit $CONTAINER_ID mylamp:latest MySQLの設定 †#初期パスワード確認 cat /var/log/mysqld.log | grep "password is generated" | head -1 | awk '{print $NF}' mysql -u root -p Enter password: 確認したパスワード # パスワードポリシーの変更 mysql> SET GLOBAL validate_password_policy=LOW; # rootパスワード変更 mysql> SET PASSWORD for root@localhost=password('rootpass'); # ホスト側からの接続を許可する為に、以下も設定しておく # (ホスト側からコンテナのMySQLに接続する際のホスト名は localhost ではなく gateway になる為) mysql> CREATE USER 'root'@'gateway' IDENTIFIED BY 'rootpass'; mysql> GRANT ALL PRIVILEGES ON *.* TO 'root'@'gateway' WITH GRANT OPTION; mysql> quit; # ターミナルを終了 #(起動時に docker stop まで入力済みなのでコンテナも終了する) # (起動時に docker commit まで入力済みなので作業状態はイメージに反映される) exit コンテナの起動 †上記までの作業でコンテナイメージが出来上がっているので、以下の通り起動する。
docker run --name mylamp -d -p 8080:80 -p 3306:3306 --privileged -v /path/to/html:/var/www/html mylamp:latest /sbin/init 次からは 「docker start mylamp」 で起動できる。 動作確認 † |