InstanceH2DAO.java 4.2 KB
Newer Older
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18
/*
 * Copyright 2017, OpenSkywalking Organization All rights reserved.
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *     http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 *
 * Project repository: https://github.com/OpenSkywalking/skywalking
 */

19 20
package org.skywalking.apm.collector.agentregister.worker.instance.dao;

clevertension's avatar
clevertension 已提交
21 22 23 24
import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.HashMap;
import java.util.Map;
clevertension's avatar
clevertension 已提交
25 26
import org.skywalking.apm.collector.client.h2.H2Client;
import org.skywalking.apm.collector.client.h2.H2ClientException;
27
import org.skywalking.apm.collector.storage.define.register.InstanceDataDefine;
clevertension's avatar
clevertension 已提交
28
import org.skywalking.apm.collector.storage.define.register.InstanceTable;
clevertension's avatar
clevertension 已提交
29
import org.skywalking.apm.collector.storage.h2.SqlBuilder;
30
import org.skywalking.apm.collector.storage.h2.dao.H2DAO;
clevertension's avatar
clevertension 已提交
31 32
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
33 34

/**
clevertension's avatar
clevertension 已提交
35
 * @author pengys5, clevertension
36 37
 */
public class InstanceH2DAO extends H2DAO implements IInstanceDAO {
clevertension's avatar
clevertension 已提交
38
    private final Logger logger = LoggerFactory.getLogger(InstanceH2DAO.class);
39

clevertension's avatar
clevertension 已提交
40 41
    private static final String GET_INSTANCE_ID_SQL = "select {0} from {1} where {2} = ? and {3} = ?";
    private static final String UPDATE_HEARTBEAT_TIME_SQL = "updatte {0} set {1} = ? where {2} = ?";
42

43
    @Override public int getInstanceId(int applicationId, String agentUUID) {
clevertension's avatar
clevertension 已提交
44 45
        logger.info("get the application id with application id = {}, agentUUID = {}", applicationId, agentUUID);
        H2Client client = getClient();
clevertension's avatar
clevertension 已提交
46
        String sql = SqlBuilder.buildSql(GET_INSTANCE_ID_SQL, InstanceTable.COLUMN_INSTANCE_ID, InstanceTable.TABLE, InstanceTable.COLUMN_APPLICATION_ID,
47 48
            InstanceTable.COLUMN_AGENT_UUID);
        Object[] params = new Object[] {applicationId, agentUUID};
clevertension's avatar
clevertension 已提交
49 50 51 52 53 54 55
        try (ResultSet rs = client.executeQuery(sql, params)) {
            if (rs.next()) {
                return rs.getInt(InstanceTable.COLUMN_INSTANCE_ID);
            }
        } catch (SQLException | H2ClientException e) {
            logger.error(e.getMessage(), e);
        }
56 57 58 59
        return 0;
    }

    @Override public int getMaxInstanceId() {
clevertension's avatar
clevertension 已提交
60
        return getMaxId(InstanceTable.TABLE, InstanceTable.COLUMN_INSTANCE_ID);
61 62 63
    }

    @Override public int getMinInstanceId() {
clevertension's avatar
clevertension 已提交
64
        return getMinId(InstanceTable.TABLE, InstanceTable.COLUMN_INSTANCE_ID);
65 66 67
    }

    @Override public void save(InstanceDataDefine.Instance instance) {
clevertension's avatar
clevertension 已提交
68 69 70 71 72 73 74 75
        H2Client client = getClient();
        Map<String, Object> source = new HashMap<>();
        source.put(InstanceTable.COLUMN_INSTANCE_ID, instance.getInstanceId());
        source.put(InstanceTable.COLUMN_APPLICATION_ID, instance.getApplicationId());
        source.put(InstanceTable.COLUMN_AGENT_UUID, instance.getAgentUUID());
        source.put(InstanceTable.COLUMN_REGISTER_TIME, instance.getRegisterTime());
        source.put(InstanceTable.COLUMN_HEARTBEAT_TIME, instance.getHeartBeatTime());
        source.put(InstanceTable.COLUMN_OS_INFO, instance.getOsInfo());
clevertension's avatar
clevertension 已提交
76
        String sql = SqlBuilder.buildBatchInsertSql(InstanceTable.TABLE, source.keySet());
clevertension's avatar
clevertension 已提交
77 78 79 80 81 82
        Object[] params = source.values().toArray(new Object[0]);
        try {
            client.execute(sql, params);
        } catch (H2ClientException e) {
            logger.error(e.getMessage(), e);
        }
83 84 85
    }

    @Override public void updateHeartbeatTime(int instanceId, long heartbeatTime) {
clevertension's avatar
clevertension 已提交
86
        H2Client client = getClient();
clevertension's avatar
clevertension 已提交
87
        String sql = SqlBuilder.buildSql(UPDATE_HEARTBEAT_TIME_SQL, InstanceTable.TABLE, InstanceTable.COLUMN_HEARTBEAT_TIME,
88
            InstanceTable.COLUMN_INSTANCE_ID);
clevertension's avatar
clevertension 已提交
89 90 91 92 93 94
        Object[] params = new Object[] {heartbeatTime, instanceId};
        try {
            client.execute(sql, params);
        } catch (H2ClientException e) {
            logger.error(e.getMessage(), e);
        }
95 96
    }
}