DevOps全面综述:从概念到实践

一、背景与概述

file

1.1 DevOps的起源与发展

DevOps(Development and Operations的缩写)是软件工程领域中的一种文化和实践方法,旨在促进开发团队与运维团队之间的协作,从而实现更高效、更可靠的软件交付。DevOps起源于敏捷软件开发方法论,并在过去十年中迅速发展成为一种广泛采用的实践。

DevOps的起源可以追溯到2009年,比利时的一次名为“DevOpsDays”的会议。会议的主要发起人Patrick Debois希望通过这次会议来解决开发和运维之间的隔阂问题。会议的成功标志着DevOps概念的诞生。此后,随着云计算、容器技术和持续交付(Continuous Delivery)的兴起,DevOps逐渐成为企业实现数字化转型的关键驱动力。

1.2 DevOps的基本原则与目标

DevOps的核心目标是通过优化开发和运维之间的协作,提升软件交付速度、质量和可靠性。为了实现这一目标,DevOps提出了一系列的基本原则:

  1. 持续集成与持续交付(CI/CD):持续集成(Continuous Integration, CI)是一种软件开发实践,开发者频繁地将代码集成到主干中,并通过自动化测试来确保代码质量。持续交付(Continuous Delivery, CD)则是在CI的基础上,进一步实现软件的自动化部署。CI/CD能够显著缩短交付周期,降低发布风险,提高软件的可用性和稳定性。

  2. 基础设施即代码(IaC):基础设施即代码(Infrastructure as Code, IaC)是指使用代码化的方式来管理和配置基础设施资源。这种方法使得基础设施的管理变得更加灵活和自动化,减少了人为错误,提高了环境的一致性。常见的IaC工具包括Terraform、Ansible和Puppet等。

  3. 监控与日志记录:高效的监控和日志记录是DevOps的重要组成部分。通过实时监控系统性能和收集日志数据,团队可以及时发现和解决潜在问题,确保系统的稳定运行。常用的监控工具包括Prometheus、Grafana和ELK Stack(Elasticsearch, Logstash, Kibana)等。

  4. 自动化测试:自动化测试是确保软件质量的关键。通过编写自动化测试用例,开发者可以在每次代码变更时进行全面的测试,从而快速发现和修复缺陷。自动化测试涵盖单元测试、集成测试和端到端测试等多个层次。

  5. 文化和协作:DevOps不仅是一套技术实践,更是一种文化变革。它强调团队之间的协作和透明度,鼓励开发者和运维人员共同承担责任,推动持续改进。成功的DevOps实施通常伴随着组织结构和流程的调整,以打破传统的“信息孤岛”,促进跨职能团队的协作。

1.3 DevOps的价值与影响

DevOps的实施为企业带来了诸多显著的价值和影响:

  1. 加速交付周期:通过自动化和持续集成,DevOps显著缩短了软件交付的周期,使企业能够更快速地响应市场需求和客户反馈。

  2. 提升软件质量:自动化测试和持续监控确保了软件的高质量和高可靠性,减少了生产环境中的故障和停机时间。

  3. 提高团队效率:DevOps促进了开发和运维团队之间的协作,减少了沟通障碍和重复劳动,提高了整体团队的效率和生产力。

  4. 增强客户满意度:更快速的交付、更高的可靠性和更及时的响应能力,显著提升了客户的满意度和信任度。

  5. 支持创新:DevOps为企业提供了更高的灵活性和敏捷性,使其能够更快地尝试新技术和新业务模式,推动创新发展。

通过深入理解DevOps的起源、基本原则和核心价值,我们可以更好地实施和推广这一重要的技术实践,为企业的数字化转型和持续创新提供坚实的基础。在接下来的章节中,我们将详细探讨DevOps的核心实践、工具和技术,进一步揭示其在实际应用中的具体方法和最佳实践。

二、核心实践

2.1 持续集成(CI)

持续集成(Continuous Integration, CI)是一种软件开发实践,旨在通过频繁地将代码集成到主干分支来快速检测并修复问题,从而提高软件开发效率和质量。在持续集成过程中,开发者会频繁地将代码提交到版本控制系统中,每次提交都会触发自动化构建和测试流程,以确保新代码与现有代码的兼容性。

