并发编程之ThreadLocal与单例的推荐写法

摘要:本文结合最近网关项目代码重构,总结介绍了ThreadLocal是一种多线程间并发访问变量的解决方案,用空间换时间,并用代码示例说明,还介绍了什么是单例以及单例的推荐两种写法分别是静态内部类写法和dubbl check instance的写法,扩展介绍了其它懒汉,枚举,饿汉的写法等。

查看更多

Mybatis代码生成+分页+Mapper继承扩展

摘要 本篇文章主要介绍使用mybatis-gennerator快速生成代码,但是每次生成的Mapper或接口都会覆盖自定义的Mapper,因此介绍了Mapper接口的继承方式解决,还介绍了如何使用分页工具使用pagehelper结合Mybatis快速实现分页。

一. mybatis-gennerator

1.1 mybatis-gennerator自动生成代码

1.1.1 mybatis-gennerator的安装

Mybatis-Generator的下载地址:https://github.com/mybatis/generator/releases

  1. 在Eclipse安装mybatis-gennerator插件。

https://marketplace.eclipse.org/content/mybatis-generator

查看更多

Spring Boot杂谈总结(一)

摘要 本篇文章主要介绍在Spring Boot中使用Fastjson代替Jackson,以及实现自己的自定义异常和扩展Spring MVC全局异常解析器,以及为了给前端测试提供接口文档Spring Boot集成swagger,以及集成swagger遇到问题的处理。

一.Spring Boot中使用Fastjson代替Jackson

1.1 为什么使用Fastjson代替Jackson

Jackson最主要的原因是Jackson在处理对象之前的循环嵌套关系时不便。什么是对象间的循环嵌套?比如A有一个List,B对象里又有一个A对象,当然返回A对象的Json字符串时,如果是Jackson就会发生异常,因为Jackson天生不具备处理这种关系的能力,而Fastjson正好具备了这种能力。

如果你用的是 Jackson,可以使用相应的注解来支持对象间的循环嵌套。可以百度Jackson循环嵌套。

查看更多

自研网关纳管Spring Cloud(一)

摘要: 本文主要从网关的需求,以及Spring Cloud Zuul的线程模型和源码瓶颈分析结合,目前最近一段时间自研网关中间件纳管Spring Cloud的经验汇总整理。

一.自研网关纳管Spring Cloud的原因

1.1 为什么要自研网关

1.网关配置实时生效,配置灰度,回滚等
2.网关的性能,特别是防刷,限流,WAF等
3.动态Filter ,目前Zuul可以做到动态Filter,Filter配置下发,实时动态Filter
4.对网关的监控,告警,流量调拨,网关集群。
5.流程审计,增加Dsboard便捷的操作。

查看更多

Spring Cloud Zuul遗失的世界(三)

摘要: 接着上一篇《Spring Cloud Zuul遗失的世界(二)》,本文主要介绍Netflix Zuul core模块的Filter链的设计和Fifter Loader和Filter Manager相关代码的设计与分析。

查看更多

Spring Cloud Zuul遗失的世界(二)

摘要: 接着上一篇《Spring Cloud Zuul遗失的世界(一)》,ZuulController继承了ServletWrappingController,将当前应用中的ZuulServlet直接包装为一个Controller,暴露为入口访问,在本篇文章中介绍etflix-zuul-core的代码Zuul的执行的生命周期等。

一.Netflix zuul core源码分析

com.netflix.zuul.http.ZuulServlet是ZuulFilter链执行的入口,通过service方法,提取请求到RequestContext,然后通过调用ZuulRunner,依次按顺序执行每种类型的Filter,完成整个Filter的生命周期,架构图如下所示。

查看更多

Spring Cloud Zuul遗失的世界(一)

摘要: Zuul作为java网关届的鼻祖,2016年自研网关中间件的时候,对其源码看了很多次,经过两大互联网公司中间件的洗礼之后,目前轮到自己设计一个网关中间件纳管Spring Cloud。最近抽空把自己的理解,备注一下。由于Spring cloud整合Zuul的代码过多。本文主要介绍Spring Cloud对Netflix Zuul高度抽象封装整合部分。即spring-cloud-netflix-core的代码。

查看更多

《Spring Cloud中国社区上海网关专题会议》

网关在微服务中的地位尤其重要,如果网关挂了或者出现任何抖动,用户请求的流量将会损耗,将会造成巨大的损失。因此Spring Cloud中国社区联合上海秦苍科技,走进企业畅聊Spring Cloud实战经验,以及网关经验。

一.会议内容

1.主题《Spring Cloud中国社区上海网关专题》
2.时间:2017年8月20,会议方式:闭门会议
3.地点:上海市浦东新区峨山路91弄陆家嘴软件园9号楼(北楼)8楼
4.主办方Spring Cloud中国社区+上海秦苍科技
5.预计参会人数: 40-50人之间,先到先得,名额满关闭报名通道。
6.分享方式(分享人分享+讨论+头脑风暴)

查看更多

微服务网关解决方案调研和使用总结

一.什么是网关

1.1 什么是网关

API Gateway(APIGW / API 网关),顾名思义,是出现在系统边界上的一个面向API的、串行集中式的强管控服务,这里的边界是企业IT系统的边界,可以理解为企业级应用防火墙,主要起到隔离外部访问与内部系统的作用。在微服务概念的流行之前,API网关就已经诞生了,例如银行、证券等领域常见的前置机系统,它也是解决访问认证、报文转换、访问统计等问题的。

查看更多

深入理解HashMap上篇

前言: HashMap是Java程序员使用频率最高的用于映射(键值对)处理的数据类型。随着JDK(Java Developmet Kit)版本的更新,JDK1.8对HashMap底层的实现进行了优化,例如引入红黑树的数据结构和扩容的优化等。最近刚好有时间,刚好把HashMap相关的内容和之前做唯品会网关的一些经验整理一下。

一.HashMap的概述

1.1 HashMap的数据结构

HashMap的内存结构和原理,以及线程安全都是面试的热点问题。Java中的数据结构基本可以用数组+链表的解决。

  • 数组的优缺点:通过下标索引方便查找,但是在数组中插入或删除一个元素比较困难。
  • 链表的优缺点:由于在链表中查找一个元素需要以遍历链表的方式去查找,而插入,删除快速。因此链表适合快速插入和删除的场景,不利于查找

查看更多