前言

刚学SpringCloud时使用eureka作为服务注册中心,随着网飞公司eureka2.x不再更新,以及最近在公司实习接触到的SpringCloud项目是使用Nacos来做服务注册中心的,所以决定学习一波,并记录一下。

Nacos是什么

Nacos是阿里巴巴的一个开源的SpringCloud项目的服务注册中心主键,但是Nacos又不仅仅是注册中心,同时可以做配置中心,将项目的配置文件版本化管理,Nacos可以无缝接入各大生态。很强大,马上来体验一下。

环境

  • Nacos-server:1.0.1
  • SpringCloud:Finchley.RELEASE
  • SpringBoot:2.0.6.RELEASE
  • spring-cloud-alibaba-dependencies:0.2.2.RELEASE

要注意spring-cloud-alibaba、SpringBoot、SpringCloud、Nacos-server四者之间版本的关系,避免出现版本冲突。可以参考下表:

SpringBoot SpringCloud spring-cloud-alibaba Nacos-server
2.1.x Greenwich 0.9.x 1.1.4
2.0.x Finchley 0.2.x 1.0.0
1.5.x Edgware、Dalston 0.1.x 1.0.0及以下

具体可参考:

https://blog.csdn.net/sq4521/article/details/90417562

https://github.com/alibaba/spring-cloud-alibaba/wiki/版本说明

https://www.cnblogs.com/didispace/p/10464188.html

启动Nacos-server

下载地址:https://github.com/alibaba/nacos/releases

下载解压之后进入bin文件夹双击startup.cmd启动。启动成功后在http://127.0.0.1:8848/nacos/index.html 访问控制台,默认账号密码是nacos/nacos。

创建工程

父工程

先创建nacos-modules作为父工程,主要做版本管理。pom依赖如下:

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>2.0.6.RELEASE</version>
<relativePath/> <!-- lookup parent from repository -->
</parent>
<packaging>pom</packaging>
<groupId>com.my</groupId>
<artifactId>nacos-modules</artifactId>
<version>0.0.1-SNAPSHOT</version>
<name>nacos-modules</name>
<description>Demo project for Spring Boot</description>
<properties>
<java.version>1.8</java.version>
<spring.cloud.version>Finchley.RELEASE</spring.cloud.version>
<spring.cloud.alibaba.version>0.2.2.RELEASE</spring.cloud.alibaba.version>
</properties>
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
</dependency>
</dependencies>
<dependencyManagement>
<dependencies>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-dependencies</artifactId>
<version>${spring.cloud.version}</version>
<!--相当于parent标签-->
<!--下面两行相当于引入这个pom文件,里面的dependencyManagement定义了很多依赖,我们可以选择性的继承。解决单继承问题-->
<!--因为里面的parent是cloud-parent,子工程就可以直接用cloud的东西了-->
<!--如果是引进来的pom有dependencies里面的会直接继承给子工程-->
<type>pom</type>
<scope>import</scope>
</dependency>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-alibaba-dependencies</artifactId>
<version>${spring.cloud.alibaba.version}</version>
<type>pom</type>
<scope>import</scope>
</dependency> <dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-dependencies</artifactId>
<version>${spring.boot.version}</version>
<type>pom</type>
<scope>import</scope>
</dependency>
</dependencies>
</dependencyManagement>
</project>

服务提供者

再创建一个maven工程nacos-provider,在nacos-modles把nacos-provider引进来,操作如下:

nacos-provider的pom依赖如下:

	<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<parent>
<groupId>com.my</groupId>
<artifactId>nacos-modules</artifactId>
<version>0.0.1-SNAPSHOT</version>
<relativePath/> <!-- lookup parent from repository -->
</parent>
<artifactId>nacos-provider</artifactId>
<version>0.0.1-SNAPSHOT</version>
<name>nacos-provider</name>
<description>Demo project for Spring Boot</description> <properties>
<java.version>1.8</java.version>
</properties> <dependencies>
<!--在父工程spring-cloud-alibaba-dependencies的management中有声明,所以不用版本号-->
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
</dependency>
</dependencies> <build>
<plugins>
<plugin>
<!-- 需要打包成jar的模块才需要这个插件-->
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
</plugin>
</plugins>
</build>
</project>

在启动类加@EnableDiscoveryClient启动服务注册发现功能。

