主要接口
更新时间:2024-05-14
云数据库 Redis(Simple Cache Service)提供稳定、高效以及高可扩展性的分布式缓存服务。云数据库 Redis 兼容 Redis/Memcached 协议,基于 Redis 提供标准版和集群版的架构模式,并支持自定义副本数量,为您提供多样化的数据结构支持。
订单服务
创建实例
使用以下代码可以创建Redis实例,用于创建一个或多个redis实例
Go
1args := &scs.CreateInstanceArgs{
2 // 选择付款方式,可以选择预付费或后付费
3 Billing: api.Billing{
4 PaymentTiming: api.PaymentTimingPostPaid,
5 },
6 // 购买个数,最大不超过10,默认1
7 PurchaseCount: 1,
8 // 实例名
9 // 要求:1)支持大小写字母、数字以及-_ /.等特殊字符,必须以字母开头;2)长度限制为1-64;
10 InstanceName: "sdk-scs",
11 // 端口号 1025<port<22222,22222<port<65535
12 Port: 6379,
13 // 引擎版本,集群:3.2、4.0、5.0 主从:2.8、3.2、4.0、5.0
14 EngineVersion: "3.2",
15 // 节点规格
16 NodeType: "cache.n1.micro",
17 // 集群类型,集群版:"cluster",主从版:"master_slave"
18 ClusterType: "master_slave",
19 // 副本个数,单副本为1,双副本为2,多副本依此类推
20 ReplicationNum: 1,
21 // 分片个数
22 ShardNum: 1,
23 // 代理节点数,主从版:0,集群版:代理节点数=分片个数
24 ProxyNum: 0,
25}
26
27// 若要生成预付费实例,可以按以下配置生成一个月的预付费实例
28args.Billing = api.Billing{
29 PaymentTiming: api.PaymentTimingPrePaid,
30 Reservation: &api.Reservation{
31 ReservationLength: 1,
32 ReservationTimeUnit: "month",
33 }
34 }
35
36// 若要设置自动续费,可以按以下参数设置一年内自动续费
37// 按月付费或者按年付费 月是"month",年是"year"
38// 自动续费的时间 按月是1-9 按年是 1-3
39args.AutoRenewTimeUnit = "year"
40args.AutoRenewTime = 1
41
42result, err := client.CreateInstance(args)
43if err != nil {
44 fmt.Println("create instance failed:", err)
45} else {
46 fmt.Println("create instance success: ", result)
47}
提示:
变更配置
Go
1args := &scs.ResizeInstanceArgs{
2 NodeType:"cache.n1.small",
3 ShardNum:2,
4}
5err := client.ResizeInstance(instanceId, args)
6if err != nil {
7 fmt.Println("resize instance failed:", err)
8} else {
9 fmt.Println("resize instance success")
提示:
- 实例计费方式为预付费时,不能进行缩容操作
- 实例计费方式为后付费时,可弹性扩缩容
- 只有实例正常运行状态时才可以进行扩缩容操作,变更接口为异步变更,可通过查询指定实例详情接口查询实例状态
释放实例
如下代码可以释放实例,实例将自动进入回收站,保留7天后删除
Go
1err := client.DeleteInstance(instanceId)
2if err != nil {
3 fmt.Println("delete instance failed:", err)
4} else {
5 fmt.Println("delete instance success")
6}
提示:
- 释放单个Redis实例,释放后实例将进入回收站,保留7天后自动删除所有物理资源。
- 可以从回收站内恢复实例或者彻底删除实例,预付费实例需要通过续费实例接口进行恢复。
实例服务
查询实例列表
以下代码可以查询Redis实例列表
Go
1args := &scs.ListInstancesArgs{}
2
3result, err := client.ListInstances(args)
4if err != nil {
5 fmt.Println("list instance failed:", err)
6} else {
7 fmt.Println("list instance success: ", result)
8}
查询指定实例详情
使用以下代码可以查询指定Redis虚机的详细信息
Go
1result, err := client.GetInstanceDetail(instanceId)
2if err != nil {
3 fmt.Println("get instance detail failed:", err)
4} else
5 fmt.Println("get instance detail success ", result)
6}
修改实例名称
如下代码可以修改实例名称
Go
1args := &scs.UpdateInstanceNameArgs{
2 InstanceName: "newInstanceName",
3}
4err := client.UpdateInstanceName(instanceId, args)
5if err != nil {
6 fmt.Println("update instance name failed:", err)
7} else {
8 fmt.Println("update instance name success")
9}
提示:
- 只有实例Running状态时可以修改实例名称
查询实例套餐规格
如下代码可以查询当前可以创建的实例的套餐的规格
Go
1result, err := client.GetNodeTypeList()
2if err != nil {
3 fmt.Println("list node type failed: ", err)
4} else {
5 fmt.Println("list node type success: ", result)
6}
获取子网列表
如下代码可以获取子网列表
Go
1args := &scs.ListSubnetsArgs{}
2_, err := client.ListSubnets(args)
3if err != nil {
4 fmt.Println("get subnet list failed:", err)
5} else {
6 fmt.Println("get subnet list success")
7}
提示:
- 请求参数 vpcId 和 zoneName 不是必须的
修改实例域名
如下代码可以修改实例域名
Go
1args := &scs.UpdateInstanceDomainNameArgs{
2 Domain: "newDomainName",
3}
4err := client.UpdateInstanceDomainName(instanceId, args)
5if err != nil {
6 fmt.Println("update instance domain name failed:", err)
7} else {
8 fmt.Println("update instance domain name success")
9}
提示:
- 只有实例Running状态时可以修改实例域名
获取可用区列表
使用以下代码可以获取可用区列表
Go
1result, err := client.GetZoneList()
2if err != nil {
3 fmt.Println("get zone list failed:", err)
4} else
5 fmt.Println("get zone list success ", result)
6}
清空实例
如下代码可以清空实例
Go
1args := &scs.FlushInstanceArgs{
2 Password: "Password",
3}
4result, err := client.FlushInstance(instanceId, args)
5if err != nil {
6 fmt.Println("flush instance failed:", err)
7} else
8 fmt.Println("flush instance success ", result)
9}
提示:
- 对redis实例,清空后表现为数据占用内存下降,数据被清空;对memcache实例,清空后表现为占用内存不会下降,但是数据被清空
- 如果没有设置密码,传递空字符串
绑定标签
如下代码可以绑定标签
Go
1args := &scs.BindingTagArgs{
2 ChangeTags: []model.TagModel{
3 {
4 TagKey: "tag1",
5 TagValue: "var1",
6 },
7 },
8}
9result, err := client.BindingTag(instanceId, args)
10if err != nil {
11 fmt.Println("bind tags failed:", err)
12} else
13 fmt.Println("bind tags success ", result)
14}
解绑标签
如下代码可以解绑标签
Go
1args := &scs.BindingTagArgs{
2 ChangeTags: []model.TagModel{
3 {
4 TagKey: "tag1",
5 TagValue: "var1",
6 },
7 },
8}
9result, err := client.UnBindingTag(instanceId, args)
10if err != nil {
11 fmt.Println("unbind tags failed:", err)
12} else
13 fmt.Println("unbind tags success ", result)
14}
提示:
- 解绑实例上定义的标签
- 可以同时解绑多个标签
网络安全
修改访问密码
如下代码可以修改访问密码
Go
1args := &scs.ModifyPasswordArgs{
2 Password: "newPassword",
3}
4result, err := client.ModifyPassword(instanceId, args)
5if err != nil {
6 fmt.Println("modify password failed:", err)
7} else
8 fmt.Println("modify password success ", result)
9}
提示:
- 密码长度8~16位,至少包含字母、数字和特殊字符中两种。允许的特殊字符包括 $^*()_+-=
查询IP白名单
如下代码可以查询允许访问实例的IP白名单
Go
1result, err := client.GetSecurityIp(instanceId)
2if err != nil {
3 fmt.Println("get security IP failed:", err)
4} else
5 fmt.Println("get security IP success ", result)
6}
提示:
- 返回参数 IP白名单列表, 包括常规地址: 如192.168.0.1,CIDR地址: 如192.168.1.0/24,0.0.0.0/0代表允许所有地址
增加IP白名单
如下代码可以增加访问实例的IP白名单
Go
1args := &scs.SecurityIpArgs{
2 SecurityIps: []string{
3 "192.0.0.1",
4 },
5}
6result, err := client.AddSecurityIp(instanceId, args)
7if err != nil {
8 fmt.Println("add security IP failed:", err)
9} else
10 fmt.Println("add security IP success ", result)
11}
删除IP白名单
如下代码可以删除访问实例的IP白名单
Go
1args := &scs.SecurityIpArgs{
2 SecurityIps: []string{
3 "192.0.0.1",
4 },
5}
6result, err := client.DeleteSecurityIp(instanceId, args)
7if err != nil {
8 fmt.Println("delete security IP failed:", err)
9} else
10 fmt.Println("delete security IP success ", result)
11}
参数管理
获取参数列表
使用以下代码可以获取Redis实例的配置参数和运行参数
Go
1result, err := client.GetParameters(instanceId)
2if err != nil {
3 fmt.Println("get parameter list failed:", err)
4} else ~~~~
5 fmt.Println("get parameter list success ", result)
6}
修改参数
如下代码可以修改redis实例参数值
Go
1args := &scs.ModifyParametersArgs{
2 Parameter: InstanceParam{
3 Name: "parameter name",
4 Value: "new value",
5 },
6}
7result, err := client.ModifyParameters(instanceId, args)
8if err != nil {
9 fmt.Println("modify parameters failed:", err)
10} else
11 fmt.Println("modify parameters success ", result)
12}
备份恢复
查看备份列表
使用以下代码可以查询某个实例备份列表
Go
1result, err := client.GetBackupList(instanceId)
2if err != nil {
3 fmt.Println("get backup list failed:", err)
4} else
5 fmt.Println("get backup list success ", result)
6}
修改备份策略
如下代码可以修改redis实例自动备份策略
Go
1args := &scs.ModifyBackupPolicyArgs{
2 BackupDays: "Sun,Mon,Tue,Wed,Thu,Fri,Sta",
3 BackupTime: "01:05:00",
4 ExpireDay: 7,
5}
6result, err := client.ModifyBackupPolicy(instanceId, args)
7if err != nil {
8 fmt.Println("modify backup policy failed:", err)
9} else
10 fmt.Println("modify backup policy success ", result)
11}
提示:
- BackupDays: 标识一周中哪几天进行备份备份周期:Mon(周一)Tue(周二)Wed(周三)Thu(周四)Fri(周五)Sat(周六)Sun(周日)逗号分隔,取值如:Sun,Wed,Thu,Fri,Sta
- BackupTime: 标识一天中何时进行备份,UTC时间(+8为北京时间)取值如:01:05:00
- ExpireDay: 备份文件过期时间,取值如:3