0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

当MySQL单表记录数过大时,增删改查性能都会急剧下降

jf_TEuU2tls 来源:浩道linux 作者:低至一折起 2022-12-15 11:44 次阅读

当MySQL单表记录数过大时,增删改查性能都会急剧下降

单表优化

除非单表数据未来会一直不断上涨,否则不要一开始就考虑拆分,拆分会带来逻辑、部署、运维的各种复杂度,一般以整型值为主的表在千万级以下,字符串为主的表在五百万以下是没有太大问题的。

而事实上很多时候 MySQL 单表的性能依然有不少优化空间,甚至能正常支撑千万级以上的数据量。

字段

  • 尽量使用 TINYINT、 SMALLINT、 MEDIUM_INT 作为整数类型而非 INT,如果非负则加上 UNSIGNED

  • VARCHAR 的长度只分配真正需要的空间

  • 使用枚举或整数代替字符串类型

  • 尽量使用 TIMESTAMP 而非 DATETIME

  • 单表不要有太多字段,建议在 20 以内

  • 避免使用 NULL 字段,很难查询优化且占用额外索引空间

  • 用整型来存 IP

索引

  • 索引并不是越多越好,要根据查询有针对性的创建,考虑在 WHERE 和 ORDER BY

  • 命令上涉及的列建立索引,可根据 EXPLAIN 来查看是否用了索引还是全表扫描

  • 应尽量避免在 WHERE 子句中对字段进行 NULL 值判断,否则将导致引擎放弃使用索引而进行全表扫描

  • 值分布很稀少的字段不适合建索引,例如"性别"这种只有两三个值的字段

  • 字符字段只建前缀索引

  • 字符字段最好不要做主键

  • 不用外键,由程序保证约束

  • 尽量不用 UNIQUE,由程序保证约束

  • 使用多列索引时主意顺序和查询条件保持一致,同时删除不必要的单列索引

查询SQL

  • 可通过开启慢查询日志来找出较慢的 SQL

  • 不做列运算:SELECT id WHERE age+1=10,任何对列的操作都将导致表扫描,它包括数据库教程函数、计算表达式等等,查询时要尽可能将操作移至等号右边

  • sql 语句尽可能简单:一条 sql 只能在一个 cpu 运算;大语句拆小语句,减少锁时间;一条大sql 可以堵死整个库

  • 不用 SELECT *

  • OR 改写成 IN:OR 的效率是 n 级别, IN 的效率是 log(n) 级别,IN 的个数建议控制在 200 以内

  • 不用函数和触发器,在应用程序实现

  • 避免 %xxx 式查询

  • 少用 JOIN

  • 使用同类型进行比较,比如用 '123' 和 '123' 比, 123 和 123 比

  • 尽量避免在 WHERE 子句中使用 != 或 <> 操作符,否则将引擎放弃使用索引而进行全表扫描

  • 对于连续数值,使用 BETWEEN 不用 IN:SELECT id FROM t WHERE num BETWEEN 1 AND 5

  • 列表数据不要拿全表,要使用 LIMIT 来分页,每页数量也不要太大

引擎

目前广泛使用的是 MyISAM 和 InnoDB 两种引擎:

MyISAM

MyISAM 引擎是 MySQL 5.1 及之前版本的默认引擎,它的特点是:

  • 不支持行锁,读取时对需要读到的所有表加锁,写入时则对表加排它锁

  • 不支持事务

  • 不支持外键

  • 不支持崩溃后的安全恢复

  • 在表有读取查询的同时,支持往表中插入新纪录

  • 支持 BLOB 和 TEXT 的前 500 个字符索引,支持全文索引

  • 支持延迟更新索引,极大提升写入性能

  • 对于不会进行修改的表,支持压缩表,极大减少磁盘空间占用

InnoDB

InnoDB 在 MySQL 5.5 后成为默认索引,它的特点是:

  • 支持行锁,采用 MVCC 来支持高并发

  • 支持事务

  • 支持外键

  • 支持崩溃后的安全恢复

  • 不支持全文索引(5.6.4之后版本逐渐开始支持)

