2009-08-30 10 views
0

Whew! OK ...私はWcf/Linqのエラーを解決しました(そして、多くのことを学びました - 一連のブログ記事が次の弱点に続く)。今私は展開する必要があります。私たちはMosso/Rackspaceクラウド上で動作し、環境は部分的な信頼環境で動作します。Medium/Partial Trust(Mosso)のWcf - 奇妙な問題/設定エラー

単純にするために、私は何もしないWcfサービスにメソッドを追加しました。

public string Echo(string what) 
{ 
    return what; 
} 

私はそれをすべてを構築し、はい、私は明らかに危険なメソッドを公開する前にセキュリティを追加する必要があります...(関連セクションのみ)次のWeb.Configでテストサーバーにそれを出荷しますが、今の私jsutが実行して、匿名のものにしたい:)

<system.serviceModel> 
<bindings> 
    <basicHttpBinding> 
     <binding name="BasicAnonymous"> 
      <security mode="None"/>     
     </binding> 
    </basicHttpBinding> 
</bindings> 
<behaviors> 
    <serviceBehaviors> 
    <behavior name="FooBar.Backend.Web.Services.CoreDataWcfServiceBehavior"> 
    <serviceMetadata httpGetEnabled="true" /> 
    <serviceDebug includeExceptionDetailInFaults="true" /> 
    </behavior> 
    </serviceBehaviors> 
</behaviors> 
<services> 
    <service behaviorConfiguration="FooBar.Backend.Web.Services.CoreDataWcfServiceBehavior" 
    name="FooBar.Backend.Web.Services.CoreDataWcfService"> 
    <endpoint address="" binding="basicHttpBinding" bindingConfiguration="BasicAnonymous" contract="FooBar.Backend.Web.Services.ICoreDataWcfService" /> 
    <endpoint address="mex" binding="mexHttpBinding" contract="IMetadataExchange" /> 
    </service> 
</services> 
<serviceHostingEnvironment aspNetCompatibilityEnabled="true"> 
    <baseAddressPrefixFilters> 
     <add prefix="http://backend.FooBar.com"/> 
    </baseAddressPrefixFilters> 
</serviceHostingEnvironment> 
</system.serviceModel> 

だから、オフ私は、コンソールアプリケーションで私ができる最も簡単な方法でそれを呼び出すために行きます。私はサービス参照を追加し、それは正常に追加されます。それから私は...

using System; 
using System.Collections.Generic; 
using System.Linq; 
using System.Text; 

using CoreWcfHarness.CoreDataServiceReference; 

namespace CoreWcfHarness 
{ 
    class Program 
    { 
     static void Main(string[] args) 
     { 
      var context = new CoreDataWcfServiceClient(); 

      var echoval = context.Echo("Hello World!"); 
      Console.WriteLine(String.Format("{0}\n", echoval)); 
      Console.ReadKey(); 
     } 
    } 
} 

そしてblammo(私は簡潔にするために、非アクティブコードを取った)と呼んでいます。私は例外で殴られる。

System.ServiceModel.FaultException`1 was unhandled 
    Message="Request failed." 
    Source="mscorlib" 
    StackTrace: 
    Server stack trace: 
     at System.ServiceModel.Channels.ServiceChannel.ThrowIfFaultUnderstood(Message reply, MessageFault fault, String action, MessageVersion version, FaultConverter faultConverter) 
     at System.ServiceModel.Channels.ServiceChannel.HandleReply(ProxyOperationRuntime operation, ProxyRpc& rpc) 
     at System.ServiceModel.Channels.ServiceChannel.Call(String action, Boolean oneway, ProxyOperationRuntime operation, Object[] ins, Object[] outs, TimeSpan timeout) 
     at System.ServiceModel.Channels.ServiceChannelProxy.InvokeService(IMethodCallMessage methodCall, ProxyOperationRuntime operation) 
     at System.ServiceModel.Channels.ServiceChannelProxy.Invoke(IMessage message) 
    Exception rethrown at [0]: 
     at System.Runtime.Remoting.Proxies.RealProxy.HandleReturnMessage(IMessage reqMsg, IMessage retMsg) 
     at System.Runtime.Remoting.Proxies.RealProxy.PrivateInvoke(MessageData& msgData, Int32 type) 
     at CoreWcfHarness.CoreDataServiceReference.ICoreDataWcfService.Echo(String what) 
     at CoreWcfHarness.CoreDataServiceReference.CoreDataWcfServiceClient.Echo(String what) in C:\PathToProject\corewcfharness\service references\coredataservicereference\reference.cs:line 1890 
     at CoreWcfHarness.Program.Main(String[] args) in C:\PathToProject\CoreWcfHarness\Program.cs:line 42 
     at System.AppDomain._nExecuteAssembly(Assembly assembly, String[] args) 
     at System.Runtime.Hosting.ApplicationActivator.CreateInstance(ActivationContext activationContext, String[] activationCustomData) 
     at Microsoft.VisualStudio.HostingProcess.HostProc.RunUsersAssemblyDebugInZone() 
     at System.Threading.ExecutionContext.Run(ExecutionContext executionContext, ContextCallback callback, Object state) 
     at System.Threading.ThreadHelper.ThreadStart() 
    InnerException: 

これはほぼ同じくらい簡単です。中規模の信頼環境に精通しているか、スタックトレースがある人は誰ですか?

ありがとうございます!

答えて

1

「リクエストが失敗しました」とは数多くのものがあります。

リクエストがサーバーに届いていない可能性が最も高いようです。サーバーログを調べて、要求が正しい場所に送信されていることを確認する必要があります。

+0

確かに、それは正しい場所に到達していませんでした。信頼環境が私の​​コードベースを嫌っていました。私はADO.NETデータサービスにリファクタリングする必要がありました。 –