@SpringBootApplication
@EnableDiscoveryClient
public class NacosConsumerApplication { public static void main(String[] args) {
SpringApplication.run(NacosConsumerApplication.class, args);
}
}

创建配置文件application.yml

server:
port: 8000
spring:
application:
name: nacos-provider
cloud:
nacos:
discovery:
server-addr: localhost:8848

创建一个controller提供服务

@RestController
@RequestMapping("/test")
public class testController { @GetMapping("/hello")
public String sayHello() {
return "雷猴啊";
}
}

服务消费者

再创建一个服务消费者,步骤与创建服务提供者一样。

pom如下:

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<parent>
<groupId>com.my</groupId>
<artifactId>nacos-modules</artifactId>
<version>0.0.1-SNAPSHOT</version>
<relativePath/> <!-- lookup parent from repository -->
</parent>
<artifactId>nacos-consumer</artifactId>
<version>0.0.1-SNAPSHOT</version>
<name>nacos-consumer</name>
<description>Demo project for Spring Boot</description> <properties>
<java.version>1.8</java.version>
</properties> <dependencies>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-alibaba-nacos-discovery</artifactId>
</dependency>
</dependencies> <build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
</plugin>
</plugins>
</build>
</project>

配置文件:

server:
port: 8010
spring:
application:
name: nacos-consumer
cloud:
nacos:
discovery:
server-addr: localhost:8848

RestTemplate+Ribbon服务调用

@RestController
@RequestMapping("/test")
public class controller { @Autowired
private RestTemplate restTemplate; @Bean
@LoadBalanced
public RestTemplate getRestTemplate() {
return new RestTemplate();
} @GetMapping("/hello")
public String sayHello() {
return restTemplate.getForObject("http://nacos-provider/test/hello", String.class);
}
}

feign方式服务调用

在实际开发,服务调用用的更多的还是Feign,Feign内部集成了Ribbon和Hystrix,使用起来更加方便好用。

  1. 在nacos-consumer添加依赖:
        <dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-openfeign</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-netflix-hystrix</artifactId>
</dependency>
  1. 添加配置开启Hystrix

    feign:
    hystrix:
    enabled: true
  2. 启动类加@EnableFeignClients注解,开启Feign。

  3. 创建Feign接口

    name为调用的服务名,path是url前缀,fallback是熔断调用的类

@FeignClient(name = "nacos-provider",path = "/test",fallback = MyHystrix.class)
public interface TestFeignClient {
@GetMapping("/hello")
String sayHello();
}
  1. 创建Hystrix熔断和降级处理的类
@Component
public class MyHystrix implements TestFeignClient {
@Override
public String sayHello() {
return "服务超时";
}
}
  1. controller
@RestController
@RequestMapping("/feign/test")
public class FeignController {
@Autowired
TestFeignClient testFeignClient; @GetMapping("/hello")
public String sayHello() {
return testFeignClient.sayHello();
}
}

启动项目

启动nacos-provider和nacos-consumer,成功的话可以在nacos控制台看到:

测试

http://localhost:8010/feign/test/hello

http://localhost:8010/test/hello

模拟异常,降级处理

  1. 修改服务提供者

    @RestController
    @RequestMapping("/test")
    public class testController { @GetMapping("/hello")
    public String sayHello() {
    int i=1/0;
    return "雷猴啊";
    }
    }
  2. 结果

总结

这次是使用Nacos作为注册中心,我们上面说到,Nacos不仅仅可以做注册中心,还能做配置中心,我们下一次就来试一下用Nacos做配置中心。

