当前位置:  技术问答>linux和unix

请教高手:消息队列排队处理繁忙如何处理?

    来源: 互联网  发布时间:2015-05-05

    本文导语:  我的系统的服务程序,一个程序(5个进程)负责接受TCP/IP交易请求,并写入消息队列;另外有一个程序(5个进程)读出消息队列并提交的数据库处理,当数据库处理慢时,等待超时就丢弃并取下一个消息,超时设为3...

我的系统的服务程序,一个程序(5个进程)负责接受TCP/IP交易请求,并写入消息队列;另外有一个程序(5个进程)读出消息队列并提交的数据库处理,当数据库处理慢时,等待超时就丢弃并取下一个消息,超时设为30秒。
    现在的问题是,有时数据库由于其他应用的原因,交易阻塞,连续多个交易超时,很快占满了所有进程。当30秒进程超时放弃,取下一个消息时,下一个消息已经超时,于是再取下一个消息,同时前端还一直有消息进来,这样,进程每次取到的消息都是已经等待了30秒以上的交易,都不断的放弃。这样一来,后面的新消息一直就没有机会处理,一直等到可以处理时又超时了。除非停止前端提交请求,否则一直没有机会恢复到可以正常提交到数据库处理。但前端用户很多,每个用户都在不断提交,超时了又重提交....
    我怎样处理才能使程序自动跳出这个排队的僵局?系统能自动恢复。现在每次发生这种现象我只有重起程序(重起会杀掉所有的消息)。
    另外:我的系统程序是Unix 下C编写的。

|
1。优化数据库的处理,提高处理速度(这是最重要的一点,否则怎么也解决不了)
2。增加服务进程数目(由5个增加到另外一个数量级别),这样同时提交给数据库操作的服务就多了,消息队列阻塞的情况就少些

不过总的来说,一般都是对数据库的操作进行优化,这才是问题的症结所在

|
消息队列可以采用双向的方式

|
1、优化数据库处理速度,减少多表查询
2、数据库分库,读写分开,甚至分布到不同机器
3、更换更快的机器

    
 
 
 
本站(WWW.)旨在分享和传播互联网科技相关的资讯和技术,将尽最大努力为读者提供更好的信息聚合和浏览方式。
本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。












  • 相关文章推荐
  • 请教一个关于linux下的消息机制的问题
  • 如何通过其他网站发送短消息(比如新浪)?JSP页面提交,高分请教!!
  • 关于线程,事件,消息!!!新手请教!
  • 请教,请教,这个问题是为什么????
  • 请教本地硬盘安装问题请教本地硬盘安装问题
  • ■请教■请教redhat最基本的问题!
  • 请教一个 shell 问题,我用下面这个 shell 语句总是失败,请教
  • 高分请教,各位大侠,请教一个问题,理论高手请进??谢谢
  • 请教Linux下pgadmin3-1.0.2的编译和安装!!高分请教!
  • 各位大虾,请教装了REDHAT9操作系统后,启动时无法引导到LINUX,请教该如何解决啊
  • 请教,请教,,,一定要看!!一定要看!!
  • 请教高手,小弟打印width=1500,height=600(A3纸)的Applet,在预览中是该区域是黑的,打印出来也是黑的,请教高手解决一下
  • :请教高手,小弟打印width=1500,height=600(A3纸)的Applet,在预览中是该区域是黑的,打印出来也是黑的,请教高手解决一下
  • 请教象我这样的硬盘应如何安装Linux,我昨天试装了,但有问题。(老问题了,也看了前面的帖子,但还是来请教,请多指教)
  • 请教这种循环的执行过程
  • 请教两个redhat9问题
  • 请教如何在指定目录下查找包含指定文字的文件
  • 请教局域网中如何通过ip地址得到主机名
  • 请教象我这样的硬盘应如何安装Linux,我昨天试装了,但有问题。(老问题了,也看了前面的帖子,但还是来请教,请多指教) iis7站长之家
  • 请教linux 下的adsl拨号问题.
  • 请教,如何用虚拟订机安装liux
  • 【请教】LINUX 下SNMP的MIB开发
  • 请教一个opengl的问题


  • 站内导航:


    特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

    ©2012-2021,,E-mail:www_#163.com(请将#改为@)

    浙ICP备11055608号-3