0、项目搭建

创建maven项目,删除其中的src目录,作为整体父项目,在其中添加module实现各个组件。

1、Eureka Server的实现

添加module,创建Spring Boot项目,添加Eureka Discovery ClientEureka Server依赖,作为Eureka Server。

启动类添加@EnableEurekaServer注释。

修改配置文件application.yml,如下:

 server:
port: 1001 eureka:
client:
//是否将自己注册到eureka server上,默认为true
//由于本节点为eureka server,设为false
registerWithEureka: false
//是否从eureka server获取注册信息,默认为true
//由于为单点的eureka server,不需要同步信息,设为false
fetchRegistry: false
//设置与eureka server交互的地址,查询和注册服务都经过这个地址
serviceUrl:
defaultZone: http://localhost:${server.port}/eureka/

启动项目,即可访问http://localhost:1001/查看eurekaServer管理中心。

2、Service节点

添加module,创建Spring Boot项目,添加Eureka Discovery ClientEureka Server依赖。

启动类添加@EnableEurekaClient注释(也可用@EnableDiscoveryClient取代,效果相同,前者对应Eureka,后者适用多种注册中心)以及@ComponentScan注释。

修改配置文件application.yml,如下:

 spring:
//服务名称
application:
name: Service1
server:
port: 8001 //在服务中心进行注册
eureka:
client:
serviceUrl:
defaultZone: http://localhost:8801/eureka/

配置完成后启动项目,可在eureka管理中心看到注册的服务。

项目中新建service和controller包,controller包中HelloController负责接受请求,并路由到service包中的具体实现,controller中仅注入service对象,然后根据请求路径调用响应的service实现,service中负责具体的实现。

同理,按上面步骤增加第二个Service节点,注册名为Service2,注册在8002端口。

3、服务调用

Sping  Cloud由两种消费方式,rest+ribbon和feign两种。

3.1、rest+ribbon调用(通过RestTemplate构造URL调用)

添加module,创建Spring Boot项目,添加Eureka Discovery ClientEureka ServerRibbon依赖。

启动类添加@EnableDiscoveryClient和@ComponentScan注释。

修改配置文件application.yml,注册在8003端口上的Service3服务。

service包和controller包同上。

Service3调用Service1和Service2:

启动类中注入RestTemplate对象,添加@LoadBalance、@Bean和@Autowired注释,开启负载均衡。

改造service包中的具体实现:

自动注入(@Autowired)RestTemplate对象,restTemplate.getForObject("http://${注册应用名}/${请求路径}?参数列表",String.class)

实现远程调用,通过注册应用名自动负载均衡。

3.2、feign调用(通过动态代理的接口来实现接口调用,在接口中实现远程调用)

添加module,创建Spring Boot项目,添加Eureka Discovery ClientEureka ServerFeign依赖。

启动类添加@EnableDiscoveryClient和@ComponentScan注释。

修改配置文件application.yml,注册在8004端口上的Service4服务。

service包和controller包同上。

Service4调用Service1和Service2:

新增feignRPC包,其中定义两个接口,分别对应两个应用Service1和Service2的调用。

service1_feign接口为:

 @FeignClients(value = "Service1")    //通过应用注册名来调用服务
public interface service1_feign() {
@RequestMapping(value = "/${请求路径}", method = RequestMethod.GET)
public String getHello(@RequestParam("service1中参数名") 具体参数);
}

改造service包中的具体实现:

自动注入(@Autowired)service1_feign接口,像调用本地方法那样调用接口的方法即可实现远程调用

Feign集成了Ribbon,通过注册应用名自动负载均衡。

4、体验负载均衡机制

创建module,普通的service节点,注册在8005端口,应用名为Service1。

在eureka server管理界面可以看到Service1有两个服务提供者提供同名应用。

通过Service3或者Service4调用应用名为Service1的服务。

由于Ribbon默认的负载均衡策略为轮询,通过刷新界面,可以看到一次调用module1和module5提供的服务。

5、网关Zuul的搭建

5.1、体验网关的请求转发功能

创建module,添加Eureka Discovery Client、Eureka Server和Zuul依赖。

启动类添加@EnableZuulProxy注释。

修改配置文件application.yml,注册在6001端口上,注册应用名为zuul。

启动项目后,可以通过网关访问服务:

直接http://localhost:8001/hello?name=world可以访问Service1;

通过网关转发,http://localhost:6001/Service1/hello?name=world访问Service1应用,Zuul默认实现了按应用名负载均衡。

5.2、网关的自定义路由

在application.yml配置文件中配置:

 zuul:
