CDC YAML 在阿里云的最佳实践

摘要:本文投稿自阿里云开源大数据平台数据通道团队,主要介绍了 Flink CDC YAML 在实时计算Flink版的最佳实践。内容分为以下五个部分:

  1. CDC YAML 简介
  2. CDC YAML 核心能力
  3. CDC YAML 应用场景
  4. 阿里云 Flink CDC 企业级功能
  5. 十分钟在阿里云免费实现一个 CDC YAML 作业

CDC YAML 简介

CDC YAML 是 Flink CDC [1] 提供的简单易用的数据集成 API,用于帮助用户快速构建功能强大的数据同步链路,实时地同步业务数据库中的数据变更和表结构变更实时同步到数据仓库,数据湖以及其他下游系统。CDC YAML 上手门槛较低,即使没有研发背景和Flink基础,用户也可以较快地完成数据的同步和ETL加工,快速完成数据的实时入湖入仓,加速数据分析效率。

阿里云实时计算 Flink 版基于 Flink CDC 提供了数据摄入 CDC YAML 开发[2],通过开发 YAML 作业的方式有效地实现将数据从源端同步到目标端的数据摄入工作,帮助用户在云上高效完成数据入湖入仓。

CDC YAML 核心能力

CDC YAML 主要用于同步数据库变更到其他系统,同步前支持对数据进行简单处理和清洗,帮助用户完成秒级的数据同步工作,构建入湖入仓作业,主要的核心能力有以下几个方面:

  1. 端到端 Data Pipeline:支持秒级同步数据变更和结构变更到其他系统,用户可以快速构建自己的数据湖和数据仓库,为数据分析提供基础。

  2. 细粒度 Schema Evolution:出于数据安全的考虑,部分高危操作(如删除表,清空数据等)用户不希望同步到目标端。CDC YAML 提供细粒度 Schema 变更的能力,帮助用户限制可同步的数据变更类型。

  3. 全增量一体化 CDC 读取:CDC YAML提供了全量和增量的一体化读取能力,全量数据读取完成后自动切换增量读取,无需用户操作。

  4. 丰富的 Transform 支持 :支持对数据字段进行处理后同步到下游,如添加额外计算列,添加元数据、只同步某些列、重新指定主键或分区键等场景。CDC YAML 内置了丰富的函数,用户也可以自行开发UDF,兼容 Flink 的 UDF。支持对数据源数据进行过滤,跳过不需要的数据,完成对无用数据和脏数据的清洗工作。

  5. 灵活的 Route 策略控制:支持自定义数据源的表同步到目标端表的映射关系,支持一对一、一对多和多对一的多种映射关系,帮助用户灵活指定目标端表名,支持分库分表合并的场景。

  6. 完善的 作业 Metric 支持:为了便于判断作业运行的阶段和状态,CDC YAML 提供了丰富的指标。如全量阶段未处理/已处理的表数量,全量阶段未处理/已处理的分片数量、最新一条数据的时间戳等。

阿里云实时计算 Flink 结合用户需求,YAML 作业支持了更多的上下游,支持同步到常见的数据湖和数据仓库,已经支持的上下游如下。

连接器支持类型
SourceSink
MySQL×
消息队列Kafka
实时数仓Hologres×
Upsert Kafka×
Print×
StarRocks×
流式数据湖仓Paimon×

YAML 作业 与 SQL / DataStream 作业对比

Flink 提供了两种级别的作业开发方式:SQL 和 DataStream,下面会比较一下相比于 SQL 和 DataStream来说 CDC YAML 开发有什么优势。

CDC YAML 作业相比 SQL 主要有以下一些优势:

数据摄入YAMLSQL
自动识别 Schema,支持整库同步需要人工写 Create Table 和 Insert 语句
支持细粒度 Schema 变更不支持 Schema 变更
支持原始 Changelog 同步破坏原始 Changelog 结构
支持读写多个表读写单个表

CDC YAML 作业相比 DataStream 作业的优势如下:

