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

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

新規登録して質問してみよう
ただいま回答率
85.36%
docker-compose

docker-composeとは、複数のコンテナで構成されるサービスを提供する手順を自動的し管理を簡単にするツール。composeファイルを使用しコマンド1回で設定した全サービスを作成・起動することが可能です。

MySQL

MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

Docker

Dockerは、Docker社が開発したオープンソースのコンテナー管理ソフトウェアの1つです

Q&A

解決済

1回答

7512閲覧

Docker-Composeで立てたMySQL用コンテナの日本語入力ができない

ttt---aaa

総合スコア21

docker-compose

docker-composeとは、複数のコンテナで構成されるサービスを提供する手順を自動的し管理を簡単にするツール。composeファイルを使用しコマンド1回で設定した全サービスを作成・起動することが可能です。

MySQL

MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

Docker

Dockerは、Docker社が開発したオープンソースのコンテナー管理ソフトウェアの1つです

0グッド

1クリップ

投稿2020/07/24 02:35

編集2020/07/26 21:26

Docker-Composeで立ちあげたMySQL用コンテナにて、日本語入力ができませんので何かご教示いただければと思います。

状況

コマンドにてテーブル作成する際、下記のように「タイトル」と入力したいのですが、入力されず無反応で弾かれてしまいます。

mysql> CREATE TABLE 'sty'( -> 'id' int auto_increment NOT NULL, -> 'title' varchar(255) NOT NULL DEFAULT 0 COMMENT 'タイトル', ```※MySQLで入力できない状態であり、接続解除すれば入力可能というか反応してくれます。 ```ここに言語を入力 zsh: command not found: コマンド

試したこと①

リンク内容

上記記事を試していますが、途中

% apt-get update zsh: command not found: apt-get ```→で先に進まず、また「apt-get(?)」のインストール方法などが分かりません。 ###  MySQL設定 ```ここに言語を入力 mysql> status -------------- mysql Ver 14.14 Distrib 5.7.30, for Linux (x86_64) using EditLine wrapper Connection id: 3 Current database: Current user: ****@localhost SSL: Not in use Current pager: stdout Using outfile: '' Using delimiter: ; Server version: 5.7.30 MySQL Community Server (GPL) Protocol version: 10 Connection: Localhost via UNIX socket Server characterset: latin1 Db characterset: latin1 Client characterset: latin1 Conn. characterset: latin1 UNIX socket: /var/run/mysqld/mysqld.sock Uptime: 32 min 9 sec
mysql> show variables like "chara%"; +--------------------------+----------------------------+ | Variable_name | Value | +--------------------------+----------------------------+ | character_set_client | latin1 | | character_set_connection | latin1 | | character_set_database | latin1 | | character_set_filesystem | binary | | character_set_results | latin1 | | character_set_server | latin1 | | character_set_system | utf8 | | character_sets_dir | /usr/share/mysql/charsets/ | +--------------------------+----------------------------+

その他設定

■docker-compose.yml

version: '3' services: web: image: nginx:1.15.6 ports: - "8000:80" depends_on: - app volumes: - ./docker/web/default.conf:/etc/nginx/conf.d/default.conf - ./app:/var/www/html app: build: ./docker/php volumes: - ./app:/var/www/html depends_on: - mysql mysql: image: mysql:5.7 environment: MYSQL_DATABASE: **** MYSQL_USER: **** MYSQL_PASSWORD: **** MYSQL_ROOT_PASSWORD: **** ports: - "3306:3306" volumes: - mysql-data:/var/lib/mysql volumes: mysql-data:

■dockerfile

FROM php:7.2-fpm RUN cd /usr/bin && curl -s http://getcomposer.org/installer| php && ls -s /usr/bin/composer.phar RUN apt-get update \ && apt-get install -y \ git \ zip \ unzip \ vim RUN apt-get update \ && apt-get install -y libpq-dev \ && docker-php-ext-install pdo_mysql pdo_pgsql mysqli # 18-21追加 RUN locale-gen en_US.UTF-8 ENV LANG en_US.UTF-8 ENV LANGUAGE en_US:en ENV LC_ALL en_US.UTF-8 WORKDIR /var/www/html

■default.conf

server { listen 80; root /var/www/html/; index index.php index.html index.htm; access_log /var/log/nginx/access.log; error_log /var/log/nginx/error.log; location / { try_files $uri $uri/ /index.php$is_args$args; } location ~ .php$ { fastcgi_split_path_info ^(.+.php)(/.+)$; fastcgi_pass app:9000; fastcgi_index index.php; include fastcgi_params; fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name; fastcgi_param PATH_INFO $fastcgi_path_info; } }

解決方法についてまた何かありましたらご教示をお願いいたします。

追記(設定変更)

■docker-compose.yml →command追記

mysql: command: mysqld --character-set-server=utf8mb4 --collation-server=utf8mb4_unicode_ci

■MySQL設定 変更されていることを確認

mysql> show variables like "chara%"; +--------------------------+----------------------------+ | 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 | utf8 | | character_sets_dir | /usr/share/mysql/charsets/ | +--------------------------+----------------------------+ 8 rows in set (0.00 sec)

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

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

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

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

ttt---aaa

2020/07/24 22:20

ありがとうございます^^修正いたしました。
Orlofsky

2020/07/24 22:24

直っていません。
ttt---aaa

2020/07/25 00:35

失礼いたしました????
ttt---aaa

2020/07/26 21:27

返信が遅くなり大変申し訳ございません。 ご指摘いただいた通り、docker-compose.yml内にてcommand:〜追記しましたが、変わらず無反応で弾かれてしまいます(追記した設定が反映されている旨は上記に記載しております)。また、状況としてはmysqlのログイン後の操作に限らず、コンテナに入ってから(root@***:/#)も同様に日本語及び全角文字が弾かれておりました。 ymlの他にdockerfileなどの修正も必要なのでしょうか? 大変恐れ入りますが、引き続きご教示をお願いできればと思います。
guest

回答1

0

ベストアンサー

docker-composeのmysql設定にて文字コードを指定していないためlatin-1になっているようです。例えば以下でutf8mb4に指定できますので、接続クライアントの文字コードもutf8になります。

services: mysql: image: mysql:5.7 container_name: mysql_docker environment: (省略) command: mysqld --character-set-server=utf8mb4 --collation-server=utf8mb4_unicode_ci
show variables like '%character%' |Variable_name |Value | |----------------------------------------------------------------|----------------------------------------------------------------------------------------------------| |character_set_client |utf8mb4 | |character_set_connection |utf8mb4 | |character_set_database |utf8mb4 | |character_set_filesystem |binary | |character_set_results | | |character_set_server |utf8mb4 | |character_set_system |utf8 | |character_sets_dir |/usr/share/mysql/charsets/ |

投稿2020/07/24 02:55

A-pZ

総合スコア12011

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

ttt---aaa

2020/07/27 01:17

返信が遅くなり大変申し訳ございません。 ご指摘いただいた通り、docker-compose.yml内にてcommand:〜追記しましたが、変わらず無反応で弾かれてしまいます(追記した設定が反映されている旨は上記に記載しております)。また、状況としてはmysqlのログイン後の操作に限らず、コンテナに入ってから(root@***:/#)も同様に日本語及び全角文字が弾かれておりました。 ymlの他にdockerfileなどの修正も必要なのでしょうか? 大変恐れ入りますが、引き続きご教示をお願いできればと思います。
ttt---aaa

2020/08/13 21:15

yml-commandの記述を修正したら反映されました。この度はご教示いただきありがとうございました!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.36%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問