沈斌
2018-05-03 8fbd26ea16e81c29926188ec5a8e149c032d102f
server.js
@@ -7,19 +7,22 @@
var mongoClient = require('mongodb').MongoClient;
var config = require('./config');
var method = require('./method');
var queue = require('./queue');
//var queue = require('./queue');
var map = {
    "5a0000010001": 32,
    "5a0000010002": 102,
    "5a0000010003": 162,
    "5a0000010004": 32,
    "5a0000010006": 122,
    "5a0000010007": 32,
    "5a000001000c": 20
    "5a0000010001": 32,  //心跳命令行
    "5a0000010002": 102, //云地址写入WIFI模块
    "5a0000010003": 162, //传感器数据上传
    "5a0000010004": 32,  //云端时间
    "5a0000010006": 122, //配网数据
    "5a0000010007": 32,  //主机休眠前发送即将休眠的命令
    "5a000001000c": 20   //联云通知
};
global.configs = {};
function handleData(db, socket, value) {
    //1.心跳命令行
    if(value.startsWith('5a0000010001')) {
        var output = [ 0x6A, 0x00, 0x00, 0x01, 0x00, 0x01, 0xA1, 0x1A, 0xC7, 0x6B ];
@@ -38,7 +41,6 @@
    if(value.startsWith('5a0000010003')) {
        var output = [ 0x6A, 0x00, 0x00, 0x01, 0x00, 0x03, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x6B ];
        method.insertData(db, value, function(data, rank) {
            method.insertDocument2(db, value, rank, function(data) {});
            var fields = method.padLeft(rank.toString(16), 8).match(/.{2}/g);
            output[6] = method.toDec(fields[0]);
            output[7] = method.toDec(fields[1]);
@@ -101,9 +103,9 @@
    var length = map[data.slice(0, 12)];
    if(length > 0) {
        var value = data.slice(0, length);
        console.log(moment().format('YYYY-MM-DD HH:mm:ss') + " => " + value);
        //console.log(moment().format('YYYY-MM-DD HH:mm:ss') + " => " + value);
        queue.publishMessage(value);
        //queue.publishMessage(value);
        handleData(db, socket, value);
@@ -111,12 +113,30 @@
    }
}
mongoClient.connect(config.URL, function(err, db) {
mongoClient.connect(config.URL, {
        server: {
            poolSize: 10,
            keepAlive: 120,
            auto_reconnect: true,
            reconnectTries: 1000,
            reconnectInterval: 5000,
            socketOptions: {
                keepAlive: 300000,
                connectTimeoutMS: 30000
            }
        }
    }, function(err, db) {
    if (err) {
        console.log(err.message);
        return;
    }
    console.log('Connecting to Mongo DB at ' + config.URL);
    //初始化三级警报通讯方式
    method.initConfigs(db);
    // //监听三级警报通讯方式的变化
    // queue.listenToMQ("ex_data_config");
    net.createServer().on('connection', function(socket){
        console.log('CONNECTED: ' + socket.remoteAddress +':'+ socket.remotePort);
@@ -132,8 +152,6 @@
                console.log("Error - invalid data - less than 12 character long");
                return;
            }
            //console.log(moment().format('YYYY-MM-DD HH:mm:ss') + " => " + value);
            doWork(db, socket, value);
        });
@@ -154,11 +172,7 @@
        socket.on('close', function(data) {
            console.log('Closed socket: ' + socket.remoteAddress +' '+ socket.remotePort);
        });
        socket.on('close', function(data) {
            console.log('Closed socket: ' + socket.remoteAddress + ' ' + socket.remotePort);
        });
    }).listen(config.PORT, config.HOST);
    console.log('TCP Server listening on ' + config.HOST + ':' + config.PORT);
});
});