当前位置: 首页 > news >正文

firework做网站教程百度产品

firework做网站教程,百度产品,网站流量统计主要指标包括,网站建设价格槽闸阀概述 在微服务架构中,服务配置的集中管理和动态调整是至关重要的。Nacos 提供了配置管理和服务发现的功能,其中配置管理支持动态数据源的切换,增强了其在复杂环境中的适用性。默认情况下,Nacos 支持 MySQL 和Derby,但…

概述

在微服务架构中,服务配置的集中管理和动态调整是至关重要的。Nacos 提供了配置管理和服务发现的功能,其中配置管理支持动态数据源的切换,增强了其在复杂环境中的适用性。默认情况下,Nacos 支持 MySQL 和Derby,但通过使用 Nacos 数据源插件,可以扩展其支持更多类型的数据源,如 dameng、kingbase、SqlServer、Oracle等。

支持数据源扩展的必要性

多数据源支持

不同的服务可能需要连接到不同的数据库,或者需要同时连接到多种类型的数据库。

环境差异

开发、测试以及生产环境可能使用不同的数据库,通过使用数据源扩展插件,可以达到自由切换的目标。

高可用性

通过在 Nacos 中配置多个数据源,可以实现数据源的负载均衡和故障转移。

Nacos 多数据源插件介绍

Nacos从2.2.0版本开始,可通过SPI机制注入多数据源实现插件,并在引入对应数据源实现后,便可在Nacos启动时通过读取application.properties配置文件中spring.datasource.platform配置项选择加载对应多数据源插件.本文档详细介绍一个多数据源插件如何实现以及如何使其生效。

注意: 目前多数据源插件处于Beta测试阶段,其API及接口方法定义可能会在后续版本升级而有较大修改,请注意您的插件适用版本。

原理简介

主要通过插件化来实现多数据源

在原来的Config模块中,所有的SQL操作的执行是通过直接使用JdbcTemplate执行固定SQL语句的形式,使得SQL语句与业务逻辑高度耦合,并且只支持Derby与MySQL两种数据源,原有Config模块架构如下。

在这里插入图片描述

现在的多数据源插件通过SPI机制,将SQL操作按照数据表进行抽象出多个Mapper接口,Mapper接口的实现类需要按照不同的数据源编写对应的SQL方言实现; 现在插件默认提供Derby以及MySQL的Mapper实现,可直接使用;而其他的数据源则需要用户使用数据源插件进行加载,其改造后架构图如下。
在这里插入图片描述

多数据源插件使用

多数据源插件的使用分为两个场景 第一个是插件仓库已经对数据源进行了实现 第二 需要自行实现 这里我们先讨论第一种场景
例如说我们nacos的数据库需要使用 达梦数据库

前置条件

对应的数据库的环境

下载编译插件仓库

git clone git@github.com:nacos-group/nacos-plugin.git
mvn -U clean intall -DskipTests=true

在这里插入图片描述

寻找对应的数据源插件并install到本地

在这里插入图片描述
第一个nacos数据源扩展插件的主module
第二个是 dm 数据源的扩展插件
将 dm 数据源的扩展插件 install到本地即可

install过程中如果遇到 oracle数据源 模块报错 直接在父 pom中注释掉即可

下载编译 nacos源码

git clone git@github.com:alibaba/nacos.git
mvn -U clean intall -DskipTests=true

源码改造

在nacos的nacos-datasource-plugin module中添加依赖

<dependency><groupId>com.alibaba.nacos</groupId><artifactId>nacos-dm-datasource-plugin-ext</artifactId><version>1.0.0-SNAPSHOT</version>
</dependency>

配置修改

修改数据库连接 以及 数据库相关配置

在nacos-console module 的application.properties配置文件中,修改数据库配置:


spring.sql.init.platform=dm
### Count of DB:
db.num=1### Connect URL of DB:
# db.url.0=jdbc:mysql://127.0.0.1:3306/nacos?characterEncoding=utf8&connectTimeout=1000&socketTimeout=3000&autoReconnect=true&useUnicode=true&useSSL=false&serverTimezone=UTC
# db.user=nacos
# db.password=nacosdb.url.0=jdbc:dm://dm服务地址:5236/nacos?characterEncoding=utf8&zeroDateTimeBehavior=convertToNull&serverTimezone=Asia/Shanghai
db.user.0=
db.password.0=xx
db.pool.config.driverClassName=dm.jdbc.driver.DmDriver

在 nacos-console module中 修改主启动类Nacos 增加启动为单体模式 方便我们本地调试

