本文介绍通过Java SDK使用日志服务告警功能的代码示例。
前提条件
已开通日志服务。更多信息,请参见开通日志服务。
已创建RAM用户并完成授权。具体操作,请参见创建RAM用户并完成授权。
已配置环境变量ALIBABA_CLOUD_ACCESS_KEY_ID和ALIBABA_CLOUD_ACCESS_KEY_SECRET。具体操作,请参见在Linux、macOS和Windows系统配置环境变量。
重要阿里云账号的AccessKey拥有所有API的访问权限,建议您使用RAM用户的AccessKey进行API访问或日常运维。
强烈建议不要把AccessKey ID和AccessKey Secret保存到工程代码里,否则可能导致AccessKey泄露,威胁您账号下所有资源的安全。
已安装0.6.100及以上版本的日志服务SDK。具体操作,请参见安装Java SDK。
告警监控规则管理
代码示例如下。具体的参数说明,请参见告警监控规则数据结构。
import com.alibaba.fastjson.JSON;
import com.aliyun.openservices.log.Client;
import com.aliyun.openservices.log.common.*;
import com.aliyun.openservices.log.exception.LogException;
import com.aliyun.openservices.log.request.*;
import com.aliyun.openservices.log.response.*;
import java.util.*;
public class App {
// 设置日志服务的服务接入点。
private static final String ENDPOINT = "cn-huhehaote.log.aliyuncs.com";
// 本示例从环境变量中获取AccessKey ID和AccessKey Secret。
private static final String ACCESS_KEY_ID = System.getenv("ALIBABA_CLOUD_ACCESS_KEY_ID");
private static final String ACCESS_KEY_SECRET = System.getenv("ALIBABA_CLOUD_ACCESS_KEY_SECRET");
// 创建日志服务Client。
private static final Client client = new Client(ENDPOINT, ACCESS_KEY_ID, ACCESS_KEY_SECRET);
private static final String PROJECT = "demo-alert";
private static final String ALERT_ID = "nginx-status-error";
private static void createAlert() throws LogException {
JobSchedule schedule = new JobSchedule();
schedule.setType(JobScheduleType.FIXED_RATE);
schedule.setInterval("1m");
AlertConfiguration configuration = new AlertConfiguration();
configuration.setVersion("2.0");
configuration.setType("default");
configuration.setDashboard("internal-alert-analysis");
Query query = new Query();
query.setStoreType("log");
query.setRegion("cn-huhehaote");
query.setProject(PROJECT);
query.setStore("nginx-access-log");
query.setQuery("status >= 400 | select count(*) as cnt");
query.setTimeSpanType(TimeSpanType.TRUNCATED);
query.setStart("-1m");
query.setEnd("absolute");
query.setPowerSqlMode("auto");
configuration.setQueryList(Collections.singletonList(query));
AlertConfiguration.GroupConfiguration groupConfiguration = new AlertConfiguration.GroupConfiguration();
groupConfiguration.setType("no_group");
configuration.setGroupConfiguration(groupConfiguration);
AlertConfiguration.SeverityConfiguration severityConfiguration = new AlertConfiguration.SeverityConfiguration();
severityConfiguration.setSeverity(AlertConfiguration.Severity.Medium);
AlertConfiguration.ConditionConfiguration conditionConfiguration = new AlertConfiguration.ConditionConfiguration();
conditionConfiguration.setCondition("cnt > 0");
conditionConfiguration.setCountCondition("");
severityConfiguration.setEvalCondition(conditionConfiguration);
configuration.setSeverityConfigurations(Collections.singletonList(severityConfiguration));
AlertConfiguration.Tag serviceLabel = new AlertConfiguration.Tag();
serviceLabel.setKey("service");
serviceLabel.setValue("nginx");
configuration.setLabels(Collections.singletonList(serviceLabel));
AlertConfiguration.Tag titleAnno = new AlertConfiguration.Tag();
titleAnno.setKey("title");
titleAnno.setValue("Nginx Status Error");
AlertConfiguration.Tag descAnno = new AlertConfiguration.Tag();
descAnno.setKey("desc");
descAnno.setValue("Nginx Status Error, count: ${cnt}");
List<AlertConfiguration.Tag> annotations = new LinkedList<AlertConfiguration.Tag>();
annotations.add(titleAnno);
annotations.add(descAnno);
configuration.setAnnotations(annotations);
configuration.setAutoAnnotation(true);
configuration.setSendResolved(false);
configuration.setThreshold(1);
configuration.setNoDataFire(false);
configuration.setNoDataSeverity(AlertConfiguration.Severity.Medium);
AlertConfiguration.PolicyConfiguration policyConfiguration = new AlertConfiguration.PolicyConfiguration();
policyConfiguration.setAlertPolicyId("sls.builtin.dynamic");
policyConfiguration.setActionPolicyId("test-action-policy");
policyConfiguration.setRepeatInterval("1m");
policyConfiguration.setUseDefault(false);
configuration.setPolicyConfiguration(policyConfiguration);
Alert alert = new Alert();
alert.setName(ALERT_ID);
alert.setDisplayName("Nginx Status Error");
alert.setState(JobState.ENABLED);
alert.setSchedule(schedule);
alert.setConfiguration(configuration);
CreateAlertRequest request = new CreateAlertRequest(PROJECT, alert);
CreateAlertResponse response = client.createAlert(request);
System.out.println("[create alert] " + JSON.toJSONString(response));
}
public static void getAndUpdateAlert() throws LogException {
GetAlertRequest getAlertRequest = new GetAlertRequest(PROJECT, ALERT_ID);
GetAlertResponse getAlertResponse = client.getAlert(getAlertRequest);
System.out.println("[get alert] " + JSON.toJSONString(getAlertResponse));
Alert alert = getAlertResponse.getAlert();
alert.getConfiguration().getQueryList().get(0).setQuery("status >= 500 | select count(*) as cnt");
UpdateAlertRequest updateAlertRequest = new UpdateAlertRequest(PROJECT, alert);
UpdateAlertResponse updateAlertResponse = client.updateAlert(updateAlertRequest);
System.out.println("[update alert] " + JSON.toJSONString(updateAlertResponse));
}
public static void disableAndEnableAlert() throws LogException {
DisableAlertRequest disableAlertRequest = new DisableAlertRequest(PROJECT, ALERT_ID);
DisableAlertResponse disableAlertResponse = client.disableAlert(disableAlertRequest);
System.out.println("[disable alert] " + JSON.toJSONString(disableAlertResponse));
EnableAlertRequest enableAlertRequest = new EnableAlertRequest(PROJECT, ALERT_ID);
EnableAlertResponse enableAlertResponse = client.enableAlert(enableAlertRequest);
System.out.println("[enable alert] " + JSON.toJSONString(enableAlertResponse));
}
public static void listAlerts() throws LogException {
ListAlertRequest request = new ListAlertRequest(PROJECT);
request.setOffset(0);
request.setSize(100);
ListAlertResponse response = client.listAlert(request);
System.out.println("[list alerts] " + JSON.toJSONString(response));
}
public static void deleteAlert() throws LogException {
DeleteAlertRequest request = new DeleteAlertRequest(PROJECT, ALERT_ID);
DeleteAlertResponse response = client.deleteAlert(request);
System.out.println("[delete alert] " + JSON.toJSONString(response));
}
public static void main(String[] args) throws LogException {
createAlert();
getAndUpdateAlert();
disableAndEnableAlert();
listAlerts();
deleteAlert();
}
}
资源数据管理
代码示例如下。具体的参数说明,请参见告警资源数据结构。
管理用户
import com.alibaba.fastjson.JSON;
import com.aliyun.openservices.log.Client;
import com.aliyun.openservices.log.common.*;
import com.aliyun.openservices.log.exception.LogException;
import com.aliyun.openservices.log.request.*;
import com.aliyun.openservices.log.response.*;
import java.util.Collections;
public class App {
// 设置日志服务的服务接入点。
// 资源数据的写操作,必须使用河源地域,读操作可以使用其它地域。
private static final String ENDPOINT = "cn-heyuan.log.aliyuncs.com";
// 本示例从环境变量中获取AccessKey ID和AccessKey Secret。
private static final String ACCESS_KEY_ID = System.getenv("ALIBABA_CLOUD_ACCESS_KEY_ID");
private static final String ACCESS_KEY_SECRET = System.getenv("ALIBABA_CLOUD_ACCESS_KEY_SECRET");
private static final String USER_RESOURCE_NAME = "sls.common.user";
private static Client client = new Client(ENDPOINT, ACCESS_KEY_ID, ACCESS_KEY_SECRET);
private static void createUser() throws LogException {
ResourceUser user = new ResourceUser();
user.setUserId("alex");
user.setUserName("Alex");
user.setEnabled(true);
user.setCountryCode("86");
user.setPhone("133****3333");
user.setEmail(Collections.singletonList("****@example.com"));
user.setSmsEnabled(true);
user.setVoiceEnabled(true);
ResourceRecord record = new ResourceRecord();
record.setId(user.getUserId());
record.setTag(user.getUserName());
record.setValue(JSON.toJSONString(user));
CreateResourceRecordRequest request = new CreateResourceRecordRequest(USER_RESOURCE_NAME, record);
CreateResourceRecordResponse response = client.createResourceRecord(request);
System.out.println("[create user]" + JSON.toJSONString(response));
}
private static void getUser() throws LogException {
GetResourceRecordRequest request = new GetResourceRecordRequest(USER_RESOURCE_NAME, "alex");
GetResourceRecordResponse response = client.getResourceRecord(request);
System.out.println("[get user]" + JSON.toJSONString(response.getRecord()));
}
private static void updateUser() throws LogException {
ResourceUser user = new ResourceUser();
user.setUserId("alex");
user.setUserName("Alex");
user.setEnabled(false);
user.setCountryCode("86");
user.setPhone("133****3333");
user.setEmail(Collections.singletonList("****@example.com"));
user.setSmsEnabled(true);
user.setVoiceEnabled(true);
ResourceRecord record = new ResourceRecord();
record.setId(user.getUserId());
record.setTag(user.getUserName());
record.setValue(JSON.toJSONString(user));
UpdateResourceRecordRequest request = new UpdateResourceRecordRequest(USER_RESOURCE_NAME, record);
UpdateResourceRecordResponse response = client.updateResourceRecord(request);
System.out.println("[update user]" + JSON.toJSONString(response));
}
private static void listUsers() throws LogException {
ListResourceRecordRequest request = new ListResourceRecordRequest(USER_RESOURCE_NAME);
request.setOffset(0);
request.setSize(100);
ListResourceRecordResponse response = client.listResourceRecord(request);
System.out.printf("[list users] count: %d, total %d, data %s",
response.getCount(), response.getTotal(), JSON.toJSONString(response.getRecords()));
}
private static void deleteUser() throws LogException {
DeleteResourceRecordRequest request = new DeleteResourceRecordRequest(USER_RESOURCE_NAME, "alex");
DeleteResourceRecordResponse response = client.deleteResourceRecord(request);
System.out.println("[delete user]" + JSON.toJSONString(response));
}
public static void main(String[] args) throws LogException {
createUser();
getUser();
updateUser();
listUsers();
deleteUser();
}
}
管理用户组
private static void createUserGroup() throws LogException {
ResourceUserGroup userGroup = new ResourceUserGroup();
userGroup.setGroupId("devops");
userGroup.setGroupName("DevOps Team");
userGroup.setEnabled(true);
userGroup.setMembers(Collections.singletonList("alex"));
ResourceRecord record = new ResourceRecord();
record.setId(userGroup.getGroupId());
record.setTag(userGroup.getGroupName());
record.setValue(JSON.toJSONString(userGroup));
CreateResourceRecordRequest request = new CreateResourceRecordRequest("sls.common.user_group", record);
CreateResourceRecordResponse response = client.createResourceRecord(request);
System.out.println("[create user group]" + JSON.toJSONString(response));
}
管理Webhook集成
private static void createWebhookIntegration() throws LogException {
ResourceWebhookIntegration dingtalk = new ResourceWebhookIntegration();
dingtalk.setId("dingtalk");
dingtalk.setName("Dingtalk Webhook");
dingtalk.setMethod("POST");
dingtalk.setUrl("https://oapi.dingtalk.com/robot/send?access_token=**********");
dingtalk.setType("dingtalk");
// 钉钉加签密钥。如果您在钉钉侧设置安全验证方式为签名校验,则需配置该字段。您可以在钉钉机器人管理界面获取加签密钥。
// dingtalk.setSecret("SEC**********");
dingtalk.setHeaders(Collections.<ResourceWebhookIntegration.Header>emptyList());
ResourceWebhookIntegration wechat = new ResourceWebhookIntegration();
wechat.setId("wechat");
wechat.setName("Wechat Webhook");
wechat.setMethod("POST");
wechat.setUrl("https://qyapi.weixin.qq.com/cgi-bin/webhook/send?key=**********");
wechat.setType("wechat");
wechat.setHeaders(Collections.<ResourceWebhookIntegration.Header>emptyList());
ResourceWebhookIntegration feishu = new ResourceWebhookIntegration();
feishu.setId("feisu");
feishu.setName("Feishu Webhook");
feishu.setMethod("POST");
feishu.setUrl("https://open.feishu.cn/open-apis/bot/v2/hook/**********");
feishu.setType("lark");
// 飞书加签密钥。如果您在飞书侧设置安全验证方式为签名校验,则需配置该字段。您可以在飞书机器人管理界面获取加签密钥。
// feishu.setSecret("**********");
feishu.setHeaders(Collections.<ResourceWebhookIntegration.Header>emptyList());
ResourceWebhookIntegration slack = new ResourceWebhookIntegration();
slack.setId("slack");
slack.setName("Slack Webhook");
slack.setMethod("POST");
slack.setUrl("https://hooks.slack.com/services/**********");
slack.setType("slack");
slack.setHeaders(Collections.<ResourceWebhookIntegration.Header>emptyList());
ResourceWebhookIntegration webhook = new ResourceWebhookIntegration();
webhook.setId("webhook");
webhook.setName("Common Webhook");
webhook.setMethod("POST");
webhook.setUrl("https://example.com/***********");
webhook.setType("custom");
ResourceWebhookIntegration.Header authHeader = new ResourceWebhookIntegration.Header();
authHeader.setKey("Authorization");
authHeader.setValue("Basic YWRtaW46Zm9vYmFy");
webhook.setHeaders(Collections.singletonList(authHeader));
ResourceWebhookIntegration[] webhooks = {dingtalk, wechat, feishu, slack, webhook};
for (ResourceWebhookIntegration webhookIntegration: webhooks) {
ResourceRecord record = new ResourceRecord();
record.setId(webhookIntegration.getId());
record.setTag(webhookIntegration.getName());
record.setValue(JSON.toJSONString(webhookIntegration));
CreateResourceRecordRequest request = new CreateResourceRecordRequest("sls.alert.action_webhook", record);
CreateResourceRecordResponse response = client.createResourceRecord(request);
System.out.println("[create webhook integration] " + record.getId() + " " + JSON.toJSONString(response));
}
}
管理行动策略
private static void createActionPolicy() throws LogException {
ResourceActionPolicy actionPolicy = new ResourceActionPolicy();
actionPolicy.setActionPolicyId("test-action-policy");
actionPolicy.setActionPolicyName("Test Action Policy");
actionPolicy.setPrimaryPolicyScript("fire(type=\"sms\", users=[\"alex\"], groups=[], oncall_groups=[], receiver_type=\"static\", external_url=\"\", external_headers={}, template_id=\"sls.builtin.cn\", period=\"any\")");
actionPolicy.setSecondaryPolicyScript("fire(type=\"voice\", users=[\"alex\"], groups=[], oncall_groups=[], receiver_type=\"static\", external_url=\"\", external_headers={}, template_id=\"sls.builtin.cn\", period=\"any\")");
actionPolicy.setEscalationStartEnabled(false);
actionPolicy.setEscalationStartTimeout("10m");
actionPolicy.setEscalationInProgressEnabled(false);
actionPolicy.setEscalationInProgressTimeout("30m");
actionPolicy.setEscalationEnabled(true);
actionPolicy.setEscalationTimeout("1h");
ResourceRecord record = new ResourceRecord();
record.setId(actionPolicy.getActionPolicyId());
record.setTag(actionPolicy.getActionPolicyName());
record.setValue(JSON.toJSONString(actionPolicy));
CreateResourceRecordRequest request = new CreateResourceRecordRequest("sls.alert.action_policy", record);
CreateResourceRecordResponse response = client.createResourceRecord(request);
System.out.println("[create action policy]" + JSON.toJSONString(response));
}
管理告警策略
private static void createAlertPolicy() throws LogException {
ResourceAlertPolicy alertPolicy = new ResourceAlertPolicy();
alertPolicy.setPolicyId("test-alert-policy");
alertPolicy.setPolicyName("Test Alert Policy");
alertPolicy.setParentId("");
alertPolicy.setGroupScript("fire(action_policy=\"test-action-policy\", group={\"alert.alert_id\": alert.alert_id}, group_by_all_labels=true, group_wait=\"15s\", group_interval=\"5m\", repeat_interval=\"1h\")");
alertPolicy.setInhibitScript("");
alertPolicy.setSilenceScript("");
ResourceRecord record = new ResourceRecord();
record.setId(alertPolicy.getPolicyId());
record.setTag(alertPolicy.getPolicyName());
record.setValue(JSON.toJSONString(alertPolicy));
CreateResourceRecordRequest request = new CreateResourceRecordRequest("sls.alert.alert_policy", record);
CreateResourceRecordResponse response = client.createResourceRecord(request);
System.out.println("[create alert policy]" + JSON.toJSONString(response));
}
管理内容模板
private static void createContentTemplate() throws LogException {
ResourceContentTemplate.Template sms = new ResourceContentTemplate.Template();
sms.setLocale("zh-CN");
sms.setContent("");
ResourceContentTemplate.Template voice = new ResourceContentTemplate.Template();
voice.setLocale("zh-CN");
voice.setContent("");
ResourceContentTemplate.Template email = new ResourceContentTemplate.Template();
email.setLocale("en-US");
email.setSubject("SLS Alert");
email.setContent("");
ResourceContentTemplate.Template dingtalk = new ResourceContentTemplate.Template();
dingtalk.setLocale("zh-CN");
dingtalk.setTitle("SLS Alert");
dingtalk.setContent("");
ResourceContentTemplate.Template wechat = new ResourceContentTemplate.Template();
wechat.setLocale("zh-CN");
wechat.setTitle("SLS Alert");
wechat.setContent("");
ResourceContentTemplate.Template lark = new ResourceContentTemplate.Template();
lark.setLocale("zh-CN");
lark.setTitle("SLS Alert");
lark.setContent("");
ResourceContentTemplate.Template slack = new ResourceContentTemplate.Template();
slack.setLocale("zh-CN");
slack.setTitle("SLS Alert");
slack.setContent("");
ResourceContentTemplate.Template webhook = new ResourceContentTemplate.Template();
webhook.setLocale("zh-CN");
webhook.setSendType("single");
webhook.setLimit(0);
webhook.setContent("");
ResourceContentTemplate.Templates templates = new ResourceContentTemplate.Templates();
templates.setSms(sms);
templates.setVoice(voice);
templates.setEmail(email);
templates.setDingtalk(dingtalk);
templates.setWechat(wechat);
templates.setLark(lark);
templates.setSlack(slack);
templates.setWebhook(webhook);
String templateId = "test-template";
String templateName = "Test Template";
Map<String, Object> contentTemplate = new HashMap<String, Object>();
contentTemplate.put("template_id", templateId);
contentTemplate.put("template_name", templateName);
contentTemplate.put("templates", templates);
ResourceRecord record = new ResourceRecord();
record.setId(templateId);
record.setTag(templateName);
record.setValue(JSON.toJSONString(contentTemplate));
CreateResourceRecordRequest request = new CreateResourceRecordRequest("sls.alert.content_template", record);
CreateResourceRecordResponse response = client.createResourceRecord(request);
System.out.println("[create content template]" + JSON.toJSONString(response));
}
相关文档
在调用API接口过程中,若服务端返回结果中包含错误信息,则表示调用API接口失败。您可以参考API错误码对照表查找对应的解决方法。更多信息,请参见API错误处理对照表。
阿里云OpenAPI开发者门户提供调试、SDK、示例和配套文档。通过OpenAPI,您无需手动封装请求和签名操作,就可以快速对日志服务API进行调试。更多信息,请参见OpenAPI开发者门户。
为满足越来越多的自动化日志服务配置需求,日志服务提供命令行工具CLI(Command Line Interface)。更多信息,请参见日志服务命令行工具CLI。
更多示例代码,请参见Aliyun Log Java SDK on GitHub。
文档内容是否对您有帮助?