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

Rundeck 介绍及安装:自动化调度与执行工具

Rundeck介绍

概述:Rundeck 是什么?

Rundeck 是一款开源的自动化调度和任务执行工具,专为运维场景设计,帮助工程师通过统一的平台管理和执行跨系统、跨节点的任务。它由 PagerDuty 维护(2016 年收购),基于 Java 开发,支持通过 Web 界面、CLI 或 API 操作。Rundeck 的核心价值在于将分散的运维任务集中化、自动化,提供任务调度、分布式执行、权限控制和日志审计能力,适用于管理服务器集群、执行批量操作和实现故障自愈等场景。

对于运维工程师,Rundeck 提供了一种高效的方式来替代手动操作(如逐台服务器登录执行脚本)或分散的定时任务(如 Cron 脚本),通过集中化的任务管理和自动化流程提升效率和可靠性。


核心功能:Rundeck 能做什么?

Rundeck 的功能围绕运维任务的定义、调度、执行和监控展开,以下是其核心功能及其对运维工作的意义:

1. 任务定义与执行(Job Execution)
  • 功能:Rundeck 允许定义“作业”(Job),可以是单个命令、脚本(Shell、Python 等)或多步骤工作流。作业可以手动触发或通过调度自动运行。
  • 技术细节:作业支持多种执行方式,包括直接命令、脚本文件或调用外部工具(如 Ansible Playbook)。可以通过 Web 界面配置作业的执行参数(如变量、选项)。
  • 运维价值:无需逐台服务器登录执行命令,Rundeck 可以将任务分发到指定节点。例如,运行 df -h 检查所有数据库服务器的磁盘使用量,只需定义一个作业,选择目标节点,一键执行。
2. 分布式节点管理
  • 功能:Rundeck 支持管理多个节点(物理服务器、虚拟机或云实例),通过 SSH(默认)或 WinRM 等协议与节点通信。
  • 技术细节:Rundeck 使用“节点资源模型”管理目标节点,支持手动定义(通过 XML 或 YAML 文件)或动态导入(如从 AWS EC2、Ansible Inventory 获取)。节点可以打标签(如 web-server、db-server),便于按组执行任务。
  • 运维价值:集中管理所有服务器,任务分发更高效。例如,更新 100 台 Web 服务器的 Nginx 配置,只需选择 web-server 标签,Rundeck 自动分发命令并收集结果。
3. 调度与定时任务
  • 功能:Rundeck 内置调度器,支持 Cron 表达式定义定时任务,可以设置任务的执行频率。
  • 技术细节:调度器基于 Quartz 框架,支持复杂的 Cron 表达式(如 0 0 4 * * ? 表示每天凌晨 4 点执行)。任务执行后支持重试机制和错误处理。
  • 运维价值:替代分散的 Cron 脚本,集中管理定时任务。例如,设置一个作业每天凌晨 2 点清理 /var/log 下的日志文件,执行结果和日志统一存储,便于后续查看。
4. 工作流管理
  • 功能:Rundeck 支持定义复杂的工作流,包含多个步骤,支持串行、并行执行,以及条件分支和错误处理。
  • 技术细节:工作流步骤可以是命令、脚本或子作业,支持设置条件(如“仅当上一步成功时执行”)和错误策略(如“失败后停止”)。
  • 运维价值:简化多步骤任务的执行。例如,部署应用可能需要:1)停止服务;2)拉取代码;3)重启服务;4)检查状态。Rundeck 可以将这些步骤串联,自动执行,减少手动干预。
5. 权限管理与访问控制
  • 功能:Rundeck 提供基于角色的访问控制(RBAC),支持项目级和作业级的权限配置。
  • 技术细节:通过 realm.properties 或集成 LDAP/AD 管理用户和角色。可以限制用户对作业的执行、查看或编辑权限。
  • 运维价值:确保任务执行的安全性。例如,限制开发团队只能查看日志收集作业的执行结果,而运维团队可以执行所有操作。
6. 日志记录与审计
  • 功能:Rundeck 记录每次作业的执行详情,包括状态、输出日志、执行时间和执行节点。
  • 技术细节:日志存储在数据库中(默认 H2,支持 MySQL/PostgreSQL),可以通过 Web 界面或 API 查询。支持日志过滤和导出。
  • 运维价值:快速定位问题。例如,某个作业失败时,可以直接查看日志,找到具体错误(如权限不足或命令超时)。
