码迷,mamicode.com
首页 > 数据库 > 详细

服务端数据库的操作如何不阻塞

时间:2015-05-31 18:26:06      阅读:156      评论:0      收藏:0      [点我收藏+]

标签:

1、业务服务器进程中包含多个线程,每个线程处理的业务不一样,master负责请求的转发,slave负责具体的事情,订阅线程负责把数据通知给订阅者。

2、这些线程都有数据库操作的业务,不同线程之间的数据库操作,操作的数据不一样,如何不阻塞呢?

  建立一个db类,每个线程包含db对象,都与数据库建立一个连接,不同的连接之间数据库操作不阻塞。

3、按照上面的设计,master与数据库一个连接,数据库的操作必须排队,前一个操作耗时,后一个操作必须等待。也就是说,不同请求之间会阻塞,同一个线程,两次数据库请求操作如何不阻塞呢?

  新建一个db线程,定时处理消息。master收到一个耗时的数据库操作,把请求扔给db线程,接着可以处理下一个数据库请求,不阻塞。db线程处理完之后,再返回给master。

注:这里的线程继承框架,会定时取出消息进行处理。

  

服务端数据库的操作如何不阻塞

标签:

原文地址:http://www.cnblogs.com/nzbbody/p/4542285.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!