数据摄入YAMLDataStream
为各级别用户设计,不只是专家需要熟悉Java和分布式系统
隐藏底层细节,便于开发需要熟悉Flink框架
YAML格式容易理解和学习需要了解Maven等工具管理相关依赖
已有作业方便复用难以复用已有代码

CDC YAML 应用场景

CDC YAML 能够支持用户数据同步多种应用场景,下面简单介绍一些常见的使用场景,以及应该如何使用 CDC YAML 解决这些问题。

整库同步,构建数据湖仓

整库同步是数据同步最常见的一种使用场景,将存在数据库的数据同步到数据湖或数据仓库中,为后续的数据分析提供基础。

如下的数据摄入YAML作业可以完成同步整个app_db数据库到Paimon的工作,快速完成数据入湖的同步工作。

source:type: mysqlname: MySQL Sourcehostname: ${secret_values.mysql-hostname}port: 3306username: flinkpassword: ${secret_values.mysql-password}tables: app_db.\.*server-id: 18601-18604sink:type: paimonname: Paimon Sinkcatalog.properties.metastore: filesystemcatalog.properties.warehouse: oss://test-bucket/warehousecatalog.properties.fs.oss.endpoint: oss-cn-beijing-internal.aliyuncs.comcatalog.properties.fs.oss.accessKeyId: ${secret_values.test_ak}catalog.properties.fs.oss.accessKeySecret: ${secret_values.test_sk}

在整库同步中,有时需要重新定义同步到目标端的表名,防止发生冲突。或者需要做一些简单的数据处理和数据过滤工作,这时需要结合 transform 模块和 route 模块完成,transform 模块负责数据处理工作,route 模块负责数据分发工作。

例如在如下的整库同步作业中,为 app_db.customers 表添加额外的计算列 upper 和数据库名这个元数据列db,同时在目标端为三张表名添加版本后缀。

source:type: mysqlname: MySQL Sourcehostname: ${secret_values.mysql-hostname}port: 3306username: flinkpassword: ${secret_values.mysql-password}tables: app_db.\.*server-id: 18601-18604transform:- source-table: app_db.customersprojection: \*, UPPER(`name`) AS upper, __schema_name__ AS dbroute:- source-table: app_db.customerssink-table: app_db.customers_v1- source-table: app_db.productssink-table: app_db.products_v0- source-table: app_db.orderssink-table: app_db.orders_v0sink:type: paimonname: Paimon Sinkcatalog.properties.metastore: filesystemcatalog.properties.warehouse: oss://test-bucket/warehousecatalog.properties.fs.oss.endpoint: oss-cn-beijing-internal.aliyuncs.comcatalog.properties.fs.oss.accessKeyId: ${secret_values.test_ak}catalog.properties.fs.oss.accessKeySecret: ${secret_values.test_sk}

CDC YAML提供了丰富的内置函数,还支持用户自定义函数来完成复杂的数据处理。CDC YAML 对Flink SQL 的自定义函数进行了兼容,大部分的 Flink 自定义函数可以在数据摄入YAML中直接使用。

分库分表合并

在高并发和大数据量场景下,用户可能选择将一个表拆分为多个库的多张表存储数据,对于分库分表在分析数据前,希望将数据合并为数据湖仓中的一张表。

假设app_db数据库中只有customers_v0,customers_v1和customers_v2三张表,如下 CDC YAML 作业可以将这三张分表合并为一张表customers,完成分库分表的数据同步。

source:type: mysqlname: MySQL Sourcehostname: ${secret_values.mysql-hostname}port: 3306username: flinkpassword: ${secret_values.mysql-password}tables: app_db.customers\.*server-id: 18601-18604route:- source-table: app_db.customers\.*sink-table: app_db.customerssink:type: paimonname: Paimon Sinkcatalog.properties.metastore: filesystemcatalog.properties.warehouse: oss://test-bucket/warehousecatalog.properties.fs.oss.endpoint: oss-cn-beijing-internal.aliyuncs.comcatalog.properties.fs.oss.accessKeyId: ${secret_values.test_ak}catalog.properties.fs.oss.accessKeySecret: ${secret_values.test_sk}

原始 Binlog 数据同步 Kafka,对接已有系统

