通常使用谷歌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.
有什么想法吗?
答案 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服务器(由我们的托管中心提供)有一个错误的缓存条目,最终导致问题。
希望这可以帮助遇到这种情况的其他人。