C# Global.asax.cs 定時任務


定時執行更新Redis緩存操作

protected void Application_Start(object sender, EventArgs e)
{
    Timer timer = new Timer();
    timer.Enabled = true;
    timer.Interval = 3600000; //執行間隔時間,單位為毫秒; 這里實際間隔為1小時  
    timer.Start();
    timer.Elapsed += new System.Timers.ElapsedEventHandler(OrgCacheInterval); 
}

/// <summary>
/// 定時檢測組織機構緩存是否需要更新
/// </summary>
/// <param name="source"></param>
/// <param name="e"></param>
public void OrgCacheInterval(object source, ElapsedEventArgs e)
{ 
    SystemService ser = new SystemService();
    ser.OrgCacheInterval();
}
/// <summary>
/// 組織機構緩存定時更新
/// </summary>
public void OrgCacheInterval()
{
    //不存在組織機構緩存或者時間戳時,更新
    if (!RedisCacheHelper.Exists("OrgList") || !RedisCacheHelper.Exists("OrgList:Time"))
    {
        UpdateAllOrgCache();
    }
    //存在時間戳時判斷時間是否一致,不一致時更新
    else
    {
        //緩存時間戳
        string cacheTime = RedisCacheHelper.Get<string>("OrgList:Time");
        //數據庫更新緩存時間
        string modifyTime = OrgDb.GetKeyLastModifyTime("OrgList", "");
        //時間戳標記不一致時更新
        if (cacheTime != modifyTime)
        {
            UpdateAllOrgCache();
        }
    }
}
/// <summary>
/// 獲取鍵值更新時間
/// </summary>
/// <param name="db_key"></param>
/// <param name="lang_type"></param>
/// <returns></returns>
public string GetKeyLastModifyTime(string db_key, string lang_type)
{
    string time = string.Empty;
    try
    {
        string sql = string.Format(@"select * from sys_dbcache_time t where 1=1 and t.db_key='{0}' ", db_key);
        if (!string.IsNullOrEmpty(lang_type))
        {
            sql += string.Format(@" and t.lang_type='{0}' ", lang_type);
        }
        DataTable dt = OdpOracleHelper.Query(sql).Tables[0];
        if (dt != null && dt.Rows.Count > 0)
        {
            time = Convert.ToDateTime(dt.Rows[0]["op_modify_time"]).ToString("yyyy-MM-dd HH:mm:ss");
        }
        else
        {
            string _time = DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss");
            string insertSql = string.Format(@"insert into sys_dbcache_time(db_key,lang_type,op_modify_time) 
                            values('{0}','{1}',to_date('{2}','yyyy-MM-dd HH24:MI:SS'))
", db_key, lang_type, _time); OdpOracleHelper.ExecuteSql(insertSql); time = _time; } } catch (Exception ex) { throw ex; } return time; }

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM