"微服务”一词源于 Martin Fowler的名为 Microservices的,博文,可以在他的官方博客上找到http:/ /martinfowler . com/articles/microservices.html简单地说,微服务是系统架构上的一种设计风格,它的主旨是将一个原本独立的系统拆分成多个小型服务,这些小型服务都在各自独立的进程中运行,服务之间通过基于HTTP的 RESTfuL AP进行通信协作。常见微服务框架:Spring的spring cloud、阿里dubbo、华为ServiceComb、腾讯Tars、Facebook thrift、新浪微博Motan。本章节我们先从了解组成完整系统的各个组件开始,下章节将利用这些组件,搭建出一个完善的分布式系统。
这就不用多说了,官网有详细的介绍。
Spring Cloud Alibaba 致力于提供微服务开发的一站式解决方案。此项目包含开发分布式应用微服务的必需组件,方便开发者通过 Spring Cloud 编程模型轻松使用这些组件来开发分布式应用服务
主要组件
Sentinel:把流量作为切入点,从流量控制、熔断降级、系统负载保护等多个维度保护服务的稳定性。
Nacos:一个更易于构建云原生应用的动态服务发现、配置管理和服务管理平台。
RocketMQ:一款开源的分布式消息系统,基于高可用分布式集群技术,提供低延时的、高可靠的消息发布与订阅服务。
Dubbo:Apache Dubbo™ 是一款高性能 Java RPC 框架。
Seata:阿里巴巴开源产品,一个易于使用的高性能微服务分布式事务解决方案。
Eureka:官方宣布2.x不再开源(闭源),之前的版本已经停止更新;也就说Eureka将来更多的技术提升已经没有了。所以,如果希望注册中心有更多强大功能的话,还需要另辟蹊径 。
Zookeeper:在企业级Zookeeper注册中心与 Dubbo组合比较多一些,kafka使用的也是,随着Eureka的停更,我们可以通过spring-cloud-starter-zookeeper-discovery这个启动器,将Zookeeper做为springcloud的注册中心。
Consul:go语言开发的,也是一个优秀的服务注册框架,使用量也比较多。
Nacos:来自于SpringCloudɵɹibaba,在企业中经过了百万级注册考验的,不但可以完美替换Eureka,还能做其他组件的替换,所以,Naocs也强烈建议使用。
(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
访问:
http://127.0.0.1:8848/nacos 账号密码都是nacos

集群
安装前提
- 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官网:https:/ /http://nacos.io/zh-cn/docs/quick-start-docker.html
1)安装Docker Compose
什么是Docker Compose
Compose项目是Docker官方的开源项目,负责实现对Docker容器集群的快速编排。
- #在Linux下下载(下载到/usr/local/bin)
- curl -L https://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 https://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)最新版本

4)停止、启动
- #启动
- docker-compose -f /usr/local/nacos/nacos-docker/example/cluster-hostname.yaml start
- #停止
- docker-compose -f /usr/local/nacos/nacos-docker/example/cluster-hostname.yaml stop
5)访问Nacos
- http://192.168.1.1:8848/nacos
- http://192.168.1.1:8849/nacos
- http://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(NacosProviderApplication.class, args);
- }
-
- @RestController
- class EchoController {
- @RequestMapping(value = "/echo/{string}", method = RequestMethod.GET)
- public String echo(@PathVariable String string) {
- return "Hello Nacos Discovery " + string;
- }
- }
- }
启动后,控制台:

说明注册成功,后台查看该服务:

下面我们用spring cloud 整合naocs实现服务调用
配置服务消费者
添加配置
- server.port=8080
- spring.application.name=service-consumer
-
- spring.cloud.nacos.discovery.server-addr=127.0.0.1:8848
添加启动类:服务消费者使用 @LoadBalanced RestTemplate 实现服务调用
- @SpringBootApplication
- @EnableDiscoveryClient
- public class NacosConsumerApplication {
-
- @LoadBalanced
- @Bean
- public RestTemplate restTemplate() {
- return new RestTemplate();
- }
-
- public static void main(String[] args) {
- SpringApplication.run(NacosConsumerApplication.class, args);
- }
-
- @RestController
- public class TestController {
-
- private final RestTemplate restTemplate;
-
- @Autowired
- public TestController(RestTemplate restTemplate) {this.restTemplate = restTemplate;}
-
- @RequestMapping(value = "/echo/{str}", method = RequestMethod.GET)
- public String echo(@PathVariable String str) {
- return restTemplate.getForObject("http://service-provider/echo/" + str, String.class);
- }
- }
- }
(5)测试
启动 ProviderApplication 和 ConsumerApplication ,调用 http://localhost:8080/echo/2018,返回内容为 Hello Nacos Discovery 2018。
目前市面上用的比较多的配置中心有(时间顺序)
Disconf:2014年7月百度开源的配置管理中心,同样具备配置的管理能力,不过目前已经不维护了,最近的一次提交是4-5年前了。
Spring Cloud Configÿ