my.iniファイルの記述方法

MySQL のサーバやクライアントに設定を行いたい場合、オプションファイルである my.ini または my.cnf に記述します。 MySQL のサーバやクライアントは起動時にオプションファイルを読み込んで設定を反映させます。ここでは my.ini ファイルにどのように設定を記述するのかについて解説します。

(Last modified: )

オプションファイルの記述方法

オプションファイルである my.ini ファイルはテキストファイルです。作成する場合はテキストエディタで作成します。 my.ini ファイルは次のような構成になっています。

#コメント
[グループ名]
オプション名=値
オプション名=値
オプション名=値

[グループ名]
オプション名=値
オプション名

ファイルの中にはいくつかのグループがあり、何に対して設定を適用するのかをグループ名で指定します。設定項目は オプション名 だけか、 オプション名=値 の形式で記述します。またコメントを記述する場合は # または ; のあとに記述してください。

実際に作成済みの my.ini ファイルをテキストエディタで開いてください。( my.ini の場所については「設定ファイル(my.ini)の作成と配置」を参照されてください)。次のような内容になっています(コメントは削除しています)。

[client]
# pipe=
# socket=MYSQL
port=3306

[mysql]
no-beep

[mysqld]
port=3306
datadir=C:/ProgramData/MySQL/MySQL Server 8.0\Data
default_authentication_plugin=caching_sha2_password
default-storage-engine=INNODB
sql-mode="STRICT_TRANS_TABLES,NO_ENGINE_SUBSTITUTION"
log-output=FILE
general-log=0
general_log_file="LAPTOP-B851ACLE.log"
slow-query-log=1
slow_query_log_file="LAPTOP-B851ACLE-slow.log"
long_query_time=10
log-error="LAPTOP-B851ACLE.err"
log-bin="LAPTOP-B851ACLE-bin"
server-id=1
lower_case_table_names=1
secure-file-priv="C:/ProgramData/MySQL/MySQL Server 8.0/Uploads"
max_connections=151
table_open_cache=2000
tmp_table_size=66M
thread_cache_size=10
myisam_max_sort_file_size=100G
myisam_sort_buffer_size=123M
key_buffer_size=8M
read_buffer_size=64K
read_rnd_buffer_size=256K
innodb_flush_log_at_trx_commit=1
innodb_log_buffer_size=1M
innodb_buffer_pool_size=8M
innodb_log_file_size=48M
innodb_thread_concurrency=17
innodb_autoextend_increment=64
innodb_buffer_pool_instances=8
innodb_concurrency_tickets=5000
innodb_old_blocks_time=1000
innodb_open_files=300
innodb_stats_on_metadata=0
created table
innodb_file_per_table=1
innodb_checksum_algorithm=0
back_log=80
flush_time=0
join_buffer_size=256K
max_allowed_packet=4M
max_connect_errors=100
open_files_limit=4161
sort_buffer_size=256K
table_definition_cache=1400
binlog_row_event_max_size=8K
sync_master_info=10000
sync_relay_log=10000
sync_relay_log_info=10000
loose_mysqlx_port=33060

この my.ini ファイルには client グループ、 mysql グループ、そして mysqld グループの 3 つのグループが記述されています。それではもう少し細かく記述方法を見ていきます。

グループ

my.ini ファイルにはグループを記述することができます。グループは [グループ] のように記述し、グループの記述のあと、別のグループが記述されるかまたは my.ini ファイルの最後までの設定がそのグループに適用されます。

[グループ1]
オプション名=値  # グループ1に適用
オプション名=値  # グループ1に適用

[グループ名2]
オプション名=値  # グループ2に適用
オプション名=値  # グループ2に適用

グループ名には設定の対象となるプログラム名を記述します。例えば MySQL のサーバである mysqld.exe を対象とする場合、グループ名は mysqld となり [mysql] のように記述します。同じく MySQL のコマンドラインツールである mysql.exe を対象とする場合は [mysql] と記述します。

[mysqld]
・・・・
・・・・

[mysql]
・・・・
・・・・

[mysqldump]
・・・・
・・・・

またすべてのクライアントに適用される設定は特別なグループである [client] に記述します。 [client] グループに記述した設定はコマンドラインツールなどクライアントアプリケーションすべてに適用されますが、サーバである mysqld には適用されません。

[client] を使用する場合は [mysql] など特定のクライアントを対象としたグループよりも先に記述してください。同じ設定が記述されていた場合、あとから記述した内容で上書きされます。

[mysqld]
・・・・
・・・・

[client]
・・・・
・・・・

[mysql]
・・・・
・・・・

[mysqldump]
・・・・
・・・・

まとめると、サーバである mysqld に適用される設定は [mysqld] グループ、クライアントアプリケーション共通の設定は [client] 、コマンドラインツールなど特定のクライアントアプリケーションに適用させる設定は [mysqld] など個別のグループに対して設定を行います。

設定の記述

設定は オプション名=値 の形式で記述します。例えばポート番号の設置とログイン用パスワードを設定する場合は次のように記述します。

[mysql]
port=3306
password=my_password

値はシングルクォーテーションまたはダブルクォーテーションで囲って記述することもできます。値の中にコメントを表す # を含めたい場合などに利用できます。

[mysql]
password='my#password'
password="my#password"

またオプション名だけで設定を記述するものもあります。

[mysql]
auto-rehash
no-beep

エスケープシーケンス

オプションに対する値を設定するときに次のエスケープシーケンスが利用できます。

\b  バックスペース
\t  タブ
\n  改行
\r  復帰改行
\\  バックスラッシュ
\s  スペース文字

バックスラッシュ(\)のあとの文字がエスケープシーケンスに一致する文字(例えば b や t )でない場合、バックスラッシュ(\)は単なる文字として扱われます。

オプションの値として Windows のパスを記述する場合、パスの区切り文字はバックスラッシュ(\)またはスラッシュ(/)のどちらでも利用できます。このときバックスラッシュを使用する場合は、区切り文字のあとの文字がエスケープシーケンスに一致する文字かどうかに注意して記述してください。

[mysqld]
datadir="C:/ProgramData/MySQL/MySQL Server 8.0/Data"
datadir="C:\ProgramData\MySQL\MySQL Server 8.0\Data"

上記の場合はバックスラッシュのあとの文字が「P」「M」「D」なので大丈夫ですが、最後のディレクトリ名が例えば「Data」ではなく「base」だった場合には \ の代わりに \\ と記述する必要があります。( 8.0\base と書いてしまうと \b の部分がエスケープシーケンスとして処理されるため)。

[mysqld]
datadir="C:\ProgramData\MySQL\MySQL Server 8.0\\base"

またはエスケープシーケンスの \\ は文字としての \ を表しますので、最初から次のように記述することもできます。

[mysqld]
datadir="C:\\ProgramData\\MySQL\\MySQL Server 8.0\\Data"

コメント

行の先頭からコメントを記述する場合は # または ; のあとにコメントを記述してください。

# サーバ用
[mysqld]
port=3306

; コマンドラインツール用
[mysql]
port=3306
password=my_password

行の途中からコメントを記述する場合は # を使ってください。

[mysqld]
port=3306  # ポート番号

[mysql]
password=my_password

-- --

MySQL のオプションファイルである my.ini ファイルにどのように設定を記述するのかについて解説しました。

( Written by Tatsuo Ikura )

Profile
profile_img

著者 / TATSUO IKURA

プログラミングや開発環境構築の解説サイトを運営しています。