SpringCloudAlibaba微服务实战系列(一)Nacos服务注册发现

这篇具有很好参考价值的文章主要介绍了SpringCloudAlibaba微服务实战系列(一)Nacos服务注册发现。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

SpringCloudAlibaba微服务实战系列(一)Nacos服务注册发现

实战前先做一个背景了解。

单体架构、SOA和微服务

单体架构:近几年技术的飞速发展,各种各样的服务已经进入到网络化。单体架构发布时只需要打成一个war或jar包发布即可;而随着业务量激增或网站流量的增加,必会暴露致命缺陷。

SOA:Service Oriented Architecture 面向服务的体系结构。旨在提升代码复用性及扩展性,降低耦合等。 如一个外卖流程,分配送餐是一个服务,短信通知也是一个服务。这些服务独立部署,通过网络互相调用(HTTP等方式),形成完整的服务系统。

微服务:微服务是由多个功能单一的小服务组成的,服务可以根据业务进行拆分;这些服务独立部署;不同的服务可以采用不同的技术(不同的变成语言或数据库等);服务之间采用HTTP等轻量协议进行交互传输数据,可看成是更细粒度的SOA架构。

微服务优缺点

优点:

  • 代码复杂度低:根据业务细粒度划分,业务功能明确清晰,体积小,便于理解和维护
  • 技术选型不被限制:单个服务可根据自身的业务选择不同的语言和技术栈实现
  • 独立部署:部署的影响范围小
  • 服务可伸缩性:某些服务的承载量大时,可多部署几个节点负载,承载量小时,可减少几个节点节省服务器资源
  • 错误隔离:多服务中,一个服务的宕机不会影响整个系统的运行
  • 分库更容易:不同服务连接不同的数据库

缺点:

  • 架构系统复杂:不是简单的服务调用,要充分考虑网络延迟和故障带来的影响,必要时可能需要采用消息中间件
  • 服务依赖:如A服务调B,然后B调C,当C服务变更时,B和A都需要进行改动
  • 数据一致性问题:典型的分布式事务的问题
  • 接口排错困难:多个服务时,需要同时查看它们的log日志
  • 部署和运维:检查和监控多个服务的健康状态,快速部署、根据服务负载进行服务动态伸缩都是不小的挑战

SpringCloud技术栈

那为了更好的管理微服务,SpringCloud技术诞生了。常用技术栈实现:

技术栈 技术栈落地实现
服务注册和发现 Eureka、Zookeeper、Consul、Nacos
熔断、降级、限流 Hystrix、Sentinel
服务调用 Ribbon、LoadBalancer、Feign、OpenFeign、Dubbo
配置 Config、Zookeeper、Consul、Nacos
网关 Zuul、Gateway
消息总线 Bus、Nacos

以上的技术实现方案有SpringCloudNetflix的也有SpringCloudAlibaba的。此系列我们只使用Alibaba的。

以下技术栈:

  • Nacos:做配置和服务注册发现
  • RocketMQ:阿里的分布式消息中间件,提供可靠的消息发布和订阅
  • Sentinel:做服务限流、降级、熔断功能
  • Seata:解决分布式事务问题(保证数据的一致性)

开始实战

环境

在实战前先确保我们的开发环境:

  • java8
  • maven
  • IDEA工具
  • mysql 5.7及以上

注意:IDEA中如果和Maven的版本不匹配会报错,Unable to import maven project,自己调整下版本吧

SpringBoot起步

在创建一个项目时,首先要注意的就是和SpringCloud和Alibaba的版本是否兼容,看一下SpringBoot和cloud的版本兼容

SpringCloudAlibaba微服务实战系列(一)Nacos服务注册发现,SpringBoot,SpringCloud,Java,架构,spring cloud,nacos

到spring官网或者阿里云的网页创建项目都可以。先创建一个项目导入到IDEA中吧

SpringCloudAlibaba微服务实战系列(一)Nacos服务注册发现,SpringBoot,SpringCloud,Java,架构,spring cloud,nacos

导入后将SpringBoot版本改为2.6.11的即可

然后再创建子module(服务者和消费者),在父工程主要做版本依赖管理:

<properties>
   <java.version>8</java.version>
   <boot.version>2.6.11</boot.version>
   <cloud.version>2021.0.4</cloud.version>
   <cloud.alibaba.version>2021.0.4.0</cloud.alibaba.version>
</properties>

<dependencyManagement>
    <dependencies>
        <!--springboot依赖-->
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-dependencies</artifactId>
            <version>${boot.version}</version>
            <type>pom</type>
            <scope>import</scope>
        </dependency>
        <!--cloud的依赖-->
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-dependencies</artifactId>
            <version>${cloud.version}</version>
            <type>pom</type>
            <scope>import</scope>
        </dependency>
        <!--cloud.alibaba依赖-->
        <dependency>
            <groupId>com.alibaba.cloud</groupId>
            <artifactId>spring-cloud-alibaba-dependencies</artifactId>
            <version>${cloud.alibaba.version}</version>
            <type>pom</type>
            <scope>import</scope>
        </dependency>
    </dependencies>