7. 通知与集成
  • 功能:Rundeck 支持作业执行后的通知(如邮件、Webhook),并提供 REST API 供外部系统调用。
  • 技术细节:通知插件支持多种方式(如 Slack、PagerDuty),API 支持触发作业、查询状态等操作。
  • 运维价值:便于团队协作和集成。例如,作业失败时自动发送邮件通知,或者通过 API 将 Rundeck 集成到监控系统(如 Zabbix),实现故障自动响应。

架构与组件:Rundeck 如何工作?

Rundeck 的架构由以下组件构成,理解这些组件有助于运维工程师更好地部署和使用它:

  1. Rundeck Server
    • 核心服务,负责任务调度、作业管理和节点通信。
    • 部署方式:支持 Docker(rundeck/rundeck:5.3.0)、WAR 文件或 RPM/DEB 包。运行时需要 Java 8 或 11。
    • 运维关注:Docker 部署最简单,但需注意内存分配(建议至少 2GB)。
  2. 项目(Project)
    • 逻辑分组单位,每个项目包含作业、节点和配置,适合按环境或团队划分(如 prod、dev)。
    • 运维关注:可以将生产和测试环境分开管理,避免误操作。
  3. 作业(Job)
    • 任务执行单元,包含命令、工作流、目标节点和调度规则。
    • 运维关注:作业支持参数化(如传入变量),适合灵活的任务定义。
  4. 节点(Node)
    • 任务执行的目标机器,Rundeck 通过 SSH 连接节点执行任务。
    • 运维关注:需要配置 SSH 密钥认证,确保 Rundeck Server 与节点通信顺畅。
  5. 数据库
    • 存储作业定义、执行历史和日志,默认使用 H2 数据库(文件存储),支持 MySQL、PostgreSQL。
    • 运维关注:生产环境建议使用外部数据库,提升性能和可靠性。
  6. Web 界面
    • 提供图形化操作,端口默认为 4440,支持作业管理、执行和日志查看。
    • 运维关注:界面直观,但设计较为传统,适合快速上手。

使用场景:Rundeck 如何提升运维效率?

Rundeck 在运维工作中可以解决多种实际问题,以下是几个典型场景:

  1. 批量操作
    • 场景:需要在 50 台服务器上更新配置文件。
    • 解决方案:定义一个作业,包含 scp 和 mv 命令,Rundeck 自动分发到目标节点,执行结果实时反馈。
  2. 定时任务管理
    • 场景:每天凌晨备份数据库,分散的 Cron 脚本管理麻烦。
    • 解决方案:在 Rundeck 中设置定时作业,集中管理,失败时发送告警,日志统一存储。
  3. 故障响应
    • 场景:服务宕机时需要快速重启。
    • 解决方案:定义一个重启服务的作业,通过 API 集成到监控系统,自动触发。
  4. 跨团队协作
    • 场景:开发团队需要查看生产环境的日志。
    • 解决方案:创建一个日志收集作业,授权开发团队执行,无需直接访问服务器。

优势与局限:Rundeck 的实际表现

优势
  • 集中化管理:将分散的脚本和定时任务统一到 Rundeck,降低管理复杂度。
  • 自动化能力:支持复杂的多步骤任务,减少手动操作。
  • 日志与审计:执行记录详尽,便于问题排查和合规审计。
  • 灵活性:通过 API 和插件支持与现有工具集成(如 Ansible、Jenkins)。
  • 易用性:Web 界面简单,适合快速部署和使用。
局限
  • 性能问题:在管理大量节点(>1000)或高并发任务时可能出现瓶颈,需优化数据库和 JVM 配置。
  • 界面体验:Web 界面功能齐全,但设计较为老旧,交互体验一般。
  • 学习曲线:配置复杂工作流或插件时需要一定的学习成本。

对运维工作的帮助:Rundeck 的价值

Rundeck 为运维工程师提供了一个统一的自动化平台,具体价值包括:

  • 效率提升:批量操作和定时任务集中化,减少重复性工作。
  • 可靠性增强:通过工作流和错误处理,确保任务按预期执行。
  • 问题排查便捷:详细的日志记录帮助快速定位问题。
  • 安全与合规:权限管理和审计日志满足安全要求。
  • 协作优化:通过权限控制和 API 集成,提升团队协作效率。

总结