总体来讲,MyISAM 适合 SELECT 密集型的表,而 InnoDB 适合 INSERT 和 UPDATE 密集型的表

系统调优参数

可以使用下面几个工具来做基准测试:

  • sysbench:一个模块化,跨平台以及多线程的性能测试工具

  • iibench-mysql:基于 Java 的 MySQL/Percona/MariaDB 索引进行插入性能测试工具

  • tpcc-mysql:Percona 开发的 TPC-C 测试工具

具体的调优参数内容较多,具体可参考官方文档,这里介绍一些比较重要的参数:

  • backlog:backlog 值指出在 MySQL 暂时停止回答新请求之前的短时间内多少个请求可以被存在堆栈中。也就是说,如果 MySql 的连接数据达到 maxconnections 时,新来的请求将会被存在堆栈中,以等待某一连接释放资源,该堆栈的数量即 backlog,如果等待连接的数量超过back_log,将不被授予连接资源。可以从默认的 50 升至 500

  • wait_timeout:数据库连接闲置时间,闲置连接会占用内存资源。可以从默认的 8 小时减到半小时

  • maxuserconnection:最大连接数,默认为 0 无上限,最好设一个合理上限

  • thread_concurrency:并发线程数,设为 CPU 核数的两倍

  • skipnameresolve:禁止对外部连接进行 DNS 解析,消除 DNS 解析时间,但需要所有远程主机用 IP 访问

  • keybuffersize:索引块的缓存大小,增加会提升索引处理速度,对 MyISAM 表性能影响最大。对于内存 4G 左右,可设为 256M 或 384M,通过查询show status like'key_read%',保证 key_reads / key_read_requests 在 0.1% 以下最好

  • innodbbufferpool_size:缓存数据块和索引块,对 InnoDB 表性能影响最大。通过查询show status like'Innodb_buffer_pool_read%',保证(Innodb_buffer_pool_read_requests –
    Innodb_buffer_pool_reads) / Innodb_buffer_pool_read_requests
    越高越好

  • innodbadditionalmempoolsize:InnoDB 存储引擎用来存放数据字典信息以及一些内部数据结构的内存空间大小,当数据库对象非常多的时候,适当调整该参数的大小以确保所有数据都能存放在内存中提高访问效率,当过小的时候,MySQL 会记录 Warning 信息到数据库的错误日志中,这时就需要该调整这个参数大小

  • innodblogbuffer_size:InnoDB 存储引擎的事务日志所使用的缓冲区,一般来说不建议超过
    32MB

  • querycachesize:缓存 MySQL 中的 ResultSet,也就是一条 SQL 语句执行的结果集,所以仅仅只能针对 select 语句。当某个表的数据有任何任何变化,都会导致所有引用了该表的select 语句在 Query Cache 中的缓存数据失效。所以,当我们的数据变化非常频繁的情况下,使用 Query Cache 可能会得不偿失。根据命中率(Qcache_hits / (Qcache_hits + Qcache_inserts) * 100))进行调整,一般不建议太大,256MB 可能已经差不多了,大型的配置型静态数据可适当调大. 可以通过命令show status like'Qcache_%'查看目前系统 Query Catch 使用大小

  • readbuffersize:MySql 读入缓冲区大小。对表进行顺序扫描的请求将分配一个读入缓冲区,MySql 会为它分配一段内存缓冲区。如果对表的顺序扫描请求非常频繁,可以通过增加该变量值以及内存缓冲区大小提高其性能

  • sortbuffersize:MySql 执行排序使用的缓冲大小。如果想要增加 ORDER BY 的速度,首先看是否可以让 MySQL 使用索引而不是额外的排序阶段。如果不能,可以尝试增加 sortbuffersize 变量的大小

  • readrndbuffer_size:MySql 的随机读缓冲区大小。当按任意顺序读取行时(例如,按照排序顺序),将分配一个随机读缓存区。进行排序查询时,MySql 会首先扫描一遍该缓冲,以避免磁盘搜索,提高查询速度,如果需要排序大量数据,可适当调高该值。但 MySql 会为每个客户连接发放该缓冲空间,所以应尽量适当设置该值,以避免内存开销过大

  • record_buffer:每个进行一个顺序扫描的线程为其扫描的每张表分配这个大小的一个缓冲区。如果你做很多顺序扫描,可能想要增加该值

  • threadcachesize:保存当前没有与连接关联但是准备为后面新的连接服务的线程,可以快速响应连接的线程请求而无需创建新的

  • tablecache:类似于 threadcache_size,但用来缓存表文件,对 InnoDB 效果不大,主要用于 MyISAM

