我们想在我们的应用程序和服务之间共享 ASP.NET session 状态。我们选择了 Elasticache/redis 来实现这一点。一切顺利,但我们遇到了僵局。
这是死锁序列:
RedisSessionStateProvider,在几毫秒内成功获取 SessionHttpWebRequest,并附加了 ASP.NET_SessionId cookieRedisSessionStateProvider,它尝试从同一个 Redis 实例中获取 Session,并在约 2 分钟后超时大概 App 1 的 RedisSessionStateProvider 在包含 session 的缓存项上持有(写?)锁。正如您从我的说法中可以看出的那样,我不是 Redis 专家...
AFAICT Elasticache 无法让您了解此类情况,只能提供性能图表。而且 RedisSessionStateProvider 是闭源的,所以我不能在那里闲逛。
我还尝试让 RedisSessionStateProvider 记录(通过 loggingClassName 参数)但是 App 1 或 App 2 没有写入任何内容(我的 Log() 方法被调用了)。
为了证明这是 RedisSessionStateProvider 死锁(而不是我们自己的代码死锁),我将 App 1 切换回使用 InProc session ,一切运行正常。
有人有什么建议吗?顺便说一句,我们的 session 数据在所有意图和目的上都是不可变的,因此实际上没有必要将其锁定。
非常感谢, 皮特
编辑:请求的 sessionState 配置。请注意,较大的 operationTimeoutInMilliseconds 值是为了让我们在调试应用程序时不会出现异常。这将在生产中更改为 ~ 5000。
<sessionState mode="Custom" customProvider="RedisSessionProvider">
<providers>
<add name="RedisSessionProvider"
type="Microsoft.Web.Redis.RedisSessionStateProvider"
host = "ec2-184-73-3-249.compute-1.amazonaws.com"
port = "6379"
ssl = "false"
throwOnError = "true"
retryTimeoutInMilliseconds = "2000"
applicationName = "PE"
connectionTimeoutInMilliseconds = "2000"
operationTimeoutInMilliseconds = "1800000"
</providers>
</sessionState>
最佳答案
This is not answer but it is not fitting in comment section.
在页面 asp.net 页面执行生命周期的开始,它调用 GetItemExclusive,它从存储(在本例中为 redis)获取 session 并锁定该 session ,以便其他并行请求无法在此请求工作时修改 session 。此锁定超时等同于您可以使用 web.config 设置的请求超时,如下所示。
<configuration>
<system.web>
<httpRuntime executionTimeout="10"/>
</system.web>
</configuration>
现在,页面执行并根据天气情况在 session 中修改或未修改任何内容,它调用 SetAndReleaseItemExclusive 或 ReleaseItemExclusive 来释放锁定。如果此请求由于某种原因失败,它将根据 retryTimeoutInMilliseconds 值重试。如果 retryTimeoutInMilliseconds 非常小于或等于 operationTimeoutInMilliseconds 那么它可能根本不会重试。如果 SetAndReleaseItemExclusive 或 ReleaseItemExclusive 未成功完成,那么基本上您的 session 将被锁定以完成您在上面设置的“executionTimeout”时间(以秒为单位)。所有其他请求都将被阻止,并且在锁定时将无法访问该 session 。锁到期后会自动释放。
使用 web.config 属性 loggingClassName 和 loggingMethodName 来配置日志记录。当您升级到上述包时,您可以在 web.config 注释中找到更多详细信息。您基本上可以提供一个返回 TextWriter 的公共(public)静态方法。 session 状态提供程序和 StackExchange.Redis.StrongName 都将使用此 TextWriter 对象来记录详细信息。
这将帮助我们获得有关问题的更多详细信息。请注意,启用日志记录会降低性能。
使用日志的例子:
namespace SSPWebAppLatest3
{
public static class Logger
{
public static TextWriter GetLogger()
{
return File.CreateText("C:\\Logger.txt");
}
}
}
网络配置:
<add name="MySessionStateStore" type="Microsoft.Web.Redis.RedisSessionStateProvider" host="127.0.0.1" accessKey="" ssl="false"
loggingClassName="Logger, SSPWebAppLatest3, Version=1.0.0.0, Culture=neutral ……."
loggingMethodName="GetLogger"/>
请给我一个可重现的测试应用程序,我用它来进一步调试它。您也可以这样做,因为 session 状态和输出缓存提供程序代码现在是开源的。 ( https://github.com/Azure/aspnet-redis-providers )
关于asp.net - RedisSessionStateProvider 弹性缓存死锁,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/30082609/
作为我的Rails应用程序的一部分,我编写了一个小导入程序,它从我们的LDAP系统中吸取数据并将其塞入一个用户表中。不幸的是,与LDAP相关的代码在遍历我们的32K用户时泄漏了大量内存,我一直无法弄清楚如何解决这个问题。这个问题似乎在某种程度上与LDAP库有关,因为当我删除对LDAP内容的调用时,内存使用情况会很好地稳定下来。此外,不断增加的对象是Net::BER::BerIdentifiedString和Net::BER::BerIdentifiedArray,它们都是LDAP库的一部分。当我运行导入时,内存使用量最终达到超过1GB的峰值。如果问题存在,我需要找到一些方法来更正我的代
是的,我知道最好使用webmock,但我想知道如何在RSpec中模拟此方法:defmethod_to_testurl=URI.parseurireq=Net::HTTP::Post.newurl.pathres=Net::HTTP.start(url.host,url.port)do|http|http.requestreq,foo:1endresend这是RSpec:let(:uri){'http://example.com'}specify'HTTPcall'dohttp=mock:httpNet::HTTP.stub!(:start).and_yieldhttphttp.shou
我试过重新启动apache,缓存的页面仍然出现,所以一定有一个文件夹在某个地方。我没有“公共(public)/缓存”,那么我还应该查看哪些其他地方?是否有一个URL标志也可以触发此效果? 最佳答案 您需要触摸一个文件才能清除phusion,例如:touch/webapps/mycook/tmp/restart.txt参见docs 关于ruby-如何在Ubuntu中清除RubyPhusionPassenger的缓存?,我们在StackOverflow上找到一个类似的问题:
尝试在我的RoR应用程序中实现计数器缓存列时出现错误Unknownkey(s):counter_cache。我在这个问题中实现了模型关联:Modelassociationquestion这是我的迁移:classAddVideoVotesCountToVideos0Video.reset_column_informationVideo.find(:all).eachdo|p|p.update_attributes:videos_votes_count,p.video_votes.lengthendenddefself.downremove_column:videos,:video_vot
我目前正在使用以下方法获取页面的源代码:Net::HTTP.get(URI.parse(page.url))我还想获取HTTP状态,而无需发出第二个请求。有没有办法用另一种方法做到这一点?我一直在查看文档,但似乎找不到我要找的东西。 最佳答案 在我看来,除非您需要一些真正的低级访问或控制,否则最好使用Ruby的内置Open::URI模块:require'open-uri'io=open('http://www.example.org/')#=>#body=io.read[0,50]#=>"["200","OK"]io.base_ur
1.错误信息:Errorresponsefromdaemon:Gethttps://registry-1.docker.io/v2/:net/http:requestcanceledwhilewaitingforconnection(Client.Timeoutexceededwhileawaitingheaders)或者:Errorresponsefromdaemon:Gethttps://registry-1.docker.io/v2/:net/http:TLShandshaketimeout2.报错原因:docker使用的镜像网址默认为国外,下载容易超时,需要修改成国内镜像地址(首先阿里
我很好奇.NET将如何影响Python和Ruby应用程序。用IronPython/IronRuby编写的应用程序是否会非常特定于.NET环境,以至于它们实际上将变得特定于平台?如果他们不使用任何.NET功能,那么IronPython/IronRuby相对于非.NET同类产品的优势是什么? 最佳答案 我不能说任何关于IronRuby的东西,但是大多数Python实现(如IronPython、Jython和PyPy)都试图尽可能忠实于CPython实现。不过,IronPython正在迅速成为这方面的佼佼者之一,并且在PlanetPyth
require'mechanize'agent=Mechanize.newlogin=agent.get('http://www.schoolnet.ch/DE/HomeDE.htm')agent.clicklogin.link_withtext:/Login/然后我得到Mechanize::UnsupportedSchemeError。 最佳答案 Mechanize不支持javascript但您可以将搜索字段添加到表单并为其分配搜索词并使用mechanize提交表单form=page.forms.firstform.add_fie
我正在尝试解析网页,但有时会收到404错误。这是我用来获取网页的代码:result=Net::HTTP::getURI.parse(URI.escape(url))如何测试result是否为404错误代码? 最佳答案 像这样重写你的代码:uri=URI.parse(url)result=Net::HTTP.start(uri.host,uri.port){|http|http.get(uri.path)}putsresult.codeputsresult.body这将打印状态码和正文。
是否有适用于Ruby语言的.NETFramework编译器?我听说过DLR(动态语言运行时),这是否将使Ruby能够用于.NET开发? 最佳答案 IronRuby是Microsoft支持的项目,建立在动态语言运行时之上。 关于.net-是否有Ruby.NET编译器?,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/199638/