Mysql高级篇(下)——主从复制

news2024/11/22 9:24:20

主从复制

  • 一、概述
  • 二、作用
    • 🎈 场景示例
    • 🎈 综合示例
  • 三、原理
    • 🎈 主从复制基本原则
    • 🎈 主从复制存在的问题
  • 四、一主一从架构搭建
    • 🌱准备工作
    • 🌞步骤
      • 1. 配置主库(Master)
      • 2. 配置从库(Slave)
      • 3. 验证主从同步状态
      • 4. 故障排查
  • 五、同步数据一致性问题
    • 1. 主从同步的要求
    • 2. 主从同步延迟问题
      • (1)概述
      • (2)延迟原因
      • (3)优化措施
    • 3. 复制模式详解
      • Ⅰ. 异步复制
      • Ⅱ. 半同步复制
      • 🌞 配置步骤
      • Ⅲ. GTID(全局事务标识符)复制
      • 🌞 配置步骤
      • 🌞 GTID 复制过程
    • 4. 解决数据一致性问题

一、概述

MySQL 主从复制是一种 用于实现数据库高可用性负载均衡的机制,它允许一个 MySQL 主服务器主库)将数据同步到一个或多个从服务器从库)。这个过程可以实时或近实时进行,主要用于 提高系统的 读取性能、故障转移 和 数据备份


二、作用

MySQ 主从复制(Master-Slave Replication)是一种用于 在多个数据库服务器之间同步数据的技术。它的作用对于保障数据安全提升系统性能实现高可用性等方面都有着重要意义。以下是对 MySQL 主从复制作用的详细阐述:

1. 数据备份与容灾

  • 实时数据备份:主从复制可以将主服务器的数据实时复制到从服务器,形成数据的冗余备份。

  • 容灾恢复:当主服务器发生故障、数据损坏或丢失时,可以迅速从从服务器恢复数据,减少业务中断时间。

  • 提高数据可靠性:通过在不同物理位置部署从服务器,防范单点故障,提高系统的容灾能力。

2. 读写分离与负载均衡

  • 读写分离:将写操作(INSERT、UPDATE、DELETE)集中在主服务器读操作(SELECT)分散到从服务器,减轻主服务器的负载。

  • 提升并发性能从服务器可以同时处理大量的请求,提升系统的并发处理能力。

  • 扩展性强:可以根据业务需求增加从服务器数量,实现系统的水平扩展。


在这里插入图片描述
在这里插入图片描述

总结:
MySQL 主从复制在现代数据库架构中扮演着关键角色,它通过数据同步分布式部署,满足了大型系统对高性能、高可用性和数据安全的需求。具体作用包括:

  • 保障数据安全与高可用性:通过实时备份和容灾恢复,提高系统的容错能力。
  • 提升系统性能与扩展性:实现读写分离和负载均衡,支持高并发访问和系统水平扩展。
  • 支持业务持续发展:为数据分析、报表生成、地理分布式部署等提供技术支持,助力业务增长。

通过合理地配置和使用主从复制,企业可以构建一个高效、稳定且可扩展的数据库系统,更好地支撑业务应用的运行和发展。

🎈 场景示例

在这里插入图片描述
在这里插入图片描述

在这里插入图片描述在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

🎈 综合示例

示例:全球电商平台的综合应用

假设你是一家全球电商平台的数据库架构师,需要设计一个 高可用高性能可扩展 的数据库系统。这个平台面临以下挑战和需求:

  • 全球用户访问:用户遍布全球,需要快速访问网站,降低网络延迟。

  • 高并发读写:每日处理大量的商品浏览(读操作)和订单交易(写操作)。

  • 数据安全与容灾:保障交易数据安全,防止数据丢失,能够快速恢复故障。

  • 复杂数据分析:业务部门需要实时的销售统计、用户行为分析等。

  • 系统维护与升级:在不影响业务的情况下,进行数据库的维护和升级。

  • 开发与测试环境:开发团队需要真实的数据环境进行测试,避免影响生产环境。

  • 权限管理与安全:保护用户敏感信息,防止未经授权的访问和操作。

  • 提高容错能力:防止单点故障,确保系统的高可用性。

为满足上述需求,采用 MySQL主从复制 技术,设计如下架构:

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

总结

