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就没问题了。

相关推荐
跨境数据猎手12 分钟前
大数据在电商行业的应用
大数据·运维·爬虫
linyanRPA1 小时前
影刀RPA店群自动化实战:多店铺活动自动报名与促销管理架构设计
运维·自动化·办公自动化·rpa·python脚本·爬虫自动化·店群自动化
mounter6251 小时前
现代 Linux 内存管理的演进与变革:从传统 LRU 到多代架构 MGLRU
linux·服务器·kernel
会Tk矩阵群控的小木1 小时前
安卓群控系统对于游戏工作室实战教程
android·运维·游戏·adb·开源软件·个人开发
赵渝强老师2 小时前
【赵渝强老师】Kubernetes(K8s)中的金丝雀升级
linux·docker·云原生·容器·kubernetes
佛山个人技术开发2 小时前
GitCode SSH连接配置教程
运维·ssh·gitcode
Qt程序员2 小时前
Linux RCU 原理与应用
linux·c++·内核·linux内核·rcu
The Sheep 20232 小时前
Vue复习
linux·服务器·数据库
兄台の请冷静2 小时前
Linux 安装es
linux·elasticsearch·jenkins
fengyehongWorld2 小时前
Linux rg命令
linux