Rundeck 是一个强大的运维自动化工具,特别适合需要管理多节点、执行批量任务或实现定时调度的场景。它通过集中化的任务管理、自动化的执行流程和详细的日志记录,帮助运维工程师提升效率、降低错误率。对于希望从手动操作转向自动化的团队,Rundeck 是一个值得尝试的工具,但需要注意性能优化和配置复杂任务时的学习成本。

安装步骤

1. 安装 Docker

Docker 是运行 Rundeck 容器的基础环境。以下命令将安装 Docker 并确保它正常运行。

# 安装 Docker
sudo apt install docker.io -y# 启动 Docker 服务
sudo systemctl start docker# 设置 Docker 开机自启
sudo systemctl enable docker

说明

  • sudo apt install docker.io -y:安装 Docker,-y 表示自动确认安装。
  • systemctl start docker:启动 Docker 服务。
  • systemctl enable docker:确保 Docker 在系统启动时自动运行。

2. 将当前用户添加到 Docker 组

为了避免每次运行 Docker 命令时都需要使用 sudo,可以将当前用户添加到 docker 组。

# 将当前用户添加到 docker 组(将 <username> 替换为你的用户名,例如 leo)
sudo usermod -aG docker <username># 激活组变更(或者重新登录)
newgrp docker

说明

  • 添加到 docker 组后,你可以直接运行 docker 命令而无需 sudo。
  • 如果不执行此步骤,后续命令需要加上 sudo。

3. 拉取 Rundeck 镜像

从 Docker Hub 拉取 Rundeck 镜像。如果你在离线环境中,可以跳过此步骤,直接加载本地镜像。

# 拉取 Rundeck 5.3.0 版本镜像
docker pull rundeck/rundeck:5.3.0

说明

  • rundeck/rundeck:5.3.0 是 Rundeck 官方镜像,版本为 5.3.0。
  • 你可以在 Docker Hub 的 Rundeck 页面 查看所有可用版本标签,选择其他版本。

4. 保存 Rundeck 镜像为本地文件

如果需要备份镜像或在无网络环境中使用,可以将镜像保存为 .tar 文件。

# 将镜像保存为本地文件
docker save -o rundeck-5.3.0.tar rundeck/rundeck:5.3.0

说明

  • -o rundeck-5.3.0.tar:指定导出的文件名。
  • rundeck/rundeck:5.3.0:要保存的镜像名和版本。
  • 执行后,当前目录下会生成 rundeck-5.3.0.tar 文件,可用于备份或迁移。

5. 加载本地 Rundeck 镜像(如果使用保存的镜像)

如果你之前保存了镜像文件,或者从其他地方获得了镜像文件,可以通过以下命令加载。

# 加载本地镜像文件
docker load -i rundeck-5.3.0.tar

说明

  • -i rundeck-5.3.0.tar:指定要加载的镜像文件。
  • 加载后,可以通过 docker images 查看镜像是否成功加载。

6. 启动 Rundeck 容器

使用以下命令启动 Rundeck 容器,并配置必要的参数。

# 启动 Rundeck 容器
docker run -d --name rundeck \-p 4440:4440 \-v rundeck_data:/home/rundeck/server/data \-e RUNDECK_GRAILS_URL=http://<your-host-ip>:4440 \rundeck/rundeck:5.3.0

参数解释

  1. -d:以分离模式运行容器(后台运行)。
  2. --name rundeck:容器命名为 rundeck,方便管理。
  3. -p 4440:4440:将宿主机的 4440 端口映射到容器内的 4440 端口,Rundeck 默认使用 4440 端口提供 Web 界面。
  4. -v rundeck_data:/home/rundeck/server/data:将宿主机的 rundeck_data 卷挂载到容器内的 /home/rundeck/server/data,用于持久化数据(如数据库、日志)。
  5. -e RUNDECK_GRAILS_URL=http://<your-host-ip>:4440:设置 Rundeck 的外部访问 URL,替换 <your-host-ip> 为宿主机的 IP 地址(例如 192.168.125.131)。这确保 Rundeck 生成的链接与实际访问地址一致。
  6. rundeck/rundeck:5.3.0:使用的镜像名称和版本。

注意

  • 将 <your-host-ip> 替换为你的宿主机 IP 地址,例如 192.168.125.131,命令变为:
    docker run -d --name rundeck \-p 4440:4440 \-v rundeck_data:/home/rundeck/server/data \-e RUNDECK_GRAILS_URL=http://192.168.125.131:4440 \rundeck/rundeck:5.3.0

7. 验证 Rundeck 是否正常运行

