• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • MsSql
  • Mysql
  • oracle
  • MariaDB
  • DB2
  • SQLite
  • PostgreSQL
  • MongoDB
  • Redis
  • Access
  • 数据库其它
  • sybase
  • HBase
您的位置:首页 > 数据库 >Mysql > mysql数据库应付大流量网站的的3种架构扩展方式介绍

mysql数据库应付大流量网站的的3种架构扩展方式介绍

作者: 字体:[增加 减小] 来源:互联网 时间:2017-05-11

通过本文主要向大家介绍了mysql数据库最大容量,mysql数据库大小写,mysql数据库大作业,mysql数据库,mysql数据库教程等相关知识,希望本文的分享对您有所帮助

数据库扩展大概分为以下几个步骤:

1、读写分离:当数据库访问量还不是很大的时候,我们可以适当增加服务器,数据库主从复制的方式将读写分离;

2、垂直分区:当写入操作一旦增加的时候,那么主从数据库将花更多的时间的放在数据同步上,这个时候服务器也是不堪重负的;那么就有了数据的垂直分区,数据的垂直分区思路是将写入操作比较频繁的数据表,如用户表_user,或者订单表_orders,那么我们就可以把这个两个表分离出来,放在不同的服务器,如果这两个表和其他表存在联表查询,那么就只能把原来的sql语句给拆分了,先查询一个表,在查询另一个,虽然说这个会消耗更过性能,但比起那种大量数据同步,负担还是减轻了不少;

3、水平分区:但是往往事情不尽人意,可能采取垂直分区能撑一段时间,由于网站太火了,访问量又每日100w,一下子蹦到了1000w,这个时候可以采取数据的进行分离,我们可以根据user的Id不同进行分配,如采取%2的形式,或者%10的形式,当然这种形式对以后的扩展有了很大的限制,当我由10个分区增加到20个的时候,所有的数据都得重新分区,那么将是一个的很庞大的计算量;以下提供几种常见的算法:
  哈希算法:就是采用user_id%的方式;
  范围:可以根据user_id字符值范围分区,如1-1000为一区,1001-2000则是另一个区等;
  映射关系:就是将user_id存在的所对应的分区放在数据库中保存,当用户操作时先去查询所在分区,再进行操作;

对于以上几种扩展方式,读写分离主要是操作上的扩展,垂直分区主要是对写入较频繁数据表的分离,水平分区主要是数据分离;

</div>
分享到:QQ空间新浪微博腾讯微博微信百度贴吧QQ好友复制网址打印

您可能想查找下面的文章:

  • mysql数据库应付大流量网站的的3种架构扩展方式介绍

相关文章

  • 2017-05-11Mysql LONGBLOB 类型存储二进制数据 (修改+调试+整理)
  • 2018-12-05给Myql创建索引
  • 2018-12-05oracle中的视图详解
  • 2017-05-11用Jena将本体文件存入MySQL数据库的实现方法
  • 2017-05-11sysbench-0.4.12编译安装和CPU测试例子分享
  • 2018-12-05MySQLi 扩展库视频教程的资源推荐
  • 2017-05-11使用mysql的disctinct group by查询不重复记录
  • 2018-12-05Mysql GTID Mha配置方法的示例代码分享
  • 2018-12-05sql 版本详解 让你认识跟sql2000的区别
  • 2018-12-05SQL SERVER 2008 CTE生成结点的FullPath

文章分类

  • MsSql
  • Mysql
  • oracle
  • MariaDB
  • DB2
  • SQLite
  • PostgreSQL
  • MongoDB
  • Redis
  • Access
  • 数据库其它
  • sybase
  • HBase

最近更新的内容

    • 讲解MySQL中<=>操作符的用法
    • MySQL中binlog日志文件的详细介绍
    • MySQL 查询某个字段不重复的所有记录
    • MySQL之—mysql命令行备份数据库详解
    • MySQL利用profile分析慢sql代码实例详解
    • Oracle9i取得建表和索引的DDL语句
    • MySQL服务器的启动和关闭
    • MySQL使用游标数据实例教程
    • sql中返回参数的值
    • linux装mysql问题

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有