基于Dubbo和Nacos搭建微服务的配置中心和服务注册中心

这篇具有很好参考价值的文章主要介绍了基于Dubbo和Nacos搭建微服务的配置中心和服务注册中心。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

1.SpringCloud Alibaba接入Nacos&restTemplate

1.添加nacos依赖

<dependency>
    <groupId>com.alibaba.cloud</groupId>
    <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
    <version>${latest.version}</version>
</dependency>

2.配置application.properties

spring:
  application:
    name: {应用名称}
  cloud:
    nacos:
      discovery:
        server-addr: 111.52.99.114:18848
        username: nacos
        password: nacos

PS:nacos2.0除了需要8848的端口之外,还新增了端口+1000的新端口用于客户端和服务端GRPC通信的端口,所以如果是自己部署的nacos需要放开这俩个端口,服务才可以启动成功。

3.配置类

3.1 添加Spring Cloud原生注解 @EnableDiscoveryClient

3.2 客户端服务使用@LoadBalanced做负载均衡调用

@LoadBalanced
@Bean
public RestTemplate restTemplate(){
    return new RestTemplate();
}

PS:使用@LoadBalanced需要引入负载均衡器的实现才能生效。

<dependency>
 <groupId>org.springframework.cloud</groupId>
 <artifactId>spring-cloud-starter-loadbalancer</artifactId>
</dependency>

3.3 通过restTemplate调用

​
@RequestMapping(value = "mappingURL", method = RequestMethod.GET)
public String echo(@PathVariable String str) {
    return restTemplate.getForObject("http://{服务提供者-服务名}/echo/" + str, String.class);
}

4.nacos控制台

服务注册成功,nacos控制台可以看到服务列表,服务调用正常。如图:

dubbo nacos配置中心,dubbo,微服务,java,spring cloud

2.Dubbo2.7集成Nacos2.0

1.添加依赖

<dependency>
    <groupId>org.apache.dubbo</groupId>
    <artifactId>dubbo</artifactId>
    <version>2.7.15</version>
</dependency>
<dependency>
    <groupId>org.apache.dubbo</groupId>
    <artifactId>dubbo-spring-boot-starter</artifactId>
    <version>2.7.15</version>
</dependency>
<dependency>
    <groupId>com.alibaba.nacos</groupId>
    <artifactId>nacos-client</artifactId>
    <version>2.0.2</version>
</dependency>

2.Dubbo&Nacos配置

dubbo:
  application:
    version: 1.0.0
    name: service-provider
  registry:
    address: nacos://111.52.99.114:18848?username=nacos&password=nacos
  protocol:
    name: dubbo
    port: -1
  provider:
    timeout: 30000

💖:对于需要认证的nacos,使用url拼接用户名密码。

3.启动类注解

@EnableDubbo(scanBasePackages = "cn.bingo.lottery")
@SpringBootApplication
public class DempApplication {
    public static void main(String[] args) {
        SpringApplication.run(DempApplication.class,args);
    }
}

4.服务导出和服务引用

//服务导出
@DubboService(version = "1.0.0",interfaceClass = IActivityBooth.class,retries = 0)
public class ActivityBooth implements IActivityBooth {

}
//服务引用
@DubboReference(version = "1.0.0",timeout =3000 )
private IActivityBooth activityBooth;

5.控制台服务列表

服务注册成功,nacos控制台可以看到服务列表,服务调用正常。如图:

dubbo nacos配置中心,dubbo,微服务,java,spring cloud

3.SpringCloud Alibaba接入Nacos&Dubbo

1.添加nacos依赖

<dependency>
            <groupId>com.alibaba.cloud</groupId>
            <artifactId>spring-cloud-starter-dubbo</artifactId>
            <exclusions>
                <exclusion>
                    <groupId>com.alibaba.nacos</groupId>
                    <artifactId>nacos-client</artifactId>
                </exclusion>
                <exclusion>
                    <groupId>org.apache.dubbo</groupId>
                    <artifactId>dubbo</artifactId>
                </exclusion>
            </exclusions>
        </dependency>
        <dependency>
            <groupId>com.alibaba.cloud</groupId>
            <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
            <exclusions>
                <exclusion>
                    <groupId>com.alibaba.nacos</groupId>
                    <artifactId>nacos-client</artifactId>
                </exclusion>
            </exclusions>
        </dependency>
        <dependency>
            <groupId>org.apache.dubbo</groupId>
            <artifactId>dubbo</artifactId>
            <exclusions>
                <exclusion>
                    <artifactId>spring-context</artifactId>
                    <groupId>org.springframework</groupId>
                </exclusion>
            </exclusions>
        </dependency>
        <dependency>
            <groupId>com.alibaba.nacos</groupId>
            <artifactId>nacos-client</artifactId>
        </dependency>

2.配置application.properties

dubbo.application.name=service-provider
dubbo.scan.base-packages=cn.service.test.api

spring:
  application:
    name: {应用名称}
  cloud:
    nacos:
      discovery:
        server-addr: 111.52.99.114:18848
        username: nacos
        password: nacos

3.服务导出和服务引用

//服务引用
@DubboReference(version = "1.0.0",retries = 0)
private ProductApi productApi;
//服务导出
@DubboService(version = "1.0.0",interfaceClass = ProductApi.class,retries = 0)
@Slf4j
public class ProductApiImpl  implements ProductApi {}