升级硬件

Scale up,这个不多说了,根据 MySQL 是 CPU 密集型还是 I/O 密集型,通过提升 CPU 和内存、使用 SSD,都能显著提升 MySQL 性能。

读写分离

也是目前常用的优化,从库读主库写,一般不要采用双主或多主引入很多复杂性,尽量采用文中的其他方案来提高性能。

同时目前很多拆分的解决方案同时也兼顾考虑了读写分离。

缓存

缓存可以发生在这些层次:

  • MySQL 内部:在系统调优参数介绍了相关设置

  • 数据访问层:比如 MyBatis 针对 SQL 语句做缓存,而 Hibernate 可以精确到单个记录,这里缓存的对象主要是持久化对象 PersistenceObject

  • 应用服务层:这里可以通过编程手段对缓存做到更精准的控制和更多的实现策略,这里缓存的对象是数据传输对象 DataTransferObject(DTO)

  • Web 层:针对 web 页面做缓存

  • 浏览器客户端:用户端的缓存

可以根据实际情况在一个层次或多个层次结合加入缓存。

这里重点介绍下服务层的缓存实现,目前主要有两种方式:

  • 直写式(Write Through):在数据写入数据库后,同时更新缓存,维持数据库与缓存的一致性。这也是当前大多数应用缓存框架如 Spring Cache 的工作方式。这种实现非常简单,同步好,但效率一般。

  • 回写式(Write Back):当有数据要写入数据库时,只会更新缓存,然后异步批量的将缓存数据同步到数据库上。这种实现比较复杂,需要较多的应用逻辑,同时可能会产生数据库与缓存的不同步,但效率非常高。

表分区

MySQL 在 5.1 版引入的分区是一种简单的水平拆分,用户需要在建表的时候加上分区参数,对应用是透明的无需修改代码

对用户来说,分区表是一个独立的逻辑表,但是底层由多个物理子表组成,实现分区的代码实际上是通过对一组底层表的对象封装,但对 SQL 层来说是一个完全封装底层的黑盒子。MySQL 实现分区的方式也意味着索引也是按照分区的子表定义,没有全局索引。

327c7444-7c19-11ed-8abf-dac502259ad0.jpg

用户的 SQL 语句是需要针对分区表做优化,SQL 条件中要带上分区条件的列,从而使查询定位到少量的分区上,否则就会扫描全部分区,可以通过 EXPLAIN PARTITIONS 来查看某条SQL 语句会落在那些分区上,从而进行 SQL 优化,如下图 5 条记录落在两个分区上:

328bbb0c-7c19-11ed-8abf-dac502259ad0.jpg

分区的好处是:

  • 可以让单表存储更多的数据

  • 分区表的数据更容易维护,可以通过清楚整个分区批量删除大量数据,也可以增加新的分区来支持新插入的数据。另外,还可以对一个独立分区进行优化、检查、修复等操作

  • 部分查询能够从查询条件确定只落在少数分区上,速度会很快

  • 分区表的数据还可以分布在不同的物理设备上,从而高效利用多个硬件设备

  • 可以使用分区表赖避免某些特殊瓶颈,例如 InnoDB 单个索引的互斥访问、ext3 文件系统的
    inode 锁竞争

  • 可以备份和恢复单个分区

分区的限制和缺点:

  • 一个表最多只能有 1024 个分区

  • 如果分区字段中有主键或者唯一索引的列,那么所有主键列和唯一索引列都必须包含进来

  • 分区表无法使用外键约束

  • NULL 值会使分区过滤无效

  • 所有分区必须使用相同的存储引擎

