limubai的个人空间 https://blog.eetop.cn/?1716315 [收藏] [复制] [分享] [RSS]

日志

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

已有 33 次阅读| 2025-12-11 15:54 |系统分类:嵌入式| OCPP, 欧标充电桩, 充电桩, 嵌入式处理器, 米尔

随着全球电动汽车产业的迅猛发展,充电基础设施的智能化与标准化已成为行业迫切需求。OCPP(Open Charge Point Protocol即开放充电点协议)作为连接充电桩与中央管理系统的"通用语言",正成为解决设备互联互通难题的关键技术。


一、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通信维护、充电状态监控、远程控制指令下发等功能。

xmr@ubuntu:~/MicroOCPP$ wget  
xmr@ubuntu:~/MicroOCPP$ tar -xzvf steve-3.6.1.tar.gz
xmr@ubuntu:~/MicroOCPP$ cd steve-steve-3.6.1
xmr@ubuntu:~/MicroOCPP/steve-steve-3.6.1$ ls
docker-compose.yml k8s     LICENSE.txt  mvnw.cmd  README.md
Dockerfile LICENSE-HEADER.txt  mvnw   pom.xml  src   website


2、客户端部署关键步骤

MYD-YF13X平台部署MicroOcpp客户端的过程中,我们充分利用了平台提供的Linux 6.6.78系统环境。首先交叉编译MicroOcpp源码库,生成针对arm架构的优化可执行文件。随后配置GPIO引脚模拟充电枪连接状态:使用两个GPIO口分别代表两个充电接口的状态检测。

xmr@ubuntu:~$ mkdir MicroOCPP
xmr@ubuntu:~$ cd MicroOCPP
xmr@ubuntu:~/MicroOCPP$ git clone --recurse-submodules https://github.com/MYiR-Dev/Ocpp_Mongoose_demo.git -b myd-yf13x 
xmr@ubuntu:~/MicroOCPP$ cd Ocpp_Mongoose_demo
xmr@ubuntu:~/MicroOCPP/Ocpp_Mongoose_demo$ tree -L 2
├── CMakeLists.txt
├── external
│ ├── ArduinoJson
│ ├── MicroOcpp
│ ├── MicroOcppMongoose
│ └── mongoose
├── include
│ └── hardware.h
├── libs
└── src
├── hardware.c
└── main.c


3、服务端与客户端通信建立

部署完成后,客户端成功与SteVe服务器建立WebSocket连接:

root@myd-yf13x:~/Microocpp# export LD_LIBRARY_PATH=/home/root/Microocpp/lib
root@myd-yf13x:~/Microocpp# ./yf13x_ocpp_client &
oot@myd-yf13x:~/Microocpp# Starting MicroOcpp on STM32MP135P...
GPIO PC13 already exported.
GPIO PI7 already exported.
PC13 and PI7 simulate evse connecto
[MO] info (MicroOcpp.cpp:379): initialized MicroOcpp v1.2.0 running OCPP 1.6.0
OCPP client initialized. Entering main loop...
[MO] warning (MicroOcppMongooseClient.cpp:707): Insecure connection (WS)
[MO] info (MicroOcppMongooseClient.cpp:711): connection ws://192.168.40.187:8180/steve/websocket/CentralSystemService/stm32mp1-charger1 -- connected!
[MO] info (BootNotification.cpp:92): request has been Accepted
[MO] info (StatusNotification.cpp:52): New status: Available (connectorId 0)
[MO] info (StatusNotification.cpp:52): New status: Available (connectorId 1)
[MO] info (StatusNotification.cpp:52): New status: Available (connectorId 2)


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


4、状态上报功能验证

通过操作GPIO电平变化模拟充电枪插拔过程,我们观察到客户端实时向服务器上报状态变更。

root@myd-yf13x:~/Microocpp# echo 0 > /sys/class/gpio/PI7/value
root@myd-yf13x:~/Microocpp# [MO] info (StatusNotification.cpp:52): New status: Available (connectorId 2
root@myd-yf13x:~/Microocpp# echo 0 > /sys/class/gpio/PC13/value
root@myd-yf13x:~/Microocpp# [MO] info (StatusNotification.cpp:52): New status: Available (connectorId 1)


服务器界面同步更新连接器状态,证明整个通信链路工作正常。

充电枪可用状态

结语

随着全球充电桩市场标准化程度不断提高,OCPP协议支持已成为产品竞争力的关键要素。米尔基于MYC-YF13X平台提供的OCPP完整解决方案,不仅大幅降低了开发门槛,更确保了产品的标准符合性和市场适应性。



点赞

评论 (0 个评论)

facelist

您需要登录后才可以评论 登录 | 注册

  • 3

    周排名
  • 14

    月排名
  • 0

    总排名
  • 0

    关注
  • 1

    粉丝
  • 1

    好友
  • 1

    获赞
  • 1

    评论
  • 254

    访问数
关闭

站长推荐 上一条 /1 下一条


手机版| 小黑屋| 关于我们| 联系我们| 用户协议&隐私声明| 版权投诉通道| EETOP 创芯网
( 京ICP备:10050787号 京公网安备:11010502037710 ) |网站地图

GMT+8, 2025-12-13 16:47 , Processed in 0.013853 second(s), 7 queries , Gzip On, Redis On.

eetop公众号 创芯大讲堂 创芯人才网
返回顶部