01 前言
"微服务”一词源于 Martin Fowler的名为 Microservices的,博文,可以在他的官方博客上找到martinfowler . com/articles/microservices.html简单地说,微服务是系统架构上的一种设计风格,它的主旨是将一个原本独立的系统拆分成多个小型服务,这些小型服务都在各自独立的进程中运行,服务之间通过基于HTTP的 RESTfuL AP进行通信协作。常见微服务框架:Spring的spring cloud、阿里dubbo、华为ServiceComb、腾讯Tars、Facebook thrift、新浪微博Motan。本章节我们先从了解组成完整系统的各个组件开始,下章节将利用这些组件,搭建出一个完善的分布式系统。
1.1 Spring Cloud
这就不用多说了,官网有详细的介绍。
1.2 Spring Cloud Alibaba
Spring Cloud Alibaba 致力于提供微服务开发的一站式解决方案。此项目包含开发分布式应用微服务的必需组件,方便开发者通过 Spring Cloud 编程模型轻松使用这些组件来开发分布式应用服务
主要组件 Sentinel:把流量作为切入点,从流量控制、熔断降级、系统负载保护等多个维度保护服务的稳定性。 Nacos:一个更易于构建云原生应用的动态服务发现、配置管理和服务管理平台。 RocketMQ:一款开源的分布式消息系统,基于高可用分布式集群技术,提供低延时的、高可靠的消息发布与订阅服务。 Dubbo:Apache Dubbo 是一款高性能 Java RPC 框架。 Seata:阿里巴巴开源产品,一个易于使用的高性能微服务分布式事务解决方案。
02 服务注册与发现
Eureka:官方宣布2.x不再开源(闭源),之前的版本已经停止更新;也就说Eureka将来更多的技术提升已经没有了。所以,如果希望注册中心有更多强大功能的话,还需要另辟蹊径 。 Zookeeper:在企业级Zookeeper注册中心与 Dubbo组合比较多一些,kafka使用的也是,随着Eureka的停更,我们可以通过spring-cloud-starter-zookeeper-discovery这个启动器,将Zookeeper做为springcloud的注册中心。 Consul:go语言开发的,也是一个优秀的服务注册框架,使用量也比较多。 Nacos:来自于SpringCloudibaba,在企业中经过了百万级注册考验的,不但可以完美替换Eureka,还能做其他组件的替换,所以,Naocs也强烈建议使用。
2.1 介绍下Nacos用作注册中心
(1)Nacos简介
Nacos(Dynamic Naming and Configur ation Service) 是阿里巴巴2018年7月开源的项目,致力于发现、配置和管理微服务。
(2)Nacos安装
单节点
--下载镜像 docker pull nacos/nacos-server:1.3.1 --启动容器 docker run --name nacos --env MODE=standalone --privileged=true -p 8848:8848 --restart=always -d dc833dc45d8f
访问:
127.0.0.1:8848/nacos 账号密码都是nacos
image
集群
安装前提
64 bit OS Linux/Unix/Mac,推荐使用Linux系统。 集群需要依赖mysql,单机可不必 3个或3个以上Nacos节点才能构成集群
(3)搭建Nacos高可用集群步骤:
1、需要去Nacos官网clone Nacos集群项目nacos-docker 2、nacos-docker是使用的Docker Compose对容器进行编排,所以首先需要安装Docker Compose详细信息可参照Nacos官网:nacos.io/zh-cn/docs/quick-start-docker.html
1)安装Docker Compose 什么是Docker Compose Compose项目是Docker官方的开源项目,负责实现对Docker容器集群的快速编排。
#在Linux下下载(下载到/usr/local/bin) curl -L github.com/docker/compose/releases/download/1.25.0/run.sh > /usr/local/bin/docker-compose # 设置文件可执行权限 chmod +x /usr/local/bin/docker-compose # 查看版本信息 docker-compose --version
2)克隆Nacos-docker项目
#切换到自定义目录 cd /usr/local/nacos #开始clone git clone github.com/nacos-group/nacos-docker.git
3)运行nacos-docker脚本
#执行编排命令 docker-compose -f /usr/local/nacos/nacos-docker/example/cluster-hostname.yaml up
上面的编排命令主要下载mysql镜像和nacos镜像,自动完成镜像下载/容器启动 Pulling from nacos/nacos-mysql,版本是5. 7(执行初始化脚本) Pulling nacos3 (nacos/nacos-server:latest)最新版本
image
4)停止、启动
#启动 -f /usr/local/nacos/nacos-docker/example/cluster-hostname.yaml start
#停止 -fstop
5)访问Nacos
192.168.1.1:8848/nacos 192.168.1.1:8849/nacos 192.168.1.1:8850/nacos
(4)Nacos快速入门
配置服务提供者
服务提供者可以通过 Nacos 的服务注册发现功能将其服务注册到 Nacos server 上。
添加nacos依赖
<dependency> <groupId>com.alibaba.cloud</groupId> <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId> <version>${latest.version}</version> </dependency>
添加配置
server.port=8070 spring.application.name=nacos-demo spring.cloud.nacos.discovery.server-addr=127.0.0.1:8848
启动类
@SpringBootApplication @EnableDiscoveryClient public class NacosProviderApplication { public static void main(String[] args) { SpringApplication.run(.class, args); } @RestController class EchoController { @RequestMapping(value = "/echo/{string}", method = RequestMethod.GET) public String echo(@PathVariable String string) { return "Hello Nacos Discovery " + string; } } }
启动后,控制台:
image
说明注册成功,后台查看该服务:
image
下面我们用spring cloud 整合naocs实现服务调用
配置服务消费者
添加配置
server.port=8080 spring.application.name=service-consumer
添加启动类:服务消费者使用 @LoadBalanced RestTemplate 实现服务调用
public class NacosConsumerApplication { @LoadBalanced @Bean public RestTemplate restTemplate() { return new RestTemplate(); } public static void main(String[] args) { SpringApplication.run(.class, args); } public class TestController { private final RestTemplate restTemplate; @Autowired public TestController(RestTemplate restTemplate) {this.restTemplate = restTemplate;} (value = "/echo/{str}", method = RequestMethod.GET) public String echo( String str) { return restTemplate.getForObject("service-provider/echo/" + str, String.class); } } }
(5)测试
启动 ProviderApplication 和 ConsumerApplication ,调用 localhost:8080/echo/2018,返回内容为 Hello Nacos Discovery 2018。
03 分布式配置中心解决方案与应用
目前市面上用的比较多的配置中心有(时间顺序) Disconf:2014年7月百度开源的配置管理中心,同样具备配置的管理能力,不过目前已经不维护了,最近的一次提交是4-5年前了。 Spring Cloud Config:2014年9月开源,Spring Cloud 生态组件,可以和Spr