建议使用percona server linux generic版,从https://www.percona.com/downloads/Percona-Server-LATEST/下载,如今不在推荐使用mariadb是由于考虑到mariadb的愈来愈不兼容mysql原生。php
对于操做系统,仅推荐rhel以及centos,优先推荐客户使用rhel(若是客户买了服务的话,不然centos,否则yum无法使用,依赖包的安装会及其麻烦),且生产环境咱们仅使用他们,不会使用windows,极少使用suse。html
对于mysql 8.0而言,没有ssl 101版本,以下:mysql
此时须要升级ssl到102(自带的极可能是101),参见linux下openssl升级指南。不然在初始化的时候会报找到openssl相关库,如openssl: error while loading shared libraries: libssl.so.1.1: cannot open shared object file: No such file or directory。
linux
下载后解压、建立符号连接,ln -s Percona-Server-5.7.22-22-Linux.x86_64.ssl101 mysql。sql
[root@v-03-01-00223 mysql]# mkdir data
# 对于mariadb 10.0、10.一、10.二、10.3须要使用scripts/mysql_install_db --user=mysql --datadir=/usr/local/mysql 进行初始化,不支持5.7版本的mysqld初始化,虽然10.1以后是5.7的分支
[root@v-03-01-00223 mysql]# bin/mysqld --initialize-insecure --datadir=/usr/local/app_1/mysql/data --basedir=/usr/local/app_1/mysql 2018-07-03T00:00:30.132880Z 0 [Warning] TIMESTAMP with implicit DEFAULT value is deprecated. Please use --explicit_defaults_for_timestamp server option (see documentation for more details). 2018-07-03T00:00:31.585743Z 0 [Warning] InnoDB: New log files created, LSN=45790 2018-07-03T00:00:31.775344Z 0 [Warning] InnoDB: Creating foreign key constraint system tables. 2018-07-03T00:00:31.855871Z 0 [Warning] No existing UUID has been found, so we assume that this is the first time that this server has been started. Generating a new UUID: 1a4f5171-7e54-11e8-96ba-00163e0d56df. 2018-07-03T00:00:31.859229Z 0 [Warning] Gtid table is not ready to be used. Table 'mysql.gtid_executed' cannot be opened. 2018-07-03T00:00:32.356281Z 0 [Warning] CA certificate ca.pem is self signed. 2018-07-03T00:00:32.636774Z 1 [Warning] root@localhost is created with an empty password ! Please consider switching off the --initialize-insecure option. [root@v-03-01-00223 mysql]# chown -R mysql:mysql data
[root@v-03-01-00223 mysql]# ./mysqld_safe --defaults-file=/etc/my.cnf.57 --user=mysql #/etc/my.cnf.57中的主要参数推荐见下文
[root@v-03-01-00223 mysql]# ./mysql --defaults-file=/etc/my.cnf.57 -uroot -h127.0.0.1 -P3308 #由于一台服务器安装了多个mysql实例,因此指定配置文件和端口号,defaults-file限制只读取指定的配置文件,且必须是第一个命令行选项,不然忽略
alter user root@'localhost' identified by '123456';
create user root@'127.0.0.1' identified by '123456';
grant all on *.* to root@'127.0.0.1';
mysql> create user root@'%' identified by '123456';
Query OK, 0 rows affected (0.00 sec)windows
mysql> grant all on *.* to root@'%';
Query OK, 0 rows affected (0.00 sec)centos
create user 'repl'@'10.20.24.89' identified by '123456'; #建立slave帐户
grant REPLICATION SLAVE ON *.* TO 'repl'@'10.20.24.89'; #建立slave帐户
这些参数都是咱们在各金融交易系统中通过数百家客户运行足够稳定、出现问题时确保可以及时排查后提炼出的对性能、稳定性较为重要的主要参数,而不是随机查看官方文档或者网上复制粘贴的,而且咱们会按期对其进行更新以确保最适合咱们在用的mysql版本和分支。服务器
query_cache_size = 0
query_cache_type=0
innodb_undo_tablespaces=16(需初始化mysql时命令行中先包含)
innodb_undo_directory=(专用redo磁盘文件系统路径)
innodb_thread_concurrency=(cpu数量+物理磁盘的数量)
innodb_strict_mode=true
tmpdir=/tmp
character_set_server=gbk或者utf8mb4(绝大多数系统应默认使用gbk,对于有特殊要求的建议在字段级别设置为utf-8)
autocommit=0
innodb_buffer_pool_size=60%-75%物理内存
innodb_flush_method=O_DIRECT(若是不使用硬件RAID控制器或者使用SAN,则不要设置)
innodb_flush_log_at_trx_commit(核心交易系统设置为1,默认为1,其余2或者0)
transaction-isolation=READ-COMMITTED
innodb_autoinc_lock_mode = 2
skip-name-resolve
large-pages(测试未看出明显受益,主要是内存没有足够压力,故当前不建议设置)
back-log=500
innodb-status-file=TRUE(推荐设置)
default-storage-engine=InnoDB
memlock=true(对于专用mysql服务器,建议禁用swap,此时此参数能够不设置,在共享服务器上,若是设置了,那么在内存不够时,可能致使Mysql由于内存不够而没法启动)
innodb_fast_shutdown=0
sync_binlog(核心交易系统设置为1,默认为1,其余2或者0)
log-bin=mysql-bin
binlog_format(OLTP为row,DSS系统为mixed,如不肯定,请使用row)
binlog_checksum=NONE
binlog_row_image=full(mariadb没有参数,设置了启动会报错)
binlog_cache_size = 8M
max_binlog_size = 500M
max_binlog_cache_size = 100M
expire_logs_days = 7
innodb_log_file_size=512m
innodb-log-buffer-size=8M
innodb-log-files-in-group=(3-5,视生成的日志量而定)
innodb_log_group_home_dir=/usr/local/mysql/redo(专用redo磁盘文件系统路径)
innodb_flush_neighbors(默认值为1,SSD设置为0,Neighbors指的是属于一个extent的全部页面,一个extent共64个页面,出于硬盘IO顺序写的考虑,InnoDB一般会刷新一个extent中的全部页面,由于SSD在随机IO上没有额外负载,因此不须要启用该特性)
innodb_page_size(SSD设置为4KB)
innodb_data_home_dir=/usr/local/mysql/data(专用data磁盘文件系统路径)
# innodb_data_file_path=ibdata1:2000M;ibdata2:10M:autoextend (专用data磁盘文件系统路径,存储系统表空间,建议不要明确设置,如若否则的话,ibdata1的大小须要和实际大小相同)
innodb_change_buffer_max_size(InnoDB使用Change buffering以最小化随机IO,一旦change buffer满了,随后的DMLs将直接在相应的表上进行更改,change buffer以固定的频率(5.5不可更改,5.6由此参数控制,change buffer越接近该值,后台执行越频繁,每次合并的量由innodb_io_capacity控制(默认为200,表明10K RPM的硬盘,对于5400或者7200 RPM的硬盘,能够设置为100,表明每次能够执行100次IOPS(测试时每次大小可配置,这里应该说的是基于16KB大小,可参考http://elf8848.iteye.com/blog/1731301)。对于RAID或者SSD,增长的话,会有所帮助,现代系统应该调整))由后台进程合并到数据页,写入和读取频率接近的系统可设置为50,默认为25,表明buffer pool大小的25%,具体请咨询DBA)
innodb_lock_wait_timeout=86400(根据实际状况配置)
default-tmp-storage-engine=InnoDB
innodb-autoextend-increment=16M
innodb-buffer-pool-instances=min(8,nGB/1GB)
innodb-file-io-threads=max(4,nGB/4GB)
innodb_io_capacity=可供MySQL使用的IOPS(建议使用Oracle ORION进行测试)
innodb-file-per-table=true
innodb_rollback_on_timeout=true
innodb-old-blocks-time(混合型系统能够调整为60000或更高,具体请咨询DBA)
innodb-print-all-deadlocks=true
innodb-sort-buffer-size=(此选项为建立索引使用,不须要设置)
sort-buffer-size(DSS可语句级别动态调整,好比SET STATEMENT sort_buffer_size=100000 FOR SELECT name FROM name ORDER BY name;)
join-buffer-size=(DSS可语句级别动态调整)
open-files-limit=32767
innodb_open_files=32767
tmp-table-size(DSS可语句级别动态调整)
sql-mode=STRICT_TRANS_TABLES,STRICT_ALL_TABLES,PIPES_AS_CONCAT, ONLY_FULL_GROUP_BY,NO_ENGINE_SUBSTITUTION,ERROR_FOR_DIVISION_BY_ZERO, ANSI_QUOTES,NO_UNSIGNED_SUBTRACTION,PAD_CHAR_TO_FULL_LENGTH, NO_ZERO_DATE,NO_ZERO_IN_DATE
log-output=FILE
slow-query-log=true
log-queries-not-using-indexes=true(对于mysql而言,该参数应该设置,具体看状况,有可能不少小表很快会使得slow_query_log增加的很快)
log_slow_filter
log_slow_sp_statements
log_slow_verbosity
innodb_show_verbose_locks=1
innodb_print_lock_wait_timeout_info=ON
server-id=1
port=3306
read_rnd_buffer_size(DSS需语句级别动态调整)
thread_handling=pool-of-threads
thread_pool_max_threads=100
thread_pool_size=50
thread_cache_size=64
max-connections=3000
event_scheduler=ON
#GTID 5.6引入主要是为了解决主从模式下主节点宕机后切换主节点时肯定当前的事务进度(由于不一样的实例日志点位不必定相同,而GTID的格式是日志source_id+事务id,因此能够保证全部节点的逻辑事务进度一致,这使得切换的难度大大下降)。
gtid-mode = ON #(Group Replication要求必须开启GTID,MariaDB没有这个参数,设置后会报错,不过默认就是启用GTID,GTID和基于binlog的区别https://www.percona.com/sites/default/files/presentations/Failover_GTID_MySQL_56_Fosdem.pdf
https://pdfs.semanticscholar.org/presentation/3036/b68bcb8bd2f4fed590fd85607e37bf511858.pdf)
log_slave_updates=ON(GTID模式必须开始log_slave_updates,对性能有必定影响)
enforce-gtid-consistency = ON(MariaDB没有这个参数,设置后会报错,不过默认就是启用GTID)
relay-log-info-repository=TABLE(MariaDB没有这个参数,设置后会报错,不过默认就是启用GTID)
master-info-repository=TABLE(MariaDB没有这个参数,设置后会报错,不过默认就是启用GTID)
slave_parallel_workers=4 --开启基于库的多线程复制默认0不开启 (MariaDB没有这个参数,设置后会报错,不过默认就是启用GTID)
innodb_lru_scan_depth(默认1024,这个参数控制page_cleaner线程扫描多少LRU列表中的脏页,对于写紧张的系统,下降该值,即便内存超大也同样;若是IO容量足够,增长该值;大型系统一般须要更改该参数)
innodb_use_global_flush_log_at_trx_commit=0
userstat=ON
thread_statistics=ON多线程
windows下安装可参考https://blog.csdn.net/ycxzuoxin/article/details/80908447app