首頁 >資料庫 >mysql教程 >mysql的設定檔是什麼

mysql的設定檔是什麼

青灯夜游
青灯夜游原創
2022-06-27 15:16:3733667瀏覽

Windows作業系統中的MySQL設定檔是“my.ini”,位置一般在MySql安裝的根目錄下,也有可能在隱藏資料夾“ProgramData”下方;而Linux作業系統中的MySQL配置檔案是“my.cnf”,位置一般在“/etc/my.cnf”或“/etc/mysql/my.cnf”目錄下。

mysql的設定檔是什麼

本教學操作環境:linux7.3&&windows7系統、mysql8版本、Dell G3電腦。

Windows作業系統中 MySQL 的設定檔 my.ini;Linux 作業系統中 MySQL 的設定檔是 my.cnf。

  • 一般情況下,my.ini 在 MySql 安裝的根目錄下,也有可能在隱藏資料夾「ProgramData」下方。

  • 一般情況下,my.cnf 在/etc/my.cnf 或/etc/mysql/my.cnf 目錄下

my.ini 設定檔

my.ini 是MySQL 預設使用的設定文件,一般情況下,只要修改my.ini 設定檔中的內容就可以對MySQL 進行設定。

除了上述介紹的目錄,MySQL 安裝目錄下可能還有幾個後綴名為.ini的設定文件,不同的設定檔代表不同的意義。

my.ini 是MySQL 預設使用的設定文件,其它的設定檔都是適合不同資料庫的設定檔的模板,在檔案名稱中就說明了適合的資料庫類型,以下對這幾個設定檔進行詳細講解。

  • my-huge.ini:適合超大型資料庫的設定檔。

  • my-large.ini:適合大型資料庫的設定檔。

  • my-medium.ini:適合中型資料庫的設定檔。

  • my-small.ini:適合小型資料庫的設定檔。

  • my-template.ini:是設定檔的模板,MySQL 設定精靈將該設定檔中選擇項目寫入到 my.ini 檔案。

  • my-innodb-heavy-4G.ini:表示該設定檔只對 InnoDB 儲存引擎有效,而且伺服器的記憶體不能小於 4GB。

為了方便讀者閱讀,我們省略了 my.ini 檔案中的註解內容。以下分開介紹my.ini 中參數的具體意義,檔案內容如下:

[client]
port=3306
[mysql]
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

以上是伺服器的參數,參數說明如下表所示:

##參數名稱說明port表示MySQL 伺服器的連接埠號碼##basedirdatadirdefault-character -setdefault-storage-enginesql-modemax_connectionsquery_cache_sizetable_open_cachetmp_table_sizethread_cache_sizemyisam_max_sort_file_sizemyisam_sort_buffer_sizekey_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 存储引擎使用的参数,参数说明如下:

  • 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 服务才会有效。

my.cnf配置文件

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

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

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

  • port:MySQL 客户端连接服务器端时使用的端口号,默认为 3306

  • socket:套接字文件所在目录

  • quick:支持较大的数据库转储,导出非常巨大的表时需要此项 。

  • max_allowed_packet:服务所能处理的请求包的最大大小以及服务所能处理的最大的请求大小(当与大的BLOB字段一起工作时相当必要),每个连接独立的大小,大小动态增加。

注意:只有 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

上述参数说明如下:

  • user:mysqld 程序在启动后将在给定 UNIX/Linux 账户下执行。mysqld 必须从 root 账户启动才能在启动后切换到另一个账户下执行。mysqld_safe 脚本将默认使用 user=mysql 选项来启动 mysqld 程序。

  • basedir:指定 MySQL 安装的绝对路径;

  • datadir:指定 MySQL 数据存放的绝对路径;

  • port:服务端口号,默认为 3306

  • server-id:MySQL 服务的唯一编号,每个 MySQL 服务的 id 需唯一。

  • socket:socket 文件所在目录

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
  • character-set-server:数据库默认字符集,主流字符集支持一些特殊表情符号(特殊表情符占用 4 个字节)

  • collation-server:数据库字符集对应一些排序等规则,注意要和 character-set-server 对应

  • init_connect:设置 client 连接 mysql 时的字符集,防止乱码

  • lower_case_table_names:是否对 sql 语句大小写敏感,1 表示不敏感

  • key_buffer_size:用于指定索引缓冲区的大小

  • max_allowed_packet:设置一次消息传输的最大值

  • no-auto-rehash:仅仅允许使用键值的 UPDATES 和 DELETES

  • sql_mode:表示 SQL 模式的参数,通过这个参数可以设置检验 SQL 语句的严格程度

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

【相关推荐:mysql视频教程

表示MySQL 的安裝路徑
表示MySQL 資料檔案的儲存位置,也是資料表的存放位置
表示伺服器端預設的字元集
#建立資料表時,預設使用的儲存引擎
表示SQL 模式的參數,透過這個參數可以設定檢驗SQL 語句的嚴格程度
表示允許同時存取MySQL 伺服器的最大連線數。其中一個連線是保留的,留給管理員專用的
表示查詢時的快取大小,快取中可以儲存先前透過SELECT 語句查詢過的訊息,再次查詢時就可以直接從快取中拿出訊息,可以改善查詢效率
表示所有行程開啟表格的總數
表示記憶體中每個暫存資料表允許的最大大小
表示快取的最大執行緒數
表示MySQL 重建索引時所允許的最大暫存檔案的大小
#表示重建索引時的快取大小
#表示關鍵字的快取大小

以上是mysql的設定檔是什麼的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn