如何在会话存储在状态服务器(Web Garden)中的情况下将会话变量与多线程一起使用

How to use Session variables with multi threading where session is stored in state server (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;
    }
}

启用网络花园后,使用会话变量更新状态无法按预期工作。

None 其中对我有用。

注意:此代码来自至少 8 年前开发的现有应用程序。

我只想 运行 在不破坏功能的情况下在网络花园中使用它。

我创建了一个数据库 table 并将值存储在那里而不是会话变量。在那里我使用 GUID+KEY 来识别数据库中的正确值。

我创建了一个方法来在进程完成时删除数据库中的记录,这样可以减少数据库中的搜索成本。

注意:写入数据库和检索它的成本相当高。

这可能不是完美的解决方案。但这可以被视为 high-cost 解决方法。