暂无图片
暂无图片
暂无图片
暂无图片
暂无图片

GaussDB​数据库能力-参数相关示例代码

wang 2023-06-09
167

 版本说明:本示例配套的SDK版本为:3.0.89

1. 简介

GaussDB是基于华为主导的openGauss生态推出的企业级分布式关系型数据库。该产品具备企业级复杂事务混合负载能力,同时支持分布式事务,同城跨AZ部署,数据0丢失,支持1000+的扩展能力,PB级海量存储。同时拥有云上高可用,高可靠,高安全,弹性伸缩,一键部署,快速备份恢复,监控告警等关键能力,能为企业提供功能全面,稳定可靠,扩展性强,性能优越的企业级数据库服务。本示例展示如何通过java版本的SDK方式对参数进行修改。

2. 前置条件

1)已 注册 华为云,并完成 实名认证 。
2)获取华为云开发工具包(SDK),您也可以查看安装JAVA SDK。
3)已获取华为云账号对应的Access Key(AK)和Secret Access Key(SK)。请在华为云控制台“我的凭证 > 访问密钥”页面上创建和查看您的AK/SK。具体请参见 访问密钥 。
4)已具备开发环境 ,支持Java JDK 1.8及其以上版本。

3. 安装SDK

您可以通过Maven方式获取和安装SDK,首先需要在您的操作系统中下载并安装Maven ,安装完成后您只需要在Java项目的pom.xml文件中加入相应的依赖项即可。
具体的SDK版本号请参见 SDK开发中心 。
<dependency>
<groupId>com.huaweicloud.sdk</groupId>
<artifactId>huaweicloud-sdk-gaussdbforopengauss</artifactId>
<version>3.0.89</version>
</dependency>
4.代码示例
以下代码展示如何使用SDK创建实例:

/*
* Copyright (c) Huawei Technologies Co., Ltd. 2022-2022. All rights reserved.
*/

package com.huaweicloud.gaussdbforopengauss.sdk.demo;

import com.huaweicloud.sdk.core.auth.BasicCredentials;
import com.huaweicloud.sdk.core.auth.ICredential;
import com.huaweicloud.sdk.core.exception.ConnectionException;
import com.huaweicloud.sdk.core.exception.RequestTimeoutException;
import com.huaweicloud.sdk.core.exception.ServiceResponseException;
import com.huaweicloud.sdk.gaussdbforopengauss.v3.GaussDBforopenGaussClient;
import com.huaweicloud.sdk.gaussdbforopengauss.v3.model.ListConfigurationsRequest;
import com.huaweicloud.sdk.gaussdbforopengauss.v3.model.ListConfigurationsResponse;
import com.huaweicloud.sdk.gaussdbforopengauss.v3.model.OpenGaussModifyInstanceConfigurationRequest;
import com.huaweicloud.sdk.gaussdbforopengauss.v3.model.ShowInstanceConfigurationRequest;
import com.huaweicloud.sdk.gaussdbforopengauss.v3.model.ShowInstanceConfigurationResponse;
import com.huaweicloud.sdk.gaussdbforopengauss.v3.model.UpdateInstanceConfigurationRequest;
import com.huaweicloud.sdk.gaussdbforopengauss.v3.model.UpdateInstanceConfigurationResponse;
import com.huaweicloud.sdk.gaussdbforopengauss.v3.region.GaussDBforopenGaussRegion;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

import java.util.HashMap;
import java.util.Map;

/**
* GaussDB参数相关示例代码
*/
public class ConfigurationsDemo {
private static final Logger logger = LoggerFactory.getLogger(ConfigurationsDemo.class.getName());

public static void main(String[] args) {
String ak = "<YOUR AK>";
String sk = "<YOUR SK>";
String instanceId = "<YOUR INSTANCE_ID>";

ICredential auth = new BasicCredentials()
.withAk(ak)
.withSk(sk);

GaussDBforopenGaussClient client = GaussDBforopenGaussClient.newBuilder()
.withCredential(auth)
.withRegion(GaussDBforopenGaussRegion.CN_NORTH_4)
.build();

// 获取参数模板列表,可在创建实例的时候指定对应的参数模板
listConfigurations(client);

// 获取指定实例的参数
ShowInstanceConfigurationResponse showInstanceConfigurationResponse = showInstanceConfiguration(client, instanceId);

if (showInstanceConfigurationResponse != null) {
// 通过map指定修改的参数,key:参数名 value:参数值
Map<String, String> values = new HashMap<>();
// 修改实例参数返回的第一个参数
values.put(showInstanceConfigurationResponse.getConfigurationParameters().get(0).getName(), "1000");
// 修改指定实例的指定参数
updateInstanceConfiguration(client, instanceId, values);
}
}

private static void listConfigurations(GaussDBforopenGaussClient client) {
ListConfigurationsRequest request = new ListConfigurationsRequest();
try {
ListConfigurationsResponse response = client.listConfigurations(request);
logger.info(response.toString());
} catch (ConnectionException e) {
logger.error("ConnectionException", e);
} catch (RequestTimeoutException e) {
logger.error("RequestTimeoutException ", e);
} catch (ServiceResponseException e) {
logger.error("httpStatusCode: {}, errorCode: {}, errorMsg: {}", e.getHttpStatusCode(), e.getErrorCode(), e.getErrorMsg());
}
}

private static ShowInstanceConfigurationResponse showInstanceConfiguration(GaussDBforopenGaussClient client, String instanceId) {
ShowInstanceConfigurationRequest request = new ShowInstanceConfigurationRequest();
request.withInstanceId(instanceId);
try {
ShowInstanceConfigurationResponse response = client.showInstanceConfiguration(request);
logger.info(response.toString());
return response;
} catch (ConnectionException e) {
logger.error("ConnectionException", e);
} catch (RequestTimeoutException e) {
logger.error("RequestTimeoutException ", e);
} catch (ServiceResponseException e) {
logger.error("httpStatusCode: {}, errorCode: {}, errorMsg: {}", e.getHttpStatusCode(), e.getErrorCode(), e.getErrorMsg());
}

return null;
}

private static void updateInstanceConfiguration(GaussDBforopenGaussClient client, String instanceId, Map<String, String> values) {
UpdateInstanceConfigurationRequest request = new UpdateInstanceConfigurationRequest();
request.withInstanceId(instanceId);
OpenGaussModifyInstanceConfigurationRequest body = new OpenGaussModifyInstanceConfigurationRequest();
body.withValues(values);
request.withBody(body);
try {
UpdateInstanceConfigurationResponse response = client.updateInstanceConfiguration(request);
logger.info(response.toString());
} catch (ConnectionException e) {
logger.error("ConnectionException", e);
} catch (RequestTimeoutException e) {
logger.error("RequestTimeoutException ", e);
} catch (ServiceResponseException e) {
logger.error("httpStatusCode: {}, errorCode: {}, errorMsg: {}", e.getHttpStatusCode(), e.getErrorCode(), e.getErrorMsg());
}
}
}

最后修改时间:2023-06-16 09:57:44
「喜欢这篇文章,您的关注和赞赏是给作者最好的鼓励」
关注作者
【版权声明】本文为墨天轮用户原创内容,转载时必须标注文章的来源(墨天轮),文章链接,文章作者等基本信息,否则作者和墨天轮有权追究责任。如果您发现墨天轮中有涉嫌抄袭或者侵权的内容,欢迎发送邮件至:contact@modb.pro进行举报,并提供相关证据,一经查实,墨天轮将立刻删除相关内容。

评论