</dependencyManagement>

<build>
   <plugins>
      <!--指定Maven的插件,和编译的jdk版本,若不指定maven3默认使用jdk1.5-->
      <plugin>
         <groupId>org.apache.maven.plugins</groupId>
         <artifactId>maven-compiler-plugin</artifactId>
         <version>3.7.0</version>
         <configuration>
            <source>1.8</source>   <!--源代码使用的jdk版本-->
            <target>1.8</target>   <!--编译后生成的class文件的版本-->
            <encoding>UTF-8</encoding> <!--字符编码集-->
         </configuration>
      </plugin>
   </plugins>
</build>

nacos的安装和配置

注意:nacos需要依赖jdk环境,必须是1.8及以上的版本

nacos的下载页面:https://github.com/alibaba/nacos/releases

SpringCloudAlibaba微服务实战系列(一)Nacos服务注册发现,SpringBoot,SpringCloud,Java,架构,spring cloud,nacos

瞅好对应的版本关系下载即可。

下载完毕后,cmd命令窗口启动即可。

注:如果下载的时2.2.1及以上版本的,nacos把默认的密钥给设置为空了,需要我们手动给添加上,然后在启动

在nacos的配置文件application.properties中

nacos.core.auth.plugin.nacos.token.secret.key=SecretKey012345678901234567890123456789012345678901234567890123456789

启动nacos

startup.cmd -m standalone

启动完成后,登录nacos的网址看下http://localhost:8848/nacos,默认的用户名和密码都是nacos。

SpringCloudAlibaba微服务实战系列(一)Nacos服务注册发现,SpringBoot,SpringCloud,Java,架构,spring cloud,nacos

简单集成nacos

创建三个子工程,分别是provider8001provicer-8002consumer9001,然后注册进入nacos后,通过Ribbon实现远程调用。

工程结构如图,3个工程都引入健康监控和nacos的服务注册发现

SpringCloudAlibaba微服务实战系列(一)Nacos服务注册发现,SpringBoot,SpringCloud,Java,架构,spring cloud,nacos

以consumer项目为例的配置文件

server:
  port: 8001
spring:
  application:
    name: provider # 应用名

  cloud:
    nacos:
      discovery:
        server-addr: localhost:8848 # nacos服务地址

图例:

SpringCloudAlibaba微服务实战系列(一)Nacos服务注册发现,SpringBoot,SpringCloud,Java,架构,spring cloud,nacos

启动类及注解:

@SpringBootApplication
@EnableDiscoveryClient
public class ProviderApplication {

    public static void main(String[] args) {
        SpringApplication.run(ProviderApplication.class, args);
    }
}

启动三个项目查看nacos服务页的变化。
SpringCloudAlibaba微服务实战系列(一)Nacos服务注册发现,SpringBoot,SpringCloud,Java,架构,spring cloud,nacos

服务已经注册,且provider的实例是两个,莫得问题~

采用RestTemplate+Ribbon实现简单远程调用

服务提供者提供接口(两个提供者都写上)

@RestController // @RestController注解是@Controller+@ResponseBody
public class TestController {
    @Value("${server.port}")
    private String port; // 获取配置文件中写的程序端口号
    @RequestMapping("/test") // 标记是该方法的请求
    public String test() {
        return "hello world test " + port;  // 返回值是一个字符串,因为用了@RestController所以不必额外加@ResponseBody了
    }
}

消费者还需要引入loadbalancer的依赖,高版本中需要自己手动引入

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

服务消费者采用JavaConfig的方式将配置类做好,代码如下:

@Configuration
public class GenericConfiguration { // 常规配置类
    @LoadBalanced // 标注此注解后,RestTemplate就具有了客户端负载均衡能力
    @Bean
    public RestTemplate restTemplate(){ // 创建RestTemplate,并交个Spring容器管理
        return new RestTemplate();
    }
}

消费者调用接口

@RestController
public class TestController {

    private final String SERVER_URL = "http://provider"; // 这里的服务地址填写注册到Nacos的应用名称
    @Resource
    private RestTemplate restTemplate;
    @RequestMapping("/test")  // 标记是该方法的请求
    public String test() {
        return restTemplate.getForObject(SERVER_URL + "/test", String.class);//调用提供者/test接口
    }

}

启动项目测试调用执行:

curl localhost:9001/test

SpringCloudAlibaba微服务实战系列(一)Nacos服务注册发现,SpringBoot,SpringCloud,Java,架构,spring cloud,nacos

