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

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

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

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

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

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

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

  

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值