通过上述架构设计,MySQL 主从复制在这个全球电商平台中发挥了以下综合作用:

  • 保障数据安全与高可用性:实现了实时数据备份和快速容灾恢复,防止数据丢失。
  • 提升系统性能与用户体验:读写分离和地理分布式部署,满足了高并发和低延迟的需求。
  • 支持业务持续发展:专用的从库用于数据分析和开发测试,助力业务优化和创新。
  • 降低运营风险:通过系统维护与升级策略,减少了对业务的影响,提高了系统的稳定性。
  • 增强系统容错性:多从库和备用主库的部署,提高了系统的容错能力,防止单点故障。
  • 强化安全与合规:严格的权限管理和数据保护措施,保障了用户信息的安全。

这个综合示例展示了 MySQL 主从复制 如何在一个复杂的业务场景中,充分发挥其多方面的作用,满足企业在性能、可用性、安全性和可扩展性等方面的需求。


三、原理

MySQL主从复制是一种将主数据库的数据和操作复制到一个或多个从数据库的机制,用于实现数据的 同步、读写分离和高可用性

关键组件

主库(Master):

  • 二进制日志(Binary Log):记录所有数据修改操作的日志文件。
  • 日志转储线程(Dump Thread):与从库的I/O线程通信,发送二进制日志。



从库(Slave)

  • I/O线程:负责从主库读取二进制日志并写入中继日志。
  • 中继日志(Relay Log):从库保存的来自主库的日志副本。
  • SQL线程:读取中继日志并执行其中的事件,更新从库数据。

复制流程详解

1、主库记录二进制日志(Binary Log)

  • 主库在执行数据修改操作(如INSERTUPDATEDELETE)时,会将这些变更以事件的形式记录到二进制日志中。
  • 二进制日志是按顺序记录的,包含了所有对数据库的更改操作。



2、从库的I/O线程读取二进制日志并写入中继日志(Relay Log)

  • 从库启动一个I/O线程,连接到主库并请求发送新的二进制日志内容。
  • 主库日志转储线程Dump Thread)将二进制日志发送给从库的I/O线程。
  • 从库I/O线程接收这些日志事件并写入自己的中继日志



3、从库的SQL线程读取并执行中继日志中的事件

  • 从库SQL线程读取中继日志中的事件,按顺序在从库上执行,重放主库的操作。
  • 通过执行这些事件,从库的数据状态与主库保持一致。

🎈 主从复制基本原则


  • 每个slave只有一个 maser

  • 每个slave只能有一个唯一的服务器ID

  • 每个master可以有多个slave

🎈 主从复制存在的问题

在这里插入图片描述


四、一主一从架构搭建

🌱准备工作

  • 准备两台虚拟机 参考 虚拟机克隆
  • 每台虚拟机安装好MySQL(以MySQL8.0为例)



注意
MySQL使用UUID来唯一标识每个服务器,以便保证主从复制过程中数据的唯一性一致性。克隆虚拟机的 MySQL serverUUID 和被克隆机是相同的,一定要修改一下,否则可能报如下错误:

Last_IO_Error: Fatal error: The slave I/O thread stops 
because master and slave have equal MySQL server UUIDs; 
these UUIDs must be different for replication to work.
  1. 首先查看克隆机 / 被克隆机server_uuid是否相同
SELECT @@server_uuid;
  1. 修改克隆机的 server_uuid,然后重启 MySQL服务器
# 通常,server_uuid存储在 MySQL 数据目录中的auto.cnf文件中
vim /var/lib/mysql/auto.cnf

# 重启 MySQL 服务器
systemctl restart mysqld

🌞步骤

1. 配置主库(Master)


(1)修改主库的配置文件

  • 首先在主库的my.cnfmy.ini配置文件中进行修改,生成支持二进制日志binary log)和唯一的服务器ID,这些是主从同步的基础。binlog-format 不是必加项

binlog_format 参数含义参考 Mysql高级篇(下)——日志---------4、二进制日志(Binary Log)

[mysqld]
server-id=1            # 主库的服务器ID,必须唯一
log-bin=mysql-bin      # 开启二进制日志,文件名可选
binlog-format=ROW      # (可选,不指定默认 STATEMENT )使用行级复制(推荐)



(2)创建用于复制的用户

  • 登录到MySQL主库中,创建一个专门的用户供从库使用,来进行复制操作。
# 创建用户
CREATE USER '用户名'@'%' IDENTIFIED BY '用户密码';

# 给用户赋予 '复制' 的权限
GRANT REPLICATION SLAVE ON *.* TO '用户名'@'%';

