操作场景
操作流程
操作步骤
在控制台响应事件
登录云服务器控制台。
在左侧导航树,选择“运维与监控 > 事件监控”,进入事件监控列表页。
在顶部导航栏,选择目标实例所属的项目和地域。
通过事件ID或时间筛选目标事件。
以实例触发InfrastructureUpgrade.Redeploy(因基础设施升级实例重新部署)事件为例,更多事件类型可查看ECS事件类型汇总。
单击事件“操作”列的“授权重新部署”按钮,进行授权响应。
选择重新部署实例的时间窗并同意授权。
单击“确定”按钮,完成授权响应。
成功授权后,事件状态将更新为执行中。
使用OpenAPI响应事件
本节通过火山引擎SDK调用相关接口,请在您的项目中导入火山引擎SDK,操作详情可查看SDK概述。
若您不想在项目中引入SDK,可自行构造HTTP/HTTPS请求,操作详情可查看调用方法。
高性能计算集群内的GPU型实例事件不支持使用OpenAPI响应事件。
调用DescribeSystemEvents接口,查询云服务器实例触发的事件信息。
public void queryInstanceEvents(){//设置您的akString ak = "Your AK";//设置您的skString sk = "Your SK";//设置您要访问的地域,本示例为北京地域String region = "cn-beijing";//初始化apiclientApiClient apiClient = new ApiClient().setCredentials(Credentials.getCredentials(ak, sk)).setRegion(region);EcsApi ecsApi = new EcsApi(apiClient);DescribeSystemEventsRequest describeSystemEventsRequest = new DescribeSystemEventsRequest();// 指定待查询的实例IDdescribeSystemEventsRequest.setResourceIds(Arrays.asList("<A实例ID>","<B实例ID>","<C实例ID>"));// 筛选生成事件的起始时间describeSystemEventsRequest.setCreatedAtStart("2023-05-20T01:29:38+08:00");// 筛选生成事件的结束时间describeSystemEventsRequest.setCreatedAtEnd("2023-05-25T18:29:38+08:00");try {DescribeSystemEventsResponse describeSystemEventsResponse = ecsApi.describeSystemEvents(describeSystemEventsRequest);System.out.println(describeSystemEventsResponse);} catch (ApiException e) {System.out.println(e.getResponseBody());}}
class DescribeSystemEventsResponse {nextToken:systemEvents: [class SystemEventForDescribeSystemEventsOutput {createdAt: 2023-05-25T14:15:21+08:00id: e-ycfroor651gh9zxxxoperatedEndAt: 2023-05-29T11:58:30+08:00operatedStartAt: 2023-05-28T23:58:30+08:00resourceId: <A实例ID>status: Inquiringtype: InfrastructureUpgrade_RedeployupdatedAt: 2023-05-26T11:58:30+08:00}, class SystemEventForDescribeSystemEventsOutput {createdAt: 2023-05-24T10:27:02+08:00id: e-ycfoo7134kgsnzdvxxxoperatedEndAt:operatedStartAt:resourceId: <B实例ID>status: Succeededtype: CreateInstanceupdatedAt: 2023-05-24T10:27:12+08:00}, class SystemEventForDescribeSystemEventsOutput {createdAt: 2023-05-23T17:44:17+08:00id: e-ycfmuzgy5im0xxxxoperatedEndAt:operatedStartAt:resourceId: <C实例ID>status: Succeededtype: RunInstanceupdatedAt: 2023-05-23T17:44:20+08:00}]}
调用DescribeEventTypes接口,查询实例触发的所有事件是否需要响应。
public void queryEventType(){//设置您的akString ak = "Your AK";//设置您的skString sk = "Your SK";//设置您要访问的地域,本示例为北京地域String region = "cn-beijing";//初始化apiclientApiClient apiClient = new ApiClient().setCredentials(Credentials.getCredentials(ak, sk)).setRegion(region);EcsApi ecsApi = new EcsApi(apiClient);DescribeEventTypesRequest describeEventTypesRequest = new DescribeEventTypesRequest();// 指定待查询的事件类型describeEventTypesRequest.setTypes(Arrays.asList("InfrastructureUpgrade_Redeploy","CreateInstance","RunInstance"));// 筛选需要响应的事件describeEventTypesRequest.setResponseRequired(true);try {DescribeEventTypesResponse describeEventTypesResponse = ecsApi.describeEventTypes(describeEventTypesRequest);System.out.println(describeEventTypesResponse);} catch (ApiException e) {System.out.println(e.getResponseBody());}}
本实践中,实例A触发的InfrastructureUpgrade_Redeploy(因基础设施升级实例重新部署)事件需要响应。
class DescribeEventTypesResponse {eventTypes: [class EventTypeForDescribeEventTypesOutput {kind: PlannedOperationsresponseRequired: truestatus: [Inquiring, Executing, Succeeded, Rejected, Canceled]title: 因基础设施升级实例重新部署type: InfrastructureUpgrade_Redeploy}]nextToken:}
调用UpdateSystemEvents接口,响应InfrastructureUpgrade_Redeploy(因基础设施升级实例重新部署)事件,授权火山引擎运维人员进行重新部署实例,排除故障。
仅InfrastructureUpgrade_Redeploy(因基础设施升级实例重新部署)事件授权时,支持使用OperatedStartAt、OperatedEndAt参数调整运维时间窗。
OperatedStartAt、 OperatedEndAt 参数仅支持传入如下时间段:
事件发生时间 ~ 事件发生时间+12h
事件发生时间+12h ~ 事件发生时间+24h
事件发生时间+24h ~ 事件发生时间+36h
事件发生时间+36h ~ 事件发生时间+48h
事件发生时间+48h ~ 事件发生时间+60h
事件发生时间+60h ~ 事件发生时间+72h
public void updateEvents(){//设置您的akString ak = "Your AK";//设置您的skString sk = "Your SK";//设置您要访问的地域,本示例为北京地域String region = "cn-beijing";//初始化apiclientApiClient apiClient = new ApiClient().setCredentials(Credentials.getCredentials(ak, sk)).setRegion(region);EcsApi ecsApi = new EcsApi(apiClient);UpdateSystemEventsRequest updateSystemEventsRequest = new UpdateSystemEventsRequest();// 传入需要响应的事件IDupdateSystemEventsRequest.setEventIds(Arrays.asList("e-ycfu1fit1f8hcczyxxx"));// 响应事件updateSystemEventsRequest.setStatus("Executing");// 指定重新部署实例时间窗updateSystemEventsRequest.setOperatedStartAt("2023-05-28T23:58:30+08:00");updateSystemEventsRequest.setOperatedEndAt("2023-05-29T11:58:30+08:00");try {UpdateSystemEventsResponse updateSystemEventsResponse = ecsApi.updateSystemEvents(updateSystemEventsRequest);System.out.println(updateSystemEventsResponse);} catch (ApiException e) {System.out.println(e.getResponseBody());}}
class UpdateSystemEventsResponse {operationDetails: [class OperationDetailForUpdateSystemEventsOutput {error: nulleventId: e-ycfu1fit1f8hcczxxx}]}
调用DescribeSystemEvents接口,传入已响应的事件ID,查询事件当前状态等信息。
public void queryInstanceEvents(){//设置您的akString ak = "Your AK";//设置您的skString sk = "Your SK";//设置您要访问的地域,本示例为北京地域String region = "cn-beijing";//初始化apiclientApiClient apiClient = new ApiClient().setCredentials(Credentials.getCredentials(ak, sk)).setRegion(region);EcsApi ecsApi = new EcsApi(apiClient);DescribeSystemEventsRequest describeSystemEventsRequest = new DescribeSystemEventsRequest();// 指定待查询事件IDdescribeSystemEventsRequest.setEventIds(Arrays.asList("e-ycfu1fit1f8hcczyxxx"));try {DescribeSystemEventsResponse describeSystemEventsResponse = ecsApi.describeSystemEvents(describeSystemEventsRequest);System.out.println(describeSystemEventsResponse);} catch (ApiException e) {System.out.println(e.getResponseBody());}}
事件处于执行中状态示例如下:
class DescribeSystemEventsResponse {nextToken:systemEvents: [class SystemEventForDescribeSystemEventsOutput {createdAt: 2023-05-26T11:58:30+08:00id: e-ycfu1fit1f8hcczyxxxoperatedEndAt: 2023-05-29T11:58:30+08:00operatedStartAt: 2023-05-28T23:58:30+08:00resourceId: <A实例ID>status: Executingtype: InfrastructureUpgrade_RedeployupdatedAt: 2023-05-26T14:19:19+08:00}]}
事件执行成功示例如下:
class DescribeSystemEventsResponse {nextToken:systemEvents: [class SystemEventForDescribeSystemEventsOutput {createdAt: 2023-05-26T11:58:30+08:00id: e-ycfu1fit1f8hcczyxxxoperatedEndAt: 2023-05-29T11:58:30+08:00operatedStartAt: 2023-05-28T23:58:30+08:00resourceId: <A实例ID>status: Succeededtype: InfrastructureUpgrade_RedeployupdatedAt: 2023-05-28T23:58:30+08:00}]}