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

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

3天内不再提示

Perforce演讲回顾(下):版本控制系统Helix Core的常见使用误区及解决办法、实用工具及新功能介绍

龙智DevSecOps 2024-10-08 16:18 次阅读
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

日前,Perforce携手合作伙伴龙智一同亮相Unreal Fest 2024上海站,分享Helix Core版本控制系统及其协作套件的强大功能与最新动态,助力游戏创意产业加速前行。

Perforce解决方案工程师Kory Luo在活动主会场带来《Helix Core+Unreal Engine工作流程与使用实践》的主题演讲,分享Helix Core在Project Titan项目中的关键角色、与Unreal Engine的配置技巧、常见的使用误区及解决办法,以及Helix Core的最新功能与应用等重磅干货。

此次演讲回顾分为上下两期为您呈现(内容有精简优化);本期为(下)期。

如何避免、解决常见问题

那些发生在Project Titan中,你也可能会遇到的问题

本节,我们将了解一些在管理Project Titan中遇到的问题和解决方法,看看大家是否遇到过同样的问题,以便下次再遇到时能够从容应对。

问题1:使用非流工作区在流版本仓中工作。

wKgaomcE22qANEGcAAC-mTL4GQM792.png

我们版本仓的常用类型有classicdepot和streamdepot。当用户第一次与服务器交互时,会创建一个工作区,用来存储从服务器下载到本地的文件。初始状态下,默认的工作区是classicdepot,stream的选项是空白的。当我们需要在stream depot下操作时,若新手用户没有将工作区与stream depot相对应,这导致会出现的问题是:用户虽然可以进行下载和更改,但无法提交,因为工作区的属性与版本仓的属性不匹配。

解决的方法也很简单:编辑工作区规范(workspace spec),将其附加到相对应的流版本仓即可。但是对于4000多人的ProjectTitan项目,我们无法逐个告知用户,所以我们创建了p4python脚本,通过设置预定任务每小时对workspace spec进行修正,以便在用户发现之前解决问题,从而大大减少用户遇到此问题的几率。

问题2:在OSX系统中,将工作区路径设置到exFat存储。

wKgZomcE22qAO-u1AADqFlvJfjI652.png

如此设置的OSX系统用户,可以正常创建工作区、下载或更改文件,但是当服务器的文件有新版本需再次下载的时候,就会出现Can’t clobber writable file”的报错。

什么原因呢?正常操作下,我们初期下载到本地的文件是read-only只读模式,需要用P4V或UE执行checkout(签出),将文件权限从read-only改成read-write,才能正常进行更改。一旦用户不通过服务器,而在本地直接更改文件的读写权限,这看似没有问题,但在后续的提交或下载时,服务器会将其判断为“离线更改”,而出现无法与服务器最新版本同步的情况。因为服务器担心覆盖掉您的本地内容,导致数据丢失,所以呢会发出“Can’t clobber writable file”的警告。

对于不兼容的文件系统,我们的解决方案也只能是——将其格式化,然后使用相匹配的文件系统。在Project Titan中,用户备份数据后,重新格式化硬盘为APFS,然后就可以继续工作了。

问题3:服务器的储存安全限制。

wKgZomcE22qAR17eAADXEDMimRk917.png

Helix Core对服务器数据的主要储存空间有一些硬性限制,比如对于储存metadata、日志、temp表的磁盘空间,默认值是250MB。即:当磁盘空间不足250MB时,服务器会停止接收任何命令。毕竟,版本控制软件是用来记录所有版本的相关信息的,如果磁盘空间不足,已经无法正常读写还继续接收版本的话,也就丧失版本控制的意义了。

为了避免这一情况,我们需要定时清理旧的磁盘和日志,例如可以保留最近7天的日志,同时可确保在遇到问题时,有足够的日志信息以便追溯问题源头。另外,也可以将旧版本的文件存档到外部硬盘或云端,以确保服务器中的磁盘空间充足,能够满足实际的需求。

当然,最重要的还是要做到密切监控。若问题发生后再着手解决,很可能会影响服务器的运行时间甚至导致停机。这时候,P4Prometheus的重要性就不言而喻了。它可以设置自定义邮件警报,比如设置当磁盘空间不足70%时,向管理员发送邮件警报,以便我们提前采取措施,避免服务器停机。

问题4:服务器大小写问题。

wKgaomcE22qACQubAAld-7LXwRw229.png

我们知道,Linux服务器区分大小写,而Windows不区分。有些团队使用的是Linux服务器,但既有Windows用户又有Linux用户,有大小写就会显得非常混乱。如果两个文件的路径、文件名都相同仅仅是大小写不同,Linux服务器会将其视为两个文件,而上传这样的文件是没有意义的。不过呢,对于涉及多个部门协同工作的项目来说,保留服务器中的大小写属性也很有必要,它能够帮助促进不同部门间的协作和兼容。

