忘记密码?

一键登录

草根吧源码论坛

论坛›技术分享›Discuz›性能与优化›MySQL 优化

查看: 242|回复: 1

论坛›技术分享›Discuz›性能与优化›MySQL 优化

[复制链接]

5760

主题

704

热度

2218

贡献

管理员

Rank: 9Rank: 9Rank: 9

DZ专员

发表于 2015-9-23 11:42:21 | 显示全部楼层 |阅读模式 | 百度  360  谷歌 
分享到:
在整个 Discuz! X3.2 产品中,为了提供效率,需要对 SQL 做相应的优化。有时候不能忽略一些细小的优化,当出现过多未优化的细节时,也能带来致命的负载问题。

一、延迟更新机制

例如:首页的在线人数等,在实际产品中,有些数据不一定需要实时更新的,因为对于这类型的数据来说,实时更新的价值不高,对于这种情况我们可以考虑在产品研发过程中引入廷迟更新机制,这样可以从一定程度上降低SQL的负载。

二、索引

索引的合理使用,能给你带来高效的SQL查询,但不是索引越多越好,索引的引入需在查看整个模块的设计,使之最大程度上使用索引。

三、读写分离

读写分离,在X2的版本中,我们引入了多SQL服务器的支持,在主从服务器中,你可以配置写服务器跟读服务器,这样对于负载高的站点中可以使用这个功能达到读写分离,降低由于写过程序中造成的mysql表锁定后的SQL排队等候时间过长。当你的服务器支持读写分离要求时,你可以在config_global.php中配置。例如:
  1. /**
  2. * 数据库主服务器设置, 支持多组服务器设置, 当设置多组服务器时, 则会根据分布式策略使用某个服务器
  3. * @example
  4. * $_config['db']['1']['dbhost'] = 'localhost'; // 服务器地址
  5. * $_config['db']['1']['dbuser'] = 'root'; // 用户
  6. * $_config['db']['1']['dbpw'] = 'root';// 密码
  7. * $_config['db']['1']['dbcharset'] = 'gbk';// 字符集
  8. * $_config['db']['1']['pconnect'] = '0';// 是否持续连接
  9. * $_config['db']['1']['dbname'] = 'x1';// 数据库
  10. * $_config['db']['1']['tablepre'] = 'pre_';// 表名前缀
  11. *
  12. * $_config['db']['2']['dbhost'] = 'localhost';
  13. * ...
  14. *
  15. */
  16. $_config['db'][1]['dbhost']                  = 'localhost';               
  17. $_config['db'][1]['dbuser']                  = 'root';               
  18. $_config['db'][1]['dbpw']                  = 'root';               
  19. $_config['db'][1]['dbcharset']                 = 'gbk';               
  20. $_config['db'][1]['pconnect']                 = 0;                        
  21. $_config['db'][1]['dbname']                  = 'ultrax';               
  22. $_config['db'][1]['tablepre']                 = 'pre_';               

  23. /**
  24. * 数据库从服务器设置( slave, 只读 ), 支持多组服务器设置, 当设置多组服务器时, 系统每次随机使用
  25. * @example
  26. * $_config['db']['slave']['1']['dbhost'] = 'localhost';
  27. * $_config['db']['slave']['1']['dbuser'] = 'root';
  28. * $_config['db']['slave']['1']['dbpw'] = 'root';
  29. * $_config['db']['slave']['1']['dbcharset'] = 'gbk';
  30. * $_config['db']['slave']['1']['pconnect'] = '0';
  31. * $_config['db']['slave']['1']['dbname'] = 'x2';
  32. * $_config['db']['slave']['1']['tablepre'] = 'pre_';
  33. *
  34. * $_config['db']['slave']['2']['dbhost'] = 'localhost';
  35. * ...
  36. *
  37. */
  38. $_config['db']['slave'] = array();
复制代码
四、SQL查询与循环

禁止在循环中进行相应的SQL查询,当遇到这种情况时,可以尽可能的将其转换成循环外的查询。

五、NOT IN

在SQL查询中禁用NOT IN条件,NOT IN的效率比IN低很多,当使用IN时,也要尽可能的保证IN的数量。

六、SQL分拆

化繁为简,在优化过程中,尽可能的化繁为简,把复杂的SQL分拆成几个简单的SQL更有种于对整体SQL的优化处理。

帖子地址: 

本文来源于草根吧源码论坛 www.caogen8.co,欢迎大家下载。
如果您没有贡献需要充值,可以直接在线充值,点击充值
如果你需要加入本站赞助VIP会员,可以直接在线开通,点击开通
如果找不到您要的资源,请搜索一下,点击搜索
回复

举报

发表回复

您需要登录后才可以回帖 登录 | 立即注册 新浪微博登陆 用百度帐号登录 一键登录:

本版积分规则

收藏帖子 返回列表 搜索
快速回复 返回顶部 返回列表