从谷歌Dapper到阿里EagleEye

1、分布式链路追踪技术解决的问题

  • 分布式系统服务非常多,很复杂
  • 每个服务可能由不同项目组开发,没有一个人能详细地了解所有的系统。
  • 每个服务都可能集群部署,有很多台机器,整个系统可能有成千上万台机器。
  • 服务可能由不同语言开发的。
  • 当需要了解系统的整体表现或系统瓶颈时,需要知道整个调用链路的每个部分的耗时情况。
  • 当一次链路过程调用出错了,需要知道具体是哪个服务的哪一台机器出错,而不是到每一台机器上去看日志。

Read More

从Pandora到PandoraBoot

看过Pandora文档的一些介绍——轻量级的依赖隔离容器,在我脑子里浮现了这几个名词:Tomcat部署多应用、OSGI、Java9模块化。谷歌“依赖隔离”这个关键词出来的结果:类加载机制、蚂蚁开源的sofa-ark。所以读了很多文章想看看这些名词之间有什么联系。

1、从Tomcat说起

Read More

从notify和metaq初窥消息队列的前世今生

上一家公司并没有用消息队列中间件,大学里对ActiveMQ有所了解但并未深入研究,RocketMQKafka也一直囿于听闻。不过在原来的项目中经常会用Redis的list实现一个分布式的阻塞队列。在短信营销任务中,会将服务的同步调用改为异步任务存入队列表,Worker批量调度以提高吞吐量,并降低大促期间大批量短信同步调用带来的压力。我觉得后面这一点也非常接近消息队列所要实现的需求。然后受益于隆基前辈的阿里消息中间件架构演进之路:notify和metaq一文,用这篇小笔记总结下我对消息队列的认识和理解。

1、为什么用消息队列

Read More

由配置文件到Diamond配置中心引发的考究

对于配置中心,我也不算是第一次接触。在我从上一家公司离职之际正好赶上项目进行容器化——将原来直接部署在ECS的应用迁移到K8S。而应用的配置都被迁移到了Nacos上,所以我也算是经历过传统到前沿的过度阶段吧。入职阿里后,趁着了解Diamond来说说我对传统配置文件的形式和配置中心的形式的一些感受吧。

1、软件的老基友——配置文件

Read More

新人对TDDL分库分表的一些思考

分库分表这个技术在之前一家公司其实也有接触。上一家公司在业务上按照用户水平分库的,所以避免了很多业务上的问题,但也只是基于Spring的AbstractRoutingDataSource,根据userId做了简单的路由。之前也在网上听说过sharding-jdbc等中间件,也仅限于了解。所以结合我从内网看到的关于TDDL中间件的文章和外网看到的一些文章,在这篇文章中整理一下我这个新人对分库分表的认识。

1、单库单表

Read More

【译】Cglib缺失的文档

本文翻译自:https://dzone.com/articles/cglib-missing-manual

作为字节码库,cglib是许多著名的java框架(HibernateSpring等)比较流行的选择。字节码库允许在java应用的编译阶段之后,操作或者动态创建新的class。由于Java类在运行时动态链接,因此可以向正在运行的Java程序中添加新类。比如,Hibernate就会将cglib用于动态代理的生成。Hibernate将返回存储类的检测版本,该版本仅在需要时才从数据库延迟加载某些值,而不是返回存储在数据库中的完整对象。又比如,Spring用cglib给你的方法调用添加安全性规则。

Read More