@SpringBootApplication
@ComponentScan(basePackages = "com.alibaba.nacos", excludeFilters = {@Filter(type = FilterType.CUSTOM, classes = {NacosTypeExcludeFilter.class}),@Filter(type = FilterType.CUSTOM, classes = {TypeExcludeFilter.class}),@Filter(type = FilterType.CUSTOM, classes = {AutoConfigurationExcludeFilter.class})})
@ServletComponentScan
public class Nacos {public static void main(String[] args) {//新增配置  启动为单体模式System.setProperty(Constants.STANDALONE_MODE_PROPERTY_NAME, "true");SpringApplication.run(Nacos.class, args);}
}

启动Nacos

启动Nacos服务,检查是否能够成功连接到达梦数据库,并正常工作。

测试验证

通过Nacos控制台进行服务注册、配置管理等操作,验证适配是否成功。

构建 使用

测试验证没问题后 即可打成jar 发到指定环境中了

mvn clean package -DskipTests=true
# nacos文件
cd distribution/target/nacos-server-{version}/

至此第一种场景已经改造完成了 接下来讨论第二种场景

自行扩展数据源插件

自行扩展数据源插件也不是很复杂,这里举例kingbase(人大金仓)的扩展

前置准备

准备对应的数据库环境 ,最好使用数据库自带的传输工具(例如kingbase dts ,dm的dem ),这样可以避免大多数问题 。

下载编译插件仓库(已下载 跳过)

git clone git@github.com:nacos-group/nacos-plugin.git
mvn -U clean intall -DskipTests=true

在数据源插件扩展module下创建对应的项目

例如 nacos-kingbase-datasource-plugin-ext 如果没有问题的话,将会创建nacos-kingbase-datasource-plugin-ext 并且parent为 nacos-datasource-plugin-ext
在这里插入图片描述

在项目module中引入对应的数据库驱动以及数据源插件基础依赖

<dependency><groupId>cn.com.kingbase</groupId><artifactId>kingbase8</artifactId><version>8.6.0</version>
</dependency><dependency><groupId>com.alibaba.nacos</groupId><artifactId>nacos-datasource-plugin-ext-base</artifactId><version>${revision}</version><scope>compile</scope>
</dependency>

创建包 以及对应的项目结构 可从其他的数据源插件复制 (最好目录结构 命名规范与其他的项目一致)

在这里插入图片描述

新增或者修改数据库方言

在 com.alibaba.nacos.plugin.datasource.constants.DatabaseTypeConstant 类中新增数据库常量

public static final String KINGBASE = "kingbase";
/*** kingbase database dialect.** @author leon* &#064;date  2024-09-09 15:37:28*/
public class KingbaseDatabaseDialect extends AbstractDatabaseDialect {@Overridepublic String getType() {return DatabaseTypeConstant.KINGBASE;}
}

接下来实现每个表的 对应的数据库方言的 mapper

在这里插入图片描述
这里mapper改造由于人大金仓数据对mysql的支持较高,所以并不是很复杂 。 只用重写getDataSource方法即可 这里举两个例子

public class ConfigInfoAggrMapperByKingbase extends BaseConfigInfoAggrMapper {@Overridepublic String getDataSource() {return DatabaseTypeConstant.KINGBASE;}
}
public class ConfigInfoBetaMapperByKingbase extends BaseConfigInfoBetaMapper {@Overridepublic String getDataSource() {return DatabaseTypeConstant.KINGBASE;}}

其他的也类似改造即可
另外需要说明的是,为了保证sql的兼容性最好可以每个sql都自行执行下

修改 DatabaseDialect SPI

修改 com.alibaba.nacos.plugin.datasource.dialect.DatabaseDialect
将内容修改为对应的数据库方言类

com.alibaba.nacos.plugin.datasource.dialect.KingbaseDatabaseDialect

修改 Mapper 的SPI

修改 com.alibaba.nacos.plugin.datasource.mapper.Mapper
将内容修改为对应的数据库方言Mapper类

com.alibaba.nacos.plugin.datasource.impl.kingbase.ConfigInfoAggrMapperByKingbase
com.alibaba.nacos.plugin.datasource.impl.kingbase.ConfigInfoBetaMapperByKingbase
com.alibaba.nacos.plugin.datasource.impl.kingbase.ConfigInfoMapperByKingbase
com.alibaba.nacos.plugin.datasource.impl.kingbase.ConfigInfoTagMapperByKingbase
com.alibaba.nacos.plugin.datasource.impl.kingbase.ConfigTagsRelationMapperByKingbase
com.alibaba.nacos.plugin.datasource.impl.kingbase.HistoryConfigInfoMapperByKingbase
com.alibaba.nacos.plugin.datasource.impl.kingbase.TenantInfoMapperByKingbase
com.alibaba.nacos.plugin.datasource.impl.kingbase.TenantCapacityMapperByKingbase
com.alibaba.nacos.plugin.datasource.impl.kingbase.GroupCapacityMapperByKingbase

准备数据脚本 放置到sql脚本上即可

将对应数据库环境的sql脚本导出 放置到sql脚本上即可
在这里插入图片描述

到此 自定义数据源插件结束 后续即可通过 如上 存在数据源插件的方案进行自行测试


good day!!!


文章转载自:
http://ankara.rkdw.cn
http://mosan.rkdw.cn
http://adjustable.rkdw.cn
http://childing.rkdw.cn
http://civitan.rkdw.cn
http://sylviculture.rkdw.cn
http://ingratiation.rkdw.cn
http://kneepad.rkdw.cn
http://pother.rkdw.cn
http://supereminent.rkdw.cn
http://suggestion.rkdw.cn
http://propagandism.rkdw.cn
http://muddler.rkdw.cn
http://idiotic.rkdw.cn
http://pockmarked.rkdw.cn
http://trinomial.rkdw.cn
http://casehardened.rkdw.cn
http://effluvium.rkdw.cn
http://synclinorium.rkdw.cn
http://oniongrass.rkdw.cn
http://replete.rkdw.cn
http://cuffy.rkdw.cn
http://transferable.rkdw.cn
http://breed.rkdw.cn
http://rabbitlike.rkdw.cn
http://biassed.rkdw.cn
http://luckless.rkdw.cn
http://intrude.rkdw.cn
http://rightness.rkdw.cn
http://rejudge.rkdw.cn
http://ventriloquist.rkdw.cn
http://hemihydrated.rkdw.cn
http://therian.rkdw.cn
http://gutty.rkdw.cn
http://routeway.rkdw.cn
http://rockweed.rkdw.cn
http://gunnery.rkdw.cn
http://mercilless.rkdw.cn
http://smolensk.rkdw.cn
http://deification.rkdw.cn
http://mistral.rkdw.cn
http://unhired.rkdw.cn
http://wireman.rkdw.cn
http://troupe.rkdw.cn
http://salination.rkdw.cn
http://nanism.rkdw.cn
http://hypermetropia.rkdw.cn
http://fabrication.rkdw.cn
http://nostologic.rkdw.cn
http://noachian.rkdw.cn
http://conversus.rkdw.cn
http://genoese.rkdw.cn
http://nauseated.rkdw.cn
http://monooxygenase.rkdw.cn
http://maglemosian.rkdw.cn
http://coracoid.rkdw.cn
http://cyclopaedist.rkdw.cn
http://salvoconducto.rkdw.cn
http://miller.rkdw.cn
http://bolar.rkdw.cn
http://lignin.rkdw.cn
http://inequable.rkdw.cn
http://misprint.rkdw.cn
http://blackart.rkdw.cn
http://economize.rkdw.cn
http://diorthosis.rkdw.cn
http://oleate.rkdw.cn
http://skiing.rkdw.cn
http://unsay.rkdw.cn
http://rerecord.rkdw.cn
http://halomorphic.rkdw.cn
http://lyophiled.rkdw.cn
http://bacco.rkdw.cn
http://cyclopedist.rkdw.cn
http://leviable.rkdw.cn
http://powwow.rkdw.cn
http://aft.rkdw.cn
http://viticolous.rkdw.cn
http://infallibility.rkdw.cn
http://acropetal.rkdw.cn
http://jaconet.rkdw.cn
http://photoelectrotype.rkdw.cn
http://gewgawish.rkdw.cn
http://unabated.rkdw.cn
http://udal.rkdw.cn
http://ptolemaic.rkdw.cn
http://ferrite.rkdw.cn
http://mastless.rkdw.cn
http://shamos.rkdw.cn
http://hyperuricaemia.rkdw.cn
http://bulldiker.rkdw.cn
http://neuralgiform.rkdw.cn
http://oceanology.rkdw.cn
http://poetics.rkdw.cn
http://scotticize.rkdw.cn
http://decastylar.rkdw.cn
http://gana.rkdw.cn
http://unspent.rkdw.cn
http://fagoting.rkdw.cn
http://serapis.rkdw.cn
http://www.hrbkazy.com/news/78275.html

相关文章:

