如何解决如何将会话变量与多线程一起使用,其中会话存储在状态服务器Web Garden中
我需要在旧应用程序中将状态管理从 inProc更改为StateServer 。
代码如下。
protected void btnTransaction_Click(object sender,EventArgs e)
{
timerTrans.Enabled = true;
timerTrans.Interval = 200;
Thread thread = new Thread(new ParameterizedThreadStart(DoAllWork));
thread.Start(dbConnectionString);
}
public void DoAllWork(object connectionString)
{
dbaccess dba = new dbaccess(connectionString.ToString());
Session["NextTransactionId"] = dba.getNewTransactionId();
//Other work
foreach(transaction t in transactions)
{
ShowTrasnactionStatus("Processing transaction "+t.id);
}
//Other work
Session["FinalStatus"] = "All Transactions Completed";
Session["TransactionStatus"] = "Done";
}
private void ShowTrasnactionStatus(string statusMsg)
{
Session["TransactionStatus"] = statusMsg;
}
protected void timerTrans_Tick(object sender,EventArgs e)
{
lblStatus.Text = Session["TransactionStatus"].ToString();
if (Session["TransactionStatus"].ToString() == "Done")
{
//Final Stage of Transaction Processing
lblStatus.Text = "Getting final status ...";
billEndTime = DateTime.Now;
ShowFinalStatus();
timerBilling.Enabled = false;
}
}
启用网络花园后,无法按预期使用会话变量来更新状态。
- 我尝试使用类变量而不是会话变量。
- 使用缓存代替会话。
他们都不为我工作。
注意:此代码来自至少8年前开发的现有应用程序。
我只想在网络花园中运行它而不会破坏功能。
解决方法
我创建了一个数据库表,并将值存储在那里,而不是会话变量。在那里,我使用了GUID + KEY来标识数据库中的正确值。
我创建了一种方法,可以在过程完成时删除db中的记录,这样可以减少数据库中的搜索成本。
注意:写入db并检索它会花费相当大的费用。
这可能不是完美的解决方案。但这可以被认为是高成本的解决方法。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。