2.1.1 核心概念

  • 自动化构建:每次代码提交后,系统会自动进行构建,生成可执行的应用程序或库。这一步骤通常包括编译代码、打包依赖项和生成工件。

  • 自动化测试:在构建完成后,系统会自动运行预定义的测试套件,以验证代码的正确性。这些测试通常包括单元测试、集成测试和回归测试。

  • 快速反馈:持续集成的一个重要目标是提供快速反馈。通过及时发现和修复代码中的问题,开发者可以更快地迭代和改进代码。

2.1.2 实践方法

  • 频繁提交代码:开发者应当频繁地将代码提交到版本控制系统中,每次提交的代码改动应当尽可能小且独立。

  • 维护绿色主干:主干分支应始终保持可构建和通过所有测试。任何导致构建失败的提交都应立即修复。

  • 自动化构建和测试工具:选择和配置适当的工具来实现自动化构建和测试。例如,Jenkins、Travis CI 和 CircleCI 是常见的 CI 工具。

2.2 持续交付(CD)

持续交付(Continuous Delivery, CD)是持续集成的延伸,旨在通过自动化部署流水线,将软件交付到生产环境中,使其随时处于可发布状态。持续交付不仅关注代码的集成和测试,还包括发布管理和部署自动化。

2.2.1 核心概念

  • 部署流水线:部署流水线是持续交付的核心,包含从代码提交到软件发布的所有自动化流程。每个流水线阶段都包括构建、测试、部署和验证。

  • 自动化部署:通过自动化工具,将构建好的应用程序部署到不同的环境中(例如开发、测试和生产环境)。

  • 可发布的工件:每个版本的代码都应生成一个可发布的工件,这些工件应经过充分测试,确保其质量和稳定性。

2.2.2 实践方法

  • 部署策略:采用蓝绿部署、金丝雀发布和滚动更新等策略,确保新版本的平滑发布和回滚。

  • 环境一致性:通过基础设施即代码(IaC)确保不同环境的一致性,避免环境差异导致的问题。

  • 自动化测试覆盖:在部署流水线的每个阶段执行全面的自动化测试,包括功能测试、性能测试和安全测试。

2.3 基础设施即代码(IaC)

基础设施即代码(Infrastructure as Code, IaC)是指使用代码来定义和管理计算基础设施。IaC 使得基础设施的配置和部署像应用程序代码一样可版本控制、可审计和可自动化。

2.3.1 核心概念

  • 声明式与命令式:IaC 有两种主要实现方式:声明式和命令式。声明式 IaC 描述了目标状态(例如,使用 Terraform),而命令式 IaC 则描述了实现目标状态的步骤(例如,使用 Ansible)。

  • 可重复性和一致性:通过 IaC,基础设施配置可以重复执行,确保不同环境之间的一致性,减少人为错误。

  • 版本控制:IaC 脚本应存储在版本控制系统中,与应用程序代码一起管理,以实现审计和回滚。

2.3.2 实践方法

  • 选择适当的工具:常见的 IaC 工具包括 Terraform、Ansible、Puppet 和 Chef。选择适合团队需求和技术栈的工具。

  • 模块化和重用:编写模块化的 IaC 代码,使得不同项目和环境可以重用相同的配置。

  • 自动化流水线集成:将 IaC 集成到持续交付流水线中,实现基础设施的自动化部署和管理。

2.4 监控与日志记录

高效的监控和日志记录是确保系统稳定性和性能优化的关键。通过持续监控系统指标和收集日志数据,团队可以及时发现和解决潜在问题。

2.4.1 核心概念

  • 监控:监控包括实时跟踪系统性能指标(如 CPU 使用率、内存使用率、响应时间和错误率)和业务指标(如交易量和用户活动)。常用的监控工具包括 Prometheus、Grafana 和 Datadog。

  • 日志记录:日志记录是指收集和存储系统生成的日志数据,以便进行故障排除和审计。日志管理工具如 ELK Stack(Elasticsearch, Logstash, Kibana)和 Splunk 可以帮助团队集中管理和分析日志数据。

  • 告警和通知:通过设置告警规则,当系统指标超过预定义的阈值时,自动发送通知,提醒团队采取行动。

2.4.2 实践方法

  • 建立监控仪表盘:使用 Grafana 等工具创建可视化仪表盘,实时展示关键性能指标。

  • 集中日志管理:配置 Logstash 或 Fluentd 将日志数据集中收集到 Elasticsearch 中,并使用 Kibana 进行分析和可视化。

  • 自动化告警:设置告警规则和通知策略,通过电子邮件、短信或即时通讯工具(如 Slack)及时通知团队。

2.5 自动化测试

自动化测试是确保软件质量和稳定性的关键实践。通过编写自动化测试用例,开发团队可以在每次代码变更时快速检测和修复缺陷。

2.5.1 核心概念

  • 测试金字塔:测试金字塔是指将自动化测试分为不同层次,从下至上分别为单元测试、集成测试和端到端测试。单元测试覆盖最小的代码单元,执行速度最快;集成测试验证多个模块的协同工作;端到端测试则模拟用户操作,验证整个系统的功能。

  • 测试覆盖率:测试覆盖率是指被自动化测试覆盖的代码比例。高覆盖率的测试可以更有效地检测缺陷。

  • 持续测试:在持续集成和持续交付流水线中集成自动化测试,实现代码变更后的持续验证。

2.5.2 实践方法

  • 编写高质量测试用例:确保测试用例覆盖关键功能和边界条件,并保持测试的独立性和可维护性。

  • 使用适当的测试框架:选择适合项目需求的测试框架和工具,如 JUnit、TestNG、Selenium 和 Cypress。

  • 集成测试报告:配置持续集成工具生成测试报告,并在每次构建后自动发送给团队,确保所有成员了解测试结果。

通过详细探讨DevOps的核心实践,我们可以更好地理解和实施这些技术,从而提升软件开发和运维的效率和质量。在下一章节中,我们将深入探讨DevOps所使用的工具和技术,进一步揭示其在实际应用中的具体方法和最佳实践。

三、工具和技术

file

3.1 源代码管理工具

3.1.1 Git

Git是目前最流行的分布式版本控制系统,广泛用于源代码管理和版本控制。它的设计初衷是为了高效地处理大型项目,特别是在分布式团队环境中。

核心概念

  • 分布式版本控制:每个开发者的工作目录都是一个完整的代码仓库,包括代码的所有版本历史。这种结构使得Git特别适合于分布式开发团队。

  • 分支与合并:Git的分支(branch)模型非常灵活,支持轻量级的分支操作,使得团队可以方便地进行并行开发和功能分离。合并(merge)操作则将不同分支的工作成果整合在一起。

  • 暂存区:Git引入了暂存区(staging area)的概念,允许开发者在提交(commit)代码之前对其进行整理和校验。

实践方法

  • 工作流:采用合适的Git工作流(如Git Flow、GitHub Flow或GitLab Flow)来规范团队的开发和发布流程。

  • 代码审查:使用Pull Request或Merge Request进行代码审查,确保代码质量和一致性。

  • 持续集成:将Git仓库与CI工具集成,每次代码提交自动触发构建和测试。

3.2 CI/CD工具

3.2.1 Jenkins

Jenkins是一个开源的自动化服务器,广泛用于实现持续集成和持续交付。它支持通过插件扩展功能,适用于各种构建、部署和自动化任务。

核心概念

  • 管道(Pipeline):Jenkins Pipeline是用于定义持续集成和持续交付过程的脚本化工具,支持复杂的构建流程和多阶段管道。

  • 插件系统:Jenkins拥有丰富的插件生态系统,可以与各种工具和服务集成,如Git、Docker、Kubernetes等。

  • 分布式构建:Jenkins支持分布式构建,可以将构建任务分配到多个节点上执行,提高构建速度和效率。

实践方法

  • 管道脚本:编写声明式或脚本式的Jenkins Pipeline,以定义和自动化CI/CD流程。

  • 管理插件:选择和配置适当的插件,以扩展Jenkins的功能并集成所需工具。

  • 监控和通知:配置Jenkins监控构建状态,并通过邮件、Slack等工具发送通知。

3.2.2 Travis CI

Travis CI是一款基于云的持续集成服务,特别适用于开源项目。它与GitHub紧密集成,支持多语言、多平台的构建和测试。

核心概念

  • YAML配置文件:Travis CI使用.travis.yml文件定义构建和测试流程,配置简单直观。

  • 自动化测试:每次代码提交或Pull Request都会触发自动化测试,确保代码质量。

  • 多语言支持:Travis CI支持多种编程语言和框架,适用于不同技术栈的项目。

实践方法

  • 配置文件编写:根据项目需求编写.travis.yml文件,定义构建、测试和部署步骤。

  • 集成GitHub:将GitHub仓库与Travis CI连接,自动触发构建和测试。

  • 测试报告:配置测试报告和覆盖率工具,将结果集成到Travis CI中。

3.3 配置管理工具

3.3.1 Ansible

Ansible是一种简单而强大的开源自动化工具,用于配置管理、应用部署和任务自动化。它采用无代理(agentless)的架构,通过SSH进行操作。

核心概念

  • 剧本(Playbook):Ansible使用YAML格式的剧本来定义自动化任务和配置,结构清晰易读。

  • 模块(Module):Ansible提供了大量预定义的模块,用于管理系统资源、应用和服务。

  • 清单(Inventory):清单文件列出了需要管理的主机和组,Ansible会根据清单执行相应的任务。

实践方法

  • 编写剧本:根据需求编写Ansible剧本,定义任务和配置。

  • 管理清单:维护清单文件,列出需要管理的主机和组。

  • 自动化流程:将Ansible集成到CI/CD流程中,实现自动化配置和部署。

3.3.2 Puppet

Puppet是一种流行的配置管理工具,使用声明式语言来定义系统配置。它采用客户端-服务器架构,通过Puppet Master和Puppet Agent进行通信。

核心概念

  • 清单(Manifest):Puppet使用清单文件(Manifest)定义系统配置,使用Puppet DSL(Domain Specific Language)编写。

  • 模块(Module):模块是Puppet的可重用单元,包含类和定义,用于管理特定资源和服务。

  • 报告与日志:Puppet生成详细的报告和日志,记录配置应用过程中的状态和结果。

实践方法

  • 编写清单:使用Puppet DSL编写清单文件,定义系统配置和资源管理。

  • 创建模块:编写和维护Puppet模块,实现配置的重用和分享。

  • 集成Puppet:将Puppet与CI/CD流程集成,实现自动化配置管理。

3.3.3 Chef

Chef是一种配置管理工具,使用Ruby编写的DSL来定义基础设施配置。它采用客户端-服务器架构,通过Chef Server和Chef Client进行通信。

核心概念

  • 食谱(Recipe):Chef使用食谱(Recipe)定义系统配置和资源管理,食谱由资源和提供者组成。

  • 运行列表(Run List):运行列表是节点在配置过程中执行的食谱和角色的顺序列表。

  • 数据包(Data Bag):数据包用于存储全局配置数据,供食谱在运行时使用。

实践方法

  • 编写食谱:使用Chef DSL编写食谱,定义系统配置和资源管理。

  • 管理运行列表:配置运行列表,确保节点按顺序执行食谱和角色。

  • 数据包管理:创建和维护数据包,存储全局配置数据。

3.4 容器与编排

3.4.1 Docker

Docker是一种开源容器化平台,通过容器技术实现应用程序的轻量级、可移植和一致的运行环境。Docker在开发、测试和生产环境中广泛应用,显著提高了部署和管理效率。

核心概念

  • 镜像(Image):Docker镜像是包含应用程序及其依赖项的只读模板,用于创建Docker容器。

  • 容器(Container):Docker容器是运行中的应用实例,基于镜像创建,具有独立的文件系统和资源隔离。

  • Dockerfile:Dockerfile是用于构建镜像的脚本文件,包含一系列指令,定义镜像的构建过程。

实践方法

  • 编写Dockerfile:根据应用需求编写Dockerfile,定义镜像构建步骤。

  • 构建和管理镜像:使用docker build命令构建镜像,使用docker push命令将镜像推送到镜像仓库。

  • 运行和管理容器:使用docker run命令启动容器,使用docker-compose编排和管理多容器应用。

3.4.2 Kubernetes

Kubernetes是一个开源的容器编排平台,用于自动化容器化应用的部署、扩展和管理。它通过集群管理和自动化调度,提供高可用性和弹性。

核心概念

  • 节点(Node):Kubernetes集群由多个节点组成,每个节点运行一个或多个容器。

  • Pod:Pod是Kubernetes中最小的部署单元,包含一个或多个紧密相关的容器,具有共享的网络和存储。

  • 服务(Service):服务定义了一组Pod的访问策略,通过负载均衡和服务发现,实现应用的高可用性和可扩展性。

  • 控制器(Controller):控制器管理Pod的生命周期,常见的控制器包括Deployment、StatefulSet和DaemonSet。

实践方法

  • 部署配置:编写Kubernetes配置文件(YAML格式),定义Pod、Service和Controller等资源。

  • 管理集群:使用kubectl命令行工具管理Kubernetes集群,执行部署、扩展和更新操作。

  • 监控与调试:集成监控工具(如Prometheus和Grafana)和日志工具(如ELK Stack)

四、DevOps文化与组织

file

4.1 团队协作与沟通

DevOps不仅仅是一套技术实践,更是一种文化变革。其核心是打破开发(Development)与运维(Operations)之间的隔阂,促进跨职能团队的协作与沟通,从而实现持续交付和高效运营。

核心概念

  • 跨职能团队:DevOps提倡形成由开发、运维、测试、安全等不同角色组成的跨职能团队,确保各方面的专业知识和技能能够融合在一起,共同完成从开发到运营的全生命周期管理。

  • 持续反馈:通过持续集成和持续交付,团队可以快速获得反馈,及时发现和解决问题。这种持续反馈机制有助于提高整个团队的响应速度和改进效率。

  • 透明度和信任:DevOps文化强调透明度和信任。团队成员应当共享信息和知识,建立开放的沟通渠道,减少信息孤岛和沟通障碍。

实践方法

  • 每日站会:通过每日站会(Daily Stand-up)或Scrum会议,团队成员分享工作进展、计划和障碍,促进信息共享和问题解决。

  • 共享工具和平台:使用共享的工具和平台(如JIRA、Confluence、Slack等),记录和跟踪任务、文档和沟通,提高协作效率。

  • 持续改进:定期举行回顾会议(Retrospective),总结经验教训,提出改进建议,推动团队的持续改进。

4.2 DevOps文化建设

DevOps文化的建设是一个长期的过程,需要企业从组织结构、管理模式和员工心态等多个方面进行调整和优化。

核心概念

  • 领导支持:成功的DevOps实施需要企业高层领导的支持和推动。领导层应当明确DevOps的战略目标和优先级,为团队提供必要的资源和授权。

  • 变革管理:DevOps是一场文化变革,涉及到企业的方方面面。变革管理方法(如ADKAR模型)可以帮助团队顺利应对和适应变革。

  • 学习和发展:企业应当鼓励员工不断学习和提升技能,通过培训、研讨会、社区活动等方式,培养团队的DevOps能力。

实践方法

  • 设立DevOps领导职位:指定DevOps负责人或团队,统筹规划和推动DevOps实践的实施和优化。

  • 培训和教育:定期组织内部培训和外部学习,帮助团队成员掌握DevOps工具和方法,提升整体技能水平。

  • 奖励和认可:建立激励机制,对在DevOps实践中表现突出的团队和个人给予奖励和认可,鼓励积极参与和贡献。

4.3 组织变革与角色转变

实施DevOps通常需要对组织结构和角色职责进行调整,以适应新的工作方式和流程。

核心概念

  • 职责融合:DevOps强调开发与运维的职责融合,打破传统的部门壁垒。开发人员需要了解运维知识,运维人员需要参与开发过程。

  • 新角色引入:DevOps引入了一些新的角色,如Site Reliability Engineer(SRE)、DevOps Engineer等,这些角色在跨职能团队中扮演着关键的桥梁作用。

  • 流程自动化:通过自动化工具和流程,减少人为干预,提高工作效率和一致性。

实践方法

  • 重新定义角色职责:根据DevOps实践的需求,重新定义和分配团队成员的角色和职责,确保每个环节都有明确的责任人。

  • 建立跨职能团队:组建由开发、运维、测试、安全等不同职能人员组成的团队,共同负责从开发到运营的全生命周期管理。

  • 推动流程自动化:引入和推广自动化工具和流程,实现持续集成、持续交付和持续监控,减少人为错误,提高效率和一致性。

4.4 文化变革的挑战与解决方案

