OpenTelemetry 赋能DevOps流程的可观测性革命

news2025/1/11 9:59:44

原作者:天颇
原出处:微信公众号 乘云数字DATABUFF
原文地址:https://mp.weixin.qq.com/s/D_f31EBtLu7Rr0gahuF-bw

图片 3

引言

在当今快节奏的软件开发和运维环境中,DevOps 已经成为主流,它通过整合开发和运维流程,推动着软件的快速迭代和持续交付。然而,随着微服务、容器化和云计算等技术的普及,系统复杂性急剧增加,传统的监控手段已经难以满足现代应用的需求。开发者和运维团队迫切需要一种能够提供全局视角、洞察系统运行状态的利器,这就是可观测性(Observability)应运而生的原因。

OpenTelemetry 正是这一领域的引领者,它作为由 Cloud Native Computing Foundation (CNCF) 领导的开源项目,为云原生应用提供了一套统一的 API 和工具,用于跨语言、跨平台的遥测数据采集和分析。OpenTelemetry 打破了传统监控工具数据孤岛的限制,通过统一的数据格式,帮助团队全面了解分布式系统的运行状态,并能够根据这些数据进行快速问题定位、性能调优以及架构优化。

更重要的是,OpenTelemetry 与 DevOps 流程中的关键策略——左移(Shift Left) 和 GitOps 深度结合,为 DevOps 实践带来了革命性的变革。左移策略强调将测试、安全和监控工作提前到开发周期的早期阶段,而 GitOps 则通过将 Git 作为唯一的基础设施和应用程序配置的来源,实现了基础设施和应用部署的高度自动化与可追溯性。

本文将深入探讨 OpenTelemetry 如何与左移和 GitOps 策略相结合,赋能 DevOps 流程中的各个环节。通过这种强大的组合,OpenTelemetry 不仅为开发、测试、部署和运维提供了全面的系统洞察力,还通过自动化和标准化的遥测数据采集,大幅度提高了系统的可靠性和交付速度,推动 DevOps 实践迈向新的高度。

OpenTelemetry:架构与功能解析

OpenTelemetry 是一个由 Cloud Native Computing Foundation (CNCF) 托管的开源项目,旨在为云原生应用和分布式系统提供统一的可观测性框架。它通过标准化的 API 和工具,帮助开发者和运维人员收集、处理和分析分布式系统中的遥测数据,包括分布式追踪(traces)、度量指标(metrics)和日志(logs)。作为 DevOps 流程中可观测性的核心工具之一,OpenTelemetry 的出现不仅帮助开发团队更加轻松地集成监控能力,还为跨平台、跨语言的监控提供了标准化解决方案。

OpenTelemetry 的诞生源于 OpenTracing 和 OpenCensus 两个开源项目的合并。这两个项目分别聚焦于分布式追踪和度量指标,但由于各自发展中存在重叠和兼容性问题,最终在 2019 年决定合并成 OpenTelemetry,以实现一个统一的、跨语言的可观测性标准。这一合并大大简化了开发者集成监控的复杂性,避免了之前在选择和集成不同工具时遇到的困扰。如今,OpenTelemetry 已成为分布式系统监控中的事实标准,广泛支持多种后端系统,如 Prometheus、Jaeger、Zipkin 等,帮助团队灵活应对各种监控和分析需求。

OpenTelemetry 的架构主要由以下几个核心组件构成:

  1. API: OpenTelemetry 的 API 是开发者用来生成和采集遥测数据的标准接口。通过这些 API,开发者可以生成自定义的度量数据、日志和追踪,并将其发送到后续处理组件。

  2. SDK: SDK 提供了 API 的具体实现,开发人员可以使用它们来配置和定制数据采集、处理和导出。例如,开发者可以通过 SDK 配置如何采样追踪数据、将数据导出到哪些系统,或如何处理超时等异常情况。

  3. Collector: Collector 是 OpenTelemetry 的核心组件之一,用于接收、处理和导出来自不同服务的遥测数据。它允许用户通过配置不同的接收器(Receiver)、处理器(Processor)和导出器(Exporter),将遥测数据从多个来源收集并导出到一个或多个后端系统。Collector 的好处在于,它是供应商中立的,可以支持多种后端目标,并在数据流动中提供强大的灵活性。

  4. 自动化仪表化: 这些库为开发人员提供了与常见框架和库(如 HTTP 客户端、数据库连接池 等)的集成,减少了手动植入代码的需求。例如,使用 Psycopg2 的应用可以通过简单的库调用,自动为 PostgreSQL 查询操作生成追踪数据和性能指标。

