【PM面试题】设计一个股价推送工具
这一轮面试时间比较短,问题在短时间内不能很全面展开,因此抓住一些关键点变得尤其重要,这里我记录下当时是怎么想这个问题的。
问题解析
子问题1:推送什么?从问题中看出我们需要推送的是股价,用户可以自定义需要关注哪个公司的股价;更深一层思考,推送除了股价也可以有一些该股票历史趋势,未来走势分析,整个这类股票的大局走势以及该公司最近的新闻等;另外触发条件也可以衍生一下,既可以是由股价到达某个点出发,也可以在变化剧烈的时候触发,也可以在股价在一段时间内的均值达到某个值触发。
子问题2:怎么推送?我们有一些传统手段如PC端的客户端或者浏览器插件推送或者使用邮件的方式推送,另外还有一些新的方式如移动端的短信、App通知推送、微信微博平台的消息推送等。
重要特性
- 时效性:对于推送工具而言,及时性是很重要的一个指标,而对于财经推送工具而言时效性尤其重要。该指标可以通过实时性的股价监控和推送到用户的时间差来衡量。
- 个性化:每个人关注的股票以及对股价的期待值是不一样的,因此让用户可以自由定制自己需要得到的信息是很必要的一个feature。
- 信息干扰的避免:推送工具要特别注意会成为信息的干扰,因此对于推送信息的时段以及信息的多少要特别注意,在用户不熟悉的时候给出提示,在用户误设定的时候给出友情提示。
系统框架图
这是现场作答的手稿

我用visio重绘了一下:

系统由四部分组成:
- 数据库端:由不同新鲜度的数据库组成,分为实时数据库(秒级别),日存储数据库,永久存储数据库等。其中实时数据库用于监控实时的股价数据,日存储用于单日的分析,长时数据库用于分析股价的趋势。
- 触发器是由用户自定义的一些条件组成,可以描述为:用户ID...IF...Then...,触发器根据当前条件决定哪些需要出发,然后将这些放入存储器。
- 存储器中有历史的触发事件,也有待通知的触发事件,经过一个推送过滤器,确定该推送在用户的请求范围内,完成推送。
- 推送可以选择多种渠道,亦可由用户指定。
关键技术难点
在面试中遇到这个问题的时候有点慌,但是还是抓住了推送服务的一个根本:及时性。因此暂不考虑用户端因为网络问题或者环境问题造成的延时,服务器端信息的采集以及处理将会称为整个系统的瓶颈所在,提高这部分的吞吐将会极大提高系统的整体时效性,让信息第一时间到达用户手中。
【PM面试题】设计一个股价推送工具的更多相关文章
- 【原创】node+express+socket搭建一个实时推送应用
技术背景 Web领域的实时推送技术,也被称作Realtime技术.这种技术要达到的目的是让用户不需要刷新浏览器就可以获得实时更新. 应用场景: 监控系统:后台硬件热插拔.LED.温度.电压发生变化 即 ...
- App设计:消息推送和界面路由跳转
概要 app消息推送.显示通知栏,点击跳转页面是很一般的功能了,下面以个推为例演示push集成,消息处理模块及app内部路由模块的简单设计. 推送 推送sdk集成 集成sdk步骤根据文档一步步做就行了 ...
- 由一个订单推送想到了ObservableCollection的神奇用法
最近在做taobao的一个卖家应用,需要订阅taobao的订单推送,示例代码如下: 看到上面的OnMessage场景之后,我突然就鬼使神差的在想最近写的一个服务,其中的一个功能是需要定时的轮询一个集合 ...
- .net core 3.0 Signalr - 实现一个业务推送系统
## 介绍 ASP.NET Core SignalR 是一个开源代码库,它简化了向应用添加实时 Web 功能的过程. 实时 Web 功能使服务器端代码能够即时将内容推送到客户端. SignalR 的适 ...
- [wxpusher]分享一个服务器推送消息到微信上的小工具,可以用于微信推送提醒和告警。
背景 作为一个程序员,业余搞点自己的东西很正常,一般程序员都会有一两台自己的服务器,谁叫今天xx云搞活动,明天yy云搞活动呢. 自家的服务器用来跑爬虫,跑博客,或者跑一些个人业务,但当服务有新状态,抢 ...
- 免费iOS第三方推送工具Urban Airship使用教程
本文转载至 http://blog.csdn.net/mamong/article/details/8542404 http://www.dapps.net/dev/iphone/ios-free ...
- 苹果cms和海洋cms通用的百度主动推送工具
百度主动推送的代码,不需要每天手动去添加地址推送,只要浏览器打开推送请求,不要关掉浏览器,程序自动帮你推送.(该插件只推送内容页,支持动态.伪静态.静态页面的推送,但这三种地址规则需要去代码里面自行拼 ...
- .net C# 苹果消息推送 工具类
public class AppleAPNSMessage { /// <summary> /// 苹果信息推送 证书 路径(注意测试版跟正式发布版证书上不一样) /// </sum ...
- 面试题——设计一个程序:运行报错Stack Overflow Error
所谓Stack Overflow就是栈里面放的东西太多了,溢出了. 大家知道栈里面存放的是基本数据类型还有引用类型. 下面看这个程序 class Test { public static void m ...
随机推荐
- JVM性能调优监控工具jps、jstack、jmap、jhat、jstat等使用详解
转载:http://blog.csdn.net/tzs_1041218129/article/details/61630981 javap 和 javac javap -help javac -hel ...
- 小白系列-免费广告路由器web认证设置(2)
要设置认证页面图片.须要到后台注冊一个帐号,绑定路由器. 路由器管理后台网址 http://115.29.12.130/router 第一步:自己主动获取一个路由器ID(上一篇文章中的路由器ID也要改 ...
- Android Tint着色与帧动画结合
需求 最近遇到一个需求: 要求根据后台接口给的色值 显示不同色值的帧动画(UI给了三张透明色的图) 正常的帧动画 是配置在xml里三张静态图片 然后加载一下就完事了现有的静态图片是透明的 还没有填充颜 ...
- Cannot make a static reference to the non-static method的解决方法
报错原因:在一个类中写了一个public String getContent()方法和一个main()方法,getContent()方法中包含了getClass()方法,在main()方法中直接调用了 ...
- Zoho CEO:云计算泡沫巨大 Salesforce仅仅是新的Siebel
最近Zoho CEO - Sridhar Vembu接受科技博客媒体Diginomica的专訪,从独特的眼光和见解.讲述了云计算行业环境.SaaS公司的生存状态.商业观念以及Zoho的商业模式. Sr ...
- vpngate 的使用
第一次为小日本打广告.. .我仅仅想仰天大喊..玛的戈壁. .. 竟然活到这个份上了...想出去看看的往下看.. vpngate 下载: http://pan.baidu.com/s/1hq5x3Ly ...
- hiberbnate 缓存策略概述
1. 首先了解什么是缓存 这里说的缓存并不是指计算机的内存或者CPU的一二级缓存. 缓存是指为了降低应用程序对物理数据源访问的频次,从而提高应用程序的运行性能的一种策略.即对物理数据源的复制,存在于内 ...
- 给第三方dll加上强命名的方法[C#]
在VS.NET 的命名行窗口下,输入如下的代码. 1 ,生成一个KeyFile sn -k keyPair.snk 2, 得到程序集的MSIL ildasm SomeAssembly.dll /out ...
- 使用DotNetZip压缩与解压缩
下载地址:http://dotnetzip.codeplex.com/ 解压后找到\\DotNetZipLib-DevKit-v1.9\zip-v1.9\Release下的Ionic.Zip.dll文 ...
- 【转载】XGBoost调参
General Parameters: Guide the overall functioning Booster Parameters: Guide the individual booster ( ...