openplc runtimev4 Python插件虚拟环境指南

Python插件虚拟环境指南

本文档描述了如何在OpenPLC运行时中为Python插件使用单独的虚拟环境(venv),允许每个插件拥有自己的依赖项而不会产生冲突。

概述

分离的虚拟环境系统允许您:

  • 让每个Python插件使用特定的库版本
  • 避免不同插件的依赖项之间的冲突
  • 简化插件开发与维护
  • 保持与现有插件的兼容性

文件结构

复制代码
openplc-runtime/
├── venvs/                          # 虚拟环境目录
│   ├── modbus_slave/               # Modbus插件的venv
│   └── mqtt_client/                # MQTT插件的venv
├── core/src/drivers/plugins/python/
│   ├── modbus_slave_plugin/
│   │   ├── simple_modbus.py
│   │   ├── modbus_slave_config.json
│   │   └── requirements.txt        # 插件特定依赖项
│   └── mqtt_plugin/
│       ├── plugin.py
│       ├── config.json
│       └── requirements.txt
└── scripts/
    └── manage_plugin_venvs.sh      # 管理脚本

使用方法

1. 创建带虚拟环境的插件

  1. 创建插件目录:

    bash 复制代码
    mkdir core/src/drivers/plugins/python/my_plugin
  2. 创建requirements.txt文件:

    bash 复制代码
    echo "pymodbus==3.6.4" > core/src/drivers/plugins/python/my_plugin/requirements.txt
    echo "paho-mqtt==2.1.0" >> core/src/drivers/plugins/python/my_plugin/requirements.txt
  3. 创建虚拟环境:

    bash 复制代码
    ./scripts/manage_plugin_venvs.sh create my_plugin
  4. 配置plugins.conf:

    复制代码
    my_plugin,./core/src/drivers/plugins/python/my_plugin/plugin.py,1,0,./config.json,./venvs/my_plugin

2. 管理虚拟环境

为插件创建虚拟环境:
bash 复制代码
./scripts/manage_plugin_venvs.sh create PLUGIN_NAME
列出所有虚拟环境:
bash 复制代码
./scripts/manage_plugin_venvs.sh list
安装依赖项:
bash 复制代码
./scripts/manage_plugin_venvs.sh install PLUGIN_NAME
移除虚拟环境:
bash 复制代码
./scripts/manage_plugin_venvs.sh remove PLUGIN_NAME
虚拟环境信息:
bash 复制代码
./scripts/manage_plugin_venvs.sh info PLUGIN_NAME

plugins.conf格式

新格式(带虚拟环境):

复制代码
# 名称,路径,启用状态,类型,配置文件路径,虚拟环境路径
modbus_slave,./core/src/drivers/plugins/python/modbus_slave_plugin/simple_modbus.py,1,0,./config.json,./venvs/modbus_slave

旧格式(无虚拟环境 - 仍然兼容):

复制代码
# 名称,路径,启用状态,类型,配置文件路径
example_plugin,./core/src/drivers/examples/example_python_plugin.py,1,0,./example_config.ini

实际示例

带有特定虚拟环境的Modbus插件:

  1. 创建requirements.txt:

    bash 复制代码
    cat > core/src/drivers/plugins/python/modbus_slave_plugin/requirements.txt << EOF
    pymodbus==3.6.4
    asyncio-mqtt==0.16.2
    EOF
  2. 创建虚拟环境:

    bash 复制代码
    ./scripts/manage_plugin_venvs.sh create modbus_slave
  3. 配置plugins.conf:

    复制代码
    modbus_slave,./core/src/drivers/plugins/python/modbus_slave_plugin/simple_modbus.py,1,0,./core/src/drivers/plugins/python/modbus_slave_plugin/modbus_slave_config.json,./venvs/modbus_slave
  4. 验证安装:

    bash 复制代码
    ./scripts/manage_plugin_venvs.sh info modbus_slave

兼容性

  • 现有插件: 无需更改即可正常工作
  • 传统系统: 如果venv_path为空或缺失,则使用系统Python
  • Python版本: 适用于Python 3.6+

故障排除

插件找不到模块:

  • 检查虚拟环境是否创建:./scripts/manage_plugin_venvs.sh list
  • 检查依赖项是否已安装:./scripts/manage_plugin_venvs.sh info PLUGIN_NAME
  • 检查plugins.conf中的路径

依赖项冲突:

  • 每个插件都有自己的隔离虚拟环境
  • requirements.txt中使用特定版本
  • 如果需要,重新创建虚拟环境:./scripts/manage_plugin_venvs.sh remove PLUGIN_NAME && ./scripts/manage_plugin_venvs.sh create PLUGIN_NAME

构建错误:

  • 更改后重新编译:./scripts/compile.sh
  • 验证Python头文件是否已安装:sudo apt install python3-dev

限制

  • 每个虚拟环境会占用额外的磁盘空间
  • 启动时间稍长
  • 需要Python 3.3+以使用原生venv

技术架构

实现:

  1. plugin_config.h: 在结构中添加了venv_path字段
  2. plugin_config.c: 更新解析器以读取可选的第六个字段
  3. plugin_driver.c: 在导入插件之前设置sys.path的逻辑
  4. manage_plugin_venvs.sh: 完整的管理脚本

加载流程:

  1. 系统读取plugins.conf
  2. 如果指定了venv_path,则设置sys.path以包含虚拟环境的site-packages
  3. 导入插件的Python模块
  4. 照常执行init/start/stop/cleanup函数

该系统在需要时保持与现有插件的完全兼容性,同时实现依赖项隔离。

相关推荐
zone77391 天前
001:简单 RAG 入门
后端·python·面试
F_Quant1 天前
🚀 Python打包踩坑指南:彻底解决 Nuitka --onefile 配置文件丢失与重启报错问题
python·操作系统
允许部分打工人先富起来1 天前
在node项目中执行python脚本
前端·python·node.js
IVEN_1 天前
Python OpenCV: RGB三色识别的最佳工程实践
python·opencv
haosend1 天前
AI时代,传统网络运维人员的转型指南
python·数据网络·网络自动化
曲幽1 天前
不止于JWT:用FastAPI的Depends实现细粒度权限控制
python·fastapi·web·jwt·rbac·permission·depends·abac
blasit2 天前
笔记:Qt C++建立子线程做一个socket TCP常连接通信
c++·qt·tcp/ip
IVEN_2 天前
只会Python皮毛?深入理解这几点,轻松进阶全栈开发
python·全栈
Ray Liang2 天前
用六边形架构与整洁架构对比是伪命题?
java·python·c#·架构设计
AI攻城狮2 天前
如何给 AI Agent 做"断舍离":OpenClaw Session 自动清理实践
python