分区的类型:

  • RANGE 分区:基于属于一个给定连续区间的列值,把多行分配给分区

  • LIST 分区:类似于按 RANGE 分区,区别在于 LIST 分区是基于列值匹配一个离散值集合中的某个值来进行选择

  • HASH 分区:基于用户定义的表达式的返回值来进行选择的分区,该表达式使用将要插入到表中的这些行的列值进行计算。这个函数可以包含 MySQL 中有效的、产生非负整数值的任何表达式

  • KEY 分区:类似于按 HASH 分区,区别在于 KEY 分区只支持计算一列或多列,且 MySQL 服务器提供其自身的哈希函数。必须有一列或多列包含整数值

分区适合的场景有:

最适合的场景数据的时间序列性比较强,则可以按时间来分区,如下所示:

329d551a-7c19-11ed-8abf-dac502259ad0.jpg

查询时加上时间范围条件效率会非常高,同时对于不需要的历史数据能很容的批量删除。

如果数据有明显的热点,而且除了这部分数据,其他数据很少被访问到,那么可以将热点数据单独放在一个分区,让这个分区的数据能够有机会都缓存在内存中,查询时只访问一个很小的分区表,能够有效使用索引和缓存。

另外 MySQL 有一种早期的简单的分区实现 - 合并表(merge table),限制较多且缺乏优化,不建议使用,应该用新的分区机制来替代

垂直拆分

垂直分库是根据数据库里面的数据表的相关性进行拆分。

比如:一个数据库里面既存在用户数据,又存在订单数据,那么垂直拆分可以把用户数据放到用户库、把订单数据放到订单库。

垂直分表是对数据表进行垂直拆分的一种方式,常见的是把一个多字段的大表按常用字段和非常用字段进行拆分,每个表里面的数据记录数一般情况下是相同的,只是字段不一样,使用主键关联

比如原始的用户表是:

32cfd6e8-7c19-11ed-8abf-dac502259ad0.jpg

垂直拆分后是:

32e31424-7c19-11ed-8abf-dac502259ad0.jpg

垂直拆分的优点是:

  • 可以使得行数据变小,一个数据块( Block )就能存放更多的数据,在查询时就会减少 I/O 次数(每次查询时读取的 Block 就少)

  • 可以达到最大化利用 Cache 的目的,具体在垂直拆分的时候可以将不常变的字段放一起,将经常改变的放一起

  • 数据维护简单

缺点是:

  • 主键出现冗余,需要管理冗余列

  • 会引起表连接 JOIN 操作(增加 CPU 开销)可以通过在业务服务器上进行 join 来减少数据库压力

  • 依然存在单表数据量过大的问题(需要水平拆分)

  • 事务处理复杂

水平拆分

概述

水平拆分是通过某种策略将数据分片来存储,分库内分表和分库两部分,每片数据会分散到不同的 MySQL 表或库,达到分布式的效果,能够支持非常大的数据量。前面的表分区本质上也是一种特殊的库内分表。

库内分表,仅仅是单纯的解决了单一表数据过大的问题,由于没有把表的数据分布到不同的机器上,因此对于减轻 MySQL 服务器的压力来说,并没有太大的作用,大家还是竞争同一个物理机上的 IO、CPU、网络,这个就要通过分库来解决

前面垂直拆分的用户表如果进行水平拆分,结果是:

32f5777c-7c19-11ed-8abf-dac502259ad0.jpg

实际情况中往往会是垂直拆分和水平拆分的结合,即将 Users_A_M 和 Users_N_Z 再拆成 Users 和 UserExtras,这样一共四张表

水平拆分的优点是:

  • 不存在单库大数据和高并发的性能瓶颈

  • 应用端改造较少

  • 提高了系统的稳定性和负载能力

缺点是:

  • 分片事务一致性难以解决

  • 跨节点 Join 性能差,逻辑复杂

  • 数据多次扩展难度跟维护量极大

