我的编程空间,编程开发者的网络收藏夹
学习永远不晚

MySQL数据库如何实现正常优化

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

MySQL数据库如何实现正常优化

下文主要给大家带来MySQL数据库如何实现正常优化,希望这些内容能够带给大家实际用处,这也是我编辑MySQL数据库如何实现正常优化这篇文章的主要目的。好了,废话不多说,大家直接看下文吧。

MySQL数据库优化:

前言:
在一个网站架构中,首先出现瓶颈的一定是数据库,其次是存储。
1、硬盘优化:不用虚拟机,用物理机(因为数据库是 IO 密集型的应用)
a、CPU   64位CPU,百度为例:一台机器 8-16 颗 CPU。普通公司:2-4颗 cpu。
b、内存(mem) 百度为例: 96G-128G,3-4个实例。普通公司:32G-64G,跑2个实例。
c、磁盘(disk)   数量越多越好。性能:SSD(高并发) > SAS(普通业务线上) > SATA(线下)
raid   4块盘:raid0 > raid10 > raid5 > raid1
d、网卡   多块网卡bond,以及buffer,tcp优化。
2、软件优化
操作系统:x86_64系统
软件:mysql 编译优化
3、my.cnf 里参数的优化
注意:my.cnf 里参数优化的幅度很小,大部分架构以及SQL语句优化。
思想:
监控:生产参数是一般情况下参数。
命令监控:show global status\G
调优工具:mysqlreport
案例:一些MySQL的错误skip-name-resolve:
http://blog.chinaunix.net/uid-7354272-id-2643611.html
4、SQL语句的优化
a、索引优化
1)、白名单机制---百度,项目开发,DBA参与,减少上线后的慢SQL数量。
抓出慢SQL,配置 my.cnf
long_query_time = 2
log-slow-queries=/data/3306/slow-log.log
按天轮询:slow-log.log
2)、慢查询日志分析工具-----mysqlsla(推荐)
MySQLdumpslow,mysqlsla,myprofi,mysql-explain-slow-log,mysqllogfilter 比较
3)、每天晚上0点定时分析慢查询,发到核心开发,DBA分析及高级运维,CTO的邮箱里。
DBA分析给出优化建议--->核心开发确认更改--->DBA线上操作处理。
b、大的复杂的SQL语句拆分成多个小的SQL语句。
子查询,join连表查询,某个表4000万条记录。
c、数据库是存储数据的地方,但是不是计算数据的地方。    
对数据计算,应用类处理,都要拿到前端应用解决。禁止在数据库上处理。
d、搜索功能,like‘%老男孩%’,一般不要用mysql 数据库。
SQL 语句的详细优化细节:
① 能用定长 char 类型的就不用 varchar 类型。
② 数据库查询尽量不用 select ,除非要查所有字段。
mysql> select id,name from test;  不用mysql> select  from test;
③ select 查询的时候,where 条件后面的列类型如果是字符串类型就要加引号,如果是数字类型就不要加引号。
④ 如果一个条件列的前 n 个字符已经接近唯一值,就可以对一个列的前 n 个字符创建索引,不需要对整个列创建索引了。
⑤ 可以创建联合索引,但要注意前缀特性。如果要做复合索引,要把最常用的当做常用条件列的字段放在前面。
⑥ 可以用 explain 查看 select 语句执行计划,慢查询日志或者 show full processlist 某语句长时间可以看到。
⑦ 能批量插入就批量插入,不要逐条插入。
mysql> insert into test values(1,'oldboy'),(2,'oldgirl'),(3,'inca'),(4,'zuma'),(5,'kaka');
⑧ 使用 set profiles 查看 SQL 语句的执行细节。
5、架构上的优化
1)、业务拆分:搜索功能,like‘%老男孩%’,一般不要用mysql 数据库。
2)、业务拆分:某些业务应用使用 nosql 持久化存储,例如:memcahcedb,redis,ttserver
粉丝关注,好友关系等等。
3)、数据库前端必须要加 cache,例如:memcached,用户登录,商品查询。
4)、动态的数据静态化。整个文件静态化,页面片段静态化。
5)、数据库集群与读写分离。一主多从,通过程序或者 dbproxy 进行集群读写分离。
6)、单表超过2000万。拆库拆表,人工拆库拆表(登录、商品、订单)
7)、百度,阿里国内前×××司,会这样搞。
6、流程、制度,安全优化
任何一次人为数据库记录的更新,都要走一个流程:
a、人的流程:开发-->核心开发-->运维或DBA
b、测试流程:内网测试-->IDC测试-->线上执行
c、客户端管理,phpmyadmin
有关 mysql 的 innodb_flush_log_at_trx_commit 参数:
innodb_flush_log_at_trx_commit = 1
参数解释:
0:log buffer 将每秒一次地写入 log file 中,并且 log file 的 flush ( 刷到磁盘 )操作同时进行。该模式下在事务提交的时候,不会主动触发写入磁盘的操作。
1:每次事务提交时MySQL都会把log buffer的数据写入log file,并且 flush ( 刷到磁盘 ) 中去,该模式为系统默认。
2:每次事务提交时 MySQL 都会把 log buffer 的数据写入 log file,但是 flush ( 刷到磁盘 ) 操作并不会同时进行。该模式下,MySQL 会每秒执行一次 flush ( 刷到磁盘 ) 操作。
参数修改:
找到 mysql 配置文件 mysql.cnf,修改成合适的值,然后重启 mysql。
注意事项:
当设置为0,该模式速度最快,但不×××全,mysqld进程的崩溃会导致上一秒钟所有事务数据的丢失。
当设置为1,该模式是最安全的,但也是最慢的一种方式。在mysqld 服务崩溃或者云服务器主机crash的情况下,binary log 只有可能丢失最多一个语句或者一个事务。。
当设置为2,该模式速度较快,也比0安全,只有在操作系统崩溃或者系统断电的情况下,上一秒钟所有事务数据才可能丢失。

