[Linux]Docker で MariaDB のコンテナの使用
公開日:2025-11-30
更新日:2025-11-30
更新日:2025-11-30
1. 概要
Docker で MariaDB のコンテナを使用します。
2. MariaDB のコンテナの起動
コマンド
docker run -d \
--name mariadb-test \
--network my-app-network \
-e MYSQL_ROOT_PASSWORD=password \
-e MYSQL_DATABASE=test \
-e MYSQL_USER=app \
-e MYSQL_PASSWORD=password \
-p 3306:3306 \
mariadb:12.0.2
MariaDB の他のバージョンは、Docker 公式イメージで確認できます。--name で、コンテナ名を指定します。
-e MYSQL_ROOT_PASSWORD で、rootユーザのパスワードを設定します。
-e MYSQL_DATABASE で、データベースを作成します。
上記の場合、test と言う DB が作成されます。
-e MYSQL_USER で、ユーザを作成します。
上記の場合、app と言うユーザが作成されます。
このユーザは、-e MYSQL_DATABASE で作成した DB と information_schema にのみアクセス可能です。
-e MYSQL_PASSWORD で、-e MYSQL_USER で作成したユーザのパスワードを設定します。
-p はポートフォワーディングです。
3. 動作確認
コンテナの MariaDB に bash で接続します。
MariaDB にログインします。
app は、MYSQL_USER で指定したユーザです。
exit で MariaDB とコンテナから抜けます。
コマンド
docker exec -it mariadb-test bash
MariaDB にログインします。
コマンド
mariadb -u app -p
パスワードは、MYSQL_PASSWORD で指定したものを入力します。app は、MYSQL_USER で指定したユーザです。
コマンド
# DB一覧の表示
show databases;
# DB の選択
use test
# テーブル一覧の表示
show tables;
# テーブルの作成
CREATE TABLE table1 (
id INT NOT NULL AUTO_INCREMENT,
text TEXT NOT NULL,
PRIMARY KEY (id)
) ENGINE = InnoDB;
# データの作成
INSERT INTO table1 (text) values ('test1'), ('test2'), ('test3');
# 追加したデータの確認
select * from table1;
exit で MariaDB とコンテナから抜けます。
4. php-fpm のコンテナとの連携
MariaDB にアクセスする php を作成します。
~/docker_test/nginx/html/test_db.php
php-fpm のコンテナに接続します。
pdo と pdo_mysql をインストールします。
exit でコンテナから抜けます。
php-fpm を再起動します。
http://localhost:8080/test_db.php
にアクセスして、insert したテストデータが表示されれば OK です。
~/docker_test/nginx/html/test_db.php
コード
<?php
$pdo = new PDO('mysql:host=mariadb-test;dbname=test;charset=utf8mb4',
'app', // user
'password', // password
[
PDO::ATTR_ERRMODE => PDO::ERRMODE_EXCEPTION,
PDO::ATTR_DEFAULT_FETCH_MODE => PDO::FETCH_ASSOC,
// プリペアドステートメントをエミュレートしない
PDO::ATTR_EMULATE_PREPARES => false,
]
);
$stmt = $pdo->query('SELECT * FROM table1');
while ($row = $stmt->fetch()) {
var_dump($row['id']);
var_dump($row['text']);
}
php-fpm のコンテナに接続します。
コマンド
docker exec -it php-fpm bash
pdo と pdo_mysql をインストールします。
コマンド
docker-php-ext-install pdo pdo_mysql
exit でコンテナから抜けます。
php-fpm を再起動します。
コマンド
docker restart php-fpm
http://localhost:8080/test_db.php
にアクセスして、insert したテストデータが表示されれば OK です。