尽管DevOps带来了显著的优势,但在实践过程中,企业可能会面临各种挑战。理解这些挑战并采取相应的解决方案,是成功实施DevOps的关键。

核心概念

  • 文化抵触:传统的企业文化可能与DevOps的协作、透明和持续改进理念相冲突,导致实施过程中的阻力。

  • 技能缺乏:实施DevOps需要团队具备广泛的技能,从开发、运维到安全和自动化,不同领域的知识交叉和融合是一个挑战。

  • 工具复杂性:DevOps工具链复杂多样,选择和集成适合企业需求的工具需要深入的了解和规划。

解决方案

  • 领导推动变革:企业高层领导应当积极支持和推动DevOps变革,营造开放和信任的文化氛围。

  • 渐进式实施:采用渐进式的实施策略,从小规模试点开始,逐步推广和优化,积累经验和成果。

  • 持续培训和学习:通过持续的培训和学习,提升团队的技能水平和DevOps能力,建立内部知识分享和交流机制。

  • 选择适合的工具:根据企业的实际需求和技术栈,选择和集成适合的DevOps工具,并确保工具链的可扩展性和灵活性。

文章转载自:techlead_krischang

原文链接:https://www.cnblogs.com/xfuture/p/18228538

体验地址:引迈 - JNPF快速开发平台_低代码开发平台_零代码开发平台_流程设计器_表单引擎_工作流引擎_软件架构

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

Mac 使用Docker安装Elasticsearch、Kibana

安装ElasticSearch 通过docker安装es docker pull elasticsearch:8.6.2 在本地创建elasticsearch.yml文件 mkdir /Users/ky/Documents/learn/es/elasticsearch.yml 编辑yml文件内容 http: host: 0.0.0.0 xpack.security.enabled: false xpack.security.enrollment.enabled: t…

阿赵UE引擎C++编程学习笔记——生成Actor

大家好,我是阿赵。   使用Unity引擎的朋友应该都知道,Unity引擎的预设资源叫做Prefab,然后把预设资源生成在场景的命令是:GameObject.Instantiate。UE引擎里面,并没有统一的Prefab类型,而是通过各种蓝图来…

DHCP及FTP

一、1、DHCP动态主机配置协议:通常被应用在大型的局域网络环境中,主要作用是集中地管理、分配IP地址,使网络环境中的主机动态的获得IP地址、Gateway地址、DNS服务器地址等信息,并能够提升地址的使用率。 2、DHCP 的优点&#xff…

数据中心的中台前端风格大屏设计开发

数据中心的中台前端风格大屏设计开发

秋招突击——算法打卡——5/28——复习{Z字形变换、两数之和}——新做:{整数反转、字符串转整数}

文章目录 复习Z字形变换实现代码参考代码 两数之和复习代码 新作整数反转个人实现实现代码 参考做法字符串转换整数个人解法 分析总结 复习 Z字形变换 实现代码 这里使用了他的思想,但是没有用他的代码,虽然已经比上次简洁了,但是还是不够&…

【创业新趋势】萤瓴优选,抓住2024年造富新机遇!

​在当下这个充满变革与机遇的时代,创业者们纷纷寻找着下一个造富的新风口。而2024年,一个备受瞩目的创业新星正在冉冉升起——萤瓴优选。这款短视频变现任务App以其独特的 keJ0277 商业模式和创新理念,正引领着创业新趋势,成为众…

java多线程初探

文章目录 countDownLatchvolatileCASjdk1.6对synchronized的优化自旋锁锁消除锁粗化轻量级锁偏向锁 java AtomicBoolean compareAndSet Demothreadlocalconcurrent queue原子操作是否需要同步copyonwrite容器可重入锁公平与非公平并发编程步骤 countDownLatch 此类位于java.ut…

python入门2

文章目录 前言一、集合与字典1、集合2、字典3、字典内置方法4、内置数据结构总结 二、控制流程1、结构流程概述2、分支结构3、循环结构 总结 前言 本文将介绍Python中的集合与字典以及控制流程。集合是一种无序且不重复的数据类型,它可以用于存储一组元素&#xff…

echarts多X轴, 多Y轴