# 此语句必须执行,否则报错 “2059 - Authentication plugin 'caching_sha2_password' cannot be loaded。。。”
alter user '用户名'@'%' identified with mysql_native_password by 'mysql数据库登录密码';

# 刷新权限
FLUSH PRIVILEGES;

MySQL连接服务器认证报错:“2059” 参考 MySQL:2059



(3)获取主库的二进制日志位置

  • 锁定主库以防止数据变化,并获取当前的二进制日志文件名和位置。执行以下命令:
FLUSH TABLES WITH READ LOCK;
SHOW MASTER STATUS;

结果类似如下,记录 FilePosition,以便配置从库

+------------------+----------+--------------+------------------+
| File             | Position | Binlog_Do_DB | Binlog_Ignore_DB |
+------------------+----------+--------------+------------------+
| mysql-bin.000001 |    154    |              |                  |
+------------------+----------+--------------+------------------+

解锁主库:

UNLOCK TABLES;

2. 配置从库(Slave)

(1)修改从库的配置文件

  • 从库MySQL 配置文件 my.cnf 中进行必要的配置,确保其有唯一的服务器 ID 并启用中继日志
[mysqld]
server-id=2          # 从库的服务器ID,确保唯一
relay-log=relay-bin  # 启用中继日志(用于接收主库的二进制日志)

(2)连接到主库并启动复制

  • 从库中,通过以下步骤来指定主库的信息并启动复制:
CHANGE MASTER TO
  MASTER_HOST='主库的IP地址',           # 主库的IP地址
  MASTER_USER='replica_user',          # 复制用户
  MASTER_PASSWORD='replica_password',  # 复制用户的密码
  MASTER_LOG_FILE='mysql-bin.000001',  # 主库的二进制日志文件名
  MASTER_LOG_POS=154;                  # 主库的二进制日志位置

然后启动从库的复制进程:

START SLAVE;

3. 验证主从同步状态

  • 通过以下命令检查从库是否成功与主库同步:
SHOW SLAVE STATUS\G;

类似以下的输出:

*************************** 1. row ***************************
               Slave_IO_State: Waiting for master to send event
                  Master_Host: 主库的IP地址
                  Master_User: replica_user
              Master_Log_File: mysql-bin.000001
          Read_Master_Log_Pos: 12345
        Relay_Master_Log_File: mysql-bin.000001
          Exec_Master_Log_Pos: 12345
             Slave_IO_Running: Yes
            Slave_SQL_Running: Yes

在结果中,确保以下字段显示正常

  • Slave_IO_RunningSlave_SQL_Running 都应该显示 Yes,表示 主从同步正常运行
  • Master_Log_FileExec_Master_Log_Pos 应与主库上的二进制日志状态 一致

4. 故障排查

如果复制进程没有正确启动,SHOW SLAVE STATUS 会显示详细的错误信息。常见问题包括:

  • Last_IO_ErrorLast_SQL_Error 表示 IOSQL 线程的问题,可以通过重启复制进程来修复:
  • 使用 RESET SLAVE; 重启命令 可以删除之前存在的中继日志
STOP SLAVE;
START SLAVE;  # 或执行 RESET SLAVE;

小结

  • 主库配置:开启二进制日志,设置唯一 server-id,并创建复制用户。
  • 从库配置:设置唯一 server-id,连接到主库,启动复制。
  • 验证:使用 SHOW SLAVE STATUS\G 确认同步状态。



这个流程可以用于搭建一主一从的 MySQL 主从复制架构,实现主从同步并确保从库实时更新主库的数据变化。


五、同步数据一致性问题

1. 主从同步的要求

在工作中遇到数据库调优时,使用读写分离的策略,但是读写分离前提就是主从复制,此时就会遇到数据同步问题,主从数据同步的基本要求如下

  • 读库写库的数据最终一致(最终一致)
  • 写数据必须写到写库
  • 读数据必须到读库

2. 主从同步延迟问题

(1)概述

MySQL 主从同步中的延迟问题是指从数据库Slave滞后于 主数据库Master)的情况,即从数据库没有及时跟上主数据库的更新。这种延迟问题可能 会导致数据查询不一致,从而影响系统的性能和数据实时性。

(2)延迟原因

在这里插入图片描述

(3)优化措施

在这里插入图片描述

[mysqld]
slave_parallel_workers=4
slave_parallel_type=LOGICAL_CLOCK

