コードの実行に問題がありますが、MSMQWCFサービスを作成しようとしています。サービスのインスタンスを作成しようとすると失敗します。MSMQをインストールしましたが、「servicemodelsamples」というプライベートが作成されていることを確認できます。
サービスを実行しているときに、次のエラーが発生しました。
サービスを開始できません。System.InvalidOperationException:キューを開くときにエラーが発生しました。MSMQがインストールされ、実行されていること、キューが存在し、読み取り元の適切な許可があることを確認してください。内部例外には、追加情報が含まれている場合があります。---> System.ServiceModel.MsmqException:キューを開いているときにエラーが発生しました:認識されないエラー-1072824283(0xc00e0025)。メッセージはキューから送受信できません。MSMQがインストールされ、実行されていることを確認します。また、必要なアクセスモードと許可でキューを開くことができることを確認してください。
制御サービスのインターフェースと実装。
[ServiceContract()]
public interface IControlService
{
[OperationContract(IsOneWay = true)]
void PricingAlert(int eventid, int marketid);
}
public class ControlService : IControlService
{
public ControlService()
{ }
public void PricingAlert(int eventid, int marketid)
{
Console.WriteLine("Acknowledged");
}
}
Service1.csサービス開始コード。
protected override void OnStart(string[] args)
{
Thread.Sleep(10000);
string queueName = Settings.Default["queueName"].ToString();
if (!MessageQueue.Exists(queueName))
MessageQueue.Create(queueName, true);
if (myServiceHost != null)
{
myServiceHost.Close();
}
myServiceHost = new ServiceHost(typeof(ControlService));
myServiceHost.Open(); // *** Code Fails Here
}
アプリケーション構成;
<?xml version="1.0" encoding="utf-8" ?>
<configuration>
<configSections>
<sectionGroup name="applicationSettings" type="System.Configuration.ApplicationSettingsGroup, System, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089" >
<section name="ControlService.Properties.Settings" type="System.Configuration.ClientSettingsSection, System, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089" requirePermission="false" />
</sectionGroup>
</configSections>
<system.web>
<compilation debug="true" />
</system.web>
<system.serviceModel>
<bindings>
<netMsmqBinding>
<binding name="netMsmqBindingConfig">
<security mode="None">
</security>
</binding>
</netMsmqBinding>
</bindings>
<services>
<service name="TheControlService.ControlService" behaviorConfiguration="MSMQBindingBehaviour">
<endpoint address="net.msmq://172.26.2.11/private/ServiceModelSamples"
binding="netMsmqBinding" bindingConfiguration="netMsmqBindingConfig"
contract="TheControlService.IControlService" />
</service>
</services>
<behaviors>
<serviceBehaviors>
<behavior name="MSMQBindingBehaviour">
<serviceMetadata httpGetEnabled="true" httpGetUrl="http://localhost:8000/Hello/" />
</behavior>
</serviceBehaviors>
</behaviors>
</system.serviceModel>
<system.diagnostics>
<trace autoflush="true" />
<sources>
<source name="System.ServiceModel"
switchValue="Information, ActivityTracing"
propagateActivity="true">
<listeners>
<add name="sdt"
type="System.Diagnostics.XmlWriterTraceListener"
initializeData="controlserviceerrors.svclog" />
</listeners>
</source>
</sources>
</system.diagnostics>
<applicationSettings>
<ControlService.Properties.Settings>
<setting name="queueName" serializeAs="String">
<value>.\private$\ServiceModelSamples</value>
</setting>
</ControlService.Properties.Settings>
</applicationSettings>
</configuration>
何か案は?winformsアプリケーションである例に基づいてコードを作成したためかもしれません。