mysql安裝優化
安裝
centos7 安裝mysql
解決方案1 安裝mariadb
解決方案2 官網下載安裝mysql-server
時區
批量
配置
編碼
遠程連接
my.cnf
簡版的參數說明
核心配置參數升級版
mysql存儲引擎
MySQL 存儲引擎中InnoDB與Myisam的主要區別
SQL執行分析
使用profiling分析sql
安裝
centos7 安裝mysql
查詢當前系統版本是否為centos7
cat /etc/redhat-release
CentOS 7 版本將MySQL數據庫軟件從默認的程序列表中移除,用mariadb代替了。
MariaDB數據庫管理系統是MySQL的一個分支,主要由開源社區在維護,采用GPL授權許可。開發這個分支的原因之一是:甲骨文公司收購了MySQL後,有將MySQL閉源的潛在風險,因此社區采用分支的方式來避開這個風險。MariaDB的目的是完全兼容MySQL,包括API和命令行,使之能輕松成為MySQL的代替品。
解決方案1 安裝mariadb
yum install mariadb-server mariadb
mariadb數據庫的相關命令是:
systemctl start mariadb #啟動MariaDB
systemctl stop mariadb #停止MariaDB
systemctl restart mariadb #重啟MariaDB
systemctl enable mariadb #設置開機啟動
解決方案2 官網下載安裝mysql-server
wget http://dev.mysql.com/get/mysql-community-release-el7-5.noarch.rpm
rpm -ivh mysql-community-release-el7-5.noarch.rpm
yum install mysql-community-server
安裝完成後重啟mysql服務
service mysqld restart
初次安裝mysql,root賬戶沒有密碼 設置密碼:
set password for ‘root‘@‘localhost‘ =password(‘password‘);
時區
mysql5.7 需要在配置中 my.ini/my.cnf裏面配置時區 否則就需要在url裏面加參數了
default-time-zone =
‘+8:00‘
批量
使用jdbc連接數據庫,批量插入時候preparedstatement 的addBatch 默認是不起作用的,需要在url後面加上參數
rewriteBatchedStatements=true
這樣批量插入才起作用
配置
編碼
mysql配置文件為/etc/my.cnf
最後加上編碼配置
[mysql]
default-character-set =utf8
遠程連接
把在所有數據庫的所有表的所有權限賦值給位於所有IP地址的root用戶。
grant all privileges on *.* to root@‘%‘identified by ‘password‘;
但是,一般來説為了安全,[email protected]
如果是新用戶而不是root,則要先新建用戶
create user ‘username‘@‘%‘ identified by ‘password‘;
my.cnf
簡版的參數說明
適用於一般開發、測試迅速搭建mysql環境。
[mysqld]
#myslqd服務運行時的端口號
port=3306
#socket文件是在Linux環境下特有的,用戶的客戶端軟件連接可以不通過TCP/IP網絡而直接使用unix socket連接到Mysql。
socket=/tmp/mysql.sock
#避免Mysql的外部鎖定,減少出錯幾率,增強穩定性。
skip-external-locking
#禁止MySql對外部連接進行DNS解析,使用這一選項可以消除MySQL進行NDS解析的時間。但需要註意的是:如果開啟該選項,則所有遠程主機連
接授權都要使用IP地址方式了,否則MYSQL將無法正常處理連接請求。
skip-name-resolve
#back_log參數的值指出在MySQL暫時停止響應新請求之前,短時間內的多少個請求可以被存在對堆棧中,如果系統短時間內有很多連接,則需>要增大該參數的值,該參數值指定到來的TCP/IP連接的監聽隊列的大小。不同的操作系統在這個隊列的大小有自己的限制,如果試圖將back_log設定得高於操作系統的限制將是無效的,其默認值為50,對於LINUX系統而言,推薦設置為小於512的整數。
back_log=384
#索引緩沖區大小,增加它可得到更好的索引處理性能,對於內存在4GB左右的服務器,該參數可設置為256M或384M。如果該參數值設置的過大>反而會使服務器的整體效率降低。
key_buffer_size=384M
#設定在網絡傳輸中一次消息傳輸量的最大值,系統默認值為1MB,最大值是1GB,必須設定為1024的倍數,單位為字節。
max_allowed_packet=4M
#設置MySQL每個線程的堆棧大小,默認值足夠大,可滿足普通操作。可設置範圍為128KB至4GB,默認192K。
thread_stack=256k
#設定查詢排序時所能使用的緩沖區大小,系統默認大小為2MB,從5.1.23版本開始,在除了WINDOWS 之外的64位平臺上可以4GB的限制。該參數
對應的分配內在是每個連接獨占的,如果有100個連接,那麽實際分配的總排序緩沖區大小為100*6=600MB,那麽對於內存4GB左右的服務器來>說,推薦將其設置為6MB-8MB。
sort_buffer_size=6M
#讀查詢操作所能使用的緩沖區大小,和sort_buffer_size一樣,該參數對應的分配內在也是每個連接獨享。
read_buffer_size=4M
#設置Thread Cache池中可以緩存的連接池線程最大數量,可設置為0-16384,默認為0。1GB內存我們配置為8,2GB內存我們配置為16,4GB或4GB以上內在我們配置為64。
thread_cache_size=64
#指定Mysql查詢緩沖區的大小,可以通過在Mysql控制臺觀察,如果Qcache_lowmem_prunes的值非常大,則表明經常出現緩沖不夠的情況,如果
Qcache_hits的值非常大,則表明查詢緩沖使用的非常頻繁
query_cache_size=64M
#設置內在臨時表最大值,如果超過該值,則會將臨時表寫入磁盤,其範圍為1KB至4GB。
tmp_table_size=256M
#指定MYSQL允許的最大連接進程數,如果在訪問程序時經常出現TOO MANY CONNECTIONS的錯誤提示,則需要增大該參數值。
max_connections=5000
#指定一個請求的最大連接時間,對於4GB左右內在的服務器來說,可以將其設置為5-10
wait_timeout=120
#該參數取值為服務器邏輯CPU數量*2,比如,服務器有兩個物理CPU,每個物理CPU支持HT超線程,所以實際取值4*2=8,這也是目前雙四核主流
服務器的配置。
thread_concurrency=8
#開啟該選項可以徹底關閉MYSQL的TCP/IP連接方式,如果WEB服務器是以遠程連接的方式訪問MYSQL的數據庫服務器,則不要開啟該選項,否則>將無法正常連接。
skip-networking
innodb_flush_log_at_trx_commit
#抱怨Innodb比MyISAM慢 100倍?那麽你大概是忘了調整這個值。默認值1的意思是每一次事務提交或事務外的指令都需要把日誌寫入(flush)
硬盤,這是很費時的。特別是使用電池供電緩存(Battery backed up cache)時。設成2對於很多運用,特別是從MyISAM表轉過來的是可以的>,它的意思是不寫入硬盤而是寫入系統緩存。日誌仍然會每秒flush到硬 盤,所以你一般不會丟失超過1-2秒的更新。設成0會更快一點,但安>全方面比較差,即使MySQL掛了也可能會丟失事務的數據。而值2只會在整個操作系統 掛了時才可能丟數據。
innodb_flush_log_at_trx_commit=2
#這是 InnoDB 存儲引擎的事務日誌所使用的緩沖區。類似於 Binlog Buffer,InnoDB 在寫事務日誌的時候,為了提高性能,也是先將信息寫>入 Innofb Log Buffer 中,當滿足 innodb_flush_log_trx_commit 參數所設置的相應條件(或者日誌緩沖區寫滿)之後,才會將日誌寫到文>件(或者同步到磁盤)中。可以通過 innodb_log_buffer_size 參數設置其可以使用的最大內存空間。
innodb_log_buffer_size=2M
#這個數字要根據實際的情況來設定,但對於大多數的情況,是一個比較合適的設置
innodb_thread_concurrency=8
#tmp_table_size 的默認大小是 32M。如果一張臨時表超出該大小,MySQL產生一個 The table tbl_name is full 形式的錯誤,如果你做很多
高級 GROUP BY 查詢,增加 tmp_table_size 值。
tmp_table_size=64M
#隨機讀取數據緩沖區使用內存(read_rnd_buffer_size):和順序讀取相對應,當 MySQL 進行非順序讀取(隨機讀取)數據塊的時候,會利用>這個緩沖區暫存讀取的數據。如根據索引信息讀取表數據,根據排序後的結果集與表進行Join等等。總的來說,就是當數據塊的讀取需要滿足>一定的順序的情況下,MySQL 就需要產生隨機讀取,進而使用到 read_rnd_buffer_size 參數所設置的內存緩沖區。
read_rnd_buffer_size=16M
#你最好在定義數據庫命名規則的時候就全部采用小寫字母加下劃線的組合,而不使用任何的大寫字母。
lower_case_table_names=1
#設置校驗模式
sql_mode=NO_ENGINE_SUBSTITUTION,STRICT_TRANS_TABLES
#默認配置沒開查詢緩存哦親
explicit_defaults_for_timestamp
核心配置參數升級版
適用於一般DBA和架構師級別。
[client]
port = 3306 # 客戶端端口號為3306
socket = /data/3306/mysql.sock
default-character-set = utf8
# 客戶端字符集,(控制character_set_client、character_set_connection、character_set_results)
[mysql]
no-auto-rehash # 僅僅允許使用鍵值的updates和deletes
[mysqld]
# 組包括了mysqld服務啟動的參數,它涉及的方面很多,其中有MySQL的目錄和文件,通信、網絡、信息安全,內存管理、優化、查詢緩存區,還有MySQL日誌設置等。
user = mysql
# mysql_safe腳本使用MySQL運行用戶(編譯時--user=mysql指定),推薦使用mysql用戶。
port = 3306
# MySQL服務運行時的端口號。建議更改默認端口,默認容易遭受攻擊。
socket = /data/3306/mysql.sock
# socket文件是在Linux/Unix環境下特有的,用戶在Linux/Unix環境下客戶端連接可以不通過TCP/IP網絡而直接使用unix socket連接MySQL。
basedir = /application/mysql
# mysql程序所存放路徑,常用於存放mysql啟動、配置文件、日誌等
datadir = /data/3306/data
# MySQL數據存放文件(極其重要)
character-set-server = utf8
# 數據庫和數據庫表的默認字符集。(推薦utf8,以免導致亂碼)
log-error=/data/3306/mysql.err
# mysql錯誤日誌存放路徑及名稱(啟動出現錯誤一定要看錯誤日誌,百分之百都能通過錯誤日誌排插解決。)
pid-file=/data/3306/mysql.pid
# MySQL_pid文件記錄的是當前mysqld進程的pid,pid亦即ProcessID。
skip-locking
# 避免MySQL的外部鎖定,減少出錯幾率,增強穩定性。
skip-name-resolv
# 禁止MySQL對外部連接進行DNS解析,使用這一選項可以消除MySQL進行DNS解析的時候。但是需要註意的是,如果開啟該選項,則所有遠程主機連接授權都要使用IP地址方式了,否則MySQL將無法正常處理連接請求!
skip-networking
# 開啟該選項可以徹底關閉MySQL的TCP/IP連接方式,如果Web服務器是以遠程連接的方式訪問MySQL數據庫服務器的,則不要開啟該選項,否則無法正常連接!
open_files_limit = 1024
# MySQLd能打開文件的最大個數,如果出現too mant open files之類的就需要調整該值了。
back_log = 384
# back_log參數是值指出在MySQL暫時停止響應新請求之前,短時間內的多少個請求可以被存在堆棧中。如果系統在短時間內有很多連接,則需要增加該參數的值,該參數值指定到來的TCP/IP連接的監聽隊列的大小。不同的操作系統在這個隊列的大小上有自己的限制。如果試圖將back_log設置得高於操作系統的限制將是無效的,其默認值為於Linux系統而言,推薦設置為小於512的整數。
max_connections = 800
# 指定MySQL允許的最大連接進程數。如果在訪問博客時經常出現 Too Many Connections的錯誤提示,則需要增大該參數值。
max_connect_errors = 6000
# 設置每個主機的連接請求異常中斷的最大次數,當超過該次數,MySQL服務器將禁止host的連接請求,直到MySQL服務器重啟或通過flush hosts命令清空此host的相關信息。
wait_timeout = 120
# 指定一個請求的最大連接時間,對於4GB左右內存的服務器來說,可以將其設置為5~10。
table_cache = 614K
# table_cache指示表高速緩沖區的大小。當MySQL訪問一個表時,如果在MySQL緩沖區還有空間,那麽這個表就被打開並放入表緩沖區,這樣做的好處是可以更快速地訪問表中的內容。一般來說,可以查看數據庫運行峰值時間的狀態值Open_tables和Open_tables,用以判斷是否需要增加table_cache的值,即如果Open_tables接近table_cache的時候,並且Opened_tables這個值在逐步增加,那就要考慮增加這個值的大小了。
external-locking = FALSE
# MySQL選項可以避免外部鎖定。True為開啟。
max_allowed_packet =16M
# 服務器一次能處理最大的查詢包的值,也是服務器程序能夠處理的最大查詢
sort_buffer_size = 1M
# 設置查詢排序時所能使用的緩沖區大小,系統默認大小為2MB。
# 註意:該參數對應的分配內存是每個連接獨占的,如果有100個連接,那麽實際分配的總排序緩沖區大小為100 x6=600MB。所以,對於內存在4GB左右的服務器來說,推薦將其設置為6MB~8MB
join_buffer_size = 8M
# 聯合查詢操作所能使用的緩沖區大小,和sort_buffer_size一樣,該參數對應的分配內存也是每個連接獨享。
thread_cache_size = 64
# 設置Thread Cache池中可以緩存的連接線程最大數量,可設置為0~16384,默認為個值表示可以重新利用保存在緩存中線程的數量,當斷開連接時如果緩存中還有空間,那麽客戶端的線程將被放到緩存中;如果線程重新被請求,那麽請求將從緩存中讀取,如果緩存中是空的或者是新的請求,那麽這個線程將被重新創建,如果有很多線程,增加這個值可以改善系統性能。通過比較Connections和Threads_created狀態的變量,可以看到這個變量的作用。我們可以根據物理內存設置規則如下:1GB內存我們配置為8,2GB內存我們配置為16,3GB我們配置為32,4GB或4GB以上我們給此值為64或更大的值。
thread_concurrency = 8
# 該參數取值為服務器邏輯CPU數量x 2,在本例中,服務器有兩個物理CPU,而每個物理CPU又支持H.T超線程,所以實際取值為4 x 2 = 8。這也是雙四核主流服務器的配置。
query_cache_size = 64M
# 指定MySQL查詢緩沖區的大小。可以通過在MySQL控制臺觀察,如果Qcache_lowmem_prunes的值非常大,則表明經常出現緩沖不夠的情況;如果Qcache_hits的值非常大,則表明查詢緩沖使用得非常頻繁。另外如果改值較小反而會影響效率,那麽可以考慮不用查詢緩沖。對於Qcache_free_blocks,如果該值非常大,則表明緩沖區中碎片很多。
query_cache_limit = 2M
# 只有小於此設置值的結果才會被緩存
query_cache_min_res_unit = 2k
# 設置查詢緩存分配內存的最小單位,要適當第設置此參數,可以做到為減少內存快的申請和分配次數,但是設置過大可能導致內存碎片數值上升。默認值為4K,建議設置為1K~16K。
default_table_type = InnoDB
# 默認表的類型為InnoDB
thread_stack = 256K
# 設置MySQL每個線程的堆棧大小,默認值足夠大,可滿足普通操作。可設置範圍為128KB至4GB,默認為192KB
#transaction_isolation = Level
# 數據庫隔離級別 (READ UNCOMMITTED(讀取未提交內容) READ COMMITTED(讀取提交內容) REPEATABLE
READ(可重讀) SERIALIZABLE(可串行化))
tmp_table_size = 64M
# 設置內存臨時表最大值。如果超過該值,則會將臨時表寫入磁盤,其範圍1KB到4GB。
max_heap_table_size = 64M
# 獨立的內存表所允許的最大容量。
table_cache = 614
# 給經常訪問的表分配的內存,物理內存越大,設置就越大。調大這個值,一般情況下可以降低磁盤IO,但相應的會占用更多的內存,這裏設置為614。
table_open_cache = 512
# 設置表高速緩存的數目。每個連接進來,都會至少打開一個表緩存。因此, table_cache 的大小應與 max_connections 的設置有關。例如,對於 200 個並行運行的連接,應該讓表的緩存至少有 200 × N ,這裏 N 是應用可以執行的查詢的一個聯接中表的最大數量。此外,還需要為臨時表和文件保留一些額外的文件描述符。
long_query_time = 1
# 慢查詢的執行用時上限,默認設置是10s,推薦(1s~2s)
log_long_format
# 沒有使用索引的查詢也會被記錄。(推薦,根據業務來調整)
log-slow-queries = /data/3306/slow.log
# 慢查詢日誌文件路徑(如果開啟慢查詢,建議打開此日誌)
log-bin = /data/3306/mysql-bin
# logbin數據庫的操作日誌,例如update、delete、create等都會存儲到binlog日誌,通過logbin可以實現增量恢復
relay-log = /data/3306/relay-bin
# relay-log日誌記錄的是從服務器I/O線程將主服務器的二進制日誌讀取過來記錄到從服務器本地文件,然後SQL線程會讀取relay-log日誌的內容並應用到從服務器
relay-log-info-file = /data/3306/relay-log.info
# 從服務器用於記錄中繼日誌相關信息的文件,默認名為數據目錄中的relay-log.info。
binlog_cache_size = 4M
# 在一個事務中binlog為了記錄sql狀態所持有的cache大小,如果你經常使用大的,多聲明的事務,可以增加此值來獲取更大的性能,所有從事務來的狀態都被緩沖在binlog緩沖中,然後再提交後一次性寫入到binlog中,如果事務比此值大,會使用磁盤上的臨時文件來替代,此緩沖在每個鏈接的事務第一次更新狀態時被創建。
max_binlog_cache_size = 8M
# 最大的二進制Cache日誌緩沖尺寸。
max_binlog_size = 1G
# 二進制日誌文件的最大長度(默認設置1GB)一個二進制文件信息超過了這個最大長度之前,MySQL服務器會自動提供一個新的二進制日誌文件接續上。
expire_logs_days = 7
# 超過7天的binlog,mysql程序自動刪除(如果數據重要,建議不要開啟該選項)
key_buffer_size = 256M
# 指定用於索引的緩沖區大小,增加它可得到更好的索引處理性能。對於內存在4GB左右的服務器來說,該參數可設置為256MB或384MB。
# 註意:如果該參數值設置得過大反而會使服務器的整體效率降低!
read_buffer_size = 4M
# 讀查詢操作所能使用的緩沖區大小。和sort_buffer_size一樣,該參數對應的分配內存也是每個連接獨享。
read_rnd_buffer_size = 16M
# 設置進行隨機讀的時候所使用的緩沖區。此參數和read_buffer_size所設置的Buffer相反,一個是順序讀的時候使用,一個是隨機讀的時候使用。但是兩者都是針對與線程的設置,每個線程都可以產生兩種Buffer中的任何一個。默認值256KB,最大值4GB。
bulk_insert_buffer_size = 8M
# 如果經常性的需要使用批量插入的特殊語句來插入數據,可以適當調整參數至16MB~32MB,建議8MB。
myisam_sort_buffer_size = 8M
# 設置在REPAIR Table或用Create index創建索引或 Alter table的過程中排序索引所分配的緩沖區大小,可設置範圍4Bytes至4GB,默認為8MB
lower_case_table_names = 1
# 實現MySQL不區分大小。(發開需求-建議開啟)
slave-skip-errors = 1032,1062
# 從庫可以跳過的錯誤數字值(mysql錯誤以數字代碼反饋,全的mysql錯誤代碼大全,以後會發布至博客)。
replicate-ignore-db=mysql
# 在做主從的情況下,設置不需要同步的庫。
server-id = 1
# 表示本機的序列號為1,如果做主從,或者多實例,serverid一定不能相同。
myisam_sort_buffer_size = 128M
# 當需要對於執行REPAIR, OPTIMIZE, ALTER 語句重建索引時,MySQL會分配這個緩存,以及LOAD DATA INFILE會加載到一個新表,它會根據最大的配置認真的分配的每個線程。
myisam_max_sort_file_size = 10G
# 當重新建索引(REPAIR,ALTER,TABLE,或者LOAD,DATA,TNFILE)時,MySQL被允許使用臨時文件的最大值。
myisam_repair_threads = 1
# 如果一個表擁有超過一個索引, MyISAM 可以通過並行排序使用超過一個線程去修復他們.
myisam_recover
# 自動檢查和修復沒有適當關閉的 MyISAM 表.
innodb_additional_mem_pool_size = 4M
# 用來設置InnoDB存儲的數據目錄信息和其他內部數據結構的內存池大小。應用程序裏的表越多,你需要在這裏面分配越多的內存。對於一個相對穩定的應用,這個參數的大小也是相對穩定的,也沒有必要預留非常大的值。如果InnoDB用廣了這個池內的內存,InnoDB開始從操作系統分配內存,並且往MySQL錯誤日誌寫警告信息。默認為1MB,當發現錯誤日誌中已經有相關的警告信息時,就應該適當的增加該參數的大小。
innodb_buffer_pool_size = 64M
# InnoDB使用一個緩沖池來保存索引和原始數據,設置越大,在存取表裏面數據時所需要的磁盤I/O越少。強烈建議不要武斷地將InnoDB的Buffer Pool值配置為物理內存的50%~80%,應根據具體環境而定。
innodb_data_file_path = ibdata1:128M:autoextend
# 設置配置一個可擴展大小的尺寸為128MB的單獨文件,名為ibdata有給出文件的位置,所以默認的是在MySQL的數據目錄內。
innodb_file_io_threads = 4
# InnoDB中的文件I/O線程。通常設置為4,如果是windows可以設置更大的值以提高磁盤I/O
innodb_thread_concurrency = 8
# 你的服務器有幾個CPU就設置為幾,建議用默認設置,一般設為8。
innodb_flush_log_at_trx_commit = 1
# 設置為0就等於innodb_log_buffer_size隊列滿後在統一存儲,默認為1,也是最安全的設置。
innodb_log_buffer_size = 2M
# 默認為1MB,通常設置為8~16MB就足夠了。
innodb_log_file_size = 32M
# 確定日誌文件的大小,更大的設置可以提高性能,但也會增加恢復數據庫的時間。
innodb_log_files_in_group = 3
# 為提高性能,MySQL可以以循環方式將日誌文件寫到多個文件。推薦設置為3。
innodb_max_dirty_pages_pct = 90
# InnoDB主線程刷新緩存池中的數據。
innodb_lock_wait_timeout = 120
# InnoDB事務被回滾之前可以等待一個鎖定的超時秒數。InnoDB在它自己的鎖定表中自動檢測事務死鎖並且回滾事務。InnoDB用locak tables 語句註意到鎖定設置。默認值是50秒。
innodb_file_per_table = 0
# InnoDB為獨立表空間模式,每個數據庫的每個表都會生成一個數據空間。0關閉,1開啟。
# 獨立表空間優點:
# 1、每個表都有自己獨立的表空間。
# 2 、每個表的數據和索引都會存在自己的表空間中。
# 3、可以實現單表在不同的數據庫中移動。
# 4、空間可以回收(除drop table操作處,表空不能自己回收。)
[mysqldump]
quick
#quick 不緩沖查詢,直接導出至stdout
max_allowed_packet = 2M
# 設定在網絡傳輸中一次消息傳輸量的最大值。系統默認值為1MB,最大值是1GB,必須設置為1024的倍數。單位為字節。
mysql存儲引擎
MySQL 存儲引擎中InnoDB與Myisam的主要區別
MySQL最重要的兩種存儲引擎InnoDB與Myisam,這是基礎,一定要知道
- 事務處理
innodb 支持事務功能,myisam 不支持。
Myisam 的執行速度更快,性能更好。 - select ,update ,insert ,delete 操作
MyISAM:如果執行大量的SELECT,MyISAM是更好的選擇
InnoDB:如果你的數據執行大量的INSERT或UPDATE,出於性能方面的考慮,應該使用InnoDB表 - 鎖機制不同
InnoDB 為行級鎖,myisam 為表級鎖。
註意:當數據庫無法確定,所找的行時,也會變為鎖定整個表。
如: update table set num = 10 where username like "%test%"; - 查詢表的行數不同
MyISAM:select count() from table,MyISAM只要簡單的讀出保存好的行數,註意的是,當count()語句包含 where條件時,兩種表的操作是一樣的
InnoDB : InnoDB 中不保存表的具體行數,也就是說,執行select count(*) from table時,InnoDB要掃描一遍整個表來計算有多少行 物理結構不同
MyISAM :每個MyISAM在磁盤上存儲成三個文件。第一個文件的名字以表的名字開始,擴展名指出文件類型。.frm文件存儲表定義.
數據文件的擴展名為.MYD (MYData)。
索引文件的擴展名是.MYI (MYIndex)
InnoDB:基於磁盤的資源是InnoDB表空間數據文件和它的日誌文件,InnoDB 表的大小只受限於操作系統文件的大小,一般為 2GBanto_increment 機制不同
一張表,裏面有ID自增主鍵,當insert了17條記錄之後,刪除了第15,16,17條記錄,再把Mysql重啟,再insert一條記錄,這條記錄的ID是18還是15 。
答案:
如果表的類型是MyISAM,那麽是18。
因為MyISAM表會把自增主鍵的最大ID記錄到數據文件裏,重啟MySQL自增主鍵的最大ID也不會丟失。
如果表的類型是InnoDB,那麽是15。
InnoDB表只是把自增主鍵的最大ID記錄到內存中,所以重啟數據庫或者是對表進行OPTIMIZE操作,都會導致最大ID丟失。
SQL執行分析
使用profiling分析sql
查看是否已經啟用profile,默認是關閉的
select @@profiling;
啟用profiling(變量profiling是用戶變量每次都得重新啟用)
set profiling = 1;
使用profiling記錄用戶執行的SQL 查詢分析的語句
show profiles;
裏面有之前執行過的語句。根據id來具體查看io,cpu使用情況
show profile block io, cpu for query 1;
mysql安裝優化