spring-cloud 学习笔记(1)

2021年11月24日 阅读数:4
这篇文章主要向大家介绍spring-cloud 学习笔记(1),主要内容包括基础应用、实用技巧、原理机制等方面,希望对大家有所帮助。

STEP 1 : Eureka 微服务的注册

做为spring-cloud中最重要最核心的组件,spring-cloud学习的第一步固然是学习使用Eureka.html

首先让咱们先了解一下Eureka的背景.java

Eureka是Netflix开源的一款提供服务注册和发现的产品,它提供了完整的服务注册和发现。也是spring-cloud体系中最重要最核心的组件之一。web

既然是提供服务注册与,那固然须要有server(服务注册中心)client(服务提供方) 以及** consumer(服务消费者)**,因为篇幅有限,接下来,咱们只针对对server和client进行学习.spring

服务注册中心 (server)

在spring-cloud的代码中已经主动帮咱们实现了服务注册中心,这样让开发人员只须要很是简单的几个步骤就能够实现服务注册中心的搭建.segmentfault

1.初始化

方法一 : 使用spring initializr进行快速初始化

spring initializr 能帮助开发人员快速搭建项目的文件结构以及各类依赖.架构

  1. 填写组织名称和项目名称
  2. 搜索 Eureka Server ,并选中
  3. Generate Project (即下载项目包)
  4. 将项目包解压并导入到IDE中

方法二 : 使用IDE自带的工具进行初始化

此处使用IntelliJ IDEA做为IDE进行演示app

  1. 新建spring initializr项目
  2. 填写组织名称和项目名称
  3. 选中 Cloud Discovery下的Eureka Server

在使用spring initializr做为项目初始化工具时,直接选择Eureka Server将默认引入spring-cloud支持而不须要手动引入spring-cloud-starteride

若是未使用spring initializr工具,则须要手动引入spring-cloud依赖微服务

<dependency>
	<groupId>org.springframework.cloud</groupId>
	<artifactId>spring-cloud-starter</artifactId>
</dependency>

2.配置

在启动代码中添加 @EnableEurekaServer 注解:工具

@SpringBootApplication
@EnableEurekaServer
public class SpringCloudEurekaServerApplication {

	public static void main(String[] args) {
		SpringApplication.run(SpringCloudEurekaServerApplication.class, args);
	}
}

在默认设置下,该服务注册中心也会将本身做为客户端来尝试注册它本身,因此咱们须要禁用它的客户端注册行为,在application.properties添加如下配置:

spring.application.name=spring-cloud-eureka-server

server.port=9999
eureka.client.register-with-eureka=false 	//表示是否将本身注册到Eureka Server,默认为true
eureka.client.fetch-registry=false		//表示是否从Eureka Server获取注册信息,默认为true。

eureka.client.serviceUrl.defaultZone=http://127.0.0.1:${server.port}/eureka/  
//设置与Eureka Server交互的地址,查询服务和注册服务都须要依赖这个地址。默认是http://localhost:8761/eureka ;多个地址可以使用 , 分隔。

3.运行

配置完成后,运行spring-cloud-eureka-server工程,访问 http://127.0.0.1:9999/,就能够看见如下页面,可是并无任何服务.

服务提供方 (client)

1.初始化

默认状况下,使用和注册中心同样的初始化过程,此处再也不重复表示

2.配置

在启动代码中添加 @EnableEurekaClient 注解:


@SpringBootApplication
@EnableEurekaClient
public class SpringCloudEurekaClientApplication {

	public static void main(String[] args) {
		SpringApplication.run(SpringCloudEurekaClientApplication.class, args);
	}
}

而后修改一下application.properties:


spring.application.name=spring-cloud-eureka-client
server.port=1001
eureka.client.service-url.defaultZone=http://127.0.0.1:9999/eureka/

此时就已经能够成功注册这个服务端到注册中心了,可是这个服务端尚未提供任何服务,因此,如今须要添加一个服务


import com.netflix.discovery.EurekaClient;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.beans.factory.annotation.Qualifier;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;

import java.util.ArrayList;
import java.util.List;

@RestController
public class HelloWorldController {

    @Autowired
    @Qualifier("eurekaClient")
    private EurekaClient client;

    @RequestMapping("/say")
    public String say(){
        List<String> registeredApps = new ArrayList<>();
        client.getApplications().getRegisteredApplications().forEach(item -> registeredApps.add(item.getName()));
        return registeredApps.toString();
    }
}

3.运行

配置完成后,运行spring-cloud-eureka-client工程,访问 http://127.0.0.1:9999/,能够在注册中心的已注册服务列表中发现咱们绑定的微服务.

而后访问http://127.0.0.1:1001/say就能够看见输出的结果了

结束

本文部分文原本源于互联网

感谢如下文章提供的灵感和帮助