0
点赞
收藏
分享

微信扫一扫

SpringCloudAlibaba微服务分布式架构

中间件小哥 2022-09-17 阅读 142

一、SpringCloudAlibaba简介

待更新

二、Nacos概述

1、什么是nacos?

        一个更易于构建云原生应用的动态服务发现配置管理服务管理平台,相当于注册中心 + 配置中心的组合,等价于Eureka+Config +Bus。

2、能干嘛?

  • 替代Eureka做服务注册中心
  • 替代config做服务配置中心 

3、去哪下?      

        官网下载:点击访问

 这里我下载的是Windows版本,下载完成后进入文件夹的bin目录下启动nacos:

4、怎么运行访问?

上面我们已经将 Nacos 初步安装好了,在启动时需要注意以下问题:

  • 如果我们直接通过cmd启动startup.cmd 发现能启动但是会报错,因为nacos默认启动方式是集群,所以我们需要更改为单机模式 startup.cmd -m standalone

  • 这个时候可以正常启动了,但是我们使用Nacos是用来搞微服务的,为什么还要搞单机呢?
    Nacos默认是以集群方式启动的,但是对于初学者来说可能是初次安装没有集群环境需要进行一些配置,在入门阶段我们还是以单机为主进行练手。
  • 配置集群模式启动

        将cluster.conf.example文件复制一份去掉.example后缀,然后进入文件修改,添加端口,然后就可以通过 startup.cmd 进行启动。

  • 访问 localhost:8848/nacos

 三、Nacos之服务注册中心

官方文档:点击查看

1、服务提供者模块(建moudle、改pom、写yml、主启动、业务类)

(1)创建moudle:cloudalibaba-provider-payment9001

(2)改pom(添加依赖):

  • 父pom(公用):
<dependency>
    <groupId>com.alibaba.cloud</groupId>
    <artifactId>spring-cloud-alibaba-dependencies</artifactId>
    <version>2.1.0.RELEASE</version>
    <type>pom</type>
    <scope>import</scope>
</dependency>
  • 子pom:
<!--SpringCloud ailibaba nacos -->
<dependency>
    <groupId>com.alibaba.cloud</groupId>
    <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
</dependency>

(3)编写配置文件 application.yml

server:
  port: 9001

spring:
  application:
    name: nacos-payment-provider #注册服务名称
  cloud:
    nacos:
      discovery:
        server-addr: localhost:8848 #配置Nacos地址
#打开全部监控端点
management:
  endpoints:
    web:
      exposure:
        include: '*'

(4)主启动类 PaymentMain9001.java

@EnableDiscoveryClient  //开启服务提供者或消费者,客户端的支持,用来注册服务或连接到注册中心
@SpringBootApplication  //主启动
public class PaymentMain9001
{
    public static void main(String[] args) {
            SpringApplication.run(PaymentMain9001.class, args);
    }
}

(5)编写业务类 PaymentController.java

@RestController
public class PaymentController
{
    @Value("${server.port}")
    private String serverPort;

    @GetMapping(value = "/payment/nacos/{id}")
    public String getPayment(@PathVariable("id") Integer id)
    {
        return "nacos registry, serverPort: "+ serverPort+"\t id"+id;
    }
}

(6)测试

  • 启动Nacos和cloudalibaba-provider-payment9001模块。
  • 访问http://localhost:9001/payment/nacos/1
  • 在服务列表中发现注册到Nacos服务注册中心中的服务:nacos-payment-provider

 2、服务提供者模块(副本,测试nacos的负载均衡功能)

(1)复制一份9001模块的代码改一下文件名和端口号,不过多赘述;

(2)在同一服务名下存在两个健康的实例。

在这里插入图片描述

 3、服务消费者(建moudle、改pom、写yml、主启动、业务类)

(1)创建moudle:cloudalibaba-consumer-nacos-order83

(2)改pom(添加依赖):

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

(3)编写配置文件 application.yml

server:
  port: 83


spring:
  application:
    name: nacos-order-consumer  #注册服务名称
  cloud:
    nacos:
      discovery:
        server-addr: localhost:8848