//前缀,请求路径前必须加
prefix: /api
//自定义路由
routes:
Service1: /service_1_zuul/**
//禁止直接访问后台服务
ignored-services: Service1

启动项目后,访问http://localhost:8001/hello?name=world失败,网关禁止直接调用后台服务Service1。

通过网关访问http://localhost:6001/api/service_1_zuul/hello?name=world,可以轮询调用Service1和Service5。

6、Eureka Server集群

7、熔断降级功能

【Spring Cloud】实战项目搭建的更多相关文章

  1. 搭建一套ASP.NET Core+Nacos+Spring Cloud Gateway项目

    前言     伴随着随着微服务概念的不断盛行,与之对应的各种解决方案也层出不穷.这毕竟是一个信息大爆发的时代,各种编程语言大行其道,各有各的优势.但是有一点未曾改变,那就是他们服务的方式,工作的时候各 ...

  2. 3.开始使用Spring Cloud实战微服务

                     开始使用Spring Cloud实战微服务 3.1. Spring Cloud实战前提 3.1.1. 需要的技术储备 语言方面:可以使用Java.scala.Groo ...

  3. spring cloud实战 1-高可用注册中心

    创建父maven项目 提交代码至GitHub 创建eureka-server-1 项目搭建两种方式: 父pom中继承spring-boot-starter-parent,子pom中直接结成父pom.该 ...

  4. 优秀的Spring Cloud开源项目整理推荐

    无论是对于初学者,还是有一定工作经验的程序员来讲,Spring Cloud开源项目都是一笔宝贵的财富.下面给大家整理了十个优秀的开源项目,分别是spring-cloud-examples.spaasc ...

  5. [Spring Cloud实战 | 第六篇:Spring Cloud Gateway+Spring Security OAuth2+JWT实现微服务统一认证授权

    一. 前言 本篇实战案例基于 youlai-mall 项目.项目使用的是当前主流和最新版本的技术和解决方案,自己不会太多华丽的言辞去描述,只希望能勾起大家对编程的一点喜欢.所以有兴趣的朋友可以进入 g ...

  6. Spring Cloud实战 | 最终篇:Spring Cloud Gateway+Spring Security OAuth2集成统一认证授权平台下实现注销使JWT失效方案

    一. 前言 在上一篇文章介绍 youlai-mall 项目中,通过整合Spring Cloud Gateway.Spring Security OAuth2.JWT等技术实现了微服务下统一认证授权平台 ...

  7. Spring Cloud实战 | 最八篇:Spring Cloud +Spring Security OAuth2+ Axios前后端分离模式下无感刷新实现JWT续期

    一. 前言 记得上一篇Spring Cloud的文章关于如何使JWT失效进行了理论结合代码实践的说明,想当然的以为那篇会是基于Spring Cloud统一认证架构系列的最终篇.但关于JWT另外还有一个 ...

  8. Spring Cloud实战 | 第九篇:Spring Cloud整合Spring Security OAuth2认证服务器统一认证自定义异常处理

    本文完整代码下载点击 一. 前言 相信了解过我或者看过我之前的系列文章应该多少知道点我写这些文章包括创建 有来商城youlai-mall 这个项目的目的,想给那些真的想提升自己或者迷茫的人(包括自己- ...

  9. Spring Cloud实战 | 第十篇 :Spring Cloud + Seata 1.4.1 + Nacos1.4.0 整合实现微服务架构中逃不掉的话题分布式事务

    Seata分布式事务在线体验地址:https://www.youlai.store 本篇完整源码地址:https://github.com/hxrui/youlai-mall 有想加入开源项目开发的童 ...

  10. Spring Cloud实战: 基于Spring Cloud Gateway + vue-element-admin 实现的RBAC权限管理系统,实现网关对RESTful接口方法权限和自定义Vue指令对按钮权限的细粒度控制

    一. 前言 信我的哈,明天过年. 这应该是农历年前的关于开源项目 的最后一篇文章了. 有来商城 是基于 Spring Cloud OAuth2 + Spring Cloud Gateway + JWT ...

随机推荐

  1. Servlet重定向

    重定向就是在访问一个Servlet时,没有得到资源,只能去找另外一个Servlet去获取资源.状态码为302. import javax.servlet.ServletException; impor ...

  2. 初识Node.js之Node与java作为后台服务器的对比

    > 文章原创于公众号:程序猿周先森.本平台不定时更新,喜欢我的文章,欢迎关注我的微信公众号. ![file](https://img2018.cnblogs.com/blog/830272/20 ...

  3. python+selenium十:selenium的二次封装

    python+selenium十:基于原生selenium的二次封装   from selenium import webdriverfrom selenium.webdriver.support.w ...

  4. MySQL索引&&开发规范

    规范总结 索引规范 默认添加的索引都是BTree索引.Innodb只支持BTree索引. 设计索引原则 - 最适合索引的列是WHERE子句中的列,而不是SELECT中的列. - 如果索引的字段很长,使 ...

  5. ES6入门八:Promise异步编程与模拟实现源码

    Promise的基本使用入门: ——实例化promise对象与注册回调 ——宏任务与微任务的执行顺序 ——then方法的链式调用与抛出错误(throw new Error) ——链式调用的返回值与传值 ...

  6. go语言-最大32位数反转

    package main import ( "fmt" "strconv" ) func fanzhuang32(number int) string { fu ...

  7. 2018年蓝桥杯java b组第四题

    标题:测试次数 x星球的居民脾气不太好,但好在他们生气的时候唯一的异常举动是:摔手机.各大厂商也就纷纷推出各种耐摔型手机.x星球的质监局规定了手机必须经过耐摔测试,并且评定出一个耐摔指数来,之后才允许 ...

  8. Docker service endpoint with name xxx already exist问题

    这是因为利用docker compose启的容器再用docker rm命令删除后,网络仍然被占用,需要手动清理 解决办法: 先用docker rm -f xxx删除容器 再输入docker netwo ...

  9. Java8新特性——lambda函数式编程

    一.遍历循环 /** * @author jiaqing.xu@hand-china.com * @version 1.0 * @name * @description 循环遍历 * @date 20 ...

  10. git clone remote: HTTP Basic: Access denied

    git clone 项目失败,报下面的错误信息: $ git clone http://192.168.0.141/xxxx.git Cloning into 'appEnterprise'... r ...