OpenTelemetry 的优势主要体现在以下几个方面:

  • 标准化与统一性: 通过提供一套跨语言、跨平台的标准,OpenTelemetry 使不同服务之间的数据能够统一采集、分析和共享。这避免了使用不同监控工具时产生的兼容性问题。

  • 自动化与简化集成: OpenTelemetry 的自动化仪表化大大减少了开发者手动插入监控代码的负担,使得应用的可观测性集成变得简单高效。

  • 灵活性与可扩展性: 无论是通过 SDK 进行自定义,还是通过 Collector 配置不同的后端,OpenTelemetry 提供了极高的灵活性,用户可以根据具体的需求定制监控方案。

  • 广泛的生态系统支持: OpenTelemetry 拥有活跃的社区和丰富的生态系统,它支持几乎所有主流的监控和日志平台,开发者可以根据项目需求选择最佳的工具组合。

左移:将可观测性融入开发流程

图片 1

开发流程并非直线或者单纯的向左向右的选项,而是一个动态调整、实时反馈的过程。当问题或瓶颈出现时,团队需要并不只是盲目地继续前进,而是能根据可观测性数据进行实时的反馈回路调整。

左移(Shift Left)是 DevOps 实践中的一个关键策略,旨在将测试、性能分析、监控等活动从传统的开发周期末期向前推移到开发周期的早期阶段。它的核心思想在于尽早发现和解决潜在问题,从而降低返工成本,提升代码质量,并加速交付速度。

传统的软件开发生命周期(SDLC)中,测试、安全验证和性能优化往往是在开发的后期阶段进行。在代码开发完成之后,开发团队才开始进行集成测试、压力测试和其他类型的验证。然而,这种模式存在一个重大缺陷,即如果开发过程中出现问题,往往需要等到集成测试或部署阶段才能被发现。而此时由于开发工作已经接近尾声,修复问题的成本显著增加,不仅导致时间和资源的浪费,还可能严重影响交付进度。

左移策略正是为了避免这一缺陷,将这些测试和验证工作尽可能向开发阶段前移。通过在开发周期的早期进行测试、性能分析和安全评估,团队可以更早地发现并解决问题,从而减少后期修复的成本。

OpenTelemetry 如何助力左移?

在左移策略中,OpenTelemetry 作为一个强大的可观测性框架,起到了关键的作用。它帮助开发人员在开发阶段就能够收集到全面的系统性能数据,极大地增强了早期测试和监控的效果。

  • 实时性能反馈: 通过 OpenTelemetry,开发团队可以在编写代码时集成追踪(tracing)、度量(metrics)和日志(logs),让开发者即时获得代码运行时的各类遥测数据,快速定位性能瓶颈或潜在错误。例如,开发人员可以使用 OpenTelemetry 在本地开发环境中集成数据库查询的性能追踪工具。通过实时监控数据库查询的执行时间和响应效率,开发者能够在开发过程中发现潜在的性能问题,而不必等到部署到测试环境或生产环境后才发现并修复。

  • 简化监控代码集成: OpenTelemetry 还通过自动化的仪器库,使得开发人员能够轻松在代码中集成可观测性工具,而无需手动编写大量的监控代码。例如,使用 OpenTelemetry 的自动化 SDK,开发人员可以快速为 HTTP 请求、数据库查询、消息队列等常见服务添加追踪和监控功能。这样,开发人员能够在提交代码之前,就对应用的性能有一个初步的了解,并能够在需要时进行优化调整。

左移与持续集成/持续交付(CI/CD)的结合

左移与持续集成(CI)和持续交付(CD)密切相关。在 CI/CD 流程中,代码提交后会自动触发构建、测试和部署任务,而左移则将这些任务的很多内容提前到开发阶段。通过将 OpenTelemetry 集成到 CI/CD 流水线中,团队能够持续监控每一次构建和测试的执行情况,并在任何阶段获得实时的性能反馈和遥测数据。

例如,在 CI 阶段,每次代码变更触发的构建任务都可以通过 OpenTelemetry 实时监控其执行效率。通过这些数据,团队能够判断代码变更对系统性能的影响,提前调整资源配置,优化部署策略。这不仅帮助团队提高了交付效率,也增强了系统的可维护性和稳定性。

GitOps:以 Git 为中心,实现基础设施和应用的自动化部署

GitOps 是 DevOps 实践中的一个重要策略,强调以 Git 仓库作为基础设施和应用程序唯一可信的真实来源。它通过声明式的配置文件管理基础设施和应用程序的状态,并使用 Git 的操作流程进行变更管理与自动化部署。

GitOps 的核心理念

GitOps 的基础在于声明式配置,即所有的基础设施和应用程序配置都存储在 Git 仓库中,以 YAML、JSON 等格式明确描述出系统的期望状态。当开发人员或运维人员需要变更某个环境时,他们不会直接登录到服务器进行配置更改,而是通过 Git 提交变更到仓库。然后,一个自动化的 CI/CD 管道 或 GitOps 引擎(例如 ArgoCD、Flux 等)会监控仓库的状态,并自动将这些变更应用到指定的目标环境中。

图片 1

GitOps 的操作流程:

  1. 声明期望状态: 开发人员或运维人员通过代码声明所需的基础设施和应用程序状态,并将这些配置文件存储在 Git 仓库中。

  2. 变更管理: 当需要对基础设施或应用程序进行更新时,开发人员通过 Git 提交新变更到仓库。所有变更都需要通过 Pull Request(PR)或其他审批机制进行审核。

  3. 自动化部署: 一旦变更被批准并合并到主分支,GitOps 工具会自动监控仓库的变更,并根据新的配置状态自动更新目标环境中的基础设施或应用程序。

  4. 持续同步和回滚: 如果在部署过程中出现问题,GitOps 工具能够基于 Git 的版本控制功能,快速将系统回滚到之前的稳定版本。

GitOps 的优势:

  • 可追溯性与透明性: 所有变更都有历史记录,可以通过 Git 的版本控制机制进行审查,提高变更的透明度,也为合规性审计提供了依据。

  • 增强的安全性: 通过 Git 仓库的访问控制机制来确保只有授权的人员可以执行部署操作。

  • 简化运维流程: 运维人员不再需要手动操作服务器或手动部署基础设施组件,而是将这些工作交给自动化工具来完成。

  • 提高响应速度: 通过自动化工具持续监控系统状态,GitOps 能够在检测到配置偏离时自动恢复期望状态。

OpenTelemetry 赋能 DevOps 流程

OpenTelemetry 作为一个全面的可观测性框架,通过提供统一的 API 和工具,帮助 DevOps 团队在开发、测试、部署和运维的各个阶段收集和分析系统的遥测数据。它涵盖了分布式追踪(tracing)、度量指标(metrics)和日志(logs)三个主要的可观测性领域,赋能开发和运维人员获得全面的系统洞察力,从而优化开发效率和系统性能。

1. 开发阶段的可观测性左移

OpenTelemetry 允许开发人员在编写代码的过程中就开始集成可观测性功能。通过 OpenTelemetry,开发人员可以将度量指标、日志和追踪数据嵌入到应用程序中,在本地或开发环境中实时监控代码的行为和性能。

例如,在开发一个涉及数据库操作的微服务时,开发人员可以通过 OpenTelemetry 收集数据库查询的执行时间、API 调用的延迟情况等关键指标。这种早期的性能反馈能够帮助开发人员迅速识别代码中的性能瓶颈或潜在的错误,而不必等到代码提交到 CI/CD 流水线之后。

2. 测试阶段的自动化与深入监控

OpenTelemetry 在测试阶段提供了强大的支持,尤其是在性能测试、集成测试和负载测试中发挥了重要作用。在测试过程中,团队可以通过 OpenTelemetry 收集每个测试用例的详细性能数据和执行情况,包括测试的成功率、资源消耗、响应时间等。

例如,团队可以将 OpenTelemetry 集成到自动化测试框架中,每次执行测试时自动收集遥测数据。这些数据可以用于评估系统在高负载下的表现,分析不同版本之间的性能差异,并确定哪些变更可能引发性能下降或导致资源过度消耗。

3. CI/CD 流程中的可观测性

在持续集成和持续交付(CI/CD)流程中,OpenTelemetry 能够为 DevOps 团队提供从构建到部署的全方位监控。通过在 CI/CD 流水线中集成 OpenTelemetry,团队可以实时追踪每次构建、测试和部署的状态,收集有关构建时间、测试覆盖率、部署成功率等关键指标的数据。

例如,当代码提交触发构建任务时,OpenTelemetry 可以自动监控构建过程的每一个步骤,并记录构建时间、依赖项的安装情况、编译错误等信息。团队可以利用这些数据快速识别构建流程中的瓶颈,并进行相应的优化。

