本示例介绍如何使用Alibaba Cloud SDK for Java调用RDS的CreateLoadBalancerHTTPSListener接口创建HTTPS监听。

前提条件

  • 使用Alibaba Cloud SDK for Java,您需要一个阿里云账号和访问密钥(AccessKey)。 请在阿里云控制台中的AccessKey管理页面上创建和查看您的AccessKey。
  • 确保您已经安装了Alibaba Cloud SDK for Java,准确的SDK版本号,请参见 阿里云开发工具包(SDK)
    <dependencies>
        <!-- https://mvnrepository.com/artifact/com.aliyun/aliyun-java-sdk-core -->
        <dependency>
            <groupId>com.aliyun</groupId>
            <artifactId>aliyun-java-sdk-core</artifactId>
            <version>4.4.3</version>
        </dependency>
        <!-- ttps://mvnrepository.com/artifact/com.aliyun/aliyun-java-sdk-slb -->
        <dependency>
            <groupId>com.aliyun</groupId>
            <artifactId>aliyun-java-sdk-slb</artifactId>
            <version>3.2.11</version>
        </dependency>
    </dependencies>

示例代码

import com.aliyuncs.DefaultAcsClient;
import com.aliyuncs.IAcsClient;
import com.aliyuncs.exceptions.ClientException;
import com.aliyuncs.profile.DefaultProfile;
import com.aliyuncs.slb.model.v20140515.CreateLoadBalancerHTTPListenerRequest;
import com.aliyuncs.slb.model.v20140515.CreateLoadBalancerHTTPListenerResponse;
import com.google.gson.Gson;

/**
 * 调用CreateLoadBalancerHTTPSListener创建HTTPS监听
 */
