创建HTTPS监听。
接口说明
注意事项
新建的监听的状态为 stopped。创建完成后,调用 StartLoadBalancerListener 接口启动监听来转发流量。
前提条件
您已经创建传统型负载均衡,具体操作,请参见 CreateLoadBalancer 。
调试
您可以在OpenAPI Explorer中直接运行该接口,免去您计算签名的困扰。运行成功后,OpenAPI Explorer可以自动生成SDK代码示例。
授权信息
下表是API对应的授权信息,可以在RAM权限策略语句的Action
元素中使用,用来给RAM用户或RAM角色授予调用此API的权限。具体说明如下:
- 操作:是指具体的权限点。
- 访问级别:是指每个操作的访问级别,取值为写入(Write)、读取(Read)或列出(List)。
- 资源类型:是指操作中支持授权的资源类型。具体说明如下:
- 对于必选的资源类型,用背景高亮的方式表示。
- 对于不支持资源级授权的操作,用
全部资源
表示。
- 条件关键字:是指云产品自身定义的条件关键字。
- 关联操作:是指成功执行操作所需要的其他权限。操作者必须同时具备关联操作的权限,操作才能成功。
操作 | 访问级别 | 资源类型 | 条件关键字 | 关联操作 |
---|---|---|---|---|
slb:CreateLoadBalancerHTTPSListener | create |
|
| 无 |
请求参数
名称 | 类型 | 必填 | 描述 | 示例值 |
---|---|---|---|---|
RegionId | string | 否 | 传统型负载均衡实例的地域 ID。 您可以从地域和可用区列表或通过调用 DescribeRegions 接口查询地域 ID。 | cn-hangzhou |
LoadBalancerId | string | 是 | 传统型负载均衡实例的 ID。 | lb-bp1o94dp5i6earr**** |
Bandwidth | integer | 是 | 监听的带宽峰值。单位:Mbps。 取值范围:
| -1 |
ListenerPort | integer | 是 | 实例前端使用的端口。 取值范围:1~65535。 | 80 |
BackendServerPort | integer | 否 | 实例后端使用的端口,取值范围:1~65535。 如果不使用服务器组(不指定 VServerGroupId),则该参数必选。 | 80 |
Tag | array<object> | 否 | 标签列表。 | |
object | 否 | 标签列表。 | ||
Key | string | 否 | 监听的标签键。N 的取值范围:1~20。一旦传入该值,则不允许为空字符串。最多支持 64 个字符,不能以 | TestKey |
Value | string | 否 | 监听的标签值。N 的取值范围:1~20。一旦传入该值,可以为空字符串。最多支持 128 个字符,不能以 | TestValue |
XForwardedFor | string | 否 | 是否通过
| on |
Scheduler | string | 否 | 调度算法。取值:
| wrr |
StickySession | string | 是 | 是否开启会话保持。取值:
| on |
StickySessionType | string | 否 | Cookie 的处理方式。取值:insert 或 server。
客户端第一次访问时,负载均衡会在返回请求中植入 Cookie(即在 HTTP/HTTPS 响应报文中插入 SERVERID),下次客户端携带此 Cookie 访问,负载均衡服务会将请求定向转发给之前记录到的后端服务器上。
负载均衡发现用户自定义了 Cookie,将会对原来的 Cookie 进行重写,下次客户端携带新的 Cookie 访问,负载均衡服务会将请求定向转发给之前记录到的后端服务器。 说明
当 StickySession 的值为 on 时,必须指定该参数。
| insert |
CookieTimeout | integer | 否 | Cookie 超时时间。单位:秒。 取值:1~86400。 说明
当 StickySession 为 on 且 StickySessionType 为 insert 时,该参数必选。
| 500 |
Cookie | string | 否 | 服务器上配置的 Cookie。 长度为 1~200 个字符,只能包含 ASCII 英文字母和数字字符,不能包含半角逗号(,)、半角分号(;)或空格,也不能以美元符号($)开头。 说明
当 StickySession 为 on 且 StickySessionType 为 server 时,该参数必选。
| testCookie |
HealthCheck | string | 是 | 是否开启健康检查。取值:
| on |
HealthCheckMethod | string | 否 | 监听 HTTP 类型健康检查的健康检查方法。取值:head 或 get。 说明
HealthCheck 值为 on 时才会有效。
| get |
HealthCheckDomain | string | 否 | 用于健康检查的域名。取值:
说明
在 HealthCheck 值为 on 时才会有效。
| 172.XX.XX.16 |
HealthCheckURI | string | 否 | 用于健康检查的 URI。 URI 长度为 1~80 个字符,可包含英文字母、数字和 说明
在 HealthCheck 值为 on 时才会有效。
| /test/index.html |
HealthyThreshold | integer | 否 | 健康检查连续成功多少次后,将后端服务器的健康检查状态由 fail 判定为 success。 取值:2~10。 说明
在 HealthCheck 值为 on 时才会有效。
| 4 |
UnhealthyThreshold | integer | 否 | 健康检查连续失败多少次后,将后端服务器的健康检查状态由 success 判定为 fail。 取值:2~10。 说明
在 HealthCheck 值为 on 时才会有效。
| 4 |
HealthCheckTimeout | integer | 否 | 接收来自运行状况检查的响应需要等待的时间。如果后端 ECS 在指定的时间内没有正确响应,则判定为健康检查失败。单位:秒。取值:1~300。 说明
在 HealthCheck 值为 on 时才会有效。
| 3 |
HealthCheckConnectPort | integer | 否 | 健康检查使用的端口。 取值:1~65535。 说明
当 HealthCheck 值为 on 时才会有效。
| 8080 |
HealthCheckInterval | integer | 否 | 健康检查的时间间隔。单位:秒。 取值:1~50。 说明
在 HealthCheck 值为 on 时才会有效。
| 5 |
HealthCheckHttpCode | string | 否 | 健康检查正常的 HTTP 状态码,多个状态码用半角逗号(,)分割。 取值:http_2xx、http_3xx、http_4xx或http_5xx。 说明
在 HealthCheck 值为 on 时才会有效。
| http_2xx,http_3xx |
ServerCertificateId | string | 是 | 服务器证书的 ID。 | idkp-123-cn-test-**** |
VServerGroupId | string | 否 | 服务器组 ID。 | rsp-cige6j5e7p**** |
CACertificateId | string | 否 | CA 证书 ID。 若既上传 CA 证书又上传服务器证书,即采用双向认证。 若用户只上传服务器证书,即为单向认证。 | 139a00604ad-cn-east-hangzh**** |
XForwardedFor_SLBIP | string | 否 | 是否通过
| on |
XForwardedFor_SLBID | string | 否 | 是否通过
| on |
XForwardedFor_proto | string | 否 | 是否通过
| on |
Gzip | string | 否 | 是否开启
| on |
AclId | string | 否 | 监听绑定的访问策略组 ID。 说明
当 AclStatus 参数的值为 on 时,该参数必选。
| acl-a2do9e413e0spzasx**** |
AclType | string | 否 | 访问控制类型。取值:
如果开启了白名单访问,但访问策略组中没有添加任何 IP,则负载均衡监听会转发全部请求。
如果开启了黑名单访问,但访问策略组中没有添加任何 IP,则负载均衡监听会转发全部请求。 说明
当 AclStatus 参数的值为 on 时,该参数有效。
| white |
AclStatus | string | 否 | 是否开启访问控制功能。取值:
| off |
Description | string | 否 | 自定义监听名称。 长度限制为 1~256 个字符,支持中文、字母、数字、短划线(-)、正斜线(/)、半角句号(.)和下划线(_)。 | HTTPS_443 |
IdleTimeout | integer | 否 | 指定连接空闲超时时间,取值范围为1~60,默认值为 15。单位:秒。 在超时时间内一直没有访问请求,负载均衡会暂时中断当前连接,直到一下次请求来临时重新建立新的连接。 | 12 |
RequestTimeout | integer | 否 | 指定请求超时时间,取值范围为1~180,默认值为 60。单位:秒。 在超时时间内后端服务器一直没有响应,负载均衡将放弃等待,给客户端返回 HTTP 504 错误码。 | 23 |
EnableHttp2 | string | 否 | 是否开启 HTTP2 特性。取值:
| off |
TLSCipherPolicy | string | 否 | 安全策略包含 HTTPS 可选的 TLS 协议版本和配套的加密算法套件。
| tls_cipher_policy_1_1 |
XForwardedFor_SLBPORT | string | 否 | 是否通过
| off |
XForwardedFor_ClientSrcPort | string | 否 | 是否通过
| off |
返回参数
示例
正常返回示例
JSON
格式
{
"RequestId": "CEF72CEB-54B6-4AE8-B225-F876FF7BA984"
}
错误码
HTTP status code | 错误码 | 错误信息 | 描述 |
---|---|---|---|
400 | ParamDuplicateError | The specified parameter value of XForwardedFor_ClientCertSubjectDNAlias is duplicate. Please change to a different one. | 参数XForwardedFor_ClientCertSubjectDNAlias重复。 |
400 | ParamDuplicateError | The specified parameter value of XForwardedFor_ClientCertIssuerDNAlias is duplicate. Please change to a different one. | 参数XForwardedFor_ClientCertIssuerDNAlias重复。 |
400 | ParamDuplicateError | The specified parameter value of XForwardedFor_ClientCertFingerprintAlias is duplicate. Please change to a different one. | 参数XForwardedFor_ClientCertFingerprintAlias重复。 |
400 | ParamDuplicateError | The specified parameter value of XForwardedFor_ClientCertClientVerifyAlias is duplicate. Please change to a different one. | 参数XForwardedFor_ClientCertClientVerifyAlias重复。 |
400 | IpVersionConflict | The ip version of this LoadBalancer and the Acl is conflict. | 指定负载均衡的IP版本与ACL支持的IP类型冲突。 |
400 | InvalidParameter.IdleTimeout | The specified IdleTimeout exceeds the limit. | 指定的IdleTimeout无效。请检查参数约束,并在修改后重试。 |
400 | InvalidParameter.RequestTimeout | The specified RequestTimeout exceeds the limit. | 指定的RequestTimeout无效。请检查参数约束,并在修改后重试。 |
400 | ListenerForwardNotSupport | X-Forward-For is not supported to a ipv6 instance. | Ipv6负载均衡实例不支持X-Forward-For。 |
400 | InvalidParameter.RegionNotSupport | The region does not support the parameter: %s. | 当前区域不支持指定参数。 |
400 | InvalidParameter.SpecNotSupport | The loadBalancer of shared spec does not support the parameter: %s. | 共享型负载均衡实例不支持当前参数。 |
400 | ListenerProcessing | A previous configuration of the listener is pending,please try again later. | 当前监听正在配置中,请稍后重试。 |
400 | Certkey.Forbidden | The specified certkey is not owned by the current user. | 指定的certkey不属于当前用户。 |
400 | InvalidParameter.ListenerPortConflict | There is conflict listener port exists. | 指定的监听端口已存在。 |
400 | ResourceNotAvailible.HttpsListener | The specified Zone did not have enough resource. | 指定可用区资源不足。 |
400 | AclNotExist | Acl does not exist. | 指定的Acl不存在。 |
400 | OperationUnsupported.CreateLoadBalancerLayer7Listener | The slb instance does not support create HTTP or HTTPS listener. | 当前负载均衡实例不支持创建HTTP或者HTTPS类型的监听。 |
400 | InvalidParameter.VServerGroupId | The MasterSlaveServerGroup can not be attached to HTTP or HTTPS listener. | HTTP或HTTPS监听不支持挂载主备服务器组。 |
400 | MissingParam.HealthCheckDomain | The HealthCheckDomain is required when HealthCheckHttpVersion is http1.1. | 参数HealthCheckDomain缺失。 |
400 | InvalidParameter.HealthCheckHttpVersion | The param HealthCheckHttpVersion is invalid. | 指定的HealthCheckHttpVersion无效。请检查参数约束,并在修改后重试。 |
400 | QuotaLimitExceeds.AclAttachedToListener | %s. | - |
400 | QuotaLimitExceeds.TotalAclEntry | %s. | - |
400 | AclListenerOverLimit | %s. | - |
400 | Duplicated.AclEntry | %s. | Acl条目重复。 |
400 | CertificateNotExist | The specified CertificateId does not exist. | 指定的证书不存在。 |
400 | OperationFailed.InsufficientResources | The loadbalancer does not support this operation because of insufficient resources. | 操作失败,原因是由于资源不足,负载均衡器不支持此操作。 |
400 | InvalidTLSPolicyId.NotExist | The specified TLS cipher policy does not exist. | 指定的TLS策略不存在。 |
400 | TLSPolicyConfiguring | The specified TLS cipher policy is configuring. | 指定的TLSCipherPolicy正在变配中。 |
400 | TLSCipherPolicyVipRelationOverLimit | The number of listeners associated with a policy has exceeded. | 监听关联TLSCipherPolicy的数量已达到配额上限。 |
400 | CertificateTypeMismatched | The certificate type does not match. | 指定证书的类型不匹配。 |
400 | MissingParam.ServerCertificates | Server certificates are required. | 参数ServerCertificates缺失。 |
400 | TooManyCertificates | The number of certificates must not be greater than one. | 证书的数量不得大于1个。 |
400 | CnCertificateNotSupport | The cn certificate is not support. | 不支持国密证书。 |
400 | InvalidParam.CertificateBindingType | The param CertificateBindingType is invalid. | 指定的CertificateBindingType无效。请检查参数约束,并在修改后重试。 |
400 | InvalidParamSize.ServerCertificates | The size of param ServerCertificates is invalid. | 指定的ServerCertificates长度无效。请检查参数约束,并在修改后重试。 |
400 | TooManyCertificates.ServerCertificates | The number of certificates must not be greater than one. | 证书的数量不得大于1个。 |
400 | SPEC_NOT_SUPPORT_PARAMETER | Share spec does not support the feature. | - |
400 | LbNotSupportTcpssl | You cannot create a TCP SSL type listener for the specified load balancer. | 指定的实例不支持创建tcpssl类型的监听。 |
400 | LbSupportTcpsslOnly | The specified load balancer supports TCP SSL type listener only. | 指定的实例只支持创建tcpssl类型的监听。 |
400 | ListenerNotSupportRule | You cannot create a rule for the specified listener. | 指定的监听不支持创建转发规则。 |
400 | Mismatch.SlbSpecTypeAndListenerProtocol | The SlbSpecType and ListenerProtocol are mismatched. | 实例规格类型和监听类型不匹配。 |
400 | InvalidParam.TagValue | %s. | - |
400 | InvalidParam.TagKey | %s. | - |
400 | SizeLimitExceeded.Tag | %s. | - |
400 | MissingParam.TagKey | The param MissingParam.TagKey is missing. | - |
404 | ResourceNotFound.Certificate | The specified resource is not found. | - |
访问错误中心查看更多错误码。
变更历史
变更时间 | 变更内容概要 | 操作 |
---|---|---|
2023-12-14 | OpenAPI 错误码发生变更、OpenAPI 入参发生变更 | 查看变更详情 |
2023-06-02 | OpenAPI 错误码发生变更 | 查看变更详情 |