标签: Java

23 篇文章

thumbnail
利用策略模式来重构可以预见的if else代码
相信大家一定见过自己项目中的满屏if else魔鬼代码,对于可以预见的逻辑分支增长,在前期代码设计阶段是有必要精心设计一番的。 案例 假设有一个需求如下,A系统的某个业务操作完成后,会发送一个webhook通知给B系统,webhook消息格式如下: { "type": "type1", // 目前已知的type为type1,type2 "data"…
thumbnail
神了,SpringBoot启动仅需0.068s!
GraalVM是Oracle搞出来的一种高性能的虚拟机,可以显著的提高程序的性能和运行效率,非常适合微服务。 最近比较火的Quarkus框架默认支持,SpringBoot当前也开始跟上了步伐,在Spring Initializr网站可以看到,基于GraalVM的Spring Native已经进入了实验阶段, 这意味着,不久的将来能提供一种全新的方式…
thumbnail
Dataway::后端接口开发或将迎来新的变革?
概述 你是否厌烦了面向CRUD编程?近期逛Github又发现了一个神奇的开源项目[zycgit/hasor],其中有个模块甚是诱人,这里摘抄一段其官网的描述: Dataway 是基于 DataQL 服务聚合能力,为应用提供的一个接口配置工具。使得使用者无需开发任何代码就配置一个满足需求的接口。 整个接口配置、测试、冒烟、发布。一站式都通过 Data…
thumbnail
微信开发:如何实现AMR->MP3->AMR音频转码
概述 接触微信公众号开发的小伙伴一定对AMR这种音频格式不陌生,在微信公众号发送的语音,基本是这种格式,接收到后台后,还需要手动转换为MP3,这里探讨一下几种实现方式。 使用七牛提供的API 如果你使用七牛作为系统的云储存,那么音频转码将非常简单,先来看几个文档:1)普通音视频转码(avthumb) https://developer.qiniu.…
thumbnail
分布式限流::Redis+Lua 在分布式应用中的限流实战
概述 作为分布式应用的三大法宝之一(缓存、降级、限流),限流系统尤其是对外开放系统中,显得尤其重要。限流的目的是通过对并发访问进行限速,一旦达到一定的速率就可以拒绝服务,从而避免业务高峰期因暴增的流量直接将服务器打死。 常见的限流算法 信号量计数器漏桶算法令牌桶算法 在这里,咱们主要研究两种比较常用的( 计数器 、 令…
当synchronized关键字作用在字符串上的一些问题
概述 现有需求如下,每个用户(租户ID:用户ID)执行某个操作时,对其进行计数,在考虑高并发的情况下,不会产生计数错误问题。 实现 看到需求后,脑中迅速想好了一个简单思路:将用户(租户ID:用户ID)作为 KEY, 在执行查询和更新时,利用关键字synchronized锁之即可,下面是测试代码: public class Main { privat…
thumbnail
深入理解 Java 中的 SPI 机制
概述 SPI(Service Provider Interface)是一种比较流行的服务发现机制,其核心原理是通过在扫描classpath:META-INF/services文件夹下定义文件,来实现自动加载某个接口的实现类。 这种机制常为很多框架的扩展提供了便捷,比较常见的,如 Dubbo、JDBC 等。 小案例 下面先通过一个小案例,来看看我们是…
Jackson对枚举字段的序列规则
现有个枚举类型,内部定义了一些属性,使用 Jaskson 来进行序列化成 JSON 字符串 enum class Error( var code: Int, var reason: String, var description: String ) { UNKNOWN(-1, "unknown", "发生了未知错误,请联系管理员…
thumbnail
浅谈如何设计一个高并发系统
概述 为什么要设计高并发的系统呢?随着日益增长的用户量,一般来说,一个系统起步都是直接是连接数据库的,而数据库支撑到每秒并发两三千的时候,基本就快完了,不断的堆配置,加集群始终不是解决之道。 一个高并发的系统,应该从以下几个方面逐步优化: 系统拆分缓存中间件MQ 消息队列分库分表数据库读写分离ElasticSearch 系统拆分 将一个系统,按照业…