Nacos笔记01——使用Nacos作为SpringCloud项目的服务注册中心的更多相关文章

  1. 【springcloud】Eureka服务注册中心搭建

    转自:https://blog.csdn.net/pengjunlee/article/details/86538997 Spring Cloud是一系列框架的集合,它利用Spring Boot的开发 ...

  2. 搭建简单的SpringCloud项目一:注册中心和公共层

    注:笔者在搭建途中其实遇见不少问题,统一放在后面的文章说明,现在的搭建是测试OK的. GitHub:https://github.com/ownzyuan/test-cloud 后续:搭建简单的Spr ...

  3. SpringCloud大白话之服务注册中心

    SpringCloud-Eureka白话说明 eureka.client.register-with-eureka 属性表示是否将自己注册到Eureka Server, 默认为true. 由于当前应用 ...

  4. 学习一下 SpringCloud (二)-- 服务注册中心 Eureka、Zookeeper、Consul、Nacos

    (1) 相关博文地址: 学习一下 SpringCloud (一)-- 从单体架构到微服务架构.代码拆分(maven 聚合): https://www.cnblogs.com/l-y-h/p/14105 ...

  5. 学习一下 SpringCloud (六)-- 注册中心与配置中心 Nacos、网关 Gateway

    (1) 相关博文地址: 学习一下 SpringCloud (一)-- 从单体架构到微服务架构.代码拆分(maven 聚合): https://www.cnblogs.com/l-y-h/p/14105 ...

  6. Nacos作为微服务注册中心,爱不释手的感觉

    我觉得Nacos用起来还不错 在使用SpringCloud做分布式微服务架构时,注册中心是必不可少的一个组件.目前可以用的主要有:Eureka.Consul.Zookeeper.今天,我们就来说一下A ...

  7. Spring Cloud Alibaba系列(一)nacos作为服务注册中心

    Spring Cloud Alibaba各组件版本关系 Spring Cloud Alibaba Version Sentinel Version Nacos Version RocketMQ Ver ...

  8. springcloud 笔记-服务注册中心

    1.搭建springcloud服务注册中心需要添加eureka的依赖: <?xml version="1.0" encoding="UTF-8"?> ...

  9. [SpringCloud教程]3. Eureka服务注册中心集成

    新微服务项目多半采用Nacos作为服务注册与发现中心,但是旧项目可能使用Eureka.zookeeper.Consul.Nacos作为服务注册中心. 新项目建议使用Nacos作为服务注册中心 Spri ...

随机推荐

  1. SpringMVC:HandlerInterceptor log 日志

    springMVC:HandlerInterceptor拦截器添加系统日志(权限校验)代码收藏 - LinkcOne - CSDN博客https://blog.csdn.net/qq_22815337 ...

  2. Dart匿名方法函数和闭包

    /* 内置方法/函数: print(); 自定义方法: 自定义方法的基本格式: 返回类型 方法名称(参数1,参数2,...){ 方法体 return 返回值; } */ void printInfo( ...

  3. 十一、LoadRunner组成和工作原理

    一.LoadRunner组成 虚拟用户发生器:Vuser Generator 压力调度和监控中心:Controller 压力生产器:Load Generator 压力结果分析工具:Analysis

  4. 实战c++中的string系列--std:vector 和std:string相互转换(vector to stringstream)

    string.vector 互转 string 转 vector vector  vcBuf;string        stBuf("Hello DaMao!!!");----- ...

  5. netty5服务端检测心跳超时断连

    客户端每5秒发送一次心跳给服务端,服务端记录最后一次心跳时间,通过定时任务每10秒检测一下,如果当前时间与最后一次收到的心跳时间之差超过某个阈值,断开与客户端的连接.基于之前的例子(netty5心跳与 ...

  6. 算法习题---5.9数据库(Uva1592)

    一:题目 对数据库中数据进行检测,是否出现数据冗余现象.即是否某一列出现两个及以上数据重复 如上图中,第二列中第2,3行数据重复,所以我们判断为数据冗余.因为他可以分解为下面两张表 (一)样例输入 H ...

  7. 通过直方图进行PCA准备

    import graphviz import mglearn from mpl_toolkits.mplot3d import Axes3D from sklearn.datasets import ...

  8. Debugging Kafka connect

    1. setup debug configuration mainClass: org.apache.kafka.connect.cli.ConnectDistributed VMOption: -D ...

  9. 《Learning a Discriminative Feature Network for Semantic Segmentation》解读

    旷世18年的CVPR,论文链接:https://arxiv.org/abs/1804.09337 Motivation:针对分割中的“类内不一致”和“类间一致性”的两大问题,设计了结合Smooth n ...

  10. SpringBoot中日志配置

    背景 由于一些框架中还使用log4j-1.x系列陈旧的日志框架,调试过程中有一些错误信息不能在控制台显示,增加了调试成本.以下配置方法 将帮助你获得log4j-1.x日志在控制台显示. 解决方法: 使 ...