码迷,mamicode.com
首页 > 编程语言
Spring Cloud Gateway 限流操作
开发高并发系统时有三把利器用来保护系统:缓存、降级和限流。API网关作为所有请求的入口,请求量大,我们可以通过对并发访问的请求进行限速来保护系统的可用性。常用的限流算法比如有令牌桶算法,漏桶算法,计数器算法等。在Zuul中我们可以自己去实现限流的功能(Zuul中如何限流在我的书《SpringCloud微服务-全栈技术与案例解析》中有详细讲解),SpringCloudGateway的出现本身就是用来
分类:编程语言   时间:2020-08-03 23:25:42    阅读次数:29
Spring Cloud微服务-全栈技术与案例解析目录
第一部分:准备篇101SpringCloud与微服务概述101.1传统的单体老项目101.1.1单体应用101.1.2改进单体应用的架构101.1.3向微服务靠拢111.2什么是微服务121.2.1微服务介绍121.2.2使用微服务架构的好处121.2.3使用微服务架构的害处131.2.4重构前的准备工作131.3什么是SpringCloud141.3.1SpringCloud介绍141.3.2S
分类:编程语言   时间:2020-08-03 23:25:23    阅读次数:20
Spring Cloud Gateway 整合Eureka路由转发
前面我们对SpringCloudGateway进行了一个入门的学习,具体文章可以查看《SpringCloudGateway网关尝鲜》进行学习。网关负责转发工作,那么它需要知道后端的服务信息,今天我们来学习下SpringCloudGateway整合Eureka的操作,实现服务转发功能。在之前的基础上添加eureka-client的依赖:<dependency><groupId>
分类:编程语言   时间:2020-08-03 23:25:08    阅读次数:21
Spring Cloud Gateway 网关尝鲜
Gateway介绍SpringCloudGateway是Spring官方基于Spring5.0,SpringBoot2.0和ProjectReactor等技术开发的网关,SpringCloudGateway旨在为微服务架构提供一种简单而有效的统一的API路由管理方式。SpringCloudGateway作为SpringCloud生态系中的网关,目标是替代NetflixZUUL,其不仅提供统一的路由
分类:编程语言   时间:2020-08-03 23:24:35    阅读次数:22
Java8新特性之函数式接口
什么时候可以使用Lambda?通常Lambda表达式是用在函数式接口上使用的。从Java8开始引入了函数式接口,其说明比较简单:函数式接口(FunctionalInterface)就是一个有且仅有一个抽象方法,但是可以有多个非抽象方法的接口。一、语法定义/***定义函数式接口*接口上标注@FunctionalInterface注解*/@FunctionalInterfacepublicinterf
分类:编程语言   时间:2020-08-03 23:24:03    阅读次数:21
Java做爬虫也很牛
首先我们封装一个Http请求的工具类,用HttpURLConnection实现,当然你也可以用HttpClient,或者直接用Jsoup来请求(下面会讲到Jsoup)。工具类实现比较简单,就一个get方法,读取请求地址的响应内容,这边我们用来抓取网页的内容,这边没有用代理,在真正的抓取过程中,当你大量请求某个网站的时候,对方会有一系列的策略来禁用你的请求,这个时候代理就排上用场了,通过代理设置不同
分类:编程语言   时间:2020-08-03 23:23:49    阅读次数:20
Spring Cloud如何提供API给客户端
长按二维码,关注我们现在越来越多的公司开始拥抱SpringCloud了,很多Java方向的同学也开始积极的学习SpringCloud,其实这边还有一个问题就是说:虽然大家学了Eureka,Ribbon,Hystrix,Zuul,Feign等等,但是要运用到实际的项目中去还是有些难度的。微服务难就难在服务的拆分上,框架只是工具,很多人都会用,服务拆分,服务之间的关系这些都是在拆分时候需要考虑的事情。
分类:编程语言   时间:2020-08-03 23:23:30    阅读次数:24
Spring Cloud Zuul过滤器获取请求参数问题?
赠书活动火热进行中,赶快参与吧!详情请查看《聊聊Akka》今天有个朋友咨询我一个问题,截图如下:qq.pngqq.png在忙完了自己的事情后,我也简单的看了下,然后写了一个Filter来实现这位朋友说的功能,其实就是想记录请求的参数信息,下面我把涉及到的请求都打印了一遍,当然日志格式你可以自定义。输出日志的FilterpublicclassDebugRequestextendsZuulFilter
分类:编程语言   时间:2020-08-03 23:23:16    阅读次数:20
Spring Cloud中Feign如何统一设置验证token
前面我们大致的聊了下如何保证各个微服务之前调用的认证问题SpringCloud中如何保证各个微服务之间调用的安全性SpringCloud中如何保证各个微服务之间调用的安全性(下篇)原理是通过每个微服务请求之前都从认证服务获取认证之后的token,然后将token放入到请求头中带过去,这样被调用方通过验证token来判断是否合法请求。我们也在zuul中通过前置过滤器来统一设置token,其实还漏掉了
分类:编程语言   时间:2020-08-03 23:23:03    阅读次数:35
Spring Cloud中Feign如何统一设置验证token
前面我们大致的聊了下如何保证各个微服务之前调用的认证问题SpringCloud中如何保证各个微服务之间调用的安全性SpringCloud中如何保证各个微服务之间调用的安全性(下篇)原理是通过每个微服务请求之前都从认证服务获取认证之后的token,然后将token放入到请求头中带过去,这样被调用方通过验证token来判断是否合法请求。我们也在zuul中通过前置过滤器来统一设置token,其实还漏掉了
分类:编程语言   时间:2020-08-03 23:22:46    阅读次数:19
Spring Cloud中如何保证各个微服务之间调用的安全性(下篇)
长按二维码,关注我们前言赠书活动马上就要结束啦!还没参与的小伙伴查看文章参与吧。《赠书|感谢关注猿天地的朋友们》上篇文章SpringCloud中如何保证各个微服务之间调用的安全性我们介绍了各个微服务之间调用认证的方式以及原理。今天我们继续接着上篇文章来聊一聊如何能够在调用方实现token的自动设置以及刷新。我们的认证token是放在请求头中的,相对于把token放在请求参数中更为友好,对业务接口无
分类:编程语言   时间:2020-08-03 23:21:52    阅读次数:19
Spring Cloud中如何保证各个微服务之间调用的安全性
长按二维码,关注我们一.背景微服务架构下,我们的系统根据业务被拆分成了多个职责单一的微服务。每个服务都有自己的一套API提供给别的服务调用,那么如何保证安全性呢?不是说你想调用就可以调用,一定要有认证机制,是我们内部服务发出的请求,才可以调用我们的接口。需要注意的是我们这边讲的是微服务之间调用的安全认证,不是统一的在API官网认证,需求不一样,API网关处的统一认证是和业务挂钩的,我们这边是为了防
分类:编程语言   时间:2020-08-03 23:21:30    阅读次数:37
知识点-Spring Boot 统一异常处理汇总
长按二维码,关注我们在实际开发中,我们会遇到很多异常,在发生异常的时候SpringBoot默认提供了错误页面展示给用户。看似比较友好,其实页面很丑。上面讲的是做页面开发的时候遇到的问题,还有一种情况就是用来开发Rest接口,当错误的时候我们希望返回给用户的是我们接口的标准格式,不是返回一段html代码。接下来分别给大家介绍下解决方案:页面处理首先我们来看页面错误的处理情况,当我们的程序内部报错的时
分类:编程语言   时间:2020-08-03 23:21:11    阅读次数:12
Spring Boot 1.X和2.X优雅重启实战
长按二维码,关注我们项目在重新发布的过程中,如果有的请求时间比较长,还没执行完成,此时重启的话就会导致请求中断,影响业务功能,优雅重启可以保证在停止的时候,不接收外部的新的请求,等待未完成的请求执行完成,这样可以保证数据的完整性。SpringBoot1.Ximportjava.util.concurrent.Executor;importjava.util.concurrent.ThreadPoo
分类:编程语言   时间:2020-08-03 23:20:45    阅读次数:11
面试-线程池的成长之路
长按二维码,关注我们背景相信大家在面试过程中遇到面试官问线程的很多,线程过后就是线程池了。从易到难,都是这么个过程,还有就是确实很多人在工作中接触线程池比较少,最多的也就是创建一个然后往里面提交线程,对于一些经验很丰富的面试官来说,一下就可以问出很多线程池相关的问题,与其被问的晕头转向,还不如好好学习。此时不努力更待何时。什么是线程池?线程池是一种多线程处理形式,处理过程中将任务提交到线程池,任务
分类:编程语言   时间:2020-08-03 23:19:44    阅读次数:12
Spring Boot 使用WebAsyncTask异步返回结果
长按二维码,关注我们在SpringBoot中(SpringMVC)下请求默认都是同步的,一个请求过去到结束都是由一个线程负责的,很多时候为了能够提高吞吐量,需要将一些操作异步化,除了一些耗时的业务逻辑可以异步化,我们的查询接口也是可以做到异步执行。一个请求到服务上,是用的web容器的线程接收的,比如线程http-nio-8084-exec-1。我们可以使用WebAsyncTask将这个请求分发给一
分类:编程语言   时间:2020-08-03 23:18:26    阅读次数:13
Spring Boot系列之配置读取
长按二维码,关注我们子曰:温故而知新,可以为师矣。周日还在学习的就真的是爱学习的人,周日大放送,这周的精彩文章推荐阅读:《分享的不仅仅是情怀》《反射面试题-请了解下》《SpringBootAsync异步执行任务》《面试题-实现多线程的方式》《SpringBoot系列之环境搭建》SpringBoot里面所有的配置信息都放在application.properties中,如果我们想读取配置中的值要怎么
分类:编程语言   时间:2020-08-03 23:17:15    阅读次数:10
444230条   上一页 1 2 3 4 5 6 ... 26132 下一页
© 2014 mamicode.com 版权所有 京ICP备13008772号-2
迷上了代码!