性能比拼: Redis vs Dragonfly
本内容是对知名性能评测博主 Anton Putra Redis vs Dragonfly Performance (Latency - Throughput - Saturation) 内容的翻译与整理, 有适当删减, 相关指标和结论以原作为准
在本视频中,我们将对比 Redis 和 Dragonfly。我们将观察 set
与 get
操作的延迟,重点关注 P99 百分位。这两个操作可能是你在使用任何缓存时最常用的操作。
我们还将查看吞吐量(THR 输出),了解每个数据库每秒能够处理多少请求,并验证 Dragonfly 声称其吞吐量是 Redis 的 25 倍的说法。
此外,我们还将测量两个数据库的 CPU 使用率、内存使用率和网络吞吐量。
第一次测试:基础测试
为了建立基准,我们将在每个缓存上使用 m7a.medium
EC2 实例,它配备一个虚拟 CPU 和 4GB 内存。我们将使用 EKS 集群部署客户端来生成负载。
Dragonfly 最大的卖点是它能够使用多个 CPU 核心,使其更容易进行垂直扩展。因此在第二次测试中,我将为 Dragonfly 使用 m7a.xlarge
实例,它拥有 4 个虚拟 CPU 和 16GB 内存。
由于 Redis 大多是单线程的,因此我会采用水平扩展的方式来扩展 Redis。我将使用四个 m7a.medium
实例组成一个由四个 master 节点构成的集群,以匹配 Dragonfly 的 4 个 CPU 和 16GB 内存的容量。
如你从 AWS 控制台看到的,第一次测试中我为两个数据库都使用了中型实例,并为 EKS 集群使用了三个 xlarge
实例,用于部署监控组件(如 Prometheus 和 Grafana),以及部署客户端以生成负载。而在第二次测试中,我将 EKS 扩展到四个节点,为 Dragonfly 使用 xlarge
实例,为 Redis 集群使用 medium
实例。
AWS 成本很高,因此我希望通过提供一对一的技术支持服务来支持我的频道并支付基础设施费用。详情请见视频描述。
Redis 集群设计
由于 Redis 多数情况下只使用单线程,因此扩展 Redis 需要使用集群。一个典型的生产集群由六个节点组成:三个 master 接受所有请求,并将数据复制到其后面的副本节点。客户端使用哈希函数(hash function)来决定将请求发送到哪一个节点。
如果一个 master 故障了,副本节点会被提升为 master,客户端不会察觉任何变化。这就是所谓的高可用(High Availability)。为了使集群正常工作,master 节点的数量应为奇数(例如 3、5、7 等),这样即便一个 master 故障,仍有多数可决定将副本提升为 master。
当然,如果你不需要高可用性(即只是把 Redis 当作缓存使用),一旦数据缺失,应用可以从别的地方(如数据库)重新获取数据,那么也可以不设置副本。此时你可以将 cluster-replicas
属性设置为 0,这样可以将基础设施成本减半。
所以在这次测试中,为了匹配 Dragonfly 的 4 个 CPU,我使用了一个由四个 master 组成、不含副本的 Redis 集群。
Dragonfly 的已知问题
Dragonfly 存在一个已知问题:当使用某些监控系统(如 Prometheus)时,CPU 使用率会异常偏高。这个问题是由于 Dragonfly 使用了相对较新的 io_uring
API,即使是网络操作也会被标记为 IO 等待(iowait),从而阻塞 CPU 使用率的准确显示。至少这是 Dragonfly 开发者的解释。
我在之前也对使用相同 API 的框架做过基准测试,但没有观察到这种行为。
虽然有一些解决方案,但从运维角度来看,你需要为这个数据库单独创建一套仪表盘和告警系统,这并不理想。这个问题似乎在新版内核中已被解决,但在此之前仍可以忽略,并不会影响 Dragonfly 的性能表现。
软件版本和配置
我使用的 Redis 版本是 7.4.1,Dragonfly 版本是 1.125.4。
我从 GitHub 下载了 Dragonfly 的 Debian 安装包,该版本已开启所有必要的优化。我也从 GitHub 获取了 Redis 的发行版本。
我在 Redis 和 Dragonfly 上都禁用了持久化(persistence),其余配置保持一致。
我使用的客户端程序也在我的 GitHub 上可用,测试中使用的是相同的 Redis 客户端。Dragonfly 的一个优化亮点是:无需修改任何代码即可将 Redis 替换为 Dragonfly。
在第二次测试中,我使用了 Redis 的集群客户端,操作仍然是 set
和 get
。
第一次测试结果
我们开始第一次测试。请注意,这次测试中 Dragonfly 和 Redis 都使用的是 m7a.medium
实例,每个实例只有一个虚拟 CPU 和 4GB 内存。
在每秒 7500 个请求之前,Redis 实际上表现出更低的延迟。set
操作相对更消耗资源,因为它需要写入数据库,而 get
操作只需根据键读取值。
在达到每秒 177,000 个请求和 25% CPU 使用率之前,Redis 的 get
操作仍然具有较低延迟。
两个数据库都使用相同的 Redis 客户端,因此网络传输使用模式应该一致。但在内存使用方面,Dragonfly 的内存使用量略低。
我在两个数据库中都设置了相同的 20 秒过期时间。
当请求达到每秒 60,000 时,你可以看到 Dragonfly 的延迟更低,因此能处理更多请求。这并不表示 Redis 已经失败。
在达到每秒 880,000 请求时,两个数据库都开始难以处理更多请求,Dragonfly 的延迟和内存使用量也急剧上升。可以说这就是每个数据库处理能力的极限。
Redis 的表现非常一致,你可以将其与我之前使用相同实例测试 Memcached 的结果进行比较。
图表分析(第一次测试)
- 每秒请求数:如果你想知道 Dragonfly 和 Memcached 的对比结果,请观看相关视频
---
结果显示 Memcached 更胜一筹。
set
操作延迟:Dragonfly 明显优于 Redis,整体延迟更低。在缓存系统中,延迟是关键因素。虽然开始几分钟 Redis 延迟更低,但在 CPU 使用率达到 10% 后就失去优势。
get
操作延迟:情况类似,Dragonfly 明显更快。Redis 的优势维持稍久,但在达到 25% CPU 使用率后也消失。
- 网络使用:由于使用的是相同客户端,网络流量基本一致。
- CPU 使用率:标准仪表盘无法准确测量 Dragonfly 的 CPU 使用率,你需要做一些调整。
- 内存使用:测试结束时 Dragonfly 的内存使用高于 Redis,可能是因为其开始失败并尝试缓存请求。
第二次测试:扩展能力对比
这是我们可以用作基准的第一次测试。Dragonfly 最大优势是能利用多个核心进行垂直扩展,只需增加 CPU 和内存即可。但两个数据库也都可以水平扩展。
为了公平起见,我给 Redis 分配相同的资源(CPU 核心和内存),但方式是水平扩展。
所以这次,单个 Dragonfly 实例运行在 m7a.xlarge
实例上,有 4 个 CPU 核心。而 Redis 使用的是四个 m7a.medium
实例,每个一个 CPU。
从基础设施成本来看,两者基本相同。
从内存图来看,Dragonfly 起初内存使用更低,因为它拥有 16GB 内存,而 Redis 的每个节点只有 4GB,共四个。
这次 Dragonfly 从一开始就能使用所有 CPU 核心,延迟更低。而 Redis 由于使用集群客户端,相比第一次测试(单节点)延迟增加。
get
操作也类似,Dragonfly 在延迟方面明显占优。
吞吐量对比
在每秒 260,000 请求时,Dragonfly 开始出现失败。考虑到一核时能处理 880,000 请求,理论上 4 核应处理 320,000。
而 Redis 实际达到了约 310,000 请求/秒,所以本次测试中,Redis 的吞吐量高于 Dragonfly。
这说明,即使你将 Dragonfly 限制为单核并进行水平扩展,它仍然表现更好。因此,Dragonfly 所宣传的“吞吐量是 Redis 的 25 倍”的说法具有一定误导性。这个结论是基于 Dragonfly 可以垂直扩展,而 Redis 是单线程且受单核限制的假设。
图表分析(第二次测试)
- 每秒请求数:Redis 达到 310,000,Dragonfly 达到 260,000。
- 延迟图表:Dragonfly 在
set
和get
操作的延迟上表现都远优于 Redis。
- 网络使用:完全一致。
- CPU 使用:看起来当一个节点失败时,客户端触发超时,整个集群宕机。我在想,如果配置一个带副本的 Redis 高可用集群,也许能处理更多请求。
- 内存使用:Dragonfly 使用商业许可证。如果你考虑替代 Redis,这点也需要考虑。你可以看看其他完全开源的数据库,例如 WeeKey。
相关文章:
性能比拼: Redis vs Dragonfly
本内容是对知名性能评测博主 Anton Putra Redis vs Dragonfly Performance (Latency - Throughput - Saturation) 内容的翻译与整理, 有适当删减, 相关指标和结论以原作为准 在本视频中,我们将对比 Redis 和 Dragonfly。我们将观察 set 与 get 操作的延迟ÿ…...
如何收集用户白屏/长时间无响应/接口超时问题
想象一下这样的场景:一位用户在午休时间打开某电商应用,准备购买一件心仪已久的商品。然而,页面加载了数秒后依然是一片空白,或者点击“加入购物车”按钮后没有任何反馈,甚至在结算时接口超时导致订单失败。用户的耐心被迅速消耗殆尽,关闭应用,转而选择了竞争对手的产品…...
来啦,烫,查询达梦表占用空间
想象一下oracle,可以查dba_segments,但是这个不可靠(达梦官方连说明书都没有) 先拼接一个sql set lineshow off SELECT SELECT ||||OWNER|||| AS OWNER,||||TABLE_NAME|||| AS TABLE_NAME,TABLE_USED_SPACE(||||OWNER||||,||||T…...
# 利用迁移学习优化食物分类模型:基于ResNet18的实践
利用迁移学习优化食物分类模型:基于ResNet18的实践 在深度学习的众多应用中,图像分类一直是一个热门且具有挑战性的领域。随着研究的深入,我们发现利用预训练模型进行迁移学习是一种非常有效的策略,可以显著提高模型的性能&#…...
AT24C02芯片简介:小巧强大的串行EEPROM存储器
一、AT24C02概述 AT24C02是一款2K位(即256字节)的串行EEPROM芯片,采用IC(Inter-Integrated Circuit)总线进行通信,适合低功耗、小容量存储需求。 主要特性: 项目 参数 存储容量 2Kb&#x…...
【Vue】状态管理(Vuex、Pinia)
个人主页:Guiat 归属专栏:Vue 文章目录 1. 状态管理概述1.1 什么是状态管理1.2 为什么需要状态管理 2. Vuex基础2.1 Vuex核心概念2.1.1 State2.1.2 Getters2.1.3 Mutations2.1.4 Actions2.1.5 Modules 2.2 Vuex辅助函数2.2.1 mapState2.2.2 mapGetters2.…...
施磊老师基于muduo网络库的集群聊天服务器(四)
文章目录 实现登录业务登录业务代码补全数据库接口:查询,更新状态注意学习一下里面用到的数据库api测试与问题**问题1:****问题2:** 用户连接信息与线程安全聊天服务器是长连接服务器如何找到用户B的连接?在业务层存储用户的连接信息多线程安全问题加锁! 处理客户端…...
深度学习-全连接神经网络(过拟合,欠拟合。批量标准化)
七、过拟合与欠拟合 在训练深层神经网络时,由于模型参数较多,在数据量不足时很容易过拟合。而正则化技术主要就是用于防止过拟合,提升模型的泛化能力(对新数据表现良好)和鲁棒性(对异常数据表现良好)。 1. 概念认知 …...
访问Maven私服的教程
1.首先准备好maven私服的启动器,到bin目录下启动: 2.等待加载,加载过程比较长: 3.访问端口号: 4.仓库简介: 5.在maven的setting中 servers配置信息(设置私服访问的密码): 6.配置私服仓库地址: 7.配置上传地址(私服地址): 8.在自己的副项…...
Linux系统编程 day9 SIGCHLD and 线程
SIGCHLD信号 只要子进程信号发生改变,就会产生SIGCHLD信号。 借助SIGCHLD信号回收子进程 回收子进程只跟父进程有关。如果不使用循环回收多个子进程,会产生多个僵尸进程,原因是因为这个信号不会循环等待。 #include<stdio.h> #incl…...
Linux 内核中 cgroup 子系统 cpuset 是什么?
cpuset 是 Linux 内核中 cgroup(控制组) 的一个子系统,用于将一组进程(或任务)绑定到特定的 CPU 核心和 内存节点(NUMA 节点)上运行。它通过限制进程的 CPU 和内存资源的使用范围,优…...
乐视系列玩机---乐视2 x520 x528等系列线刷救砖以及刷写第三方twrp 卡刷第三方固件步骤解析
乐视2 x520 x528 x526等,搭载了高通骁龙652处理器,骁龙652的GPU性能甚至优于前一年的骁龙810,配备了3GB RAM和32GB ROM的存储空间, 通过博文了解💝💝💝 1💝💝💝-----详细解析乐视2 x520系列黑砖线刷救砖的步骤 2💝💝💝----官方两种更新卡刷步骤以及刷…...
电容加速电路!
大家好,我是记得诚。 今天分享一个小电路:电容加速电路。 下面是一个普通的三极管开关电路,区别是多了一个C1,C1被称为加速电容。作用是:加速三极管VT1的开通和截止,做到快开快关。 工作原理:…...
MCP Host、MCP Client、MCP Server全流程实战
目录 准备工作 MCP Server 实现 调试工作 MCP Client 实现 MCP Host 配置 第一步:配置支持 function calling的 LLM 第二步:添加MCP Server 一般有两种方式,第一种json配置,第二种直接是Command形式,我这里采用Command形式 第三步:使用MCP Server 准备工作 安装…...
Win10一体机(MES电脑设置上电自动开机)
找个键盘,带线的那种,插到电脑上,电脑开机;连续点按F11;通过↑↓键选择Enter Setup 然后回车; 选择 smart settings ; 选择 Restore AC Power Loss By IO 回车; 将prower off 改为…...
强化学习和微调 区别如下
强化学习和微调 区别如下 定义与概念 强化学习**:是一种机器学习范式,强调智能体(agent)如何在环境中采取一系列行动,以最大化累积奖励**。智能体通过与环境进行交互,根据环境反馈的奖励信号来学习最优的行为策略。例如,机器人通过不断尝试不同的动作来学习如何在复杂环…...
【EasyPan】文件上传、文件秒传、文件转码、文件合并、异步转码、视频切割分析
【EasyPan】项目常见问题解答(自用&持续更新中…)汇总版 文件上传方法解析 一、方法总览 Transactional(rollbackFor Exception.class) public UploadResultDto uploadFile(...)核心能力: 秒传验证:通过MD5文件大小实现文…...
React18+ 项目搭建-从初始化、技术选型到开发部署的全流程规划
搭建一个 React 项目需要从项目初始化、技术选型到开发部署的全流程规划。以下是详细步骤和推荐的技术栈: 一、项目初始化 1. 选择脚手架工具 推荐工具: Vite(现代轻量级工具,支持 React 模板,速度快)&am…...
day3 打卡训练营
循环语句和判断语句之前已经会了,把列表的方法练一练 浙大疏锦行 python训练营介绍...
MySQL VS SQL Server:优缺点全解析
数据库选型、企业协作、技术生态、云数据库 1.1 MySQL优缺点分析 优点 开源免费 社区版完全免费,适合预算有限的企业 允许修改源码定制功能(需遵守GPL协议) 跨平台兼容性 支持Windows/Linux/macOS,适配混合环境部署 云服务商…...
【CPP】固定大小内存池
程序运行时,通常会频繁地进行内存的分配和释放操作。传统的内存分配方式(如使用new和delete运算符)可能会导致内存碎片的产生,并且每次分配和释放内存都有一定的时间开销。内存池通过在程序启动时一次性分配一大块内存或一次性分配…...
[数据结构]树和二叉树
概念 树是一种 非线性 的数据结构,它是由 n ( n>0 )个有限结点组成一个具有层次关系的集合。 树形结构中,子树之间不能有交集,否则就不是树形结构 双亲结点或父结点 :若一个结点含有子结点,则…...
监控页面卡顿PerformanceObserver
监控页面卡顿PerformanceObserver 性能观察器掘金 const observer new PerformanceObserver((list) > {}); observer.observe({entryTypes: [longtask], })...
Web开发-JavaEE应用JNDI注入RMI服务LDAP服务DNS服务高版本限制绕过
知识点: 1、安全开发-JavaEE-JNDI注入-LADP&RMI&DNS等 2、安全开发-JavaEE-JNDI注入-项目工具&手工原理等 演示案例-WEB开发-JavaEE-JNDI注入&LDAP&RMI服务&DNS服务&高版本限制绕过 JNDI全称为 Java Naming and DirectoryInterface&am…...
深度学习训练中的显存溢出问题分析与优化:以UNet图像去噪为例
最近在训练一个基于 Tiny-UNet 的图像去噪模型时,我遇到了经典但棘手的错误: RuntimeError: CUDA out of memory。本文记录了我如何从复现、分析,到逐步优化并成功解决该问题的全过程,希望对深度学习开发者有所借鉴。 训练数据&am…...
【Spring】单例模式的创建方式(Bean解析)
在Java中,单例模式(Singleton Pattern)确保一个类只有一个实例,并提供全局访问点。以下是实现单例的五种常见方式:懒汉式、饿汉式、双重检查锁、静态内部类和枚举,包括代码示例和优缺点分析。 1. 懒汉式&am…...
小小矩阵设计
在电气设计图中,矩阵设计的接线方法是通过结构化布局实现多灵活链接的技术,常用于信号切换、配电调压或更加复杂的控制场景。 今天聊一种在电气图纸中用到的一种简单矩阵接法,一眼就看明白,很大程度简化了程序控制点和继电器的使用…...
IOT项目——双轴追光系统
双轴太阳能追光系统 - ESP32实现 系统概述 这个系统使用: ESP32开发板2个舵机(水平方向和垂直方向)4个光敏电阻(用于检测光照方向)适当的电阻(用于光敏电阻分压) 接线示意图 --------------…...
深度学习基石:神经网络核心知识全解析(一)
神经网络核心知识全解析 一、神经网络概述 神经网络作为机器学习领域的关键算法,在现代生活中发挥着重要作用,广泛应用于图像识别、语音处理、智能推荐等诸多领域,深刻影响着人们的日常生活。它通过模拟人类大脑神经系统的结构和功能&#…...
什么是 金字塔缩放(Multi-scale Input)
金字塔缩放 什么是金字塔缩放(Multi-scale Input)什么场景下会用到金字塔缩放?图像识别目标跟踪图像压缩视频处理如何在计算机程序中实现金字塔缩放?准备数据缩小数据(构建金字塔的上层)存储数据使用数据(在程序中应用金字塔缩放)金字塔缩放的记忆卡片什么是金字塔缩放(M…...
从零开始配置 Zabbix 数据库监控:MySQL 实战指南
Zabbix作为一款开源的分布式监控工具,在监控MySQL数据库方面具有显著优势,能够为数据库的稳定运行、性能优化和故障排查提供全面支持。以下是使用Zabbix监控MySQL数据库的配置。 一、安装 Zabbix Agent 和 MySQL 1. 安装 Zabbix Agent services:zabbix…...
机器学习超参数优化全解析
机器学习超参数优化全解析 摘要 本文全面深入地剖析了机器学习模型中的超参数优化策略,涵盖了从参数与超参数的本质区别,到核心超参数(如学习率、批量大小、训练周期)的动态调整方法;从自动化超参数优化技术…...
【算法】双指针8道速通(C++)
1. 移动零 思路: 拿示例1的数据来举例,定义两个指针,cur和dest,cur表示当前遍历的元素,dest以及之前表示非零元素 先用cur去找非零元素,每找到一个非零元素,就让dest的下一个元素与之交换 单个…...
synchronized锁
在了解锁之前我们要先了解对象布局 什么是java对象布局 在JVM中,对象在内存中存储的布局可以分为三块区域,即实例化之后的对象 对象头:分配的空间是固定的12Byte,由Mark Word(标记字段)和Class Pointer&…...
实训Day-2 流量分析与安全杂项
目录 实训Day-2-1流量分析实战 实训目的 实训任务1 SYN半链接攻击流量分析 实训任务2 SQL注入攻击流量分析一 实训任务3 SQL注入攻击流量分析二 实训任务4 Web入侵溯源一 实训任务5 Web入侵溯源二 编辑 实训Day-2-1安全杂项实战 实训目的 实训任务1 流量分析 FTP…...
LOH 怎么进行深度标准化?
The panel of normals is applied by replacing the germline read depth of the sample with the median read depth of samples with the same genotype in our panel. 1.解释: panel of normal 正常组织,用于识别技术噪音 germline read depth: 胚系测序深度。根…...
[预备知识]3. 自动求导机制
自动求导机制 本章节介绍 PyTorch 的自动求导机制,包括计算图、反向传播和梯度计算的原理及实现。 1. 计算图原理 计算图是深度学习框架中的一个核心概念,它描述了计算过程中各个操作之间的依赖关系。 计算图由节点(节点)和边…...
蓝桥杯中的知识点
总结: 这次考的并不理想 比赛前好多知识点遗漏 但到此为止已经结束了 mod 是 模运算(Modulo Operation)的缩写,表示求两个数相除后的 余数 10mod31 (a % b) (7%21) 1e9代表1乘以10的9次方,…...
2023蓝帽杯初赛内存取证-6
这里需要用到pslist模块,结合一下查找关键词: vol.py -f memdump.mem --profile Win7SP1x64 pslist | grep -E "VeraCrypt" 将2023-06-20 16:47:41 UTC0000世界标准时间转换成北京时间: 答案:2023-06-21 00:47:41...
《MySQL 核心技能:SQL 查询与数据库概述》
MySQL 核心技能:SQL 查询与数据库概述 一、数据库概述1. 什么是数据库2.为什么要使用数据库3.数据库的相关概念3.1 数据库(DB):数据的“仓库”3.2 数据库管理系统(DBMS):数据库的“管家”3.3 SQ…...
三维几何变换
一、学习目的 了解几何变换的意义 掌握三维基本几何变换的算法 二、学习内容 在本次试验中,我们实现透视投影和三维几何变换。我们首先定义一个立方体作为我们要进行变换的三维物体。 三、具体代码 (1)算法实现 // 获取Canvas元素 con…...
TDengine 查询引擎设计
简介 TDengine 作为一个高性能的时序大数据平台,其查询与计算功能是核心组件之一。该平台提供了丰富的查询处理功能,不仅包括常规的聚合查询,还涵盖了时序数据的窗口查询、统计聚合等高级功能。这些查询计算任务需要 taosc、vnode、qnode 和…...
15.第二阶段x64游戏实战-分析怪物血量(遍历周围)
免责声明:内容仅供学习参考,请合法利用知识,禁止进行违法犯罪活动! 本次游戏没法给 内容参考于:微尘网络安全 上一个内容:14.第二阶段x64游戏实战-分析人物的名字 如果想实现自动打怪,那肯定…...
vue浅试(1)
先安装了vue nvm安装详细教程(安装nvm、node、npm、cnpm、yarn及环境变量配置) 稍微了解了一下cursor cursor的使用 请出我们的老师: 提示词: 你是我的好朋友也是一个前端专家,你能向我传授前端知识,…...
VSCode连服务器一直处于Downloading
使用vscode的remote插件连接远程服务器时,部分服务器可能会出现一直处于Downloading VS Code Server的情况 早期的一些教程,如https://blog.csdn.net/chongbin007/article/details/126958840, https://zhuanlan.zhihu.com/p/671718415给出的方法是手动下…...
QGIS实用功能:加载天地图与下载指定区域遥感影像
QGIS 实用功能:加载天地图与下载指定区域遥感影像 目录标题 QGIS 实用功能:加载天地图与下载指定区域遥感影像一、安装天地图插件,开启地图加载之旅二、获取天地图密钥,获取使用权限三、加载天地图服务,查看地图数据四…...
mybatis-plus开发orm
1、mybatis 使用mybatis-generator自动生成代码 这个也是有系统在使用 2、mybatis-plus开发orm--有的系统在使用 MybatisPlus超详细讲解_mybatis-plus-CSDN博客...
ubuntu 交叉编译 macOS 库, 使用 osxcross 搭建 docker 编译 OS X 库
1. ubuntu 交叉编译 macOS 库, 使用 osxcross 搭建 docker 编译 OS X 库 1. ubuntu 交叉编译 macOS 库, 使用 osxcross 搭建 docker 编译 OS X 库 1.1. 安装依赖1.2. 安装 osxcross 及 macOS SDK 1.2.1. 可能错误 1.3. 编译 cmake 类工程1.4. 编译 configure 类工程1.5. 单文件…...
抱佛脚之学SSM四
MyBatis基础 一个接口对应一个映射文件 在映射文件中指定对应接口指定的位置 sql语句中id对应方法名par..参数的类型,resul..返回值的类型 WEB-INF下的文件是受保护的,不能直接访问,只能通过请求转发的方式访问 SqlSessionFactory࿱…...
2.5 函数的拓展
1.匿名函数(简化代码) python中没有这个概念,通过lambda关键字可以简化函数的代码写法 2.lambda表达式 arguments lambda 参数列表 : 函数体 print(aarguments(参数)) #测试lambda #原本代码def sum1(x,y):return xyprint(sum1…...