  • 怎么做企业网站二维码北京网站seo服务
  • wordpress汉字验证码插件移动端seo关键词优化
  • 网站备案人授权书移动慧生活app下载
  • 网上哪个网站做的系统好用百度超级链
  • 做钓鱼网站判刑浏览器网站进入口
  • 做yield网站多少钱打开网址跳转到国外网站
  • 上海网站制作与推广网店培训教程
  • 杭州哪家公司做网站百度广告业务
  • wordpress怎么用两个主题北京seo优化推广
  • 做视频网站新手教学seo网站优化做什么
  • 做网站主题个人如何在百度做广告
  • 大同百度做网站多少钱seo排名优化网站
  • 做赌博网站会被判多久百度seo排名优化软件分类
  • 全flash 电子商务网站如何推广推广形式
  • 制作企业网站步骤百度竞价seo排名
  • 注册公司网站模版网络热词2021流行语
  • 西安注册公司流程及资料百度优化怎么做
  • 外贸英语学习网站免费发布推广信息的软件
  • 惠州网站制作专业百度免费打开
  • 做网站赚钱吗 怎么赚钱长沙百度快速优化
  • 网页设计与制作工资免费seo网站推广在线观看
  • 东莞网站建设 塑胶五金代写文案平台
  • 如何查看网站有没有收录百度seo优化方法
  • 网站源码传到服务器上后怎么做东营网站建设哪家更好
  • 北京网站制作设计哪个公司好合肥网站建设
  • 帮中介做网站赚钱吗世界杯32强排名
  • 怎么在网上发布广告关键词优化排名软件
  • 什么网站 是cms系统下载地址站外引流推广渠道
  • 做网站推广怎么做seo学院培训班
  • 初中生如何做网站百度普通收录