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

STM32F103用IO口模拟SPI驱动CH376读写U盘,保姆级移植教程(附完整源码)

STM32F103通过IO模拟SPI驱动CH376实现U盘文件读写的实战指南在嵌入式系统开发中经常需要实现数据存储功能。对于STM32这类资源有限的微控制器而言直接操作U盘进行文件读写是一个极具实用价值的技术方案。本文将详细介绍如何利用STM32F103的普通IO口模拟SPI接口驱动沁恒CH376芯片完成U盘文件操作的全过程。1. 硬件与开发环境搭建1.1 所需硬件组件实现这一功能需要准备以下硬件STM32F103开发板作为主控制器建议使用最小系统板或常见的开发板如正点原子/野火系列CH376模块市面上常见的CH376模块通常已集成必要的外围电路USB转TTL模块用于调试信息输出如CH340U盘建议使用FAT32格式的小容量U盘≤32GB杜邦线用于各模块间的连接1.2 硬件连接示意图CH376与STM32的SPI接口连接方式如下STM32引脚CH376引脚功能说明PB12SCS片选信号PB13SCK时钟信号PB14SDO数据输出PB15SDI数据输入PB10INT中断信号注意实际连接时需确认模块的具体引脚定义不同厂家的模块可能略有差异1.3 开发环境准备IDE选择Keil MDK-ARM推荐IAR Embedded WorkbenchSTM32CubeIDE驱动库标准外设库SPLHAL库本文示例基于HAL调试工具ST-Link/V2调试器串口调试助手如SecureCRT2. 软件资源获取与工程建立2.1 官方资源下载从沁恒官网获取CH376开发包访问沁恒下载中心搜索并下载CH376EVT_ZIP压缩包解压后主要关注以下文件EXAM/包含各种操作示例CH376编程指南.PDF移植参考文档FILE_SYS.H和FILE_SYS.C文件系统接口2.2 工程文件组织建议按以下结构组织工程目录Project/ ├── Core/ ├── Drivers/ ├── CH376/ │ ├── Inc/ │ │ ├── HAL.H │ │ ├── FILE_SYS.H │ │ └── DEBUG.H │ └── Src/ │ ├── HAL_BASE.C │ ├── FILE_SYS.C │ ├── DEBUG.C │ └── PARA_HW.C └── ...2.3 关键文件筛选从官方示例中需要提取以下核心文件硬件抽象层HAL.H硬件接口定义HAL_BASE.C基础函数实现文件系统接口FILE_SYS.H文件操作API声明FILE_SYS.C文件操作实现调试支持DEBUG.H调试宏定义DEBUG.C调试函数实现3. 底层驱动移植与实现3.1 GPIO模拟SPI时序实现CH376支持硬件SPI和软件模拟SPI两种方式。当STM32的硬件SPI资源紧张时使用GPIO模拟更为灵活/* 模拟SPI相关宏定义 */ #define CH376_CS_GPIO_PORT GPIOB #define CH376_CS_PIN GPIO_PIN_12 #define CH376_SCK_GPIO_PORT GPIOB #define CH376_SCK_PIN GPIO_PIN_13 #define CH376_MOSI_GPIO_PORT GPIOB #define CH376_MOSI_PIN GPIO_PIN_15 #define CH376_MISO_GPIO_PORT GPIOB #define CH376_MISO_PIN GPIO_PIN_14 /* 片选控制宏 */ #define CH376_CS_LOW() HAL_GPIO_WritePin(CH376_CS_GPIO_PORT, CH376_CS_PIN, GPIO_PIN_RESET) #define CH376_CS_HIGH() HAL_GPIO_WritePin(CH376_CS_GPIO_PORT, CH376_CS_PIN, GPIO_PIN_SET) /* SPI写一个字节 */ void Spi376OutByte(uint8_t data) { for(uint8_t i 0; i 8; i) { HAL_GPIO_WritePin(CH376_SCK_GPIO_PORT, CH376_SCK_PIN, GPIO_PIN_RESET); HAL_GPIO_WritePin(CH376_MOSI_GPIO_PORT, CH376_MOSI_PIN, (data 0x80) ? GPIO_PIN_SET : GPIO_PIN_RESET); data 1; HAL_GPIO_WritePin(CH376_SCK_GPIO_PORT, CH376_SCK_PIN, GPIO_PIN_SET); } } /* SPI读一个字节 */ uint8_t Spi376InByte(void) { uint8_t data 0; for(uint8_t i 0; i 8; i) { HAL_GPIO_WritePin(CH376_SCK_GPIO_PORT, CH376_SCK_PIN, GPIO_PIN_RESET); data 1; if(HAL_GPIO_ReadPin(CH376_MISO_GPIO_PORT, CH376_MISO_PIN) GPIO_PIN_SET) { data | 0x01; } HAL_GPIO_WritePin(CH376_SCK_GPIO_PORT, CH376_SCK_PIN, GPIO_PIN_SET); } return data; }3.2 CH376基础通信函数移植CH376的操作基于四个核心函数需要根据STM32平台进行适配/* 写命令到CH376 */ void xWriteCH376Cmd(uint8_t cmd) { CH376_CS_LOW(); Spi376OutByte(cmd); HAL_Delay(1); // 适当延时确保时序 } /* 写数据到CH376 */ void xWriteCH376Data(uint8_t data) { Spi376OutByte(data); HAL_Delay(1); } /* 从CH376读取数据 */ uint8_t xReadCH376Data(void) { CH376_CS_LOW(); uint8_t data Spi376InByte(); HAL_Delay(1); return data; } /* 查询中断状态 */ uint8_t Query376Interrupt(void) { return (HAL_GPIO_ReadPin(GPIOB, GPIO_PIN_10) GPIO_PIN_RESET) ? 1 : 0; }3.3 初始化流程实现完整的CH376初始化应包括以下步骤GPIO初始化void CH376_GPIO_Init(void) { GPIO_InitTypeDef GPIO_InitStruct {0}; __HAL_RCC_GPIOB_CLK_ENABLE(); /* SPI引脚配置 */ GPIO_InitStruct.Pin CH376_CS_PIN | CH376_SCK_PIN | CH376_MOSI_PIN; GPIO_InitStruct.Mode GPIO_MODE_OUTPUT_PP; GPIO_InitStruct.Pull GPIO_NOPULL; GPIO_InitStruct.Speed GPIO_SPEED_FREQ_HIGH; HAL_GPIO_Init(GPIOB, GPIO_InitStruct); /* MISO引脚配置 */ GPIO_InitStruct.Pin CH376_MISO_PIN; GPIO_InitStruct.Mode GPIO_MODE_INPUT; HAL_GPIO_Init(GPIOB, GPIO_InitStruct); /* 中断引脚配置 */ GPIO_InitStruct.Pin GPIO_PIN_10; GPIO_InitStruct.Mode GPIO_MODE_INPUT; GPIO_InitStruct.Pull GPIO_PULLUP; HAL_GPIO_Init(GPIOB, GPIO_InitStruct); CH376_CS_HIGH(); }CH376硬件初始化uint8_t CH376_HardwareInit(void) { CH376_GPIO_Init(); /* 设置工作模式为USB主机 */ xWriteCH376Cmd(CMD_SET_USB_MODE); xWriteCH376Data(0x06); // 模式6USB主机模式 HAL_Delay(20); /* 检查芯片是否就绪 */ if(Query376Interrupt()) { uint8_t status xReadCH376Data(); if(status USB_INT_SUCCESS) { return 0; // 初始化成功 } } return 1; // 初始化失败 }4. 文件系统操作实战4.1 U盘检测与挂载在操作文件前需要先检测U盘并挂载文件系统uint8_t CheckUDisk(void) { uint8_t status; uint8_t retry 0; /* 检查U盘连接 */ while((status CH376DiskConnect()) ! USB_INT_SUCCESS) { if(retry 20) return 1; // 超时 HAL_Delay(100); } /* 挂载磁盘 */ retry 0; while((status CH376DiskMount()) ! USB_INT_SUCCESS) { if(retry 10) return 2; // 挂载失败 HAL_Delay(50); } return 0; // 成功 }4.2 文件创建与写入以下示例演示如何创建文件并写入数据void WriteToFileDemo(void) { uint8_t status; uint16_t bytesWritten; const uint8_t testData[] STM32 CH376 U盘读写测试数据\r\n; /* 创建文件 */ status CH376FileCreate(/TEST.TXT); if(status ! USB_INT_SUCCESS) { printf(文件创建失败: %02X\r\n, status); return; } /* 写入数据 */ status CH376ByteWrite(testData, sizeof(testData)-1, bytesWritten); if(status ! USB_INT_SUCCESS) { printf(写入失败: %02X\r\n, status); return; } /* 关闭文件 */ status CH376FileClose(TRUE); // TRUE表示保存修改 if(status ! USB_INT_SUCCESS) { printf(文件关闭失败: %02X\r\n, status); return; } printf(文件写入成功写入字节数: %d\r\n, bytesWritten); }4.3 文件读取操作读取文件内容的实现示例void ReadFileDemo(void) { uint8_t status; uint8_t buffer[128]; uint16_t bytesRead; /* 打开文件 */ status CH376FileOpen(/TEST.TXT); if(status ! USB_INT_SUCCESS) { printf(文件打开失败: %02X\r\n, status); return; } /* 定位到文件开头 */ CH376ByteLocate(0); /* 读取文件内容 */ status CH376ByteRead(buffer, sizeof(buffer), bytesRead); if(status ! USB_INT_SUCCESS) { printf(读取失败: %02X\r\n, status); return; } /* 关闭文件 */ CH376FileClose(FALSE); /* 输出读取内容 */ printf(读取到%d字节数据:\r\n, bytesRead); for(uint16_t i 0; i bytesRead; i) { printf(%c, buffer[i]); } printf(\r\n); }4.4 目录操作示例CH376也支持基本的目录操作void DirectoryDemo(void) { uint8_t status; /* 创建目录 */ status CH376DirCreate(/DATA); if(status ! USB_INT_SUCCESS) { printf(目录创建失败: %02X\r\n, status); return; } /* 打开目录 */ status CH376DirOpen(/DATA); if(status ! USB_INT_SUCCESS) { printf(目录打开失败: %02X\r\n, status); return; } /* 这里可以执行目录下的文件操作 */ /* 关闭目录 */ CH376DirClose(); }5. 常见问题与调试技巧5.1 典型错误排查在实际开发中可能会遇到以下问题U盘无法识别检查硬件连接是否正确确认U盘格式为FAT32尝试不同的U盘某些U盘兼容性较差文件操作失败确保路径格式正确以/开头检查文件是否已存在创建时或不存在打开时确认U盘没有写保护数据传输错误检查SPI时序是否符合要求适当增加操作间的延时确保电源稳定U盘需要足够的电流5.2 调试建议利用串口输出调试信息printf(CH376状态: %02X\r\n, CH376GetVer());分阶段验证先验证SPI通信是否正常再测试U盘检测功能最后实现文件操作使用逻辑分析仪捕捉SPI波形确认时序正确检查命令和数据传输是否符合预期5.3 性能优化技巧减少延时在确保稳定的前提下尽可能减少操作间的延时使用硬件SPI可以显著提高速度批量操作对大文件操作时使用多扇区读写命令合理设置缓冲区大小中断方式使用CH376的中断引脚而非轮询方式减少CPU占用率6. 进阶应用与扩展6.1 多文件操作管理在实际项目中可能需要同时管理多个文件void MultiFileDemo(void) { /* 打开第一个文件 */ CH376FileOpen(/CONFIG.INI); /* 保存文件句柄 */ uint8_t hFile1 CH376GetHandle(); /* 打开第二个文件 */ CH376FileOpen(/DATA.TXT); /* 在两个文件间切换操作 */ CH376SetHandle(hFile1); /* 操作第一个文件 */ CH376SetHandle(CH376GetHandle()); /* 操作第二个文件 */ /* 关闭所有文件 */ CH376FileClose(TRUE); CH376SetHandle(hFile1); CH376FileClose(TRUE); }6.2 文件属性操作获取和设置文件属性void FileAttrDemo(void) { uint8_t attr; /* 获取文件属性 */ CH376FileOpen(/TEST.TXT); CH376GetFileAttr(attr); printf(文件属性: %02X\r\n, attr); /* 设置文件为只读 */ attr | ATTR_READ_ONLY; CH376SetFileAttr(attr); CH376FileClose(TRUE); }6.3 大文件分块处理对于大文件应采用分块处理策略void LargeFileProcess(const char* filename, uint32_t fileSize) { #define BLOCK_SIZE 512 uint8_t buffer[BLOCK_SIZE]; uint32_t processed 0; CH376FileCreate(filename); while(processed fileSize) { uint16_t chunk (fileSize - processed) BLOCK_SIZE ? BLOCK_SIZE : (fileSize - processed); /* 这里填充或处理数据 */ // PrepareData(buffer, chunk); uint16_t written; CH376ByteWrite(buffer, chunk, written); processed written; } CH376FileClose(TRUE); }在实际项目中CH376的U盘操作功能可以广泛应用于数据采集、配置存储、固件升级等场景。通过合理的代码组织和优化可以在资源有限的STM32平台上实现稳定可靠的文件存储解决方案。

