〇Joomlaの管理者画面
○構築方法
以下の手順で、Joomla3.8.13とMariaDB10.3のコンテナを構築・実行します。
1. Joomla用のMariaDBイメージの作成(Dockerfileとsetupdb.shのあるディレクトリで実行)
docker build -f Dockerfile -t mariadb-joomla .
Dockerfile-mariadb
FROM alpine:3.8
COPY ./setupdb.sh /
RUN apk --no-cache add mariadb mariadb-client \
&& addgroup mysql mysql \
&& chmod +x /setupdb.sh
VOLUME /var/lib/mysql
EXPOSE 3306
ENTRYPOINT ["/setupdb.sh"]
setupdb.sh
#!/bin/sh
if [ ! -d "/run/mysqld" ]; then
mkdir -p /run/mysqld
chown -R mysql:mysql /run/mysqld
fi
if [ ! -e /usr/my.cnf ]; then
cat << EOF > /usr/my.cnf
[mysqld]
datadir=/var/lib/mysql
log-bin = /var/lib/mysql/mysql-bin
port = 3306
user = mysql
symbolic-links=0
character-set-server = utf8
pid-file=/run/mysqld/mysqld.pid
EOF
chown -R mysql:mysql /var/lib/mysql
mysql_install_db --user=mysql
nohup /bin/sh /usr/bin/mysqld_safe \
--datadir=/var/lib/mysql \
--socket=/run/mysqld/mysqld.sock \
--pid-file=/run/mysqld/mysqld.pid \
--basedir=/usr \
--user=mysql \
--skip-grant-tables \
--skip-networking &
while :
do
[ -r /run/mysqld/mysqld.pid ] || continue
if ps -ef | grep -q $(cat /run/mysqld/mysqld.pid) ; then
break
fi
sleep 10
done
cat << EOF > /tmp/setupdb.sql
USE mysql;
UPDATE mysql.user SET Password=PASSWORD('joomla') WHERE User='root';
FLUSH PRIVILEGES;
GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' IDENTIFIED BY 'joomla';
FLUSH PRIVILEGES;
EOF
/usr/bin/mysql < /tmp/setupdb.sql
cat << EOF > /tmp/createdb.sql
CREATE DATABASE joomla DEFAULT CHARACTER SET utf8mb4;
EOF
/usr/bin/mysql -uroot -pjoomla < /tmp/createdb.sql
kill `cat /run/mysqld/mysqld.pid`
sleep 10
fi
exec /usr/bin/mysqld --defaults-file=/usr/my.cnf --console --user=mysql --character-set-server=utf8mb4 --collation-server=utf8mb4_unicode_ci
2. JoomlaとMariaDBコンテナの構築・実行(docker-compose.ymlがあるフォルダで実行)
docker-compose up -d
docker-compose.yml
version: "2"
services:
joomla:
image: joomla:3.8.13
container_name: "joomla"
volumes:
- "joomla-data:/var/www/html"
ports:
- "80:80"
depends_on:
- db
environment:
JOOMLA_DB_HOST: db
MYSQL_PORT_3306_TCP: 3306
JOOMLA_DB_NAME: joomla
JOOMLA_DB_USER: root
JOOMLA_DB_PASSWORD: joomla
db:
image: mariadb-joomla
container_name: "joomla-db"
volumes:
- "db-data:/var/lib/mysql"
ports:
- "3306:3306"
volumes:
db-data:
driver: local
joomla-data:
driver: local
3.ブラウザでhttp://<Dockerホスト名またはIP>/にアクセスして、サイト設定画面のサイト名称や管理者情報を入力します。
4.データベース設定画面で接続情報を入力します。
データベース: MySQLi
ホスト名: db
ユーザ名: root
パスワード: joomla
データベース: joomla
5. 最終確認画面で設定内容を確認し、「インストール」ボタンをクリックする
6. インストール完了画面で「installationディレクトリを削除」ボタンをクリックします。
〇参考情報
・Raspberry PiにDockerとdocker-composeをインストールするには以下の記事を参照してください。
Raspberry Pi Raspbian GNU/Linux 9 (stretch)にdocker-composeをインストールする
・Joomlaに関する他の記事はこちらを参照してください。
0 件のコメント:
コメントを投稿