0

我需要在旧应用程序中将状态管理从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 年前开发的现有应用程序。

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

4

1 回答 1

0

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

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

注意:写入 db 和检索它的成本很高。

这可能不是完美的解决方案。但这可以被认为是一种高成本的解决方法。

于 2020-10-05T03:42:08.870 回答