嵌入式技术论坛
直播中

飞洋

7年用户 404经验值
擅长:处理器/DSP
私信 关注

米尔OCPP协议实战开发指南,赋能欧标充电桩市场

本帖最后由 blingbling111 于 2025-12-11 17:36 编辑

随着全球电动汽车产业的迅猛发展,充电基础设施的智能化与标准化已成为行业迫切需求。OCPP(Open Charge Point Protocol即开放充电点协议)作为连接充电桩与中央管理系统的"通用语言",正成为解决设备互联互通难题的关键技术。
2.png
一、OCPP:为何是出海欧标的必选项?OCPP是一个开放、标准的通信协议,它确保了不同制造商生产的充电桩能够与任何兼容的后台管理系统进行无缝通信。集成OCPP协议意味着为产品赋予“标准通信接口”,其核心价值在于:

  • 打破互联壁垒:使充电桩能接入任何符合OCPP标准的第三方运营平台,提升产品适配性;
  • 满足法规要求:满足欧盟对充电设施互操作性的强制法规,是市场准入的前提;
  • 解锁智能功能:支持远程控制、充电计费、状态监控与固件OTA,大幅减少上层应用开发量;
  • 降低集成成本:采用广泛认可的协议栈,避免私有协议带来的定制开发和长期维护成本。


二、MicroOcpp:专为嵌入式设备优化的轻量级方案针对资源受限的嵌入式环境,MicroOcpp提供了理想的OCPP协议栈实现,其主要优势包括:

  • 极低资源占用:采用C/C++编写,专为微控制器和嵌入式Linux优化;
  • 全面协议支持:完整兼容OCPP 1.6,并支持升级至2.0.1;
  • 模块化设计:可仅编译所需功能,最大化利用硬件资源;
  • 开发友好:提供清晰的API接口与丰富的示例,集成门槛低。

三、部署实践:从零构建OCPP通信系统1、服务端环境搭建使用Docker容器快速部署SteVe OCPP服务器,SteVe作为开源中央管理系统,提供了完整的充电桩管理能力,包括WebSocket通信维护、充电状态监控、远程控制指令下发等功能。
  1. xmr@ubuntu:~/MicroOCPP$ wget  
  2. xmr@ubuntu:~/MicroOCPP$ tar -xzvf steve-3.6.1.tar.gz
  3. xmr@ubuntu:~/MicroOCPP$ cd steve-steve-3.6.1
  4. xmr@ubuntu:~/MicroOCPP/steve-steve-3.6.1$ ls
  5. docker-compose.yml k8s     LICENSE.txt  mvnw.cmd  README.md
  6. Dockerfile LICENSE-HEADER.txt  mvnw   pom.xml  src   website
2、客户端部署关键步骤在MYD-YF13X平台部署MicroOcpp客户端的过程中,我们充分利用了平台提供的Linux 6.6.78系统环境。首先交叉编译MicroOcpp源码库,生成针对ARM架构的优化可执行文件。随后配置GPIO引脚模拟充电枪连接状态:使用两个GPIO口分别代表两个充电接口的状态检测。
  1. xmr@ubuntu:~$ mkdir MicroOCPP
  2. xmr@ubuntu:~$ cd MicroOCPP
  3. xmr@ubuntu:~/MicroOCPP$ git clone --recurse-submodules https://github.com/MYiR-Dev/Ocpp_Mongoose_demo.git -b myd-yf13x
  4. xmr@ubuntu:~/MicroOCPP$ cd Ocpp_Mongoose_demo
  5. xmr@ubuntu:~/MicroOCPP/Ocpp_Mongoose_demo$ tree -L 2
  6. ├── CMakeLists.txt
  7. ├── external
  8. │ ├── ArduinoJson
  9. │ ├── MicroOcpp
  10. │ ├── MicroOcppMongoose
  11. │ └── mongoose
  12. ├── include
  13. │ └── hardware.h
  14. ├── libs
  15. └── src
  16. ├── hardware.c
  17. └── main.c

3、服务端与客户端通信建立部署完成后,客户端成功与SteVe服务器建立WebSocket连接:
  1. root@myd-yf13x:~/Microocpp# export LD_LIBRARY_PATH=/home/root/Microocpp/lib
  2. root@myd-yf13x:~/Microocpp# ./yf13x_ocpp_client &
  3. oot@myd-yf13x:~/Microocpp# Starting MicroOcpp on STM32MP135P...
  4. GPIO PC13 already exported.
  5. GPIO PI7 already exported.
  6. PC13 and PI7 simulate evse connecto
  7. [MO] info (MicroOcpp.cpp:379): initialized MicroOcpp v1.2.0 running OCPP 1.6.0
  8. OCPP client initialized. Entering main loop...
  9. [MO] warning (MicroOcppMongooseClient.cpp:707): Insecure connection (WS)
  10. [MO] info (MicroOcppMongooseClient.cpp:711): connection ws://192.168.40.187:8180/steve/websocket/CentralSystemService/stm32mp1-charger1 -- connected!
  11. [MO] info (BootNotification.cpp:92): request has been Accepted
  12. [MO] info (StatusNotification.cpp:52): New status: Available (connectorId 0)
  13. [MO] info (StatusNotification.cpp:52): New status: Available (connectorId 1)
  14. [MO] info (StatusNotification.cpp:52): New status: Available (connectorId 2)

服务端管理界面将实时显示新上线的充电桩,证明底层链路与协议交互正常。

3.png

4、状态上报功能验证通过操作GPIO电平变化模拟充电枪插拔过程,我们观察到客户端实时向服务器上报状态变更。
  1. root@myd-yf13x:~/Microocpp# echo 0 > /sys/class/gpio/PI7/value
  2. root@myd-yf13x:~/Microocpp# [MO] info (StatusNotification.cpp:52): New status: Available (connectorId 2
  3. root@myd-yf13x:~/Microocpp# echo 0 > /sys/class/gpio/PC13/value
  4. root@myd-yf13x:~/Microocpp# [MO] info (StatusNotification.cpp:52): New status: Available (connectorId 1)
服务器界面同步更新连接器状态,证明整个通信链路工作正常。
4.png
充电枪可用状态
结语随着全球充电桩市场标准化程度不断提高,OCPP协议支持已成为产品竞争力的关键要素。米尔基于MYC-YF13X平台提供的OCPP完整解决方案,不仅大幅降低了开发门槛,更确保了产品的标准符合性和市场适应性。
  • 4.png
  • 3.png
  • 2.png

更多回帖

发帖
×
20
完善资料,
赚取积分