MySQL 8.0 是一個(gè)開源數(shù)據(jù)庫(kù)管理系統(tǒng),它由 Oracle 公司開發(fā)和維護(hù)。相比于早期版本,MySQL 8.0 在安全性、性能和可擴(kuò)展性方面有了顯著提升。然而,一個(gè)有趣的事實(shí)是 MySQL 8.0 不再使用 my.ini 這個(gè)配置文件,而是使用 my.cnf。
在過(guò)去的版本中,my.ini 是 MySQL 的默認(rèn)配置文件。它包含了關(guān)于數(shù)據(jù)庫(kù)的各種配置和設(shè)置,比如端口號(hào)、字符集、緩存大小等等。但是,MySQL 8.0 不再使用 my.ini,而是改用 my.cnf。
my.cnf 是一個(gè)基于文本的配置文件,它的作用和 my.ini 類似,但是它更加靈活和強(qiáng)大。與 my.ini 不同的是,my.cnf 可以包含多個(gè)片段,每個(gè)片段對(duì)應(yīng)一個(gè)配置節(jié),每個(gè)配置節(jié)都可以單獨(dú)配置相關(guān)的參數(shù)。
如果你是 MySQL 8.0 的用戶,那么你需要?jiǎng)?chuàng)建一個(gè) my.cnf 文件并將其保存在 MySQL 的安裝目錄下。下面是一個(gè)典型的 my.cnf 文件示例:
[mysqld] port=3306 socket=/tmp/mysql.sock datadir=/usr/local/mysql/data pid-file=/usr/local/mysql/data/mysql.pid character-set-server=utf8mb4 collation-server=utf8mb4_general_ci [client] port=3306 socket=/tmp/mysql.sock default-character-set=utf8mb4
在上述示例中,[mysqld] 和 [client] 是兩個(gè)配置節(jié)。在 [mysqld] 中,我們?cè)O(shè)置了 MySQL 服務(wù)器的端口號(hào)、sock 文件位置、數(shù)據(jù)目錄、PID 文件位置、字符集和校對(duì)規(guī)則。在 [client] 中,我們?cè)O(shè)置了 MySQL 客戶端的端口號(hào)、sock 文件位置和默認(rèn)字符集。
總之,MySQL 8.0 改用 my.cnf 來(lái)替代早期版本中的 my.ini 配置文件。my.cnf 是一個(gè)基于文本的配置文件,它更加靈活和強(qiáng)大,能夠包含多個(gè)片段,每個(gè)片段對(duì)應(yīng)一個(gè)配置節(jié),每個(gè)配置節(jié)都可以單獨(dú)配置相關(guān)的參數(shù)。