質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

ただいまの
回答率

88.04%

Docker Laravel MySQL でseederを実行すると文字化けが起こってしまう

解決済

回答 1

投稿

  • 評価
  • クリップ 0
  • VIEW 94

score 15

MySQLの文字化けが直らない

タイトル通りです。
Docker内のDBに接続して、seederを実行しているのですが、MySQL内を覗くと文字化けが起こってしまいます。
お力添えいただけると幸いです。

DBのVariable_name

以下3点が正しいため、設定は問題ないと認識しております。

  • character_set_database
  • character_set_server
  • character_set_system
+--------------------------+--------------------------------+
| Variable_name            | Value                          |
+--------------------------+--------------------------------+
| character_set_client     | latin1                         |
| character_set_connection | latin1                         |
| character_set_database   | utf8mb4                        |
| character_set_filesystem | binary                         |
| character_set_results    | latin1                         |
| character_set_server     | utf8mb4                        |
| character_set_system     | utf8mb3                        |
| character_sets_dir       | /usr/share/mysql-8.0/charsets/ |
+--------------------------+--------------------------------+
mysql> select * from users;
+----+-----------------------------------------+-----------+------------+------------------------------+---------------------+---------------------+
| id | company                                 | last_name | first_name | email                        | created_at          | updated_at          |
+----+-----------------------------------------+-----------+------------+------------------------------+---------------------+---------------------+
|  1 | ?????????????????????????????           | ?? ?      | ?? ??      | hiroshi.kato@example.net     | 2021-05-04 06:07:19 | 2021-05-04 06:07:19 |
|  2 | ????????????????????????????            | ?? ???    | ?? ??      | tsuda.kana@example.com       | 2021-05-04 06:07:19 | 2021-05-04 06:07:19 |
|  3 | ???????????????????????????????????     | ?? ??     | ?? ??      | tsuda.yosuke@example.net     | 2021-05-04 06:07:19 | 2021-05-04 06:07:19 |
|  4 | ????????????????????????????????????    | ?? ??     | ?? ??      | wakamatsu.hanako@example.org | 2021-05-04 06:07:19 | 2021-05-04 06:07:19 |
|  5 | ??????????????????????????????          | ?? ??     | ?? ?       | eyamamoto@example.net        | 2021-05-04 06:07:19 | 2021-05-04 06:07:19 |
|  6 | ????????????????????                    | ?? ?      | ? ??       | koizumi.satomi@example.net   | 2021-05-04 06:07:19 | 2021-05-04 06:07:19 |
|  7 | ???????????????????                     | ?? ??     | ?? ??      | kazuya03@example.org         | 2021-05-04 06:07:19 | 2021-05-04 06:07:19 |
|  8 | ?????????????????????????               | ??? ??    | ?? ??      | thirokawa@example.net        | 2021-05-04 06:07:19 | 2021-05-04 06:07:19 |
|  9 | ??????????????????????????????          | ?? ??     | ?? ??      | sayuri.koizumi@example.com   | 2021-05-04 06:07:19 | 2021-05-04 06:07:19 |
| 10 | ??????????????????????????????????????? | ?? ???    | ?? ??      | tsuda.jun@example.net        | 2021-05-04 06:07:19 | 2021-05-04 06:07:19 |
+----+-----------------------------------------+-----------+------------+------------------------------+---------------------+---------------------+

コード一覧

該当しそうな箇所の、以下3つのプログラムを添付させていただきます。

  • /app/docker-compose.yml
  • /app/infra/mysql/my.cnf
  • /app/backend/config/database.php
// 格納場所:/app/docker-compose.yml

version: "3.9"
services:
  app:
    build: ./infra/php
    volumes:
      - ./backend:/work

  web:
    image: nginx:1.20-alpine
    ports:
      - 10080:80
    volumes:
      - ./backend:/work
      - ./infra/nginx/default.conf:/etc/nginx/conf.d/default.conf
    working_dir: /work

  db:
    build: ./infra/mysql
    volumes:
      - db-store:/var/lib/mysql

volumes:
  db-store:
# 格納場所:/app/infra/mysql/my.cnf

[mysqld]
# character set / collation
character_set_client = utf8mb4
collation_server = utf8mb4_unicode_ci

# timezone
default-time-zone = SYSTEM
log_timestamps = SYSTEM

# Error Log
log-error = mysql-error.log

# Slow Query Log
slow_query_log = 1
slow_query_log_file = mysql-slow.log
long_query_time = 1.0
log_queries_not_using_indexes = 0

# General Log
general_log = 1
general_log_file = mysql-general.log

[mysql]
default-character-set = utf8mb4

