9.5. 软件管理
即使日志记录服务不可用,YUM 功能或插件也可能记录消息
某些 YUM 功能或插件可能在日志记录服务不可用时将消息记录到标准输出或标准错误输出。日志消息的级别指示消息记录在哪里:
- 信息消息记录到标准输出。
- 错误和调试消息记录到标准错误输出。
因此,当编写 YUM 选项脚本时,标准输出或标准错误输出上的不需要的日志消息可能会影响脚本的功能。
要临时解决这个问题,使用 yum -q
命令抑制标准输出和标准错误输出上的日志消息。这抑制了日志消息,但不是在标准输出上预期的命令结果。
Jira:RHELPLAN-50409[1]
cr_compress_file_with_stat()
可能会导致内存泄漏
createrepo_c
C 库包含 API cr_compress_file_with_stat()
函数。这个函数被声明为以 char **dst
作为第二个参数。根据其他参数,cr_compress_file_with_stat()
要么使用 dst
作为输入参数,要么使用它来返回一个分配的字符串。这种无法预测的行为可能会导致内存泄漏,因为它不会通知用户何时释放 dst
内容。
要临时解决这个问题,增加了一个新的 API cr_compress_file_with_stat_v2
函数,它只使用 dst
参数作为输入。它被声明为 char *dst
。这可防止内存泄漏。
请注意,cr_compress_file_with_stat_v2
函数为临时的,仅存在于 RHEL 8 中。之后,cr_compress_file_with_stat()
将会被修复。
Bugzilla:1973588[1]
当 scriptlet 失败时,YUM 事务被报告为成功
从 RPM 版本 4.6 开始,允许安装后 scriptlet 失败,而不会对事务造成致命影响。这个行为也被传播到 YUM。这导致 scriptlets 可能会偶尔失败,而整个软件包事务报告为成功。
目前还没有可用的临时解决方案。
请注意,这是预期行为,其在 RPM 和 YUM 之间保持一致。scriptlet 中的任何问题都应在软件包层面上解决。