这是我的场景,我有一个夜间批处理作业,将记录插入到第 3 方系统/数据库中。所有这些导入调用都通过我创建的代理服务进行路由,主要是因为我的夜间批处理作业由于防火墙而没有直接连接到第 3 方服务。
因此,我在每次作业运行时导入 10000 条记录。我建立了与代理服务的连接,其中代理服务建立了与第 3 方 Web 服务的静态引用/连接。现在(别笑),我在代理服务中为每个记录建立连接。这意味着,我的代理服务中有 10000 个“OpenConnection”和“CloseConnection”方法调用来完成这 1 个作业的运行。我每天两次运行这项工作。
我的问题是,如果我在第一次 Web 服务调用时建立连接,但在第一次调用时不关闭连接,后续 Web 服务调用是否会重新使用现有连接(因为它是静态的)?或者它会使用 3rd 方服务重新创建另一个会话?
如果这确实有效(为后续调用保持连接打开),我如何在我的工作完成后关闭连接,以便我可以释放我的托管(或非托管)资源?我不想在我自己的 Web 服务中添加一个名为“CloseConnection”的方法......
除此之外,我们的服务器每晚都会自动进行 IIS 重置,如果那时连接仍然打开,它会正确处理我的连接吗?
抱歉,这里有很多问题,只是在寻找一种“最佳实践”方法来完成我加快这一过程的任务。
我将尝试给出一个代码示例,这是批处理作业代码:
ws.EstablishConnection();
for (int counter = 0; counter < 10000; counter++)
{
ws.ImportRecord(myRecords[counter]);
}
ws.Dispose();
网络服务代码:
[WebMethod]
public static void ImportRecord(MyRecord myRecord)
{
try
{
OpenConnection();
_3rdPartyWS.ImportRecord(myRecord);
}
catch (Exception)
{
throw;
}
finally
{
CloseConnection();
}
}