需要的效果 原始数据 props.monitorData:{"lst_monitor_flow": ["152.68","207.64","103.82","21.21","33.81","40.71","273.80","208.66","104.33","15.80"…

如何在vs code中安装JavaFX

目录 下载JavaFX 配置vs code工程 编写测试代码 下载JavaFX 网站链接:https://openjfx.io 选择如下的版本

傲医医疗集成引擎 Rhapsody 在超融合信创平台表现如何?

作者:SmartX 商业团队 黄玉辉 随着越来越多的医疗用户基于超融合基础设施实现 IT 基础架构信创转型,超融合信创架构在医疗业务场景中的实际表现也得到更多关注。尤其是集成平台业务场景——作为三甲医院互联互通评级中不可缺少的核心业务系统&#xff0…

指针的认识(传值调用和传地址调用)

学习指针的目的是使用指针解决问题,那什么问题,非指针不可呢? 当要求写个函数来交换两个变量的值时,我们稍加思索,可以写成如下函数: void Swap1(int x, int y) {int tmp x;x y;y tmp; } 那么我们来进…

HBuilderX编写APP二、获取数据代码以及如何打包发行app

<template><!-- 修改APP名字的地方在pages.json文件里面 --><!-- <view class"content"><view class"">温度{{temp}} ℃ </view> //添加温度显示<view class"">湿度{{humi}} % </view> //添加湿度…

“OZON售后管理:加速处理流程,优化顾客售后体验“

在跨境电商领域欣欣向荣的发展浪潮中&#xff0c;退货及其它售后问题成为了许多卖家心头的一大困扰。为了解决卖家在处理退货售后时所面临的问题&#xff0c;无忧易售ERP上线了专为Ozon平台设计的退货规则&#xff0c;旨在帮助卖家们更好的优化售后服务、提升运营效率。 无忧易…

支付通道接口被脚本刷,如何解决

在数字交易日益频繁的今天&#xff0c;支付通道接口的安全性成为商家和平台不容忽视的问题。当支付接口被脚本恶意刷单时&#xff0c;不仅会导致财务损失&#xff0c;还可能引发合规风险和客户信任危机。本文将探讨支付接口被脚本刷单的原因、识别方法、应急处理方案&#xff0…

弘君资本:如何洞察先机?前瞻性指标揭秘新一轮船舶周期

多项目标共同提醒船只上行周期的到来。本文将以我国船只为例&#xff0c;综合剖析这一强周期职业的发展趋势。 复盘全球造船周期&#xff0c;可以看出均匀全球造船周期约为9.6年&#xff1b;在1886—2007年期间&#xff0c;有12个独立的周期&#xff0c;周期均匀长度约为9.6年…

YOLOv10环境搭建推理测试

引子 两个多月前YOLOv9发布&#xff08;感兴趣的童鞋可以移步YOLOv9环境搭建&推理测试_yolov9安装-CSDN博客&#xff09;&#xff0c;这才过去这么短的时间&#xff0c;YOLOv10就横空出世了。现在YOLO系列搞得就和追剧一样了。。。OK&#xff0c;那就让我们开始吧。 一、…

记一次 .NET某质量检测中心系统 崩溃分析

一&#xff1a;背景 1. 讲故事 这些天有点意思&#xff0c;遇到的几个程序故障都是和Windows操作系统或者第三方组件有关系&#xff0c;真的有点无语&#xff0c;今天就带给大家一例 IIS 相关的与大家分享&#xff0c;这是一家国企的.NET程序&#xff0c;出现了崩溃急需分析。…

年中企业业绩管理新篇章:用友BIP收入云助力高效管理!

随着市场竞争的加剧&#xff0c;年中时刻对于企业而言&#xff0c;不仅是评估上半年业绩的节点&#xff0c;更是调整策略、确保全年目标达成的关键时期。高效的业绩管理不仅需要明确的目标设定和计划制定&#xff0c;更需要借助先进的信息技术工具来提升管理效率和决策质量。在…

LES大涡模拟基础

参考自https://www.bilibili.com/video/BV1EL411A7gu?p30&vd_sourceb624b9d3e49866ce8c6a455f1ab7c03f 如何解析涡 用网格不能解析单元尺度以下的涡&#xff08;小涡&#xff09;而只能解析大涡 对于小涡&#xff0c;需要引入亚格子模型 如何选择合适的网格尺寸&…