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

我不是在用 AI 助手,我在把自己的能力沉淀成组织资产坟

1. 什么是 Apache SeaTunnelApache SeaTunnel 是一个非常易于使用、高性能、支持实时流式和离线批处理的海量数据集成平台。它的目标是解决常见的数据集成问题如数据源多样性、同步场景复杂性以及资源消耗高的问题。核心特性丰富的数据源支持支持 100 种 Connector涵盖主流数据库、云存储、SaaS 服务等。批流一体同一套 Connector 代码同时支持批处理离线和流处理实时。高性能支持多引擎Zeta, Flink, Spark提供高吞吐、低延迟的数据同步能力。简单易用通过简单的配置文件Config即可定义复杂的数据同步任务。2. 架构与环境2.1 架构图SeaTunnel 采用了解耦的设计架构Source、Transform、Sink 插件与具体的执行引擎Engine是分离的。ST architecture2.2 操作系统支持SeaTunnel 基于 Java 开发理论上支持所有安装了 JDK 的操作系统。操作系统 适用场景 说明Linux (CentOS, Ubuntu, etc.) 生产环境 (推荐) 稳定性高适合长期运行服务。macOS 开发/测试 适合开发者本地调试和编写 Config。2.3 环境准备在开始安装 SeaTunnel 之前请确保你的环境满足以下要求JDK 版本必须安装 Java 8 或 Java 11。可以通过命令 java -version 检查。确保设置了 JAVA_HOME 环境变量。3. 核心组件深度解析在使用 SeaTunnel 之前深入理解其核心组件的内部机制有助于你更好地调优和排查问题。3.1 Source (数据源)Source 负责从外部系统读取数据并将其转换为 SeaTunnel 内部的行格式SeaTunnelRow。Enumerator (枚举器)运行在 Master 节点Coordinator。负责发现数据分片Splits。例如在 JDBC Source 中Enumerator 会根据 partition_column 的最大值和最小值计算出多个查询范围Splits。Reader (读取器)运行在 Worker 节点。负责接收 Enumerator 分配的 Splits并真正执行读取操作。多个 Reader 并行工作极大提高了读取效率。Checkpoint 支持对于流式作业Source 还需要支持状态保存如 Kafka 的 Offset以便在故障恢复时实现断点续传。3.2 Transform (数据转换)Transform 负责在数据从 Source 流向 Sink 的过程中对数据进行处理。无状态转换大多数 Transform如 Sql, Filter, Replace是无状态的即处理当前行不需要依赖其他行的数据。Schema 变更Transform 可以改变数据的 Schema增加、删除、修改字段下游 Sink 会感知到这种变化。3.3 Sink (数据目标)Sink 负责将 SeaTunnel 处理后的数据写入到外部系统。Writer (写入器)运行在 Worker 节点。负责将数据写入目标系统。通常支持批量写入以提高吞吐量。Committer (提交器)运行在 Master 节点可选。对于支持事务的 Sink如文件系统、Iceberg需要一个全局的 Committer 来在 Checkpoint 完成时统一提交事务二阶段提交从而实现 Exactly-Once精确一次语义。3.4 执行流程解析配置SeaTunnel 解析配置文件构建逻辑执行计划。资源分配Master 节点根据并行度申请资源。任务分发Enumerator 生成分片分发给 Reader。数据流转Reader - Transform - Writer。状态提交周期性触发 Checkpoint保存状态并提交事务。4. 支持的 Connector 及其优缺点分析SeaTunnel 支持超过 100 种 Connector以下是几类最常用的 Connector 及其特性分析4.1 关系型数据库 (JDBC)支持列表: MySQL, PostgreSQL, Oracle, SQLServer, DB2, Teradata, Dameng(达梦), OceanBase, TiDB 等。优点通用性强只要有 JDBC 驱动即可连接几乎所有 SQL 数据库。功能完善支持列投影只读部分列、并行读取基于 partition_column 切分、Exactly-Once取决于实现。自动建表部分 Connector 支持在目标端自动创建表结构。缺点性能瓶颈受限于 JDBC 协议和单机驱动性能超大规模数据读取可能需要精细调优如 fetch_size。源库压力如果并行度设置过高可能打满源库连接池或 CPU。4.2 消息队列支持列表: Kafka, Pulsar, RocketMQ, Amazon DynamoDB Streams 等。优点高吞吐天生适合大规模流数据处理支持削峰填谷。格式丰富支持 JSON, Avro, Protobuf, Canal-JSON, Debezium-JSON 等多种序列化格式。Exactly-Once支持端到端的精确一次语义依赖 Checkpoint 机制。缺点配置复杂涉及 Offset 管理、序列化 Schema 配置、Consumer Group 管理等。数据可见性相比数据库数据在 Topic 中不够直观调试稍显麻烦。4.3 变更数据捕获 (CDC)支持列表: MySQL-CDC, PostgreSQL-CDC, Oracle-CDC, MongoDB-CDC, SQLServer-CDC, TiDB-CDC 等。优点实时性毫秒级捕获数据库增删改操作。无锁读取SeaTunnel 的 CDC 实现了无锁并行快照算法极大降低了对源库的影响。断点续传支持从 Binlog/WAL 指定位置恢复。Schema Evolution支持表结构变更同步部分支持。缺点权限要求通常需要较高的数据库权限如 REPLICATION SLAVE。依赖日志源库必须开启 Binlog或 WAL且保留时间需足够长。4.4 文件系统 云存储支持列表: LocalFile, HDFS, S3, OSS, GCS, FTP, SFTP 等。优点海量存储适合数据湖场景成本低廉。格式支持原生支持 Parquet, ORC, Avro, JSON, CSV, Excel, Text 等。压缩支持支持 Snappy, Gzip, Lzo 等多种压缩算法。缺点小文件问题流式写入时如果 Checkpoint 间隔太短容易产生大量小文件SeaTunnel 有文件合并功能但会增加复杂度。4.5 NoSQL 其他支持列表: Elasticsearch, Redis, MongoDB, Cassandra, HBase, InfluxDB, ClickHouse, Doris, StarRocks 等。特点针对各数据库特性进行了优化例如 ClickHouse/StarRocks 支持 Stream Load 高速导入Elasticsearch 支持批量写入。5. Transform 实战演练 (附带详细注释)Transform 插件用于在 Source 和 Sink 之间处理数据。以下是几个常用 Transform 的配置示例。5.1 Sql Transform (最推荐)使用 SQL 语法对数据进行处理支持重命名、计算、常量添加、过滤等。transform {Sql {# 输入表名必须与 Source 的 result_table_name 一致plugin_input fake# 输出表名供后续 Transform 或 Sink 使用plugin_output fake_sql# SQL 查询语句# 1. name as full_name: 字段重命名# 2. age 1: 数值计算# 3. US as country: 增加常量列# 4. where age 10: 数据过滤query select name as full_name, age 1 as next_year_age, US as country from fake where age 10}}5.2 Filter Transform用于删除或保留指定字段注意不是过滤行是过滤列/字段。transform {Filter {plugin_input fakeplugin_output fake_filter# 仅保留 name 和 age 字段其他字段会被丢弃include_fields [name, age]# 或者使用 exclude_fields 删除指定字段# exclude_fields [card]}}5.3 Replace Transform用于字符串替换支持正则表达式。transform {Replace {plugin_input fakeplugin_output fake_replace# 需要替换的字段名replace_field name# 匹配模式旧字符串pattern # 替换后的字符串新字符串replacement _# 是否使用正则表达式这里设为 true表示 pattern 是一个正则is_regex true# 是否只替换第一个匹配项replace_first true}}5.4 Split Transform将一个字符串字段拆分为多个字段。transform {Split {plugin_input fakeplugin_output fake_split# 分隔符这里使用空格separator # 需要拆分的源字段split_field name# 拆分后生成的新字段名列表output_fields [first_name, last_name]}}6. 快速安装对于新手推荐直接下载编译好的二进制发行包进行体验。步骤 1: 下载前往 SeaTunnel 下载页面 下载最新版本的二进制包例如 apache-seatunnel-2.3.x-bin.tar.gz。步骤 2: 解压tar -xzvf apache-seatunnel-2.3.x-bin.tar.gzcd apache-seatunnel-2.3.x步骤 3: 安装 Connector 插件SeaTunnel 的 Connector 是插件化的。首次使用需要下载插件sh bin/install-plugin.sh注意该命令会根据 config/plugin_config 文件中的配置从 Maven 中央仓库下载常用插件如 connector-fake, connector-console 等。如果下载速度慢请耐心等待或配置 Maven 镜像。?? 技巧配置 Maven 国内镜像加速下载如果遇到下载速度极慢或超时失败的情况建议配置 Maven 阿里云镜像。找到或创建 Maven 配置文件~/.m2/settings.xml (Windows 下为 C:\Users\你的用户名\.m2\settings.xml)。添加如下镜像配置aliyunmaven*阿里云公共仓库https://maven.aliyun.com/repository/public保存后再次运行 sh bin/install-plugin.sh 即可享受高速下载。7. 实战第一个 SeaTunnel 任务我们将创建一个简单的任务生成一些随机数据FakeSource并将其打印到控制台Console Sink。步骤 1: 创建配置文件在 config 目录下创建一个名为 hello_world.conf 的文件内容如下env {# 并行度设置决定了有多少个线程同时执行任务。# 设置为 1 表示单线程执行适合测试生产环境可根据资源调大。parallelism 1# 作业模式# BATCH (批处理)一次性处理完数据后结束如离线同步。# STREAMING (流处理)持续运行实时处理数据如实时同步。job.mode BATCH}source {# FakeSource 是一个虚拟数据源用于生成测试数据FakeSource {# result_table_name: 将此数据源产生的数据注册为一个临时表表名为 fake# 后续的 Transform 或 Sink 可以通过这个名字引用这份数据result_table_name fake# row.num: 指定生成数据的总行数这里生成 16 行数据row.num 16# schema: 定义数据的结构字段名和类型schema {fields {name string # 定义一个名为 name 的字符串字段age int # 定义一个名为 age 的整型字段}}}}transform {# Sql Transform: 使用 SQL 语句对数据进行处理Sql {# plugin_input: 指定输入数据来源这里引用了 Source 中定义的 fake 表plugin_input fake# plugin_output: 指定处理后的结果表名命名为 fake_transformed# 下游的 Sink 将使用这个名字来获取处理后的数据plugin_output fake_transformed# query: 执行的 SQL 查询语句# 这里演示了选择 name 和 age 字段并新增一个常量字段 new_fieldquery select name, age, new_field_val as new_field from fake}}sink {# Console Sink: 将数据输出打印到控制台标准输出Console {# plugin_input: 指定要输出的数据来源这里引用了 Transform 输出的 fake_transformed 表plugin_input fake_transformed}}步骤 2: 运行任务使用 SeaTunnel 自带的 Zeta 引擎运行该任务。执行命令./bin/seatunnel.sh --config ./config/hello_world.conf -e local命令详解./bin/seatunnel.sh: 启动脚本默认使用 Zeta 引擎。--config (或 -c): 指定配置文件的路径。这里我们指定了刚才创建的 hello_world.conf。-e local (或 -m local): 指定执行模式。local: 本地模式。SeaTunnel 会在当前进程中启动一个轻量级的 Zeta 引擎集群来运行任务任务结束后集群关闭。适合开发和测试。cluster: 集群模式。任务会提交到已经运行的 SeaTunnel 集群中执行。适合生产环境。步骤 3: 查看结果与日志分析任务启动后终端会输出大量日志。我们需要关注以下关键信息任务提交成功看到 Job execution started 表示配置文件解析通过任务已提交给引擎。数据处理过程由于我们使用的是 Console Sink数据会直接打印在日志中。你应能看到类似如下的输出...INFO ...ConsoleSinkWriter - subtaskIndex0 rowIndex1: SeaTunnelRow#tableId-1 SeaTunnelRow#kindINSERT: CpiOd, 12345, new_field_valINFO ...ConsoleSinkWriter - subtaskIndex0 rowIndex2: SeaTunnelRow#tableId-1 SeaTunnelRow#kindINSERT: eQqTs, 67890, new_field_val...subtaskIndex: 并行任务的编号。rowIndex: 当前处理的行号。SeaTunnelRow: 打印出的具体数据内容。任务结束最后看到 Job Execution Status: FINISHED 表示任务执行成功结束。8. 常见问题排查 (Troubleshooting)如果在运行过程中遇到报错请参考以下常见问题进行排查?? 问题 1: command not found: java 或 JAVA_HOME is not set现象运行脚本时直接报错提示找不到 Java。原因环境未安装 Java 或未配置环境变量。解决运行 java -version 确认 Java 8 或 11 已安装。设置环境变量export JAVA_HOME/path/to/your/java (建议写入 ~/.bashrc 或 ~/.zshrc)。?? 问题 2: Exception in thread main ... ClassNotFoundException现象报错提示找不到某个类例如 ClassNotFoundException: org.apache.seatunnel.connectors.seatunnel.fake.source.FakeSourceFactory。原因Connector 插件未安装。默认包中只有引擎核心没有包含具体的数据源插件。解决确保你执行过 sh bin/install-plugin.sh。检查 connectors/seatunnel 目录下是否有对应的 jar 包例如 connector-fake-*.jar。?? 问题 3: Config file not valid 或 HOCONSyntaxError现象提示配置文件格式错误。原因hello_world.conf 中的括号 {} 不匹配或者关键字拼写错误。解决仔细检查配置文件语法。SeaTunnel 使用 HOCON 格式确保每一层级的 { 和 } 都是成对出现的。?? 问题 4: 任务卡住不动现象日志停止更新但任务没有结束。原因可能是资源不足CPU/内存或者在流模式STREAMING下这是正常现象流任务是无休止运行的。解决如果是 BATCH 模式卡住检查 plugin_config 里的内存设置。检查是否在 env 中错误地设置了 job.mode STREAMING。畏滥矣招

相关文章:

我不是在用 AI 助手,我在把自己的能力沉淀成组织资产坟

1. 什么是 Apache SeaTunnel? Apache SeaTunnel 是一个非常易于使用、高性能、支持实时流式和离线批处理的海量数据集成平台。它的目标是解决常见的数据集成问题,如数据源多样性、同步场景复杂性以及资源消耗高的问题。 核心特性 丰富的数据源支持&#…...

2026奇点大会文本生成赛道暗战全记录,含3家未上市独角兽的私有化RLHF训练范式(内部流出版)

第一章:2026奇点智能技术大会:大模型文本生成 2026奇点智能技术大会(https://ml-summit.org) 核心突破:上下文感知的动态长度建模 本届大会首次公开演示了支持16M tokens超长上下文的开源大模型Lingua-16M,其采用分层稀疏注意力…...

5大核心功能深度解析:Jasminum如何重塑你的中文文献管理工作流

5大核心功能深度解析:Jasminum如何重塑你的中文文献管理工作流 【免费下载链接】jasminum A Zotero add-on to retrive CNKI meta data. 一个简单的Zotero 插件,用于识别中文元数据 项目地址: https://gitcode.com/gh_mirrors/ja/jasminum 如果你…...

开源Windows系统优化工具:3分钟让你的电脑运行速度提升51%

开源Windows系统优化工具:3分钟让你的电脑运行速度提升51% 【免费下载链接】Win11Debloat A simple, lightweight PowerShell script that allows you to remove pre-installed apps, disable telemetry, as well as perform various other changes to declutter an…...

我不是狐狸,我是那Harness Engineering闹

Julia(julialang.org)由Stefan Karpinski、Jeff Bezanson等在2009年创建,目标是融合Python的易用性、C的高性能、R的统计能力、Matlab的科学计算生态。 其核心设计哲学是: 高性能:编译型语言(JIT&#xff0…...

大模型解释性不是选修课:3类监管合规红线+4套生产级XAI工具链,今天不部署明天被叫停

第一章:大模型工程化中的模型解释性方案 2026奇点智能技术大会(https://ml-summit.org) 在大规模语言模型落地金融风控、医疗辅助与司法决策等高敏感场景时,模型解释性已从“可选能力”升级为合规性刚需。缺乏可追溯的推理依据不仅阻碍人工复核&#xf…...

Unity 3D游戏性能优化全攻略:如何让你的游戏在低配设备上也能流畅运行

Unity 3D游戏性能优化全攻略:如何让你的游戏在低配设备上也能流畅运行 当你的游戏在高端设备上运行如丝般顺滑,却在低配手机上卡成幻灯片时,那种挫败感每个开发者都深有体会。性能优化不是锦上添花,而是决定游戏生死的关键战役。本…...

Avalonia UI ..-RC正式发布前

一、什么是 Q 饱和运算? 1. 核心痛点:普通运算的 “数值回绕” 普通算术运算(如 ADD/SUB)溢出时,数值会按补码规则 “回绕”,导致结果完全错误: 示例:int8_t 类型最大值 127 1 → 结…...

2026最权威的五大AI辅助写作工具实测分析

Ai论文网站排名(开题报告、文献综述、降aigc率、降重综合对比) TOP1. 千笔AI TOP2. aipasspaper TOP3. 清北论文 TOP4. 豆包 TOP5. kimi TOP6. deepseek 利用自然语言处理跟知识图谱技术的AI开题报告工具,能够快速剖析研究领域的动态变…...

老马失前蹄,竟然在数据库外键上翻车了,重温外键级联浩

AI Agent 时代的沙箱需求 从 Copilot 到 Agent:执行能力的质变 在生成式 AI 的早期阶段,应用主要以“Copilot”形式存在,AI 仅作为辅助生成建议。然而,随着 AutoGPT、BabyAGI 以及 OpenAI Code Interpreter(现为 Advan…...

DAMOYOLO-S镜像免配置:内置ModelScope模型零下载部署

DAMOYOLO-S镜像免配置:内置ModelScope模型零下载部署 1. 开箱即用的目标检测新体验 如果你正在寻找一个能快速上手、无需折腾环境配置的目标检测工具,那么今天介绍的DAMOYOLO-S镜像可能就是你的理想选择。它最大的特点就是“开箱即用”——镜像里已经内…...

Llama-3.2V-11B-cot实战教程:自定义提示词模板提升CoT推理结构化程度

Llama-3.2V-11B-cot实战教程:自定义提示词模板提升CoT推理结构化程度 1. 工具概览与核心价值 Llama-3.2V-11B-cot是基于Meta最新多模态大模型开发的专业级视觉推理工具,特别针对双卡RTX 4090环境进行了深度优化。这个工具最突出的特点是实现了开箱即用…...

轻松下载网页视频:VideoDownloadHelper浏览器扩展完全指南

轻松下载网页视频:VideoDownloadHelper浏览器扩展完全指南 【免费下载链接】VideoDownloadHelper Chrome Extension to Help Download Video for Some Video Sites. 项目地址: https://gitcode.com/gh_mirrors/vi/VideoDownloadHelper 还在为无法保存网页视频…...

2026年怎么集成OpenClaw?腾讯云5分钟小白部署OpenClaw,千问大模型Coding Plan配置教程

2026年怎么集成OpenClaw?腾讯云5分钟小白部署OpenClaw,千问大模型Coding Plan配置教程。本文面向零基础用户,完整说明在轻量服务器与本地Windows11、macOS、Linux系统中部署OpenClaw(Clawdbot)的流程,包含环…...

2026年OpenClaw怎么部署?5分钟腾讯云保姆级安装及百炼Coding Plan方法

2026年OpenClaw怎么部署?5分钟腾讯云保姆级安装及百炼Coding Plan方法。本文面向零基础用户,完整说明在轻量服务器与本地Windows11、macOS、Linux系统中部署OpenClaw(Clawdbot)的流程,包含环境配置、服务启动、Skills集…...

深度技术解析:QKeyMapper如何实现Windows系统级按键重映射与虚拟手柄模拟

深度技术解析:QKeyMapper如何实现Windows系统级按键重映射与虚拟手柄模拟 【免费下载链接】QKeyMapper [按键映射工具] QKeyMapper,Qt开发Win10&Win11可用,不修改注册表、不需重新启动系统,可立即生效和停止。支持游戏手柄映射…...

2026年如何集成OpenClaw?4分钟阿里云零门槛集成及百炼Coding Plan流程

2026年如何集成OpenClaw?4分钟阿里云零门槛集成及百炼Coding Plan流程。本文面向零基础用户,完整说明在轻量服务器与本地Windows11、macOS、Linux系统中部署OpenClaw(Clawdbot)的流程,包含环境配置、服务启动、Skills集…...

Behaviac终极指南:掌握游戏AI行为树的7个实用技巧

Behaviac终极指南:掌握游戏AI行为树的7个实用技巧 【免费下载链接】behaviac behaviac is a framework of the game AI development, and it also can be used as a rapid game prototype design tool. behaviac supports the behavior tree, finite state machine …...

c#文件结构

c#程序运行和调试最基础的三剑客bin\Debug 文件夹,已经成功编写并编译(生成)了一个 C# 程序啦!在 C# 项目中,当你点击“运行”或“生成”后,Visual Studio 会把你的代码翻译成计算机能懂的语言,…...

GLM-4.1V-9B-Bate后端开发实战:构建高并发图像处理任务队列

GLM-4.1V-9B-Bate后端开发实战:构建高并发图像处理任务队列 1. 为什么需要异步任务队列 电商平台每天要处理数百万张商品图片的智能分析请求,传统同步接口直接返回结果的方式已经无法满足需求。当用户上传一张图片等待AI分析时,如果采用同步…...

终极免费AI字幕工具VideoCaptioner:3分钟学会智能视频字幕处理

终极免费AI字幕工具VideoCaptioner:3分钟学会智能视频字幕处理 【免费下载链接】VideoCaptioner 🎬 卡卡字幕助手 | VideoCaptioner - 基于 LLM 的智能字幕助手 - 视频字幕生成、断句、校正、字幕翻译全流程处理!- A powered tool for easy a…...

HunyuanVideo-Foley 模型服务容器化:使用Docker Compose编排多组件依赖

HunyuanVideo-Foley 模型服务容器化:使用Docker Compose编排多组件依赖 1. 引言 想象一下,你正在开发一个智能音效生成平台,需要同时管理AI模型服务、数据库和缓存系统。每次启动都要手动配置多个组件,不仅耗时还容易出错。这就…...

基于Simulink的超外差单边带接收机建模与动态仿真分析

1. 超外差单边带接收机基础原理 第一次接触超外差接收机时,我被它的"变频"概念搞得一头雾水——为什么要把信号变来变去?后来在调试收音机电路时才恍然大悟:这就好比把不同尺寸的快递包裹统一放到标准传送带上处理。具体来说&#…...

基于圣女司幼幽-造相Z-Turbo与LSTM的序列图像生成:简易动画制作

基于圣女司幼幽-造相Z-Turbo与LSTM的序列图像生成:简易动画制作 你有没有想过,把一段文字故事,直接变成一帧帧连贯的画面,就像简易的动画分镜或者连环画?这听起来像是电影导演或专业画师的工作,但现在&…...

Autosar代码调试实战:从ErrorHook到PC指针的精准定位

1. Autosar代码调试的三大核心武器 第一次接触Autosar代码时,我被它庞大的工程量和复杂的宏定义搞得晕头转向。记得有一次项目联调,ECU莫名其妙地死机重启,我花了整整三天时间才定位到问题所在。后来在多个项目实战中,我逐渐总结出…...

SpringBoot + ShardingSphere实战:如何优雅地处理千万级订单表分库分表?

SpringBoot与ShardingSphere深度整合:千万级订单系统的分库分表实战指南 电商平台的订单系统往往是最先遭遇性能瓶颈的模块。当单表数据突破5000万条时,即使是最优化的SQL查询也会变得举步维艰。我曾参与过一个日订单量超30万的电商平台改造项目&#xf…...

AI 工程化实战:从零手搓代码,这一次彻底搞懂MCP!嗜

简介 langchain中提供的chain链组件,能够帮助我门快速的实现各个组件的流水线式的调用,和模型的问答 Chain链的组成 根据查阅的资料,langchain的chain链结构如下: $$Input \rightarrow Prompt \rightarrow Model \rightarrow Outp…...

2025实战:从零构建企业级本地知识库的避坑指南

1. 为什么企业需要本地知识库? 最近两年,我帮十几家企业搭建过本地知识库系统。最让我印象深刻的是某金融公司的案例:他们原先使用某知名云笔记产品,结果一次服务器故障导致全员无法访问核心业务文档,直接影响了当天的…...

Excel数据导入与批处理脚本的完美结合

在日常工作中,我们常常需要处理大量的重复性工作,而这些工作如果能够通过自动化脚本来完成,无疑会极大地提高我们的工作效率。本文将介绍如何利用一个简单的批处理脚本(.bat文件),结合Excel数据,实现自动打开多个账户页面的功能。 问题背景 假设我们有一个Excel文档,…...

FanControl:让Windows风扇控制变得简单而智能的终极指南

FanControl:让Windows风扇控制变得简单而智能的终极指南 【免费下载链接】FanControl.Releases This is the release repository for Fan Control, a highly customizable fan controlling software for Windows. 项目地址: https://gitcode.com/GitHub_Trending/…...