启动容器后,检查容器状态并访问 Rundeck 的 Web 界面。

# 查看运行中的容器
docker ps# 查看 Rundeck 容器日志
docker logs rundeck
  • docker ps:确认容器是否正在运行,状态应为 Up。
  • docker logs rundeck:查看日志,确认是否有错误(例如数据库初始化失败)。

8. 访问 Rundeck Web 界面

在浏览器中打开以下地址:

http://<your-host-ip>:4440
  • 例如:http://192.168.125.131:4440
  • 默认用户名:admin
  • 默认密码:admin

 

如果页面无法加载,参考以下步骤排查:

  • 确保 4440 端口已开放:
    sudo netstat -tuln | grep 4440
    sudo ufw allow 4440
  • 检查日志是否有错误:docker logs rundeck。

9. 停止和删除容器(如果需要)

如果需要停止或删除容器,可以使用以下命令:

# 停止容器
docker stop rundeck# 删除容器
docker rm rundeck

注意:删除容器不会删除 rundeck_data 卷,数据会保留。

相关文章:

Rundeck 介绍及安装:自动化调度与执行工具

Rundeck介绍 概述&#xff1a;Rundeck 是什么&#xff1f; Rundeck 是一款开源的自动化调度和任务执行工具&#xff0c;专为运维场景设计&#xff0c;帮助工程师通过统一的平台管理和执行跨系统、跨节点的任务。它由 PagerDuty 维护&#xff08;2016 年收购&#xff09;&#…...

济南国网数字化培训班学习笔记-第二组-6-输电线路现场教学

输电线路现场教学 杆塔组装 角钢塔 角钢-连扳-螺栓 螺栓&#xff08;M&#xff09;&#xff1a; 脚钉-螺栓&#xff08;螺栓头-无扣长-螺纹-螺帽&#xff09;-垫片-螺帽/防盗帽/防松帽M20*45 表示直径20mm&#xff0c;长度45mm螺栓级别由一个类似浮点数表示&#xff0c;如…...

数据结构——二叉树,堆

目录 1.树 1.1树的概念 1.2树的结构 2.二叉树 2.1二叉树的概念 2.2特殊的二叉树 2.3二叉树的性质 2.4二叉树的存储结构 2.4.1顺序结构 2.4.2链式结构 3.堆 3.1堆的概念 3.2堆的分类 3.3堆的实现 3.3.1初始化 3.3.2堆的构建 3.3.3堆的销毁 3.3.4堆的插入 3.3.5…...

PostgreSQL 分区表——范围分区SQL实践

PostgreSQL 分区表——范围分区SQL实践 1、环境准备1-1、新增原始表1-2、执行脚本新增2400w行1-3、创建pg分区表-分区键为创建时间1-4、创建24年所有分区1-5、设置默认分区&#xff08;兜底用&#xff09;1-6、迁移数据1-7、创建分区表索引 2、SQL增删改查测试2-1、查询速度对比…...

第八节:进阶特性高频题-Pinia与Vuex对比

优势&#xff1a;无嵌套模块、Composition API友好、TypeScript原生支持 核心概念&#xff1a;state、getters、actions&#xff08;移除mutation&#xff09; 深度对比 Pinia 与 Vuex&#xff1a;新一代状态管理方案的核心差异 一、核心架构设计对比 维度VuexPinia设计目标集…...

路由交换网络专题 | 第七章 | BGP练习 | 次优路径 | Route-Policy | BGP认证

基本部分配置讲解&#xff1a; 配置BGP相关部分&#xff1a; // BGP区域配置: 用作环回口创建BGP对等体// “ipv4-family unicast”是指进入BGP的IPv4单播地址族视图。 // 配置完后仅仅只在IPV4地址簇下建立对等体。* [AR3]bgp 100 [AR3-bgp]peer 1.1.1.1 as-number 100 [AR…...

序论文42 | patch+MLP用于长序列预测

论文标题&#xff1a;Unlocking the Power of Patch: Patch-Based MLP for Long-Term Time Series Forecasting 论文链接&#xff1a;https://arxiv.org/abs/2405.13575v3 代码链接&#xff1a;https://github.com/TangPeiwang/PatchMLP &#xff08;后台回复“交流”加入讨…...

【mongodb】系统保留的数据库名

