SpringCloud搭建微服务(服务中心+消费者+提供者)

微服务之初体验

​ Eureka:专门用于给其他服务注册的称为Eureka Server(服务注册中心),注册到 Eureak Server 的服务称为 Eureak Client 。EureakClient的默认端口号默认为8761

1、创建注册中心

实现服务治理,提供者,消费者都需要再注册中心中进行注册

​ 实现步骤:

1.1、依赖

​ 建立一个Maven项目,设置打包方式为 pom ,设置子项目标签

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>

    <groupId>org.springframework.boot</groupId>
    <artifactId>SpringCloud_1902</artifactId>
    <version>2.1.6.RELEASE</version>
    <!--设置打包方式为pom-->
    <packaging>pom</packaging>

    <!--设置子项目-->
    <modules></modules>
</project>
1.2、右键项目建立一个子项目(SpringBoot项目)。

​ Boot项目构想 SpringWebStarter 和 EurekaServer(核心依赖必选),这个Boot项目为注册中心,注册中心依赖的jar包为:

		<dependency>
			<groupId>org.springframework.cloud</groupId>
			<artifactId>spring-cloud-starter-netflix-eureka-server</artifactId>
		</dependency>
1.3、开关类配置

​ 先在启动类上方加上注解 @EnableEurekaServer 标记这是一个注册中心服务器。

@SpringBootApplication
@EnableEurekaServer//标记这是一个注册中心服务器
public class CloudEurekaServerApplication {
	public static void main(String[] args) {
		SpringApplication.run(CloudEurekaServerApplication.class, args);
	}

}
1.4、全局配置文件设置

​ 将注册中心中的application的配置文件后缀改为yml,配置如下

server:
# 端口号
  port: 8761

eureka:
#实例
  instance:
#  主机名
    hostname: localhost
#    客户端配置
  client:
#  当前的项目在注册中心中注册为服务,因为这个项目是一个注册中心,所以设为false
    registerWithEureka: false
#    查询或抓取服务中心
    fetchRegistry: false
#    服务的路径名
    serviceUrl:
      defaultZone: http://${eureka.instance.hostname}:${server.port}/eureka/
1.5、启动并测试

运行开关类,启动成功后,在浏览器中输入:http://localhost:8761/

格式为appliction配置文件中的:主机名:端口号

可以看到注册中心页面,说明就成功了。

在这里插入图片描述


2、创建服务提供者
2.1、建立一个和服务中心同级的Boot项目

​ 勾选:Spring Web StarterEureka Discover Client(核心依赖必选)

​ 其服务提供者的核心依赖jar包为

		<dependency>
			<groupId>org.springframework.cloud</groupId>
			<artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
		</dependency>
2.2、编写控制器
/**
 * @RestController: 相当于@Controller+@ResponseBody两个注解的结合,
 * 返回json数据不需要在方法前面加@ResponseBody注解了,但使用@RestController
 * 这个注解,就不能返回jsp,html页面,视图解析器无法解析jsp,html页面
 */
@RestController
public class HelloController {
    @GetMapping("/provider/hello")
    public R hello(){
        return R.setOK("提供者",null);
    }
}
2.3、开关类配置

​ 在开关类上使用注解 @EnableEurekaClient 标记此项目为服务提供者

@SpringBootApplication
@EnableEurekaClient //注册服务,标记这是客户端(服务提供者)
public class CloudHelloproviderApplication {
	public static void main(String[] args) {
		SpringApplication.run(CloudHelloproviderApplication.class, args);
	}
}
2.4、全局配置文件

​ 将application修改后缀为yml,配置如下

eureka:
#客户端
  client:
#  客户中心注册地址
    serviceUrl:
      defaultZone: http://localhost:8761/eureka/
server:
#端口号
  port: 9901
spring:
#服务名称
  application:
    name: HelloProvider
2.5、启动并测试

​ 注:服务提供的接口也可以直接通过ip:端口/路径直接请求返回数据,不推荐这么做(这么做注册中心就没有存在的必要了)

​ 运行开关类,查看注册中心页面,观察服务是否注册(注册中心不可以关)。注册中心中会多出现一个服务,服务和服务提供者的application.yml中配置的服务名称一样,说明服务已提供成功

在这里插入图片描述


3、创建服务消费者

​ Spring Cloud服务消费由两种方式,第一种:Feign;第二种:RestTemplate+Ribbon

实现步骤

​ Feign是一个种声明式、模块化的HTTP客户端、可以进行网络请求

3.1、建一个和服务中心同级的SpringBoot项目

​ 勾选勾选:Spring Web Starter

Eureka Discover Client (核心依赖必选)

OpenFeign(核心依赖必选)

​ 消费者的核心依赖jar包为:

<dependency>
			<groupId>org.springframework.cloud</groupId>
			<artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
		</dependency>
		<dependency>
			<groupId>org.springframework.cloud</groupId>
			<artifactId>spring-cloud-starter-openfeign</artifactId>
		</dependency>
3.2、编写代码

编写Service层接口

​ @FeignClient要和对应的服务名称一样

​ 接口种的方法须和对应服务的Controller层的方法一样

/**
 * @FeignClient: 去注册中心找一个名为name的服务
 */
@FeignClient(name = "HelloProvider")
public interface HelloService {
    @GetMapping("/provider/hello")
    public R hello();
}

编写Controller层控制器

@RestController
public class HellowController {
    @Autowired(required = false)
    private HelloService helloService;

    @GetMapping("/hello.do")
    public R hellow(){
        return  helloService.hello();
    }
}
3.3、编写开关类

​ 在开关类上使用注解

@SpringBootApplication
@EnableDiscoveryClient	//发现服务
@EnableFeignClients	//基于Fign实现服务消费
public class CloudHelloconsumerApplication {
	public static void main(String[] args) {
		SpringApplication.run(CloudHelloconsumerApplication.class, args);
	}

}
3.4、配置全局配置文件

​ 注:

​ 修改application配置文件后缀名为yml。

​ 消费者的配置和提供者是一样的,只需修改端口号和服务名称

​ 提供者和消费者须在一个消费中心

eureka:
#客户端
  client:
#  客户中心注册地址
    serviceUrl:
      defaultZone: http://localhost:8761/eureka/
server:
#端口号
  port: 9902
spring:
#服务名称
  application:
    name: HelloConsumer

3.5、运行并测试

​ 打开控制中心,服务列表中多出了一个消费者

在这里插入图片描述

浏览器输入url访问消费者的路径进行测试,返回服务提供者提供的数据
在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值