相关文章:

STM32F103用IO口模拟SPI驱动CH376读写U盘,保姆级移植教程(附完整源码)

STM32F103通过IO模拟SPI驱动CH376实现U盘文件读写的实战指南 在嵌入式系统开发中,经常需要实现数据存储功能。对于STM32这类资源有限的微控制器而言,直接操作U盘进行文件读写是一个极具实用价值的技术方案。本文将详细介绍如何利用STM32F103的普通IO口模…...

AutoSAR PNC实战:手把手教你配置一个省电的‘局部唤醒’网络(基于AUTOSAR 4.0.3+)

AutoSAR PNC实战:手把手教你配置一个省电的‘局部唤醒’网络(基于AUTOSAR 4.0.3) 在车载电子系统日益复杂的今天,如何平衡功能丰富性与能耗效率成为工程师面临的核心挑战。想象一下,当车辆熄火停放时,信息娱…...

FATFS文件操作避坑指南:如何优雅地实现CSV日志的持续记录?

FATFS文件操作避坑指南:如何优雅地实现CSV日志的持续记录? 在物联网设备和嵌入式系统中,持续记录传感器数据或系统日志是常见需求。使用FATFS文件系统在SD卡上存储CSV格式数据看似简单,但实际开发中会遇到文件损坏、数据丢失、性能…...

