【HAVENT原創】Firebase 定時任務遍歷刪除子節點

来源:http://www.cnblogs.com/HAVENT/archive/2017/06/27/7084373.html
-Advertisement-
Play Games

每周定時執行,遍歷 Firebase 資料庫,刪除過期的節點: ...


每周定時執行,遍歷 Firebase 資料庫,刪除過期的節點:

  1 var config = require('./config.json');
  2 
  3 var admin = require('firebase-admin');
  4 var schedule = require('node-schedule');
  5 
  6 var log4js = require('log4js');
  7 log4js.configure({ // configure to use all types in different files.
  8     appenders: [
  9         {   type: 'file',
 10             filename: config.firebase.log,
 11             category: 'service',
 12             maxLogSize: 20480000,
 13             backups: 10
 14         }
 15     ]
 16 });
 17 var logger = log4js.getLogger('service');
 18 
 19 var mysql = require('mysql');
 20 var pool = mysql.createPool({
 21     connectionLimit: 10,
 22     host: config.mysql.host,
 23     user: config.mysql.user,
 24     password: config.mysql.password,
 25     database: config.mysql.db
 26 });
 27 
 28 
 29 var defaultAppConfig = {
 30     credential: admin.credential.cert(config.firebase.cert),
 31     databaseURL: config.firebase.databaseURL
 32 };
 33 
 34 var defaultAppName = 'GoPeople-NodeJS-Admin';
 35 var defaultApp = admin.initializeApp(defaultAppConfig, defaultAppName);
 36 
 37 var isWorking = false;
 38 var hasMoreData = true;
 39 function init() {
 40     logger.info('People Post remove signatures service start.');
 41 
 42     // '0 0 0 * * 6' Saturday 00:00:00
 43     // '*/5 * * * *' per 5 min
 44     // '*/30 * * * * *' per 30 sec
 45     var weekTask = schedule.scheduleJob('11 34 11 * * 2', function () {
 46         logger.info('schedule week task start!');
 47 
 48         var j = schedule.scheduleJob('*/30 * * * * *', function(){
 49             startRemoveSignatures();
 50 
 51             if(!hasMoreData){
 52                 logger.info('schedule task finished!');
 53                 logger.info();
 54                 logger.info();
 55                 schedule.cancelJob(j);
 56             }
 57         });
 58     });
 59 }
 60 
 61 function startRemoveSignatures() {
 62     var expiredDataCount = 0;
 63 
 64     if(isWorking){
 65         logger.info('startRemoveSignatures: hold on ...');
 66         return;
 67     }else{
 68         isWorking = true;
 69         logger.info();
 70         logger.info('startRemoveSignatures: loading signatures data ...');
 71     }
 72 
 73     var signaturesRef = defaultApp.database().ref('signatures');
 74 
 75     //signaturesRef.orderByChild("isChecked").equalTo(true).limitToLast(300).once("value")
 76     signaturesRef.orderByChild("timestamp").limitToFirst(50).once("value")
 77         .then(function(snapshot) {
 78 
 79             snapshot.forEach(function(childSnapshot) {
 80                 var key = childSnapshot.key;
 81                 var childData = childSnapshot.val();
 82 
 83                 var now = new Date();
 84                 var date = new Date(childData.date);
 85                 var dayDiff = parseInt((now - date) / (1000 * 60 * 60 * 24)); // day diff
 86 
 87                 if(dayDiff > 7){
 88                     expiredDataCount++;
 89 
 90                     signaturesRef.child(key).remove(function(error) {
 91                         console.log(key);
 92                         console.log(dayDiff);
 93                         console.log(error ? ("Uh oh! " + error) : "Success!");
 94 
 95                         logger.info(key);
 96                         if(error){
 97                             logger.error(error);
 98                         }else{
 99                             logger.info("Success! [ " + dayDiff + ' day ]');
100                         }
101                     });
102                 }else{
103                     console.log(key);
104                     console.log(dayDiff);
105 
106                     logger.info(key);
107                     logger.info("Jump!");
108                 }
109             });
110 
111             isWorking = false;
112             logger.info('expiredDataCount: ' + expiredDataCount);
113 
114             if(expiredDataCount < 30){
115                 hasMoreData = false;
116             }
117         });
118 }
119 
120 init();

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • Dockerfile這個東西我們之前是介紹過,它方便,快捷,易用,而在vs2017中也對docker進行了支持,而生成docker image的方式就是有用Dockerfile為基礎的,在添加docker支持之後,vs會為我們在根目錄下生成一個Dockerfile的文件,我們可以通過docker客戶 ...
  • 課程基於真實的每日上億流量的大型電商網站中的商品詳情頁系統,作為項目實戰。詳細講解如何實現一個複雜的緩存系統架構,去直接支撐電商背景下的高併發與高性能的訪問,同時基於緩存架構本身所處的複雜分散式系統架構環境下,如何設計與實現一個高可用的分散式系統架構。 ...
  • 以下彙總三種行內元素轉為塊級元素的方法: (1)display (2)float (3)position(absolute和fixed) 少說多做,運行以下代碼看效果: 通過審查元素查看是否轉為塊級元素: ...
  • #前言因為在做美團外賣商家端的nw.js殼子項目,需要保證在殼子裡面使用localStorage的數據可以持久化保存。發現nw可以保存,即使刪除應用重寫打包也可以保存,所以解決了這個需求,但是還是需要知道具體儲存在哪裡,否則不清楚什麼情況下數據會丟失。# 儲存位置nw.js打包出來的應用的local... ...
  • 1.首先是效果圖,要在網頁中實現下圖的輪播效果,有四張圖片,每張圖片有自己的標題,然後還有右下角的小方框,滑鼠懸浮在小方框上,會切換到對應的圖片中去。 2.先是HTML中的內容,最外層是輪播圖整個的容器“slideShowContainer”,裡邊是用來裝圖片的“picUl”和用來顯示小方框的“do ...
  • 1、普通的二三級菜單 2、變成水平方向 3、彈簧式 菜單製作的方式多種多樣,這次先給大家分享這幾種,如大家有好的建議和菜單效果,可以在下方回覆給我,大家共同學習一下。 ...
  • 變形分類 縮放 使用scale方法來實現文字或圖像的縮放,在參數中指定縮放倍率。例如“scale(0.5)”,表示縮小50 傾斜 使用skew方法來實現文字或圖像的縮放,在參數中指定水平方向的傾斜角度與垂直方向的傾斜角度,若只有一個數值,則為水平方向的傾斜角度,單位為deg。 註:rotate表示的 ...
  • a. js對象都是關聯數組 b. inherit();返回一個繼承自原型對象p的屬性的新對象 對象的方法: 創建(create) 設置(set) 查找(query) 刪除(delete) 檢測(test)和枚舉(enumerate) 創建對象的方法: 對象直接量 關鍵字new es5中的Object ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...