4. 运维阶段的实时监控与问题诊断

在生产环境中,OpenTelemetry 提供了实时的系统监控和问题诊断功能。运维团队可以通过 OpenTelemetry 收集应用程序的运行数据,包括 CPU 使用率、内存消耗、请求延迟、错误率等各类度量数据,并利用分布式追踪来深入分析系统的性能瓶颈。

在一个复杂的分布式系统中,应用的不同组件可能分布在多个服务和节点上,传统的监控工具难以全面洞察整个系统的状态。而 OpenTelemetry 的分布式追踪功能能够帮助运维人员跟踪每个请求的路径,深入了解请求在各个微服务之间的传播情况。

OpenTelemetry 与 GitOps 的协同效应

OpenTelemetry 和 GitOps 是 DevOps 实践中的两个重要组成部分,它们在自动化和可观测性方面的结合,带来了显著的协同效应。

1. GitOps 中的变更触发可观测性

在 GitOps 工作流中,所有的变更都通过 Git 提交 来管理。OpenTelemetry 可以提供关键的可观测性支持,帮助团队实时监控变更的影响。

通过 OpenTelemetry,团队可以在变更触发时自动开始收集遥测数据。这包括从代码提交到最终部署过程中,各个阶段的系统性能指标、资源使用情况、API 调用的响应时间等。这样,团队不仅可以全面了解每次变更对系统的影响,还能够在变更失败或出现性能问题时迅速回滚,减少对用户的影响。

2. GitOps 部署过程的全面监控

在 GitOps 的自动化部署流程中,OpenTelemetry 的实时监控功能能够帮助团队跟踪每次部署的状态,确保部署过程的可见性。OpenTelemetry 可以实时监控这些部署的具体执行情况,如部署时间、资源分配情况、各个服务的启动和运行状态等,确保每一个部署步骤都在可控范围内。

3. GitOps 回滚操作的精确可观测性

GitOps 另一个显著的优势是自动化回滚。当新的变更导致系统问题时,GitOps 工具可以迅速将系统回滚到之前的稳定状态。而 OpenTelemetry 提供的可观测性数据可以帮助团队在回滚之前和回滚之后,精确对比系统的运行状况,从而更好地理解问题的根源并及时修复。

4. 环境差异的监控与优化

OpenTelemetry 提供了对不同环境的深入监控能力,帮助团队识别这些差异,并确保各环境的运行状况与期望一致。

通过在每个环境中部署 OpenTelemetry,团队可以收集不同环境的性能数据,如网络延迟、资源消耗、微服务调用链路等,并进行对比分析。例如,团队可以监控同一个微服务在测试环境与生产环境中运行的性能,识别出由于资源分配、网络配置等引起的性能差异,进而优化生产环境的配置。

OpenTelemetry、左移与 GitOps 的未来发展

随着 DevOps 实践的不断发展,OpenTelemetry、左移(Shift Left) 和 GitOps 之间的结合正在重塑软件开发、测试、部署和运维的方式。

1. 更广泛的集成与工具支持

随着 OpenTelemetry 的普及,未来我们将看到它与越来越多的开发和运维工具深度集成。OpenTelemetry 将与更多的工具进行集成,使得自动化可观测性成为软件开发和运维的标准做法。

2. 更智能的分析与自动化运维

OpenTelemetry 与 AI(人工智能) 和 机器学习(ML) 技术的结合,将为 DevOps 团队带来更多智能化的功能。通过分析 OpenTelemetry 所收集的大量遥测数据,AI/ML 系统可以自动识别性能瓶颈、故障模式,甚至能够预测潜在的系统风险。

3. 左移策略的进一步强化

未来,随着 OpenTelemetry 的功能不断增强,左移策略将更加深入地渗透到 DevOps 流程的各个环节。开发人员将能够在编写代码的同时,实时获取系统的性能反馈和可观测性数据,而这些数据将帮助他们在开发阶段就进行调优和改进。

4. GitOps 与 OpenTelemetry 的深度融合

GitOps 和 OpenTelemetry 的结合将不仅仅停留在基础设施管理和应用部署上,它们的协同效应还将进一步推动 DevOps 实践中的智能化运维和自动化部署。随着 GitOps 的普及,越来越多的团队将采用 Git 作为声明式基础设施的唯一真实来源,而 OpenTelemetry 提供的遥测数据将帮助团队在部署过程中持续监控系统状态,并在需要时自动进行调整。

