albon arith

一些总结,欢迎交流

系统设计:关于高可用系统的一些技术方案

系统设计关于高可用系统的一些技术方案 高可用方法论 扩展 隔离 解耦 限流 分类 漏桶算法 令牌桶算法 滑动窗口计数法 动态限流 降级 熔断 发布相关 模块级自动化测试 灰度发布 回滚 其他 总结 参考资料 系统设计:关于高可用系统的一些技术方案 可靠的系统是业务稳定...

2017-09-17 09:22:32

阅读数:3253

评论数:0

Effective Java 读书笔记(二):对于所有对象都通用的方法

Effective Java 读书笔记二对于所有对象都通用的方法 覆盖 equals 时要遵守的约定 覆盖 equals 的时候总是覆盖 hashCode 始终要覆盖 toString 谨慎覆盖 clone 考虑实现 Comparable 接口

2017-09-30 16:13:53

阅读数:192

评论数:0

Effective Java 读书笔记(一):创建和销毁对象

考虑用静态工厂方法代替构造器 构造器参数较多时考虑用 Builder 构建 用私有构造器或枚举类型强化 Singleton 属性 在私有构造器里抛异常来强化不可实例化的能力 避免创建不必要的对象 消除过期的引用 避免使用终结方法 finalize

2017-09-29 17:44:22

阅读数:255

评论数:0

Java 日志框架解析:设计模式、性能

在平常的系统开发中,日志起到了重要的作用,日志写得好对于线上问题追踪有着很大的帮助。一个好的日志框架,既要方便易用,也要有较好的性能,减少日志输出对系统内存、CPU 的影响。 研究一款开源项目,学到的不仅仅是这个项目本身,还会学到很多设计思想,可以利用到日常工作中。

2017-09-28 10:00:54

阅读数:1475

评论数:0

Java 进阶:异常影响性能吗?

Java 进阶:异常影响性能吗?曾经在给一个业务系统增加限流功能,使用的限流组件在流量超过阈值时,会直接抛异常,异常导致 CPU 占用率飙升。第一次遇到这样的情况,让我们不得不思考,异常怎么会对性能造成这么大的影响?下面我们写几个测试程序观察一下。

2017-09-24 10:31:26

阅读数:1283

评论数:0

Java 进阶:如何让线程主动让出 CPU

在 Java 中,有哪些方法可以让线程让出 CPU 呢?

2017-09-22 23:22:04

阅读数:1080

评论数:0

深入理解 Java 泛型:类型擦除、通配符、运行时参数类型获取

泛型的本质是参数化类型,相比于直接使用 Object 的好处是:编译期强类型检查、无需进行显式类型转换。这里介绍一些泛型的用法、特性,以及如何在运行时获取泛型参数类型信息。

2017-09-21 10:00:58

阅读数:584

评论数:0

Java 迭代器介绍

迭代器介绍迭代器模式迭代器模式是一个典型的设计模式,提供一种方法访问一个容器对象中各个元素,而又不暴露该对象的内部细节。因为屏蔽了细节,可以针对不同实现的容器,提供一致的标准化的访问方法。

2017-09-18 14:46:01

阅读数:414

评论数:0

Java 注解:注解处理器获取泛型真实类型

注解 annotation 是 Java 中的一大特性,是插入代码中的元数据。注解的使用能够大大简化代码的编写,所以在很多框架中得到了使用,比如 spring、hibernate-validator。泛型的真实类型信息会在编译期间擦除,注解处理器正是运行在编译期间,能够用来获取泛型真实信息。

2017-09-17 16:30:31

阅读数:1106

评论数:0

降级熔断框架 Hystrix 源码解析:滑动窗口统计

一个滑动窗口统计主要分为两步: 1. bucket 统计,bucket 的大小决定了滑动窗口滚动时间间隔; 2. window 统计,window 的时长决定了包含的 bucket 的数目。 Hystrix 实现滑动窗口利用了 RxJava 这个响应式函数编程框架。

2017-09-14 11:25:09

阅读数:2171

评论数:0

Java 线程同步基础类 LockSupport 解析

LockSupport 类提供了基本的线程同步原语,是实现 AbstractQueuedSynchronizer 和 ReentrantLock 的基础。

2017-09-12 21:13:30

阅读数:293

评论数:0

Java 同步框架 AQS 深入分析

AQS 框架提供了先进先出的阻塞锁实现,在此基础上,提供了独占和共享等多种模式供使用方实现。除此之外,还提供了一个条件变量的实现。 锁是一种线程同步机制,用于保护对临界资源的访问。条件变量提供了一个“等待 - 唤醒”的机制,在阻塞队列里起到了生产者和消费者之间的通信的作用。

2017-09-12 09:14:33

阅读数:356

评论数:0

Java 同步原语 synchronized 剖析和锁优化

本文解析了 synchronized 的底层实现,介绍了 JVM 中优化锁的一些方法,以及实际编程中使用的一些锁优化方法。

2017-09-10 10:36:05

阅读数:471

评论数:0

日志压缩资源消耗优化: Linux CGroup 的使用

我们有一个系统,本身压力比较大,平常 CPU 占用率在 60% 左右。在整点之后的日志压缩时,CPU 占用率更是飙到来 80%,造成系统 Load 经常报警,烦不胜烦。 使用 top 命令查看后发现,gzip 压缩进程占用 CPU 资源过多,于是想到了利用 CGroup 来限制日志压缩进程的资...

2017-09-08 23:41:03

阅读数:433

评论数:0

深度剖析 JDK7 ConcurrentHashMap 中的知识点

看源码时候的一点儿总结:锁分离 Lock Stripping、Unsafe、自旋、顺序一致性 Sequential Consistency、权衡 Trade Offs。

2017-09-05 20:49:25

阅读数:248

评论数:0

性能优化概述

如何做性能优化 确定优化目标 定位性能瓶颈 制定优化方法 测试优化效果 性能优化目标是什么 吞吐量,越大越好 延时,越低越好 同样的资源下(前提),吞吐量越高越好,响应时间越低越好。通俗的讲就是:多快好省。 如何定位系统性能的瓶颈呢 资源分析 代码分析 资源分...

2017-09-04 10:53:10

阅读数:200

评论数:0

提示
确定要删除当前文章?
取消 删除
关闭
关闭