blob: 178aaa574007637f5a20309bb791f3053a92a887 [file] [log] [blame]
/*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright ownership.
* The ASF licenses this file to You 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.
*
*/
package org.apache.skywalking.oap.server.core.alarm;
import java.util.List;
import lombok.Getter;
import lombok.Setter;
import org.apache.skywalking.oap.server.core.Const;
import org.apache.skywalking.oap.server.core.analysis.Stream;
import org.apache.skywalking.oap.server.core.analysis.record.Record;
import org.apache.skywalking.oap.server.core.analysis.worker.RecordStreamProcessor;
import org.apache.skywalking.oap.server.core.source.DefaultScopeDefine;
import org.apache.skywalking.oap.server.core.source.ScopeDeclaration;
import org.apache.skywalking.oap.server.core.storage.annotation.BanyanDB;
import org.apache.skywalking.oap.server.core.storage.annotation.Column;
import org.apache.skywalking.oap.server.core.storage.annotation.ElasticSearch;
import org.apache.skywalking.oap.server.core.storage.annotation.SQLDatabase;
import org.apache.skywalking.oap.server.core.storage.type.Convert2Entity;
import org.apache.skywalking.oap.server.core.storage.type.Convert2Storage;
import org.apache.skywalking.oap.server.core.storage.type.StorageBuilder;
import static org.apache.skywalking.oap.server.core.analysis.record.Record.TIME_BUCKET;
import static org.apache.skywalking.oap.server.core.source.DefaultScopeDefine.ALARM;
@Getter
@Setter
@ScopeDeclaration(id = ALARM, name = "Alarm")
@Stream(name = AlarmRecord.INDEX_NAME, scopeId = DefaultScopeDefine.ALARM, builder = AlarmRecord.Builder.class, processor = RecordStreamProcessor.class)
@SQLDatabase.ExtraColumn4AdditionalEntity(additionalTable = AlarmRecord.ADDITIONAL_TAG_TABLE, parentColumn = TIME_BUCKET)
public class AlarmRecord extends Record {
public static final String INDEX_NAME = "alarm_record";
public static final String ADDITIONAL_TAG_TABLE = "alarm_record_tag";
public static final String SCOPE = "scope";
public static final String NAME = "name";
public static final String ID0 = "id0";
public static final String ID1 = "id1";
public static final String START_TIME = "start_time";
public static final String ALARM_MESSAGE = "alarm_message";
public static final String RULE_NAME = "rule_name";
public static final String TAGS = "tags";
public static final String TAGS_RAW_DATA = "tags_raw_data";
@Override
public String id() {
return getTimeBucket() + Const.ID_CONNECTOR + ruleName + Const.ID_CONNECTOR + id0 + Const.ID_CONNECTOR + id1;
}
@Column(columnName = SCOPE)
private int scope;
@Column(columnName = NAME, storageOnly = true)
private String name;
@Column(columnName = ID0, storageOnly = true)
@BanyanDB.ShardingKey(index = 0)
private String id0;
@Column(columnName = ID1, storageOnly = true)
private String id1;
@Column(columnName = START_TIME)
private long startTime;
@Column(columnName = ALARM_MESSAGE)
@ElasticSearch.MatchQuery
private String alarmMessage;
@Column(columnName = RULE_NAME)
private String ruleName;
@Column(columnName = TAGS, indexOnly = true)
@SQLDatabase.AdditionalEntity(additionalTables = {ADDITIONAL_TAG_TABLE})
private List<String> tagsInString;
@Column(columnName = TAGS_RAW_DATA, storageOnly = true)
private byte[] tagsRawData;
public static class Builder implements StorageBuilder<AlarmRecord> {
@Override
public AlarmRecord storage2Entity(final Convert2Entity converter) {
AlarmRecord record = new AlarmRecord();
record.setScope(((Number) converter.get(SCOPE)).intValue());
record.setName((String) converter.get(NAME));
record.setId0((String) converter.get(ID0));
record.setId1((String) converter.get(ID1));
record.setAlarmMessage((String) converter.get(ALARM_MESSAGE));
record.setStartTime(((Number) converter.get(START_TIME)).longValue());
record.setTimeBucket(((Number) converter.get(TIME_BUCKET)).longValue());
record.setRuleName((String) converter.get(RULE_NAME));
record.setTagsRawData(converter.getBytes(TAGS_RAW_DATA));
// Don't read the TAGS as they are only for query.
return record;
}
@Override
public void entity2Storage(final AlarmRecord storageData, final Convert2Storage converter) {
converter.accept(SCOPE, storageData.getScope());
converter.accept(NAME, storageData.getName());
converter.accept(ID0, storageData.getId0());
converter.accept(ID1, storageData.getId1());
converter.accept(ALARM_MESSAGE, storageData.getAlarmMessage());
converter.accept(START_TIME, storageData.getStartTime());
converter.accept(TIME_BUCKET, storageData.getTimeBucket());
converter.accept(RULE_NAME, storageData.getRuleName());
converter.accept(TAGS_RAW_DATA, storageData.getTagsRawData());
converter.accept(TAGS, storageData.getTagsInString());
}
}
}