自定义博客皮肤VIP专享

*博客头图:

格式为PNG、JPG,宽度*高度大于1920*100像素,不超过2MB,主视觉建议放在右侧,请参照线上博客头图

请上传大于1920*100像素的图片!

博客底图:

图片格式为PNG、JPG,不超过1MB,可上下左右平铺至整个背景

栏目图:

图片格式为PNG、JPG,图片宽度*高度为300*38像素,不超过0.5MB

主标题颜色:

RGB颜色,例如:#AFAFAF

Hover:

RGB颜色,例如:#AFAFAF

副标题颜色:

RGB颜色,例如:#AFAFAF

自定义博客皮肤

-+

知秋的博客

功不唐捐

  • 博客(55)
  • 收藏
  • 关注

原创 Springboot 3.x - Reactive programming (2)

Spring WebFlux

2024-07-16 21:23:52 612

原创 Java Reactive Streams Backpressure mechanisms

Java Reactive Streams Backpressure mechanisms

2024-07-13 13:52:53 942

原创 Springboot 3.x - Reactive programming

Reactive programming

2024-07-07 17:29:34 1045 2

原创 极致性能优化之道之消除伪共享

伪共享是由于缓存行的概念引起的。现代计算机架构中,缓存被分割成一些大小固定的缓存行,通常为64字节。多个线程可能在不同的核上同时访问同一缓存行的不同部分,这导致了缓存行的频繁无效化和刷新,从而降低了性能。

2023-11-21 14:16:51 578

原创 Kafka从安装使用到集成Springboot详细教程

kafka使用指南

2023-11-15 13:49:20 807

原创 Java使用Zstandard压缩算法对字节数组进行压缩和解压缩

最近在做项目的时候,因为项目部署在国外,又是公网的环境,流量费用很贵,所以需要使用Netty对传输的数据进行压缩和解压缩,准备用Facebook的Zstandard试试性能,听说压缩性能好,还可以根据需求调整压缩比。然而在网上搜索了一阵子发现,java通过zstd对字节数组做压缩和解压缩的例子很少,仅有的几个给出的API还都是错误的,更别说跑通了,就算使用Gpt3.5和4.0给的的示例也是错误的,所以干脆写篇文章记录一下。

2023-11-02 14:06:48 949

原创 Netty使用SslHandler实现加密通信

不积跬步,无以至千里。

2023-10-17 18:30:27 928

原创 Zookeeper断网重连事件回调源码分析

不积跬步,无以至千里。

2023-10-14 16:17:46 1108

原创 Linux环境安装及使用Openresty:构建高性能Web应用

Openresty应用

2023-10-14 16:13:52 500

原创 Linux运行环境搭建系列-虚拟机安装

注意:需要开启CPU的虚拟化。

2023-10-14 16:12:31 277

原创 Linux运行环境搭建系列-Redis安装

构建环境:腾讯云CentOS 7.9。

2023-10-14 16:09:30 60

原创 Linux运行环境搭建系列-Docker安装

问题:新版 MySQL 授权用户时报错 near ‘IDENTIFIED BY ‘密码’ with grant option’ at line 1。原因:因为新版的的mysql版本已经将创建账户和赋予权限的方式分开了。

2023-10-14 16:08:27 194

原创 Linux运行环境搭建系列-Flink安装

【代码】Linux运行环境搭建系列-Flink安装。

2023-10-14 16:04:24 475

原创 Linux运行环境搭建系列-Kafka安装

【代码】Linux运行环境搭建系列-Kafka安装。

2023-10-14 16:02:57 284

原创 Linux运行环境搭建系列-Zookeeper安装

【代码】Linux运行环境搭建系列-Zookeeper安装。

2023-10-14 16:01:21 362

原创 Spring源码解析-环境变量(中)

spring源码

2022-12-14 15:29:06 405

原创 Spring源码解析-环境变量(上)

spring源码解析

2022-12-10 19:52:00 816

原创 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关注的人

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