我试图从远程队列中读取消息(大约1Mb大小)。方法queue.get(theMessage,gmo)大约需要3-6秒才能完成.是否有任何提高性能的选项(如缓冲区大小)?
qMgr = new MQQueueManager(qManager);
int openOptions = CMQC.MQOO_FAIL_IF_QUIESCING | CMQC.MQOO_INPUT_SHARED | CMQC.MQOO_BROWSE;
MQQueue queue = qMgr.accessQueue(qQueue, openOptions);
MQMessage theMessage = new MQMessage();
//theMessage.messageFlags = CMQC.MQMF_SEGMENTATION_ALLOWED;
MQGetMessageOptions gmo = new MQGetMessageOptions();
gmo.options = CMQC.MQGMO_LOGICAL_ORDER | CMQC.MQGMO_ALL_SEGMENTS_AVAILABLE | CMQC.MQGMO_COMPLETE_MSG | CMQC.MQGMO_WAIT | CMQC.MQGMO_BROWSE_FIRST;
gmo.matchOptions = CMQC.MQMO_NONE;
gmo.waitInterval = 5000;
queue.get(theMessage, gmo);
发布于 2017-10-21 12:19:34
没有具体的数据很难给出建议
MQGMO_LOGICAL_ORDER能显着地影响性能-我会测试是否去除它可以提高性能。
MQGMO_ALL_SEGMENTS_AVAILABLE似乎无关紧要,因为MQMF_SEGMENTATION_ALLOWED被注释掉了--但是如果使用它,也会影响性能
还尝试在服务器和\或客户端上运行跟踪,以便更深入地了解所用的时间。
发布于 2017-10-23 16:05:41
Ping到远程服务器大约100 to。也许我需要用多个线程重写我的应用程序?
那就解释了很多事。点击服务器的时间应该小于5ms,接近1ms。如果需要100毫秒,那么你的网络就慢了,真的慢了。
除了压缩之外,再多的编程都解决不了你的问题。即使那样压缩也不是一颗神奇的子弹。
到你的网络用户那里,问他们2台服务器之间的网络速度是多少。如果他们说它小于1Gb/s,那么指出这是21世纪,您的应用程序至少需要1Gb/s。
https://stackoverflow.com/questions/46863068
复制相似问题