
arnested/systemd-statesystemd-state 是一个小型HTTP服务器,用于暴露systemd的整体运行状态,功能等效于执行 systemctl is-system-running 命令。其核心用途是作为轻量级监控解决方案,将系统状态以HTTP接口形式提供给外部监控服务(如Pingdom、StatusCake等),便于快速判断系统是否正常运行。
服务器通过HTTP状态码反馈systemd系统状态,具体对应关系如下:
systemctl is-system-running 返回 running)。degraded、maintenance、starting、stopping 等)。程序体积小,资源占用低,仅依赖systemd的运行时信息,无需复杂配置。
Docker Hub地址:arnested/systemd-state
拉取命令:
bashdocker pull arnested/systemd-state
需挂载主机的 /run/systemd/ 目录(只读)以获取systemd状态:
bashdocker run -d \ --name systemd-state \ -v /run/systemd/:/run/systemd/:ro \ -p 8080:80 \ --restart always \ arnested/systemd-state
-v /run/systemd/:/run/systemd/:ro:挂载systemd运行时目录(只读权限,确保安全性)。-p 8080:80:将容器内80端口映射到主机8080端口(可根据需求调整)。--restart always:确保容器异常退出后自动重启。访问 http://<主机IP>:8080 即可获取系统状态(通过HTTP状态码判断)。
以下示例通过Traefik暴露HTTPS接口并添加基本认证,适用于生产环境。
[***]。foo,密码 bar(示例密码哈希需替换为实际生成值)。traefik_webgateway。yamlversion: "2" services: systemd-state: image: arnested/systemd-state volumes: - '/run/systemd/:/run/systemd/:ro' # 只读挂载systemd运行时目录 restart: always labels: - 'traefik.frontend.auth.basic=foo:$$apr1$$WCYo2XY2$$7PDdo922necZuGkMAeTI70' # 基本认证(示例哈希对应密码bar) - "traefik.port=80" # 容器内服务端口 - "traefik.enable=true" # 启用Traefik代理 - "traefik.frontend.rule=Host:example.com;Path:/_systemd" # 路由规则(替换为实际域名) networks: - web networks: web: external: name: traefik_webgateway # 关联Traefik外部网络
使用 htpasswd 生成密码哈希(需安装apache2-utils):
bashhtpasswd -n foo # 输入密码后输出类似:foo:$apr1$WCYo2XY2$7PDdo922necZuGkMAeTI70
将生成的哈希替换到 traefik.frontend.auth.basic 标签中。
/run/systemd/ 时使用只读权限(:ro),避免容器修改主机系统状态。设计理念与Prometheus类似,优先保证简单性和轻量性。如需安全访问,建议通过反向代理层实现(如Traefik、Nginx)。详情可参考Prometheus FAQ。
访问HTTP接口后,通过状态码判断:200表示系统正常,503表示系统异常,500表示无法获取状态(需检查容器是否正确挂载 /run/systemd/ 目录)。




manifest unknown 错误
TLS 证书验证失败
DNS 解析超时
410 错误:版本过低
402 错误:流量耗尽
身份认证失败错误
429 限流错误
凭证保存错误
来自真实用户的反馈,见证轩辕镜像的优质服务