• 技术文章 >数据库 >mysql教程

    mysql的配置文件是什么

    青灯夜游青灯夜游2022-06-27 15:16:37原创472

    Windows操作系统中的MySQL配置文件是“my.ini”,位置一般在MySql安装的根目录下,也有可能在隐藏文件夹“ProgramData”下面;而Linux操作系统中的MySQL配置文件是“my.cnf”,位置一般在“/etc/my.cnf”或“/etc/mysql/my.cnf”目录下。

    本教程操作环境:linux7.3&&windows7系统、mysql8版本、Dell G3电脑。

    Windows操作系统中 MySQL 的配置文件 my.ini;Linux 操作系统中 MySQL 的配置文件是 my.cnf。

    my.ini 配置文件

    my.ini 是 MySQL 默认使用的配置文件,一般情况下,只要修改 my.ini 配置文件中的内容就可以对 MySQL 进行配置。

    除了上述介绍的目录,MySQL 安装目录下可能还有几个后缀名为.ini的配置文件,不同的配置文件代表不同的含义。

    my.ini 是 MySQL 默认使用的配置文件,其它的配置文件都是适合不同数据库的配置文件的模板,在文件名中就说明了适合的数据库类型,下面对这几个配置文件进行详细讲解。

    为了方便读者阅读,我们省略了 my.ini 文件中的注释内容。下面分开介绍 my.ini 中参数的具体意义,文件内容如下:

    [client]
    port=3306
    [mysql]
    default-character-set=gbk

    上面显示的是客户端的参数,[client] 和 [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

    以上是服务器的参数,参数说明如下表所示:

    参数名称说明
    port表示 MySQL 服务器的端口号
    basedir表示 MySQL 的安装路径
    datadir表示 MySQL 数据文件的存储位置,也是数据表的存放位置
    default-character-set表示服务器端默认的字符集
    default-storage-engine创建数据表时,默认使用的存储引擎
    sql-mode表示 SQL 模式的参数,通过这个参数可以设置检验 SQL 语句的严格程度
    max_connections表示允许同时访问 MySQL 服务器的最大连接数。其中一个连接是保留的,留给管理员专用的
    query_cache_size表示查询时的缓存大小,缓存中可以存储以前通过 SELECT 语句查询过的信息,再次查询时就可以直接从缓存中拿出信息,可以改善查询效率
    table_open_cache表示所有进程打开表的总数
    tmp_table_size表示内存中每个临时表允许的最大大小
    thread_cache_size表示缓存的最大线程数
    myisam_max_sort_file_size表示 MySQL 重建索引时所允许的最大临时文件的大小
    myisam_sort_buffer_size表示重建索引时的缓存大小
    key_buffer_size表示关键词的缓存大小
    read_buffer_size表示 MyISAM 表全表扫描的缓存大小
    read_rnd_buffer_size表示将排序好的数据存入该缓存中
    sort_buffer_size表示用于排序的缓存大小
    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 存储引擎使用的参数,参数说明如下:

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

    my.cnf配置文件

    为了方便读者阅读,我们省略了 my.cnf 文件中的注释内容。下面分开介绍 my.cnf 中参数的具体意义,文件内容如下:

    [client]
    port=3306
    socket=/var/run/mysql/mysql.sock
    [mysqldump]
    quick
    max_allowed_packet = 16M

    以上参数会被 MySQL 客户端应用读取,参数说明如下:

    注意:只有 MySQL 附带的客户端应用程序保证可以读取这段内容。如果想要自己的 MySQL 应用程序获取这些值,需要在 MySQL 客户端库初始化的时候指定这些选项。

    [mysqld]
    user = mysql
    basedir = /usr/local/mysql
    datadir = /mydata/mysql/data
    port=3306
    server-id = 1
    socket=/var/run/mysql/mysql.sock

    上述参数说明如下:

    character-set-server = utf8mb4
    collation-server = utf8mb4_general_ci
    init_connect='SET NAMES utf8mb4'
    lower_case_table_names = 1
    key_buffer_size=16M
    max_allowed_packet=8M
    no-auto-rehash
    sql_mode=TRADITIONAL

    上述内容可能与你的配置文件不同,当有什么需求时,复制使用相应的参数即可。

    【相关推荐:mysql视频教程

    以上就是mysql的配置文件是什么的详细内容,更多请关注php中文网其它相关文章!

    声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn核实处理。
    专题推荐:mysql
    上一篇:mysql怎么查询最小值 下一篇:什么是mysql主从复制
    20期PHP线上班

    相关文章推荐

    • 【活动】充值PHP中文网VIP即送云服务器• mysql concat()函数怎么用• mysql怎么删除表的一行数据• mysql怎么将日期转为数字• mysql能在linux中使用吗• 如何用好MySQL索引?你必须了解这些事!• linux中的mysql有10061错误怎么办
    1/1

    PHP中文网