(我是 Windows 服务的新手)我有一个自动 Windows 服务,它从数据库表中获取一些记录,为每条记录调用一个 Web 服务方法,并将该方法的返回值和一些其他信息插入到表中。我的问题如下:
1-当我尝试手动启动服务时,我得到Error 1053 (the service did not respond to the start or control request in a timely fashion)
. 顺便说一句,尽管错误服务启动并执行它必须做的事情。
2-(我知道这是一个常见问题,但我更愿意再问一次)服务是自动的,但取决于数据库连接。当服务正在运行的系统正在重新启动时,我必须手动启动它。我添加了Thread.Sleep()
一行代码来避免这个问题。解决问题的真正方法是什么?
protected override void OnStart(string[] args)
{
checkRegistryForOracleNLS();
//Creating event log
plog = new System.Diagnostics.EventLog();
if (!System.Diagnostics.EventLog.SourceExists("Prov"))
{
System.Diagnostics.EventLog.CreateEventSource("Prov", "ProvLog");
}
plog.Source = "Prov";
plog.Log = "ProvLog";
plog.Clear();
Log("Service started at " + DateTime.Now.ToLongTimeString(), System.Diagnostics.EventLogEntryType.Information);
class_ora_tran.int_class_ora_tran();
DataTable dt;
Thread.Sleep(300000);
while (true)
{
Con2DB();
if (class_ora_tran.dbConnected())
{
RemoveOldRecords();
dt = FetchRec();
if (dt != null)
{
if (dt.Rows.Count > BLKSize)
Bulk(dt);
else
Single(dt);
}
}
}
}
3-虽然我写了OnStop()
方法,但服务运行时没有停止功能,我想停止它。我还应该提到我的服务始终处于启动模式,并且永远不会更改为已启动。
Protected void OnStop(string[] args)
{
class_ora_tran.Disconnect();
Log("Service stoped at " + DateTime.Now.ToLongTimeString(), System.Diagnostics.EventLogEntryType.Information);
plog.Close();
}
4- 时不时地,虽然状态正在启动,但我的服务会停止做它必须做的事情,并且不会从表中获取记录。它之前发生过两次,不幸的是我忘记检查事件查看器以查看是否发生了一些错误。有人知道是什么原因吗?和我上面提到的问题有关系吗?
5-每次我想卸载服务我都必须运行卸载命令两次!有什么帮助吗?
编辑: 记录被有争议地插入到表中,每当有新记录输入到表中时,都应该执行调用 Web 服务等的过程。我认为需要一个 While(true) 循环。有什么建议更换这部分吗?