public void SaveLastTraceAlertStatus(Guid vehicleCode, LastTraceAlertStatus status) { string key = CONST_KEY_LAST_TRACE_STATUS + vehicleCode.ToString(); if (status == null) { status = new LastTraceAlertStatus(); } this.CachedService.Add(key, status, DateTime.Now.AddDays(1)); }
protected void Alert(AlarmHandleContext context, EGPSCurrentInfo current, EnumAlertState state, ETraceAlertSetting alertSetting, LastTracePointAlertStatus lastCachingPointStatus) { if (alertSetting.EnableSMS || alertSetting.Enable) { // 生成报警实例,并将报警存入数据库,最新的报警状态放入缓存中 ETraceAlertReport alertReport = this.CreateAlertReport(context, current, state, alertSetting); DateTime dt1 = DateTime.Now; GPSServiceFacade.AlertService.Add<ETraceAlertReport>(alertReport); Logger.Info(string.Format("Static_AlertReportService.Add<ETraceAlertReport>(alertReport)共花销{0}毫秒", (DateTime.Now - dt1).TotalMilliseconds)); lastCachingPointStatus.LastAlertTime = current.ReportTime; AlarmLastStatusService.Singleton.SaveLastTracePointAlertStatus(current, alertSetting, lastCachingPointStatus); LastTraceAlertStatus lastCachingStatus = new LastTraceAlertStatus() { LastAlertTracePointId = alertSetting.TracePointID.ToString().ToLower(), LastAlertTime = current.ReportTime }; AlarmLastStatusService.Singleton.SaveLastTraceAlertStatus(current.VehicleCode.Value, lastCachingStatus); if (alertSetting.EnableSMS && this.IsInMobileReceiveTime(alertReport)) { this.SendSMS(context, alertReport); } if (alertSetting.Enable && this.IsInUserReceiveTime(alertReport)) { this.SendWebSiteSMS(context, alertReport); } } }
public LastTraceAlertStatus GetLastTraceAlertStatus(EGPSCurrentInfo current, ETraceAlertSetting alertSetting) { if (!current.VehicleCode.HasValue) return null; string key = CONST_KEY_LAST_TRACE_STATUS + current.VehicleCode.Value.ToString(); var result = this.CachedService.Get(key) as LastTraceAlertStatus; if (result == null) { // 找不到则从数据库查找最后一条报表记录 DateTime dt1 = DateTime.Now; var lastReport = GPSServiceFacade.Report.Trace.GetAllLastReport(alertSetting.VehicleCode); Logger.Info("从数据库查找最后一条Trace报表记录", "开销时间(毫秒)", (DateTime.Now - dt1).TotalMilliseconds, "Vehicle Code", current.VehicleCode.Value, "TracePoint", alertSetting.TracePoint.RecordID); result = new LastTraceAlertStatus(); if (lastReport != null) { result.LastAlertTracePointId = lastReport.TracePointID.ToString().ToLower(); // alertSetting.RecordID.ToString(); result.LastAlertTime = lastReport.GPSReportTime; } lastReport = null; this.SaveLastTraceAlertStatus(current.VehicleCode.Value, result); } return result; }