速通springcloud--01nacos

创建微服务工程

cloud-demo
|__services
    |__service-product
    |__service-order

1.创建父项目

创建一个名为cloud-demo的springboot父项目,用于对springboot,springcloud,springcloud alibaba版本锁定

<packaging>pom</packaging>
<properties>
    <java.version>17</java.version>
    <maven.compiler.source>17</maven.compiler.source>
    <maven.compiler.target>17</maven.compiler.target>
    <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
    <spring-cloud.version>2023.0.3</spring-cloud.version>
    <spring-cloud-alibaba.version>2023.0.3.2</spring-cloud-alibaba.version>
</properties>
<!-- 这里使用dependencyManagement来进行依赖管理 -->
<!-- 即让子模块需要显式声明依赖,不用指定version或scope -->
<dependencyManagement>
    <dependencies>
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-dependencies</artifactId>
            <version>${spring-cloud.version}</version>
            <type>pom</type>
            <scope>import</scope>
        </dependency>
        <dependency>
            <groupId>com.alibaba.cloud</groupId>
            <artifactId>spring-cloud-alibaba-dependencies</artifactId>
            <version>${spring-cloud-alibaba.version}</version>
            <type>pom</type>
            <scope>import</scope>
        </dependency>
    </dependencies>
</dependencyManagement>

2.创建微服务管理子项目

创建一个名为services的普通maven项目该子项目继承自cloud-demo项目,其管理了所有微服务的公共依赖

<packaging>pom</packaging>

<dependencies>
    <!--注册中心-->
    <dependency>
        <groupId>com.alibaba.cloud</groupId>
        <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
    </dependency>
    <!--远程调用-->
    <dependency>
        <groupId>org.springframework.cloud</groupId>
        <artifactId>spring-cloud-starter-openfeign</artifactId>
    </dependency>
</dependencies>

3.创建微服务子项目

创建名为service-product,service-order的普通maven子项目。这两个项目都是services项目的子项目,是微服务项目

Nacos

官网:https://nacos.io/docs/latest/overview/

它是一个能更易于构建云原生应用的动态服务发现、配置管理和服务管理平台。可以实现服务发现和服务健康检测,动态配置服务,动态DNS服务,服务以及元数据管理

对于windows平台的nacos在官网下载并解压后可以在nacos/bin目录通过startup.cmd -m standalone以单机状态启动nacos

服务注册

  1. 启动nacos
    1. nacos/bin目录通过startup.cmd -m standalone以单机状态启动nacos
  2. 启动微服务
    1. 由于所有微服务模块都继承自cloud-demo,那么其本身也是boot项目
    2. 直接在微服务模块中导入spring-boot-starter-web依赖即可实现web开发
    3. 创建一个boot的启动类
    4. 编写一个配置文件,在其中配置应用名(会在服务中心显示为服务名),端口号,nacos地址
  3. 引入服务发现依赖
    1. spring-cloud-starter-alibaba-nacos-discovery
    2. 该依赖是所有微服务模块的公共依赖,故在service-product模块中导入
  4. 配置nacos地址
    1. spring.cloud.nacos.server-addr=127.0.0.1:8848
  5. 查看注册中心
### 介绍 - **spring-cloud-starter-alibaba-nacos-config**:这是 Spring Cloud Alibaba 提供的用于集成 Nacos 配置中心的启动器。Nacos 配置中心可以实现应用配置的集中管理,方便在不同环境下对配置进行动态调整,比如修改数据库连接信息、日志级别等,而无需重新部署应用。 - **spring-cloud-starter-alibaba-nacos-discovery**:是 Spring Cloud Alibaba 提供的用于集成 Nacos 服务发现的启动器。Nacos 服务发现可以让服务之间相互发现和调用,实现微服务架构中的服务注册与发现功能,提高系统的可扩展性和灵活性。 ### 使用方法 #### spring-cloud-starter-alibaba-nacos-config 1. **添加依赖**:在 `pom.xml` 中添加以下依赖 ```xml <dependency> <groupId>com.alibaba.cloud</groupId> <artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId> </dependency> ``` 2. **配置 Nacos 地址和应用名**:在 `bootstrap.properties` 中配置 Nacos server 的地址和应用名 ```properties spring.cloud.nacos.config.server-addr=127.0.0.1:8848 spring.application.name=example ``` #### spring-cloud-starter-alibaba-nacos-discovery 1. **添加依赖**:在 `pom.xml` 中添加以下依赖 ```xml <dependency> <groupId>com.alibaba.cloud</groupId> <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId> </dependency> ``` 2. **启用服务发现**:在 Spring Boot 主类上添加 `@EnableDiscoveryClient` 注解 ```java import org.springframework.boot.SpringApplication; import org.springframework.boot.autoconfigure.SpringBootApplication; import org.springframework.cloud.client.discovery.EnableDiscoveryClient; @SpringBootApplication @EnableDiscoveryClient public class YourApplication { public static void main(String[] args) { SpringApplication.run(YourApplication.class, args); } } ``` ### 区别 - **功能侧重点**:`spring-cloud-starter-alibaba-nacos-config` 主要侧重于配置管理,解决应用配置的集中管理和动态更新问题;而 `spring-cloud-starter-alibaba-nacos-discovery` 主要侧重于服务发现,解决微服务之间的注册与发现问题。 - **使用场景**:当需要对应用的配置进行集中管理和动态调整时,使用 `spring-cloud-starter-alibaba-nacos-config`;当需要实现微服务之间的相互调用和服务治理时,使用 `spring-cloud-starter-alibaba-nacos-discovery`。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值