告别SourceForge:用GitHub源码在Ubuntu 22.04上快速搭建CanFestival开发环境

告别SourceForge:用GitHub源码在Ubuntu 22.04上快速搭建CanFestival开发环境 在开源硬件通信领域,CanFestival作为轻量级CANopen协议栈实现,一直是工业自动化、嵌入式设备开发者的首选工具。传统安装指南往往推荐从SourceForge下载稳定版压缩…...

从GPS定位到机器人导航:一文讲透ROS中坐标系转换(WGS-84/UTM/ENU)的底层逻辑与实战

从GPS定位到机器人导航:一文讲透ROS中坐标系转换(WGS-84/UTM/ENU)的底层逻辑与实战 当你在机器人项目中第一次看到GPS数据在ROS中飘忽不定时,是否曾困惑于如何将这些经纬度数字变成机器人能理解的导航指令?坐标系转换就…...

终极免费屏幕标注工具ppInk:5分钟掌握Windows最强注释神器

终极免费屏幕标注工具ppInk:5分钟掌握Windows最强注释神器 【免费下载链接】ppInk Fork from Gink 项目地址: https://gitcode.com/gh_mirrors/pp/ppInk 你是否曾在在线会议、教学演示或产品展示中,因为找不到合适的屏幕标注工具而手忙脚乱&#…...