用户除了整库整表同步,有些场景下需要获取到详细的 Changelog 变更历史,而不是变更后的数据。将 Binlog 同步到 Kafka,结合分布式消息队列 Kafka 可以提高数据消费速度,解决消费同一个 Binlog 导致的数据瓶颈。后续能够使用 Kafka 里的 Binlog 历史, 进行数据回放和数据审计工作,或者消费 Kafka 实时监控数据变更历史,从而触发通知和报警。

由于 Flink SQL 作业里传递的数据结构是 RowData,会将一条 Update 操作拆分为 Update before 和 Update after 两条消息发送,破坏了 Changelog 原有的结构,无法完成原始 Binlog 数据同步。CDC YAML 使用了 SchemaChangeEvent 和 DataChangeEvent 传递数据,可以完整保留 Changelog,帮助用户完成同步原始 Binlog 数据到 Kafka 的工作。

如下作业可以将数据库 app_db 的变更历史同步到 Kafka,app_db 数据库下的表 customers、products 和 shipments 的变更会各自写入对应的 topic 中。

source:type: mysqlname: MySQL Sourcehostname: ${secret_values.mysql-hostname}port: 3306username: flinkpassword: ${secret_values.mysql-password}tables: app_db.\.*server-id: 18601-18604metadata-column.include-list: op_tssink:type: Kafkaname: Kafka Sinkproperties.bootstrap.servers: ${secret_values.bootstraps-server}properties.enable.idempotence: false

存储时支持使用 debezium-json(默认) 或 canal-json 格式,使用 debezium 或 canal 的历史同步作业可以平滑切换为使用 Flink CDC YAML 进行同步,下游的消费者无需修改逻辑。以一条Update消息为例,debezium-json 和 canal-json 数据格式分别如下。

{"before": {"id": 4,"name": "John","address": "New York","phone_number": "2222","age": 12},"after": {"id": 4,"name": "John","address": "New York","phone_number": "1234","age": 12},"op": "u","source": {"db": null,"table": "customers","ts_ms": 1728528674000}
}
{"old": [{"id": 4,"name": "John","address": "New York","phone_number": "2222","age": 12}],"data": [{"id": 4,"name": "John","address": "New York","phone_number": "1234","age": 12}],"type": "UPDATE","database": null,"table": "customers","pkNames": ["id"],"ts": 1728528674000
}

细粒度 Schema 变更

CDC YAML 作业支持同步数据源的 Schema 变更到目标端,例如创建表、添加列、重命名列、更改列类型、删除列和删除表等。但是下游目标端可能无法支持全部类型的变更,或者出于数据安全和权限的考虑,不希望将全部的变更同步到下游。比如希望保留全部历史数据,不希望执行删除和清空等操作。

为了满足更多的用户场景,数据摄入YAML提供了多种变更策略:

  • LENIENT(默认):按照固定的模式,将部分类型的变更转换后同步或跳过同步,确保 Schema Evolution 的向后兼容性。

  • EXCEPTION:不允许变更行为,发生变更时作业抛出异常。

  • IGNORE:跳过全部变更。

  • EVOLVE:同步所有变更,同步失败作业抛出异常。

  • TRY_EVOLVE:尝试同步变更,目标端不支持变更时不报错。

如果不同的变更策略无法满足需求,数据摄入YAML还提供了更细粒度的调控配置,在 Sink 模块中设置 include.schema.changes 和 exclude.schema.changes 选项可以控制需要同步的和需要过滤的变更类型。

如下作业使用 EVOLVE 模式,可以正常同步全部变更,但是会跳过同步删除表,删除列和清空表的操作。

source:type: mysqlname: MySQL Sourcehostname: localhostport: 3306username: usernamepassword: passwordtables: holo_test.\.*server-id: 8601-8604sink:type: hologresname: Hologres Sinkendpoint: ****.hologres.aliyuncs.com:80dbname: cdcyaml_testusername: ${secret_values.holo-username}password: ${secret_values.holo-password}sink.type-normalize-strategy: BROADENexclude.schema.changes: [drop, truncate.table]pipeline:name: MySQL to Hologres yaml jobschema.change.behavior: EVOLVE

