TiDB 在西山居实时舆情监控系统中的应用

Easter79
• 阅读 181

公司简介

西山居创建 1995 年初夏,在美丽的海滨小城珠海,西山居工作室孕育而生,一群西山居居士们十年如一日尅勊业业的奋斗。"创造快乐,传递快乐!" 一直是西山居居士们的创作宗旨。西山居以领先的技术作为坚实的基础以独特的本土化产品为玩家提供时尚化服务。在未来,西山居仍以娱乐软件为主导产品,不断进行研发和市场活动,逐步发展成为国内最优秀的集制作、发行于一体的数字化互动娱乐公司。

业务背景

由于公司产品的社交属性都非常强,对相关舆情进行分析与了解就显得很有必要,在此背景下,舆情监控系统应运而生。该系统利用算法组提供的分词算法,对文本进行解析与分类,打上各类标记后再通过计算产生中间结果。舆情系统直接查询这些中间结果,产生各类报表与趋势图,为及时掌握各类舆情趋势提供便利。用户可以自由组合舆情关注点,从而对平台有很严格的实时交互性查询要求,是典型的实时 HTAP 类业务。

存储技术选型

舆情系统之前我们曾经实现过一个客服系统,这个系统要求能实时查询,但面对是海量的玩家行为记录。在当时情况下(2016 年),可以选择的对象只有 MyCAT 这类数据库中间件,通过综合压力测试后,我们选定了 KingShard 这一款由公司前同事开发的中间件,KingShard 虽然没有 MyCAT 丰富的周边功能,但它在满足我们业务需求的核心功能上有更快的表现。但正因为有了这一次中间件的使用,我们对中间件有了比较全面的了解,它们在查询优化上有着天生的弱点,无法满足更复杂的查询或者表现极不友好,为此我们还不得不砍掉了客服系统的部分业务功能,所以在那时我已开始寻找更优的技术方案,其中分布式数据库是我们考察的重点方向。

BigTable、GFS、MapReduce 是谷歌在分布式存储与查询领域的探索成果,他们没有公开具体实现代码,但却发布了相应论文,对分布式文件系统、大数据挖掘和 NoSQL 发展起了重大促进作用。开源界根据这一成果开发出对应产品是 HBase、HDFS、Hadoop,这三个产品红极一时,相关周边产品更是百花齐放,很多细分领域都同时出现了多个产品竞争,让整个生态非常繁荣但也变得复杂,提高了我们的学习与使用成本。那么,在一些领域中有没有更加简单、直接、具有较强融合能力的解决方案呢?此时距谷歌这三篇论文发表已近 10 年,谷歌内部早已在尝试融合 NoSQL 和 SQL,并对它们进行了多次更新换代,Spanner、F1 两篇论文便是谷歌在这一方向的探索成果。开源分布式数据库 TiDB 便是受论文启发而设计的 HTAP (Hybrid Transactional and Analytical Processing) 数据库,结合了传统的 RDBMS 和 NoSQL 的最佳特性,兼容 MySQL,具有支持分布式事务、无限的水平扩展、数据强一致性保证等核心 NewSQL 特性。

当时,舆情系统接入的第一个游戏平均每天入库数据量就已达到 8500 万条,并且还需要支持各种实时交互性查询,显然中间件已不能满足要求,传统的关系型数据库则更加不可能了。考虑到以后还会有其它游戏接入,我们果断选择了分布式数据库。 随着互联网经济的发展,数据量跟并发数也在飞速增长,单机数据库已越来越不能满足要求了,为此谷歌、阿里等大厂都有了自研的分布式数据库,但都没有开源,而 MySQL 的 MGR 及相关功能进展的步子太小,TiDB 的出现很好的弥补了市场空白,成为我们的唯一选择。

服务器配置

舆情系统是内部孵化项目,服务器具体如下:

新购物理机器 6 台:

TiDB 在西山居实时舆情监控系统中的应用

旧物理机 4 台:

TiDB 在西山居实时舆情监控系统中的应用

我们将对资源使用相对较小的 PD、监控服务分别放在旧物理机上,TiDB、TiKV 和 TiSpark 则分配在新机器上,详细如下:

TiDB 在西山居实时舆情监控系统中的应用

其中每个 TiKV 分配 CPU 10C / 内存 64G / 硬盘 2T,每个 TiSpark 分配 CPU 20C / 内存 64G。在资源有限情况下,结合数据量及舆情系统的 AP 业务属性,我们设计了这样相对复杂的架构,目的是为了充分利用好服务器资源,让它们能承担更极限的压力,事后有多次历史数据的导入也证明了我们这样设计的必要性,多谢 TiDB 的兄弟全程耐心指导及帮助。

项目开发过程

得出中间结果是一个非常大的计算过程,所以我们使用了 TiSpark。TiSpark 是 PingCAP 为解决用户复杂 OLAP 需求而推出的产品,它是将 Spark SQL 直接运行在分布式存储引擎 TiKV 上的 OLAP 解决方案。有了 TiSpark 我们可以方便地使用 Spark,而不需要再单独搭建一套 Spark 集群。

