当前位置: 首页 > news >正文

避坑指南:在Ubuntu for Raspberry上安装OpenPLC运行时,搞定WiringPi.h报错

避坑指南:在Ubuntu for Raspberry上安装OpenPLC运行时,搞定WiringPi.h报错

树莓派爱好者们常常喜欢尝试不同的操作系统,Ubuntu for Raspberry Pi凭借其稳定性和丰富的软件生态成为不少开发者的选择。然而,当你在树莓派上运行Ubuntu系统并尝试安装OpenPLC运行时,可能会遇到一个令人头疼的问题——编译过程中提示"WiringPi.h头文件缺失"。这个问题看似简单,却让不少开发者耗费数小时排查。本文将带你深入分析问题根源,并提供一套经过验证的解决方案。

1. 问题背景与诊断

OpenPLC作为一个开源PLC解决方案,其运行时环境需要与硬件底层交互,而WiringPi库正是实现树莓派GPIO控制的关键组件。当你在Raspberry Pi OS上安装OpenPLC时,一切都很顺利,因为官方系统对硬件支持最为完善。但在Ubuntu系统上,情况就变得复杂起来。

执行安装命令后,系统报错通常如下:

fatal error: wiringPi.h: No such file or directory

这个错误的本质在于:

  • Ubuntu的wiringpi软件包只包含运行时组件,不包含开发所需的头文件和静态库
  • OpenPLC的编译过程需要完整的开发环境支持
  • 官方安装脚本background_installer.sh假设系统会安装完整的wiringpi开发包

提示:这个问题不仅影响OpenPLC,任何需要访问树莓派GPIO的开发项目在Ubuntu系统上都可能遇到类似情况

2. 解决方案:手动编译安装WiringPi

既然系统仓库提供的软件包不完整,我们就需要从源码构建WiringPi。以下是经过验证的完整步骤:

2.1 准备工作

首先确保系统已安装必要的构建工具:

sudo apt update sudo apt install git build-essential

2.2 获取WiringPi源码

官方仓库已经归档,我们需要使用最终发布的2.50版本:

git clone --branch final_official_2.50 https://github.com/WiringPi/WiringPi.git cd WiringPi

2.3 编译与安装

WiringPi提供了简单的构建脚本:

./build

编译完成后,验证安装是否成功:

gpio -v

如果看到版本信息输出,说明安装成功。此时系统中应该已经包含以下关键文件:

  • /usr/local/include/wiringPi.h
  • /usr/local/lib/libwiringPi.so

3. 解决OpenPLC编译问题

完成WiringPi安装后,回到OpenPLC的安装目录,重新运行安装脚本:

cd ~/OpenPLC_v3 ./install.sh rpi

这次编译应该能够顺利完成。如果仍然遇到问题,可以尝试以下额外步骤:

3.1 检查链接库路径

确保系统能够找到新安装的库:

sudo ldconfig

3.2 验证头文件位置

确认wiringPi.h确实存在于标准包含路径中:

find /usr -name wiringPi.h

4. 系统配置优化

为了确保长期稳定性,建议进行以下系统级配置:

4.1 固定WiringPi版本

防止后续系统更新覆盖手动安装的版本:

sudo apt-mark hold wiringpi

4.2 环境变量设置

在某些情况下,可能需要明确指定库路径:

export LD_LIBRARY_PATH=/usr/local/lib:$LD_LIBRARY_PATH

可以将这行添加到~/.bashrc文件中实现永久生效。

5. 替代方案评估

如果手动编译WiringPi仍然无法解决问题,可以考虑以下替代方案:

5.1 使用pigpio库

pigpio是另一个流行的GPIO访问库,OpenPLC也支持:

sudo apt install pigpio

然后在OpenPLC硬件设置中选择"Raspberry Pi (pigpio)"选项。

5.2 容器化部署

考虑使用Docker容器来隔离环境依赖:

docker run -d --privileged --name openplc -p 8080:8080 thiagoralves/openplc-raspberry

这种方法避免了系统库冲突问题,但牺牲了一些性能。

6. 深度技术解析

理解这个问题的本质有助于预防类似情况。Ubuntu for Raspberry Pi与Raspberry Pi OS的主要差异在于:

特性Raspberry Pi OSUbuntu for Raspberry Pi
内核优化专为树莓派优化通用ARM优化
硬件支持完整GPIO支持基础GPIO支持
软件仓库包含树莓派专用包标准Ubuntu仓库
更新策略跟随树莓派硬件跟随Ubuntu发布周期

这种差异导致了一些树莓派专用软件在Ubuntu上需要额外配置才能正常工作。

7. 实际应用测试

完成安装后,建议运行一个简单的测试程序验证功能是否正常:

  1. 在OpenPLC Editor中创建一个新项目
  2. 添加一个简单的梯形图逻辑,例如:
    • 当输入0.0为高电平时,输出0.0也为高电平
  3. 将程序上传到运行时
  4. 使用GPIO命令手动控制输入引脚:
    gpio mode 0 in gpio mode 2 out gpio write 2 1 # 模拟输入信号
  5. 观察输出引脚状态变化

这种端到端的验证可以确保整个软件栈工作正常。

8. 性能调优建议