目录 1. admin2. config3. local4. test&#xff08;非严格保留&#xff0c;但常作为默认测试数据库&#xff09;5. 注意事项6. 其他相关说明 1. admin 1.用途&#xff1a;用于存储数据库的权限和用户管理相关数据。2.特点&#xff1a;该数据库是 MongoDB 的超级用户数据库&am…...

js 的call 和apply方法用处

主要用于ECMAScript与宿主环境&#xff08;文档对象&#xff08;DOM&#xff09;、浏览器对象&#xff08;BOM&#xff09;&#xff09;的交互中&#xff1b; 例子&#xff1a;function changeStyle(attr, value){ this.style[attr] value; } …...

济南国网数字化培训班学习笔记-第二组-2节-输电线路施工及质量

输电线路施工及质量 质量管控基本规定 基本规定 项目分类 土石方&#xff08;测量挖坑&#xff09;、基础、杆塔、架线、接地、线路防护 检验项目分类原则&#xff1a; 1.主控项目&#xff1a;影响工程性能、强度、安全性和可靠性&#xff0c;且不易修复和处理 2.一般项…...

“Daz to Unreal”将 G8 角色(包括表情)从 daz3d 导入到 UE5。在 UE5 中,我发现使用某个表情并与闭眼混合后,上眼睑出现了问题

1) Bake & Export Corrective Morphs from Daz before you go into UE5 1) 在进入 UE5 之前&#xff0c;从 Daz 烘焙并导出修正型变形 In Daz Studio 在 Daz Studio 中 Load your G8 head, dial in the exact mix (e.g. Smile 1.0 Eyes Closed 1.0). 加载你的 G8 头部&am…...

Linux系统之----进程优先级、调度与切换

在开启本篇文章的学习之前&#xff0c;我们先要熟悉如下两个事 1.概念 进程优先级指的是进程能得到某种资源的先后顺序&#xff0c;要理解好它与权限的关系&#xff0c;优先级是 能&#xff0c;拥有资源的先后顺序&#xff0c;权限是 能还是不能的问题 2.为什么要有优先级…...

Web3钱包开发功能部署设计

Web3钱包开发功能部署设计全景指南&#xff08;2025技术架构与实战&#xff09; ——从核心模块到多链生态的完整解决方案 一、核心功能模块设计 1.1 资产管理体系 Web3钱包的核心功能围绕资产存储、交易验证、多链兼容展开&#xff1a; • 密钥管理&#xff1a;…...

【含文档+PPT+源码】基于SpringBoot的开放实验管理平台设计与实现

项目介绍 本课程演示的是一款基于SpringBoot的开放实验管理平台设计与实现&#xff0c;主要针对计算机相关专业的正在做毕设的学生与需要项目实战练习的 Java 学习者。 1.包含&#xff1a;项目源码、项目文档、数据库脚本、软件工具等所有资料 2.带你从零开始部署运行本套系统…...

小刚说C语言刷题——1317正多边形每个内角的度数?

1.题目描述 根据多边形内角和定理&#xff0c;正多边形内角和等于&#xff1a;&#xff08; n&#xff0d;2 &#xff09; 180∘ ( n 大于等于 3且 n 为整数&#xff09; 请根据正多边形的边数&#xff0c;计算该正多边形每个内角的度数。&#xff08;结果保留1位小数&#x…...

Spring—AOP

AOP是在不惊动原有的代码的基础上对功能进行增强操作 连接点&#xff1a;JoinPoint&#xff0c;可以被AOP控制的方法 通知&#xff1a;Advice&#xff0c;增强的逻辑&#xff0c;共性功能 切入点&#xff1a;PointCut&#xff0c;匹配连接点的条件&#xff0c;表明连接点中哪…...

算法训练营第二天| 209.长度最小的子数组、59.螺旋矩阵II、区间和

209.长度最小的子数组 题目 思路与解法 **第一想法&#xff1a;**无 carl的讲解&#xff1a; 滑动窗口 class Solution:def minSubArrayLen(self, target: int, nums: List[int]) -> int:ij0lens len(nums)sum 0res lens 1while j < lens:# for m in range(i, j1)…...

【C++ 真题】P3456 [POI2007] GRZ-Ridges and Valleys

[POI2007] GRZ-Ridges and Valleys 题面翻译 题目描述 译自 POI 2007 Stage 2. Day 0「Ridges and Valleys」 给定一个 n n n \times n nn 的网格状地图&#xff0c;每个方格 ( i , j ) (i,j) (i,j) 有一个高度 w i j w_{ij} wij​。如果两个方格有公共顶点&#xff0c…...