那如何控制这一问题呢?——可以通过安装CheckCase Trigger,将那些待提交的仅大小写不同、但文件内容完全相同的两个文件名或目录名进行拦截,以避免产生冲突。

那些我们创建的实用工具和脚本

分享和构建一些免费的社区支持工具

接下来,为大家介绍一些我们创建的实用脚本和工具。

工具1:简易密码重置工具

wKgaomcE22yAItIzAAxlFAWw0-k967.png

我们常常会遇到忘记密码的情况。 如果某个用户忘记了,管理员可在P4Admin上操作重置。规模比较小的项目中,管理员一一手动重置是没有问题的,但对于4000人以上的大规模项目,管理员可能每天都收到大量的重置请求,再手动重置的话,无疑会令人崩溃。

对此,我们创建了一个实用脚本,即简易密码重置工具,来帮助管理员自动生成临时密码。在Project Titan中,我们通过Discord聊天软件将密码发送给用户进行重置。国内使用微信的用户更多,那我们也可以根据需求,改为通过微信或邮件来与用户交流。

工具2:强制解锁工具

wKgZomcE22uAcjReAAw2oe8Ba48208.png

由于二进制文件不可合并,一旦某个用户检出后未及时上传,其他任何成员都不能对该文件进行修改。对于小型团队,或许可以和用户沟通,由管理员逐个强制解锁,但对于数百甚至上千人的大体量项目,沟通的成本就会显著增加。所以我们必须使用工具。

通过将我们的强制解锁工具加载到P4V的CustomTools中,右键单击选择“强制解锁”,即可解锁该文件,以确保工作的流通和顺利推进。这对大体量的工作室来说,非常有帮助。

工具3:超时自动复原工具

wKgZomcE22yAXngzAA3zsw2DA_k205.png

这一工具与前面的强制解锁工具有异曲同工之妙,但是更为强硬一些。它会设定一个时间期限,若用户在期限内未对检出的文件进行上传或提交,系统就会自动复原该文件至检出前的状态。复原后,用户的本地更改会全部消失。当然,这很可能会引起用户的不满,但某些情况下,特别是在Project Titan这样的大型项目中,由于人数众多,存在很多迟迟不上传的情况,我们又无法与各个用户高效沟通,这时候,超时自动复原就成为一项必要的手段。

不过在实施此功能时,可以进行一些柔化处理。我们可以设置预警机制,比如提前3天发送邮件提醒用户上传,以减少不必要的工作损失。

工具4:P4项目模版工具

wKgaomcE22yABa8FAA3ME3RgSZs687.png

这是一款面向管理员的模板化服务器部署工具。对于经常需要为项目组部署服务器的管理员来说,这一工具可帮助大大简化部署流程。通过模板工具,管理员可以快速搭建出具有基本功能的服务器环境,后续再根据具体的需求进行微调。

那些您需要了解的新功能

了解如何将其应用到您的工作室中

最后,我们再来看看Helix Core近年来推出的几项瞩目的新功能。

1、虚拟文件同步-Helix Core 2023.1

这项功能在23.1版本中首次推出。什么是“虚拟文件同步”呢?就是工作区同步时,只会下载元数据(包括谁、在什么时间、执行了什么操作以及文件名、文件历史记录等),但不会立即将实体文件下载到本地。只有当用户对文件进行更改时,系统才会将实体文件从服务器端同步到本地。通过这一功能,我们可以大大节省磁盘空间,并提升初期的下载速度。

2、系统资源监控- Helix Core 2023.1

当服务器资源紧张时,我们Helix Core的服务器会将用户的命令行排队,待资源充足后再进行逐个处理,以确保服务器的正常工作,改善系统在高压下的运行时间。

3、Sparse Streams-Helix Core 2024.1

Sparse Streams可以理解为轻量级的分支流,和刚才提到的“虚拟文件同步”类似,Sparse Streams在创建初期,只生成少量的元数据,并允许用户选择需要包含的文件。它不会立即下载大量的实体文件到本地,从而帮助节省磁盘空间,创建流的体验也会非常流畅。

Sparse Streams与其Parent Stream相关联,只有在用户对实体文件进行实际更改时,才会从parent stream中抓取相应的文件到Sparse Streams,并传送给用户。这对于修复小bug或开发一些简易功能非常有用,后续也可以轻松升级为其他类型的流,比如开发流或发布流。