public class CreateLoadBalancerHTTPListener {
    public static void main(String[] args) {
        // 初始化请求参数
        DefaultProfile profile = DefaultProfile.getProfile(
                 "<your-region-id>",// 地域ID
                 "<your-access-key-id>",// 您的AccessKey ID
                 "<your-access-key-secret>");// 您的AccessKey Secret
        IAcsClient client = new DefaultAcsClient(profile);
        // 配置请求参数
        CreateLoadBalancerHTTPListenerRequest request = new CreateLoadBalancerHTTPListenerRequest();
        //是否开启健康检查。
        // 取值:on | off。
        request.setHealthCheck("on");
        // 负载均衡实例前端使用的端口。
        // 取值:1~65535。
        request.setListenerPort(80);
        // 负载均衡实例的ID。
        request.setLoadBalancerId("lb-2zeu0f9t55z38vconltat");
        // 是否开启会话保持。
        // 取值:on | off。
        request.setStickySession("on");
        // 监听绑定的访问策略组ID。
        // 当AclStatus参数的值为on时,该参数必选。
        request.setAclId("acl-2zeo3lz5dkhto3dipzgzj");
        // 是否开启访问控制功能。
        // 取值:on | off(默认值)。
        request.setAclStatus("on");
        /**
         * 访问控制类型:
         * white: 仅转发来自所选访问控制策略组中设置的IP地址或地址段的请求,白名单适用于应用只允许特定IP访问的场景。
         *    设置白名单存在一定业务风险。
         *    一旦设置白名单,就只有白名单中的IP可以访问负载均衡监听。
         * 如果开启了白名单访问,但访问策略组中没有添加任何IP,则负载均衡监听不会转发请求。
         * black: 来自所选访问控制策略组中设置的IP地址或地址段的所有请求都不会转发,黑名单适用于应用只限制某些特定IP访问的场景。
         *    如果开启了黑名单访问,但访问策略组中没有添加任何IP,则负载均衡监听会转发全部请求。
         */
        request.setAclType("white");
        // 负载均衡实例后端使用的端口。
        // 取值:1~65535。
        request.setBackendServerPort(80);
        //监听的带宽峰值,取值:
        // -1:不限制带宽峰值。
        // 1-5120:监听的带宽峰值,所有监听的带宽峰值之和不能超过实例的带宽峰值。
        request.setBandwidth(-1);
        // 服务器上配置的Cookie。当StickySession为on且StickySessionType为server时,该参数必选。
        request.setCookie("B490B5EBF6F3CD402E515D22BCDA1598");
        // Cookie超时时间。
        // 取值:1~86400(秒)。
        request.setCookieTimeout(500);
        // 设置监听的描述信息。
        request.setDescription("test111111111");
        // HTTP至HTTPS的监听转发端口。
        request.setForwardPort(443);
        // 是否开启Gzip压缩,对特定文件类型进行压缩。默认值为on。
        // 取值:on | off。
        request.setGzip("on");
        // 健康检查的后端服务器的端口。
        // 取值: 1~65535。
        request.setHealthCheckConnectPort(80);
        // 用于健康检查的域名,
        request.setHealthCheckDomain("$_ip");
        // 健康检查正常的HTTP状态码,多个状态码用逗号分隔。
        request.setHealthCheckHttpCode("http_2xx,http_3xx");
        // 健康检查的时间间隔。
        // 取值: 1-50(秒)。
        request.setHealthCheckInterval(5);
        // 接收来自运行状况检查的响应需要等待的时间。如果后端ECS在指定的时间内没有正确响应,则判定为健康检查失败。
        // 取值:1~300(秒)。
        request.setHealthCheckTimeout(3);
        // 用于健康检查的URI。
        request.setHealthCheckURI("/test/index.html");
        // 健康检查连续成功多少次后,将后端服务器的健康检查状态由fail判定为success。
        request.setHealthyThreshold(4);
        // 指定连接空闲超时时间,取值范围为1-60秒,默认值为15秒。
        // 在超时时间内一直没有访问请求,负载均衡会暂时中断当前连接,直到一下次请求来临时重新建立新的连接。
        request.setIdleTimeout(20);
        // 是否开启HTTP至HTTPS的转发。
        // 取值:on | off。
        request.setListenerForward("off");
        // 指定请求超时时间,取值范围为1-180秒,默认值为60秒。
        request.setRequestTimeout(30);
        /**
         * 调度算法。取值:
         * wrr(默认值):权重值越高的后端服务器,被轮询到的次数(概率)也越高。
         * wlc:除了根据每台后端服务器设定的权重值来进行轮询,同时还考虑后端服务器的实际负载(即连接数)。当权重值相同时,当前连接数越小的后端服务器被轮询到的次数(概率)也越高。
         * rr:按照访问顺序依次将外部请求依序分发到后端服务器。
         */
        request.setScheduler("wrr");
        /**
         * cookie的处理方式。取值:
         * insert:植入Cookie。
         * 客户端第一次访问时,负载均衡会在返回请求中植入Cookie(即在HTTP/HTTPS响应报文中插入SERVERID),
         * 下次客户端携带此Cookie访问,负载均衡服务会将请求定向转发给之前记录到的后端服务器上。
         * server:重写Cookie。
         * 负载均衡发现用户自定义了Cookie,将会对原来的Cookie进行重写,下次客户端携带新的Cookie访问,负载均衡服务会将请求定向转发给之前记录到的后端服务器。
         */
        request.setStickySessionType("insert");
        // 健康检查连续失败多少次后,将后端服务器的健康检查状态由success判定为fail。
        request.setUnhealthyThreshold(4);
        // 服务器组ID。
        request.setVServerGroupId("rsp-2ze2y1k7w37al");
        // 是否开启通过X-Forwarded-For头字段获取来访者真实 IP。默认值为on。
        request.setXForwardedFor("on");
        // 是否通过SLB-ID头字段获取负载均衡实例ID。
        request.setXForwardedFor_proto("on");
        // 是否通过SLB-IP头字段获取客户端请求的真实IP。
        request.setXForwardedFor_SLBID("on");
        // 是否通过X-Forwarded-Proto头字段获取负载均衡实例的监听协议。
        request.setXForwardedFor_SLBIP("on");

        try {
            // 发送请求获取返回结果
            CreateLoadBalancerHTTPListenerResponse response = client.getAcsResponse(request);
            // 处理返回结果
            System.out.println(new Gson().toJson(response));
        } catch (ClientException e) {
            System.out.println("ErrCode:" + e.getErrCode());
            System.out.println("ErrMsg:" + e.getErrMsg());
            System.out.println("RequestId:" + e.getRequestId());
        }
    }
}
说明 更多参数和接口信息,请参见API概览