别再死磕Two-Stream了!用PyTorch从零实现一个轻量级C3D模型(附Kinetics数据集实战)

用PyTorch打造轻量级C3D模型:Kinetics数据集实战指南 在视频理解领域,动作识别一直是开发者们关注的焦点。传统Two-Stream方法虽然精度可观,但其复杂的双流结构和光流计算成本让许多实际项目望而却步。今天我们将用PyTorch实现一个更高效的解…...

WarcraftHelper:解决魔兽争霸III现代化运行难题的完整技术方案

WarcraftHelper:解决魔兽争霸III现代化运行难题的完整技术方案 【免费下载链接】WarcraftHelper Warcraft III Helper , support 1.20e, 1.24e, 1.26a, 1.27a, 1.27b 项目地址: https://gitcode.com/gh_mirrors/wa/WarcraftHelper WarcraftHelper是一款专为魔…...

【Linux从入门到精通】第16篇:计划任务——让机器在半夜自动干活主要内容:crontab 语法格式详解(分时日月周);at 命令执行一次性任务;日志轮替(Logrotate)原理简述。

目录 一、引言:凌晨3点,谁在替你工作? 二、crontab:周期性任务的王者 2.1 crontab是什么? 2.2 基础命令 2.3 语法格式:分时日月周 2.4 实战示例 2.5 新手最容易踩的三个坑 2.6 排查crontab问题的方法…...

