- 第二十八:Fiddler抓包-抓取Android7.0以上的Https包(三)-夜神模拟器+Xposed+JustTrustMe
卢卡平头哥
Fiddlerfiddlerhttpsandroid
一.简介1.二次加密:有的APP,在涉及到关键数据通信时,会将正文二次加密后才通过HTTPS发送1.1.抓包抓到的是一堆二进制base642.自带HTTPClient:像支付宝那样的变态,自己带一个基于so的HTTPClient库2.1.对于关键数据,都不走URLConnection和OkHttp,而是走自己的HTTPClient库2.2.甚至一些
- 基于Xposed的高级数据爬取实战:突破APP反爬机制的企业级解决方案
Python×CATIA工业智造
人工智能大数据网络爬虫pycharm
引言:移动端数据采集的技术困境在App数据价值日益凸显的时代,传统爬取方案面临三大核心挑战:协议加密壁垒:金融类App采用非标准加密方案比例高达92%(来源:2023年移动安全年报)动态防护升级:行为分析技术识别异常请求准确率达85%法律合规风险:违反《数据安全法》最高罚款可达年营收5%行业数据显示:主流电商平台单用户画像价值1.2-5.3传统爬虫方案识别率超过75%数据采集综合成本增长120%X
- Android xposed 安装教程
口袋安少
android
AndroidXposed安装教程Xposed框架是一个强大的工具,它可以让开发者和高级用户在Android设备上进程地修改应用程序而不需要修改APK文件。本文将教你如何在Android设备上安装Xposed框架。我们将详细介绍整个过程,并提供每一步需使用的代码及其解释。安装流程概览安装Xposed框架的步骤如下:步骤描述步骤1确认设备已root步骤2下载并安装XposedInstaller应用步
- Qt中opengl使用swapBuffers()函数报错解决办法
啊 哈
QTOPENGL
swapBuffers():qt文档中方的翻译:用屏幕外缓冲区交换屏幕内容。仅当窗口小部件的格式指定双缓冲模式时,此方法才有效。通常,不需要显式调用此函数,因为它是在每个小部件重新绘制后(即每次执行paintGL()之后)自动完成的。我是在线程中使用swapBuffers时候报下面这个错。报错:QOpenGLContext::swapBuffers()calledwithnon-exposedwi
- 微信ipad协议/个人微信协议/个微协议
ylianxin
微信
目前微信社群比较火,市面上社群管理工具也是有各式各样的,但是最终都不开微信的协议,协议样式也有很多,例如web、PCHook、模拟机、Xposed等。但是目前各类协议的稳定性有待考究。目前稳定不封号,安全性好,功能满足,行业占有率高。已将8037协议封装为统一的框架服务,用户可一次性完成所有对接,省去了频繁更新接口的烦恼。功能如下:登录:扫码登录,获取数据,登录,自动心跳好友管理:添加好友、删除好
- 太极APP:免Root,畅享Xposed模块的神奇魅力
非凡ghost
linux运维服务器软件需求android智能手机
在安卓系统中,Xposed框架一直以其强大的功能和高度的自定义能力受到众多用户的喜爱。然而,传统的Xposed框架需要Root权限和复杂的刷机操作,这使得许多普通用户望而却步。太极APP的出现,打破了这一限制,它为用户提供了一个免Root、免解锁、免刷机的Xposed模块运行环境,让每一位用户都能轻松体验Xposed模块带来的强大功能。软件简介太极APP是一款专为安卓用户设计的免RootXpose
- docker dockerfile开启2375端口
棠十一
docker容器运维
windows中dockerdesktop设置中dockerengine中增加2375的配置“hosts”:[“unix:///var/run/docker.sock”,“tcp://127.0.0.1:2375”],其次在General设置中勾选Exposedaemonontcp://localhost:2375withoutTLS
- xposed 入门之修改手机 IMEI
去哪儿网技术沙龙
androidimei安全经验分享安卓
吕元江2019年1月加入去哪儿网,现负责app的分析和设备指纹反爬事项,对app脱壳,java/nativec层加解密算法分析还原有丰富经验。1.背景xposed对于很多安卓安全和逆向人员来说并不陌生,在对app的函数功能分析和拦截时经常会用到。本文以xposed修改某个应用的IMEI为例,作为一个简单入门介绍。供新手了解如何使用xposed编写自己所需的hook模块,以及简单介绍xposed在其
- 安卓逆向篇&LSP 模块&HOOK 添加技术&绕过检测&算法解密&逻辑验证
我最厉害。,。
android里氏替换原则
前置解释:0、Magisk:是当前Android社区用来获取root权限的主流方式开源工具1、LSP框架:XPosed框架因只支持安卓8及以下,故高版本应使用Magisk+LSPosed2、HOOK技术:钩子技术,本质就是劫持调用,将自身的代码“融入”被勾住(Hook)的程序的进程中3、算法助手:LSPosed下的模块,集成常见功能外加自定义HOOK方便逆向调试安装使用:见上次(88-1天内容环境
- 记录一次抓包实战,全局代理+xposed+frida绕过各种坑点
韭零后程序猿
python黑科技抓包fridaxposed全局代理postern
遇到的问题apk使用了360加固,无法反编译apk没有走系统代理,导致设置wifi代理抓不到包问题1解决办法:使用FRIDA-DEXDump工具直接从内存dump出dex包,然后使用jadx-gui-1.1.0-with-jre-windows工具打开dex文件查看代码FRIDA-DEXDUMPgithub链接jadx-gui网上比较多,自行百度下载需要先按照frida,自行百度下载安装问题2解决
- Lspatch的使用原理及机制
王景程
智能手机vscodetypescript
很多搞机佬们在玩机的时候都会偏向于给系统装上LSposed框架,这对于有root的小伙伴来说那可是刚需。但是在手机没有root的情况下或者是bootloader未解锁的时候,想要玩机那就得用LSpatch啦!下面给大家讲一讲其工作原理LSPatch的工作原理可以从以下几个关键方面来分析,包括XposedHook机制、补丁注入方式、代码修改方式、运行时加载机制、签名与安全机制。1.LSPatch的核
- 360加固一键脱壳工具2020_Android逆向之路---脱壳360加固原理解析
weixin_39870132
360加固一键脱壳工具2020android二维码解析原理
需要的环境无,看文章就可以了解大致了(当然你要是想编译下dumpDex项目,需要如下工具)AndroidStudiosdkndk入口所有的程序执行的时候都是有个入口的,dumpDex工程也不例外。由于是个xposed插件,所以我们先看com.wrbug.dumpdex.XposedInit类。publicclassXposedInitimplementsIXposedHookLoadPackage
- Frida零基础入门教程
疯人院的院长大人
安卓应用优化专题javalinux开发语言
阅读这篇文章,不仅能了解frida是什么,还能知道如何搭建Frida运行换以及学会用frida进行简单的java/nativehook实战。Xposed大家不陌生,在手机上运行的Hook框架,Xposed插件编写完成并在手机上通过hook框架加载,打开指定应用就能实现代码注入,也就是说Xposed插件的代码是编写在手机上的,每次运行都需要更新Xposed上的插件并重启应用,否则hook不会生效。在
- 安卓逆向(Xposed-Hook)
奶龙牛牛
android前端javascript
关于参数问题如果方法是这样publicintaddNumbers(inta,intb){returna+b;}Hook代码XposedHelpers.findAndHookMethod("com.example.app.Calculator",lpparam.classLoader,"addNumbers",int.class,int.class,//两个参数,都是intnewXC_MethodH
- python抖音接口_「docker实战篇」python的docker-抖音分析接口数据分析(21)
weixin_39890633
python抖音接口
上节xposed已经安装完毕,设置对应的android的版本和代理服务器。准备工作1.xposed和JustTruestMe的安装2.抖音安装完毕启动fildder点击进入指定的粉丝界面查看数据GEThttps://api.amemv.com/aweme/v1/user/follower/list/?user_id=108719454702&max_time=1549012794&count=20
- Android逆向(Xposed配置)
奶龙牛牛
android
settings.gradle1.settings.gradlevs.build.gradle文件作用settings.gradle管理整个Gradle项目(包括多模块)build.gradle管理单个模块的构建(比如依赖、插件)重点:settings.gradle负责全局配置,比如项目名称、多模块、仓库地址等。build.gradle负责每个模块的构建配置,比如Java版本、依赖项等。//Gra
- Android逆向学习知识体系(三)
zhangjianming2018
Androidkotlinandroid
第二阶段:Android逆向进阶学习:Android系统结构深入分析,自定义ClassLoader,自定义注解和元注解原理分析;了解AndroidNDK,静态注册,动态注册,SO加载分析,App保护策略去除霸哥磁力搜素APK签名验证,一键去除签名验证,静态代理,动态代理HookActivity启动函数,Hook签名验证函数介绍xposed框架:Xposed框架:绕过验证码注册Xposed框架:登陆
- 【转】android安全与逆向进阶路线
Synioe
androidandroid
【转自论坛热帖】此篇整理了最完整的--Android逆向学习线路知识体系。希望给迷糊的入门者指出一个明确的方向。真心建议:先正向开发几年再搞逆向吧……正向都不会破解的是啥?不看代码只会脱壳?只会xposed?远远不够,hook只是很小一部分技术,xposed是hook功能众多框架中的一个而已。相对于任何程序的开发来说,逆向知识点很少很少了,关键是基础知识,基础就是正向开发经验。学习Android逆
- Gallery2 视频静音功能 闪退 exposed beyond app through Intent.getData()
wxx2150
BUGandroidgallerymutecrash
具体的错误log如下---------beginningofcrash03-2219:19:17.950E/AndroidRuntime(5809):FATALEXCEPTION:main03-2219:19:17.950E/AndroidRuntime(5809):Process:com.android.gallery3d,PID:580903-2219:19:17.950E/AndroidRu
- exposed beyond app through Intent.getData()
秋天的春
Androidandroid
调用相册打开图片startActivity时报了个错startActivityForResulterror:file:///storage/emulated/0/Android/data/xxx.jpgexposedbeyondappthroughIntent.getData()调查发现是AndroidStudio7.0之后官方对这权限做了调整:官方解答:出于用户隐私安全考虑,对于面向Androi
- Android Hook与简单的xposed模块开发实例
Hook是一种在特定事件或操作发生时插入自定义代码的编程技术。在前端开发中,例如Vue和Angular的生命周期钩子,体现了Hook的机制,允许开发者在组件的不同阶段执行代码,提升代码的模块化和可重用性。AndroidHook与此类似,允许开发者在Android应用程序运行时修改或扩展现有功能。通过拦截方法调用、修改参数或返回值,Hook可用于调试、测试和逆向工程,例如监控应用程序行为、捕获API
- Xposed模块 -- Hook函数参数
web安全工具库
安卓逆向Xposed模块安卓逆向
安卓系统7.1搭建Xposed环境安卓逆向--Xposed模块编写安卓逆向--Jeb动态调试一、根据以前的课程,我们通过抓包分析,知道了如下的关键函数packagecom.dodonew.online.http;importandroid.text.TextUtils;importandroid.util.Log;importcom.dodonew.online.util.DesSecurity;
- xposed中hook的用法
socketyc
android
1.普通的类中方法;XposedHelpers.findAndHookMethod(clazz,//类"test",//方法名String::class.java,//参数object:XC_MethodHook(){@Throws(Throwable::class)overridefunbeforeHookedMethod(param:MethodHookParam){Log.i(TAG,"正在
- xposed-hook-反射
aπ
文章
xposedhook反射不介绍介绍hook经验如何找怎么写有时间再写(想想怎么深入的写,找几个app,hook一下,写写过程,谈谈经验…)
- xposed 03 - hook字段与一般方法
二手的程序员
xposed逆向前端java
本文主要讨论一下如何hook字段与方法hook字段有两种方式:使用反射使用xposedapi由于xposed模块也运行在app进程中,所以我们可以将app的代码当作自己的,直接反射访问。Hook静态字段与成员字段测试代码:package com.example.hooktargeclass HookTarget2 { private var str: String = "hello"
- Xposed-Hook
奶龙牛牛
android
配置Xposed模块的AndroidManifest.xml:在app/src/main/assets创建一个xposed_init文件。xposed_init文件是Xposed模块必需的一个配置文件,它用来指定模块的入口类。这个文件需要包含你的Xposed模块的主类的完整类名(包含包名):your.package.name.MainHookapp/build.gradle配置一下:depende
- 【Vue3】defineExpose
正宗咸豆花
vue.jsjavascript前端
【Vue3】defineExposedefineExpose是Vue3.2引入的一个新API,它是的配套API之一。在中,所有定义的变量和函数默认是私有的,不能从组件外部访问。如果你想让外部组件访问到内定义的属性或方法,你需要使用defineExpose显式地暴露它们。这是defineExpose的基本用法:import{defineExpose}from'vue'//...定义响应式数据、函数等
- 什么是Xposed和LSPosed框架?
王景程
githubgit
1.什么是Xposed框架?Xposed框架是一个面向Android平台的模块化框架,允许开发者和用户通过加载模块来修改应用程序或系统行为,而无需修改应用程序的APK文件或系统文件。工作原理:Xposed框架通过挂钩(Hook)Android系统的方法或类,来改变这些方法或类的运行行为。它的核心是通过动态加载用户编写的模块代码,在系统或应用运行时注入代码。主要特性:可以修改应用的行为而不需要重新编
- 避免检测:安卓模拟器/安卓虚拟机/root环境
圣道寺
日常使用android
目录标题可选方案问题解决XposedInstallermagisk安装报错:Unabletodetecttargetimage如何避免模拟器被检测可选方案如果你想要避免某些安卓应用检测到你正在使用安卓虚拟机,你可以尝试以下方法。但请注意,这些操作可能违反了应用的使用条款,因此请在遵守相关法规和条款的前提下进行操作。修改虚拟机设备信息:一些应用会检查设备的制造商、型号等信息。你可以使用一些工具来修改
- android原生乐视made,乐视Pro3 lineage16 安卓9.0 极致省电 纯净原生 完美root Xposed 经典版...
小6加油
android原生乐视made
乐视系列可刷上lineageos16,再次开启享受类原生的乐趣。乐视Max2和Pro3支持PT项目,也就是说必须刷入支持PT版本TWRP后Vendor分区才可以正常启动LOS16.0特色介绍源于lineage16.0最新源码制作,稳定靠谱默认添加开机语音中文,时区为正常北京超级纯净,非常流畅。它有电话、信息、相机、时钟、录音录屏、邮件、文件管理器和音乐播放器等几个最基本的功能,无谷歌服务和全家桶l
- 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