宽容模式同步

Schema 变更同步相比于数据同步可能耗时更多,因为在多并发情况下需要等全部数据都写出后,才可以安全地进行 Schema 变更,而且下游的目标端可能无法支持重现全部的 Schema 变更。

为了作业能够更宽容地处理这些变更,在 Hologres 目标端支持了宽容模式同步。Hologres 不支持变更列的类型,在宽容模式下,CDC YAML 将多个 MySQL 数据类型映射到更宽的 Hologres 类型,跳过不必要的类型变更事件,从而让作业正常运行,可以通过配置项sink.type-normalize-strategy进行更改。

例如,如下作业使用 ONLY_BIGINT_OR_TEXT 让 MySQL 类型只对应到 Hologres 的 int8 和 text 两种类型。如果 MySQL 某个列类型从 INT 改为 BIGINT ,Hologres 将这两种 MySQL 类型都对应到 int8 类型,作业不会因为无法处理类型转换而报错。

source:type: mysqlname: MySQL Sourcehostname: localhostport: 3306username: usernamepassword: passwordtables: holo_test.\.*server-id: 8601-8604sink:type: hologresname: Hologres Sinkendpoint: ****.hologres.aliyuncs.com:80dbname: cdcyaml_testusername: ${secret_values.holo-username}password: ${secret_values.holo-password}sink.type-normalize-strategy: ONLY_BIGINT_OR_TEXT

新增同步表

在一些业务场景企业开发了新业务模块(如会员系统、积分系统),需要新增数据库表,并将其数据同步到现有的数据仓库、数据湖或实时计算平台中。或者由于业务调整变化,作业启动时未同步的表需要同步到数据湖仓。

对于在运行中的作业,这些新表就是新增表。新增表存在两种不同的场景,CDC YAML 对不同新增表场景需要使用不同的处理方式,不需要新增作业。

  • 如果新增加的表是空表,由于数据都是新插入的数据,因此不需要同步历史数据,可以在 mysql source 模块上设置 scan**.binlog.**newly-added-table.enabled=true。在这种场景下,被 CDC YAML 作业匹配的新创建的表会自动同步到目标端。

  • 如果新增加的表是作业启动前存在的表,客户希望表里的历史数据需要同步,可以在 mysql source 模块上设置 scan.newly-added-table.enabled=true,然后从 savepoint 重启作业。

指定同步位点重跑数据

运行中的 CDC YAML 作业可能因为一些预期外的错误而退出,比如 Binlog 过期清理,无法解析的 Binlog 内容,解析代码的 Bug 等,这些错误会导致作业无法从原有位置恢复。CDC YAML 支持使用指定位点启动作业,通过修正部分数据 + 指定位点的方式,可以帮助作业继续运行。

阿里云 Flink CDC 企业级功能

阿里云实时计算 Flink 版在支持开源Flink CDC的所有功能外,还结合企业级客户的需求和场景,提供了以下企业级特性,帮助云上企业更好地完成数据实时化改造。

MySQL CDC 企业级性能优化

MySQL CDC 消费 Binlog 是单并行度运行的,消费性能存在瓶颈,阿里云实时计算 Flink 版数据摄入 YAML 对MySQL CDC 消费性能进行了大幅优化:

  1. Debezium Bump参数优化:Debezium 读取数据时,一些参数可以适当调整以获取更好的性能。该方式对比开源 Flink CDC 可以提高11%的性能。

  2. 过滤无关表数据:MySQL CDC 消费整个实例的 Binlog,跳过不匹配的表的数据可以加速解析。该方式提升的性能取决于无关表数据的占比。

  3. 并行解析 Binlog:Binlog 解析字节流时,可以从单并发优化为多并发加速解析速度。该方式对比开源 Flink CDC 可以提高14%的性能。

  4. 并行序列化:通过火焰图发现 CPU 在完成从 Event 到 SourceRecord 和从 SourceRecord 到 JSON 的序列化过程中耗时较多,优化为并行序列化并保序可以提高性能。该方式对比开源 Flink CDC 可以提高42%的性能。