2026最权威的五大降AI率工具实测分析

Ai论文网站排名(开题报告、文献综述、降aigc率、降重综合对比) TOP1. 千笔AI TOP2. aipasspaper TOP3. 清北论文 TOP4. 豆包 TOP5. kimi TOP6. deepseek 把AIGC率予以降低的关键要点包含于对人类写作所具备的随机性以及逻辑方面那些瑕疵加以模仿之…...

告别Qt Creator,在VS2019里丝滑开发Qt5.14.2项目:保姆级插件配置与项目迁移指南

在VS2019中高效开发Qt5.14.2项目的终极指南 对于习惯使用Visual Studio的C开发者来说,Qt Creator虽然功能完善,但总有些不够顺手。本文将带你彻底摆脱Qt Creator的束缚,在熟悉的VS2019环境中实现Qt项目的无缝开发和调试。 1. 环境准备与工具配…...

计算机毕业设计:Python基金列表搜索详情与多只基金收益对比系统 Django框架 数据分析 可视化 爬虫 大数据 大模型(建议收藏)✅

博主介绍:✌全网粉丝50W,前互联网大厂软件研发、集结硕博英豪成立工作室。专注于计算机相关专业项目实战8年之久,选择我们就是选择放心、选择安心毕业✌ > 🍅想要获取完整文章或者源码,或者代做,拉到文章底部即可与…...

内存计算架构建模与仿真技术解析

1. 内存计算架构的建模与仿真技术全景 在传统冯诺依曼架构中,数据需要在处理器和内存之间频繁移动,这已成为制约计算系统性能提升的主要瓶颈。内存计算(Processing-in-Memory, PIM)技术通过将计算单元直接嵌入内存层级&#xff0c…...

Helix 511工业级无风扇嵌入式计算机详解

1. Helix 511工业级无风扇嵌入式计算机概述在工业自动化和边缘计算领域,设备需要具备稳定、可靠且适应恶劣环境的特性。OnLogic推出的Helix 511正是为这类场景设计的工业级无风扇嵌入式计算机。它搭载了Intel第12代Alder Lake处理器,从入门级的Celeron 7…...

Qclaw:一键唤醒你的音乐MV导演天赋

一、整体思路 本方案设计一个端到端的音乐创作Agent,包含两个核心Skill:歌词生成Skill和MV生成Skill。Agent采用流水线架构,首先调用歌词生成Skill创建原创歌词,然后将歌词内容作为输入参数传递给MV生成Skill,最终输出…...

3步掌握Heightmapper:免费生成专业地形高度图的神器

3步掌握Heightmapper:免费生成专业地形高度图的神器 【免费下载链接】heightmapper interactive heightmaps from terrain data 项目地址: https://gitcode.com/gh_mirrors/he/heightmapper 想要为你的3D场景创建真实地形却不知从何入手?Heightma…...

Amlogic S9xxx盒子无线网卡终极适配指南:5分钟搞定RTL8822CS驱动

Amlogic S9xxx盒子无线网卡终极适配指南:5分钟搞定RTL8822CS驱动 【免费下载链接】amlogic-s9xxx-armbian Supports running Armbian on Amlogic, Allwinner, and Rockchip devices. Support a311d, s922x, s905x3, s905x2, s912, s905d, s905x, s905w, s905, s905l…...

BetterNCM插件管理器:网易云音乐功能扩展终极指南

BetterNCM插件管理器:网易云音乐功能扩展终极指南 【免费下载链接】BetterNCM-Installer 一键安装 Better 系软件 项目地址: https://gitcode.com/gh_mirrors/be/BetterNCM-Installer BetterNCM插件管理器是一款专为网易云音乐客户端设计的功能扩展工具&…...

树莓派低成本ToF相机深度感知开发指南

1. 项目概述:Arducam ToF相机为树莓派带来低成本深度感知在机器人导航、物体识别和交互式装置开发中,深度感知一直是个关键且成本较高的技术门槛。Arducam最新推出的ToF(Time-of-Flight)相机模块以30美元的众筹价,让树…...

