-
前言在当今数据驱动的世界中,数据库事务的一致性和隔离性是至关重要的。MySQL作为一款强大而广泛使用的数据库管理系统,其事务隔离级别对于确保数据完整性至关重要。让我们一起踏上探索之旅,揭开MySQL隔离级别的神秘面纱。事务概述数据库事务是指数据库上执行的一组操作单元,这些操作单元要么全部成功执行,要么全部不执行,保持数据库的一致性。事务通常具有以下四大特性,通常被称为ACID属性:原子性(Atomicity): 事务是原子的,它要么完全执行,要么完全不执行。如果在事务执行期间发生故障,系统应该能够将数据库恢复到事务开始前的状态。一致性(Consistency): 事务使数据库从一个一致性状态转移到另一个一致性状态。在事务执行前后,数据库应保持一致性,不违反任何完整性约束。隔离性(Isolation): 事务的执行应该是相互隔离的,即一个事务的执行不应影响其他事务的执行。隔离性确保多个事务可以并发执行而不产生不一致的结果。持久性(Durability): 一旦事务成功完成,其结果应该是永久性的,即使在系统发生故障或重新启动后,数据库的状态也应该保持不变。这些特性确保了事务的可靠性和数据库的稳定性。在实际的数据库应用中,开发人员需要确保编写的数据库操作代码能够遵循这些事务特性,以保障数据的完整性和可靠性。mysql隔离级别MySQL支持四种隔离级别,它们分别是读未提交(Read Uncommitted)、读提交(Read Committed)、可重复读(Repeatable Read)和串行化(Serializable)。这些隔离级别决定了一个事务在执行期间对数据的读取和锁定行为,不同的隔离级别在事务并发执行时会产生不同的效果。读未提交(Read Uncommitted):允许一个事务读取另一个事务未提交的修改。最低的隔离级别,不提供任何隔离保护,可能导致脏读、不可重复读和幻读的问题。读提交(Read Committed):保证一个事务不会读取到另一个事务未提交的数据。防止了脏读,但仍然可能发生不可重复读和幻读的问题。可重复读(Repeatable Read):保证在事务执行期间,一个事务不会读取到另一个事务已提交的修改。防止了脏读和不可重复读,但仍可能发生幻读的问题。串行化(Serializable):最高的隔离级别,确保事务的完全隔离。防止了脏读、不可重复读和幻读,但性能开销较大,因为它通常需要使用锁机制来确保事务的串行执行。开发人员在选择隔离级别时需要根据应用需求和性能要求权衡,低隔离级别通常性能较高但可能牺牲了一些数据的一致性,而高隔离级别则提供更严格的一致性但可能影响性能。并发问题与隔离级别关系在多用户环境下,数据库并发问题可能包括脏读(Dirty Read)、不可重复读(Non-Repeatable Read)、幻读(Phantom Read)等。不同的隔离级别采用不同的机制来解决这些并发问题:脏读(Dirty Read):问题: 一个事务读取到另一个事务未提交的数据。解决: 读提交(Read Committed)及以上的隔离级别都解决了脏读问题,确保一个事务只能读取到已提交的数据。不可重复读(Non-Repeatable Read):问题: 一个事务在同一事务中的两次读取之间,另一个事务修改了数据,导致两次读取结果不一致。解决: 可重复读(Repeatable Read)及以上的隔离级别通过锁定读取的数据,防止其他事务修改,从而解决了不可重复读问题。幻读(Phantom Read):问题: 一个事务在同一事务中的两次查询之间,另一个事务插入或删除了数据,导致两次查询结果不一致。解决: 串行化(Serializable)隔离级别通过锁定整个范围的数据,包括插入和删除,以确保事务执行期间其他事务无法对数据进行修改,从而解决了幻读问题。隔离级别越高,解决并发问题的能力越强,但也伴随着性能的损耗。开发人员需要在性能和数据一致性之间做出权衡,选择适当的隔离级别以满足应用需求。事务隔离级别的配置与设置在MySQL中,可以使用SET TRANSACTION语句来设置事务隔离级别。以下是一个详细的MySQL配置示例,演示如何设置和修改事务隔离级别:查看当前隔离级别:SELECT @@tx_isolation; 这将显示当前的事务隔离级别。设置隔离级别:SET TRANSACTION ISOLATION LEVEL <隔离级别>; 例如,设置隔离级别为可重复读:SET TRANSACTION ISOLATION LEVEL REPEATABLE READ; 启动事务:在设置隔离级别之后,启动事务以应用新的隔离级别。START TRANSACTION; 执行事务操作:在事务中执行相应的SQL操作。提交或回滚事务:COMMIT; -- 提交事务 -- 或 ROLLBACK; -- 回滚事务 请注意,在MySQL中,事务隔离级别的更改仅在当前事务中有效,对其他并发事务不产生影响。一旦事务提交或回滚,隔离级别将恢复为数据库的默认设置。如果要在连接启动时设置隔离级别,可以在连接字符串中使用tx_isolation参数,例如:mysql -h <hostname> -u <username> -p<password> --tx_isolation=REPEATABLE-READ 这个示例中,你可以替换<hostname>, <username>, <password>和REPEATABLE-READ为实际的数据库连接参数和所需的隔离级别。
-
前言在数据库的世界里,就像是一场激烈的竞技赛,各种技术都在争夺着最佳的位置。而数据库读写分离,就像是其中的一场精彩对决,而选手们分别是Spring Boot的代码实现和ProxySQL的管理应用。Spring Boot代码实现就像是一位精通武艺的武林高手,能够凭借自身的实力切换数据源;而ProxySQL则像是一位智慧型策略家,能够通过配置来管理数据库读写分离。现在,就让我们一起来看看这两位选手各自的绝技,探索它们的异同之处吧!原理对比Spring Boot代码实现和ProxySQL管理的读写分离是两种不同层面上的解决方案,它们各有特点和工作原理。以下是它们的原理对比:Spring Boot代码实现读写分离:工作原理:在Spring Boot框架中,通过编程方式实现读写分离,通常涉及到AOP(面向切面编程)和抽象的数据源定义。使用AOP拦截对数据库的调用,在运行时动态决定使用读数据源还是写数据源。通常通过注解或方法名称约定来区分读操作和写操作,例如,所有以find、select、get开头的方法使用从库(读数据源),其他如save、update、delete使用主库(写数据源)。实现方式:定义两个数据源,一个指向主库,另一个指向从库。创建一个数据源路由器来动态选择实际的数据源。在业务代码中,通过注解或自定义规则来标记方法应该使用哪个数据源。ProxySQL管理读写分离:工作原理:ProxySQL是一个高性能的SQL查询中间件,工作在数据库和应用服务器之间。它通过解析、分析和转发SQL语句来实现读写分离,而这一切对应用层是透明的。ProxySQL有内置的读写分离逻辑,可以识别SQL查询,并将读操作路由到从库,写操作路由到主库。实现方式:通过配置ProxySQL,定义主库和从库的连接信息和读写分离的规则。应用程序不需要关心具体的数据库实例,只需连接到ProxySQL即可。ProxySQL根据预定义的规则和权重,自动将查询分发到相应的数据库实例。对比两种方法:工作层面:Spring Boot实现是在应用层进行的,需要开发者在代码中定义数据源和切换逻辑;ProxySQL是数据库层面的中间件,对应用层是透明的,不需要修改应用代码。灵活性:Spring Boot方法可以非常灵活地定义何时使用特定数据源,可以基于业务逻辑;ProxySQL则依赖于SQL语句和静态规则。性能:ProxySQL作为独立组件运行,减轻了应用服务器的压力,但引入了额外的网络跳转;Spring Boot方法则增加了应用服务器的负载,但减少了网络延迟。复杂性:Spring Boot方法可能需要更复杂的配置和多数据源管理;ProxySQL作为专门工具,配置相对集中,但需要额外的维护和监控。可维护性:在Spring Boot中,读写分离逻辑分散在代码中,可能影响可维护性;ProxySQL集中管理,逻辑修改不需要改动应用代码。根据实际业务需求和环境,开发者可以选择最适合的读写分离实现方式性能与稳定性分析性能和稳定性是评估读写分离方案的重要因素。以下是基于Spring Boot代码实现和ProxySQL管理的读写分离在性能和稳定性方面的分析:Spring Boot代码实现读写分离:性能:优点:应用层直接管理数据源,避免了中间件可能带来的额外网络延迟。在同一个应用服务器内决策,减少了数据在网络中的传输。缺点:由于在应用层进行动态数据源切换,可能会增加应用服务器的计算负担,尤其是在高并发情况下,动态判断和数据源切换可能影响性能。稳定性:优点:由于没有额外的中间件,减少了系统组件的数量,理论上可以减少故障点。缺点:如果数据源的切换逻辑不够健壮,或者配置错误,可能导致数据源切换失败,影响稳定性。ProxySQL管理读写分离:性能:优点:ProxySQL专为高性能设计,能够处理大量并发连接和查询,不会成为瓶颈。它可以缓存结果,降低从库的压力。缺点:中间件引入了额外的网络跳转,对于网络延迟敏感的应用,可能会对性能产生负面影响。稳定性:优点:作为独立的中间件,ProxySQL可以在不干扰应用服务器的情况下进行维护和升级。它提供故障切换和自动重连机制,增强了数据库操作的稳定性。缺点:增加了系统的复杂性,如果ProxySQL出现问题,可能会影响到所有的数据库操作。性能测试结果和实际案例分析:性能测试应该在实际的生产环境中进行,需要注意的是,测试结果可能会因网络状况、服务器配置、数据库负载、查询复杂度等多种因素而有所不同。理论上,ProxySQL作为专门的数据库中间件,在处理大量并发请求时性能可能更优,因为它可以提供查询缓存、并发控制等高级功能。实际案例分析应基于实际生产环境中的数据和统计信息。例如,可以通过监控工具收集应用服务器和ProxySQL的CPU使用率、内存使用情况、响应时间、吞吐量等指标,然后对比在使用Spring Boot代码实现和ProxySQL管理的读写分离方案时这些指标的变化。最终,选择哪种读写分离实现方案应该基于具体的业务需求、技术栈、团队经验和维护能力。在决定之前,进行充分的测试和评估是非常重要的。灵活性与扩展性对比在考虑读写分离方案时,灵活性和扩展性是重要的因素,尤其是在面对复杂场景和不断变化的需求时。以下是Spring Boot代码实现和ProxySQL管理读写分离的灵活性和扩展性对比:Spring Boot代码实现读写分离:灵活性:优点:可以基于业务逻辑灵活地控制数据源路由,例如,可以通过注解、方法命名规则或业务参数来动态选择数据源。缺点:随着业务复杂性的增加,维护多种数据源和路由逻辑可能变得复杂和笨重。扩展性:优点:在应用层实现的读写分离允许开发者根据不同服务的需求定制数据源切换策略。缺点:随着系统规模的扩大,可能需要更多的工作来确保数据源路由的一致性和正确性。ProxySQL管理读写分离:灵活性:优点:ProxySQL支持复杂的查询规则和重写,可以根据查询类型、模式或其他属性进行路由。缺点:路由逻辑主要基于SQL查询本身,而不是应用层的业务逻辑。扩展性:优点:ProxySQL作为中间件,可以独立于应用进行横向扩展,支持读写分离规则的集中管理。它也支持负载均衡和故障转移,有助于系统的扩展和稳定运行。缺点:对于非标准的复杂路由需求,可能需要更复杂的配置,且对ProxySQL的深度了解和精细调整。应对复杂场景和需求变化:Spring Boot代码实现:在应对业务逻辑密切相关的复杂场景时,Spring Boot的方法可能更加灵活,因为它可以直接在应用代码中实现复杂的决策逻辑。然而,对于需求变化,这种方案可能需要更频繁的代码更改和部署。ProxySQL管理:ProxySQL在处理通用数据库路由和负载均衡需求方面效果很好,特别是在多数据库实例和大规模部署的情况下。但是,对于紧密绑定到业务逻辑的特定路由需求,修改和测试ProxySQL的配置可能相对麻烦。综上所述,Spring Boot代码实现提供了更细粒度的控制,适合高度定制的数据源路由需求,但可能不易维护和扩展。而ProxySQL提供了强大的中间件功能,适用于常见的读写分离场景,便于扩展,但在特定情况下可能缺乏灵活性。两种方法各有优势,选择哪一种取决于具体的场景、技术栈、维护能力和长远发展规划。
-
前言在数据库的世界里,就像是一座宝库,拥有无数珍贵的数据财富。然而,要保护这座宝库,就需要一把坚固的大门和一套严密的钥匙。而MySQL的权限管理系统,就像是这座宝库的大门和钥匙,它能够帮助我们控制谁能够进入这座宝库,以及谁能够获取其中的宝藏。现在,就让我们一起来揭开MySQL权限管理的神秘面纱,探索它的魅力所在吧!用户和组的概念用户和组的概念在 MySQL 中,用户和组是权限管理的基础。它们用于控制对数据库资源的访问和操作。用户(User):MySQL 中的用户是登录数据库系统的实体,每个用户都有自己的用户名和密码。用户账号定义了该用户可以连接到数据库的权限,以及他们可以对哪些数据库对象执行哪些操作。每个用户都可以具有不同的权限集,从而实现细粒度的访问控制。组(Role):MySQL 8.0 引入了角色(Role)的概念,它类似于用户组。角色是一组权限的集合,可以分配给一个或多个用户。角色使得权限管理变得更加简单和集中,因为您可以为角色指定一组权限,然后将该角色授权给多个用户,而无需单独为每个用户分配相同的权限。在权限管理中,用户是执行数据库操作的实体,而角色则是权限的集合。将角色分配给用户后,用户就拥有了角色中定义的所有权限。创建和管理用户创建用户:使用 CREATE USER 语句创建新用户:CREATE USER 'username'@'host' IDENTIFIED BY 'password'; 其中 `username` 是新用户的用户名,`host` 表示用户可以从哪些主机连接到数据库(使用 `%` 表示任意主机),`password` 是用户的密码。授权权限:使用 GRANT 语句为用户授予权限:# 这将授予用户对指定数据库的表的 SELECT 和 INSERT 权限。 GRANT SELECT, INSERT ON database.table TO 'username'@'host'; 查看权限:使用 SHOW GRANTS 语句查看用户权限:SHOW GRANTS FOR 'username'@'host'; 撤销权限:使用 REVOKE 语句撤销用户权限:REVOKE INSERT ON database.table FROM 'username'@'host'; 删除用户:使用 DROP USER 语句删除用户:DROP USER 'username'@'host'; 创建和管理角色创建角色:使用 CREATE ROLE 语句创建角色:CREATE ROLE 'role_name'; 授予角色权限:使用 GRANT 语句为角色授予权限:GRANT SELECT, INSERT ON database.table TO 'role_name'; 角色赋予用户:使用 GRANT 语句将角色赋予给用户:GRANT 'role_name' TO 'username'@'host'; 撤销角色权限:使用 REVOKE 语句撤销角色的权限:REVOKE 'role_name' FROM 'username'@'host'; 删除角色:使用 DROP ROLE 语句删除角色:DROP ROLE 'role_name'; 权限的类型和分配MySQL中的权限类型在MySQL中,权限可以根据其适用范围被分为三种主要类型:全局权限、数据库权限和表权限。这些权限可以通过不同级别的粒度控制用户对数据库、表或其他对象的访问和操作能力。全局权限:全局权限适用于服务器上的所有数据库。它们在 mysql.user 表中为每个用户定义。示例权限包括 CREATE USER(创建新用户的权限)、RELOAD(重新加载权限表或刷新日志等的权限)等。数据库权限:数据库权限仅适用于特定的数据库及其内的所有对象。这些权限在 mysql.db 和 mysql.tables_priv 表中定义。示例权限包括 CREATE(在数据库中创建新表或索引的权限)、SELECT(从数据库表中读取数据的权限)等。表权限:表权限仅适用于特定的表。它们提供了对单个表的细粒度控制。示例权限包括 INSERT(向表中添加数据的权限)、UPDATE(修改表中现有数据的权限)等。分配不同类型的权限给用户和组分配全局权限:使用 GRANT 语句为用户或角色分配全局权限,并在 GRANT 语句中不指定任何数据库或表。示例:为用户 john 分配全局的 CREATE USER 权限。GRANT CREATE USER ON *.* TO 'john'@'localhost'; 分配数据库权限:使用 GRANT 语句为用户或角色分配数据库级别的权限,需要在 GRANT 语句中指定数据库名称。示例:为用户 john 分配对 mydb 数据库的 SELECT 和 INSERT 权限。GRANT SELECT, INSERT ON mydb.* TO 'john'@'localhost'; 分配表权限:使用 GRANT 语句为用户或角色分配表级别的权限,需要在 GRANT 语句中指定数据库和表名称。示例:为用户 john 分配对 mydb 数据库中的 mytable 表的 UPDATE 权限。GRANT UPDATE ON mydb.mytable TO 'john'@'localhost'; 分配权限给角色:创建角色并为角色分配相应的权限,然后将角色授予给用户。示例:创建角色 role1 并为其分配全局的 SELECT 权限,然后将该角色授予给用户 john。CREATE ROLE 'role1'; GRANT SELECT ON *.* TO 'role1'; GRANT 'role1' TO 'john'@'localhost'; 在分配权限时,重要的是要仔细考虑权限的范围和粒度,以确保用户只拥有他们完成工作所需的最小权限集,这是遵循最小权限原则的一部分,有助于提高系统的安全性。权限变更后,使用 FLUSH PRIVILEGES; 命令使更改立即生效,或者等待用户下次登录时自动刷新。权限验证与日志MySQL中的权限验证机制MySQL的权限验证机制负责确认用户的身份和授权用户对数据库资源的访问。这个过程通常分为两个步骤:身份验证和权限验证。身份验证:连接时身份验证:当用户尝试连接到MySQL服务器时,首先进行身份验证。MySQL会根据提供的用户名和密码,以及连接的来源地址,查找mysql.user表中相应的记录来验证用户身份。如果找到匹配的记录并且密码正确,则允许连接;否则,连接被拒绝。加密:MySQL支持使用SSL加密连接,确保用户名和密码等敏感信息在网络中的传输安全。权限验证:访问控制:一旦用户成功连接,对于用户的每个请求(如查询、更新等操作),MySQL都会根据mysql.user、mysql.db和mysql.tables_priv等表中的权限记录进行权限验证,以确定用户是否有权执行该操作。权限层次:MySQL的权限系统是分层的,包括全局权限、数据库权限、表权限等,MySQL会从最具体的权限(如表权限)开始检查,如果未定义,则向上检查到更广泛的权限(如数据库权限),直到全局权限。通过日志记录和审计监控权限使用情况日志记录:错误日志:记录MySQL服务器启动、运行或停止时遇到的问题,包括客户端连接失败的信息,有助于诊断身份验证问题。查询日志:记录所有对MySQL服务器执行的查询,包括成功和失败的查询。这对于审计和分析数据库活动非常有用。二进制日志:记录了对数据库执行更改的所有操作,如INSERT、UPDATE和DELETE语句。二进制日志不仅对数据恢复重要,也可以用来审计数据更改。审计插件:MySQL还支持使用审计插件来收集和记录服务器活动,包括客户端连接、查询和服务器操作等。审计插件如MySQL Enterprise Audit插件,提供了更细粒度的审计功能,能够帮助组织满足合规性要求。使用审计插件,管理员可以配置特定的审计策略,如记录所有或特定用户的查询,或只记录特定类型的数据库操作。监控和分析:日志文件和审计记录可以用来监控和分析权限的使用情况,通过定期检查这些记录,管理员可以发现异常行为、尝试的安全攻击或不必要的权限赋予。对于复杂的环境或严格的安全要求,可以使用专门的日志管理和分析工具来自动化日志审计过程,生成报告并及时发现安全问题。总之,MySQL的权限验证机制确保了只有经过认证和授权的用户才能访问和操作数据库资源。通过有效地使用日志和审计功能,可以增强数据库的安全性和合规性,及时发现并应对潜在的安全威胁。特殊权限和高级功能当谈论数据库的权限管理时,MySQL是一个非常强大并且灵活的选项。它不仅提供了基本的数据读写权限,还提供了一些特殊的权限和高级的权限管理功能。让我们一起探讨这些特性。特殊权限GRANT OPTION权限在MySQL中,GRANT OPTION是一个特殊的权限,它允许用户将自己的权限授予给其他用户。这是一个强大但需要谨慎使用的权限,因为它可能使权限控制变得复杂并可能引发安全问题。例如,如果用户A将其权限授予了用户B,并给予了GRANT OPTION,那么用户B就可以将这些权限再授予给用户C。这样,用户A可能无法直接控制用户C的权限,这可能是一个安全风险。因此,在授予GRANT OPTION权限时,我们需要确保被授予权限的用户是可信的,并且了解他们可能带来的安全影响。SUPER权限SUPER权限是MySQL中的另一个特殊权限。用户拥有SUPER权限后,可以执行许多高级操作,包括但不限于:更改系统全局变量执行KILL命令终止任何连接或查询安装或卸载插件显然,这是一个非常强大的权限,只应授予需要执行这些操作的用户。未经正确使用,SUPER权限可能会导致严重的系统问题,包括数据丢失。高级权限管理功能存储过程和视图的权限控制在MySQL中,可以通过DEFINER和SQL SECURITY语句来控制存储过程和视图的权限。这允许创建者定义谁可以执行存储过程或查看视图,以及执行或查看时使用的权限级别。例如,如果存储过程的DEFINER是用户A,并且SQL SECURITY设置为DEFINER,那么只有用户A可以执行这个存储过程,并且执行时使用的是用户A的权限。这样,我们可以精细控制哪些用户可以访问和修改数据库的特定部分。在权限管理中,理解和正确使用这些特殊权限和高级功能是很关键的。它们提供了更大的灵活性,但同时也带来了更大的责任。我们需要确保我们的数据库安全,同时满足用户的需求。总结一下,MySQL的特殊权限和高级功能使我们可以更精细、更灵活地管理数据库权限。但是,这些功能的强大同时也要求我们更加谨慎和负责任地使用它们。
-
前言数据库就像是一座巨大的图书馆,而MySQL的主从复制技术就像是这座图书馆中的藏书分发系统,能够让我们的读者在不同的阅览室中阅读到同样的书籍。而今天,就让我们一起来探索MySQL主从复制的多种实现方式,带您进入这座神秘的数据库世界!基于语句的复制基于语句的复制(Statement-Based Replication, SBR)是MySQL复制的一种模式,它在主服务器(master)上执行的每一个SQL语句都会被记录到二进制日志(binary log)中。然后,这些SQL语句会被复制到从服务器(slave)上,并在从服务器上重新执行,从而达到主从数据一致的目的。原理在基于语句的复制模式中,当在主服务器上执行一个SQL操作时,MySQL会将这个操作转换成一个相应的日志事件,并将其写入到二进制日志中。从服务器上的复制线程会定期从主服务器上读取这些日志事件,并在从服务器上重新执行它们。实现方法配置主服务器:在主服务器的配置文件(通常是my.cnf或my.ini)中,需要开启二进制日志,并指定服务器ID。[mysqld] log-bin=mysql-bin server-id=1 配置从服务器:在从服务器的配置文件中,也需要指定服务器ID(确保与主服务器不同),并配置主服务器的信息。[mysqld] server-id=2 之后,你需要在从服务器上执行CHANGE MASTER TO命令,指定主服务器的地址、登录凭证、二进制日志文件名及位置。启动复制:在从服务器上,启动复制进程。START SLAVE; 应用场景及优缺点应用场景读写分离:基于语句的复制可以用于读写分离,提高数据库的读取性能。数据备份:通过在从服务器上复制数据,可以实现数据的实时备份。灾难恢复:在主服务器出现故障时,可以快速切换到从服务器,保证服务的连续性。优点效率高:只复制执行的SQL语句,而不是数据本身,减少了数据传输量。兼容性好:几乎所有的SQL操作都可以通过基于语句的复制进行复制。缺点非确定性操作:对于一些非确定性的SQL语句(如使用NOW()或RAND()函数的语句),可能在主从服务器上产生不一致的结果。依赖环境:由于复制是通过重新执行SQL语句实现的,从服务器上必须具有与主服务器相同的数据库结构和相似的环境设置。潜在的性能问题:对于一些复杂的SQL语句,可能会在从服务器上消耗更多的资源来重新执行。总的来说,基于语句的复制是MySQL复制中一个简单高效的模式,适用于多种场景。但在使用时,也需要注意其潜在的问题,特别是在涉及非确定性操作和高资源消耗操作时,可能需要考虑其他复制模式。基于行的复制基于行的复制(Row-Based Replication, RBR)是MySQL复制的一种方式,它与基于语句的复制(SBR)有所不同。在RBR中,复制过程不是通过复制执行的SQL语句,而是通过复制数据变更后的行来实现的。原理当在主服务器上执行数据修改操作(如INSERT、UPDATE、DELETE)时,MySQL会识别出哪些数据行被修改,并生成相应的行事件。这些行事件会记录具体的数据变更,然后被写入到二进制日志中。从服务器从主服务器的二进制日志中读取这些行事件,并在本地应用这些变更,从而与主服务器保持数据一致。实现方法基于行的复制的设置与基于语句的复制类似,但需要确保复制格式设置为基于行。在主服务器上配置:在my.cnf或my.ini配置文件中,设置复制格式为基于行,并指定服务器ID。[mysqld] binlog_format=ROW log-bin=mysql-bin server-id=1 在从服务器上配置:在从服务器的配置文件中,设置服务器ID(确保与主服务器不同),并配置主服务器信息。[mysqld] server-id=2 启动复制进程:在从服务器上执行CHANGE MASTER TO命令,配置主服务器的信息,并启动复制。START SLAVE; 优势和适用性优势数据一致性:由于是基于数据行的变更来复制,因此可以避免基于语句复制中由于非确定性函数或语句导致的数据不一致问题。减少冲突:在高并发的环境下,基于行的复制减少了由于复制延迟导致的数据冲突。适用于复杂查询:对于包含复杂查询和函数的操作,基于行的复制只关注结果的变化,因此可以保证从服务器的数据准确性。适用性数据更新频繁的场景:在数据更新操作非常频繁的场景中,基于行的复制能够有效地保持主从服务器间的数据一致性。大量的DML操作:对于有大量INSERT、UPDATE和DELETE操作的数据库,基于行的复制确保了复制的效率和准确性。复杂的SQL操作:当执行的SQL语句在从服务器上可能产生不同结果时,基于行的复制是更好的选择,因为它复制的是数据的变化,而不是SQL语句本身。总而言之,基于行的复制在数据更新频繁和复杂SQL操作的场景下提供了优势,因为它专注于数据的变化本身,从而减少了数据不一致的风险,并且通常可以提供更好的复制性能。然而,需要注意的是,由于复制的是行变更的信息,对于数据量大的变更操作,基于行的复制可能会产生比基于语句复制更大的二进制日志。基于混合模式的复制混合模式复制的工作原理混合模式复制是一种数据复制策略,结合了异步复制和同步复制的优点。在混合模式复制中,一部分数据节点使用同步复制,另一部分数据节点使用异步复制。在同步复制中,当一条数据写入原始节点时,该数据同时也会写入所有的备份节点。只有当所有的备份节点确认数据写入成功后,写入操作才会被确认为成功。这种方式保证了数据的一致性,但可能会因为网络延迟或备份节点的处理能力而影响写入速度。在异步复制中,数据首先被写入原始节点,然后在后续的某个时间点,这些数据被复制到备份节点。这种方式的写入速度较快,但在某些情况下可能会导致数据的不一致。混合模式复制通过将一部分备份节点设置为同步复制,一部分设置为异步复制,既保证了数据的一致性,又提高了写入速度。混合模式复制的优势数据一致性:通过同步复制,混合模式复制确保了至少一部分备份节点与原始节点的数据一致。写入速度:通过异步复制,混合模式复制提高了写入速度,减少了由于等待备份节点确认而产生的延迟。灵活性:用户可以根据自己的需求,调整同步复制和异步复制节点的比例,以达到最佳的效果。混合模式复制在不同场景下的应用和配置方法数据一致性要求较高的场景:在这种场景下,可以增加同步复制节点的比例,以确保数据的一致性。写入速度要求较高的场景:在这种场景下,可以增加异步复制节点的比例,以提高写入速度。混合模式复制的配置方法因具体的数据库系统而异。一般来说,可以通过配置文件或命令行参数,指定哪些节点为同步复制,哪些节点为异步复制。总的来说,混合模式复制提供了一种灵活的数据复制策略,能够根据不同的应用场景和需求,提供高效且一致的数据复制服务。基于GTID基于 GTID 的复制是 MySQL 数据库复制的高级特性,它使用全局事务标识符(GTID)来跟踪和管理数据库的复制过程。每个事务都有一个唯一的 GTID,这使得复制过程更加可靠和易于管理。工作原理当事务在主服务器上提交时,它被赋予一个唯一的 GTID,这个标识符随着二进制日志一起被记录下来。从服务器在复制过程中,会通过 GTID 来确保它接收和执行的事务是完整和唯一的,同时保持与主服务器的事务顺序一致。优势简化配置和管理自动化复制复位:GTID 让从服务器可以自动找到主服务器上的正确位置继续复制,即使在主服务器发生故障后进行了故障转移。易于监控:通过检查 GTID 执行和未执行的集合,可以轻松监控复制状态和任何潜在的复制延迟。提高容错性无缝故障转移:在多主服务器的复制设置中,如果一个主服务器宕机,其他的主服务器可以接管,而不会丢失事务。避免复制错误:GTID 确保每个事务只复制一次,避免了复制过程中的重复或丢失。配置方法启用 GTID:在主服务器和所有从服务器的配置文件(my.cnf或my.ini)中启用 GTID。[mysqld] gtid_mode=ON enforce_gtid_consistency=ON log-bin log-slave-updates配置主从服务器:在从服务器上设置主服务器的信息,并启动 GTID 复制。 CHANGE MASTER TO MASTER_HOST='主服务器地址', MASTER_USER='复制用户', MASTER_PASSWORD='复制密码', MASTER_AUTO_POSITION=1; START SLAVE; 检查 GTID 复制状态:在主从服务器上检查复制状态,确保 GTID 正确配置并且复制在正常运行。 SHOW SLAVE STATUS\G故障转移:如果主服务器发生故障,您可以使用 GTID 来选择新的主服务器,并使从服务器重新连接并开始复制。基于 GTID 的复制为 MySQL 数据库提供了一个更加稳定、可靠、易于管理的复制环境。尤其在具有高可用需求的大型数据库系统中,基于 GTID 的复制是推荐的复制方式。多源复制多源复制(Multi-Source Replication)是MySQL 5.7版本开始引入的新特性,它允许一台从库连接多个主库进行复制。在此之前,MySQL只支持单源复制,即一台从库只能连接一个主库进行复制。什么是多源复制?多源复制是指一台MySQL服务器可以从多个主库复制数据。每个主库和从库的复制关系独立于其他主库,每个复制通道独立运行。多源复制的优点降低系统复杂度和成本:在多源复制的架构中,无需再为每个主库部署独立的从库,减少了硬件和维护的成本。提高灵活性:多源复制提供了更多的复制策略,用户可以根据业务需求灵活配置。提高可用性:在某个主库出现问题时,从库可以从其他正常的主库复制数据,保证了业务的连续性。如何配置多源复制?配置多源复制的步骤与配置单源复制类似,主要的区别在于在从库上需要为每个主库配置一个独立的复制通道。每个复制通道由一个唯一的通道名来标识。多源复制的应用场景多源复制在很多场景下都非常有用,比如数据聚合,数据备份,以及提高查询性能等。总的来说,多源复制作为MySQL 5.7版本的新特性,它的引入极大地提高了MySQL的灵活性和可用性。
-
前言在数据库的世界里,同步是一场永恒的舞蹈,而MySQL GTID模式就像是这场舞蹈中的舞者,能够带领我们跳出传统的舞步,进入全新的境界。而今天,就让我们一起来揭开MySQL GTID模式下主从配置的神秘面纱,探索它的魅力所在吧!GTID模式简介GTID,全称为全局事务标识(Global Transaction ID),是MySQL数据库中用于唯一标识每个事务的一种机制。在GTID模式下,每个事务都会被分配一个唯一的全局标识符,由服务器生成和维护,以标识该事务在整个数据库集群中的唯一位置。GTID通常由两个部分组成:服务器唯一标识符和事务序列号。优势:全局唯一标识符:GTID是全局唯一的,不会出现在整个数据库集群中两个不同的事务拥有相同的标识符的情况,这使得在主从复制中更容易地跟踪和处理事务。简化主从配置:使用GTID模式可以简化主从复制配置,不再需要手动记录和配置复制位置,因为GTID自动跟踪每个事务的位置。自动故障切换:GTID模式可以在主从切换时提供更可靠的自动故障切换,因为从服务器可以准确地知道它应该从哪里开始复制,而无需依赖于手动的复制位置配置。对主从复制的影响和改进:数据一致性:GTID模式可以确保主从数据库之间的数据一致性。当主数据库发生故障时,从数据库可以准确地知道它需要从哪个位置开始重新复制数据,从而避免数据不一致的情况。故障切换:GTID模式可以改善故障切换的效率和准确性。当主服务器发生故障时,从服务器可以快速且准确地切换到新的主服务器,因为它知道它应该从哪里开始复制数据。自动重连接:在使用GTID模式时,从服务器在主服务器重连接后,可以自动恢复复制进程,而无需手动干预或重新配置复制位置。总的来说,GTID模式简化了主从复制的管理和维护,并提高了数据一致性和故障切换的效率和可靠性,使得数据库集群的管理更加容易和可靠。常用配置参数[mysqld] # 设置服务器唯一标识符,每个服务器必须有唯一的ID server-id = 1 # 启用二进制日志,用于主从复制 log-bin = mysql-bin # 确保从服务器也会记录二进制日志 log-slave-updates = 1 # 启用GTID模式,全局事务标识符将被用于唯一标识每个事务 gtid-mode = ON # 强制GTID一致性,防止非GTID事务的复制 enforce-gtid-consistency = ON # 如果主服务器启用了gtid-executed参数记录了当前的GTID集合,则它会被用于从服务器初始化的时候自动配置 # 在从服务器初始化时,使用CHANGE MASTER TO ... MASTER_AUTO_POSITION = 1可以自动获取主服务器的GTID集合 # master_info_repository和relay_log_info_repository必须设置为TABLE,以确保GTID复制的正确性 gtid-executed = COMPRESSION_AUTO, ENCRYPTION_OFF # 如果从服务器初始化时自动配置,则设置为ON,否则设置为OFF # 如果不需要使用从服务器自动获取GTID集合,请将此参数设置为OFF # 如果master_info_repository和relay_log_info_repository都设置为TABLE,这个参数将被自动设置为ON slave_preserve_commit_order = ON # 定义二进制日志的文件名前缀,与log-bin参数一起使用 binlog_format = ROW # 如果slave-sql-verify-checksum=1并且gtid-mode=ON,GTID位置信息的存储(当使用TABLE选项时)将包括校验和 slave-sql-verify-checksum = 1 # 设置二进制日志的缓存大小,影响二进制日志的写入性能 binlog_cache_size = 1M # 设置二进制日志的最大大小,当二进制日志达到这个大小后会自动滚动并创建新的日志文件 max_binlog_size = 100M # 设置主服务器和从服务器之间的超时时间,单位为秒 # 如果主服务器在此时间内未发送任何数据,从服务器会认为主服务器已经失效并重新尝试连接 # 这个值应该根据网络和负载情况进行调整 master-info-repository = TABLE relay-log-info-repository = TABLE relay-log-recovery = 1 # 如果不需要从服务器自动获取GTID集合,请将此参数设置为OFF # 设置为ON时,从服务器会自动从主服务器获取GTID集合,否则需要手动指定GTID集合 # 设置为OFF时,必须在CHANGE MASTER TO ... MASTER_AUTO_POSITION = 0的情况下使用 # 在master_info_repository和relay_log_info_repository设置为TABLE的情况下,此参数将自动设置为ON # master_info_repository和relay_log_info_repository必须设置为TABLE,以确保GTID复制的正确性 # 设置主服务器和从服务器之间的超时时间,单位为秒 # 如果主服务器在此时间内未发送任何数据,从服务器会认为主服务器已经失效并重新尝试连接 # 这个值应该根据网络和负载情况进行调整 slave_net_timeout = 60 # 限制主服务器发出的二进制日志数据的速率 # 如果主服务器的写入速率过快,从服务器可能无法跟上复制进程,导致延迟 # 通过限制主服务器的写入速率,可以减轻从服务器的负载压力 max-binlog-transaction-size = 1073741824 # 设置binlog文件的过期时间,过期后的binlog文件将被自动删除 # 可以避免磁盘空间被过多的binlog文件占用 expire_logs_days = 7 # 设置复制线程在从服务器上重新连接主服务器之前等待的时间 # 如果从服务器与主服务器之间的连接断开,复制线程将等待这段时间然后尝试重新连接 # 这个值应该根据网络和负载情况进行调整 master-connect-retry = 60 # 定义复制过滤规则,用于过滤不需要复制的数据库或表 # 在此处可以定义需要排除的数据库或表,以避免复制不必要的数据 replicate-ignore-db = mysql replicate-ignore-db = test replicate-ignore-table = mysql.user replicate-ignore-table = mysql.help_category # 设置主服务器的字符集,确保与从服务器的字符集一致 character-set-server = utf8mb4 collation-server = utf8mb4_unicode_ci # 设置SQL模式,确保与从服务器的SQL模式一致,以避免由于不同的SQL模式导致的数据不一致性 sql-mode = "STRICT_TRANS_TABLES,NO_ENGINE_SUBSTITUTION" # 设置innodb_flush_log_at_trx_commit参数,控制事务提交时日志刷新的时机 # 设置为2时,表示每次事务提交时只将日志写入日志文件而不进行刷新,可以提高性能 innodb_flush_log_at_trx_commit = 2 # 设置innodb_file_per_table参数,每个InnoDB表都使用独立的表空间文件 # 可以提高性能和管理性 innodb_file_per_table = 1 # 设置innodb_buffer_pool_size参数,指定InnoDB缓冲池的大小 # 可以提高InnoDB存储引擎的性能 innodb_buffer_pool_size = 512M # 设置innodb_flush_method参数,指定InnoDB刷新日志和数据文件的方法 # 设置为O_DIRECT可以减少I/O操作,提高性能 innodb_flush_method = O_DIRECT # 设置innodb_log_file_size参数,指定InnoDB日志文件的大小 # 较大的日志文件大小可以提高性能,但也会增加恢复时间 innodb_log_file_size = 256M # 设置innodb_log_buffer_size参数,指定InnoDB日志缓冲区的大小 # 较大的缓冲区可以提高性能,但也会增加内存使用量 innodb_log_buffer_size = 8M # 设置innodb_autoinc_lock_mode参数,控制InnoDB自增锁的行为 # 设置为2时,表示采用交错自增锁,可以提高性能 innodb_autoinc_lock_mode = 2 # 设置innodb_flush_neighbors参数,指定InnoDB是否在写入数据时使用邻居页刷新策略 # 设置为0时,表示禁用邻居页刷新,可以提高性能 innodb_flush_neighbors = 0 # 设置innodb_io_capacity参数,指定InnoDB每秒可以处理的I/O操作数 # 可以根据系统性能和I/O负载进行调整 innodb_io_capacity = 2000 # 设置innodb_io_capacity_max参数,指定InnoDB每秒最大可以处理的I/O操作数 # 可以根据系统性能和I/O负载进行调整 innodb_io_capacity_max = 4000 GTID复制监控与管理监控和管理GTID复制的状态和延迟是确保数据库系统稳定运行的重要任务。以下是一些系统工具和方法,可以帮助您监控和管理GTID复制:1. 监控GTID复制状态和延迟MySQL内置状态查询:SHOW SLAVE STATUS命令:通过执行该命令,您可以查看从服务器的复制状态,包括当前复制位置、延迟时间、错误信息等。外部监控工具:Prometheus + MySQL Exporter:使用Prometheus和MySQL Exporter可以定期收集和存储MySQL的指标数据,包括GTID复制相关的指标,如延迟时间等。Grafana:与Prometheus集成,可视化显示GTID复制状态和延迟的数据,并设置警报以及实时监控。2. 管理GTID复制的故障和异常情况自动化故障恢复:监控警报设置:设置警报规则,以便在复制延迟超过阈值或复制出现错误时收到通知。自动化脚本:编写脚本定期检查复制状态,并在发现延迟或错误时自动进行故障恢复操作,如重新连接主服务器或重启复制进程。手动故障恢复:检查复制状态:定期手动检查主从服务器的复制状态,包括复制位置、延迟时间等。日志分析:定期分析MySQL的错误日志,查找可能导致复制故障的异常情况,如网络问题、磁盘IO问题等。故障恢复策略:重新连接主服务器:如果从服务器与主服务器的连接断开,尝试重新连接主服务器。重新启动复制进程:如果复制进程出现异常,尝试重新启动复制进程。手动同步数据:如果延迟时间过长或复制进程无法恢复,考虑手动同步数据以重新建立复制关系。3. 预防措施定期备份数据:定期备份:定期备份数据库数据,以防止数据丢失或损坏,并在需要时用于恢复数据。定期维护:定期维护:定期进行数据库维护,包括索引优化、清理日志等,以保证数据库系统的稳定性和性能。监控系统性能:监控系统性能:定期监控服务器资源使用情况,包括CPU、内存、磁盘IO等,以及数据库性能指标,如查询响应时间、慢查询等,及时发现和解决潜在问题。GTID模式的优势与应用GTID模式在实际项目中具有许多优势,并且适用于各种场景和最佳实践。以下是一些常见的GTID模式应用案例:1. 主从复制管理场景:跨数据中心复制:在跨地域或跨数据中心部署的情况下,GTID模式可以简化主从复制的管理,确保数据一致性和故障切换的高可用性。多主复制:在多主复制环境中,GTID模式可以更轻松地管理多个主服务器之间的复制关系,减少复制冲突和数据不一致性的风险。最佳实践:定期监控复制状态:通过监控GTID复制状态和延迟时间,及时发现并解决复制延迟或故障。自动化故障恢复:使用自动化脚本或工具来处理复制故障和异常情况,提高故障恢复的效率和可靠性。2. 数据库迁移和升级场景:平滑迁移:在将数据库迁移到新的硬件或云平台时,GTID模式可以确保在迁移过程中不丢失数据,并简化迁移后的主从复制配置。版本升级:在进行MySQL版本升级时,GTID模式可以简化升级过程,确保升级后的数据库与之前的数据库保持一致。最佳实践:备份和恢复:在进行迁移或升级之前,务必备份数据库,以防止数据丢失或损坏,并在需要时用于恢复数据。逐步迁移:将数据库逐步迁移到新的环境中,确保迁移过程中的数据一致性和可用性。3. 备份和恢复管理场景:在线备份:GTID模式可以简化在线备份的管理,确保备份的数据与原始数据一致,而不会影响主从复制关系。点播恢复:通过GTID模式可以实现精确的点播恢复,将数据库恢复到指定的时间点或事务点。最佳实践:定期备份:定期备份数据库以确保数据的安全性和可恢复性。测试恢复流程:定期测试备份和恢复流程,确保在发生故障时能够快速有效地恢复数据。4. 复制监控和故障切换场景:自动故障切换:GTID模式可以简化故障切换的流程,使得从服务器能够快速、自动地切换到新的主服务器,提高系统的可用性和可靠性。最佳实践:定期演练:定期进行故障切换演练,以确保团队对故障切换流程的熟悉度和有效性。监控和报警:设置监控和报警机制,及时发现和处理复制延迟或故障,确保故障切换能够及时响应并恢复服务。GTID模式在实际项目中的应用场景和最佳实践取决于具体的业务需求和系统架构,但总的来说,GTID模式可以简化数据库管理和维护,并提高数据库系统的可用性、可靠性和可维护性。
-
MySQL的行级锁锁的到底是什么?可以详细讲一下吗?
-
当前读和快照读有什么区别?在mysql中哪种隔离级别会用到快照读呢?
-
一、引言MySQL是一个广泛使用的开源关系型数据库管理系统。其强大的功能部分归功于其灵活性和可扩展性,这主要体现在其支持多种存储引擎上。每种存储引擎都有其独特的特点和用途,适用于不同的应用场景。本文将详细介绍MySQL中常见的几种存储引擎及其区别。二、MySQL的存储引擎种类InnoDBInnoDB是MySQL的默认存储引擎,它提供了事务安全(ACID兼容)的表,支持行级锁定和外键约束。InnoDB具有崩溃恢复能力,对于需要高并发读写和事务支持的应用场景非常适用。它采用聚簇索引,将数据和索引存储在一起,优化了点查询和范围查询的性能。MyISAMMyISAM是MySQL的传统存储引擎,它提供了较快的查询性能,特别是对于只读或大量读取的应用。然而,MyISAM不支持事务处理和外键约束,并且在高并发写入时可能表现不佳。MyISAM的数据和索引分开存储在.MYD和.MYI文件中,适用于读取密集型应用。Memory (HEAP)Memory(也称为HEAP)是一种内存引擎,它将数据存储在内存中,因此提供了非常快的访问速度。但是,由于数据存储在内存中,因此数据容量受到内存大小的限制,并且当数据库服务器重启时,数据会丢失。这种引擎适用于缓存、会话管理等轻量级应用。NDB ClusterNDB Cluster是MySQL的簇式数据库引擎,专为高性能查找和高可用性而设计。它可以将数据分布在多台服务器上,提供高可扩展性和高并发性能,适用于大规模分布式系统。CSVCSV是一种文本文件引擎,可以将数据存储在CSV格式的文本文件中。它适用于需要与其他系统进行数据交换的场景,但同样不支持事务处理和外键约束。三、存储引擎之间的区别事务支持:InnoDB支持事务处理,而MyISAM和Memory不支持。这使得InnoDB在需要保证数据一致性和完整性的应用中更具优势。锁定机制:InnoDB支持行级锁定,而MyISAM仅支持表级锁定。行级锁定可以提高并发性能,尤其是在多用户同时更新同一表的不同行时。数据存储:InnoDB采用聚簇索引,将数据和索引存储在一起,而MyISAM则将数据和索引分开存储。这使得InnoDB在点查询和范围查询方面具有较高的性能。崩溃恢复:InnoDB具有崩溃恢复能力,可以在数据库崩溃后自动恢复数据。而MyISAM在数据库崩溃时可能会丢失数据。数据容量和持久性:Memory引擎将数据存储在内存中,因此其数据容量受到内存大小的限制,并且在数据库服务器重启时数据会丢失。相比之下,InnoDB和MyISAM将数据存储在磁盘上,具有更大的数据容量和持久性。四、总结MySQL的多种存储引擎为开发者提供了灵活性和可扩展性。选择合适的存储引擎对于优化数据库性能至关重要。在选择存储引擎时,需要考虑应用的需求、并发性、数据一致性、数据容量和持久性等因素。通过了解各种存储引擎的特点和区别,开发者可以更好地选择适合自己应用的存储引擎。
-
本PPT主要介绍了武汉大学弘毅学堂计算机专业的同学学完数据库系统实现后,开发一个移动端数据库的教学课件。该课件重点介绍了该数据库开发的技术路线。文档可以通过百度网盘进行下载。https://pan.baidu.com/s/1pPqhwQ5t9IEURZ5cc4Z0iw 提取码: vgk7
-
主要代码PGReplicationStream stream = pgConnection.getReplicationAPI() .replicationStream() .logical() .withSlotName("test_slot") .withSlotOption("include-xids", false) .withStatusInterval(2000, TimeUnit.SECONDS) .start();在调用 stream.read();方法的时候 报错 org.postgresql.util.PSQLException: FATAL: insufficient data left in messagestream.read() 在正常打印一部分数据 后才报错误,如图:求帮助 ,感谢。
-
想要学习openGauss找不到环境实践?想要试用openGauss,测试下语法和兼容性等?想要测试和复现一些问题又不想自己搭环境?我懂,就是懒不想搭环境!推荐大家使用O3社区上线的沙箱,https://cn.o3community.huawei.com/o3/1663500457860972546/detail?activeIndex=4&subIndex=1&o3src=https%3A%2F%2Fcn.o3.huawei.com%2Fstmo3%2Ftraining%2Flab-online-detail-shixizhi%3FlabType%3D3%26labId%3D5639%26domainCode%3DFORUM_221126028当前我们做了个单机的实验环境(ARM+openEuler 22.03 LTS+openGauss5.0.0),用户可以在上面预约使用,一次预约可以使用3小时,结束后释放并且复原环境。后续看需求陆续也把集群也上线>_<
-
在MySQL转神通数据库时,在网上找了一篇可以代替MySQL自带的AES_ENCRYPT加密函数。考虑到直接用数据库加密对性能会有影响,所以打算用java代码加密后直接存到数据库中。请问如何用Java代码实现ENCRYPT_ORA这个函数呢?或者说ENCRYPT_ORA底层是如何加密的呢?
上滑加载中
推荐直播
-
HDC深度解读系列 - Serverless与MCP融合创新,构建AI应用全新智能中枢2025/08/20 周三 16:30-18:00
张昆鹏 HCDG北京核心组代表
HDC2025期间,华为云展示了Serverless与MCP融合创新的解决方案,本期访谈直播,由华为云开发者专家(HCDE)兼华为云开发者社区组织HCDG北京核心组代表张鹏先生主持,华为云PaaS服务产品部 Serverless总监Ewen为大家深度解读华为云Serverless与MCP如何融合构建AI应用全新智能中枢
回顾中 -
关于RISC-V生态发展的思考2025/09/02 周二 17:00-18:00
中国科学院计算技术研究所副所长包云岗教授
中科院包云岗老师将在本次直播中,探讨处理器生态的关键要素及其联系,分享过去几年推动RISC-V生态建设实践过程中的经验与教训。
回顾中 -
一键搞定华为云万级资源,3步轻松管理企业成本2025/09/09 周二 15:00-16:00
阿言 华为云交易产品经理
本直播重点介绍如何一键续费万级资源,3步轻松管理成本,帮助提升日常管理效率!
回顾中
热门标签