




已阅读5页,还剩6页未读, 继续免费阅读
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
智能调度系统数据库架构初步设计方案一、 概述智能公交调试管理系统,将公交日常运营涉及到的各对象,各流程,各业务等经过优化后全部通过计算机信息化管理起来,做到对整个运营过程包括车辆,司机,线路,行车计划,排班计划,发车调度,行车调度,客户服务等的实时,细致,有效的监督,控制和调理,管理人员能对整个运营做出及时有效的决策,并可快速看到决策效果。杭州市公共交通集团拥有13家分公司,14家全资子公司(企业),14家控股公司,11家参股公司。至2011年底,集团共60.10亿总资产,2.3万名员工,548条公交线路,7200辆公交车。若所有车辆都安装了gps设备并使用智能公交调度系统,每天将会产生大量数据,包括行车计划、排班计划、发车调度、行车调度、车辆行驶记录等如果不能设计一个合理的数据库模型,不仅会增加客户端和服务器程序的编程和维护的难度,而且将会影响系统实际运行的性能。在一个系统分析、设计阶段,因为数据量较小,负荷较低。我们往往只注意到功能的实现,而很难注意到性能的薄弱之处,等到系统投入实际运行一段时间后,才发现系统的性能在降低,这时再来考虑提高系统性能则要花费更多的人力物力,而整个系统也不可避免的形成了一个打补丁工程。特别是杭州公交集团规模、路线、车辆都很多,我们必须要考虑,在高并发大数据量的访问情况下,系统会不会出现极端的情况。二、 智能调度管理系统存储需求分析1、 系统主要的数据表及存储占用:系统现在只使用了一条线路(k198路)进行测试,该线路共有运营车辆 台,从 月份使用至今,现主要数据表的使用状况如下表:2、 系统规划数据表容量杭州公交集团要求数据能保存三年,那么将会产生多少数据,占用多少空间呢?我们进行了初步的分析如下:u 行车计划:u 排班计划u 发车调度u 行车调度u 行车grs记录若以8000台车辆计算,车载设备每15秒发送一条记录,以每台车每天运营16小时算,每台车每天共产生:16*60*4=1536条每天共产生:1536*8000=12288000条。需要存储3年的记录共:12288000*12*30*3=13,271,040,000由此可见,行车grs记录将是整个系统中数据量最多,访问最集中的表,解决grs记录的并发、存储和效率将是整个数据存储方案的关键。三、 sqlserver常用高负载高并发的处理方式智能调试系统使用了ms sqlserver作为数据库,sqlserver为中小型应用提供了优秀的性能,也非常易于管理。但当数据库系统遇到高并发高负载的大型应用(如上述规则中grs行车记录),每天上千万的数据无疑对数据库造成了相当高的负载。对于系统的稳定性和扩展性造成了极大的问题。以往人们提到海量数据的解决方案都会想到oracle和db2,但这些产生价格和维护成本非常高昂,其实sqlserver2005对海量数据处理也提供了不俗的性能,sqlserver可以取用下面方法来处理海量数据应用:1、数据库的读写分离1),实现原理:读写分离简单的说是把对数据库读和写的操作分开对应不同的数据库服务器,这样能有效地减轻数据库压力,也能减轻io压力。主数据库提供写操作,从数据库提供读操作,其实在很多系统中,主要是读的操作。当主数据库进行写操作时,数据要同步到从的数据库,这样才能有效保证数据库完整性。(ebay的读写比率是260:1,ebay的读写分离)(微软数据库分发)2),实现方法:在ms sqlserver中可以使用发布定义的方式实现数据库复制,实现读写分离,复制是将一组数据从一个数据源拷贝到多个数据源的技术,是将一份数据发布到多个存储站点上的有效方式。使用复制技术,用户可以将一份数据发布到多台服务器上。复制技术可以确保分布在不同地点的数据自动同步更新,从而保证数据的一致性。sql server复制技术类型有三种,分别是:快照复制、事务复制、合并复制。sql server 主要采用出版物、订阅的方式来处理复制。源数据所在的服务器是出版服务器,负责发表数据。出版服务器把要发表的数据的所有改变情况的拷贝复制到分发服务器,分发服务器包含有一个分发数据库,可接收数据的所有改变,并保存这些改变,再把这些改变分发给订阅服务器。3),优缺点(1)数据的实时性差:数据不是实时同步到自读服务器上的,当数据写入主服务器后,要在下次同步后才能查询到。(2)数据量大时同步效率差:单表数据量过大时插入和更新因索引,磁盘io等问题,性能会变的很差。(3)同时连接多个(至少两个)数据库:至少要连接到两个数据数据库,实际的读写操作是在程序代码中完成的,容易引起混乱(4)读具有高性能高可靠性和可伸缩:只读服务器,因为没有写操作,会大大减轻磁盘io等性能问题,大大提高效率;只读服务器可以采用负载均衡,主数据库发布到多个只读服务器上实现读操作的可伸缩性。2、数据库拆分(分布式)通过某种特定的条件,将存放在同一个数据库中的数据分散存放到多个数据库上,实现分布存储,通过路由规则路由访问特定的数据库,这样一来每次访问面对的就不是单台服务器了,而是n台服务器,这样就可以降低单台机器的负载压力。垂直(纵向)拆分:是指按功能模块拆分,比如分为订单库、商品库、用户库.这种方式多个数据库之间的表结构不同。水平(横向)拆分:将同一个表的数据进行分块保存到不同的数据库中,这些数据库中的表结构完全相同。(纵向拆分)(横向拆分)1),实现原理:使用垂直拆分,主要要看应用类型是否合适这种拆分方式,如系统可以分为,订单系统,商品管理系统,用户管理系统业务系统比较明的,垂直拆分能很好的起到分散数据库压力的作用。业务模块不明晰,耦合(表关联)度比较高的系统不适合使用这种拆分方式。但是垂直拆分方式并不能彻底解决所有压力问题,例如 有一个5000w的订单表,操作起来订单库的压力仍然很大,如我们需要在这个表中增加(insert)一条新的数据,insert完毕后,数据库会针对这张表重新建立索引,5000w行数据建立索引的系统开销还是不容忽视的,反过来,假如我们将这个表分成100个table呢,从table_001一直到table_100,5000w行数据平均下来,每个子表里边就只有50万行数据,这时候我们向一张只有50w行数据的table中insert数据后建立索引的时间就会呈数量级的下降,极大了提高了db的运行时效率,提高了db的并发量,这种拆分就是横向拆分2),实现方法:垂直拆分,拆分方式实现起来比较简单,根据表名访问不同的数据库就可以了。横向拆分的规则很多,这里总结前人的几点,(1)顺序拆分:如可以按订单的日前按年份才分,2003年的放在db1中,2004年的db2,以此类推。当然也可以按主键标准拆分。优点:可部分迁移缺点:数据分布不均,可能2003年的订单有100w,2008年的有500w。(2)hash取模分: 对user_id进行hash(或者如果user_id是数值型的话直接使用user_id的值也可),然后用一个特定的数字,比如应用中需要将一个数据库切分成4个数据库的话,我们就用4这个数字对user_id的hash值进行取模运算,也就是user_id%4,这样的话每次运算就有四种可能:结果为1的时候对应db1;结果为2的时候对应db2;结果为3的时候对应db3;结果为0的时候对应db4,这样一来就非常均匀的将数据分配到4个db中。 优点:数据分布均匀 缺点:数据迁移的时候麻烦;不能按照机器性能分摊数据 。 在整个系统中,除了gps数据表的数据量太大外,其他表都可以通过分区表和历史表来解决数据量大时查询慢的问题。针对如何解决gps行车数据存储和访问有以下几个备选方案:四、 备选方案一方案描述:gps行车记录表把数据库分为一个主数据库和n个行车记录数据库,主数据库中创建一个对照查找表记录着某线路、某车辆、某天的记录及明细记录所在的数据库和表名,这表担当索引的作用。当天的行车数据存储在主库里面,通过自动任务把不是当天的记录根据配置存储到对应的服务器数据表中,查询数据时不再直接操作该表,而是通过存储过程操作。查找表的数据表结构如下:方案优点:方案缺点:需要服务器较多五、 备选方案二只使用一个数据库服务器,不进行分库, 主数据库gps数据表保存一天左右的数据量,每天以自动任务把非当天的行车gps数据以每车每天一个文件的形式以文本文件保存起来(每个文件的记录数是60*16*4=1536条)存放到磁盘柜,数据库中建立一个查找对照表,用来存储线路、车辆、日期、数据文件的存储路径等信息。查询先把文本数据取出来放到内存表里进行查询分析。方案简介:方案优点:数据库压力较小,每台车每天只产生一条记录。方案缺点:查询时需要把文本文件转化为数据库记录,速度较慢。文件太多目录复杂。六、 备选方案三使用第三方中间件系统moebius-for-sql-server数据库集群技术。1、负载均衡技术负载均衡集群是由一组相互独立的计算机系统构成,通过常规网络或专用网络进行连接,由路由器衔接在一起,各节点相互协作、共同负载、均衡压力,对客户端来说,整个群集可以视为一台具有超高性能的独立服务器。 1)、实现原理实现数据库的负载均衡技术,首先要有一个可以控制连接数据库的控制端。在这里,它截断了数据库和程序的直接连接,由所有的程序来访问这个中间层,然后再由中间层来访问数据库。这样,我们就可以具体控制访问某个数据库了,然后还可以根据数据库的当前负载采取有效的均衡策略,来调整每次连接到哪个数据库。2)、实现多据库数据同步对于负载均衡,最重要的就是所有服务器的数据都是实时同步的。这是一个集群所必需的,因为,如果数不据实时、不同步,那么用户从一台服务器读出的数据,就有别于从另一台服务器读出的数据,这是不能允许的。所以必须实现数据库的数据同步。这样,在查询的时候就可以有多个资源,实现均衡。比较常用的方法是moebius for sql server集群,moebius for sql server集群采用将核心程序驻留在每个机器的数据库中的办法,这个核心程序称为moebius for sql server 中间件,主要作用是监测数据库内数据的变化并将变化的数据同步到其他数据库中。数据同步完成后客户端才会得到响应,同步过程是并发完成的,所以同步到多个数据库和同步到一个数据库的时间基本相等;另外同步的过程是在事务的环境下完成的,保证了多份数据在任何时刻数据的一致性。正因为moebius 中间件宿主在数据库中的创新,让中间件不但能知道数据的变化,而且知道引起数据变化的sql语句,根据sql语句的类型智能的采取不同的数据同步的策略以保证数据同步成本的最小化。数据条数很少,数据内容也不大,则直接同步数据数据条数很少,但是里面包含大数据类型,比如文本,二进制数据等,则先对数据进行压缩然后再同步,从而减少网络带宽的占用和传输所用的时间。数据条数很多,此时中间件会拿到造成数据变化的sql语句, 然后对sql语句进行解析,分析其执行计划和执行成本,并选择是同步数据还是同步sql语句到其他的数据库中。此种情况应用在对表结构进行调整或者批量更改数据的时候非常有用。3)、优缺点(1) 扩展性强:当系统要更高数据库处理速度时,只要简单地增加数据库服务
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2025内蒙古自治区农牧业科学院招聘48人考前自测高频考点模拟试题及答案详解(夺冠系列)
- 出纳转正月度工作总结4篇
- 2025江西吉安市文化旅游投资发展集团有限公司及下属子公司招聘10人(第一批)考前自测高频考点模拟试题及答案详解(各地真题)
- 2025年延安东辰中学教师招聘考前自测高频考点模拟试题及1套参考答案详解
- 2025年福建省厦门海沧华附实验小学招聘1人考前自测高频考点模拟试题及参考答案详解一套
- 2025年威海火炬高技术产业开发区公开招聘教师(第二批)(61人)考前自测高频考点模拟试题及完整答案详解
- 2025国网山西省电力公司博士后科研工作站招聘1人考前自测高频考点模拟试题附答案详解(典型题)
- 2025湖北咸宁市通城县事业单位高层次和急需紧缺人才引进48人考前自测高频考点模拟试题及1套完整答案详解
- 2025湖南邵阳市新宁产业开发区选调5人模拟试卷含答案详解
- 2025广西南宁市人民路东段小学春季学期教师招聘1人模拟试卷附答案详解(完整版)
- 2025年度国家电投校园招聘模拟试卷及答案详解(历年真题)
- 钢厂吊装安全培训课件
- 德育教育 课题申报书
- 维生素D佝偻病课件
- 液压实训安全培训课件
- 义齿行业安全教育培训课件
- 第8课《回忆鲁迅先生》公开课一等奖创新教学设计 统编版语文八年级上册
- 胆结石课件教学课件
- 第2课《中国人首次进入自己的空间站》课件+2025-2026学年统编版语文八年级上册
- 耳灸疗法护理操作规范
- 2025年卫生知识健康教育知识竞赛-医疗质量与安全管理知识竞赛历年参考题库含答案解析(5套典型题)
评论
0/150
提交评论