1、业务服务器进程中包含多个线程,每个线程处理的业务不一样,master负责请求的转发,slave负责具体的事情,订阅线程负责把数据通知给订阅者。
2、这些线程都有数据库操作的业务,不同线程之间的数据库操作,操作的数据不一样,如何不阻塞呢?
建立一个db类,每个线程包含db对象,都与数据库建立一个连接,不同的连接之间数据库操作不阻塞。
3、按照上面的设计,master与数据库一个连接,数据库的操作必须排队,前一个操作耗时,后一个操作必须等待。也就是说,不同请求之间会阻塞,同一个线程,两次数据库请求操作如何不阻塞呢?
新建一个db线程,定时处理消息。master收到一个耗时的数据库操作,把请求扔给db线程,接着可以处理下一个数据库请求,不阻塞。db线程处理完之后,再返回给master。
注:这里的线程继承框架,会定时取出消息进行处理。
时间: 2024-10-06 21:13:43