4、支持S3(及兼容S3)对象存储 - Helix Core 2024.1

这一功能扩展了对更具有成本效益的云存储的支持。24.1之前只支持存档(archive depot)版本仓。24.1版本后,支持remotedepot外的所有版本仓类型。(*remotedepot适用于与其他公司或第三方合作时分享文件、数据、代码或数字资产。)

5、Delta Submits - Helix Core 2024.1

Delta Submits是今年新推出的一项非常强大的功能,可减少未压缩的二进制文件在提交时的网络负载。简单来说,它将大文件分割成多个小块,并通过算法比较,仅提交相对于上一版本有更改的一些小块,从而减少上传的负载和时间。在服务器端,这些小块会与之前的版本内容合并重构,生成最新的版本存储在服务器上。对于网络延迟较高的环境,这项功能尤为有用,我们的内部测试显示,上传速度可提升至少3到4倍。

以上是我们Helix Core的一些功能介绍,以及在Project Titan项目中的一些应用分享。如需进一步体验Helix Core的强大功能,欢迎联系Perforce中国授权合作伙伴龙智,获得下载安装支持。

5人及以下的小团队,可以免费使用Helix Core,所有功能与付费版相同。对于没有技术人员专管服务器的团队,我们也提供HelixRemoteAdmin(HRA)服务,涵盖了Helix Core所有产品、Swarm版本审查工具等,由Perforce专业团队帮您部署和持续管理。此外,我们还推出了Helix Core Cloud服务,适用于50人及以下的团队。通过云托管,您可以获得专属的VM,用于部署和运行服务器。这种部署方式更为经济,也非常安全,只有本公司的人员才能访问。同时,我们也提供全面的备份服务,可根据您的需求定制不同的云容量。

以上就是本次演讲的全部内容,谢谢大家!

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

    关注

    41

    文章

    7004

    浏览量

    114608
  • 版本管理
    +关注

    关注

    0

    文章

    15

    浏览量

    454
  • 版本控制
    +关注

    关注

    0

    文章

    26

    浏览量

    170