结合以上 4 种优化方式,实时计算 Flink 版数据摄入 YAML 相比于社区 Flink CDC 来说,如果 Binlog 只有单个表的数据,普适的性能会提升 80%左右;如果 Binlog 包含多个表的数据且 YAML 作业只需要同步部分表,则可以获得 10 倍左右的性能提升。

OSS 持久化 binlog 消费支持

MySQL 的数据库实例只有一份 Binlog,如果数据更新太快很可能导致消费速度赶不上生产速度,从而 Binlog 日志被清理,无法从消费失败的位置指定位点重启作业。

阿里云 RDS MySQL 实例支持将 Binlog 同步到 OSS,MySQL CDC 可以使用这部分离线的日志启动作业。用户使用 RDS MySQL 作为上游时,可以指定对应 OSS 配置,当指定的时间戳或者 Binlog 位点对应的文件保存在 OSS 时,会自动拉取 OSS 日志文件到 Flink 集群本地进行读取,当指定的时间戳或者 Binlog 位点对应的文件保存在数据库本地时,会自动切换使用数据库连接读取,彻底解决 Binlog 日志过期导致的作业重跑或数据不一致问题。

更丰富的监控指标

为了便于判断作业运行的阶段和状态,商业版提供更丰富的监控指标。

  • 当前作业处于全量或增量阶段

  • 全量阶段未处理/已处理的表数量

  • 全量阶段未处理/已处理的分片数量

  • 最新一条数据的时间戳

  • 读取数据的延迟

  • 全量阶段的消息条数/全量阶段每个表的消息条数

  • 消息总条数/每个表的消息条数

十分钟在阿里云免费实现一个 CDC YAML 作业

接下来我们使用阿里云免费试用 [3] 来快速测试一下 CDC YAML 作业的功能,完成一个简单的 MySQL 到 Paimon 的整库同步作业。

资源准备

开始测试前需要准备好一个 RDS MySQL 实例,一个实时计算 Flink 版环境,一个 OSS 对象存储。

OSS 对象存储

OSS 对象存储用作数据湖存储,并且用在实时计算 Flink 版的 checkpoint 存储。

在免费试用搜索oss,点击立即试用对象存储 OSS。

试用成功后,在 OSS 控制台创建一个杭州地区的Bucket。创建成功后,在新建的 Bucket 的文件列表中新建目录 warehouse,用于存储数据湖数据。

RDS MySQL 实例

RDS MySQL 作为测试的 MySQL 数据源。

在免费试用搜索RDS MySQL,点击立即试用云数据库 RDS MySQL。

试用成功后,在 RDS 控制台创建一个杭州地区的RDS MySQL集群。

在实例列表点击进入刚创建的实例,在账号管理创建一个高权限账号。

账号创建完成后,在数据库管理创建一个数据库用于测试。

点击登录数据库,使用用户名和密码登录,然后在数据库下创建一些表并插入测试数据。此处创建了products 和 users 两张表,每个表各生成 5 条测试数据。

在白名单与安全组点击全部开放,打通网络连接。此处因为测试目的使用了全部开放,在生产环境请合理配置白名单。

实时计算 Flink 版

在免费试用搜索 flink,点击立即试用实时计算 Flink 版。

完成RAM授权并领取资源抵扣包后,在杭州地区与RDS相同的可用区创建实时计算 Flink 版实例。

创建 AccessKey

Paimon 访问 OSS 时需要使用 AccessKey,参照创建AccessKey文档[4]创建 AccessKey。

CDC YAML 整库同步 Paimon

当所需资源和测试数据都准备好后,接下来让我们在实时计算 Flink 版本上快速开发整库同步作业。

为了数据安全,可以将需要使用的信息在变量管理用密文保存。

保存好变量后,在数据摄入中创建一个整库同步作业并部署上线。

部署成功后,在作业运维点击启动按钮启动作业。

作业启动后,可以在监控告警的数据摄入看到 CDC YAML 同步状态。如下监控可以看出测试作业已经进入了增量阶段,一共同步了2张表,2个分片,每个表全量分别同步了5条数据。

为了查看测试数据,可以使用数据开发 ETL 的调试功能。

