Docker啟動MySQL容器時,如何自定義配置字符集?

Docker啟動MySQL容器時,如何自定義配置字符集?

docker啟動mysql容器時如何修改字符集?

官方給定的命令行啟動mysql容器時,指定字符集的方法無效。但可以通過自定義配置文件實現。

解決方案:

  1. 在宿主機新建conf文件,例character_set.cnf:
[mysqld] character-set-server = utf8mb4 [client] default-character-set = utf8mb4 [mysql] default-character-set = utf8mb4
  1. 啟動容器時,將容器的/etc/mysql/conf.d掛載到character_set.cnf所在目錄:
docker run  --name mysql  -v /path/to/character_set.cnf:/etc/mysql/conf.d  -e mysql_root_password=my-secret-pw  -d mysql:tag

進入容器并查看字符集:

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/ | +--------------------------+--------------------------------+

以上方法可正確設置字符集。

此外,還可以參考mysql文檔“設置字符集”。

? 版權聲明
THE END
喜歡就支持一下吧
點贊7 分享