本示例介绍如何使用Alibaba Cloud SDK for Java调用CreateLoadBalancerUDPListener接口创建UDP监听。

前提条件

  • 使用Alibaba Cloud SDK for Java,您需要一个阿里云账号和访问密钥(AccessKey)。 请在阿里云控制台中的AccessKey管理页面上创建和查看您的AccessKey。
  • 确保您已经安装了Alibaba Cloud SDK for Java,准确的SDK版本号,请参见阿里云开发工具包(SDK)
    <project>
        <modelVersion>4.0.0</modelVersion>
        <groupId>java.demo</groupId>
        <artifactId>test</artifactId>
        <version>1.0-SNAPSHOT</version>
        <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>
    </project>

示例代码

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

/**
 * 调用CreateLoadBalancerUDPListener创建UDP监听。
 */
public class CreateLoadBalancerUDPListener {
    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);
        // 配置请求参数
        CreateLoadBalancerUDPListenerRequest request = new CreateLoadBalancerUDPListenerRequest();
        // 监听的带宽峰值。
        request.setBandwidth(34);
        // 负载均衡实例前端使用的端口 取值:1-65535
        request.setListenerPort(80);
        // 负载均衡的实例ID
        request.setLoadBalancerId("<your-LoadBalancerId>");
        // 是否打开访问控制 取值:on|off(默认值)
        request.setAclStatus("on");
        // 监听绑定的访问策略组ID 当AclStatus参数为on是,该参数必选
        request.setAclId("<your-AclId>");
        // 访问控制类型
        request.setAclType("white");
        // 负载均衡实例后端使用的端口,取值:1-65535
        request.setBackendServerPort(80);
        // 设置监听的描述信息
        request.setDescription("测试");
        // 健康检查使用的端口,不设置此参数时,表示使用后端服务端口(BackendServerPort)
        request.setHealthCheckConnectPort(81);
        // 接收来自运行状况检查的响应需要等待的时间,取值:1-300(秒)
        request.setHealthCheckConnectTimeout(100);
        // 健康检查连续成功多少次后,将后端服务器的健康检查状态由fail判定为success。// 取值:2-10。
        request.setHealthyThreshold(4);
        // 主备服务器组ID。说明 服务器组ID和主备服务器组ID只能选择一个。
        // request.setMasterSlaveServerGroupId("");
        /**
         * 调度算法。
         * wrr(默认值):权重值越高的后端服务器,被轮询到的次数(概率)也越高。
         * wlc:除了根据每台后端服务器设定的权重值来进行轮询,同时还考虑后端服务器的实际负载(即连接数)。当权重值相同时,当前连接数越小的后端服务器被轮询到的次数(概率)也越高。
         * rr:按照访问顺序依次将外部请求依序分发到后端服务器。
         * sch:基于源IP地址的一致性hash,相同的源地址会调度到相同的后端服务器。
         * tch:基于四元组的一致性hash(源IP+目的IP+源端口+目的端口),相同的流会调度到相同的后端服务器。
         * qch:基于QUIC Connection ID一致性hash,相同的QUIC Connection ID会调度到相同的后端服务器。
         */
        request.setScheduler("wrr");
        // 健康检查连续失败多少次后,将后端服务器的健康检查状态由success判定为fail。取值:2-10。
        request.setUnhealthyThreshold(4);
        // 服务器组ID。说明 服务器组ID和主备服务器组ID只能选择一个。
        request.setVServerGroupId("<your-serverGroupId>");
        // UDP监听健康检查的响应串
        request.setHealthCheckExp("ok");
        // 健康检查的时间间隔。 取值:1-50(秒)。
        request.setHealthCheckInterval(3);
        // UDP监听健康检查的请求串
        request.setHealthCheckReq("hello");
        try {
            // 发送请求获取返回结果
            CreateLoadBalancerUDPListenerResponse 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());
        }
    }
}