分片原则

  • 能不分就不分,参考单表优化

  • 分片数量尽量少,分片尽量均匀分布在多个数据结点上,因为一个查询 SQL 跨分片越多,则总体性能越差,虽然要好于所有数据在一个分片的结果,只在必要的时候进行扩容,增加分片数量

  • 分片规则需要慎重选择做好提前规划,分片规则的选择,需要考虑数据的增长模式,数据的访问模式,分片关联性问题,以及分片扩容问题,最近的分片策略为范围分片,枚举分片,一致性 Hash 分片,这几种分片都有利于扩容

  • 尽量不要在一个事务中的 SQL 跨越多个分片,分布式事务一直是个不好处理的问题

  • 查询条件尽量优化,尽量避免 Select * 的方式,大量数据结果集下,会消耗大量带宽和
    CPU 资源,查询尽量避免返回大量结果集,并且尽量为频繁使用的查询语句建立索引。

  • 通过数据冗余和表分区依赖降低跨库 Join 的可能

这里特别强调一下分片规则的选择问题,如果某个表的数据有明显的时间特征,比如订单、交易记录等,则他们通常比较合适用时间范围分片,因为具有时效性的数据,我们往往关注其近期的数据,查询条件中往往带有时间字段进行过滤,比较好的方案是,当前活跃的数据,采用跨度比较短的时间段进行分片,而历史性的数据,则采用比较长的跨度存储。

总体上来说,分片的选择是取决于最频繁的查询 SQL 的条件,因为不带任何 Where 语句的查询 SQL,会遍历所有的分片,性能相对最差,因此这种 SQL 越多,对系统的影响越大,所以我们要尽量避免这种 SQL 的产生。

解决方案

由于水平拆分牵涉的逻辑比较复杂,当前也有了不少比较成熟的解决方案。这些方案分为两大类:

  • 客户端架构

  • 代理架构

客户端架构

通过修改数据访问层,如 JDBC、Data Source、MyBatis,通过配置来管理多个数据源,直连数据库,并在模块内完成数据的分片整合,一般以 Jar 包的方式呈现

这是一个客户端架构的例子:

330d20d4-7c19-11ed-8abf-dac502259ad0.jpg

可以看到分片的实现是和应用服务器在一起的,通过修改 Spring JDBC 层来实现

客户端架构的优点是:

  • 应用直连数据库,降低外围系统依赖所带来的宕机风险

  • 集成成本低,无需额外运维的组件

缺点是:

  • 限于只能在数据库访问层上做文章,扩展性一般,对于比较复杂的系统可能会力不从心

  • 将分片逻辑的压力放在应用服务器上,造成额外风险

代理架构

通过独立的中间件来统一管理所有数据源和数据分片整合,后端数据库集群对前端应用程序透明,需要独立部署和运维代理组件

这是一个代理架构的例子:

331e3374-7c19-11ed-8abf-dac502259ad0.jpg

代理组件为了分流和防止单点,一般以集群形式存在,同时可能需要 Zookeeper 之类的服务组件来管理

代理架构的优点是:

  • 能够处理非常复杂的需求,不受数据库访问层原来实现的限制,扩展性强

  • 对于应用服务器透明且没有增加任何额外负载

缺点是:

  • 需部署和运维独立的代理中间件,成本高

  • 应用需经过代理来连接数据库,网络上多了一跳,性能有损失且有额外风险

各方案比较

框架 出品方 架构模型 支持数据库 分库 分表 读写分离 外部依赖 是否开源 实现语言 支持语言 GitHub星数
MySQL Fabric MySQL官方 代理架构 MySQL python 无限制 35
Cobar 阿里巴巴 代理架构 MySQL Java 无限制 1287
Cobar Client 阿里巴巴 客户端架构 MySQL Java Java 344
TDDL 淘宝 客户端架构 无限制 Diamond 只开源部分 Java Java 519
Atlas 奇虎360 代理架构 MySQL C 无限制 1941
Heisenberg 百度熊照 代理架构 MySQL Java 无限制 197
TribeDB 个人 代理架构 MySQL NodeJS 无限制 126
Sharding JDBC 当当 客户端架构 MySQL Java Java 1144
Shark 个人 客户端架构 MySQL Java Java 84
KingShard 个人 代理架构 MySQL Golang 无限制 1836
OneProxy 平民软件 代理架构 MySQL 未知 无限制 未知
MyCat 社区 代理架构 MySQL Java 无限制 1270
Vitess Youtube 代理架构 MySQL Golang 无限制 3636
Mixer 个人 代理架构 MySQL Golang 无限制 472
JetPants Tumblr 客户端架构 MySQL Ruby Ruby 957
HibernateShard Hibernate 客户端架构 无限制 Java Java 57
MybatisShard MakerSoft 客户端架构 无限制 Java Java 119
Gizzard Twitter 代理架构 无限制 Java 无限制 2087