收藏 人收藏
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

    评论

    相关推荐
    热点推荐

    MAX11504评估套件:SDTV视频处理的实用工具

    MAX11504评估套件:SDTV视频处理的实用工具 在电子工程领域,对于标准定义电视(SDTV)应用中的视频处理,MAX11504评估套件是一个非常实用的工具。今天就来详细介绍
    的头像 发表于 05-30 11:45 243次阅读

    ADA2200评估板介绍:为电子工程师提供的实用工具

    ADA2200 评估板介绍:为电子工程师提供的实用工具 在电子设计领域,评估板是验证和测试芯片性能的重要工具。今天就来给大家介绍ADA2
    的头像 发表于 05-23 13:25 528次阅读

    10个必装Linux实用工具推荐

    做运维这些年,最直观的感受是:工具选对了,效率能差出好几倍。同样的活儿,有人敲半天命令才能定位问题,有人三五个工具组合起来,几分钟就能把根因找出来。Linux本身自带了大量实用工具,但很多工程师只用了最基础的那几个,更多宝藏被忽
    的头像 发表于 05-14 10:32 424次阅读

    LM5008A评估板:助力电源设计的实用工具

    LM5008A评估板:助力电源设计的实用工具 在电子工程师的日常工作中,电源设计是一个至关重要的环节。今天,我们就来深入了解一TI公司的LM5008A评估板,看看它在电源设计领域能为我们带来
    的头像 发表于 04-21 09:40 175次阅读

    芯片烧录总是出错?常见 6 个问题及解决办法

    做电子生产和 SMT 贴片的朋友,经常会遇到芯片烧录不稳定、报错、漏烧、错烧等问题。今天结合我们做烧录机多年的经验,总结一常见的原因和解决思路,欢迎同行交流。 常见 6 个问题及解决办法
    的头像 发表于 04-10 15:30 544次阅读
    芯片烧录总是出错?<b class='flag-5'>常见</b> 6 个问题及<b class='flag-5'>解决办法</b>

    MAX15046B评估套件:助力电源设计的实用工具

    MAX15046B评估套件:助力电源设计的实用工具 作为电子工程师,在电源设计中,一款性能可靠且易于评估的控制器是至关重要的。今天我们就来详细了解一MAX15046B评估套件(EV kit),它能
    的头像 发表于 04-02 14:05 206次阅读

    工具升级】 I OrCAD X 全版本新功能汇总,高效搞定电路协同设计

    在电子电路设计领域,一款功能强大、适配协同工作的工具,能大幅提升设计效率与精准度。OrCADX系列版本更新,围绕协作、易用性、仿真分析三大核心,为个人及小型设计团队带来全方位的功能升级
    的头像 发表于 01-16 21:43 1838次阅读
    【<b class='flag-5'>工具</b>升级】 I OrCAD X 全<b class='flag-5'>版本</b><b class='flag-5'>新功能</b>汇总,高效搞定电路协同设计

    VCS安装教程及常见问题和解决办法

    一、简要介绍 在对蜂鸟E203处理器进行运行系统级仿真测试时,可以利用VCS这一编译型仿真工具来对运行E203的模拟测试。本文即介绍在Linux
    发表于 10-27 07:58

    汽车电子开发必看:基于Perforce P4实现ISO 26262合规认证的版本管理解决方案

    目前全球唯一通过ISO 26262认证的版本控制系统Perforce P4!从代码管理到审计追溯,保障研发的每一步都经得起严苛审核。龙智正在为更多车企和零部件厂商提供合规支持,欢迎交流~
    的头像 发表于 09-09 14:38 2493次阅读
    汽车电子开发必看:基于<b class='flag-5'>Perforce</b> P4实现ISO 26262合规认证的<b class='flag-5'>版本</b>管理解决方案

    【聚焦汽车软件开发】从版本管理到静态分析,详解Perforce工具链在汽车嵌入式开发中的全栈应用

    很高兴为大家呈现这场高质量的技术分享!涵盖游戏引擎跨界应用、#P4版本管理、合规性实践等等。我们不只提供#Perforce工具,更赋能工具的落地深化。
    的头像 发表于 09-01 13:18 1053次阅读
    【聚焦汽车软件开发】从<b class='flag-5'>版本</b>管理到静态分析,详解<b class='flag-5'>Perforce</b><b class='flag-5'>工具</b>链在汽车嵌入式开发中的全栈应用

    「龙智×Perforce」研讨会干货回顾Perforce工具链在汽车行业的应用与中国本土化落地实践

    研讨会干货回顾来了!本次会议不仅带来了Perforce工具在汽车软件研发中的技术优势与全球价值,更输出了龙智“验证-赋能-护航”的本土落地三部曲。推荐给每一位汽车软件人~
    的头像 发表于 08-21 14:35 965次阅读
    「龙智×<b class='flag-5'>Perforce</b>」研讨会干货<b class='flag-5'>回顾</b>:<b class='flag-5'>Perforce</b><b class='flag-5'>工具</b>链在汽车行业的应用与中国本土化落地实践

    单向阀气密性检测仪常见故障及解决办法

    单向阀气密性检测仪在工业生产中起着至关重要的作用,然而在使用过程中难免会出现一些故障。了解常见故障及其解决办法,能有效提高设备的使用效率和检测准确性。一、检测结果不准确故障表现检测数据波动
    的头像 发表于 06-30 14:01 853次阅读
    单向阀气密性检测仪<b class='flag-5'>常见</b>故障及<b class='flag-5'>解决办法</b>

    版本控制教程】如何使用Unreal Engine 5 + UE源代码控制Perforce P4)

    项目越大,越需要靠谱的版本控制系统Perforce P4不仅是Epic官方推荐的源代码控制工具,更是大厂团队协作的核心支持之一。如何配置P
    的头像 发表于 06-25 11:22 1984次阅读
    【<b class='flag-5'>版本</b><b class='flag-5'>控制</b>教程】如何使用Unreal Engine 5 + UE源代码<b class='flag-5'>控制</b>(<b class='flag-5'>Perforce</b> P4)

    【文章转载】CANoe产品体系19版本新功能) - 基础功能与XIL测试

    版本持续为智能电动网联汽车软件开发测试带来全新功能,IDE开发环境支持.NET8.0、Python、MATLAB2024b,VisualStudioCode集成测试开发和调试功能,支持
    的头像 发表于 06-25 10:03 2166次阅读
    【文章转载】CANoe产品体系19<b class='flag-5'>版本</b><b class='flag-5'>新功能</b>(<b class='flag-5'>下</b>) - 基础<b class='flag-5'>功能</b>与XIL测试

    主流版本控制工具Git vs Perforce P4:架构模式、性能、大文件管理及分支管理对比详解

    Git vs Perforce P4,如何选型?架构模式、性能、大文件管理、分支策略四大维度对比,帮你全面了解两者的核心差异,选择更合适你团队需求的版本控制系统
    的头像 发表于 06-13 14:52 1044次阅读
    主流<b class='flag-5'>版本</b><b class='flag-5'>控制</b><b class='flag-5'>工具</b>Git vs <b class='flag-5'>Perforce</b> P4:架构模式、性能、大文件管理及分支管理对比详解