

- 1. 禅道介绍
- 1.1 关于禅道项目管理软件
- 1.2 如何获得支持
- 1.3 各版本功能差异
- 1.4 关注我们
- 2. 安装禅道
- 2.1. 环境搭建
- 2.1.1 搭建Ubuntu环境安装禅道
- 2.1.2 搭建Centos环境安装禅道
- 2.1.3 安装PHP的ioncube扩展
- 2.2. 安装禅道
- 2.2.1 选择适合您的安装方法
- 2.2.2 新版本禅道的安装升级
- 2.2.3 Windows一键安装包(新版)
- 2.2.4 Windows一键安装包(旧版)
- 2.2.5 linux用一键安装包(推荐)
- 2.2.6 使用源码包安装(各系统通用)
- 2.2.7 使用源码包安装(MAC系统)
- 2.2.8 基于禅道当前的一键安装包(Windows和Linux)如何源码安装旗舰版禅道
- 2.2.9 渠成命令行安装禅道
- 2.2.10 Docker和Kubernetes方式部署禅道
- 2.3 安装PHP的LDAP扩展
- 2.4 在线安装云禅道
- 2.5 安装 APCu扩展
- 2.6 安装DuckDB引擎
- 2.7. 信创支持
- 2.7.1 OceanBase数据库
- 2.1. 环境搭建
- 3. 升级禅道
- 3.1. 升级禅道新版本
- 3.1.1 选择和自己环境对应的升级方式
- 3.1.2 通过源代码方式升级(通用)
- 3.1.3 windows一键安装包的升级
- 3.1.4 linux一键安装包升级
- 3.1.5 docker安装禅道-升级禅道
- 3.1.6 旧版Docker镜像升级说明
- 3.1.7 通过Roadrunner管理定时任务
- 3.2 如何安装ioncube扩展
- 3.1. 升级禅道新版本
- 4. 维护配置
- 4.1. 维护禅道
- 4.1.1 初始化管理脚本
- 4.1.2 备份禅道
- 4.1.3 恢复删除的资源
- 4.1.4 如何更新燃尽图
- 4.1.5 一键安装包如何实现mysql异机连接
- 4.1.6 linux一键安装包配置https
- 4.1.7 禅道一键安装包迁移/更新禅道一键安装包
- 4.2. 配置禅道
- 4.2.1 设置是否允许匿名访问
- 4.2.2 如何配置email发信
- 4.2.3 如何成为超级管理员
- 4.2.4 配置禅道系统为静态访问
- 4.2.5 去掉禅道访问地址中的zentao
- 4.2.6 linux一键安装包去掉禅道访问地址中的zentao
- 4.2.7 集成禅道和svn
- 4.2.8 集成禅道和git
- 4.2.9 在第三方应用中集成禅道
- 4.2.10 第三方应用配置免密登录禅道
- 4.2.11 第三方应用集成禅道客户端进行消息通知
- 4.2.12 集成webhook
- 4.2.13 集成ZDOO
- 4.2.14 客户端集成
- 4.2.15 浏览器通知的设置
- 4.2.16 集成钉钉工作消息通知
- 4.2.17 集成企业微信应用消息通知
- 4.2.18 集成企业微信群机器人
- 4.2.19 集成飞书群机器人
- 4.2.20 集成飞书消息通知
- 4.2.21 解决一键安装包密码口令弱的问题
- 4.3. 性能优化
- 4.3.1 nginx反向代理禅道502或504bad gateway错误
- 4.3.2 linux系统中配置session使用redis
- 4.3.3 缓存功能
- 4.1. 维护禅道
- 5. 快速入门
- 5.1. 新版本快速入门
- 5.1.1 20版本禅道的新增功能
- 5.1.2 新版本禅道的最简使用
- 5.1.3 20版本禅道的界面变化
- 5.1. 新版本快速入门
- 6. 按照角色使用
- 6.1. 管理员
- 6.2. 项目集负责人
- 6.3. 产品经理
- 6.4. 项目经理
- 6.5. 研发人员
- 6.5.1 参加产品计划会议,分解任务
- 6.5.2 领取任务,并每天更新任务
- 6.5.3 创建构建,提交测试
- 6.5.4 确认Bug,解决Bug
- 6.5.5 执行的综合、需求、Bug、任务看板
- 6.6. 测试人员
- 7. 功能介绍
- 7.1. 核心管理结构
- 7.1.1 项目集(Program)
- 7.1.2 项目(Project)
- 7.1.3 产品(Product)
- 7.1.4 执行(Execution)
- 7.1.5 管理模型
- 7.2. 地盘
- 7.3. 项目集
- 7.4. 产品
- 7.4.1 创建产品
- 7.4.2 维护模块
- 7.4.3 产品多分支/平台管理
- 7.4.4 维护计划
- 7.4.5 维护需求
- 7.4.6 需求的评审
- 7.4.7 创建发布
- 7.4.8 跟踪进度
- 7.4.9 业务需求&需求多层级
- 7.5. 项目
- 7.6. 执行
- 7.6.1 参加产品计划会议,分解任务
- 7.6.2 领取任务,并每天更新任务
- 7.6.3 创建构建,提交测试
- 7.6.4 确认Bug,解决Bug
- 7.6.5 执行的综合、需求、Bug、任务看板
- 7.7. 测试
- 7.8. 自动化测试
- 7.9 DevOps(解决方案)
- 7.10. 文档
- 7.11. AI
- 7.11.1 AI小程序简介
- 7.11.2 创建与设计AI小程序
- 7.11.3 发布与禁用小程序
- 7.11.4 调试AI小程序
- 7.11.5 前台小程序的应用
- 7.11.6 AI小程序的导入导出
- 7.11.7 管理AI小程序权限
- 7.12. BI
- 7.12.1 维度(企业版8.4+)
- 7.12.2 大屏(企业版8.4+)
- 7.12.3 透视表
- 7.12.4 透视表下钻
- 7.12.5 图表
- 7.12.6. 度量项
- 7.12.6.1 查看度量项
- 7.13. 反馈
- 7.14. 看板
- 7.14.1 通用看板功能
- 7.15. 工作流
- 7.16. 学堂
- 7.17. 资产库(旗舰版)
- 7.17.1 资产库管理(旗舰版)
- 7.18. 组织
- 7.18.1 团队成员和工作信息
- 7.18.2 人力资源日历(需安装插件)
- 7.18.3 组织动态
- 7.18.4 公司信息
- 7.19. 办公
- 7.20. 后台设置
- 7.20.1 后台首页
- 7.20.2. 系统设置
- 7.20.3 功能开关
- 7.20.4. 人员管理
- 7.20.5. 模型配置
- 7.20.6. 功能配置
- 7.20.7 文档模板
- 7.20.8. 通知设置
- 7.20.9 插件管理
- 7.20.10 二次开发
- 7.20.11 Jira数据导入
- 7.20.12 Jira数据导入--数据迁移说明
- 7.20.13 Confluence数据导入
- 7.20.14. 权限维护和控制
- 7.20.14.1 项目集的权限维护和访问控制
- 7.20.14.2 产品的权限维护和访问控制
- 7.20.14.3 项目的权限维护和访问控制
- 7.20.14.4 执行的权限维护和访问控制
- 7.20.14.5 项目和执行的访问控制和数据关系
- 7.20.15. AI配置
- 7.20.16. DevOps设置
- 7.20.16.1. 资源
- 7.21. 客户端增强版会议SRS
- 7.21.1. 音视频会议配置
- 7.21.1.1 安装音视频服务端
- 7.21.1.2 安装SRS音视频服务端
- 7.21.1.3 开启和配置音视频功能
- 7.21.2. 发起会议
- 7.21.2.1 一对一会话中发起音视频会议
- 7.21.2.2 群组会话中发起音视频会议
- 7.21.2.3 独立发起音视频会议入口
- 7.21.3. 加入会议
- 7.21.3.1 分享音视频会议到会话
- 7.21.3.2 通过会议的ID加入会议
- 7.21.4. 预约会议
- 7.21.4.1 预约会议
- 7.21.5. 会议应用
- 7.21.5.1 音视频会议应用
- 7.21.1. 音视频会议配置
- 7.22. 客户端增强版会议Jitsi
- 7.1. 核心管理结构
- 8. 其他相关
- 9. IPD版本功能介绍
- 9.1. 禅道IPD版介绍
- 9.1.1 关于禅道IPD版
- 9.1.2 禅道IPD版的核心流程
- 9.2. IPD版的安装和升级
- 9.2.1 选择适合您的安装方法
- 9.2.2 选择适合您的升级方法
- 9.3. 需求与市场管理界面
- 9.4. IPD研发管理界面
- 9.1. 禅道IPD版介绍
缓存功能 分享链接 /book/zentaopms/cache-1694.html?releaseID=17
本篇目录
禅道21.2版本对缓存功能做了较大的调整,以下是相关说明。
一、名词解释
SQL查询结果缓存:把SQL查询的结果放到缓存中。
整表数据缓存:把整张表的数据放到缓存中。
计算结果缓存:把业务逻辑计算出的结果放到缓存中。
二、缓存内容及更新策略
21.2版本之前的缓存底层使用PHP-APCu扩展实现,只缓存了SQL查询的结果,默认缓存生命周期为1个月。当SQL查询的表的内容发生增删改时缓存失效。
21.2版本开始,缓存底层同时支持PHP-APCu和Redis。缓存内容除了SQL查询结果外,增加了整表数据缓存和计算结果缓存。其中SQL查询结果的默认缓存生命周期调整为1周,当SQL查询的表的内容发生增删改时缓存失效。整表数据缓存和计算结果缓存默认生命周期为永久,即永不失效。整表数据缓存和计算结果缓存会记录关联的表,当这些表发生增删改时,整表数据缓存会自动更新内容,计算结果缓存会被标记为失效,由业务逻辑重新对计算结果数据进行缓存。
三、性能测试
1. 测试数据
数据库容量 9.4G 项目集数量 182 项目数量 874 迭代数量 3594 产品数量 129 需求数量 67873 任务数量 131879 Bug数量 67873 用例数量 10890 模块数量 11255 日志数量 2317479
2. 测试对象
使用10个常用页面作为测试对象,分别为我的地盘、项目集列表、产品列表、项目列表、执行列表、需求列表、任务列表、测试仪表盘、Bug列表、用例列表。
3. 测试结果
使用JMeter对上述10个页面进行读取测试,开启缓存后的吞吐量提升从26%-100%不等,同时CPU使用率下降了40%-80%,下面为详细数据。
四、APCu和Redis的差异
APCu是PHP扩展直接操作内存,而Redis是网络服务,需要建立网络连接,因此APCu缓存的性能高于Redis。下面说明两者的差异,用户可根据自己的实际场景选择。
- APCu不支持分布式,不能设置缓存淘汰策略。当分配的内存不足时,APCu会清空所有缓存内容再写入,此时会对性能有较大影响。APCu可以自动处理复杂数据类型如数组、对象等,无需应用层序列化。
-
Redis支持分布式,可以设置缓存淘汰策略。推荐的缓存淘汰策略为
volatile-lru: 从设置了过期时间的缓存中选择最近最久未使用的进行淘汰
,即内存不足时会优先淘汰SQL查询结果缓存 。Redis需要应用层把复杂数据类型序列化为字符串后存储(Hash类型可以存储对象但不适用于禅道的应用场景)。
五、禅道缓存配置
禅道中的缓存配置功能在【后台】=>【系统设置】=>【缓存】页面。
如果用APCu做缓存服务只需要选择服务范围并填写命名空间即可,如果用Redis则还需要填写Redis相关配置。下面对几个特殊配置进行说明。
1. 服务范围
缓存作为基础设施可以同时提供给多个应用使用,如果该缓存服务只有禅道使用可以选择【本应用独享】,否则选择【多应用共享】。这两个选项的区别在于清除缓存时采用不同的机制,性能略有差异,使用方面没有差异。
【本应用独享】清除缓存时调用缓存服务自身提供的清除机制,APCu为apcu_clear_cache()
,Redis为flushDB
。
【多应用共享】清除缓存时对缓存的内容遍历,清除以【命名空间】中设置的值为前缀的缓存键。
2. 命名空间
命名空间主要用于【多应用共享】场景下区分禅道和其他应用的缓存数据,要求确保唯一性,默认值为禅道连接的数据库名。
3. Redis序列化器
因为Redis存储复杂数据类型需要序列化为字符串后存储,所以需要选择序列化器。PHP内置序列化器即内置的serialize()
方法,igbinary
序列化器为PHP-igbinary扩展提供。由于igbinary序列化的性能和空间占用优于内置序列化器,因此作为默认值。
六、缓存服务配置
1. APCu
APCu配置较简单,对禅道来说仅设置内存使用限制即可。
apc.shm_size=2G
2. Redis
Redis推荐的配置如下,主要是内存使用限制、缓存淘汰策略、禁用持久化。
# TCP连接队列长度,高并发环境建议增大此值 tcp-backlog 511 # 客户端连接空闲超时时间,0表示不超时 timeout 0 # 禁用持久化 save "" # 最大客户端连接数 maxclients 10000 # 最大内存使用限制 maxmemory 2gb # 内存达到限制时的淘汰策略: maxmemory-policy volatile-lru # 是否启用AOF持久化 appendonly no