Sharding-JDBC 使用 Nacos 作为配置中心 【下 代码实战】

Sharding-JDBC 使用 Nacos 作为配置中心 【下 代码实战】

1. 实现 ShardingSphereDriverURLProvider

由上一篇博文我们已经知道了 Sharding-JDBC 是基于 Java SPI 机制去加载 并实例化 ShardingSphereDriverURLProvider 的实现类

public interface ShardingSphereDriverURLProvider {
    boolean accept(String var1);

    byte[] getContent(String var1);
}

ShardingSphereDriverURLProvider接口有两个抽象方法 accept()方法用于判断当前的url是否满足条件,如果满足将调用 getContent ()方法获取数据源配置信息。因此我们可以新建一个 NacosDriverUrlProvider 实现 ShardingSphereDriverURLProvider ,并在 META-INF/services下新建一个文件 org.apache.shardingsphere.driver.jdbc.core.driver.ShardingSphereDriverURLProvider ,文件内容为 NacosDriverUrlProvider 的全限定类名。

image-20240612215136982

image-20240612215156026

2.NacosDriverUrlProvider

2.1 重写 accept() 方法

我们先重写 accept()方法,判断url中是否包含 “nacos:”,如果有,则适用于 NacosDriverUrlProvider 类去加载配置

private final static String NACOS_MARK = "nacos:";


@Override
public boolean accept(String url) {
    return StringUtils.isNotBlank(url) && url.contains(NACOS_MARK);
}

2.2 重写 getContent() 方法

我们获取到nacos的url的连接后,通过 NacosFactory.createConfigService 去获取 nacos的配置信息,相关案例在nacos官网也有实例代码

try {
  String serverAddr = "{serverAddr}";
  String dataId = "{dataId}";
  String group = "{group}";
  Properties properties = new Properties();
  properties.put("serverAddr", serverAddr);
  ConfigService configService = NacosFactory.createConfigService(properties);
  String content = configService.getConfig(dataId, group, 5000);
  System.out.println(content);
} catch (NacosException e) {
    // TODO Auto-generated catch block
    e.printStackTrace();
}

将url分割获取到参数后,封装到 Properties 中,然后通过 NacosFactory.createConfigService 获取 ConfigService 对象后获取到配置信息

 private final static String FIXED_PREFIX = "jdbc:shardingsphere:";


public byte[] getContent(String url) {
    int nacosPrefix = url.indexOf(FIXED_PREFIX + NACOS_MARK);

    String realUrl = url.substring(nacosPrefix + (FIXED_PREFIX + NACOS_MARK).length(), url.length());

    int serverAddrEndIndex = realUrl.indexOf("?");

    String serverAddr = realUrl.substring(0, serverAddrEndIndex);

    String args = realUrl.substring(serverAddrEndIndex+1, realUrl.length());

    String[] split = args.split("&");

    String dataId = "";
    String group = "";
    String namespace = "";
    String username = "";
    String password = "";

    for (String str : split) {
        int index = str.indexOf("=");
        String substring = str.substring(0, index);
        switch (substring){
            case  "dataId" :
                dataId = str.substring(index+1,str.length());
                break;
            case  "group" :
                group = str.substring(index+1,str.length());
                break;
            case  "namespace" :
                namespace = str.substring(index+1,str.length());
                break;
            case  "username" :
                username = str.substring(index+1,str.length());
                break;
            case  "password" :
                password = str.substring(index+1,str.length());
                break;
        }
    }

    String content = "";
    try {
        Properties properties = new Properties();
        properties.put("serverAddr", serverAddr);
        properties.put("namespace", namespace);
        properties.put("username", username);
        properties.put("password", password);
        ConfigService configService = NacosFactory.createConfigService(properties);
        content = configService.getConfig(dataId, group, 5000);
    } catch (NacosException e) {
        // TODO Auto-generated catch block
        e.printStackTrace();
    }


    return content.getBytes();
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

秋日的晚霞

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值