**其中,·LOGICAL_CLOCK· 能够基于事务的逻辑时间戳进行并行处理,提升效率。**

INSTALL PLUGIN rpl_semi_sync_master SONAME 'semisync_master.so';
INSTALL PLUGIN rpl_semi_sync_slave SONAME 'semisync_slave.so';

SET GLOBAL rpl_semi_sync_master_enabled = 1;
SET GLOBAL rpl_semi_sync_slave_enabled = 1;

在这里插入图片描述


3. 复制模式详解

MySQL 复制模式可以通过配置不同的复制方式来提高数据一致性,主要有异步复制半同步复制和基于 GTID(全局事务标识符)的复制模式。我们将通过代码示例详细解释这些复制模式的配置和使用,并探讨它们如何在 MySQL 主从复制中解决数据一致性问题。

Ⅰ. 异步复制

异步复制MySQL 默认的复制模式。它的优点是主数据库(Master)不会等待从数据库(Slave)确认就能继续处理其他事务,但这种模式容易导致数据不一致,特别是在主数据库宕机的情况下,未同步的事务会丢失。

🌞 配置步骤 参考上述一主一从架构搭建步骤

Ⅱ. 半同步复制

半同步复制(Semi-Synchronous Replication)是为了解决异步复制带来的数据不一致问题。在这种模式下,主数据库提交事务时会等待至少一个从数据库确认收到该事务的二进制日志,从而减少数据丢失的风险。

🌞 配置步骤

1、在主数据库上安装并启用半同步插件:

INSTALL PLUGIN rpl_semi_sync_master SONAME 'semisync_master.so';
SET GLOBAL rpl_semi_sync_master_enabled = 1;

2、在从数据库上安装并启用半同步插件:

INSTALL PLUGIN rpl_semi_sync_slave SONAME 'semisync_slave.so';
SET GLOBAL rpl_semi_sync_slave_enabled = 1;

3、配置从数据库连接主数据库并启动复制: 和异步复制类似,配置从数据库连接:

CHANGE MASTER TO 
MASTER_HOST='master_ip', 
MASTER_USER='replica_user', 
MASTER_PASSWORD='password', 
MASTER_LOG_FILE='mysql-bin.000001', 
MASTER_LOG_POS=1234;

START SLAVE;

在这里插入图片描述

Ⅲ. GTID(全局事务标识符)复制

GTID 复制(Global Transaction Identifiers)是一种 基于全局事务 ID 的复制模式。每个事务在主数据库提交时都会分配一个唯一的 GTID主从数据库通过 GTID 来确保复制的一致性。GTID 可以简化复制管理并提高数据一致性。

🌞 配置步骤

1. 在主数据库从数据库上启用 GTID 模式: 在主数据库从数据库的配置文件中都启用 GTID

[mysqld]
gtid_mode=ON
enforce_gtid_consistency=ON
log_bin=ON
log_slave_updates=ON

2. 在主数据库上创建复制用户: 与异步复制类似,创建一个用于复制的用户:

# 创建用户
CREATE USER '用户名'@'%' IDENTIFIED BY '用户密码';

# 给用户赋予 '复制' 的权限
GRANT REPLICATION SLAVE ON *.* TO '用户名'@'%';

# 此语句必须执行,否则报错 “2059 - Authentication plugin 'caching_sha2_password' cannot be loaded。。。”
alter user '用户名'@'%' identified with mysql_native_password by 'mysql数据库登录密码';

# 刷新权限
FLUSH PRIVILEGES;

MySQL连接服务器认证报错:“2059” 参考 MySQL:2059


3. 在从数据库上配置主从复制: 使用 GTID 复制时,不需要指定二进制日志文件和位置,直接通过 GTID 来控制复制:

CHANGE MASTER TO 
MASTER_HOST='master_ip', 
MASTER_USER='replica_user', 
MASTER_PASSWORD='password', 
MASTER_AUTO_POSITION=1;

START SLAVE;

在这里插入图片描述

🌞 GTID 复制过程

假设主数据库中发生了崩溃,我们需要将某个从数据库提升为新的主数据库。如果没有使用 GTID 模式,则需要手动查找崩溃时的二进制日志文件和位置,确保从库能从正确的地方开始复制。而在 GTID 模式下,从库直接基于 GTID 进行复制和故障恢复,确保所有事务在主从数据库之间保持一致。

例如,当主库崩溃后,提升从库主库的步骤:

1. 停止从库的复制:

STOP SLAVE;

2. 将从库提升为主库并接受新的写入操作:

RESET MASTER;

3. 重新配置其他从库连接到新的主库

CHANGE MASTER TO MASTER_HOST='new_master_ip', MASTER_AUTO_POSITION=1;
START SLAVE;

在这里插入图片描述


4. 解决数据一致性问题

MySQL 主从复制中,数据一致性问题指的是主数据库(Master)和从数据库(Slave)在数据同步时可能出现的数据不一致情况。虽然 MySQL 提供了复制机制,但由于异步复制的特性、网络、硬件差异等原因,可能会导致主从数据不一致。为了解决数据一致性问题,可以采取以下措施:

在这里插入图片描述

INSTALL PLUGIN rpl_semi_sync_master SONAME 'semisync_master.so';
INSTALL PLUGIN rpl_semi_sync_slave SONAME 'semisync_slave.so';

SET GLOBAL rpl_semi_sync_master_enabled = 1;
SET GLOBAL rpl_semi_sync_slave_enabled = 1;

在这里插入图片描述

mysqldump -u root -p --all-databases --single-transaction --flush-logs --master-data=2 > dump.sql

在这里插入图片描述

[mysqld]
slave_parallel_workers = 4
slave_parallel_type = LOGICAL_CLOCK

在这里插入图片描述

pt-table-checksum --replicate=percona.checksums --databases=mydb --host=master_ip

在这里插入图片描述

pt-table-sync --execute --replicate percona.checksums --databases=mydb --host=master_ip

在这里插入图片描述

[mysqld]
gtid_mode = ON
enforce_gtid_consistency = ON
log_slave_updates = ON

在这里插入图片描述


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

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

相关文章

如何搭建基于大模型的智能知识库

自从2022年底ChatGPT横空出世引爆了大模型技术浪潮,时至今日已经一年有余,如何从技术侧向商业侧落地转化是一直以来业内普遍关注的问题。 从目前企业端观察到的情况来看,基于大模型的知识库是一个比较有潜力和价值的应用场景,能够…

落伍警告:不了解AI Agent,你可能会被编程界淘汰

AI Agent火爆到什么程度? OpenAI创始人奥特曼预测,未来各行各业,每一个人都可以拥有一个AI Agent;比尔盖茨在2023年层预言:AI Agent将彻底改变人机交互方式,并颠覆整个软件行业;吴恩达教授在AI…

UE5 武器IK瞄准系统

创建空项目 创建基础蓝图类My_GameMode,My_HUD,My_PlayChar,My_PlayController 项目设置地图模式 近裁平面 0.1 My_PlayChar蓝图中添加摄像机,角色骨骼网格体,武器骨骼网格体 编辑角色骨骼,预览控制器使用特定动画,动画选择ANM_ark-47-Idle hand_r 添加插槽WeaponMes…

Stable Diffusion绘画 | 如何做到不同动作表情,人物角色保持一致性(下篇)

在 人物角色保持一致性(上篇)中,我们已经得到了自己创造的角色的各个角度头像图片: 从中选择一个符合自己需求的角度,截图保存,例如下图: 更换人物表情 进入到「图生图」页面,把上一…

短视频时代,网站建设存在的意义还有多大?

在短视频时代,网站建设的存在意义依然具有多方面的价值和作用。尽管短视频作为一种新兴的传播方式迅速发展并受到广泛欢迎,但网站作为互联网的基础设施之一,仍然在许多领域发挥着不可替代的作用。以下是具体分析: 信息深度与完整性…

医院管理新思维:Spring Boot技术应用

5系统详细实现 5.1 医生模块的实现 5.1.1 病床信息管理 医院管理系统的医生可以管理病床信息,可以对病床信息添加修改删除操作。具体界面的展示如图5.1所示。 图5.1 病床信息管理界面 5.1.2 药房信息管理 医生可以对药房信息进行添加,修改,…

开源项目带来的思考

分享一位在Hacker News上的一个帖子,该开源作者在Github上年收入达到10万美元,你不得不承认,个人开源项目的影响力还是很大的。 这条帖子讲述了一位Laravel的开发者,是如何在Github上做到年收入10万美元。该帖子一发布&#xff0c…

rust使用tokio