首先在元数据管理创建对应的Paimon Catalog。

创建一个 Session 集群用于运行查看数据结果的 SQL,注意选择数据摄入支持的引擎版本。

在数据开发 ETL 中,创建一个 select SQL 作业查看数据,点击调试在 Session 集群运行,可以在控制台查看数据结果。

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

至此一个完整的业务案例就已经实现了,接下来可以自由地在 RDS MySQL 数据库侧操作相应的数据修改,重新执行 select 命令查看数据时,变能够观察到通过YAML作业实时同步到Paimon中的数据了。

相关链接

[1] https://nightlies.apache.org/flink/flink-cdc-docs-stable/

[2] https://help.aliyun.com/zh/flink/user-guide/develop-a-yaml-draft?spm=a2c4g.11186623.help-menu-45029.d_2_2_3.a09a2a71KBQ8n5&scm=20140722.H_2846225._.OR_help-V_1

[3] https://free.aliyun.com/

[4] [https://help.aliyun.com/zh/ram/user-guide/create-an-accesskey-pair?spm=a2c4g.11186623.0.0.4ed27ad1pdxcBb](

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

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

相关文章

【教程】创建NVIDIA Docker共享使用主机的GPU

转载请注明出处:小锋学长生活大爆炸[xfxuezhagn.cn] 如果本文帮助到了你,欢迎[点赞、收藏、关注]哦~ 这套是我跑完整理的。直接上干货,复制粘贴即可! # 先安装toolkit sudo apt-get update sudo apt-get install -y ca-certifica…

SpringMVC纯注解快速开发

此文章适合具有一定的java基础的同学看哦,如果有看不懂的基本代码还是先补补java基础哦。 此教程带您不使用xml文件而是纯注解开发,易懂、快捷、迅速,从0开始搭建,很快就能构建起一个SpringMVC项目,能学到两种使用tom…

【计算机网络】期末速成(2)

部分内容来源于网络,侵删~ 第五章 传输层 概述 传输层提供进程和进程之间的逻辑通信,靠**套接字Socket(主机IP地址,端口号)**找到应用进程。 传输层会对收到的报文进行差错检测。 比特流(物理层)-> 数据帧(数据链路层) -> 分组 / I…

多人聊天室 NIO模型实现

NIO编程模型 Selector监听客户端不同的zhuangtai不同客户端触发不同的状态后,交由相应的handles处理Selector和对应的处理handles都是在同一线程上实现的 I/O多路复用 在Java中,I/O多路复用是一种技术,它允许单个线程处理多个输入/输出&…

数据结构——有序二叉树的删除

在上一篇博客中,我们介绍了有序二叉树的构建、遍历、查找。 数据结构——有序二叉树的构建&遍历&查找-CSDN博客文章浏览阅读707次,点赞18次,收藏6次。因为数据的类型决定数据在内存中的存储形式。left right示意为左右节点其类型也为…

威联通-001 手机相册备份

文章目录 前言1.Qfile Pro2.Qsync Pro总结 前言 威联通有两种数据备份手段:1.Qfile Pro和2.Qsync Pro,实践使用中存在一些区别,针对不同备份环境选择是不同。 1.Qfile Pro 用来备份制定目录内容的。 2.Qsync Pro 主要用来查看和操作文…

C语言学习:速通指针(2)

这里要学习的有以下内容 1. const修饰指针 2. 野指针 3. assert断⾔ 4. 指针的使⽤和传址调⽤ 那么从这里开始 1. const 修饰指针 const修饰变量 首先我们知道变量是可以修改的,如果把变量的地址交给⼀个指针变量,通过指针变量的也可以修改这个变…

使用 MATLAB 绘制三维散点图:根据坐标和距离映射点的颜色和大小

在数据可视化中,三维散点图是一种非常直观的方式来展示数据的分布。MATLAB 提供了强大的 scatter3 函数,可以用来绘制三维散点图,而通过调整点的颜色和大小,可以进一步增强图形的表现力。 在本篇博客中,我们将逐步讲解…

卷积神经网络(CNN)的层次结构

卷积神经网络(CNN)是一种以其处理图像和视频数据的能力而闻名的深度学习模型,其基本结构通常包括以下几个层次,每个层次都有其特定的功能和作用: 1. 输入层(Input Layer): 卷积神经网…

【深度学习】四大图像分类网络之ResNet

ResNet网络是在2015年由微软实验室中的何凯明等几位提出,在CVPR 2016发表影响深远的网络模型,由何凯明团队提出来,在ImageNet的分类比赛上将网络深度直接提高到了152层,前一年夺冠的VGG只有19层。斩获当年ImageNet竞赛中分类任务第…

美团一面,有点难度

前几天分享过一篇训练营的朋友在阿里的一面面经,挺简单的她也是很轻松的过了,感兴趣的可以看一下我之前发的文章。 今天要分享的还是她的面经,美团的一面,感觉比阿里的难一些,各位观众老爷你怎么看? 自我介…

Windows电脑伪关机(快速启动模式),怎么真关机

Windows电脑在关机的时候,进入到一个伪关机的状态,也就是并没有真正的关机,但是在一些系统更新、变更了一些设置,进行重启等操作也会进入到真关机状态 这种一般是开启快速启动模式,开启了快速启动模式功能会在关机的时…

计算属性computed

使用 export default 的写法(Vue 单文件组件)和 使用 new Vue() 的写法(实例化 Vue)二者之间的区别: 1. 使用 export default 的写法(Vue 单文件组件) 这种写法常用于 Vue 的单文件组件&#xf…

element Plus中 el-table表头宽度自适应,不换行

在工作中,使用el-table表格进行开发后,遇到了小屏幕显示器上显示表头文字会出现换行展示,比较影响美观,因此需要让表头的宽度变为不换行,且由内容自动撑开。 以下是作为工作记录,用于demo演示教程 先贴个…

三维测量与建模笔记 - 5.3 光束法平差(Bundle Adjustment)

此篇笔记尚未理解,先做笔记。 如上图,在不同位姿下对同一个物体采集到了一系列图像, 例子中有四张图片。物体上某点M,在四幅图像上都能找到其观测点。 上式中的f函数是对使用做投影得到的估计点位置。求解这个方程有几种方法&…

【NLP 10、优化器 ① SGD 随机梯度下降优化器】

目录 一、定义 二、什么是梯度下降 三、SGD的工作原理 四、SGD的优化公式(更新规则) 五、SGD的优缺点 优点 缺点 六、如何选择学习率 七、使用SGD优化器训练一个简单的线性回归模型 祝你 随时攥紧偶然 永远拥有瞬间 —— 24.12.6 一、定义 随机梯度下降…

WiFi受限不再愁,电脑无网络快速修复指南

有时在试图连接WiFi时,会发现网络连接受限,或无法正常访问互联网。这种情况不仅影响了工作效率,还可能错过重要的信息。那么,究竟是什么原因导致了电脑WiFi连接受限呢?又该如何解决这一问题呢?小A今天就来教…

java对整张图片添加水印(把水印铺满整张图片)

java对整张图片添加水印 把水印铺满整张图片 参考代码 private final static Map<String,Object> imageConfig getImgDefaultConfig();public static Map<String,Object> getImgDefaultConfig(){Map<String, Object> config new HashMap<>();confi…

微服务即时通讯系统(5)用户管理子服务,网关子服务

用户管理子服务&#xff08;user文件&#xff09; 用户管理子服务也是这个项目中的一个业务最多的子服务&#xff0c;接口多&#xff0c;但是主要涉及的数据表只有user表&#xff0c;Redis的键值对和ES的一个搜索引擎&#xff0c;主要功能是对用户的个人信息进行修改管理&#…

基于合成错误增强的标签精细化网络用于医学图像分割|文献速递-生成式模型与transformer在医学影像中的应用

Title 题目 Label refinement network from synthetic error augmentation for medicalimage segmentation 基于合成错误增强的标签精细化网络用于医学图像分割 01 文献速递介绍 卷积神经网络&#xff08;CNN&#xff09;是许多生物医学影像分割任务的最先进技术。许多CNN…