在《MySQL安装后的目录结构介绍》一节中,我们了解到 my.ini 是 MySQL 数据库中使用的配置文件,MySQL 服务器启动时会读取这个配置文件,我们可以通过修改这个文件,达到更新配置的目的。本节以 Windows 系统下的 my.ini 配置文件为样板,讲解 MySQL 配置文件中的参数。

    一般情况下,my.ini 在 MySql 安装的根目录下,也有可能在隐藏文件夹“ProgramData”下面。
    为了方便读者阅读,我们省略了 my.ini 文件中的注释内容。下面分开介绍 my.ini 中参数的具体意义,文件内容如下:

    1. [client]
    2. port=3306
    3. [mysql]
    4. default-character-set=gbk

    上面显示的是客户端的参数,[client] 和 [mysql] 都是客户端,参数说明如下:

    • port:表示 MySQL 客户端连接服务器端时使用的端口号,默认的端口号为 3306。如果需要更改端口号的话,可以直接在这里修改。
    • default-character-set:表示 MySQL 客户端默认的字符集。 ``` [mysqld]

    port=3306 basedir=C:/Program Files/MySQL/MySQL Server 5.7/ datadir=C:/ProgramData/MySQL/MySQL Server 5.7/Data

    character-set-server=gb2312 default-storage-engine=INNODB sql-mode=”STRICT_TRANS_TABLES,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION”

    max_connections=100 query_cache_size=0 table_cache=256 tmp_table_size=35M thread_cache_size=8 myisam_max_sort_file_size=100G myisam_sort_buffer_size=69M key_buffer_size=55M read_buffer_size=64K read_rnd_buffer_size=256K sort_buffer_size=256K

    1. 以上是服务器的参数,参数说明如下表所示:<br /> ![image.png](https://cdn.nlark.com/yuque/0/2022/png/29221073/1655733267054-de5bd1c3-f57e-4a2d-b7a4-d0a03706219d.png#clientId=u9e3e9f34-a737-4&crop=0&crop=0&crop=1&crop=1&from=paste&height=624&id=udebd2cf9&margin=%5Bobject%20Object%5D&name=image.png&originHeight=780&originWidth=1211&originalType=binary&ratio=1&rotation=0&showTitle=false&size=96731&status=done&style=none&taskId=u7917d32d-c5d9-4b89-bedd-a5bda26820d&title=&width=968.8)

    innodb_additional_mem_pool_size=3M innodb_flush_log_at_trx_commit=1 innodb_log_buffer_size=2M innodb_buffer_pool_size=107M innodb_log_file_size=54M innodb_thread_concurrency=18 ``` 以上是 InnoDB 存储引擎使用的参数,参数说明如下:

    • innodb_additional_mem_pool_size:表示附加的内存池,用来存储 InnoDB 表的内容。
    • innodb_flush_log_at_trx_commit:是设置提交日志的时机,若设置为 1,InnoDB 会在每次提交后将事务日志写到磁盘上。
    • innodb_log_buffer_size:表示用来存储日志数据的缓存区的大小。
    • innodb_buffer_pool_size:表示缓存的大小,InnoDB 使用一个缓冲池类保存索引和原始数据。
    • innodb_log_file_size:表示日志文件的大小。
    • innodb_thread_concurrency:表示在 InnoDB 存储引擎允许的线程最大数。


    注意:每次修改 my.ini 文件中的参数后,必须重新启动 MySQL 服务才会有效。