别再被getcwd坑了!Windows/Linux下获取程序运行路径的3种实战方案(含VS/Qt场景)

别再被getcwd坑了!Windows/Linux下获取程序运行路径的3种实战方案(含VS/Qt场景) 刚接手跨平台项目的C开发者小林,在调试一个配置文件加载功能时遇到了诡异现象:Windows的Visual Studio里运行正常,但直接双击…...

C语言register关键字实战解析:从历史演进到现代编译器优化

1. register关键字的起源与硬件背景 在早期的计算机系统中,CPU和内存之间的速度差距并不像今天这么悬殊。上世纪70年代,当C语言刚刚诞生时,内存访问速度只比CPU慢几倍。那时候的编译器优化技术也相对简单,程序员需要手动告诉编译器…...

解锁缝纫新利器:泉州誉财针刺机械手夹具专利揭秘

一、专利基础信息专利名称:一种针刺机械手夹具专利类型:实用新型专利专利号:CN 223805253申请号:202520410472.8申请日期:2025 年 03 月 11 日专利权人:泉州誉财自动化设备有限责任公司专利权人地址&#x…...

猫抓浏览器扩展:一站式网页资源嗅探与下载解决方案

猫抓浏览器扩展:一站式网页资源嗅探与下载解决方案 【免费下载链接】cat-catch 猫抓 浏览器资源嗅探扩展 / cat-catch Browser Resource Sniffing Extension 项目地址: https://gitcode.com/GitHub_Trending/ca/cat-catch 你是否曾经在浏览网页时&#xff0c…...

免费TCP路由追踪终极指南:3分钟快速掌握网络诊断神器

免费TCP路由追踪终极指南:3分钟快速掌握网络诊断神器 【免费下载链接】tracetcp tracetcp. Traceroute utility that uses tcp syn packets to trace network routes. 项目地址: https://gitcode.com/gh_mirrors/tr/tracetcp 你是否遇到过这样的网络困扰&am…...

光子脉冲神经网络硬件协同设计与能效优化

1. 光子脉冲神经网络硬件协同设计概述光子脉冲神经网络(Photonic Spiking Neural Network, PSNN)是近年来兴起的一种新型计算架构,它巧妙地将生物神经元的脉冲编码机制与光子器件的高速并行特性相结合。这种架构的核心价值在于突破了传统电子…...

微信小程序二维码生成终极指南:5分钟掌握原生与多框架集成方案

微信小程序二维码生成终极指南:5分钟掌握原生与多框架集成方案 【免费下载链接】weapp-qrcode weapp.qrcode.js 在 微信小程序 中,快速生成二维码 项目地址: https://gitcode.com/gh_mirrors/we/weapp-qrcode 还在为微信小程序中二维码生成功能而…...

一款简约高效导航系统源码v2.0.1

内容目录一、详细介绍二、效果展示1.部分代码2.效果图展示请添加图片描述三、学习资料下载一、详细介绍 这是一款简约高效导航系统源码,这套源码作者是听风写的系统,很简约,更新了 2.0.1 版本, 更新了前 / 后台刷新加载有特效效…...

如何快速配置京东自动下单工具:新手完整指南

如何快速配置京东自动下单工具:新手完整指南 【免费下载链接】jd-happy [DEPRECATED]Node 爬虫,监控京东商品到货,并实现下单服务 项目地址: https://gitcode.com/gh_mirrors/jd/jd-happy 还在为抢不到京东热门商品而烦恼吗&#xff1…...

一站式在解析加密转换工具源码 实用工具HTML 在线工具箱

内容目录一、详细介绍二、效果展示1.部分代码2.效果图展示三、学习资料下载一、详细介绍 这是一款集成多种实用工具的html源码,包含 JSON 处理、加解密、压缩格式化、文本工具、计算器和编码转换等功能。页面设计将采用现代 UI 风格,确保用户体验流畅且…...

基于Jmeter的性能测试框架搭建

谈到性能测试,部分公司连专门用于性能测试的环境都没有,更别提性能测试框架/平台了。下面,笔者就“基于Jmeter的性能测试框架搭建”这个话题,谈谈自己的一些想法。 工具 Jmeter Influxdb Grafana Telegraf Jenkins Ant Gitlab …...