如此多的方案,如何进行选择?可以按以下思路来考虑:

  • 确定是使用代理架构还是客户端架构。中小型规模或是比较简单的场景倾向于选择客户端架构,复杂场景或大规模系统倾向选择代理架构

  • 具体功能是否满足,比如需要跨节点 ORDER BY,那么支持该功能的优先考虑

  • 不考虑一年内没有更新的产品,说明开发停滞,甚至无人维护和技术支持

  • 最好按大公司 -> 社区 -> 小公司 -> 个人这样的出品方顺序来选择

  • 选择口碑较好的,比如 GitHub 星数、使用者数量质量和使用者反馈

  • 开源的优先,往往项目有特殊需求可能需要改动源代码

按照上述思路,推荐以下选择:

  • 客户端架构:ShardingJDBC

  • 代理架构:MyCat 或 Atlas

兼容 MySQL 且可水平扩展的数据库

目前也有一些开源数据库兼容 MySQL 协议,如:

  1. https://github.com/pingcap/tidb

  2. http://www.cubrid.org/

但其工业品质和 MySQL 尚有差距,且需要较大的运维投入,如果想将原始的 MySQL 迁移到可水平扩展的新数据库中,可以考虑一些云数据库:

  1. https://cn.aliyun.com/product/petadata/?spm=5176.7960203.237031.38.cAzx5r

  2. https://cn.aliyun.com/product/oceanbase?spm=5176.7960203.237031.40.cAzx5r

  3. https://www.qcloud.com/product/dcdbfortdsql.html

NoSQL

在 MySQL 上做 Sharding 是一种戴着镣铐的跳舞,事实上很多大表本身对 MySQL 这种
RDBMS 的需求并不大,并不要求 ACID,可以考虑将这些表迁移到 NoSQL,彻底解决水平扩展问题,例如:

  • 日志类、监控类、统计类数据

  • 非结构化或弱结构化数据

  • 对事务要求不强,且无太多关联操作的数据

审核编辑 :李倩


声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 数据库
    +关注

    关注

    7

    文章

    3754

    浏览量

    64255
  • MySQL
    +关注

    关注

    1

    文章

    799

    浏览量

    26413

原文标题:谁还说不懂MySQL常用优化,我就把这个丢过去!

文章出处:【微信号:浩道linux,微信公众号:浩道linux】欢迎添加关注!文章转载请注明出处。

