我有一个本地的私人队列。我还在一个MVC应用程序中有一个WCF服务,它使用msmqIntegrationBinding侦听队列。问题是,当消息排队时,服务契约从未被调用过,但是消息在那一刻就被拒绝了。消息不在毒队列中。下面是我声明绑定到队列的config-部分:
<services>
<service name="SkruvInfo.Web.Service.QueueMessageReceiver">
<endpoint address="msmq.formatname:DIRECT=OS:LEIA\private$\screwinfo_autotests_messagequeue"
binding="msmqIntegrationBinding"
bindingConfiguration="MsmqBinding"
contract="SkruvInfo.Web.Service.IQueueMessageReceiver" />
</service>
</services>这是合同:
[ServiceContract(Namespace = "http://localhost/SkruvWeb/Service")]
public interface IQueueMessageReceiver
{
[OperationContract(IsOneWay = true, Action = "*")]
void PutScrewInfoMessage(MsmqMessage<string> msg);
}以下是服务中的方法:
[OperationBehavior(TransactionScopeRequired = true, TransactionAutoComplete = true)]
public void PutScrewInfoMessage(System.ServiceModel.MsmqIntegration.MsmqMessage<string> msg)
{
log4net.Config.XmlConfigurator.Configure();
var log = LogManager.GetLogger(System.Reflection.MethodBase.GetCurrentMethod().DeclaringType);
try
{
log.Debug("Message from queue: " + msg.Body.ToString(CultureInfo.InvariantCulture));
var xDoc = new XmlDocument();
xDoc.LoadXml(msg.Body);
CacheScrewInfoModelFromScrewInfoXmlDoc(xDoc);
}
catch (Exception e)
{
log.Error("Error parsing message from queue",e);
EventLog.WriteEntry("Application","Message error for screws");
}
}对于为什么消息拒绝而不调用服务有任何建议吗?
发布于 2012-07-25 09:16:20
尝试使用ServiceKnownType属性修改您的服务合同:
[ServiceContract(Namespace = "http://localhost/SkruvWeb/Service")]
[ServiceKnownType(typeof(String))]
public interface IQueueMessageReceiver
{
[OperationContract(IsOneWay = true, Action = "*")]
void PutScrewInfoMessage(MsmqMessage<string> msg);
}更新
如果您正在使用MsmqIntegrationBinding,那么我假设您的队列客户端是一个像VB6客户端一样的遗留应用程序?如果是,则需要在服务绑定配置中指定序列化格式。例如:
<msmqIntegrationBinding>
<binding name="MsmqBinding" serializationFormat="ActiveX">
<security mode="None" />
</binding>
</msmqIntegrationBinding>允许的值是文档化的这里。
发布于 2013-06-24 12:27:05
在我的经验中,这种行为是由序列化失败或消息大(64 In是默认的最大消息大小)引起的。这会导致WCF无声崩溃(是的,我也不理解这种设计选择),但仍然将消息从队列中删除。
只需启用跟踪,您将很快在WCF中看到导致这种情况的异常。
将其添加到您的web.config (我在下面)以进行粗略的跟踪设置。确保AppPool用户对日志记录文件夹有写访问权。
<system.diagnostics>
<trace autoflush="true" indentsize="4" />
<sources>
<source name="System.ServiceModel" switchValue="Warning">
<listeners>
<add name="textLogger" />
</listeners>
</source>
</sources>
<sharedListeners>
<add name="textLogger"
type="System.Diagnostics.TextWriterTraceListener"
initializeData="C:\logs\webbackend_wcf_log.txt" />
</system.diagnostics>https://stackoverflow.com/questions/11645131
复制相似问题