Vue3 中 computed的详细用法

Vue 3 中 computed 是一个非常重要的响应式 API&#xff0c;它是基于其依赖项的值来计算得出的值&#xff0c;当依赖项发生变化时&#xff0c;计算属性会自动更新 基本用法 在选项式 API 中&#xff0c;computed 通常作为一个选项直接在组件的选项对象中定义。例如 <temp…...

位带和位带别名区

位带区域和位带别名区域 位带区域&#xff08;Bit-banding&#xff09;是一种技术&#xff0c; 允许开发者直接访问和修改内存中的单个位。 这种技术在某些微控制器&#xff08;如ARM Cortex-M系列&#xff09;中特别有用&#xff0c;因为它可以简化对寄存器位的访问和修改。 …...

DRF凭什么更高效?Django原生API与DRF框架开发对比解析

一、原生 Django 开发 API 的局限性 虽然 Django 可以通过 JsonResponse 和视图函数手动构建 API&#xff0c;但存在以下问题&#xff1a; 手动序列化与反序列化 需要手动将模型实例转换为 JSON&#xff0c;处理复杂数据类型&#xff08;如嵌套关系&#xff09;时代码冗长且易…...

Agent智能体应用详解:从理论到实践的技术探索

一、Agent智能体是什么&#xff1f; 1. 核心定义 Agent智能体是能够感知环境、自主决策并执行动作以实现目标的软件实体。其核心特征包括&#xff1a; 自主性&#xff1a;无需外部指令持续运行。 反应性&#xff1a;实时响应环境变化。 目标导向&#xff1a;基于预设或学习…...

Windows下使用 VS Code + g++ 开发 Qt GUI 项目的完整指南

&#x1f680; 使用 VS Code g 开发 Qt GUI 项目的完整指南&#xff08;Windows MSYS2&#xff09; 本指南帮助你在 Windows 下使用 VS Code g CMake Qt6 快速搭建 Qt GUI 项目&#xff0c;适合熟悉 Visual Studio 的开发者向跨平台 VS Code 工具链迁移。 &#x1f6e0;️…...

arm64适配系列文章-第三章-arm64环境上mariadb的部署

ARM64适配系列文章 第一章 arm64环境上kubesphere和k8s的部署 第二章 arm64环境上nfs-subdir-external-provisioner的部署 第三章 arm64环境上mariadb的部署 第四章 arm64环境上nacos的部署 第五章 arm64环境上redis的部署 第六章 arm64环境上rabbitmq-management的部署 第七章…...

YOLOv8融合CPA-Enhancer【提高恶略天气的退化图像检测】

1.CPA介绍 CPA-Enhancer通过链式思考提示机制实现了对未知退化条件下图像的自适应增强&#xff0c;显著提升了物体检测性能。其插件式设计便于集成到现有检测框架中&#xff0c;并在物体检测及其他视觉任务中设立了新的性能标准&#xff0c;展现了广泛的应用潜力。 关于CPA-E…...

编译 C++ 报错“找不到 g++ 编译器”的终极解决方案(含 Windows/Linux/macOS)

前言 在使用终端编译 C 程序时&#xff0c;报错&#xff1a; 或类似提示&#xff0c;意味着你的系统尚未正确安装或配置 g 编译器。本篇将从零手把手教你在 Windows / Linux / macOS 下安装并配置 g&#xff0c;适用于新手或 C 入门阶段的你。 什么是 g&#xff1f; g 是 GN…...

Spring 过滤器详解:从基础到实战应用

Spring 过滤器详解&#xff1a;从基础到实战应用 引言 在 Spring 框架中&#xff0c;过滤器&#xff08;Filter&#xff09;是处理 HTTP 请求和响应的重要组件。它们为开发者提供了一种在请求到达控制器之前或响应返回客户端之前进行操作的机制。本文将深入探讨 Spring 中常见…...

达梦并行收集统计信息

达梦收集统计信息速度如何&#xff1f; 答&#xff1a;1分钟1G 大库收集起来可能比较慢&#xff0c;想并行收集需要一些条件 3个参数先了解一下 我把max_parallel_degree改为16 相关说明可以看一下 对一个3G的表收集 收集方法 DBMS_STATS.GATHER_TABLE_STATS( TEST,T1,…...

AOSP CachedAppOptimizer 冻结方案