[client]
default-character-set = utf8mb4
// 格納場所:/app/backend/config/database.php

        'mysql' => [
            'driver' => 'mysql',
            'url' => env('DATABASE_URL'),
            'host' => env('DB_HOST', '127.0.0.1'),
            'port' => env('DB_PORT', '3306'),
            'database' => env('DB_DATABASE', 'forge'),
            'username' => env('DB_USERNAME', 'forge'),
            'password' => env('DB_PASSWORD', ''),
            'unix_socket' => env('DB_SOCKET', ''),
            'charset' => 'utf8mb4',
            'collation' => 'utf8mb4_unicode_ci',
            'prefix' => '',
            'prefix_indexes' => true,
            'strict' => true,
            'engine' => null,
            'options' => extension_loaded('pdo_mysql') ? array_filter([
                PDO::MYSQL_ATTR_SSL_CA => env('MYSQL_ATTR_SSL_CA'),
            ]) : [],

試したこと

1.Dockerを再起動してseederを実行

docker-compose down --rmi all --volumes --remove-orphans
docker-compose up
docker-compose exec app bash
php artisan migrate:fresh --seed
2.DBを削除

drop databaseで削除し、その後1を再度行いました。

factory と seederも一応

# UserFactory

return [
    'company' => $this->faker->realText(rand(15, 40)),
    'last_name' => $this->faker->name(),
    'first_name' => $this->faker->name(),
    'email' => $this->faker->unique()->safeEmail(),
    'created_at' => now(),
    'updated_at' => now(),
];
// UserSeeder

public function run()
{
    User::factory()->count(10)->create();
}

お力添えいただけると幸いです。
どうぞ、よろしくお願いいたします。

  • 気になる質問をクリップする

    クリップした質問は、後からいつでもマイページで確認できます。

    またクリップした質問に回答があった際、通知やメールを受け取ることができます。

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 過去に投稿した質問と同じ内容の質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

質問への追記・修正、ベストアンサー選択の依頼

  • ucan-lab

    2021/05/04 15:54

    ./infra/mysql/Dockerfile の中身はどうなってますか?

    キャンセル

回答 1

checkベストアンサー

+1

多分、私が書いた記事を参考にしていただいたと思うんですが、
mysql/mysql-server は /etc/mysql/conf.d/ 配下の設定ファイルを読み込まないようでした。

mysql/mysql-server:8.0 のデフォルトの /etc/my.cnf

$ docker run -it mysql/mysql-server:8.0 cat /etc/my.cnf

[Entrypoint] MySQL Docker Image 8.0.24-1.2.2-server
# For advice on how to change settings please see
# http://dev.mysql.com/doc/refman/8.0/en/server-configuration-defaults.html

[mysqld]
#
# Remove leading # and set to the amount of RAM for the most important data
# cache in MySQL. Start at 70% of total RAM for dedicated server, else 10%.
# innodb_buffer_pool_size = 128M
#
# Remove leading # to turn on a very important data integrity option: logging
# changes to the binary log between backups.
# log_bin
#
# Remove leading # to set options mainly useful for reporting servers.
# The server defaults are faster for transactions and fast SELECTs.
# Adjust sizes as needed, experiment to find the optimal values.
# join_buffer_size = 128M
# sort_buffer_size = 2M
# read_rnd_buffer_size = 2M

# Remove leading # to revert to previous value for default_authentication_plugin,
# this will increase compatibility with older clients. For background, see:
# https://dev.mysql.com/doc/refman/8.0/en/server-system-variables.html#sysvar_default_authentication_plugin
# default-authentication-plugin=mysql_native_password
skip-host-cache
skip-name-resolve
datadir=/var/lib/mysql
socket=/var/lib/mysql/mysql.sock
secure-file-priv=/var/lib/mysql-files
user=mysql

pid-file=/var/run/mysqld/mysqld.pid

!include ディレクティブが設定されてないため、COPYした my.cnf が読み込まれません。

./infra/mysql/Dockerfile

FROM mysql/mysql-server:8.0

# ...

COPY ./my.cnf /etc/my.cnf
RUN chmod 644 /etc/my.cnf

./infra/mysql/my.cnf

[mysqld]
# default
skip-host-cache
skip-name-resolve
datadir=/var/lib/mysql
socket=/var/lib/mysql/mysql.sock
secure-file-priv=/var/lib/mysql-files
user=mysql

pid-file=/var/run/mysqld/mysqld.pid

# character set / collation
character_set_server = utf8mb4
collation_server = utf8mb4_ja_0900_as_cs_ks

# timezone
default-time-zone = SYSTEM
log_timestamps = SYSTEM

# Error Log
log-error = mysql-error.log

# Slow Query Log
slow_query_log = 1
slow_query_log_file = mysql-slow.log
long_query_time = 1.0
log_queries_not_using_indexes = 0

# General Log
general_log = 1
general_log_file = mysql-general.log

[mysql]
default-character-set = utf8mb4

[client]
default-character-set = utf8mb4

MySQL8.0.2以降のバージョンを利用している場合は、utf8mb4_ja_0900_as_cs_ks の文字列照合順序を利用するのがお勧めです。

https://mysqlserverteam.com/mysql-8-0-kana-sensitive-collation-for-japanese-ja_jp/

確認

$ docker-compose down -v
$ docker-compose build db
$ docker-compose up -d db
$ docker-compose exec db bash
# mysql -u${MYSQL_USER} -p${MYSQL_PASSWORD} ${MYSQL_DATABASE}
> show variables like '%char%';
+--------------------------+--------------------------------+
| Variable_name            | Value                          |
+--------------------------+--------------------------------+
| character_set_client     | utf8mb4                        |
| character_set_connection | utf8mb4                        |
| character_set_database   | utf8mb4                        |
| character_set_filesystem | binary                         |
| character_set_results    | utf8mb4                        |
| character_set_server     | utf8mb4                        |
| character_set_system     | utf8mb3                        |
| character_sets_dir       | /usr/share/mysql-8.0/charsets/ |
+--------------------------+--------------------------------+

こんな感じになってればokなはずです。

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2021/05/04 19:36

    具体的なコードまで、誠に有難うございます!
    無事、解決しました。
    他の参考記事だと、以下の3つのみ変更できれば良いと記載がありましたが、全て変えた方が良いんですね。

    character_set_database
    character_set_server
    character_set_system

    キャンセル

  • 2021/05/04 23:23

    解決してよかったです!
    文字コードは揃えておいて損はないと思います!

    キャンセル

15分調べてもわからないことは、teratailで質問しよう!

  • ただいまの回答率 88.04%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

関連した質問

同じタグがついた質問を見る