从 TiDB 的 1.0 RC 3 版本开始,我们就在金山云上搭建集群来试用与压测。期间经历了多次版本热更,集群也一直很稳定,功能与性能越来越强,所以在舆情系统开始开发时我们果断使用了 TiDB。并且 TiDB 有强烈的市场需求,他们的版本更新非常迅速,在试用期间时发现了一些功能不能满足需要,往往在下一个版本就解决了,这让人非常惊叹。

当前版本未加入实时计算业务,再加上使用了 TiSpark,所以整个架构相对简单,详细如下图:

TiDB 在西山居实时舆情监控系统中的应用

项目上线及使用情况

舆情系统目前总数据量数 T,已正式上线三个月,期间从未出现过异常,系统平稳、使用效果也非常好。现在每天原始文本数据在 2500 万条以上,通过算法分词后产生的中间结果则每天有 6000 万条左右(日均入库 8500 万条),高峰时段的平均 QPS 在 3K 以上,闲时的平均 QPS 为 300 多一点。根据这样的量级,在一开始评估时设定的目标是:支持最近一个星期的实时交互性查询,但现在已经远远超过我们的预期。目前所有一个月内的时间跨度查询都在 1 秒左右完成,个别复杂的 3 个月的实时交互性查询则需要 2 秒多一点。

可以说 TiDB 给我们的体验远超预期,这样的数据量级及响应,单机版数据库是不可能达到要求的。

作者介绍:邹学,舆情监控系统技术负责人,珠海金山网络游戏科技有限公司(西山居)数据中心架构师,2015 年加入西山居,具有 10 年游戏行业软件开发经验,主要参与了公司的游戏网关设计,数据分析框架底层架构建设等,现专注于实时计算、爬虫、分布式系统方向。

点赞
收藏
评论区
推荐文章
Jacquelyn38 Jacquelyn38
1年前
2020年前端实用代码段,为你的工作保驾护航
有空的时候,自己总结了几个代码段,在开发中也经常使用,谢谢。 1、使用解构获取json数据let jsonData   id: 1, status: "OK", data: ['a', 'b'] ; let  id, status, data: number   jsonData; console.log(id, status, number )
blmius blmius
1年前
MySQL:[Err] 1292 - Incorrect datetime value: ‘0000-00-00 00:00:00‘ for column ‘CREATE_TIME‘ at row 1
文章目录 问题 用navicat导入数据时,报错: 原因这是因为当前的MySQL不支持datetime为0的情况。 解决修改sql\mode: sql\mode:SQL Mode定义了MySQL应支持的SQL语法、数据校验等,这样可以更容易地在不同的环境中使用MySQL。 全局s
Stella981 Stella981
1年前
KVM调整cpu和内存
一.修改kvm虚拟机的配置 1、virsh edit centos7 找到“memory”和“vcpu”标签,将 <name>centos7</name> <uuid>2220a6d1-a36a-4fbb-8523-e078b3dfe795</uuid>
Stella981 Stella981
1年前
QClub 太原,2014年11月15日 Global Day of Coderetreat
QClub 太原,2014年11月15日 Global Day of Coderetreat ============================================== **活动时间:** 2014年11月15日星期六,全天(9:00-18:00) **活动地点:** 高新区体育路科技街口,大豪益达402(从KK这边的巷子进去,统一这面
Wesley13 Wesley13
1年前
Java日期时间API系列36
  十二时辰,古代劳动人民把一昼夜划分成十二个时段,每一个时段叫一个时辰。二十四小时和十二时辰对照表: **时辰** **时间** **24时制** 子时 深夜 11:00 - 凌晨 01:00 23:00 - 01 :00 丑时 上午 01:00 - 上午 03:00 01:00 - 03 :00 寅时 上午 03:00 - 上午 0
Wesley13 Wesley13
1年前
MySQL查询按照指定规则排序
1.按照指定(单个)字段排序 select * from table_name order id desc; 2.按照指定(多个)字段排序 select * from table_name order id desc,status desc; 3.按照指定字段和规则排序 selec
Stella981 Stella981
1年前
Django中Admin中的一些参数配置
### **设置在列表中显示的字段,id为django模型默认的主键** list_display = ('id', 'name', 'sex', 'profession', 'email', 'qq', 'phone', 'status', 'create_time') ### **设置在列表可编辑字段** list_editable
Stella981 Stella981
1年前
Angular material mat
Icon Icon Name mat-icon code _add\_comment_ add comment icon <mat-icon> add\_comment</mat-icon> _attach\_file_ attach file icon <mat-icon> attach\_file</mat-icon> _attach\
Wesley13 Wesley13
1年前
MySQL部分从库上面因为大量的临时表tmp_table造成慢查询
#### 背景描述 # Time: 2019-01-24T00:08:14.705724+08:00 # User@Host: **[**] @ [**] Id: ** # Schema: sentrymeta Last_errno: 0 Killed: 0 # Query_time: 0.315758 Lock_
helloworld_34035044 helloworld_34035044
4个月前
皕杰报表之UUID
​在我们用皕杰报表工具设计填报报表时,如何在新增行里自动增加id呢?能新增整数排序id吗?目前可以在新增行里自动增加id,但只能用uuid函数增加UUID编码,不能新增整数排序id。 uuid函数说明:获取一个UUID,可以在填报表中用来创建数据ID语法:uuid() 或 uuid(sep)参数说明:sep 布尔值,生成的uuid中是否包含分隔符'',缺省为