Google OpenId:找不到OpenID端点(间歇性)

时间:2012-04-08 11:07:14

标签: asp.net openid dotnetopenauth google-openid

通常使用谷歌OpenId工作正常,每天数千次,然后它会间歇性地出错并超时一小时左右(有些请求会验证,但不是全部)。重复验证最终会起作用。

错误消息是:

Event code: 200000 
Event message: No OpenID endpoint found. : https://www.google.com/accounts/o8/id 

Sequence contains no elements

添加log4net产量:

DotNetOpenAuth.Yadis:
Error while performing discovery on: "https://www.google.com/accounts/o8/id": 
DotNetOpenAuth.Messaging.ProtocolException:
 Error occurred while sending a direct message or getting the response. 
 ---> System.Net.WebException: The operation has timed out     
  at System.Net.HttpWebRequest.GetResponse()    
  at DotNetOpenAuth.Messaging.StandardWebRequestHandler.GetResponse
     (HttpWebRequest request, DirectWebRequestOptions options) 
     in  c:\...\Dot...Core\Messaging\StandardWebRequestHandler.cs:line 127    
 --- End of inner exception stack trace ---     
  at DotNetOpenAuth.Messaging.StandardWebRequestHandler.GetResponse
     (HttpWebRequest request, DirectWebRequestOptions options) 
     in c:\...\Dot...Core\Messaging\StandardWebRequestHandler.cs:line 175
  at DotNetOpenAuth.Messaging.UntrustedWebRequestHandler.GetResponse
     (HttpWebRequest request, DirectWebRequestOptions options)
     in c:\...\Dot...Core\Messaging\UntrustedWebRequestHandler.cs:line 250
  at DotNetOpenAuth.Yadis.Yadis.Request
     (IDirectWebRequestHandler requestHandler,
       Uri uri, Boolean requireSsl, String[] acceptTypes) 
     in c:\...\Dot...OpenId\Yadis\Yadis.cs:line 172
  at DotNetOpenAuth.Yadis.Yadis.Discover
     (IDirectWebRequestHandler requestHandler, UriIdentifier uri, Boolean requireSsl)
     in c:\...\DotNetOpenAuth.OpenId\Yadis\Yadis.cs:line 63
  at DotNetOpenAuth.OpenId.UriDiscoveryService.Discover
     (Identifier identifier, IDirectWebRequestHandler requestHandler, 
           Boolean& abortDiscoveryChain) 
     in c:\...\DotNet...OpenId\OpenId\UriDiscoveryService.cs:line 51
  at DotNetOpenAuth.OpenId.IdentifierDiscoveryServices.Discover
     (Identifier identifier) 
     in c:\...\Dot...OpenId\OpenId\IdentifierDiscoveryServices.cs:line 58
  at DotNetOpenAuth.OpenId.RelyingParty.AuthenticationRequest.Create
     (Identifier userSuppliedIdentifier, OpenIdRelyingParty relyingParty,
       Realm realm, Uri returnToUrl, Boolean createNewAssociationsAsNeeded) 
     in ...OpenId.RelyingParty\OpenId\RelyingParty\AuthenticationRequest.cs:line 364

并且

DotNetOpenAuth.Http WebException: 
 Timeout from https://www.google.com/accounts/o8/id, no response available.

有什么想法吗?

2 个答案:

答案 0 :(得分:2)

听起来您需要修复网络延迟。谷歌似乎不太可能成为这里的瓶颈。

您可能还希望增加结束时的HTTP超时以降低故障率。提供了完整的选项集here。特别是你可能正在寻找:

<untrustedWebRequest
            timeout="00:00:10"
            readWriteTimeout="00:00:01.500" />

查看配置链接以查看其中的上下文。

答案 1 :(得分:2)

我们最近遇到了同样的问题。阅读了几个不同的场景并完成了跟踪步骤后我终于得出结论,正如我在其他地方看到的那样,这个问题可能是由DNS服务器问题引起的。在我们的案例中,我们有一个生产服务器已经使用超过18个月,并且刚刚开始遇到与上面提到的相同的问题,但它在这一台服务器上非常一致。另一个网络上的另一台服务器和我们的开发计算机没有任何问题。

长话短说我将生产服务器的主DNS更改为Google的公共DNS,8.8.8.8,它立即开始工作。我在此之前手动刷新了生产服务器上的DNS缓存(没有正面结果),因此它让我相信DNS服务器(由我们的托管中心提供)有一个错误的缓存条目,最终导致问题。

希望这可以帮助遇到这种情况的其他人。