#消费者将要去访问的微服务名称(注册成功进nacos的微服务提供者)
service-url:
  nacos-user-service: http://nacos-payment-provider 
 

(4)主启动类 OrderNacosMain83.java

@EnableDiscoveryClient  //开启服务提供者或消费者,客户端的支持,用来注册服务或连接到注册中心
@SpringBootApplication  //主启动
public class OrderNacosMain83
{
    public static void main(String[] args)
    {
        SpringApplication.run(OrderNacosMain83.class,args);
    }
} 

(5)编写业务类,需要添加一个RestTemplate的配置类:

@Configuration
public class ApplicationContextBean
{
    //这里就是创建一个轮询负载均衡的RestTemplate Bean
    @Bean
    @LoadBalanced
    public RestTemplate getRestTemplate()
    {
        return new RestTemplate();
    }
}
@RestController
public class OrderNacosController
{
    @Resource
    private RestTemplate restTemplate;

    @Value("${service-url.nacos-user-service}")
    private String serverURL;

    @GetMapping("/consumer/payment/nacos/{id}")
    public String paymentInfo(@PathVariable("id") Long id)
    {
        return restTemplate.getForObject(serverURL+"/payment/nacos/"+id,String.class);
    }

}

(6)测试

  • 启动Nacos和9001、9002、83模块。
  • 访问 http://localhost:83/consumer/payment/nacos/13
  • 可以发现83模块会访问9001/9002,轮询负载

在这里插入图片描述

 4、服务注册中心对比

这里先来了解一下什么是CAP模型?

  • 一致性(Consistency)同一时刻同一请求的实例返回结果相同,所有数据具有强一致性。
  • 可用性(Availability):所有实例的读写请求在一定时间内可以得到正确的响应。
  • 分区容错性(Partition tolerance):在网络异常的情况下系统仍能提供正常的服务。

        这就是CAP原则,又被称为CAP定理,但是三个特性不可能同时被满足,所以分布式系统设计要考虑的是在满足P(分区容错性)的前提下选择C(一致性)还是A(可用性),即:CP或AP

        CP:

        AP:

服务注册与发现框架CAP模型控制台管理社区活跃度
EurekaAP支持低(2.x版本闭源)
ZookeeperCP不支持
ConsulCP支持
NacosAP/CP支持

四、Nacos之服务配置中心

1、nacos作为配置中心----基本配置

(1)创建子模块: cloudalibaba-config-nacos-client3377

(2)编写pom文件:

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

(3)编写application.yml:

        Nacos同springcloud-config一样,在项目初始化时,要保证先从配置中心进行配置拉取,拉取之后,才能保证项目的正常启动。

        bootstrap.yml

server:
  port: 3377
spring:
  application:
    name: nacos-config-client
  cloud:
    nacos:
      discovery:
        server-addr: localhost:8848 #nacos服务注册中心地址
      config:
        server-addr: localhost:8848 #nacos作为配置中心地址
        file-extension: yaml #指定yaml格式的配置

        application.yml

spring:
  profiles:
    active: dev # 表示开发环境

(4)创建主启动类:

@EnableDiscoveryClient
@SpringBootApplication
public class NacosConfigClientMain3377
{
    public static void main(String[] args) {
            SpringApplication.run(NacosConfigClientMain3377.class, args);
    }
}

(5)编写业务类:

@RestController
@RefreshScope //在控制器类加入@RefreshScope注解使当前类下的配置支持Nacos的动态刷新功能。
public class ConfigClientController
{
    @Value("${config.info}")
    private String configInfo;

    @GetMapping("/config/info")
    public String getConfigInfo() {
        return configInfo;
    }
}

2、在Nacos中添加配置信息

(1)Nacos中的匹配规则:官方文档

(2)在Nacos中新增配置

  • 配置文件命名规则

  •  Nacos 配置页面对应:

 (3)测试,启动3377模块

        发起请求访问: localhost:3377/config/info

        修改配置文件内容,如果可以动态刷新,那么Nacos Config中心配置成功!

3、Nacos作为配置中心----分类配置(持续更新中)

(1)

(2)

(3)

举报

相关推荐

0 条评论