什么是nacos?
Nacos 支持基于 DNS 和基于 RPC 的服务发现(可以作为springcloud的注册中心)、动态配置服务(可以做配置中心)、动态 DNS 服务。
官方介绍是这样的:
Nacos 致力于帮助您发现、配置和管理微服务。Nacos 提供了一组简单易用的特性集,帮助您实现动态服务发现、服务配置管理、服务及流量管理。
Nacos 帮助您更敏捷和容易地构建、交付和管理微服务平台。 Nacos 是构建以“服务”为中心的现代应用架构(例如微服务范式、云原生范式)的服务基础设施。
官网地址
众所周知 分布式中有CAP之说 C 一致性 A高可用 P 分布式
CAP中只能选择两个,加之P是必选的,所以分布式又分为两大类 -> CP AP
Nacos 可以切换AP和CP两种方式,并且nacos集成了config,Ribbon等等的东西,就不需要每一个得去单独配置了
在项目开始搭建之前我们需要去阿里nacos的官网下载对应版本的nacos并运行起来
nacos下载官网页面
== 下载下来之后==
1.解压
2.进入bin目录运行
运行成功之后访问http://ip:8848如果能看到一下页面就代表运行成功
现在我们来搭建一个基于nacos的springcloud alibaba
项目的基本结构如下图
在最外面的包的maven
<?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 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>org.example</groupId>
<artifactId>SpringCloudAlibaba</artifactId>
<version>1.0-SNAPSHOT</version>
<packaging>pom</packaging>
<properties>
<java.version>1.8</java.version>
<spring-boot.version>2.2.2.RELEASE</spring-boot.version>
<spring-cloud.version>Finchley.RELEASE</spring-cloud.version>
<nacos.version>2.1.0.RELEASE</nacos.version>
<spring-cloud-alibaba.version>2.2.0.RELEASE</spring-cloud-alibaba.version>
</properties>
<modules>
<module>pamanet-boot</module>
<module>consumer-boot</module>
</modules>
<!-- 子模块继承之后提供作用 锁定版本 子model不用写groupid和version-->
<dependencyManagement>
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-dependencies</artifactId>
<version>${spring-boot.version}</version>
<type>pom</type>
<scope>import</scope>
</dependency>
<dependency>
<groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-alibaba-depe