[client]
default-character-set = utf8mb4mysql
[mysql]
#開啓 tab 補全
#auto-rehash
default-character-set = utf8mb4sql
[mysqld]
port=3306
basedir=/data/server/mysql57/
datadir=/data/server/mysql57/data/
socket=/data/server/mysql57/data/mysql.sock
symbolic-links=0
log-error=/data/logs/mysql57/mysqld.log
pid-file=/data/server/mysql57/data/mysqld57.pid數據庫
skip-name-resolve後端
default-storage-engine = InnoDB
innodb-file-per-table=1innodb_force_recovery = 1#一些坑
group_concat_max_len = 10240sql_mode=expire_logs_days = 7memlock緩存
character-set-client-handshake = FALSE
character-set-server = utf8mb4
collation-server = utf8mb4_unicode_ci
init_connect='SET NAMES utf8mb4'### GTID
server_id = 330759# 爲保證 GTID 複製的穩定, 行級日誌
binlog_format = row安全
gtid_mode = on服務器
enforce-gtid-consistency = true# 如下兩條配置爲主從切換, 數據庫高可用的必須配置session
log_bin = mysql57-bin 多線程
log-slave-updates = on
#slave複製進程不隨mysql啓動而啓動
skip_slave_start=1### 慢查詢日誌併發
slow_query_log = 1# 超過2秒的查詢記錄下來
long_query_time = 2# 記錄下沒有使用索引的查詢
log_queries_not_using_indexes = 0slow_query_log_file =/data/logs/mysql57/slow.log
#log=/data/logs/mysql57/all.log
relay_log_info_repository = TABLE
master_info_repository = TABLE
relay_log_recovery = on
relay_log_purge = 1### 數據安全性配置
log_bin_trust_function_creators = on
sync_binlog = 1# timestamp 列若是沒有顯式定義爲 not null, 則支持null屬性
explicit_defaults_for_timestamp=true### 優化配置
ft_min_word_len = 1# 默認庫名錶名保存爲小寫, 不區分大小寫
lower_case_table_names = 1# 單條記錄寫入最大的大小限制
max_allowed_packet = 256M
#rpl_semi_sync_master_enabled = 1#rpl_semi_sync_slave_enabled = 1# 半同步複製超時時間設置
#rpl_semi_sync_master_timeout = 1000# 複製模式(保持系統默認)
#rpl_semi_sync_master_wait_point = AFTER_SYNC
#rpl_semi_sync_master_wait_slave_count = 1# 多線程複製
slave_parallel_type = logical_clock
#並行的SQL線程數量,此參數只有設置 1<N的狀況下才會才起N個線程進行SQL重作。
#通過測試對比發現, 若是主庫的鏈接線程爲M, 只有M < N的狀況下, 備庫的延遲才能夠徹底避免。
slave_parallel_workers = 4### 鏈接數限制
max_connections = 1500# 驗證密碼超過20次拒絕鏈接
max_connect_errors = 200# back_log值指出在mysql暫時中止回答新請求以前的短期內多少個請求能夠被存在堆棧中
back_log = 500open_files_limit = 65535# 服務器關閉交互式鏈接前等待活動的秒數
interactive_timeout = 3600# 服務器關閉非交互鏈接以前等待活動的秒數
wait_timeout = 3600### 內存分配
table_open_cache = 1024# 爲每一個session 分配的內存, 在事務過程當中用來存儲二進制日誌的緩存
binlog_cache_size = 4M
tmp_table_size = 128M
max_heap_table_size = 16M
read_buffer_size = 1M
read_rnd_buffer_size = 8M
sort_buffer_size = 1M
query_cache_size = 64M
query_cache_limit = 1M
join_buffer_size = 16M
thread_cache_size = 64### InnoDB 優化
innodb_buffer_pool_size=2G
innodb_log_file_size = 256M
innodb_log_buffer_size = 4M
innodb_log_buffer_size = 3M
innodb_flush_log_at_trx_commit = 1# mysql 的數據文件設置, 初始100, 以10M 自動擴展
#innodb_data_file_path = ibdata1:100M:autoextend
innodb_log_files_in_group = 3##其餘設置
#innodb_open_files = 800# 爲每一個 InnoDB 表分配單獨的表空間
innodb_file_per_table = 1# InnoDB 使用後臺線程處理數據頁上寫 I/O(輸入)請求的數量
innodb_write_io_threads = 8# InnoDB 使用後臺線程處理數據頁上讀 I/O(輸出)請求的數量
innodb_read_io_threads = 8# 啓用單獨的線程來回收無用的數據
innodb_purge_threads = 1# 髒數據刷入磁盤(先保持系統默認, swap 過多使用時, 調小此值, 調小後, 與磁盤交互增多, 性能下降)
innodb_max_dirty_pages_pct = 90# 事務等待獲取資源等待的最長時間
innodb_lock_wait_timeout = 120# 開啓 InnoDB 嚴格檢查模式, 不警告, 直接報錯 1開啓 0關閉
innodb_strict_mode=1# 容許列索引最大達到3072
innodb_large_prefix = on
[mysqldump]
quickdefault-character-set = utf8mb4max_allowed_packet = 256M