应该是怎么需要visudo去编辑把ota_manager.service引入进去的

你说得对!为了让 ota_manager.py(以 cat 用户身份运行)能够启动和停止 ota_http_server.service(以及其他 ROS 服务),我们需要在 sudoers 配置中明确授予 cat 用户执行这些特定 systemctl 命令的权限,并且是无需密码 (NOPASSWD) 的。

使用 visudo 编辑 sudoers 配置(推荐且安全的方式):

  1. 打开 visudo 编辑器:

    bash 复制代码
    sudo visudo

    这会使用系统默认的文本编辑器(通常是 nano 或 vim)打开一个临时文件进行编辑。visudo 会在保存时检查语法,防止你搞坏 sudo

  2. 添加权限规则: 在文件的末尾(或者用户权限规则部分),添加以下行。注意: 每一行对应一个允许的操作。你需要为每个服务添加 startstop 的权限。

    sudoers 复制代码
    # Allow cat user to start/stop specific services without a password for OTA management
    cat ALL=(ALL) NOPASSWD: /usr/bin/systemctl start ota_http_server.service
    cat ALL=(ALL) NOPASSWD: /usr/bin/systemctl stop ota_http_server.service
    cat ALL=(ALL) NOPASSWD: /usr/bin/systemctl start camera_processor_launch.service
    cat ALL=(ALL) NOPASSWD: /usr/bin/systemctl stop camera_processor_launch.service
    cat ALL=(ALL) NOPASSWD: /usr/bin/systemctl start ot_agent_launch.service
    cat ALL=(ALL) NOPASSWD: /usr/bin/systemctl stop ot_agent_launch.service
    cat ALL=(ALL) NOPASSWD: /usr/bin/systemctl start ogger_launch.service
    cat ALL=(ALL) NOPASSWD: /usr/bin/systemctl stop ogger_launch.service
    cat ALL=(ALL) NOPASSWD: /usr/bin/systemctl start le_reader_launch.service
    cat ALL=(ALL) NOPASSWD: /usr/bin/systemctl stop le_reader_launch.service
    • cat: 指定哪个用户。
    • ALL=: 表示允许从任何主机执行。
    • (ALL): 表示允许以任何用户身份运行命令(通常是 root)。
    • NOPASSWD:: 表示执行后面的命令时不需要输入密码。
    • /usr/bin/systemctl start <service_name> : 明确指定允许执行的命令及其参数。使用 systemctl 的绝对路径 (/usr/bin/systemctlwhich systemctl 的输出) 很重要!
  3. 保存并退出:

    • Nano 编辑器:Ctrl+X,然后按 Y 确认保存,再按 Enter 确认文件名。
    • Vim 编辑器:Esc,然后输入 :wq,再按 Enter

    visudo 会在你保存时检查语法。如果有错误,它会提示你,不允许你保存错误的配置。

替代方案:使用 /etc/sudoers.d/ 目录(更推荐,更易管理)

创建一个单独的文件来存放你的 OTA 相关权限规则,这样更容易管理,并且不容易影响主 /etc/sudoers 文件。

bash 复制代码
# (需要 root 权限)

# 1. 创建并编辑新文件 (文件名不重要,但最好有意义)
sudo visudo -f /etc/sudoers.d/ota_manager_permissions

# 2. 在打开的编辑器中,粘贴以下内容:
# Allow cat user to start/stop specific services without password for OTA management
cat ALL=(ALL) NOPASSWD: /usr/bin/systemctl start http_server.service
cat ALL=(ALL) NOPASSWD: /usr/bin/systemctl stop _server.service
cat ALL=(ALL) NOPASSWD: /usr/bin/systemctl start amera_processor_launch.service
cat ALL=(ALL) NOPASSWD: /usr/bin/systemctl stop camera_processor_launch.service
cat ALL=(ALL) NOPASSWD: /usr/bin/systemctl start bot_agent_launch.service


# 3. 保存并退出编辑器。

# 4. (重要)设置正确的文件权限,否则 sudo 会忽略它!
sudo chmod 440 /etc/sudoers.d/ota_manager_permissions

echo "Sudoers rule created in /etc/sudoers.d/ota_manager_permissions"

完成以上配置后:

  1. 重启 ota_manager.service

    bash 复制代码
    sudo systemctl restart ota_manager.service
  2. 检查日志: 查看 journalctl -u ota_manager.service~/ota_workspace/logs/ota_manager.log。这次 run_systemctl 函数调用 sudo systemctl ... 时应该不会再有 PAM 认证失败的错误了,服务应该能被成功启动和停止。

  3. 测试 HTTP 服务自启动:

    bash 复制代码
    # (确保 manager 服务正在运行)
    sudo systemctl stop ota_http_server.service # 手动停止 HTTP 服务
    sleep 2
    sudo systemctl restart ota_manager.service # 重启 Manager
    sleep 5 # 等待 manager 启动并检查
    sudo systemctl status ota_http_server.service --no-pager # 确认 HTTP 服务被 Manager 重新启动了
    sudo netstat -tulnp | grep ':5000' # 确认端口监听

这样配置后,ota_manager.py(以 cat 用户运行)就获得了控制这些特定服务的必要权限,并且整个流程都运行在更低的用户权限下,更加安全。

相关推荐
小鸡脚来咯33 分钟前
RESTful API 面试详解
后端·面试·restful
鹏程十八少1 小时前
2.Android 3分钟跑通Shadow官方插件化Demo(Maven版):宿主/管理器/插件三工程(实战)
android·前端·面试
熏鱼的小迷弟Liu1 小时前
【消息队列】如何在RabbitMQ中处理消息的重复消费问题?
面试·消息队列·rabbitmq
求梦8202 小时前
前端八股文【CSS核心面试题库】
前端·css·面试
NAGNIP9 小时前
万字长文!回归模型最全讲解!
算法·面试
qq_318121599 小时前
互联网大厂Java面试故事:从Spring Boot到微服务架构的技术挑战与解答
java·spring boot·redis·spring cloud·微服务·面试·内容社区
且去填词11 小时前
Go 语言的“反叛”——为什么少即是多?
开发语言·后端·面试·go
青莲84313 小时前
RecyclerView 完全指南
android·前端·面试
青莲84314 小时前
Android WebView 混合开发完整指南
android·前端·面试
37手游后端团队17 小时前
gorm回读机制溯源
后端·面试·github