5. OpenTelemetry 社区与生态系统的壮大

未来,OpenTelemetry 社区将继续壮大,并吸引更多的开发者和工具集成商参与其中。作为 CNCF 旗下的核心项目之一,OpenTelemetry 已经逐渐成为云原生生态中的标准可观测性框架。随着社区的扩展,更多的开源工具和商业化平台将与 OpenTelemetry 深度集成,提供更加多样化和专业化的功能支持。

结论

OpenTelemetry 正在引领一场 DevOps 流程中的可观测性革命,使得 DevOps 流程不再局限于传统的运维监控,而是演变为全生命周期、全方位的系统洞察与优化。

无论是通过监控代码的性能、测试系统的健壮性,还是在实际生产环境中优化部署,OpenTelemetry 提供的数据驱动能力,使得 DevOps 团队能够在各个阶段做出更好的决策。此外,OpenTelemetry与左移、GitOps 的结合,推动了开发和运维实践的持续改进,使团队能够以更敏捷、更可靠的方式交付高质量的软件系统。

对于任何希望提升系统可见性、优化流程效率并保持技术竞争力的团队来说,拥抱 OpenTelemetry 及其赋能的可观测性革命,无疑是迈向未来的关键一步。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2245062.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

计算机视觉算法——基于深度学习的高精地图算法(MapTRv2 / PivotNet / BeMapNet)

计算机视觉算法——基于深度学习的高精地图算法(MapTRv2 / PivotNet / BeMapNet) 计算机视觉算法——基于深度学习的高精地图算法(MapTRv2 / PivotNet / BeMapNet)1. MapTRv21.1 网络结构及特点1.2 Decoupled Self-Attention1.3 O…

nodejs21: 快速构建自定义设计样式Tailwind CSS

Tailwind CSS 是一个功能强大的低级 CSS 框架,只需书写 HTML 代码,无需书写 CSS,即可快速构建美观的网站。 1. 安装 Tailwind CSS React 项目中安装 Tailwind CSS: 1.1 安装 Tailwind CSS 和相关依赖 安装 Tailwind CSS: npm…

《Python网络安全项目实战》项目6 编写密码工具程序

《Python网络安全项目实战》项目6 编写密码工具程序 项目6 编写密码工具程序任务6.1 猜数字游戏任务描述任务分析任务实施6.1.1 编写基本的猜数字程序 6.1.2 为猜数字程序加入连续猜数的功能6.1.3 测试并修改程序6.1.4 给程序增加注释 任务拓展 任务6.2 编写密码工具程序任务描…

MATLAB蒙特卡洛仿真计算投资组合的VaR(Value at Risk )

1. 计算VaR简介 VaR(Value at Risk),一般被称为“风险价值”或“在险价值”,是指在一定的置信水平下,某一金融资产(或证券组合)在未来特定的一段时间内的最大可能损失。VaR提供了一个具体的数值…

【linux学习指南】VSCode部署Ubantu云服务器,与Xshell进行本地通信文件编写

文章目录 📝前言🌠 步骤🌉测试同步 🚩总结 📝前言 本文目的是讲使用Vscode连接Ubantu,与本地Xshell建立通信同步文件编写。 查看本机系统相关信息: cat /etc/lsb*DISTRIB_IDUbuntu: 表示这是 Ubuntu 发行…

stm32下的ADC转换(江科协 HAL版)

十二. ADC采样 文章目录 十二. ADC采样12.1 ADC的采样原理12.2 STM32的采样基本过程1.引脚与GPIO端口的对应关系2.ADC规则组的四种转换模式(**)2.2 关于转换模式与配置之间的关系 12.3 ADC的时钟12.4 代码实现(ADC单通道 & ADC多通道)1. 单通道采样2. 多通道采样 19.ADC模数…

DockerFile与容器构建技术

一、 Docker架构 二、容器镜像分类 操作系统类 CentOSUbuntu在dockerhub下载或自行制作 应用类 TomcatNginxMySQLRedis 三、容器镜像获取的方法 主要有以下几种: 1、在DockerHub直接下载 2、把操作系统中文件系统打包为容器镜像 3、把正在运行的容器打包为容器镜…

分布式数据库中间件可以用在哪些场景呢

在数字化转型的浪潮中,企业面临着海量数据的存储、管理和分析挑战。华为云分布式数据库中间件(DDM)作为一款高效的数据管理解决方案,致力于帮助企业在多个场景中实现数据的高效管理和应用,提升业务效率和用户体验。九河…

