polkit服务没起来,导致防火墙命令卡住

一、问题描述:

前端时间升级漏洞,升级了polkit,导致防火墙执行**firewall-cmd --list-all**卡住,

polkit(PolicyKit)权限问题 ,是因为 firewalld 服务在向 polkit 请求权限时被阻塞或拒绝,导致进程在后台"挂起"等待授权。

为什么 polkit 会导致 firewall-cmd 卡住?

  • firewall-cmd需要修改或读取防火墙状态时,会通过 D-Bus 向 firewalld守护进程发送请求。

  • firewalld在响应前,会通过 polkit​ 检查当前用户(即使是 root)是否有权限执行该操作。

  • 如果 polkit 服务异常、规则文件损坏或 D-Bus 通信阻塞firewall-cmd就会一直等待 polkit 的授权响应,表现为"命令卡死"。

    查看polkit报错 systemctl status polkit报错:

    ● polkit.service - Authorization Manager

    Loaded: loaded (/usr/lib/systemd/system/polkit.service; static; vendor preset: enabled)

    Active: inactive (dead) since Tue 2026-05-19 10:16:17 CST; 2s ago

    Docs: man:polkit(8)

    Process: 1268741 ExecStart=/usr/lib/polkit-1/polkitd --no-debug (code=exited, status=0/SUCCESS)

    Main PID: 1268741 (code=exited, status=0/SUCCESS)

    5月 19 10:16:17 syzl-api systemd1: Starting Authorization Manager...

    5月 19 10:16:17 syzl-api polkitd1268741: Started polkitd version 0.116

    5月 19 10:16:17 syzl-api polkitd1268741: Loading rules from directory /etc/polkit-1/rules.d

    5月 19 10:16:17 syzl-api polkitd1268741: Error opening rules directory: Error opening directory "/etc/polkit-1/rules.d": Permission denied (g>

    5月 19 10:16:17 syzl-api polkitd1268741: Loading rules from directory /usr/share/polkit-1/rules.d

    5月 19 10:16:17 syzl-api polkitd1268741: Finished loading, compiling and executing 5 rules

    5月 19 10:16:17 syzl-api polkitd1268741: Lost the name org.freedesktop.PolicyKit1 - exiting

    5月 19 10:16:17 syzl-api systemd1: polkit.service: Succeeded.

    5月 19 10:16:17 syzl-api systemd1: Started Authorization Manager

二、解决:

1. 检查 polkit 服务状态

复制代码
systemctl status polkit

如果状态不是 active (running),这就是根本原因。

重启 polkit 与 D-Bus(最常用)

复制代码
# 1. 重启 polkit 服务
systemctl restart polkit

# 2. 重启 D-Bus(注意:这会短暂中断桌面和系统服务)
systemctl restart dbus

# 3. 再次测试 firewall-cmd
firewall-cmd --list-all

如果还不行就重新安装

2.重新安装 polkit 相关包

查看 polkit 相关包

rpm -qa | grep polkit

重新安装(以 Kylin/RedHat 系为例)

复制代码
yum reinstall polkit polkit-pkla-compat -y

重启服务

复制代码
systemctl restart polkit dbus firewalld

只要polkit服务起来,在执行 firewall-cmd --list-all就没问题了。

相关推荐
AlfredZhao2 天前
生产环境里,为什么不建议把普通端口直接暴露到公网?
linux·https·443·80
戴为沐3 天前
Linux内存扩容指南
linux
zylyehuo3 天前
Linux 彻底且安全地删除文件
linux
用户805533698034 天前
主线 U-Boot 上 RK3506:和闭源 rkbin 拔河的三个隐性契约
linux·嵌入式
用户034095297914 天前
linux fcitx 5 雾凇拼音 设置在中文输入法下仍然输入英文标点
linux
乘云数字DATABUFF4 天前
5分钟部署开源APM Databuff:OpenTelemetry全链路追踪入门实战
运维·后端
Web3探索者5 天前
可视化服务器管理和传统命令行区别是什么?新手教程:Linux 运维到底该用图形界面还是 SSH 命令行?
linux·ssh
zylyehuo6 天前
Linux系统中网线与USB网络共享冲突
linux
荣--6 天前
一键部署不是为了省时间 —— 它是把"买来的 PaaS"变成"自己的平台"的拐点
运维·zabbix·工程化·一键部署·平台化·边界设计
江华森6 天前
动手实战学 Docker — 从零到集群编排完全指南
运维