DC3是基于Spring Cloud的开源可分布式物联网(IOT)平台,用于快速开发、部署物联设备接入项目,是一整套物联系统解决方案。
IOT DC3 is an open source, distributed Internet of Things (IOT) platform based on Spring Cloud. It is used for rapid development of IOT projects and management of IOT devices. It is a set of solutions for IOT system.
GitHub:https://github.com/pnoker/iot-dc3
码云:https://gitee.com/pnoker/iot-dc3
- 设备微服务层:用于提供标准或者私有协议连接物理设备的SDK;
- 核心微服务层:用于提供微服务注册中心、配置管理中心、设备指令接口、设备注册与关联配对、数据管理中心,是所有微服务交互的核心部分;
- 支持微服务层:用于提供规则引擎、任务调度、报警与消息通知、日志管理、数据清理;
- 开放微服务层:用于提供数据开放等服务...
- 跨平台分布式、多设备、多协议(目前支持Mqtt\Rtsp\Rtmp\Http\Plc-S7\Opc\Opc-Ua\自定义Tcp\自定义Socket\数据报文解析);
- 物联设备数据采集、边缘处理、数据持久化、数据缓存、全文搜索、功能性微服务调用;
- 物联设备端代码一键生成,快速安全的接入设备和物联设备管理(目前支持Java);
- 安全权限控制、数据支持对称和非对称加密(目前支持AES\RSA);
- 物联设备远程指令透传、监控和控制;
- 对外开放数据接口及微服务接口;
- 支持网关端和云端部署;
- 低功耗运行;
- 容器化。
- 可伸缩:水平可伸缩的平台,构建使用领先的Spring Cloud开源技术;
- 容错:没有单点故障弱,集群中的每个节点是相同的;
- 健壮和高效:单一服务器节点可以处理甚至数百成千上万的设备根据用例;
- 可定制:添加新的设备协议,并注册到服务中心;
- 跨平台:使用Java环境可异地、分布式多平台部署;
- 完善性:设备快速接入、注册、权限校验;
- 安全:数据加密传输;
- Docker:容器化。
DC3平台是基于Spring Cloud架构开发的,是一系列松耦合、开源的微服务集合。 微服务集合由4个微服务层和两个增强的基础系统服务组成,提供从物理域数据采集到信息域数据处理等一系列的服务。
Spring Cloud Netflix
、Spring Cloud Gateway
、Spring Cloud Security
、Spring Cloud OpenFeign
、Spring Cloud Config
、Spring Cloud Bus
等微服务模块。
(平台功能正在逐步完善中...)
iot-dc3
├── dc3-web -- 基于Vue3.0的前端工程
├── dc3-api -- 已于Spring Cloud OpenFeign的声明式接口
├── dc3-common -- 系统公共模块
├── dc3-gateway -- Spring Cloud Gateway网关[8000]
└── dc3-center -- 平台中心模块集合
├── dc3-register -- 服务注册与发现中心[8100]
├── dc3-monitor -- 服务监控中心[8200]
├── dc3-dbs -- 数据服务中心[8300]
├── dc3-auth -- 授权管理中心[8400]
└── dc3-collect -- 数据采集中心[8500]
└── dc3-device -- 设备服务集合
├── dc3-manager -- 设备管理[8600]
└── dc3-group -- 设备组管理与数据接入[8700]
└── dc3-transfer -- 数据交换&协议模块集合
├── dc3-opc -- Opc Server[8810]
├── dc3-opc-ua -- Opc Ua Server[8820]
├── dc3-rtmp -- Rtsp转Rtmp服务[8830]
└── dc3-resource -- 文件资源服务器[8840]
可运行镜像集合:IOT DC3 Docker Hub Repositories
依赖 | 版本 |
---|---|
Spring Boot | 2.1.6.RELEASE |
Spring Cloud | Greenwich.SR1 |
Spring Security OAuth2 | 2.3.5 |
Mybatis Plus | 3.1.0 |
Vue | 3.0 |
感谢:lombok
、netty
、spring boot
、spring cloud
、s7connector
等提供的工具以及源码
- Fork项目到自己的repo
- clone到本地
- 修改代码(dev分支)
- commit后push到自己的库(dev分支)
- pull request
- 等待作者合并
# Git强制覆盖本地
git fetch --all && git reset --hard origin/master && git pull
# Maven操作
mvn clean package
# Yarn 操作
# 安装项目全部依赖
yarn
# 添加|更新|删除依赖
yarn add|upgrade|remove [package]
# 启动项目
yarn run [script] [<args>]
# Docker操作命令
# list
docker images
# build
docker build -t pnoker/dc3-dbs:3.0 .
# delete
docker rmi -f pnoker/dc3-dbs:3.0
# run
docker run -d -p 80:8080 --name dc3-dbs -h iotdc3.dbs --link dc3-register:iotdc3.register pnoker/dc3-dbs:3.0
# stop/start/restart
docker start|start|restart pnoker/dc3-dbs:3.0
# exec
docker exec -i -t pnoker/dc3-dbs:3.0 /bin/bash