- 博客(55)
- 收藏
- 关注
原创 Java Reactive Streams Backpressure mechanisms
Java Reactive Streams Backpressure mechanisms
2024-07-13 13:52:53
942
原创 极致性能优化之道之消除伪共享
伪共享是由于缓存行的概念引起的。现代计算机架构中,缓存被分割成一些大小固定的缓存行,通常为64字节。多个线程可能在不同的核上同时访问同一缓存行的不同部分,这导致了缓存行的频繁无效化和刷新,从而降低了性能。
2023-11-21 14:16:51
578
原创 Java使用Zstandard压缩算法对字节数组进行压缩和解压缩
最近在做项目的时候,因为项目部署在国外,又是公网的环境,流量费用很贵,所以需要使用Netty对传输的数据进行压缩和解压缩,准备用Facebook的Zstandard试试性能,听说压缩性能好,还可以根据需求调整压缩比。然而在网上搜索了一阵子发现,java通过zstd对字节数组做压缩和解压缩的例子很少,仅有的几个给出的API还都是错误的,更别说跑通了,就算使用Gpt3.5和4.0给的的示例也是错误的,所以干脆写篇文章记录一下。
2023-11-02 14:06:48
949
原创 Linux运行环境搭建系列-Docker安装
问题:新版 MySQL 授权用户时报错 near ‘IDENTIFIED BY ‘密码’ with grant option’ at line 1。原因:因为新版的的mysql版本已经将创建账户和赋予权限的方式分开了。
2023-10-14 16:08:27
194
原创 Linux压测工具wrk安装与使用
简介wrk是一款简单的HTTP压测工具,托管在Github上,https://github.com/wg/wrk。wrk 的一个很好的特性就是能用很少的线程压出很大的并发量. 原因是它使用了一些操作系统特定的高性能 io 机制, 比如 select, epoll, kqueue 等. 其实它是复用了 redis 的 ae 异步事件驱动框架。 确切的说 ae 事件驱动框架并不是 redis 发明的, 它来自于 Tcl 的解释器 jim, 这个小巧高效的框架, 因为被 redis 采用而更多的被大家所熟知
2022-05-12 12:10:33
2406
原创 Gor + Apisix实现流量复制
环境准备#安装Go 1.13+$ wget https://dl.google.com/go/go1.13.linux-amd64.tar.gz$ tar -C /usr/local -zxvf go1.13.linux-amd64.tar.gz$ sudo vim /etc/profileexport GOROOT=/usr/local/goexport PATH=$PATH:$GOROOT/bin$ source /etc/profile#查看Go版本$ go version##
2022-05-12 12:06:17
962
1
原创 设计模式系列(2)- 迭代器模式、适配器模式
迭代器模式简介所谓迭代器模式,就是面向Iterator接口编程,无论底层的数据结构和迭代算法如何变化,调用者都不用修改代码;高内聚,低耦合,才是程序设计之道。一般很少需要自己写这个iterator模式,都是在集合编程中使用,尤其是如果要对集合元素遍历过程中做插入删除操作,那就用iterator,如果要对某个类中的集合进行遍历,由那个集合类返回一个iterator回来,统一面向iterator迭代器接口来编程遍历,提高系统整体的可维护性,可扩展性。如果自己写iterator模式,一般是研发底层的框架
2021-12-23 13:12:53
2308
1
原创 设计模式系列(1)- 状态模式 、观察者模式
状态模式简介状态模式,就是维护多种不同的状态,每种状态下可以去执行一些特殊的逻辑。然后由一个Context类负责根据请求参数调用,来维护这些状态之间的切换,形成一个状态机的概念。状态模式里,非常重要的一点就是将状态之间流转的逻辑,封装在Context类里面。本来可能需要调用方自己维护复杂的状态流转逻辑,流转到不同的状态之后,执行状态对应的代码逻辑。使用场景这个状态模式,在电商系统中有天然的运用场景,系统中很多数据都有大量的状态变更的逻辑,像订单,出库单等等,我们可以将状态变更的逻辑用状态模式来实现
2021-12-23 10:37:14
1260
原创 xxl-job系列(3)- 几种任务调度形式
1 BEAN模式(类形式)Bean模式任务,支持基于类的开发方式,每个任务对应一个Java类。优点:不限制项目环境,兼容性好。即使是无框架项目,如main方法直接启动的项目也可以提供支持,可以参考示例项目 “xxl-job-executor-sample-frameless”;缺点:每个任务需要占用一个Java类,造成类的浪费;不支持自动扫描任务并注入到执行器容器,需要手动注入。步骤一:执行器项目中,开发Job类:1、开发一个继承自"com.xxl.job.core.handler.
2021-12-22 19:21:16
4505
原创 xxl-job系列(2)- 任务详解
开发第一个任务“Hello World”“GLUE模式(Java)”的执行代码托管到调度中心在线维护,相比“Bean模式任务”需要在执行器项目开发部署上线,更加简便轻量。前提:请确认“调度中心”和“执行器”项目已经成功部署并启动;步骤一:新建任务:登录调度中心,进入任务管理,点击“新建任务”按钮,新建示例任务。然后,点击保存。步骤二:“GLUE模式(Java)” 任务开发:点击任务操作栏 “GLUE IDE” 按钮,进入 “GLUE编辑器开发界面” ,见下图。“GLUE模式(Java)”
2021-12-22 18:39:19
3467
原创 xxl-job系列(1)- 快速入门
快速入门1 初始化“调度数据库”“调度数据库初始化SQL脚本” 位置为:/xxl-job/doc/db/tables_xxl_job.sql调度中心支持集群部署,集群情况下各节点务必连接同一个mysql实例;如果mysql做主从,调度中心集群节点务必强制走主库;2 编译源码解压源码,按照maven格式将源码导入IDE, 使用maven进行编译即可,源码结构如下:xxl-job-admin:调度中心xxl-job-core:公共依赖xxl-job-executor-samples:执行器
2021-12-22 18:38:21
416
原创 高性能微服务网关APISIX - 常用插件(3)
limit-req简介限制请求速度的插件,使用的是漏桶算法。属性名称类型必选项默认值有效值描述rateinteger必须rate > 0指定的请求速率(以秒为单位),请求速率超过 rate 但没有超过 (rate + burst)的请求会被加上延时。burstinteger必须burst >= 0t请求速率超过 (rate + burst)的请求会被直接拒绝。keystring必须[“remote_addr”, “ser
2021-12-17 20:11:54
2352
原创 高性能微服务网关APISIX - 常用插件(2)
proxy-rewrite简介proxy-rewrite 是上游代理信息重写插件,支持对 scheme、uri、host 等信息的重写。属性NameTypeRequirementDefaultValidDescriptionschemestring可选“http”[“http”, “https”]不推荐使用。应该在 Upstream 的 scheme 字段设置上游的 scheme。uristring可选转发到上游的新 uri 地址。meth
2021-12-17 19:15:45
1918
1
原创 高性能微服务网关APISIX - 常用插件(1)
APISIX 常用插件(1)APISIX 插件机制Plugin 表示将在 HTTP 请求/响应生命周期期间执行的插件配置。Plugin 配置可直接绑定在 Route 上,也可以被绑定在 Service 或 Consumer上。而对于同一 个插件的配置,只能有一份是有效的,配置选择优先级总是 Consumer > Route > Service。在 conf/config.yaml 中,可以声明本地 APISIX 节点都支持哪些插件。这是个白名单机制,不在该白名单的插件配置,都将会被自动忽
2021-12-17 13:32:29
4891
原创 Linux运行环境搭建系列-JDK安装
安装Java构建环境:腾讯云CentOS 7.9。JDK jar包:自备。使用scp命令上传Jar包到/usr/local目录下:$ scp jdk-8u152-linux-x64.tar.gz root@81.70.247.41:/usr/local解压缩$ cd /usr/local && tar zxvf jdk-8u152-linux-x64.tar.gz && rm -f jdk-8u152-linux-x64.tar.gz设置环境变
2021-12-16 15:28:15
1650
原创 使用kubeadm部署Kubernetes集群(v1.20.0)
使用kubeadm部署Kubernetes集群(v1.20.0)介绍Kubeadm是一个K8s部署工具,提供kubeadm init和kubeadm join,用于快速部署Kubernetes集群。环境准备服务器要求:• 建议最小硬件配置:2核CPU、2G内存、30G硬盘• 服务器最好可以访问外网,会有从网上拉取镜像需求,如果服务器不能上网,需要提前下载对应镜像并导入节点软件环境:软件版本操作系统CentOS 7.x 64位容器引擎Docker CE 19
2021-12-15 20:41:33
1285
原创 高性能微服务网关APISIX - API文档
Admin APIDescriptionAdmin API 是为 Apache APISIX 服务的一组 API,我们可以将参数传递给 Admin API 以控制 APISIX 节点。更好地了解其工作原理,请参阅 architecture-design 中的文档。启动 Apache APISIX 时,默认情况下 Admin API 将监听 9080 端口(HTTPS 的 9443 端口)。您可以通过修改 conf/config.yaml 文件来改变默认监听的端口。在下面出现的 X-API-KEY 指
2021-12-15 18:37:25
8227
2
原创 APISIX Dashboard 源码构建
APISIX Dashboard 源码构建注:此文档构建环境为腾讯云CentOS 7.9,虚拟机同样适用。SourceThe Dashboard project contains both manager-api and web, but web is optional.The manager-api and web will be included in this build guide product.PrerequisitesBefore using source codes to b
2021-12-15 18:29:28
2122
1
原创 Apache APISIX 源码构建
如何构建 Apache APISIX注:此文档构建环境为腾讯云CentOS7.9,虚拟机同样适用。步骤1:安装依赖# 编写依赖脚本cd /usr/local && mkdir apisix-depscd apisix-deps && vim deps.sh# 脚本内容见下方代码块# 添加权限并执行脚本,安装依赖chmod +x deps.sh && ./deps.shrm -f deps.sh#!/usr/bin/env bash
2021-12-15 16:51:03
1349
原创 Feign源码深度刨析-(7)终章:请求处理组件LoadBalancerCommand
“不积跬步,无以至千里。”Controller中调用FeignClient 接口方法,经过动态代理机制,由FeignInvocationHandler 的invoke() 方法处理,转而交给SynchronousMethodHandler 的invoke() 方法处理,继续调用LoadBalancerFeignClient 的execute() 方法return lbClient(clientName).executeWithLoadBalancer(ribbonRequest, requestCo.
2021-08-27 16:26:49
683
原创 Feign源码深度刨析-(6)动态代理核心处理器:FeignInvocationHandler
“不积跬步,无以至千里。”前面说了,FeignClientFactoryBean的getObject()方法返回的就是一个类型为FeignInvocationHandler的代理对象所有,一旦Controller 中调用feign接口的方法,实际调用的就是这个动态代理,有点尝试的都知道,对于动态代理对象的方法调用,都会经过其绑定的InvocationHandler 的invoke()方法来处理private final Map<Method, MethodHandler> dispat.
2021-08-20 18:05:30
761
原创 Feign源码深度刨析-(5)核心组件FeignClientFactoryBean(下)
“不积跬步,无以至千里。”回顾一下,前面说了,把Feign.Builder、context、HardCodedTarget 一起传入了一个loadBalance()方法里面,最后给 return 了,这个 return 的就是feign client的代理对象,然后注入给Controller的属性这篇文章来着重分析一下 loadBalance() 方法protected <T> T loadBalance(Feign.Builder builder, FeignContext cont.
2021-08-20 15:44:55
384
原创 Feign源码深度刨析-(4)核心组件FeignClientFactoryBean(中)
“不积跬步,无以至千里。”这一篇文章的话,就来看一下feign的动态代理是怎么生成的,生成的动态代理会被添加到容器中,在需要的时候被调用,实际上我们前面也说了,在Controller中自动注入的就是这里生成的动态代理对象,那么这个对象里面包含了什么组件?怎么读取application.yml中配置的跟feign相关的参数的?接着上篇的代码继续跟进,给Feign.Builder 注入一些组件(logger、encoder、decoder等)之后configureFeign(context, buil.
2021-08-19 11:42:33
328
原创 Feign源码深度刨析-(3)核心组件:FeignClientFactoryBean(上)
“不积跬步,无以至千里。”前面说了,@EnableFeignClients 这个注解往容器中导入了一个组件 FeignClientsRegistrar ,这个组件实现了 ImportBeanDefinitionRegistrar接口,那么它的 registerBeanDefinitions() 方法就会往spring容器中导入一些组件registerFeignClients(metadata, registry);这个方法会搞一个组件扫描器ClassPathScanningCandidateCom.
2021-08-18 14:40:05
570
原创 Feign源码深度刨析-(2)组件扫描器:ClassPathScanningCandidateComponentProvider
“不积跬步,无以至千里。”这篇文章,一起来看看feign的核心机制,看看是如何扫描所有包下的@FeignClient注解的接口入口就是这个registerFeignClients(metadata, registry)方法public void registerFeignClients(AnnotationMetadata metadata, BeanDefinitionRegistry registry) { ClassP.
2021-08-16 18:22:36
727
2
原创 Feign源码深度刨析-(1)初探:@EnableFeignClients
“不积跬步,无以至千里。”之前我们讲了ribbon的核心源码,其实在实际生产环境中,国内用ribbon+restTemplate去做微服务调用的甚少,因为会导致我们每次去调用人家一个接口,都要单独写一些代码,非常不简洁,所以我们这一个专题开始,研究一下feign的底层核心源码。feign这个东西呢,底层也是依赖了ribbon做负载均衡的,所以是整合了ribbon的,feign的具体用法这里就不赘述了,相信来看这篇博文的,都是熟练使用的,技术,用,是很简单的,随便百度一下,csdn其他的文章,一搜一大.
2021-08-16 12:39:28
541
原创 Ribbon源码深度刨析-(5)ServiceRequestWrapper
“不积跬步,无以至千里。”上文写到,ribbon通过其内置的IRule组件,使用指定的负载均衡算法(默认轮询)从ILoadBalancer组件的server list中会拿到一个真正要发送请求的server地址,那么接下来,就会调用网络通信组件发起http请求了。@Overridepublic <T> T execute(String serviceId, ServiceInstance serviceInstance, LoadBalancerRequest<T> req.
2021-08-13 11:33:10
1291
2
空空如也
空空如也
TA创建的收藏夹 TA关注的收藏夹
TA关注的人