3

コードの実行に問題がありますが、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アプリケーションである例に基づいてコードを作成したためかもしれません。

4

1 に答える 1