微服务路由解决方案: "Zuul" 服务搭建;以及自定义Zuul过滤器的代码编写。
微服务架构有一个问题,那就是客户端如何访问各个微服务。 总不能在客户端APP/HTML写很多个不同的地址来请求吧?这样维护及其困难、开发不易。 这时候就需要一个网关,客户端的请求都发给这个网关, 然后由他来给你路由到别的微服务里边。 netflix 就开源了一个微服务网关:Zuul ,可以和 SpringCloudNetflix 全家桶 ...
点滴心得,在此分享
微服务架构有一个问题,那就是客户端如何访问各个微服务。 总不能在客户端APP/HTML写很多个不同的地址来请求吧?这样维护及其困难、开发不易。 这时候就需要一个网关,客户端的请求都发给这个网关, 然后由他来给你路由到别的微服务里边。 netflix 就开源了一个微服务网关:Zuul ,可以和 SpringCloudNetflix 全家桶 ...
上个文章使用了Eureka搭建了集群服务注册中心,但是最后实现 RPC 的方式还是 从代码中获得服务对应地址->字符串拼接->请求获得响应 的这样一种方式。 这种方式弊端还是有不少的。如果可以像调用自己的服务一样调用别人提供的服务那该多舒适啊。 而 Feign 就可以实现这种需求,Feign也是网飞开发的,Spri ...
上一篇 Spring Cloud 项目的搭建文章 : 链接 再说下我的版本号 , 用的比较新: Spring Boot 2.0.5 RELEASE Spring Cloud Finchley.SR3 项目管理工具: gradle 进入正题: 从之前的项目构造来看,RPC虽然是实现了,但是调用的链接确是写死在代码中的,比较丑陋。 要是提供服务的地址突然换了,那这边消费者 ...
Spring Cloud 是在 Spring Boot 基础上构建的,用于快速构建分布式系统的通用模式的工具集。 别的理论、使用场景、历史之类的也不说了,直接切入主题。 这里,我就来架构一个简单 Spring Cloud 的应用。 既然要用,都9102年了,当然要与时俱进,我这里选择的是基于Spring Boot 2.0.x 的Spring Cloud Finc ...
看下这样一段代码: 我在一个方法中建立了个死循环,循环的判断条件为一个boolean类型的成员变量。 然后在main线程中,创建了一个新的名为 “t1” 的线程,去执行这个方法。 等待一秒后,mian线程自身,将该成员变量的值改为false,试图使其不满足条件从而循环终止。 按照正常的逻辑来说,按照脑海中预演的情 ...
AMQP核心概念: Server:又称Broker,接收客户端的连接,实现AMQP实体服务 Connection:连接,应用程序与Broker的网络连接。 Channel:网络信道,几乎所有的操作都在Channel中进行,每个Channel代表一个会话任务。 Message:消息,服务器和应用程序之间传送的数据,由Properties和Body组成。Properties可以对消息进行修饰,比 ...
过不久就需要亲身参与/负责一个分布式架构。得用到消息进行服务器之间的通信。技术选型为RabbitMQ,赶紧自学一下。 今天太晚了之后的就不弄了。也就安装完了进了下管控台。特么主要是我想用虚拟机里边的mysql,偏偏这mysql密码我忘了,搞了好久。 RabbitMQ是一个开源的消息代理和队列服务器,用来通过普通协议在完全不同 ...
做了个导出Excel文档的需求 于是写了个泛用性挺高的工具,只要是简单对象都没问题。即对象Field的类型都为基本数据类型及其包装类、String、Date这些就可以。要是对象里边还有集合啊、对象啊啥的就不行了。 挺简单的,就懒得传到Github了,写篇博客记录一下。 既然要使用apache poi,,首先就得导入依赖 XML: & ...
我总感觉网上写的和我写的不是同一个模式似的… 我这个状态切换的流畅的一批,而且外部调用者完全与其状态的变换隔离。 也完美符合迪米特法则,新增状态原有代码逻辑一丝都不用修改。 就是实现起来略复杂 核心: 用于解决系统中复杂对象的状态转换以及不同状态下行为的封装问题 结构: -Context环境类 ...
模板方法模式是编程中经常用到到的模式。它定义了一个操作中的算法骨架,将某些步骤延迟到子类中实现。这样,新的子类可以在不改变一个算法结构的前提下重新定义该算法的某些特定步骤。 核心:处理某个流程的代码已经都具备,但是其中某个节点的代码暂时不能确定。因此,可以将该节点的代码实现转移给子类完成。即:处理 ...