收藏 人收藏

    评论

    相关推荐

    tlv320aic3101怎样才能在使用AGC效果的同时,保证SINAD参数的良好?

    mVRMS 时,输出信号出现削峰,此时SINAD急剧下降。 (2)芯片的总增益为一定值K,通过对寄存器进行设置,将最终输出恒定设置为630 mVRMS 输出随输入的增加,第一次到达630 mVRMS
    发表于 11-06 06:51

    电源轨的封装电感过大怎么办

    电源轨的封装电感过大时,可能会对电路的性能和稳定性产生不利影响,如增加能量损耗、降低效率、增加噪声等。针对这一问题,可以采取以下几种方法来解决:
    的头像 发表于 10-01 15:32 189次阅读

    磁路饱和对磁路的等效电感有何影响

    。磁路饱和通常发生在磁路中磁通密度较高的区域,如磁芯、磁环等。 磁路饱和的原因主要有以下几点: 1.1 材料特性:不同的磁性材料具有不同的饱和磁通密度,磁通密度超过材料的饱和磁通密度时,磁导率会急剧下降,导致磁路饱
    的头像 发表于 08-29 15:20 757次阅读

    精准记录,高效分析:北斗现场记录仪在各行各业的应用

    在这个信息爆炸、效率至上的时代,每一个细节的记录与分析都成为了推动行业进步的关键力量。北斗现场记录仪,作为集高精度定位、高清视频录制、智能数据分析于一体的创新设备,正悄然改变着各行各业的作业模式
    的头像 发表于 08-28 11:46 298次阅读
    精准<b class='flag-5'>记录</b>,高效分析:<b class='flag-5'>单</b>北斗现场<b class='flag-5'>记录</b>仪在各行各业的应用

    索尼日本裁员应对光盘需求下滑

    近日,索尼公司宣布将在其位于日本东北部的可记录媒体制造厂进行大规模裁员,共计250名员工将受到影响。此次裁员的主要原因是随着流媒体服务的日益普及,消费者对传统光盘媒体的需求急剧下降,导致市场销量萎缩。
    的头像 发表于 07-02 16:07 1177次阅读

    电感饱和会有怎么样的后果

    电感饱和是指电感器的磁芯达到其磁化曲线的饱和区,此时磁芯的磁导率急剧下降,导致电感值显著降低。
    的头像 发表于 05-06 15:22 4167次阅读

    如何通过PCB接地设计实现环路面积最小化

    对于低频磁场屏蔽采用高磁导率材料的选择非常重要,磁导率会随外界磁场强度的变化而变。外加磁场强度较低时,磁导率会随磁场强度的增加而升高,而外加的磁场强度超过某限值时,磁导率就会急剧下降,此时磁导材料发生了磁饱和,也意味着该材料
    发表于 02-28 11:43 2821次阅读
    如何通过PCB接地设计实现环路面积最小化

    运算放大器电路的放大倍数为什么不能太大或太小呢?

    或过小都会对电路的性能产生不良影响。本文将详细讨论为什么放大倍数不能过大或过小,并对其原因进行详实而细致的解释。 首先,让我们讨论为什么放大倍数过大会引起问题。
    的头像 发表于 02-04 09:32 2833次阅读

    鸿蒙ArkUI开发-实现增删Tab页签

    本文以浏览器中增加或删除页签为例,实现Tabs中页签的增删功能。
    的头像 发表于 01-29 18:43 1527次阅读
    鸿蒙ArkUI开发-实现<b class='flag-5'>增删</b>Tab页签

    阿里二面:了解MySQL事务底层原理吗

    MySQL 是如何来解决脏写这种问题的?没错,就是锁。MySQL 在开启一个事务的时候,他会将某条记录和事务做一个绑定。这个其实和 JVM 锁是类似的。
    的头像 发表于 01-18 16:34 310次阅读
    阿里二面:了解<b class='flag-5'>MySQL</b>事务底层原理吗

    什么是锂电池的内阻?锂电池内阻过大或过小对电池有什么影响?

    对电池产生不利影响。 首先,内阻过大会导致电池的电压下降。内阻会消耗电压,使得电池输出的电压无法达到设计值。这会降低电池的能量密度和容量,限制了电池的使用时间和性能内阻
    的头像 发表于 01-10 15:47 6895次阅读

    伺服电机中的刚性是什么意思 伺服电机刚性过大导致什么后果

    ,控制精度越高。 刚性过大的后果包括: 1. 动态性能降低:刚性过大会使得伺服电机的动态响应能力降低,降低控制系统的速度和加速度性能。 2. 控制精度
    的头像 发表于 12-20 17:36 7869次阅读

    谁说MySQL表行数不要超过2000W?

    网上看了一篇文章《为什么说MySQL表行数不要超过2000w》,亲自实践了一下,跟原作者有不同的结论。原文的结论是2000W左右性能会成指数级的下降,而我的结论是:随着数据量成倍地增
    的头像 发表于 12-15 10:02 984次阅读
    谁说<b class='flag-5'>MySQL</b><b class='flag-5'>单</b>表行数不要超过2000W?

    MySQL性能优化方法

    MySQL 性能优化是一项关键的任务,可以提高数据库的运行速度和效率。以下是一些优化方法,包括具体代码和详细优化方案。
    的头像 发表于 11-22 09:59 541次阅读

    电动机带负载不能起动的解决方法

    电动机带负载不能起动或加上负载转速就急剧下降怎么办?
    的头像 发表于 11-18 16:50 2502次阅读