jmeter常用配置元件介绍总结之断言

系列文章目录 1.windows、linux安装jmeter及设置中文显示 2.jmeter常用配置元件介绍总结之安装插件 3.jmeter常用配置元件介绍总结之线程组 4.jmeter常用配置元件介绍总结之函数助手 5.jmeter常用配置元件介绍总结之取样器 6.jmeter常用配置元件介绍总结之jsr223执行pytho…

项目技术栈-解决方案-web3去中心化

web3去中心化 Web3 DApp区块链:钱包:智能合约:UI:ETH系开发技能树DeFi应用 去中心化金融P2P 去中心化网络参考Web3 DApp 区块链: 以以太坊(Ethereum)为主流,也包括Solana、Aptos等其他非EVM链。 区块链本身是软件,需要运行在一系列节点上,这些节点组成P2P网络或者半…

多目标优化算法:多目标蛇鹫优化算法(MOSBOA)求解DTLZ1-DTLZ9,提供完整MATLAB代码

一、蛇鹫优化算法 蛇鹫优化算法(Secretary Bird Optimization Algorithm,简称SBOA)由Youfa Fu等人于2024年4月发表在《Artificial Intelligence Review》期刊上的一种新型的元启发式算法。该算法旨在解决复杂工程优化问题,特别是…

数据集-目标检测系列- 花卉 鸡蛋花 检测数据集 frangipani >> DataBall

数据集-目标检测系列- 花卉 鸡蛋花 检测数据集 frangipani >> DataBall DataBall 助力快速掌握数据集的信息和使用方式,会员享有 百种数据集,持续增加中。 贵在坚持! 数据样例项目地址: * 相关项目 1)数据集…

【Pikachu】SSRF(Server-Side Request Forgery)服务器端请求伪造实战

尽人事以听天命 1.Server-Side Request Forgery服务器端请求伪造学习 SSRF(服务器端请求伪造)攻击的详细解析与防范 SSRF(Server-Side Request Forgery,服务器端请求伪造) 是一种安全漏洞,它允许攻击者通…

Element Plus

快速入门: 然后我在src下创建了一个Button.vue文件,再去Element-plus官网查找组件的源码 常用组件 表格: <script lang"ts" setup> import {Delete,Edit, } from element-plus/icons-vueconst tableData [{title: 标题1,category: 时事,time: 2000-…

界面控件DevExpress WPF中文教程:网格视图数据布局的列和卡片字段

DevExpress WPF拥有120个控件和库&#xff0c;将帮助您交付满足甚至超出企业需求的高性能业务应用程序。通过DevExpress WPF能创建有着强大互动功能的XAML基础应用程序&#xff0c;这些应用程序专注于当代客户的需求和构建未来新一代支持触摸的解决方案。 无论是Office办公软件…

实现两个表格的数据传递(类似于穿梭框)

类似于element的 第一个表格信息以及按钮&#xff1a; <div style"height: 80%"><el-table :data"tableData1" border :cell-style"{text-align:center}" style"width: 100%;"ref"multipleTable1"selection-chang…

NPOI 实现Excel模板导出

记录一下使用NPOI实现定制的Excel导出模板&#xff0c;已下实现需求及主要逻辑 所需Json数据 对应参数 List<PurQuoteExportDataCrInput> listData [{"ItemName": "电缆VV3*162*10","Spec": "电缆VV3*162*10","Uom":…

凸函数与深度学习调参

问题1&#xff1a;如何区分凸问题和凹问题&#xff1f; 问题2&#xff1a;深度学习如何区分调参&#xff1f;

DBeaver MACOS 安装 并连接到docker安装的mysql

官网下载&#xff1a;Download | DBeaver Community 网盘下载&#xff1a;链接: https://pan.baidu.com/s/15fAhbflHO-AGc-uAnc3Rjw?pwdbrz9 提取码: brz9 下载驱动 连接测试 报错 null, message from server: "Host 172.17.0.1 is not allowed to connect to this M…

php:使用socket函数创建WebSocket服务

一、前言 闲来无事&#xff0c;最近捣鼓了下websocket&#xff0c;但是不希望安装第三方类库&#xff0c;所以打算用socket基础函数创建个服务。 二、构建websocket服务端 <?phpclass SocketService {// 默认的监听地址和端口private $address 0.0.0.0;private $port 8…