对于以上关于MySQL数据库如何实现正常优化,大家是不是觉得非常有帮助。如果需要了解更多内容,请继续关注我们的行业资讯,相信你会喜欢上这些内容的。

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

MySQL数据库如何实现正常优化

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

如何优化数据库的数据异常

优化数据库的数据异常可以采取以下措施:数据输入验证:对用户输入的数据进行验证,避免非法字符输入、数据类型不匹配等情况导致的数据异常。添加索引:为经常查询的字段添加索引,可以提高查询效率,减少数据异常的发生。规范化数据结构:设计良好的数据库结
如何优化数据库的数据异常
2024-07-03
如何实现MySQL底层优化:数据库分布式架构和性能优化
2023-11-08

如何优化MySQL数据库的性能?

如何优化MySQL数据库的性能?在现代信息时代,数据已经成为企业和组织的重要资产。作为最常用的关系型数据库管理系统之一,MySQL在各行各业都广泛地应用着。然而,随着数据量的增长和负载的增加,MySQL数据库的性能问题也逐渐凸显。为了提高系
2023-10-22

如何优化数据库的数据变化

要优化数据库的数据变化,可以考虑以下几个方面:数据库设计:合理设计数据库表结构,避免冗余字段和表,减少数据更新时的复杂性和开销。索引优化:为经常被查询和更新的字段添加索引,提高查询效率和减少数据更新时的开销。批量更新:尽可能使用批量更新操作
如何优化数据库的数据变化
2024-07-03

Mysql数据库慢查询常用优化方式

目录慢查询日志概念一、数据库中设置SQL慢查询1、mysql慢查询相关配置参数介绍2、实现配置步骤二、分析慢查询日志三、常见的慢查询优化1、索引没起作用的情况2、优化数据库结构3、分解关联查询4、优化LIMIT分页四、常用优化方法1. SQ
2023-05-05

MySQL数据库锁如何实现

这篇“MySQL数据库锁如何实现”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“MySQL数据库锁如何实现”文章吧。1.什么是
2023-03-23

如何优化数据库的数据计数

以下是一些优化数据库数据计数的方法:使用索引:确保在进行数据计数时使用到索引,可以加快查询速度。对于经常需要进行数据计数的字段,可以考虑创建索引。缓存结果:将数据计数的结果缓存起来,避免重复计算,特别是在数据量大或者计算复杂的情况下。数据分
如何优化数据库的数据计数
2024-07-03

如何调优mysql数据库

如何调优mysql数据库?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。1、排除缓存干扰在MySQL8.0之前,数据库存在缓存。因为存在缓存,所以同一个sql的执
2023-06-15

编程热搜

目录