我现在要实现一个以WPF作为客户端,WCF作为服务端连接数据库并查询得到DataSet返回客户端的功能。
但是由于数据库有访问数量的限制,如果访问人数过多可能会出现连接失败的情况,所以不能直接用请求-响应模式来做。
本来我是打算把所有的数据库查询语句放在MSMQ里面,然后服务端读取进行查询然后返回,但是netMsmqBinding只支持单程传输不能双工,所以现在不知道该怎么把结果反馈回来。
请各位前辈提提意见,是否我们的设计思路有误不需要用消息队列?还是有什么其他的解决方案?
WCF连接数据库方式的疑问
- 写回答
- 好问题 0 提建议
- 追加酬金
- 关注问题
- 邀请回答
-
4条回答 默认 最新
- hxycsdn9159 2018-08-22 06:47关注
你使用了WCF来通讯又怎么使用消息队列呢?首先要明确一个问题,你所说的“访问人数过多”到底有多多?数百个还是上万级别还是更高的级别?如果只是数百个级别的你只要在服务端使用一个队列来缓存并发的请求,简单的.net框架自带的Queue以及线程安全的Concurrent这两个数据结构就能够满足你的需求。如果你所谓的所是上万级别或者更多的你可以使用消息队列来通讯,那就根本用不到WCF了,如果消息队列只支持单工通讯模式那么你可以给每个报文做标记,只要保证你发送的一次请求能找到对应的返回就可以了
本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 无用评论 打赏 举报