4.nacos控制台

可以看到这种接入,dubbo2.0的接口级对齐了springcloud的服务级。

dubbo nacos配置中心,dubbo,微服务,java,spring cloud文章来源地址https://www.toymoban.com/news/detail-599030.html

到了这里,关于基于Dubbo和Nacos搭建微服务的配置中心和服务注册中心的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • nacos2.1.1版本,作为注册中心,配置中心如何使用,nacos服务端启动,微服务搭建,nacos集群化部署

    关于nacos 相信大多数人一样,在接触微服务的时候知道有Netflix系列和alibaba系列 但是Netflix这一套如今由于部分组件不在开源,又有alibaba这一套的出现,市面上,alibaba系列微服务架构已经是最火热的了,而nacos则是alibaba系列组件充当服务注册发现和配置中心的角色 说白了,就是将每个

    2024年02月03日
    浏览(49)
  • Dubbo3使用Zookeeper作为注册中心的方案讨论!详解DubboAdmin与PrettyZoo来监控服务的优劣!

    文章目录 一:Dubbo注册中心的基本使用 二:Zookeeper注册中心的使用 1:依赖引入 2:实际开发 三:Zookeeper作为注册中心的使用展示 1:启动注册Zookeeper服务 2:引入注册中心 (一):Provider (二):Consumer 3:启动服务结果展示 4:监控服务的两种手段         我们使用的和分析讲解

    2024年02月05日
    浏览(41)
  • Dubbo引入Zookeeper等注册中心简介以及DubboAdmin简要介绍,为后续详解Dubbo各种注册中心做铺垫!

    文章目录 一:Dubbo注册中心引言 1:什么是Dubbo的注册中心? 2:注册中心关系图解 3:引入注册中心服务执行流程 4:Dubbo注册中心好处 5:注册中心核心作用 二:注册中心实现方案 1:早期 2:当前现状 三:DubboAdmin介绍 1:DubboAdmin简介 2:DubboAdmin的主要功能         Dubbo注册

    2024年02月05日
    浏览(45)
  • DUBBO注册中心

    providers: 服务提供者目录,记录着服务提供者的ip、端口等信息。 consumers: 服务消费者目录,记录服务消费者的元数据信息,服务提供者并不会用到服务消费者的信息,这里要记录消费者的信息,是给服务治理中心(dubbo-admin)使用的。 routers: 用于消费者路由策略元数据信息。

    2023年04月14日
    浏览(35)
  • 基于Kubernetes(k8s)部署Dubbo+Nacos服务

    本文介绍基于 Kubernetes(k8s) 环境集成阿里云 私有镜像仓库 来部署一套 Dubbo + Nacos 的微服务系统,并使用 Kubernetes DNS 以及 port-forward 的方式来打通网络访问。 k8s环境搭建参考文章《基于minikube快速搭建kubernetes单节点环境》 中在阿里云镜像仓库构建的镜像来进行部署。 基于《基

    2024年02月02日
    浏览(38)
  • Dubbo(六):zookeeper注册中心的应用

    Dubbo中有一个非常本质和重要的功能,那就是服务的自动注册与发现,而这个功能是通过注册中心来实现的。而dubbo中考虑了外部许多的注册组件的实现,zk,redis,etcd,consul,eureka… 各自实现方式各有不同,但是对外表现都是一致的:都实现了 Registry 接口! 今天我们就来看看最常

    2024年02月22日
    浏览(43)
  • 从0到1搭建spring cloud alibaba +springboot+nacos+dubbo微服务

      由以上版本对应关系:         springboot版本:2.3.2.RELEASE         spring cloud 版本选择:Hoxton.SR9         spring cloud alibaba版本选择:2.2.6.RELEASE 父工程的父工程:()  版本依赖关系:            其他业务模块依赖: 使用nacos做配置中心和注册中心+dubbo做RPC调用 配置文

    2024年02月11日
    浏览(37)
  • SpringCloud | Dubbo 微服务实战——注册中心详解

    前些天发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,忍不住分享一下给大家 :https://www.captainbed.cn/z chatgpt体验地址 在项目开发过程中,随着项目不断扩大,也就是业务的不断增多,我们将采用集群,微服务的形式去降低配置,集群是指将一个项目部署到多个服

    2024年02月05日
    浏览(45)
  • Dubbo 应用切换 ZooKeeper 注册中心实例,流量无损迁移

    首先思考一个问题:如果 Dubbo 应用使用 ZooKeeper 作为注册中心,现在需要切换到新的 ZooKeeper 实例,如何做到流量无损? 本文提供解决这个问题的一种方案。 有两个基于 Dubbo 的微服务应用,一个是服务提供者,简称 Provider,另一个是服务消费者,简称 Consumer; 使用 ZooKeepe

    2024年02月10日
    浏览(37)
  • 在项目中同时使用SpringCloud和Dubbo,注册中心选用Eureka?

    在pom.xml文件中添加Dubbo相关依赖:服务提供者和服务消费者都需要 1)配置服务提供者 1、在配置文件中配置Dubbo的相关信息: 2、在服务提供者的启动类上添加@EnableDubbo注解: 3、编写服务提供者的接口和实现类: 添加@Service,指定interfaceClass属性来指定要暴露的接口 2)配置

    2024年01月18日
    浏览(47)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包