目录
1.服务间如何进行远程调用
2.什么是服务治理
3.常见注册中心
4.Nacos 简介
5.Nacos实战入门
1.服务间如何进行远程调用
上篇文章搭建了订单服务和商品服务【微服务】-微服务环境搭建_MXin5的博客-CSDN博客,商品微服务已经提供了数据接⼝了,订单微服务应该如何去调⽤呢?
其实就是如何通过Java代码去调⽤⼀个http的接⼝地址,我们可以使⽤RestTemplate来进⾏调⽤。
1.在启动类上添加RestTemplate的bean配置
@SpringBootApplication
public class OrderServer {public static void main(String[] args) {SpringApplication.run(OrderServer.class,args);}@Beanpublic RestTemplate restTemplate(){return new RestTemplate();}
}
2.在OrderServiceImpl中注⼊RestTemplate并实现远程调⽤
@Service
@Slf4j
public class OrderServiceImpl implements OrderService {@Autowiredprivate OrderDao orderDao;@Autowiredprivate RestTemplate restTemplate;@Overridepublic Order createOrder(Long productId,Long userId) {log.info("接收到{}号商品的下单请求,接下来调⽤商品微服务查询此商品信息",
productId);//远程调⽤商品微服务,查询商品信息Product product = restTemplate.getForObject("http://localhost:8081/product/"+productId,Product.class);log.info("查询到{}号商品的信息,内容是:{}", productId,
JSON.toJSONString(product));//创建订单并保存Order order = new Order();order.setUid(userId);order.setUsername("mxin5");order.setPid(productId);order.setPname(product.getPname());order.setPprice(product.getPprice());order.setNumber(1);orderDao.save(order);log.info("创建订单成功,订单信息为{}", JSON.toJSONString(order));return order;}
}
虽然我们已经可以实现微服务之间的调⽤。但是我们把服务提供者的⽹络地址(ip,端⼝)等硬编码到了代码中,这种做法存在许多问题:
⼀旦服务提供者地址变化,就需要⼿⼯修改代码
⼀旦是多个服务提供者,⽆法实现负载均衡功能
⼀旦服务变得越来越多,⼈⼯维护调⽤关系困难
那么应该怎么解决呢, 这时候就需要通过注册中⼼动态的实现服务治理,这时候就引入了Nacos进行实现服务治理。
2.什么是服务治理
服务治理是微服务架构中最核⼼最基本的模块。⽤于实现各个微服务的⾃动化注册与发现。
服务注册:在服务治理框架中,都会构建⼀个注册中⼼,每个服务单元向注册中⼼登记⾃⼰提供服
务的详细信息。并在注册中⼼形成⼀张服务的清单,服务注册中⼼需要以⼼跳的⽅式去监测清单中
的服务是否可⽤,如果不可⽤,需要在服务清单中剔除不可⽤的服务。
服务发现:服务调⽤⽅向服务注册中⼼咨询服务,并获取所有服务的实例清单,实现对具体服务实
例的访问。
通过上⾯的调⽤图会发现,除了微服务,还有⼀个组件是服务注册中⼼,它是微服务架构⾮常重要
的⼀个组件,在微服务架构⾥主要起到了协调者的⼀个作⽤。注册中⼼⼀般包含如下⼏个功能:
1. 服务发现:
服务注册:保存服务提供者和服务调⽤者的信息
服务订阅:服务调⽤者订阅服务提供者的信息,注册中⼼向订阅者推送提供者的信息
2. 服务健康检测
检测服务提供者的健康情况,如果发现异常,执⾏服务剔除。
3.常见注册中心
Zookeeper
Zookeeper是⼀个分布式服务框架,是Apache Hadoop 的⼀个⼦项⽬,它主要是⽤来解决分布式
应⽤中经常遇到的⼀些数据管理问题,如:统⼀命名服务、状态同步服务、集群管理、分布式应⽤
配置项的管理等。
Eureka
Eureka是Springcloud Netflflix中的重要组件,主要作⽤就是做服务注册和发现。但是现在已经闭
源
Consul
Consul是基于GO语⾔开发的开源⼯具,主要⾯向分布式,服务化的系统提供服务注册、服务发现
和配置管理的功能。Consul的功能都很实⽤,其中包括:服务注册/发现、健康检查、Key/Value
存储、多数据中⼼和分布式⼀致性保证等特性。Consul本身只是⼀个⼆进制的可执⾏⽂件,所以
安装和部署都⾮常简单,只需要从官⽹下载后,在执⾏对应的启动脚本即可。
Nacos
Nacos是⼀个更易于构建云原⽣应⽤的动态服务发现、配置管理和服务管理平台。它是 Spring
Cloud Alibaba 组件之⼀,负责服务注册发现和服务配置。
4.Nacos 简介
Nacos 致⼒于帮助您发现、配置和管理微服务。Nacos 提供了⼀组简单易⽤的特性集,帮助您快速
实现动态服务发现、服务配置、服务元数据及流量管理。
从上⾯的介绍就可以看出,Nacos的作⽤就是⼀个注册中⼼,⽤来管理注册上来的各个微服务。
核心功能点:
服务注册: Nacos Client会通过发送REST请求想Nacos Server注册⾃⼰的服务,提供⾃身的元数
据,⽐如IP地址,端⼝等信息。Nacos Server接收到注册请求后,就会把这些元数据存储到⼀个双
层的内存Map中。
服务⼼跳: 在服务注册后,Nacos Client会维护⼀个定时⼼跳来维持统治Nacos Server,说明服务⼀
致处于可⽤状态,防⽌被剔除,默认5s发送⼀次⼼跳
服务同步: Nacos Server集群之间会相互同步服务实例,⽤来保证服务信息的⼀致性。
服务发现: 服务消费者(Nacos Client)在调⽤服务提供的服务时,会发送⼀个REST请求给Nacos
Server,获取上⾯注册的服务清单,并且缓存在Nacos Client本地,同时会在Nacos Client本地开启⼀
个定时任务拉取服务最新的注册表信息更新到本地缓存。
服务健康检查: Nacos Server 会开启⼀个定时任务来检查注册服务实例的健康情况,对于超过15s
没有收到客户端⼼跳的实例会将他的healthy属性设置为false(客户端服务发现时不会发现),如果某
个实例超过30s没有收到⼼跳,直接剔除该实例(被剔除的实例如果恢复发送⼼跳则会重新注册)
5.Nacos实战入门
接下来,我们就在现有的环境中加⼊nacos,并将我们的两个微服务注册上去。
1 搭建Nacos环境
1. 安装Nacos
下载地址: https://github.com/alibaba/nacos/releases下载zip格式的安装包,然后进⾏解压缩操作,上课使⽤的Nacos Server版本是1.3.2
2. 启动Nacos
#切换⽬录cd nacos/bin#命令启动startup.cmd -m standalone
3. 访问Nacos
打开浏览器输⼊http://localhost:8848/nacos,即可访问服务, 默认密码是nacos/nacos
2 将商品服务注册到Nacos
接下来开始修改 shop-product-server 模块的代码, 将其注册到nacos服务上
1. 在pom.xml中添加Nacos的依赖
<!--nacos客户端--><dependency><groupId>com.alibaba.cloud</groupId><artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId></dependency
2. 在主类上添加@EnableDiscoveryClient注解
@SpringBootApplication@EnableDiscoveryClientpublic class ProductServer {public static void main(String[] args) {SpringApplication.run(ProductServer.class,args);}}
3. 在application.yml中添加Nacos服务的地址
spring:cloud:nacos:discovery:server-addr: localhost:8848
4. 启动服务, 观察Nacos的控制⾯板中是否有注册上来的商品微服务
3 将订单服务注册到Nacos
接下来开始修改 shop-order-server 模块的代码, 将其注册到nacos服务上
1. 在pom.xml中添加Nacos的依赖
<!--nacos客户端--><dependency><groupId>com.alibaba.cloud</groupId><artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId></dependency>
2. 在主类上添加@EnableDiscoveryClient注解
@SpringBootApplication@EnableDiscoveryClientpublic class OrderServer {public static void main(String[] args) {SpringApplication.run(OrderServer.class,args);}}
3. 在application.yml中添加Nacos服务的地址
spring:cloud:nacos:discovery:server-addr: localhost:8848
4. 启动服务, 观察Nacos的控制⾯板中是否有注册上来的订单微服务
5. 修改OrderServiceImpl, 实现微服务调⽤
@Service
@Slf4j
public class OrderServiceImpl implements OrderService {@Autowiredprivate OrderDao orderDao;@Autowiredprivate DiscoveryClient discoveryClient;@Autowiredprivate RestTemplate restTemplate;@Overridepublic Order createOrder(Long productId,Long userId) {log.info("接收到{}号商品的下单请求,接下来调⽤商品微服务查询此商品信息",
productId);//从nacos中获取服务地址ServiceInstance instance = discoveryClient.getInstances("product-service").get(0);String url = instance.getHost()+":"+instance.getPort();//远程调⽤商品微服务,查询商品信息Product product = restTemplate.getForObject("http://"+url+"/product/"+productId,Product.class);log.info("查询到{}号商品的信息,内容是:{}", productId,JSON.toJSONString(product));//创建订单并保存Order order = new Order();order.setUid(userId);order.setUsername("叩丁狼教育");order.setPid(productId);order.setPname(product.getPname());order.setPprice(product.getPprice());order.setNumber(1);orderDao.save(order);log.info("创建订单成功,订单信息为{}", JSON.toJSONString(order));return order;}
}