# :-: audit内存泄露问题分析报告
| 适用范围 | 适用版本 | 人员 | 发布时间 | 文档版本 |备注 |
| --- | --- | --- | --- | --- |--- |
| 服务器操作系统 | V10-SP1、V10-SP2 | 王国武 |2022.3.4| V1.0|发布|
| 服务器操作系统 | V10-SP1、V10-SP2 | 张志勇 |2022.3.4| V1.1|模板调整|
### 经测试,该方案有效可行
*****
### 1.问题现象描述
在 audit 服务启动状态下,top查看audit服务的内存使用情况,会不断的增加
### 2.影响版本及触发条件
影响版本
V10-SP1-0711及以后版本
V10-SP2-0524版本
触发条件:
安装了audit-3.0-5.se.05.ky10软件包,并启动了auditd服务
### 3.问题分析
在系统中执行ssh远程连接,产生用户登录的audit日志,观察audit进程的内存使用情况。内存使用情况监视命令:`watch -n 1 -d cat "/proc/"`ps -ef | grep -w auditd |grep -v grep | awk 'NR==1 {print $2}'`"/status"`。占用的内存不释放,通过代码分析发现存在内存未释放的地方,如下图所示:

audit程序中会在写日志之前判断当前分区是否已满,即获取分区剩余空间的大小,通过在此处移植df相关的实现到audit中,移植的代码中有一处内存申请,在用完之后未释放,从而导致了内存泄露。
### 4.问题影响
在安装并启动auditd服务长时间运行后,由于其内存泄漏问题且auditd的优先级高,所以会消耗系统内存,从而影响一些应用的使用。
### 5.问题修复
修改了判断当前分区是否已满的逻辑,解决内存未能正确释放的问题。
### 6.解决方案
升级audit至audit-3.0-5.se.07.ky10及以后版本
- 常见问题
- 进入救援模式
- 进入单用户模式
- grub引导修复
- V10SP1-biosdevname解析
- 外设挂载和卸载
- audit关闭解决方案
- 终端无法切换
- 救援模式取数据
- 网卡更名操作
- 问题复现解决类
- xgboost复现解决步骤
- 激活类
- 麒麟服务器激活常用命令
- 服务器故障激活问题--须知
- 激活权限获得方式
- V10-SP系列服务器激活
- 银河麒麟高级服务器操作系统V7&V10激活手册
- shell脚本类
- 多网卡队列绑定CPU脚本
- 服务器健康检查脚本
- 服务安装配置类
- 银河麒麟高级服务器操作系统V10(sp1)安装手册
- LVM创建
- Chrony时间同步配置
- 搭建网络yum源
- PXE部署实施
- Man手册安装
- 部署VNC服务
- Kylin-Server-V10-SP1-0711-DNS服务单机部署文档
- 麒麟ks文件定制-封装iso文件
- iptables端口配置
- V10-SP1-aarch64安装jdk1.7
- 工具使用类
- cyclictest测试工具
- e2fsprogs工具介绍
- Logrotate工具说明
- nmon工具安装与使用
- 升、降级类
- rsyslog升级报告
- 性能优化类
- 日志轮转
- 大页内存与透明大页详解
- 优化磁盘IO调度方式
- core文件设置
- 分析报告类
- bond模式4协商不通排查
- audit内存泄露问题分析报告
- mate-indicators内核占用过高问题分析报告
- ansible问题-hostname以及lvol报错
- 关于Linux内存计算的说明
- 磁盘IO调度算法
- 硬件相关类
- 串口
- 网络相关类
- bond创建
- 在已配置好网络情况下添加路由
- 网卡配合网桥实现内网互通KVM虚拟机
- Bond模式4协商不通排查过程
- HA高可用
- kylin HA shell实践
- kylin HA概念性及shell使用
- 虚拟化
- KVM创建虚拟机(图形化操作)
- KVM创建虚拟机(命令操作)
- 容器类
- docker-runc升级
- docker基础镜像制作-服务器版
- 麒麟云平台
- USB3.0设备穿透方法(针对win10云主机穿透)
- 麒麟云平台开关机操作说明
- 技术演练
