- Spring Boot使用WebSocket
洗发水很好用
springbootwebsocket后端
跟其他http的控制层类似,我们需要实现一个基本的WebSocket服务器端点。PlatformAsyncWebSocket.javapackagecom.rmeservice.platform.websocket;importlombok.extern.slf4j.Slf4j;importorg.springframework.stereotype.Component;importjavax.w
- Spring Boot 全局异常处理
十二同学啊
SpringBootspringbootjava前端
在开发任何应用程序时,异常处理都是至关重要的。一个良好的异常处理机制不仅能提高用户体验,还能帮助开发者更好地定位和修复问题。SpringBoot提供了强大的异常处理能力,使我们能够集中处理应用程序中抛出的各种异常,从而构建更健壮和可靠的系统。 本文将深入探讨SpringBoot中全局异常处理的最佳实践,包括如何创建全局异常处理器,如何自定义异常响应,以及如何处理不同类型的异常。为什么需要全局
- Spring Boot 统一返回数据格式
十二同学啊
SpringBootspringbootjava
在构建RESTfulAPI时,保持一致的返回数据格式至关重要。统一的返回格式不仅可以提高API的可读性,还能方便客户端解析和处理响应数据。SpringBoot提供了多种方式来实现统一的返回数据格式,本文将深入探讨如何在SpringBoot项目中实现这一目标,并提供代码示例和最佳实践。为什么需要统一的返回数据格式?提高API可读性:统一的格式可以让客户端更容易理解API的响应数据。简化客户端解析
- 解决jdk17下升级Spring6.x导致api方法无法获取参数名称的问题
由于我们的api接口是通过参数名称与json对象属性名绑定的,类似这样:调用时传递json对象:因此参数名称很重要。原本以为通过-parameters参数可以在编译时保留参数,但因为使用混淆工具后,参数名称变了,还是导致参数绑定失败。而且我们用的混淆工具也不支持保留参数名。原本jdk1.8的情况下,由于Spring框架内部有兼容机制(见后述),也是可以兼容的。但升级到jdk17的Spring6.x
- Java HTTP POST请求工具方法详解:架构、实践与最佳实践(可变参数)
码农阿豪@新空间代码工作室
好“物”分享javahttp架构
个人名片作者简介:java领域优质创作者个人主页:码农阿豪工作室:新空间代码工作室(提供各种软件服务)个人邮箱:[
[email protected]]个人微信:15279484656个人导航网站:www.forff.top座右铭:总有人要赢。为什么不能是我呢?专栏导航:码农阿豪系列专栏导航面试专栏:收集了java相关高频面试题,面试实战总结️Spring5系列专栏:整理了Spring5重要知识点与
- springboot 利用html模版导出word
经典1992
springboothtmlword
1.maven配置 org.freemarker freemarker 2.3.32 2.控制层业务代码@GetMapping("/exportConstructionLogDocx")@ApiOperation(value="Ai施工日志导出docx")publicvoidexportConstructionLogDocx(
- Spring中的@Cacheable 注解基本知识点
码农研究僧
Javaspringjava后端Cacheable
目录前言1.基本知识2.实战详解前言找工作,来万码优才:#小程序://万码优才/r6rqmzDaXpYkJZF对于Java的基本知识推荐阅读:java框架零基础从入门到精通的学习路线附开源项目面经等(超全)【Java项目】实战CRUD的功能整理(持续更新)1.基本知识@Cacheable是Spring提供的注解,用于声明一个方法的返回结果会被缓存当方法被调用时,Spring会先检查缓存中是否存在该
- docker + nginx +微信小程序后台 (springboot)
少侠好刀法
dockernginxdocker容器
1.资源环境阿里云ecs服务器、centos8系统、docker2.0、nginx、微信小程序、springbootjar包、ssl证书、已备案的域名www.dan-huang.cn2.centos8中安装docker卸载原有docker环境yumremovedocker\docker-client\docker-client-latest\docker-common\docker-latest\
- Spring Boot 和微服务:快速入门指南
王子良.
Java经验分享springboot微服务后端
欢迎来到我的博客!非常高兴能在这里与您相遇。在这里,您不仅能获得有趣的技术分享,还能感受到轻松愉快的氛围。无论您是编程新手,还是资深开发者,都能在这里找到属于您的知识宝藏,学习和成长。博客内容包括:Java核心技术与微服务:涵盖Java基础、JVM、并发编程、Redis、Kafka、Spring等,帮助您全面掌握企业级开发技术。大数据技术:涵盖Hadoop(HDFS)、Hive、Spark、Fli
- springboot + redis 实现多数据源
小橘快跑
redisspringbootredisjava
1、引用pom依赖org.springframework.bootspring-boot-starter-data-redisredis.clientsjedis2、application.yml配置文件spring:redis:timeout:20000cluster:nodes:127.0.0.1:6379,127.0.0.1:6380maxRedirects:3pool:max-active
- SpringBoot3-Security 之 认证与UsernamePasswordAuthenticationFilter
名字忘了取了
springSecurityspringboot
文章目录前言一、用户相关的类认证信息Authentication常见的Authentication的子类匿名用户身份信息AnonymousAuthenticationToken用户名密码认证信息UsernamePasswordAuthenticationToken用户信息UserDetails常见的UserDetails子类User用户信息操作类UserDetailsService常见的子类用户管
- Springboot 之 ObjectPostProcessor
名字忘了取了
springbootspringbootjava后端
文章目录一、ObjectPostProcessor是什么?二、代码示例三、AutowireBeanFactoryObjectPostProcessor实现原理一、ObjectPostProcessor是什么?ObjectPostProcessor能对我们没有被扫描的类执行初始化,注意是初始化(initializeBean)。二、代码示例ObjectPostProcessor有两个实现类,这里只研究
- springboot + redis多数据源 + jedis集群模式
machunlin~
javaspringbootredisredisspringbootjava缓存springcloud
最近有个项目需要redis支持多个集群,网上搜了下,发现有个开源的项目spring-boot-starter-dynamic-redis,代码写的挺好,可惜只有单机版的,于是fork了他的代码改了下,支持jedis集群模式。新代码昨天已提交给了原作者,还没看到他的回复。今天就先写个博客简单介绍下吧。支持集群版的项目地址:forkfromspring-boot-starter-dynamic-red
- 【SpringAOP】Spring AOP 底层逻辑:切点表达式与原理简明阐述
GGBondlctrl
SpringBootjava后端切点表达式SpringAOP代理模式
前言本期讲解关于springaop的切面表达式和自身实现原理介绍~~~感兴趣的小伙伴看一看小编主页:GGBondlctrl-CSDN博客你的点赞就是小编不断更新的最大动力那么废话不多说直接开整吧~~目录️1.切点表达式1.1execution表达式1.2@annotation1.自定义注解2.切面类3.添加注解️2.SpringAOP原理2.1代理模式1.静态代理(了解)2.动态代理(八股)2.2
- 《CPython Internals》阅读笔记:p61-p75
python
《CPythonInternals》学习第4天,p61-p75总结,总计15页。一、技术总结1.编译器类型(1)self-hostedcompilerSelf-hostedcompilersarecompilerswritteninthelanguagetheycompile,suchastheGocompiler.Thisisdonebyaprocessknownasbootstrapping.
- Spring Cloud项目中集成Sentinel?
用心去追梦
springcloudsentinelspring
在SpringCloud项目中集成Sentinel可以帮助你实现服务的流量控制、熔断降级等功能,从而提升系统的稳定性和可用性。以下是集成Sentinel的步骤:1.添加依赖首先,你需要在你的项目中添加Sentinel的相关依赖。如果你使用的是Maven,可以在pom.xml文件中添加如下依赖:com.alibaba.cloudspring-cloud-starter-alibaba-sentine
- spring cache 配置缓存存活时间
SpringCache@Cacheable本身不支持keyexpiration的设置,以下代码可自定义实现SpringCache的expiration,针对Redis、SpringBoot2.0。直接上代码:@Service@ConfigurationpublicclassCustomCacheMng{privateLoggerlogger=LoggerFactory.getLogger(this
- OpenTelemetry 开源遥测框架
ejinxian
架构设计开源OpenTelemetry测试
OpenTelemetry简称为OTel,是一个供应商中立的开源遥测框架,用于检测、生成、收集和导出遥测数据,例如跟踪、度量、日志,以帮助分析软件的性能和行为。作为一种行业标准,OpenTelemetry受到支持供应商。它是工具、API和SDK的集合,可与流行的库和框架集成,例如Spring、ASP.NETCore、Express、Quarkus等。OpenTelemetry是一个CNCF孵化项目
- 电商项目-基于ElasticSearch实现商品搜索功能(三)
kong7906928
项目功能Java框架elasticsearch电商项目商品搜索
本系列文章主要介绍基于SpringDataElasticsearch实现商品搜索的后端代码,介绍代码逻辑和代码实现。主要实现功能:根据搜索关键字查询、条件筛选、规格过滤、价格区间搜索、搜索查询分页、搜索查询排序、高亮查询。主要应用技术:canal,Eureka,微服务架构(MicroservicesArchitecture),SpringDataElasticsearch一、搜索分页1分页分析基于
- Spring Boot教程之五十七:在 Apache Kafka 上发布 JSON 消息
潜洋
Java中级SpringBootspringbootapachekafka
SpringBoot|如何在ApacheKafka上发布JSON消息ApacheKafka是一个发布-订阅消息系统。消息队列允许您在进程、应用程序和服务器之间发送消息。在本文中,我们将了解如何在SpringBoot应用程序中向ApacheKafka发送JSON消息。为了了解如何创建SpringBoot项目,请参阅本文。JSON的全称是JavaScriptObjectNotation。JSON是一种
- springmvc复习笔记
漫漫逆袭路
springmvc
springmvc1:j简单的入门案例springmvc.xmlpom,xmlUTF-81.81.85.0.2.RELEASEorg.springframeworkspring-context${spring.version}org.springframeworkspring-web${spring.version}org.springframeworkspring-webmvc${spring.
- xxx.jar中没有主清单属性
手揽回忆怎么睡
springboot报错mavenspringbootjavajar
pom.xml添加:org.springframework.bootspring-boot-maven-plugin2.1.1.RELEASEtruerepackageorg.apache.maven.pluginsmaven-war-plugin3.1.0false${project.artifactId}${project.artifactId}
- Spring常见知识
凉秋girl
springjavaservlet
1、什么是spring的ioc?其实就是控制反转,提前定义了一个bean,到时候使用的时候直接autowire就可以了。目的是减低计算机代码之间的耦合度。创建三个文件,分别是Bean的定义、Bean的使用、Bean的配置。IOC通过将对象创建和管理的控制权从应用代码转移到Spring容器中,实现了松耦合设计。通过Spring的IOC容器,开发者可以更加专注于业务逻辑,而无需关心对象的创建和管理,从
- 202501015
C18298182575
数据库
为什么不遵循最左匹配原则会导致索引失效最左匹配原则原因为什么不遵循最左匹配原则会导致索引失效最左匹配原则原因_mob6454cc7a6087的技术博客_51CTO博客java事物失效原因Spring事务@Transactional常见的8种失效场景(通俗易懂)_事务失效的8大场景-CSDN博客sql优化方案sql优化的15个小技巧(必知五颗星),面试说出七八个就有了_sql优化常用的15种方法-C
- Spring Bean 生命周期
spring生命周期
Bean生命周期指的是从Spring容器创建一个Bean到销毁它的整个过程。Spring通过管理Bean的生命周期来帮助我们控制Bean的创建、初始化、使用和销毁。SpringBean生命周期实例化:通过构造函数或工厂方法创建Bean的实例。属性赋值(依赖注入):Spring会为Bean设置依赖的属性(也就是依赖注入,通常是通过构造器、Setter方法或者字段注入)。调用BeanPostProce
- 如何在SpringBoot/MySQL事务中并行执行多条SQL?
springboot
在SpringBoot和MySQL事务中并行执行多条SQL语句,可以通过以下步骤实现:1、配置事务管理器在SpringBoot项目中,需要配置事务管理器来管理事务。通常,可以使用DataSourceTransactionManager作为事务管理器。在配置类中添加如下代码:importorg.springframework.context.annotation.Bean;importorg.spr
- Spring Boot 2 学习指南与资料分享
来恩1003
SpringBoot2springboot后端java
SpringBoot2学习资料SpringBoot2学习资料SpringBoot2学习资料在当今竞争激烈的Java后端开发领域,SpringBoot2凭借其卓越的特性,为开发者们开辟了一条高效、便捷的开发之路。如果你渴望深入学习SpringBoot2,以下这份精心准备的学习指南与丰富的资料分享将成为你前行的得力伙伴。一、学习指南(一)入门奠基环境搭建:Java环境:确保开发机器安装了Java8或更
- Spring AOP 的通知顺序
javaspringaop
在SpringAOP中,通知(Advice)的顺序是由通知的类型和声明的顺序决定的。SpringAOP提供了几种不同类型的通知,包括前置通知、后置通知、环绕通知、异常通知和最终通知。它们的执行顺序主要依赖于通知的类型和它们在配置中声明的顺序。通知类型及其执行顺序前置通知(@Before):在方法执行前执行。执行顺序:最先执行。环绕通知(@Around):在方法执行前后都能执行,可以控制方法是否被调
- 系统设计架构——互联网案例
大猩猩爱分享
java架构
Netflix的技术栈移动和网络:Netflix采用Swift和Kotlin来构建原生移动应用。对于其Web应用程序,它使用React。前端/服务器通信:Netflix使用GraphQL。后端服务:Netflix依赖ZUUL、Eureka、SpringBoot框架和其他技术。数据库:Netflix使用EV缓存、Cassandra、CockroachDB和其他数据库。消息传递/流媒体:Netflix
- 初学者如何用 Python 写第一个爬虫?
王子良.
python经验分享python开发语言爬虫
欢迎来到我的博客!非常高兴能在这里与您相遇。在这里,您不仅能获得有趣的技术分享,还能感受到轻松愉快的氛围。无论您是编程新手,还是资深开发者,都能在这里找到属于您的知识宝藏,学习和成长。博客内容包括:Java核心技术与微服务:涵盖Java基础、JVM、并发编程、Redis、Kafka、Spring等,帮助您全面掌握企业级开发技术。大数据技术:涵盖Hadoop(HDFS)、Hive、Spark、Fli
- Linux的Initrd机制
被触发
linux
Linux 的 initrd 技术是一个非常普遍使用的机制,linux2.6 内核的 initrd 的文件格式由原来的文件系统镜像文件转变成了 cpio 格式,变化不仅反映在文件格式上, linux 内核对这两种格式的 initrd 的处理有着截然的不同。本文首先介绍了什么是 initrd 技术,然后分别介绍了 Linux2.4 内核和 2.6 内核的 initrd 的处理流程。最后通过对 Lin
- maven本地仓库路径修改
bitcarter
maven
默认maven本地仓库路径:C:\Users\Administrator\.m2
修改maven本地仓库路径方法:
1.打开E:\maven\apache-maven-2.2.1\conf\settings.xml
2.找到
 
- XSD和XML中的命名空间
darrenzhu
xmlxsdschemanamespace命名空间
http://www.360doc.com/content/12/0418/10/9437165_204585479.shtml
http://blog.csdn.net/wanghuan203/article/details/9203621
http://blog.csdn.net/wanghuan203/article/details/9204337
http://www.cn
- Java 求素数运算
周凡杨
java算法素数
网络上对求素数之解数不胜数,我在此总结归纳一下,同时对一些编码,加以改进,效率有成倍热提高。
第一种:
原理: 6N(+-)1法 任何一个自然数,总可以表示成为如下的形式之一: 6N,6N+1,6N+2,6N+3,6N+4,6N+5 (N=0,1,2,…)
- java 单例模式
g21121
java
想必单例模式大家都不会陌生,有如下两种方式来实现单例模式:
class Singleton {
private static Singleton instance=new Singleton();
private Singleton(){}
static Singleton getInstance() {
return instance;
}
- Linux下Mysql源码安装
510888780
mysql
1.假设已经有mysql-5.6.23-linux-glibc2.5-x86_64.tar.gz
(1)创建mysql的安装目录及数据库存放目录
解压缩下载的源码包,目录结构,特殊指定的目录除外:
- 32位和64位操作系统
墙头上一根草
32位和64位操作系统
32位和64位操作系统是指:CPU一次处理数据的能力是32位还是64位。现在市场上的CPU一般都是64位的,但是这些CPU并不是真正意义上的64 位CPU,里面依然保留了大部分32位的技术,只是进行了部分64位的改进。32位和64位的区别还涉及了内存的寻址方面,32位系统的最大寻址空间是2 的32次方= 4294967296(bit)= 4(GB)左右,而64位系统的最大寻址空间的寻址空间则达到了
- 我的spring学习笔记10-轻量级_Spring框架
aijuans
Spring 3
一、问题提问:
→ 请简单介绍一下什么是轻量级?
轻量级(Leightweight)是相对于一些重量级的容器来说的,比如Spring的核心是一个轻量级的容器,Spring的核心包在文件容量上只有不到1M大小,使用Spring核心包所需要的资源也是很少的,您甚至可以在小型设备中使用Spring。
 
- mongodb 环境搭建及简单CURD
antlove
WebInstallcurdNoSQLmongo
一 搭建mongodb环境
1. 在mongo官网下载mongodb
2. 在本地创建目录 "D:\Program Files\mongodb-win32-i386-2.6.4\data\db"
3. 运行mongodb服务 [mongod.exe --dbpath "D:\Program Files\mongodb-win32-i386-2.6.4\data\
- 数据字典和动态视图
百合不是茶
oracle数据字典动态视图系统和对象权限
数据字典(data dictionary)是 Oracle 数据库的一个重要组成部分,这是一组用于记录数据库信息的只读(read-only)表。随着数据库的启动而启动,数据库关闭时数据字典也关闭 数据字典中包含
数据库中所有方案对象(schema object)的定义(包括表,视图,索引,簇,同义词,序列,过程,函数,包,触发器等等)
数据库为一
- 多线程编程一般规则
bijian1013
javathread多线程java多线程
如果两个工两个以上的线程都修改一个对象,那么把执行修改的方法定义为被同步的,如果对象更新影响到只读方法,那么只读方法也要定义成同步的。
不要滥用同步。如果在一个对象内的不同的方法访问的不是同一个数据,就不要将方法设置为synchronized的。
- 将文件或目录拷贝到另一个Linux系统的命令scp
bijian1013
linuxunixscp
一.功能说明 scp就是security copy,用于将文件或者目录从一个Linux系统拷贝到另一个Linux系统下。scp传输数据用的是SSH协议,保证了数据传输的安全,其格式如下: scp 远程用户名@IP地址:文件的绝对路径
- 【持久化框架MyBatis3五】MyBatis3一对多关联查询
bit1129
Mybatis3
以教员和课程为例介绍一对多关联关系,在这里认为一个教员可以叫多门课程,而一门课程只有1个教员教,这种关系在实际中不太常见,通过教员和课程是多对多的关系。
示例数据:
地址表:
CREATE TABLE ADDRESSES
(
ADDR_ID INT(11) NOT NULL AUTO_INCREMENT,
STREET VAR
- cookie状态判断引发的查找问题
bitcarter
formcgi
先说一下我们的业务背景:
1.前台将图片和文本通过form表单提交到后台,图片我们都做了base64的编码,并且前台图片进行了压缩
2.form中action是一个cgi服务
3.后台cgi服务同时供PC,H5,APP
4.后台cgi中调用公共的cookie状态判断方法(公共的,大家都用,几年了没有问题)
问题:(折腾两天。。。。)
1.PC端cgi服务正常调用,cookie判断没
- 通过Nginx,Tomcat访问日志(access log)记录请求耗时
ronin47
一、Nginx通过$upstream_response_time $request_time统计请求和后台服务响应时间
nginx.conf使用配置方式:
log_format main '$remote_addr - $remote_user [$time_local] "$request" ''$status $body_bytes_sent "$http_r
- java-67- n个骰子的点数。 把n个骰子扔在地上,所有骰子朝上一面的点数之和为S。输入n,打印出S的所有可能的值出现的概率。
bylijinnan
java
public class ProbabilityOfDice {
/**
* Q67 n个骰子的点数
* 把n个骰子扔在地上,所有骰子朝上一面的点数之和为S。输入n,打印出S的所有可能的值出现的概率。
* 在以下求解过程中,我们把骰子看作是有序的。
* 例如当n=2时,我们认为(1,2)和(2,1)是两种不同的情况
*/
private stati
- 看别人的博客,觉得心情很好
Cb123456
博客心情
以为写博客,就是总结,就和日记一样吧,同时也在督促自己。今天看了好长时间博客:
职业规划:
http://www.iteye.com/blogs/subjects/zhiyeguihua
android学习:
1.http://byandby.i
- [JWFD开源工作流]尝试用原生代码引擎实现循环反馈拓扑分析
comsci
工作流
我们已经不满足于仅仅跳跃一次,通过对引擎的升级,今天我测试了一下循环反馈模式,大概跑了200圈,引擎报一个溢出错误
在一个流程图的结束节点中嵌入一段方程,每次引擎运行到这个节点的时候,通过实时编译器GM模块,计算这个方程,计算结果与预设值进行比较,符合条件则跳跃到开始节点,继续新一轮拓扑分析,直到遇到
- JS常用的事件及方法
cwqcwqmax9
js
事件 描述
onactivate 当对象设置为活动元素时触发。
onafterupdate 当成功更新数据源对象中的关联对象后在数据绑定对象上触发。
onbeforeactivate 对象要被设置为当前元素前立即触发。
onbeforecut 当选中区从文档中删除之前在源对象触发。
onbeforedeactivate 在 activeElement 从当前对象变为父文档其它对象之前立即
- 正则表达式验证日期格式
dashuaifu
正则表达式IT其它java其它
正则表达式验证日期格式
function isDate(d){
var v = d.match(/^(\d{4})-(\d{1,2})-(\d{1,2})$/i);
if(!v) {
this.focus();
return false;
}
}
<input value="2000-8-8" onblu
- Yii CModel.rules() 方法 、validate预定义完整列表、以及说说验证
dcj3sjt126com
yii
public array rules () {return} array 要调用 validate() 时应用的有效性规则。 返回属性的有效性规则。声明验证规则,应重写此方法。 每个规则是数组具有以下结构:array('attribute list', 'validator name', 'on'=>'scenario name', ...validation
- UITextAttributeTextColor = deprecated in iOS 7.0
dcj3sjt126com
ios
In this lesson we used the key "UITextAttributeTextColor" to change the color of the UINavigationBar appearance to white. This prompts a warning "first deprecated in iOS 7.0."
Ins
- 判断一个数是质数的几种方法
EmmaZhao
Mathpython
质数也叫素数,是只能被1和它本身整除的正整数,最小的质数是2,目前发现的最大的质数是p=2^57885161-1【注1】。
判断一个数是质数的最简单的方法如下:
def isPrime1(n):
for i in range(2, n):
if n % i == 0:
return False
return True
但是在上面的方法中有一些冗余的计算,所以
- SpringSecurity工作原理小解读
坏我一锅粥
SpringSecurity
SecurityContextPersistenceFilter
ConcurrentSessionFilter
WebAsyncManagerIntegrationFilter
HeaderWriterFilter
CsrfFilter
LogoutFilter
Use
- JS实现自适应宽度的Tag切换
ini
JavaScripthtmlWebcsshtml5
效果体验:http://hovertree.com/texiao/js/3.htm
该效果使用纯JavaScript代码,实现TAB页切换效果,TAB标签根据内容自适应宽度,点击TAB标签切换内容页。
HTML文件代码:
<!DOCTYPE html>
<html xmlns="http://www.w3.org/1999/xhtml"
- Hbase Rest API : 数据查询
kane_xie
RESThbase
hbase(hadoop)是用java编写的,有些语言(例如python)能够对它提供良好的支持,但也有很多语言使用起来并不是那么方便,比如c#只能通过thrift访问。Rest就能很好的解决这个问题。Hbase的org.apache.hadoop.hbase.rest包提供了rest接口,它内嵌了jetty作为servlet容器。
启动命令:./bin/hbase rest s
- JQuery实现鼠标拖动元素移动位置(源码+注释)
明子健
jqueryjs源码拖动鼠标
欢迎讨论指正!
print.html代码:
<!DOCTYPE html>
<html>
<head>
<meta http-equiv=Content-Type content="text/html;charset=utf-8">
<title>发票打印</title>
&l
- Postgresql 连表更新字段语法 update
qifeifei
PostgreSQL
下面这段sql本来目的是想更新条件下的数据,可是这段sql却更新了整个表的数据。sql如下:
UPDATE tops_visa.visa_order
SET op_audit_abort_pass_date = now()
FROM
tops_visa.visa_order as t1
INNER JOIN tops_visa.visa_visitor as t2
ON t1.
- 将redis,memcache结合使用的方案?
tcrct
rediscache
公司架构上使用了阿里云的服务,由于阿里的kvstore收费相当高,打算自建,自建后就需要自己维护,所以就有了一个想法,针对kvstore(redis)及ocs(memcache)的特点,想自己开发一个cache层,将需要用到list,set,map等redis方法的继续使用redis来完成,将整条记录放在memcache下,即findbyid,save等时就memcache,其它就对应使用redi
- 开发中遇到的诡异的bug
wudixiaotie
bug
今天我们服务器组遇到个问题:
我们的服务是从Kafka里面取出数据,然后把offset存储到ssdb中,每个topic和partition都对应ssdb中不同的key,服务启动之后,每次kafka数据更新我们这边收到消息,然后存储之后就发现ssdb的值偶尔是-2,这就奇怪了,最开始我们是在代码中打印存储的日志,发现没什么问题,后来去查看ssdb的日志,才发现里面每次set的时候都会对同一个key