`
IXHONG
  • 浏览: 456377 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

唯品会Redis cluster大规模生产实践经验

阅读更多

嘉宾:陈群
很高兴有机会给大家分享redis cluster的生产实践经验。目前在唯品会主要负责redis/hbase的运维和开发支持工作,也参与工具开发工作。

Outline
一、生产应用场景
二、存储架构演变
三、应用最佳实践
四、运维经验总结
第1、2节:介绍redis cluster在唯品会的生产应用场景,以及存储架构的演变。
第3节:redis cluster的稳定性,应用成熟度,踩到过那些坑,如何解决这些问题?这部分是大家比较关心的内容。
第4节:简单介绍大规模运营的一些经验,包括部署、监控、管理以及redis工具开发。

一、生产应用场景
1、业务范围
redis cluster在唯品会主要应用于后端业务,用作内存存储服务。主要大数据实时推荐/ETL、风控、营销三大业使用。cluster用于取代当前twemproxy三层架构,作为通用的存储架构。redis cluster可以大幅度简化我们的存储架构,也解决twemproxy架构无法在线扩容节点的问题。目前我们在线有生产几十个cluster集群,约2千个instances,单个集群最大达到250+instances。
这是我们的生产应用场景,主要是后端业务的存储,目前没有作为cache使用的场景。

2、大数据、风控、营销系统的特征

  • cluster作为数据量大, 单个cluster集群在几十个GB到上TB级别内存存储量。
  • 作为后端应用的存储,数据来源主要以下三种方式:
    • Kafka --> Redis Cluster,Storm/Spark实时
    • Hive -->  Redis Cluster,  MapReduce程序
    • MySQL -->  Redis Cluster,Java/C++程序。
  • 数据由离线/实时job生成, 读写请求量大, 对读写性能也要求高。
  • 业务高峰期请求量急剧上升,几倍的读写量增加,需要多个redis实例承担业务的读写压力。
  • 业务需求变化快, schema变化频繁。如果使用MySQL作为存储,那么将会是频繁的DLL变更,而且需要做online schema change。
  • 大促销活动时扩容频繁。


3、为什么选择redis cluster3.1 cluster适合我们后端生产应用场景

  • 在线水平扩展能力,能够解决我们大量的扩容需求。
  • Failover能力和高可用性。
  • 虽然cluster不保证主从数据强一致性,但是后端业务能够容忍failover后少量的数据丢失。

3.2 架构简单

  • 无中心架构,各个节点度等。slave节点提供数据冗余,master节点异常时提升为master。
  • 取代twemproxy三层架构,系统复杂性降低。
  • 可以节约大量的硬件资源,我们的Lvs + Twemproxy层 使用了近上千台物理机器。
  • 少了lvs和twemproxy层,读写性能提升明显。响应时间从100-200us减少到50-100us。
  • 系统瓶颈更少。lvs层网卡和pps吞吐量瓶颈;对于请求长度较大的业务,twemproxy单节点性能低。
    总结下,我们选择redis cluster主要这两点原因:简单、扩展性。另外,我们用cluster取代twemproxy集群,三层架构实在是很令人头疼,复杂、瓶颈多、管理不方面。


二、存储架构演变

1、架构演变
<ignore_js_op style="word-wrap: break-word; color: rgb(68, 68, 68); font-family: Tahoma, Helvetica, SimSun, sans-serif;"> 

在2014年7月,为了准备当时的814撒娇节大促销活动,我们把单个redis的服务迁移到twemproxy上。twemproxy在后端快速完成数据分片和扩容。为了避免再次扩容,我们静态分配足够多的资源。
之后,twemproxy暴露出来的系统瓶颈很多,资源使用很多,也存在一定的浪费。我们决定用redis cluster取代这种复杂的三层架构。
redis cluster GA之后,我们就开始上线使用。最初是3.0.2 版本,后面大量使用3.0.3 ,上个月开始使用3.0.7版本。
下面简单对比下两种架构,解析下他们的优缺点。

2、Twemproxy架构优点

  • sharding逻辑对开发透明,读写方式和单个redis一致。
  • 可以作为cache和storage的proxy(by auto-eject)。


缺点

  • 架构复杂,层次多。包括lvs、twemproxy、redis、sentinel和其控制层程序。
  • 管理成本和硬件成本很高。
  • 2 * 1Gbps 网卡的lvs机器,最大能支撑140万pps。
  • 流量高的系统,proxy节点数和redis个数接近。
  • Redis层仍然扩容能力差,预分配足够的redis存储节点。

<ignore_js_op style="word-wrap: break-word; color: rgb(68, 68, 68); font-family: Tahoma, Helvetica, SimSun, sans-serif;"> 


这是twemproxy的架构,客户端直接连接最上面的lvs(LB),第二层是同构的twemproxy节点,下面的redis master节点以及热备的slave节点,另外还有独立的sentinel集群和切换控制程序,twemproxy先介绍到这里。

3、Redis Cluster架构优点

  • 无中心 架构。
  • 数据按照slot存储分布在多个redis实例上。
  • 增加slave做standby数据副本,用于failover,使集群快速恢复。
  • 实现故障auto failover。节点之间通过gossip协议交换状态信息;投票机制完成slave到master角色的提升。
  • 亦可manual failover,为升级和迁移提供可操作方案。
  • 降低硬件成本和运维成本,提高系统的扩展性和可用性。


缺点和不足的地方

  • client实现复杂,驱动要求实现smart client,缓存slots mapping信息并及时更新。
  • 目前仅JedisCluster相对成熟,异常处理部分还不完善,比如常见的“max redirect exception”。
  • 客户端的不成熟,影响应用的稳定性,提高开发难度。
  • 节点会因为某些原因发生阻塞(阻塞时间大于clutser-node-timeout),被判断下线。这种failover是没有必要,sentinel也存在这种切换场景。
    cluster的架构如下:

<ignore_js_op style="word-wrap: break-word; color: rgb(68, 68, 68); font-family: Tahoma, Helvetica, SimSun, sans-serif;"> 


图上只有master节点(slave略去),所有节点构成一个完全图,slave节点在集群中与master只有角色和功能的区别。
架构演变讲完了,开始讲第三部分,也是大家最感兴趣的一部分。

三、应用最佳实践

  • redis cluster的稳定性如何?
  • 存在哪些坑?
  • develop guideline & best practice


1、稳定性

  • 不扩容时集群非常稳定。
  • 扩容resharding时候,早期版本的Jedis端有时会出现“max-redirect”异常。
    分析Jedis源码,请求重试次数达到了上限,仍然没有请求成功。两方面分析:redis连接不上?还是集群节点信息不一致?
  • 存活检测机制缺陷
      redis 存活检测机制可能因为master 节点上慢查询、阻塞式命令、或者其它的性能问题导致长时间没有响应,这个节点会认为处于failed状态,并进行切换。这种切换是没必要的。    优化策略:a) 默认的cluster-node-timeout为15s,可以适当增大;
    b) 避免使用会引起长时间阻塞的命令,比如save/flushdb等阻塞操作,或者keys pattern这种慢查询。

总体来说,redis cluster已经非常稳定了,但是要注意一些应用中的小问题,下面是5个坑,大家注意了。

2、有哪些坑?

2.1 迁移过程中Jedis“Max Redirect”异常。

  • github上讨论的结果是程序retry。
  • max redirt issues:https://github.com/xetorthio/jedis/issues/1238
  • retry时间应该大于failover 时间。
  • Jedis参数优化调整:增大jedis中的‘DEFAULT_MAX_REDIRECTIONS’参数,默认值是5.
  • 避免使用multi-keys操作,比如mset/mget. multi-key操作有些客户端没有支持实现。


2.2 长时间阻塞引起的不必要的failover

  • 阻塞的命令。比如save/flushall/flushdb
  • 慢查询。keys *、大key的操作、O(N)操作
  • rename危险操作:
    • rename-command FLUSHDB REDIS_FLUSHDB
    • rename-command FLUSHALL REDIS_FLUSHALL
    • rename-command KEYS REDIS_KEYS


2.3 同时支持ipv4和ipv6侦听服务埋下的坑
具体现象:redis启动正常,节点的协议端口只有ipv6 socket创建正常。异常节点也无法加入到集群中,也无法获取epoch。
解决方法:启动时指定网卡ipv4地址,也可以是0.0.0.0,配置文件中添加:bind 0.0.0.0
这个是在setup集群的时候发生过的一个问题,bind 0.0.0.0虽然存在一些安全性问题,但是是比较简单通用的解决方法。

2.4 数据迁移速度较慢

  • 主要使用的redis-trib.rb reshard来完成数据迁移。
  • redis-3.0.6版本以前migrate操作是单个key逐一操作。从redis-3.0.6开始,支持单次迁移多个key。
  • redis集群内部最多只允许一个slot处于迁移状态,不能并发的迁移slots。
  • redis-trib.rb reshard如果执行中断,用redis-trib.rb fix修复集群状态。


2.5 版本选择/升级建议

  • 我们已经开始使用3.0.7版本,很多3.2.0修复的bug已经backport到这个版本。
  • 另外我们也开始测试3.2.0版本,内存空间优化很大。
  • Tips
    • redis-trib.rb支持resharding/rebalance,分配权重。
    • redis-trib.rb支持从单个redis迁移数据到cluster集群中。后面2点不算坑把,算是不足,tips也很实用.开始分享下最佳实践。


3、最佳实践3.1 应用做好容错机制

  • 连接或者请求异常,进行连接retry和reconnect。
  • 重试时间应该大于cluster-node-time时间
    还是强调容错,这个不是针对cluster,所有的应用设计都适用。


3.2 制定开发规范

  • 慢查询,进程cpu 100%、客户端请求变慢,甚至超时。
  • 避免产生hot-key,导致节点成为系统的短板。
  • 避免产生big-key,导致网卡打爆、慢查询。
  • TTL, 设置合理的ttl,释放内存。避免大量key在同一时间段过期,虽然redis已经做了很多优化,仍然会导致请求变慢。
  • key命名规则。
  • 避免使用阻塞操作,不建议使用事务。
    开发规范,使你们的开发按照最优的方式使用nosql。


3.3 优化连接池使用

  • 主要避免server端维持大量的连接。
  • 合理的连接池大小。
  • 合理的心跳检测时间。
  • 快速释放使用完的连接。
  • Jedis一个连接创建异常问题(fixed):
    https://github.com/xetorthio/jedis/issues/1252

连接问题是redis开发使用中最常见的问题,connection timeout/read timeout,还有borrow connection的问题。

3.4 区分redis/twemproxy和cluster的使用

  • redis建议使用pipeline和multi-keys操作,减少RTT次数,提高请求效率。
  • twemproxy也支持pipeline, 支持部分的multi-key可以操作。
  • redis cluster不建议使用pipeline和multi-keys操作,减少max redirect产生的场景。

区分redis 和 cluster的使用,一方面是数据分片引起的;另一方面,与client的实现支持相关。

3.5 几个需要调整的参数
1)设置系统参数vm.overcommit_memory=1,可以避免bgsave/aofrewrite失败。
2)设置timeout值大于0,可以使redis主动释放空闲连接。
3)设置repl-backlog-size 64mb。默认值是1M,当写入量很大时,backlog溢出会导致增量复制不成功。
4)client buffer参数调整
     client-output-buffer-limit normal 256mb 128mb 60
     client-output-buffer-limit slave  512mb  256mb 180

四、运维经验总结1、自动化管理

  • CMDB管理所有的资源信息。
  • Agent方式上报硬软件信息。
  • 标准化基础设置。机型、OS内核参数、软件版本。
  • Puppet管理和下发标准化的配置文件、公用的任务计划、软件包、运维工具。
  • 资源申请自助服务。


2、自动化监控

  • zabbix作为主要的监控数据收集工具。
  • 开发实时性能dashboard,对开发提供查询。
  • 单机部署多个redis,借助于zabbix discovery。
  • 开发DB响应时间监控工具Titan。
  • 基本思想来源于pt-query-degest,通过分析tcp应答报文产生日志。flume agent + kafka收集,spark实时计算,hbase作为存储。最终得到hotquery/slowquery,request source等性能数据。


3、自动化运维

  • 资源申请自助服务化。
  • 如果申请合理,一键即可完成cluster集群部署。
    能不动手的,就坚决不动手,另外,监控数据对开发开发很重要,让他们了解自己服务性能,有时候开发会更早发现集群的一些异常行为,比如数据不过期这种问题,运维就讲这么多了,后面是干货中的干货,由deep同学开发的几个实用工具。


4、redis开源工具介绍4.1 redis实时数据迁移工具
1) 在线实时迁移
2) redis/twemproxy/cluster 异构集群之间相互迁移。
3)github:https://github.com/vipshop/redis-migrate-tool 

4.2 redis cluster管理工具
1)批量更改集群参数
2)clusterrebalance
3)很多功能,具体看github :
https://github.com/deep011/redis-cluster-tool

4.3 多线程版本Twemproxy
1)大幅度提升单个proxy的吞吐量,线程数可配置。
2)压测情况下,20线程达到50w+qps,最优6线程达到29w。
3)完全兼容twemproxy。
4)github:
https://github.com/vipshop/twemproxies

4.4 在开发的中的多线redis
1)Github:
https://github.com/vipshop/vire
2)欢迎一起参与协作开发,这是我们在开发中的项目,希望大家能够提出好的意见。

问答(陈群和申政解答):问题1:版本更新,对数据有没有影响?
答:我们重启升级从2.8.17到3.0.3/3.0.7没有任何的异常。3.0到3.2我们目前还没有实际升级操作过。

问题2:请问下sentinel模式下有什么好的读写分离的方法吗
答:我们没有读写分离的使用,读写都在maste;集群太多,管理复杂;此外,我们也做了分片,没有做读写分离的必要;且我们几乎是一主一从节点配置

问题3:redis的fork主要是为了rdb吧,去掉是为了什么呢
答:fork不友好

问题4:如果不用fork,是怎么保证rdb快照是精确的,有其他cow机制么
答:可以通过其他方法,这个还在探究阶段,但目标是不用fork

问题5:就是redis cluster模式下批量操作会有很多问题,可是不批量操作又会降低业务系统的性能
答:确实存在这方面的问题,这方面支持需要客户端的支持,但是jedis的作者也不大愿意支持pipeline或者一些multi key操作。如果是大批量的操作,可以用多线程提高客户端的吞吐量。

附录:
嘉宾微信:qunchenmy
技术博客:[http://mdba.cn]
微博:[http://weibo.com/sylarqun]
Redis中国用户组官网:[http://redis.cn]
Redis知识图谱:
           [http://lib.csdn.net/base/redis]
           [http://lib.csdn.net/mobile/base/34]


原文链接:http://www.jianshu.com/p/ee2aa7fe341b
著作权归作者所有,转载请联系作者获得授权,并标注“简书作者”。

0
1
分享到:
评论

相关推荐

    唯品会大数据实践方案.ppt

    Greenplum被用于复杂分析和快速查询,而Hadoop则承担大规模数据存储和ETL任务。 - 通过混合使用Greenplum和Hadoop,既保留了Greenplum的快速查询能力,又利用Hadoop的可扩展性,实现数据仓库的优化。 2. **实时...

    中国数据资产管理峰会-唯品会大数据.pptx

    例如,选择了Hive、Presto和Spark作为离线和实时计算的基础,利用HDFS进行大规模数据存储,通过Redis Cluster和Hbase解决高并发访问和海量数据存储问题。在实时计算中,面对Redis与Hbase的选择,唯品会根据业务场景...

    【数学建模竞赛】美国大学生数学建模竞赛(MCM/ICM)简介:竞赛规则与意义综述

    内容概要:美国大学生数学建模竞赛(MCM/ICM)由美国数学及其应用联合会主办,旨在提高学生运用数学知识和计算机技术解决实际问题的能力,培养团队合作精神和创新思维。竞赛始于1985年,至今已有近40年历史,是全球最具影响力的数学建模竞赛之一。竞赛分为MCM和ICM两部分,涵盖多个领域,参赛队伍需在4天内完成题目的分析、建模、求解和论文撰写。竞赛面向全球在校大学生,设有多个奖项,获奖对学生的升学和就业有积极影响。参赛队伍应提前学习数学建模知识,掌握常用软件工具,如MATLAB、Python等,同时加强团队协作和时间管理能力。; 适合人群:全球范围内的在校大学生,特别是对数学建模感兴趣的学生。; 使用场景及目标:①提高学生运用数学知识和计算机技术解决实际问题的能力;②培养团队合作精神和创新思维;③为升学和就业积累宝贵经验。; 阅读建议:参赛队伍应提前做好充分准备,学习相关数学建模知识,熟悉常用软件工具,加强团队协作和时间管理能力,以应对竞赛的挑战。

    光伏三相并网逆变器MATLAB仿真:从MPPT到LCL滤波的全流程解析

    内容概要:本文详细介绍了光伏三相并网逆变器的MATLAB仿真过程,涵盖了从光伏板输出直流电经过MPPT升压、三相桥逆变成交流,再到LCL滤波器滤波并网的全过程。具体包括MPPT算法(如扰动观察法)、坐标变换(Clarke变换和Park变换)、锁相环(采用二阶广义积分器SOGI)、电流内环PI控制以及SPWM调制和LCL滤波器的设计。每个环节都有详细的代码实现和调试技巧,确保并网电流的质量和稳定性。 适合人群:具备电力电子和控制系统基础知识的研究人员、工程师和技术爱好者。 使用场景及目标:适用于希望深入了解光伏并网逆变器工作原理及其仿真的技术人员。目标是掌握从光伏板到并网的完整控制流程,能够独立进行相关仿真和优化。 其他说明:文中提供了大量实用的代码片段和调试经验,帮助读者更好地理解和应用这些技术。同时强调了实际调试过程中可能遇到的问题及解决方案。

    永磁同步电机高频方波注入仿真的实现与优化

    内容概要:本文详细介绍了永磁同步电机采用高频方波注入方法进行低速带载启动的仿真模型及其优化。首先,文章阐述了高频方波注入的基本原理,包括选择2.5kHz的注入频率以及在旋转坐标系下的d轴方向进行方波注入的原因。接着,文章深入探讨了状态机设计,将整个流程分为三个阶段:转子预定位、高频注入阶段和平滑切换到反电势观测器。此外,还讨论了电流环参数的计算方法,强调了根据电机参数精确计算PI调节器参数的重要性。同时,文章详细解释了锁相环(PLL)的实现,指出PLL带宽应设为高频信号频率的1/10以避免震荡。最后,文章分享了一些调试技巧,如处理逆变器死区补偿和合理设置注入电压幅值。 适合人群:从事永磁同步电机控制研究与开发的工程师和技术人员,尤其是对高频方波注入技术和无感控制感兴趣的读者。 使用场景及目标:适用于希望深入了解永磁同步电机高频方波注入技术的工程师,帮助他们掌握从仿真建模到实际应用的全过程,确保在低速带载启动过程中实现稳定可靠的控制效果。 其他说明:文中提供了详细的代码片段和调试建议,有助于读者更好地理解和实践相关技术。同时,附带的文档和参考文献也为进一步研究提供了丰富的资料。

    永磁同步电机(PMSM)全速度域无位置传感器控制与切换策略仿真

    内容概要:本文详细探讨了永磁同步电机(PMSM)在全速度范围内实现无位置传感器控制的方法和技术难点。主要内容涵盖高速段采用超螺旋滑模(Super Twisting Sliding Mode)观测器进行位置估计,以及低速段利用高频方波注入(High Frequency Injection)方法获取转子位置信息。针对两者之间的平滑切换提出了基于滞环和置信度加权的软切换策略,并介绍了扩张状态观测器(ESO)的应用以提高系统的鲁棒性和稳定性。文中提供了具体的MATLAB/Simulink代码片段用于实现各个控制环节,强调了参数调节的重要性及其实践经验。 适合人群:从事电机控制系统研究的专业人士、研究生及以上学历的学生,尤其是对无位置传感器控制感兴趣的科研工作者。 使用场景及目标:适用于需要精确控制PMSM应用场景的研发项目,如电动汽车驱动系统、工业自动化设备等。主要目标是掌握PMSM无位置传感器控制的关键技术和实现方法,提升系统的可靠性和性能。 其他说明:文中不仅分享了理论知识,还包括大量实用的编程技巧和调试建议,有助于读者快速理解和应用所介绍的技术。此外,作者还特别指出了一些常见的错误和注意事项,帮助读者规避潜在的问题。

    爬取淘宝京东(1).py

    爬取淘宝京东(1)

    python编译部署智能合约(上传和取回数据)

    solcx、web3搭配使用

    MATLAB环境下基于偏置场校正的改进模糊c-均值聚类图像分割算法及其应用

    内容概要:本文介绍了一种基于偏置场校正的改进模糊c-均值(FCM)聚类图像分割算法。传统的FCM算法在处理噪声较多的图像时表现不佳,为此,作者提出了引入偏置场校正项的方法,以提高算法的鲁棒性和分割精度。文中详细描述了算法的实现步骤,包括数据加载与预处理、目标函数的设计、迭代更新过程以及实验结果分析。实验结果显示,改进后的算法在噪声较多的图像上显著提高了分割效果。 适合人群:从事计算机视觉、图像处理领域的研究人员和技术人员,尤其是对模糊聚类算法和偏置场校正感兴趣的开发者。 使用场景及目标:适用于医学图像处理等领域,特别是在处理带有噪声和强度不均匀性的图像时,能够有效改善分割质量,提供更精确的图像分析工具。 其他说明:本文不仅提供了详细的理论解释,还附有MATLAB代码实现,便于读者理解和实践。此外,文中还分享了一些实用的经验和技巧,如参数选择、性能优化等,有助于读者更好地掌握和应用该算法。

    蓝牙单芯片解决方案BlueCore3-Flash:射频与基带集成及DSP优化

    内容概要:本文详细介绍了CSR公司BlueCore3-Flash芯片,这款2004年推出的蓝牙单芯片解决方案集成了射频前端、基带处理和6Mbit闪存。文章首先回顾了其硬件架构,包括RF前端、ARM7 TDMI处理器、DSP协处理器及其存储管理。接着深入探讨了DSP协处理器对CVSD编码的优化以及RF部分的天线匹配和寄存器配置技巧。文中还提到了Flash分区管理和一些有趣的细节,如复活节彩蛋代码和通过GPIO模拟I2C控制EEPROM的方法。此外,作者分享了许多实用的经验教训,如Flash编程时序要求、寄存器配置陷阱等。最后强调了800页逆向分析报告的价值,特别是在射频校准方面的指导意义。 适合人群:从事蓝牙开发的工程师和技术爱好者,尤其是对早期蓝牙技术和硬件设计感兴趣的读者。 使用场景及目标:帮助读者深入了解BlueCore3-Flash芯片的工作原理和设计思路,掌握射频调试、DSP优化等关键技术,避免常见错误,提高开发效率。 其他说明:尽管BlueCore3-Flash已停产多年,但其设计理念和技术细节仍然值得借鉴,对于理解和优化现代蓝牙低能耗(BLE)系统具有重要参考价值。

    自动泊车系统中基于五次多项式曲线优化的平行泊车路径规划技术解析

    内容概要:本文深入探讨了自动泊车系统中平行泊车路径规划的关键技术,特别是五次多项式曲线的应用及其优化方法。首先介绍了五次多项式的基本概念和数学模型,展示了如何利用六阶多项式来精确描述车辆从初始位置到最终入库位置的完整运动过程。接着详细解释了路径规划过程中面临的挑战,如狭窄车位、复杂环境等因素的影响,并提出了相应的解决方案,包括曲率优化、碰撞检测以及路径分段处理等。最后通过具体实例演示了优化前后路径性能的变化,证明了经过改进的五次多项式能够显著提高泊车的成功率和平顺性。 适合人群:对自动驾驶技术感兴趣的工程师和技术爱好者,尤其是从事智能交通系统研究的专业人士。 使用场景及目标:适用于希望深入了解自动泊车算法内部机制的研究人员,帮助他们掌握五次多项式在路径规划中的应用技巧,从而提升相关项目的开发效率和技术水平。 其他说明:文中提供了大量Python代码片段用于辅助理解和实践,同时也分享了一些实际项目中遇到的问题及解决经验,对于想要快速入门并应用于实际工作的读者非常有价值。

    【软件开发工具】GitHub使用教程及操作指南:从入门到协作开发全流程介绍了文档的主要内容

    内容概要:本文档详细介绍了GitHub的使用方法,从基础概念到高级功能,帮助用户全面掌握GitHub的操作。首先解释了GitHub作为基于Git的代码托管平台的功能,包括支持多人协作开发、提供Web界面管理代码仓库、issue跟踪、Wiki文档和自动化工作流等特性。接着,逐步指导用户完成入门操作,如注册账号、创建仓库、安装Git以及配置账户信息。文档还列举了核心操作命令,涵盖基础工作流(克隆、添加、提交、推送)、分支管理和常用辅助命令。对于团队协作,文中描述了邀请协作者、使用Fork和Pull Request的方式,以及Issue跟踪机制。最后,介绍了GitHub的高级功能,如GitHub Pages、GitHub Actions、Wiki和Project看板,并提供了学习资源和遇到问题时的解决途径。 适合人群:适用于初学者及有一定编程经验但不熟悉GitHub的开发者。 使用场景及目标:①帮助个人或团队快速搭建并管理代码仓库;②提高代码版本控制能力,确保项目开发流程顺畅;③利用GitHub提供的协作工具提升团队合作效率。 阅读建议:由于文档内容详尽,建议初次接触GitHub的读者按照章节顺序逐步学习,同时动手实践每个操作步骤,遇到问题时参考提供的学习资源或求助于社区。

    基于MATLAB的多层膜光学计算算法(转移矩阵法)源码+使用说明文档.zip

    基于MATLAB的多层膜光学计算算法(转移矩阵法)源码+使用说明文档.zip 一个基于MATLAB的多层膜光学计算算法。当光束击中具有不同折射率的多层系统时,它会被反射、折射和吸收,这可以通过菲涅尔方程来推导。但随着层数的增加,数学计算变得越来越复杂。这个项目提供了一个基于传输矩阵方法的MATLAB算法,用于计算多层膜系统的光学特性。 主要功能点 基于传输矩阵方法的多层膜光学特性计算 包括反射率、透射率和吸收率的计算 支持任意数量的层数 技术栈 MATLAB

    10G cmos tia ref for rxio

    跨阻放大器设计for高速光通信

    textern-0.8-1.el8.x64-86.rpm.tar.gz

    1、文件说明: Centos8操作系统textern-0.8-1.el8.rpm以及相关依赖,全打包为一个tar.gz压缩包 2、安装指令: #Step1、解压 tar -zxvf textern-0.8-1.el8.tar.gz #Step2、进入解压后的目录,执行安装 sudo rpm -ivh *.rpm

    texlive-xstring-7:20180414-23.el8.x64-86.rpm.tar.gz

    1、文件说明: Centos8操作系统texlive-xstring-7:20180414-23.el8.rpm以及相关依赖,全打包为一个tar.gz压缩包 2、安装指令: #Step1、解压 tar -zxvf texlive-xstring-7:20180414-23.el8.tar.gz #Step2、进入解压后的目录,执行安装 sudo rpm -ivh *.rpm

    Simulink电动汽车仿真模型解析:涵盖行驶阻力、工作模式切换与驾驶员模型

    内容概要:本文详细介绍了基于Simulink平台构建的电动汽车仿真模型,涵盖了行驶阻力模型、工作模式切换逻辑以及驾驶员模型等多个方面。行驶阻力模型通过MATLAB函数实现了滚动阻力、空气阻力和坡度阻力的精确计算,揭示了不同车速下各阻力成分的变化规律。工作模式切换部分利用Stateflow状态机实现了纯电驱动、能量回收和混合动力之间的平滑过渡,确保了系统的稳定性和高效性。驾驶员模型则采用PID控制方法,优化了车速跟踪性能,特别是在CLTC工况下的表现更为突出。此外,文章还对比了NEDC和CLTC两种工况下的能耗差异,展示了CLTC工况下频繁启停对能耗的影响。 适合人群:从事电动汽车研究与开发的技术人员,尤其是熟悉Simulink和MATLAB的工程师。 使用场景及目标:帮助研究人员深入理解电动汽车的工作原理及其仿真建模方法,为实际产品设计提供理论支持和技术指导。 其他说明:文中提供了大量具体的代码片段和仿真结果,便于读者理解和复现相关实验。同时提醒读者关注实际路况与仿真环境之间的差异,强调仿真结果仅供参考。

    基于Qt的串口通信工具

    串口AT操作调试程序

    基于SVPWM的T型三电平LCL型并网逆变器Matlab/Simulink仿真与优化

    内容概要:本文详细介绍了基于空间矢量脉宽调制(SVPWM)的T型三电平LCL型并网逆变器在Matlab/Simulink中的仿真方法及其优化技巧。首先,文章阐述了T型三电平逆变器的优点,如低开关损耗和高效抑制高频谐波的能力。接着,深入探讨了主电路建模、电流双闭环控制、SVPWM生成以及LCL滤波器的设计。针对常见的仿真问题,如代数环错误、谐振尖峰和波形震荡,提供了具体的解决方案。此外,还分享了一些实用的经验公式和调试技巧,确保模型在不同工况下的稳定性和性能。 适合人群:从事电力电子、新能源并网系统的工程师和技术人员,尤其是对T型三电平逆变器和SVPWM技术感兴趣的读者。 使用场景及目标:适用于光伏和储能系统的并网逆变器设计与仿真。主要目标是在THD和动态响应之间取得良好平衡,提高并网电流质量,降低谐波失真,确保系统稳定性。 其他说明:文中提供的代码片段和参数设置有助于快速搭建和调试仿真模型,同时附带的波形对比图直观展示了优化前后的效果。建议读者在实践中结合实际情况进行参数调整,以达到最佳性能。

    thrift-glib-0.13.0-2.el8.x64-86.rpm.tar.gz

    1、文件说明: Centos8操作系统thrift-glib-0.13.0-2.el8.rpm以及相关依赖,全打包为一个tar.gz压缩包 2、安装指令: #Step1、解压 tar -zxvf thrift-glib-0.13.0-2.el8.tar.gz #Step2、进入解压后的目录,执行安装 sudo rpm -ivh *.rpm

Global site tag (gtag.js) - Google Analytics