背景 Android 一直面临一个核心难题&#xff1a;如何优化进程对有限系统资源&#xff08;如 CPU、电量&#xff09;的使用&#xff0c;同时保证用户体验。 当进程进入后台后&#xff0c;它们虽不再贡献用户体验&#xff0c;却仍可能消耗资源。传统的杀后台方案虽然节省资源&a…...

JVM-类加载机制

类加载 前言&#xff1a;为什么需要了解类加载&#xff1f;什么是类加载&#xff1f;生命周期概览类加载过程详解3.1 加载 (Loading)3.2 连接 (Linking)3.2.1 验证 (Verification)3.2.2 准备 (Preparation)3.2.3 解析 (Resolution) 3.3 初始化 (Initialization)3.3.1 <clini…...

【小白福音】SFTP限制权限登录

下面以在 Linux 环境(例如 Ubuntu 或 CentOS)上配置 SFTP chroot 为例,给出详细的步骤说明。即使你不熟悉服务器运维,也可以按照以下步骤进行配置,保证指定的 SFTP 用户只能访问预设目录,而无法触碰其他文件。 目录 一、配置SFTP权限1. 创建专用 SFTP 用户和用户组2. 搭建…...

海量数据笔试题--Top K 高频词汇统计

问题描述&#xff1a; 假设你有一个非常大的文本文件&#xff08;例如&#xff0c;100GB&#xff09;&#xff0c;文件内容是按行存储的单词&#xff08;或其他字符串&#xff0c;如 URL、搜索查询词等&#xff09;&#xff0c;单词之间可能由空格或换行符分隔。由于文件巨大&…...

Postman设置环境变量与Token

设置环境变量 设置某个Collection下的变量...

项目中数据结构为什么用数组,不用List

总结 1&#xff0c;从内存和性能角度&#xff0c;数组占用更小的内存&#xff08;&#xff09;&#xff0c;访问性能更高&#xff08;&#xff09; 分配效率&#xff1a;数组在内存中是连续分配的一块固定空间 访问速度&#xff1a;直接操作内存&#xff0c;数组的读写操作是…...

Linux常见指令介绍下(入门级)

1. head head就和他的名字一样&#xff0c;是显示一个文件头部的内容&#xff08;会自动排序&#xff09;&#xff0c;默认是打印前10行。 语法&#xff1a;head [参数] [文件] 选项&#xff1a; -n [x] 显示前x行。 2. tail tail 命令从指定点开始将文件写到标准输出.使用t…...

从Kafka读取数据

用Spark-Streaming从Kafka读取数据 在大数据处理领域&#xff0c;Spark-Streaming和Kafka都是明星技术。今天咱们就来聊聊怎么用Spark-Streaming从Kafka读取数据并做处理&#xff0c;就算你是小白&#xff0c;也保证能看懂&#xff01;先讲讲从Kafka获取数据的两种方式。早期有…...

硬件工程师面试常见问题(7)

第三十一问&#xff1a;RTC电路&#xff0c;电池寿命估算 上图可知&#xff0c;该电路有两个供电一个是电池供电&#xff0c;一个是其他供电&#xff0c;已知电池大小为120mAh&#xff0c;该电路在电池供电下吃3uA的电流&#xff0c;计算 120*&#xff08;10^3&#xff09;/ 3…...

二分小专题

P1102 A-B 数对 P1102 A-B 数对 暴力枚举还是很好做的&#xff0c;直接上双层循环OK 二分思路:查找边界情况&#xff0c;找出最大下标和最小下标&#xff0c;两者相减1即为答案所求 废话不多说&#xff0c;上代码 //暴力O(n^3) 72pts // #include<bits/stdc.h> // usin…...

Explain详解与索引最佳实践

Explain工具介绍 使用EXPLAIN关键字可以模拟优化器执行SQL语句&#xff0c;分析你的查询语句或是结构的性能瓶颈 在 select 语句之前增加 explain 关键字&#xff0c;MySQL 会在查询上设置一个标记&#xff0c;执行查询会返回执行计划的信息&#xff0c;而不是执行这条SQL 注意…...

【Qt6 QML Book 基础】07:布局项 —— 锚定布局与动态交互(附完整可运行代码)

引言 在 QML 界面开发中&#xff0c;** 锚定布局&#xff08;Anchors&#xff09;** 是实现响应式设计的核心机制。通过声明式的锚定规则&#xff0c;开发者无需手动计算坐标&#xff0c;即可让元素与父容器或其他元素保持动态位置关联。本文结合官方示例&#xff0c;详细解析…...

