9cubed
ブログ | Tailwind | Vite | Python | MariaDB | Node.js | Linux | PowerShell | Docker | Git | その他 | 将棋ウォーズ | 歌の練習
< 前の記事

Docker で Nginx と PHP の連携

次の記事 >

Docker Compose でコンテナの作成

Linux Docker

[Linux]Docker で MariaDB のコンテナの使用

公開日: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 で、コンテナ名を指定します。

--network で、ネットワークを指定します。MariaDB 単独で使う場合は省略可能。

-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 で接続します。
コマンド
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
$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 です。
< 前の記事

Docker で Nginx と PHP の連携

次の記事 >

Docker Compose でコンテナの作成

YouTube X

新着一覧

  • テーブル結合(CROSS JOIN、INNER JOIN、LEFT JOIN)MariaDB
  • 楽観ロック・悲観ロックMariaDB
  • カレントリードMariaDB
  • インデックスMariaDB
  • 論理削除(ソフトデリート)MariaDB
  • awk(オーク)の使い方についてLinux
  • NOT NULL 制約と NULL を許容した時の動作MariaDB
  • 外部キー制約MariaDB
  • MySQL と MariaDB の関係MariaDB
  • Docker で PostgreSQL のコンテナの使用Linux

アーカイブ

  • 2026/01
  • 2025/12
  • 2025/11
  • 2025/10
  • 2025/09
  • 2025/08
  • /00

以前のカテゴリー一覧

  • CakePHP3
  • CentOS7
  • HTML・CSS・JavaScript
  • Haskell
  • JavaScript
  • Kotlin
  • Laravel5
  • PHP
  • Python
  • Ruby
  • RubyOnRails5
  • TypeScript
  • Vue.js
  • Webサーバ講座
  • Webプログラミング講座
  • jQuery
  • linux
  • パソコン講座
  • ブログ
  • プログラミング講座
  • メモ帳作成講座
  • 数学

Copyright © 9cubed. All Rights Reserved.

プライバシーポリシー 利用規約
▲