Rust 是一种系统编程语言,它强调安全、并发和高性能。tokio 是一个基于 Rust 的异步运行时库,专门用于构建异步应用程序。使用 tokio 可以轻松地管理异步任务,并实现高效的并发。 添加依赖: cargo add tokio -F full 示例: 示例1: fn main() {let rt = tokio::runti…

RabbitMQ事务模块

目录 消息分发​​​​​​​ 负载均衡 幂等性保障 顺序性保障 顺序性保障方案 二号策略:分区消费 三号策略:消息确认机制 四号策略: 消息积压 RabbitMQ集群 选举过程 RabbitMQ是基于AMQP协议实现的,该协议实现了事务机制,要么全部成功,要么全…

软件设计师:03操作系统原理

文章目录 一、操作系统地位图二、前趋图(PV操作)三、移臂调度算法(1)最短移臂调度算法(2)先来先服务(3)最短寻道时间优先(4)扫描算法或电梯调度算法&#xff…

大模型~合集8

我自己的原文哦~ https://blog.51cto.com/whaosoft/11566472 # From r to Q∗ 这就是OpenAI神秘的Q*?斯坦福:语言模型就是Q函数 近日,斯坦福大学一个团队的一项新研究似乎为这一研究方向的潜力提供了佐证,其声称现在已经取得非…

【Linux-基础IO】磁盘的存储管理详解

磁盘的存储管理 由于一个磁盘中包含了大量的扇区,为了方便管理,我们对磁盘进行了分区,其中每个分区又进一步划分为多个块组(Block Group),每个块组中包含该块组的数据存储情况以及具体的数据 假设有一个8…

分层解耦-01.三层架构

一.对案例的思考 所有的代码都在这一个controller文件中,虽然该代码不复杂。但是如果针对大型项目,代码会很复杂。而且不利于项目的维护,复用性差。因此要修改该代码,使其满足维护方便,复用性好的特点。因此要用到一个…

VMware ESXi更改https的TLS协议版本

简要概述 TLS 1.0 和 1.1 是已弃用的协议,具有广为人知的缺点和漏洞。应在所有接口上启用 TLS 1.2,并在支持的情况下禁用 SSLv3、TL 1.1 和 1.0。强制要求 TLS 1.2 可能会破坏 vSphere 的第三方集成和加载项。在实施 TLS 1.2 后仔细测试这些集成&#x…

游戏报错x3daudio1_7.dll缺失怎么回事?总结几个有效解决方法分享

1. x3daudio1_7.dll 简介 1.1 定义 x3daudio1_7.dll 是一个动态链接库(DLL)文件,它与 Microsoft DirectX 音频组件紧密相关。该文件主要负责处理三维(3D)音频效果,提供给游戏和多媒体应用程序以增强用户体…

HDLBits中文版,标准参考答案 | 3.1.2 Multiplexers | 多路复用器

关注 望森FPGA 查看更多FPGA资讯 这是望森的第 9 期分享 作者 | 望森 来源 | 望森FPGA 目录 1 2-to-1 multiplexer | 2 对 1 多路复用器 2 2-to-1 bus multiplexer | 2 对 1 总线多路复用器 3 9-to-1 multiplexer | 9 对 1 多路复用器 4 256-to-1 multiplexer | 256 对 …

CPU、GPU、显卡

CPU VS GPUCPU(Central Processing Unit),中央处理器GPU(Graphics Processing Unit),图形处理单元GPU 的技术演变CUDA(Compute Unified Device Architecture) 显卡(Video…

【数据结构与算法】Greedy Algorithm

1) 贪心例子 称之为贪心算法或贪婪算法,核心思想是 将寻找最优解的问题分为若干个步骤每一步骤都采用贪心原则,选取当前最优解因为没有考虑所有可能,局部最优的堆叠不一定让最终解最优 贪心算法是一种在每一步选择中都采取在当前状态下最好…

华为OD机试 - 冠亚军排名(Python/JS/C/C++ 2024 E卷 100分)

华为OD机试 2024E卷题库疯狂收录中,刷题点这里 专栏导读 本专栏收录于《华为OD机试真题(Python/JS/C/C)》。 刷的越多,抽中的概率越大,私信哪吒,备注华为OD,加入华为OD刷题交流群,…

Electron桌面应用打包现有的vue项目

1 环境准备 Node:v16.20.2(本地vue项目nodejs版本)Electron:22.3.7vue:2 版本管理 2 Vue项目准备 更新相关依赖npm install --registry https://registry.npmmirror.com/npm run dev 3、引入Electorn 安装指定版…