rocky9.4部署k8s群集v1.28.2版本(containerd)(纯命令)

文章目录 前言三个节点的主机名 所有节点操作主机名和ip解析关闭交换分区&#xff0c;关闭防火墙&#xff0c;关闭selinux更换阿里云yum源时间同步修改内核参数修改系统最大打开文件数开启bridge网桥过滤&#xff0c;加载br_netfilter模块&#xff0c;加载配置文件安装ipset及i…...

Crawl4AI 部署安装及 n8n 调用,实现自动化工作流(保证好使)

Crawl4AI 部署安装及 n8n 调用&#xff0c;实现自动化工作流&#xff08;保证好使&#xff09; 简介 Crawl4AI 的介绍 一、Crawl4AI 的核心功能 二、Crawl4AI vs Firecrawl Crawl4AI 的本地部署 一、前期准备 二、部署步骤 1、检查系统的网络环境 2、下载 Crawl4AI 源…...

onlyoffice8.3.3发布了-豆豆容器市场同步更新ARM64版本

8.3.3 修复内容 文档编辑器 • 修复从右到左&#xff08;RTL&#xff09;段落的计算问题 (DocumentServer#2590) • 修复从右到左段落中"项目符号/编号/多级列表"样式缩略图的显示问题 • 修复从右到左段落中编号列表&#xff08;项目符号&#xff09;的显示问题 (…...

rabbitmq安装项目集成

使用Docker来安装 1.1.下载镜像 docker pull rabbitmq:3-management 1.2.安装MQ docker run \-e RABBITMQ_DEFAULT_USER=root \-e RABBITMQ_DEFAULT_PASS=123123 \--name mq \--hostname mq1 \-p 15672:15672 \-p 5672:5672 \-d \rabbitmq:3-management 15672:RabbitMQ提供…...

济南国网数字化培训班学习笔记-第二组-3节-电网工程建设项目部门

电网工程建设项目部 组成 监理项目部 履行监理合同&#xff0c;监理单位派驻&#xff1a;负责合同管理&#xff0c;审查&#xff0c;见证&#xff0c;旁站&#xff0c;巡视&#xff0c;验收&#xff0c;控制进度&#xff0c;安全&#xff0c;质量&#xff0c;协调各方 造价…...

JDK(java)安装及配置 --- app笔记

JDK官方下载地址&#xff1a;Java Downloads | Oracle 安装好后&#xff0c;配置 “环境变量”&#xff1a; 新建JAVA_HOME变量&#xff0c;值为 jdk 安装 根目录&#xff08;C:\Program Files\Java\jdk-24&#xff09; 在path变量最后面&#xff0c;添加 %JAVA_HOME% 新建 CLA…...

【前端】【面试】在前端开发中,如何优化 CSS 以提升页面渲染性能?

题目&#xff1a;在前端开发中&#xff0c;如何优化 CSS 以提升页面渲染性能&#xff1f; 关键词总结 关键词说明选择器优化避免通配符、减少层级深度、防止后代选择器过度嵌套样式规则优化合并重复规则、慎用高成本属性加载与渲染优化关键 CSS 优先加载、合理使用媒体查询文…...

python的mtcnn检测图片中的人脸并标框

python的mtcnn检测图片中的人脸并标框&#xff0c;标记鼻尖位置 import cv2 from mtcnn import MTCNN# 初始化 MTCNN 检测器 # stages&#xff1a;指定检测阶段 # 指定运行设备为CPU detector MTCNN(stages"face_and_landmarks_detection", device"CPU:0"…...

矩阵系统源码搭建账号分组功能开发全流程解析,支持OEM

在短视频矩阵运营场景下&#xff0c;企业和创作者往往管理着数十甚至上百个不同平台的账号&#xff0c;传统的统一管理模式效率低下&#xff0c;难以满足精细化运营需求。矩阵系统的账号分组功能通过对账号进行分类整合&#xff0c;实现差异化管理与精准化操作。本文将从功能需…...

跟着deepseek学golang--认识golang

文章目录 一、Golang核心优势1. 极简部署方式生产案例​​&#xff1a;依赖管理​​&#xff1a;容器实践​​&#xff1a; 2. 静态类型系统​​类型安全示例​​&#xff1a;性能优势​​&#xff1a;​​代码重构​​&#xff1a; 3. 语言级并发支持​​GMP调度模型实例​​&…...