Springcloud--Nacos服务治理

本文介绍了如何使用Nacos作为服务注册中心,实现微服务之间的服务发现与注册。包括Nacos的基本介绍、环境搭建步骤、商品微服务和订单微服务的具体注册流程,以及通过Controller进行服务调用的方法。

1.服务治理介绍

1.一旦服务提供者地址变化,就需要手工修改代码

2.一旦是多个服务提供者,无法实现负载均衡功能

3.一旦服务变得越来越多,人工维护调用关系困难

怎么样来解决这些问题呢,通过注册中心动态的实现服务治理

2.Nacos的介绍

Nachos的全称是“Not Another Completely Heuristic Operating System”,它是一个可修改和跟踪的操作系统教学软件。它给出了一个支持多线程虚拟存储的操作系统骨架,可让学生在较短的时间内对操作系统中的基本原理和核心算法有一个全面和完整的了解。Nacos 致力于帮助您发现、配置和管理微服务。Nacos 提供了一组简单易用的特性集,帮助您快速 实现动态服务发现、服务配置、服务元数据及流量管理。 从上面的介绍就可以看出,nacos的作用就是一个注册中心,用来管理注册上来的各个微服务。

3.搭建Nacos环境

3.1安装nacos

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

下载zip格式的安装包,然后进行解压缩操作

3.2启动nacos

#切换目录

cd nacos/bin

#命令启动

startup.cmd -m standalone

3.3访问nacos

打开浏览器输入http://localhost:8848/nacos,即可访问服务, 默认密码是nacos/nacos 

4.讲商品微服务注册到nacos注册中心

4.1在pom.xml文件中引入nacos的依赖

<dependency>
    <groupId>com.alibaba.cloud</groupId>
    <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
</dependency>

4.2在application.yml添加nacos的配置

#商品微服务
#指定nacos注册中心的地址 ip:port
spring.cloud.nacos.discovery.server-addr=localhost:8848
#指定服务器的名称springcloud-product是我的服务器名你需要改成自己的
spring.application.name=springcloud-product

#订单微服务
#指定nacos注册中心的地址 ip:port
spring.cloud.nacos.discovery.server-addr=localhost:8848
#指定是否把该服务注册到注册中心
spring.cloud.nacos.discovery.register-enabled=false
#指定服务器的名称
spring.application.name=springcloud-order

4.3查看订单微服务和商品微服务是否注册到nacos注册中心

5.在Controller中修改代码

@Autowired
private DiscoveryClient discoveryClient;

List<ServiceInstance> instances = discoveryClient.getInstances("springcloud-product");
//需要设置订单对象中商品的信息
//商品操作都在商品微服务---订单微服务远程调用商品微服务即可拿到商品信息,远程调用:http协议的restFul风格调用适合微服务,基于TCP协议的RPC调用适合SOA分布式
//一定采用的为http协议:(1)自己写代码完成http调用【httpclient】微信支付---适合调用第三方网址。(2) spring提高了一个工具类RestTemplate,该类也是基于http协议的
ServiceInstance serviceInstance = instances.get(new Random().nextInt(instances.size()));
Product product = restTemplate.getForObject(serviceInstance.getUri()+"/product/findById/" + pid, Product.class);

5.1观察nacos的控制面板中是否有注册上来的订单微服务,然后通过访问消费者服务验证调用是否成功

### 介绍 - **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`。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值