在Ubuntu系统上运行OpenPLC可能会遇到性能问题,以下调优措施值得尝试:

  • 关闭不必要的系统服务:

    sudo systemctl disable --now snapd.service sudo systemctl disable --now apt-daily-upgrade.timer
  • 调整CPU调度策略:

    echo performance | sudo tee /sys/devices/system/cpu/cpu*/cpufreq/scaling_governor
  • 增加交换空间(针对内存不足情况):

    sudo fallocate -l 1G /swapfile sudo chmod 600 /swapfile sudo mkswap /swapfile sudo swapon /swapfile

9. 长期维护策略

为了确保系统长期稳定运行,建议:

  • 定期检查WiringPi库更新

  • 备份关键配置文件:

    sudo tar czvf openplc_backup.tar.gz /usr/local/lib/libwiring* /usr/local/include/wiring*
  • 监控系统日志中的GPIO相关错误:

    journalctl -u openplc -f

10. 社区资源利用

遇到难以解决的问题时,可以求助于以下资源:

  • OpenPLC官方论坛:https://openplc.discussion.community/
  • WiringPi GitHub仓库的Issues页面
  • 树莓派Ubuntu社区论坛

在寻求帮助时,提供以下信息会大大提高解决效率:

  • 完整的错误日志
  • gpio -v输出
  • uname -a输出
  • OpenPLC版本信息

我在多个树莓派项目中使用这套解决方案,发现最关键的还是确保开发环境的一致性。建议团队开发时建立标准化的环境配置文档,避免每个成员都踩同样的坑。

http://www.jsqmd.com/news/696621/

相关文章:

  • 影墨·今颜FLUX.1-dev部署避坑指南:CUDA版本/驱动/PyTorch匹配
  • cuBLASLt动态切分策略失效?揭秘CUDA 13.1+Triton混合部署下batch size=1时的$0.83/千token隐性溢价
  • 网络工程师转行能干什么_网络工程师转行选择建议(非常详细)收藏这篇就够了_网络工程师不同岗位
  • PKIX path building failed: sun.security.provider.certpath.SunCertPathBuilderException
  • 408考研避坑指南:我踩过的那些“弯路”(教材、网课、题海战术)
  • 2026赤芍苗批发基地靠谱榜:天冬苗批发/天麻苗批发基地/射干苗批发/枳壳苗批发/桔梗苗批发/毛慈菇苗批发/淫羊藿苗批发/选择指南 - 优质品牌商家
  • 蓝桥杯I2C实战:EEPROM数据持久化与PCF8591信号转换
  • 【26年最新】英语四六级高频核心词汇1500个+历年真题PDF电子版
  • 2026成都工业风机厂家名录:成都耐高温风机厂家、成都轴流风机厂家、成都防腐风机厂家、成都隧道风机厂家、成都风机厂家选择指南 - 优质品牌商家
  • Mac窗口置顶终极指南:5分钟掌握Topit提升你的工作效率
  • HPH核心构造详解:三大系统一图看懂
  • 怎样通过Navicat高效导出ER模型为PDF文档_大幅提升绘制效率
  • 自动驾驶定位实战:从GICP到VGICP,手把手教你用PCL实现点云匹配(附避坑指南)
  • G-Helper终极指南:释放华硕笔记本隐藏性能的简单秘诀
  • AI赋能新药研发!化合物虚拟筛选春日特惠3天极速交付
  • Windows Server 2019上搞定Connectify Dispatch网卡聚合,保姆级避坑指南
  • 别再用Oligo6了!试试这3个免费的在线PCR引物设计工具,小白也能搞定
  • 智能计算中的资源分配与任务调度
  • 手把手教你用STM32CubeMX配置TM7711高精度ADC(附完整代码与电平转换电路详解)
  • Fairseq-Dense-13B-Janeway部署案例:基于CUDA 12.4+PyTorch 2.5.0的高性能推理环境搭建
  • 智慧农业茶叶嫩芽检测数据集VOC+YOLO格式3288张1类别有增强100
  • 别再只会wsl -l -v了!这10个WSL2实用命令,帮你搞定开发环境迁移与备份
  • 2026成都货物托运公司可靠指南:专线托运/大件托运/大件物流/工具物流托运/成都发省外物流/成都托运物流/成都物流公司/选择指南 - 优质品牌商家
  • 2026防微振基座施工技术解析:FAB厂二次配、光伏厂二次配、半导体二次配工程、厂区配电工程、厂房二次配施工、机电二次配选择指南 - 优质品牌商家
  • LLM大语言模型(九):从BAAI/bge-large-zh-v1.5看Embedding模型如何优化ChatGLM3-6B的语义理解与检索
  • 性能优化-MySQL索引
  • Excel打开密码怎么取消?两种方法教你快速移除工作簿密码
  • 3步完成Tabletop Simulator数据保护:TTS-Backup终极指南
  • 从《我的第一份工作》看技术面试:如何避免踩中那些‘令人沮丧的旅程’和‘最后一根稻草’
  • 2026川内中央空调回收厂家靠谱推荐榜:电力变压器回收、箱式变压器回收、中央空调回收价格、变压器回收价格、变压器回收报价选择指南 - 优质品牌商家