UTM 用户线程模型

Utm-简介git

 

Git@OSC: http://git.oschina.net/daemon_c/UTM  ( utm相关:http://git.oschina.net/daemon_c/QTM)数据库

 

UTM-Demo安全

Git@OSC: http://git.oschina.net/daemon_c/UTM-demo (SmartFoxServer,Netty)并发

 

 

在一些金融交易处理、游戏数据处理等逻辑较为复杂的领域中,各个接口可能会交叉使用和修改一些资源数据,这样就很容易致使一些并发的问题,若是对于每一个资源都要考虑如何保证其并发安全问题,那么整个分析过程就会变得很复杂,而复杂的逻辑每每容易有所疏漏。异步

 

Utm就是设计来屏蔽单个用户的并发问题的,就是用户访问本身的资源是不须要考虑其并发安全问题的(多个用户访问的资源依然须要处理),主要想法是将用户的请求排序并调用线程池中的线程依次处理。高并发

 

一个简单的场景:用户买入一个东西的总额是受限制的,用户a发起两次买入请求(请求1 和请求2)spa

在一般状况下,须要在用户买入请求中加入锁或者使用原子类,从而避免 请求1 和 请求2 同时处理致使超过限制;.net

而在utm下则不须要考虑相似问题,用户a的请求1执行完了才会执行请求2。线程

而现实业务中相似的场景有不少,使用utm确实使开发的复杂度下降。设计

 

这样就不会有说一个用户的两个请求被同时处理这样的状况,相对起来开发的复杂度就下降了不少,并且也意味着多个线程争抢资源的几率减小了(一个用户最多只有一个请求正在被处理)。用户的请求不会被并发处理,从单个用户上来是比原来要慢点,但从硬件相对整个用户群来讲,一般的应用的用户的数量都会远远大于cpu的数量,因此这样不会致使cpu利用不足问题,相反utm能更好的将cpu资源分配给各个用户,竞争减小也意味着程序更高效了。Utm的核心qtm自己虽然会有一些锁操做,但都是一些小锁块,应对多个用户的每秒几千甚至上万个的请求并无什么延迟,因此也就没有打算开发基于CAS版本的qtm的打算(服务处理的瓶颈一般出在涉及IO方面,特别是数据库处理,相比起来utm的开销有点微不足道)。

 

 

特色:

1.      Utm保证用户生命流程的完整性和执行顺序。

(eg:一个用户登陆,若是他已经登陆了,那么旧的用户会被先退出,而后新的用户再登陆)

(eg:用户发起 请求1 后 发起 请求2,则 请求1 必定先于 请求2 执行)

 

2.      用户的请求被有序的执行,因此用户访问本身的资源是不须要考虑其并发安全问题,下降了开发的复杂度。

(eg:有一个用户未读消息的统计,在utm中就能够直接是一个int类型保存在内存中,若是在其余没有保证并发控制的地方则至少要声明为AtomicInteger 或者使用锁来维护这个字段)

 

3.      提供用户资源接口,提供了用户生命流程中的各个重要点的切面,让开发者能够更好的管理本身定义的用户资源;并提供在异常状况下恢复用户队列的处理。

(eg:用户队列:在用户开始登录标志位设置成功后 申请,当用户登陆链接检查失败、用户退出的时候释放)

 

4.      高并发性

Utm的核心qtm自己虽然有一些锁操做,但都是一些小锁块,能够应对多个用户的每秒几千甚至上万个的请求(服务处理的瓶颈一般出在涉及IO方面,特别是数据库处理,相比起来utm的开销过小);并提供实现异步操做的接口(挂起和恢复当前队列,详见9.用户队列管理

 

5.      具备良好的 兼容性

Utm能够很是容易得应用在不一样的服务端(像SmartFoxServer, Netty等)

 

 

 

1.Utm简介

2. Utm 模块设计

3. Utm详细实现-用户生命流程

4. Utm详细实现-用户资源管理

5.Utm线程模型

6. Utm示例-公共部分

7. Utm示例-SmartFoxServer集成

8. Utm示例-Netty集成

9.(1.0.2版本更新)用户队列管理 与 用户异常处理

相关文章
相关标签/搜索