可看到远程调用以及简单的负载实现效果。文章来源地址https://www.toymoban.com/news/detail-609759.html

到了这里,关于SpringCloudAlibaba微服务实战系列(一)Nacos服务注册发现的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

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

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

相关文章

  • SpringCloudAlibaba微服务实战系列(四)Sentinel熔断降级、异常fallback、block细致处理

    接着上篇文章的内容,在Sentinel中如何进行降级和熔断呢? 降级规则 在Sentinel中降级主要有三个策略:RT、异常比例、异常数,也是针对某个资源的设置。而在 1.8.0+ 版本后RT改为了 慢调用比例 需要设置允许的慢调用 RT(即最大的响应时间),请求的响应时间大于该值则统计

    2024年02月16日
    浏览(34)
  • springCloudAlibaba组件-Nacos-服务发现与负载均衡(三)

    如果项目使用微服务架构,如果A微服务需要访问B微服务,需要http请求进行调用,当然需要B微服务的地址与端口号,微服务可以向之前提到的服务中心进行获取B服务的ip地址和端口号,这就是服务发现 1.客户端主动获取 客户端: 流程: 1.先是故障转移机制判断是否去本地文

    2024年02月10日
    浏览(36)
  • Asp .Net Core 系列:集成 Ocelot+Nacos+Swagger+Cors实现网关、服务注册、服务发现

    什么是 Ocelot ? Ocelot是一个开源的ASP.NET Core微服务网关,它提供了API网关所需的所有功能,如路由、认证、限流、监控等。 Ocelot是一个简单、灵活且功能强大的API网关,它可以与现有的服务集成,并帮助您保护、监控和扩展您的微服务。 以下是Ocelot的一些主要功能: 路由管理

    2024年01月19日
    浏览(48)
  • 【微服务 SpringCloudAlibaba】实用篇 · Nacos注册中心

    微服务(5) 国内公司一般都推崇阿里巴巴的技术,比如注册中心,SpringCloudAlibaba也推出了一个名为Nacos的注册中心。 而我们现在差不多在学习SpringCloudAlibaba了,它与SpringCloud的关系就有点像SpringBoot与SpringMVC,SpringBoot引入SpringWeb框架就可以说是SpringMVC项目了,也可以说还是

    2024年02月08日
    浏览(30)
  • SpringCloudAlibaba微服务 【实用篇】| Nacos注册中心

    目录 一:Nacos注册中心 1. 认识和安装Nacos 2. Nacos快速入门 3. Nacos服务分级存储模型 ①Nacos服务分级存储模型 ②NacosRule负载均衡  ③根据权重负载均衡 4. Nacos环境隔离 二:Nacos和Eureka的对比 tips :前些天突然发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,忍不住

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

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

    2024年02月05日
    浏览(29)
  • 云原生微服务实战 Spring Cloud Alibaba 之 Nacos

    第一章 Java线程池技术应用 第二章 CountDownLatch和Semaphone的应用 第三章 Spring Cloud 简介 第四章 Spring Cloud Netflix 之 Eureka 第五章 Spring Cloud Netflix 之 Ribbon 第六章 Spring Cloud 之 OpenFeign 第七章 Spring Cloud 之 GateWay 第八章 Spring Cloud Netflix 之 Hystrix 第九章 代码管理gitlab 使用 第十章 Spr

    2024年02月08日
    浏览(41)
  • Nacos:服务的注册、发现和配置中心(注册篇)

    Nacos 是阿里巴巴推出来的一个新开源项目,这是一个更易于构建云原生应用的动态服务发现、配置管理和服务管理平台。 Nacos 致力于帮助您发现、配置和管理微服务。Nacos 提供了一组简单易用的特性集,帮助您快速实现动态服务发现、服务配置、服务元数据及流量管理。 N

    2024年02月15日
    浏览(35)
  • 微服务·架构组件之服务注册与发现-Nacos

    Nacos服务注册与发现流程 服务注册:Nacos 客户端会通过发送REST请求的方式向Nacos Server注册自己的服务,提供自身的元数据,比如ip地址、端口等信息。 Nacos Server接收到注册请求后,就会把这些元数据信息存储在一个双层的内存Map中。 服务心跳:在服务注册后,Nacos Client会维

    2024年02月02日
    浏览(37)
  • 微服务 – Spring Cloud – Nacos服务注册、发现

    1、引入依赖 父pom依赖 子pom依赖 2、配置文件 3、主启动类 第三部完成 打开nacos 在服务列表即可看到注册进来的服务. 4、业务类 写一个接口供服务发现者使用 1、引入依赖 2、配置文件 3、主启动类 打开nacos 在服务列表即可看到注册进来的服务. 4、发现第一个服务 并调用第一

    2024年02月11日
    浏览(42)

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

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

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

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

二维码1

领取红包

二维码2

领红包