高并发网站集群场景下如何优化MySQL数据库
发布时间:2020-06-05 16:50:46
阅读:136
作者:三月
栏目:数据库
本篇文章给大家主要讲的是关于高并发网站集群场景下如何优化MySQL数据库的内容,感兴趣的话就一起来看看这篇文章吧,相信看完高并发网站集群场景下如何优化MySQL数据库对大家多少有点参考价值吧。
1、硬件层面优化
1.1数据库物理机
a.CPU:64位,服务器2-16个CPU,2-4颗,L1,L2越大越好;
b.mem(内存):48G-96G-128G-256G(48g 2-3个实例;96g 3-4个实例 );
c.disk(磁盘IO)数据库是IO密集应用
机械盘:SAS(不要选择SATA),300G*12块,磁盘数量越多IO越高,SAS 15K转的硬盘。
SSD:固态硬盘
测试对比:SAS单盘随机IO,300IOPS,SSD单盘随机IO达到上万。
d.raid阵列:选硬件RAID(0>10>5>1),选10
e.网卡至少千兆(bond),万兆交换机
f.数据库服务器尽量不用虚拟化
g.SLAVE服务器配置最好是大于等于Master
案例:
百度:IBM服务器,内存96-128G,CPU48核,3-4个实例
SINA: DELL R510,内存48G,磁盘300*12块,raid10
多实例:就是一台服务器多个数据库,比喻一个房子多个卧室。
1.2 硬件调整:
Bios调整提高CPU性能
1) 打开DAPC模式,发挥CPU性能。
2) 启动Node Interleaving,避免NUMA问题(NUMA=0)。
3) 关键C1E和State等选项。
陈列卡:
1) 配置CACHE和BBU模块(机械盘)
2) 写策略调为(wb)
3) 不用wt策略,关闭陈列预读策略
2、软件层面优化
2.1 操作系统层面优化
1) 选择x86_64位系统
2) 将系统盘和数据盘分开
3) 尽量避免是用swap
4) 避免使用操作系统软raid
5) 避免使用LVM
6) 专库专用(不要跑LNMP,TOMCAT)
7) 调整Cache mode
启动wce=1(Write Cache Enable) RCD=0(Read Cache Disable)
8) 调度算法默认cfq,noop,deadline。针对deadline可以调参(内核参数)
9) Centos6.8默认ext4可以作为数据为的文件系统,访问量大的话,XFS就更好。Centos7默认也选了XFS,调整XFS日志,缓冲参数。
10) mount参数很重要,async,noatime,nodirname,nobarrier等。
2.2 文件系统层优化
2.3 内核层面优化
1) vm.swappiness设置0,或者0-5,让数据库尽量不使用swap.
2) Vm.dirty_background_ration设置5-10,vm.dirty_ration设置前面的2倍。持续将系统脏数据刷到磁盘。
3) net.ipv4.tcp_tw_recyle=1,net.ipv4.tcp_reuse=1, net.ipv4.tcp_fin_timeout=2,net.ipv4.tcp_keepalived_time=600减少time_wait
4) 内核优化,参考老男孩博客;
3、MySQL层面优化
3.1 my.conf参数的优化
1) 如果采用myisam引擎,key_buffer_szie加大。尽量采用innnodb.
2) 推荐使用innodb,5.5.5以后默认就是innodb引擎
3) innodb_buffer_pool_szie,调整为内存的50%,单实例。
4) innodb_flush_log_at_trx_commit,sync_binlog,设置为1,数据可以丢,设置0,从库设置为0。
5) 使用独立表空间。innodb_file_per_table=1
6) innodb_log_file_size=256M
7) log_query_time=1 ,超过1秒的语句记录LOG。
8) 一些session参数不要设置过大,一个连接就会占用参数设置的大小。Sort_buffer_size,join_buffer_size这类参数都是session级别参数。
9) 查询缓存参数要设置小一些:query_cache_size=64M,要想缓存,前端加mc,redis。
3.2 库和表的设计优化
1) 字符集UTF-8
2) 固定字符串的内容,可以选择char
3) 数据库都要给一个自增的主键,没有什么业务用途
4) 字段长度,在满足需求前提下,用最短的。Varchar(16)
5) 省份,性别,这类内容字段可以设置ENUM类型,mysql系统表(char ,ENUM)
6) 尽可能不用text/blob,如果使用的话,放到子表里。
7) 针对字段索引,尽量采用字段的前N个字符索引,不要整个字段索引。
8) 多用联合索引,前缀特性,少用独立索引,性别列不要建立独立索引了。
3.3 SQL语句的优化
A、索引优化
1)抓出来慢查询
百度:白名单的方法,设计程序时候参与设计,程序上线连接数据库,有个控制查库的东西,请示放我库里,才能查询,数据库没有或者减少慢查询。
给常给开发做培训,DB水平更高。
现在网站慢了,show full processlist;抓慢查询,连续执行两下。间隔1-2秒,如果还有,怀疑他是慢查询。
日常:把慢查询语句记录到log。
My.cnf
Long_query_time=2
Log_queryies_not_using_indexes
Log-slow-queries=/data/3306/slow.log
每天生成slow.log,按天切割slow.log,切割以后用分析软件分析(mysqlsla,-pt-query-digest)
Mysqldumpslow,myprofi。优化的语句不一定是单条占用时间长的,频率高单条不长,但是总时间很长的,这些可能也是优化的重点。
运维来讲,慢查询SQL发给开发。
Explain测试语句是否走索引。Set profile深度查看语句执行情况。
检查删除重复的索引,pt-duplicate-key-checker,效率很低的索引检查删除,pt-index-usage
2)尽量不用子查询,用join替代
数据库是存放数据的地方,不是计算数据的地方,计算放在前面Web。搜索功能,like “%daf%”,不用数据库搜索。
3)语句中尽量去掉in or <>
4、网站集群架构上优化数据库
1) 服务器跑多实例2-4个
2) 主从复制最多9个,1主5从,采用mixed,不要跨机房复制(远程写,本地读)
3) 业务拆分:搜索功能,like “%daf%”,不用数据库搜索。
搜索软件:Sphinx,Xapian,Solr
4) 粉丝关注,好关系,统计这类应用比较简单,不用数据,放到redis。
5) 数据库前端加缓存
6) 动态内转静态化(数据库的数据,转成html文件,放到存储上)使用CDN。
7) 数据库采用读写分离,MyCat,atlas,cobar,amoeba,MySQL-proxy
8) 单表超过800万,拆库拆表。自动扩容,自动收缩。
9) 选择从库备份,锁表,备份时间很长,影响数据访问。
10) 备份时采用分表分库。
5、流程、制度、安全:50%的故障都是人为造成的。
1) 操作流程:开发-核心开发—运维或DBA
2) 测试流程:办公室测试-IDC测试-IDC正式
以上关于高并发网站集群场景下如何优化MySQL数据库详细内容,对大家有帮助吗?