重写 ELK 相关信息
ELK in docker官方文档见:《Running the Elastic Stack (“ELK”) on Docker》 Start Elasticsearch and Kibana in Docker任意在容器中启动的单节点 Elasticsearch 集群都会 security will be automatically enabled and configured for you。这包括: 证书和key会在配置目录下自动生成。Certificates and keys are generated for the transport and HTTP layers.``When you install Elasticsearch, the following certificates and keys are generated in the Elasticsearch configuration directory, which are used to connect a Kibana instance to your secured Elasticsearch...
一个隐藏了17年的 JDK Bug
问题起因因为工作需要,笔者最近考虑利用 Java 标准文档里的标准 API做一个批量执行任务的框架,: 这个 API 的语义是: 批量执行任务。 在任务执行完成(不管任务是被正常终止还是异常终止)后,批量返回一个持有任务状态的 Future 列表。 我们团队内部的代码里已经有了一个自定义线程池的工厂方法,大义是: 1234567891011121314151617181920212223242526272829303132333435363738394041/** * 一个有缺陷的线程池构造器 * * @param corePoolSize the number of threads to keep in the pool, even * if they are idle, unless {@code allowCoreThreadTimeOut} is set * @param maximumPoolSize the maximum number of threads to allow...
Lombok 拾遗
sneakyThrow12345678public static RuntimeException sneakyThrow(Throwable t) { if (t == null) throw new NullPointerException("t"); return Lombok.<RuntimeException>sneakyThrow0(t); } private static <T extends Throwable> T sneakyThrow0(Throwable t) throws T { throw (T)t; }
基于 Play 框架进行开发
构建和编译的方法sbt clean "project leads-web" "universal:packageZipTarball" 常用命令1234567891011121314151617# 在 sbt 里# 刷新命令reload;update;clean;compile# 切换到项目 aproject a# 在 sbt 的项目 a 里run "-Dotel.resource.attributes=serviceName=iouy"# 如果使用了 coursier 来管理依赖的话,查看依赖coursierDependencyTree# 在普通的 shell 里# 开启远程调试sbt -jvm-debug 9999 run# 传递 jvm 参数sbt -J-javaagent:skywalking-agent.jar -jvm-debug 9999 run ORMebean1234567891011121314151617181920212223242526lazy val `model-base` =...
领域驱动设计汇总
总结DDD 主要是面向对象范式的高级应用。分治、分层、抽象、演化是架构设计的4大原则。 分治是为了让复杂度变小,而且围绕单一的中心概念具有内聚,又通过边界区别彼此。在DDD中,在解决规模性问题,防止模型出现分裂-矛盾和重复的时候,使用战略设计:上下文(支持边界,天然为微服务服务,这里的上下文边界也是组织架构的边界,也强调团队管理)、精炼(围绕核心域的种种动作)、大型结构(分层在这里被强调)。战术设计则是围绕各种职责类型,强调程序的构造块。 分层 主要依赖于大型结构和模型驱动设计提到的 flexible layered architecture。 抽象意味着永远留有余地,核心越薄越好,这也是精炼要求的。 演化在这里则体现为,允许系统设计不断通过重构来精化模型。 在 DDD 的原书里面,为了防止模型出问题,才逐渐引入战略设计。但别的 DDD 书籍里面,作者们都主张直接从战略设计入手。 DDD 官网 真实的架构是由项目需求驱动出来的。 左半段最外层叫 interface 层;右半段最外层叫 infra 层。左半段的 bus 是 command query bus,右半段的...
如何写业务代码
业务研发面对的问题 稳定的业务模式 不稳定的需求 业务对交付的渴望 假设 命名规范(《clean code》) 面向对象设计(SOLID原则、贫血/充血模型、设计模式) 系统要拆分流程控制系统与领域系统.drawio 每一个用例(解决的一个问题)都由访问逻辑和执行逻辑组成。访问逻辑负责用例执行的顺序与分支,并调用执行逻辑完成完整业务逻辑。 访问逻辑由单独的交易系统负责。执行逻辑由个子系统负责。 工程要拆分三层架构 + 洋葱架构 代码要拆分 业务代码:描述核心业务逻辑的代码,核心是保持业务的流程及业务状态的一致性 领域对象与领域服务,不得对外部有任何依赖(工具类除外) 最核心的几个抽象: 校验:参数有效性校验、参数的业务属性校验。在进入正常业务逻辑代码前,完成所有的校验工作。 异常:业务异常:所有不符合业务逻辑而产生的异常。 系统异常:因为程序本身or依赖产生的异常。 所有的异常第一位runningtime异常。 数据: 业务数据:保存领域对象状态的数据。...
Idea 的小技巧
调试的时候的断点Suspend Policies Specifies whether to pause the program execution when the breakpointis hit. Non-suspending breakpoints are useful when you need to log someexpression without pausing the program (for example, when you need toknow how many times a method was called) or if you need to create amaster breakpoint that will enable dependent breakpoints when hit. The following policies are available for the breakpoints that suspendprogram execution: All: all threads are suspended when any...
面向好的架构编程
前言本文是《架构随笔》系列的第五篇,也是它的收官之作。 架构的定义架构是一个界定不清的东西,我们很难讲清楚哪些东西是架构,哪些东西不是架构。但软件行业里其实人人都在搞架构,软件设计就是架构本身。 架构这个词出现得很早,有些人认为是 NASA(也可能是NATO)...
性能优化
每个人都应该知道的操作时间出处:《每个程序员都应该知道的延迟数字》
技术拾遗
JavaJava 8LambdaJava 8 Lambdas - A Peek Under the HoodWhat does $$ in javac generated name mean? lambda 表达式并不总是持有外部 enclosing object 的引用,如果它不访问任何外部变量,即不持有这样的引用。只要设计一个对比实验,就会发现引用过外部变量的lambda实例才会产生一个 arg 的隐式参数引用。而内部类内部总是含有一个this$0。 lambda表达式是词法作用域的-意思是不产生新的作用域,不产生任何shadowing问题。它可以无缝访问外部作用域的东西,就好像从一个 if block 里访问一个方法里的其他变量一样。但,同样地,不能声明新变量。