CocoaPods快速开发
使用Artifact Repository Manager的10个理由
执行概要
在CocoaPods出现之前,在Xcode项目中使用第三方组件涉及大量手工和容易出错的工作,以保持组件及其依赖项的最新和彼此一致。CocoaPods可以根据项目所需的pods的简单规范解析和下载依赖项,从而使事情变得更简单。然而,CocoaPods仍然面临着挑战,比如在网络或存储库宕机时访问pod和规范、管理安全性、优化构建、支持额外的包格式等等。这些挑战由JFrog Artifactory, Universal来解决工件存储库管理器它的功能是作为一个单一接入点组织所有二进制资源,包括专有库、远程工件和其他第三方资源,特别是包括pods和podspecs。2022世界杯阿根廷预选赛赛程完全支持CocoaPods客户端,Artifactory透明地替换CocoaPods存储库在使用CocoaPods和开源库进行开发时提高您组织的生产力。
| 可靠且一致地访问包 | |
| CocoaPods主回购和GitHub是开发CocoaPods的宝贵资源,但作为外部资源,它们可能是2022世界杯阿根廷预选赛赛程 如果出现故障或网络问题,则无法访问。 |
Artifactory通过将远程工件缓存到“2022世界杯阿根廷预选赛赛程远程存储库”;作为远程资源代理的本地缓存,从而消除了对资源本身或网络的依赖。 |
| 减少网络流量并优化构建 | |
| 许多开发人员和构建机器/CI服务器不断下载组件会产生大量网络流量并降低构建速度。 | 一旦Artifactory下载了组件,所有开发人员和构建工具/CI服务器都可以在本地使用它,从而大大减少网络流量,加快构建过程。 |
| 全面支持Docker | |
| 随着Docker的流行程度持续增长,您可能会发现自己比想象中更早地加入了这一潮流。所以现在你需要管理pod和podspecs 码头工人的图像。 |
除了支持CocoaPods, Artifactory还是一个羽翼丰满的软件Docker注册表支持所有Docker注册表api.在那里 不需要安装额外的工具来支持pod和Docker映像。 |
| 与您的构建生态系统完全集成 | |
| 无论你的构建生态系统是如何构建的,你的构建系统,每天运行几个构建,必须能够很容易地访问你的pod和podspecs。 | 通过一组插件,Artifactory与当今常用的大多数构建工具和CI系统紧密集成 在现场或在云端。这些集成使Artifactory能够生成详尽的构建信息,从而实现完全可再现 构建。 |
| 安全和访问控制 | |
| 每个组织都需要实施安全策略,以便人们只能访问他们被授权使用的内部和外部资源。2022世界杯阿根廷预选赛赛程 | Artifactory在多个级别上提供安全性和访问控制。使用“包含”和“排除”模式、团队和权限,以及与常见访问协议(如LDAP、SAML和Crowd)的集成,Artifactory提供了细粒度的 访问控制,从限制完整的存储库到限制单个工件,以及从任何大小的组到 一个开发者。 |
| 在您的组织中分发和共享工件 | |
| 为了充分利用开发成果,您需要与组织中的其他开发人员和团队共享内部开发的pod。 | 使用局部存储库, Artifactory为您提供了一个存储内部二进制文件的中心位置,以便所有团队都可以访问任何二进制文件 工件从一个URL。为了支持远程团队,Artifactory提供了推式复制和拉式复制。 |
| 智能搜索和人工查询语言 | |
| 考虑到在任何软件开发组织中都可能积累大量的包,找到特定的包有时会非常复杂。 | Artifactory提供了多种搜索选项,从简单的名称搜索到常见的内置搜索功能,如“最新” 版本搜索”。Artifactory还提供独特的服务通过校验和搜索.Artifactory查询语言(AQL)将搜索带到新的 级别提供了一种简单的方法来根据任意数量的参数来制定复杂的查询。 |
| 高可用性 | |
| 作为组织中的关键任务组件,存储库管理器中的任何停机都可能对组织的生产力产生严重影响。 | Artifactory可以部署在具有两台或更多服务器的高可用性配置中,这可以使您的正常运行时间达到 5个9的可用性。 |
| 维护和监控 | |
| 你生成的豆荚数量可以快速增长。如果没有适当的管理,您的系统很快就会被旧的和不相关的豆荚堵塞。 | Artifactory通过自动、定时的清理过程、监控和限制设置使您的系统免于混乱 关于磁盘空间的使用,以及在最关键的pod上定义“手表”的能力。 |
| 适用于所有二进制文件的通用端到端解决方案 | |
| 没有单一的包装格式或技术足以支持现代组织中的开发。管理所有不同打包格式的二进制文件并进行集成 生态系统中所有移动的部分都可能成为维护的噩梦。 |
作为一个通用的存储库管理器,Artifactory支持所有主要的打包格式,包括CocoaPods,并集成了所有主要的构建工具和CI服务器。Artifactory还集成了通用分发平台JFrog Bintray。它们一起构成了一个通用的、完全自动化的软件分发管道。 |
总结
JFrog Artifactory是一个通用的工件存储库,支持使用CocoaPods以及目前常用的所有其他打包格式的苹果平台的软件开发。与所有主要的构建工具和CI服务器集成,Artifactory作为任何开发生态系统中的中心枢纽,提供无与伦比的稳定性和高可用性配置,并提供对软件构件的可靠和一致的访问。通过管理和优化对pod和podspecs的访问,Artifactory提高了组织开发和DevOps团队的生产力。Artifactory还与通用软件分发平台JFrog Bintray紧密集成。Artifactory和Bintray共同为使用CocoaPods或任何其他开发技术的软件开发和分发提供了最全面的端到端解决方案。
简介
使用第三方开源组件在成本和代码质量方面的好处是众所周知的。然而,如果没有正确的依赖管理器,使用第三方组件将涉及大量手动和容易出错的工作,以保持所有这些组件的最新和彼此一致。CocoaPods进入了Xcode项目的这个领域,使与第三方库的工作更容易。将源文件复制到Xcode项目中,然后手动更新项目的依赖项,取而代之的是一个简单的依赖项和pod规范,供CocoaPods管理。CocoaPods可以解决和下载你需要的不同库之间的依赖关系,保持版本的更新,搜索新的库,并且通常使第三方组件的开发更易于管理。然而,CocoaPods还存在一些无法克服的问题:
- 如果CocoaPods主回购或GitHub不可访问,会发生什么,无论是他们正在经历停机或只是网络问题?
- 如何优化需要数百(或数千)个依赖项的构建?
- 如何防止两个(或200个)开发人员下载同一个pod?
- 如何管理内部创建的pod的访问控制?
- 当他们的数量在你的组织中成倍增加时,你如何找到一个特定的豆荚?
- 您如何与您站点上的团队以及地理位置遥远的团队共享内部pod ?
- CocoaPods可能能够管理你的pod和podspecs,但是如何管理Docker映像和其他来自你可能使用的其他开发技术的包呢?
所有这些问题的答案是JFrog Artifactory,通用存储库管理器,作为一个单一的接入点组织所有二进制资源,包括专有库,远程工件和其他第三方资源,包括pods和podspecs。2022世界杯阿根廷预选赛赛程Artifactory完全支持CocoaPods客户端,透明地取代了您的CocoaPods存储库,以应对这些挑战,并在使用CocoPods和开源库进行开发时提高您组织的生产力。
01 |可靠和一致的Podspecs和Pods访问
为了管理项目的依赖关系,CocoaPods客户端需要访问远程Specs存储库,例如publicCocoaPods规格GitHub上的存储库。然后,CocoaPods需要访问依赖舱本身,这些依赖舱也托管在远程资源上,通常也在GitHub上。2022世界杯阿根廷预选赛赛程这意味着要构建一个项目,你需要依赖外部网络访问和GitHub的可用性,这两者都存在潜在的故障点。像GitHub2022世界杯阿根廷预选赛赛程这样的远程资源可能会中断,而且网络访问并不总是有保证,在这两种情况下,你的工作可能会戛然停止。
远程存储库
远程存储库作为在远程站点(如GitHub)管理的存储库的缓存代理。工件根据控制缓存和代理行为的各种配置参数在远程存储库中存储和更新。
了解更多>
JFrog Artifactory是开发者和外部资源之间的中介。2022世界杯阿根廷预选赛赛程作为一名开发人员,您的所有请求都被定向到Artifactory,它通过将远程工件在本地缓存为您提供了快速且一致的访问远程存储库.由于远程工件很容易从本地网络的缓存中获得,所以你不受外部网络问题的影响,如果GitHub或任何其他远程资源宕机也不会受到影响。即使在远程资源完全不存在的极端情况下,已经下载到本地缓存的任何工件仍然可用。作为开发人员,您可以继续您的开发工作,并且您的构建不会受到网络问题或存储库崩溃的阻碍。

02 |减少网络流量和优化构建
由于您的大部分代码可能是组装而不是构建的,因此您希望确保优化了从外部资源下载的pod的使用。2022世界杯阿根廷预选赛赛程两个(或200个)开发人员使用同一个pod分别下载它是没有意义的。
除了可靠性之外,远程存储库的另一个好处是减少了网络连接。一旦下载了包,组织中的所有其他开发人员就可以在本地使用它(从而减少网络流量)。当然,这对每个开发人员都是透明的。一旦通过Artifactory访问pod,开发人员就可以继续做她最擅长的工作,而把其余的工作留给Artifactory。
如果我们从一个角度来看网络流量构建服务器这样做的好处是显而易见的。一个典型的项目可能依赖于来自外部资源的数十个(如果不是数百个)pod。2022世界杯阿根廷预选赛赛程对于构建这些项目的服务器,所有远程工件必须对服务器环境可用。下载所有这些必需的工件可能会在网络上产生千兆字节的数据流量,这会花费大量的时间来延迟构建过程。通过在本地缓存远程工件,构建过程会更快,并减少网络开销。

03 |完全支持Docker
随着Docker技术的不断发展,它的使用也在不断增长。如果您还没有在您的组织中使用Docker,可能很快就会这样做。所以现在,除了管理CocoaPods包,你还需要管理Docker映像。但是没有必要安装和维护另一个工具。Artifactory是一个成熟的Docker存储库,支持所有Docker Registry api。这允许Docker客户端直接与Artifactory合作,为企业Docker用户带来了几个好处。
使用本地存储库就可以分发和共享图像在组织内轻松管理不同团队之间的映像。您甚至可以将Docker注册表复制到Artifactory的远程实例,以便与地理位置遥远的站点的同事共享映像。
Artifactory提供细粒度的访问通过安全的“docker push”和“docker pull”有效地控制您组织的映像安全的、私有的Docker注册表超出Docker可信注册表提供的安全性。使用Artifactory,而不是Docker Hub上的私有存储库,消除了与互联网连接相关的任何问题可靠且一致地访问图像.当跑步的时候高可用性配置, Artifactory为您的Docker映像提供了业界无与伦比的系统稳定性和可用性。
Artifactory的智能搜索可以很容易地找到存储在系统中的任何Docker映像。Docker Registry API支持Docker客户端的基本搜索,但Artifactory提供了更多。内置搜索通过单击操作来回答常见需求,自定义属性提供了满足各种特定需求的灵活性,Artifactory Query Language提供了一种简单的方法来制定复杂的查询,让您可以根据任何标准集找到图像。
无论你是已经开始使用Docker,还是只是在评估如何将它引入到你的组织中,一旦你使用Artifactory来管理你的CocoaPods包,你就已经覆盖了Docker映像。
与您的构建生态系统完全集成
虽然让开发人员轻松高效地访问pod很重要,但对于可能每天运行多次构建的构建系统来说,这更重要。
通过一组插件,Artifactory提供了与当今流行的CI系统(如Jenkins、Bamboo和TeamCity)的紧密集成。这些系统在创建构建时使用Artifactory来提供工件和解决依赖关系,并且还将其作为将构建输出部署到相应的本地存储库的目标。
通过Artifactory运行构建的主要好处之一是完全可重复的构建。Artifactory存储详尽的构建信息,包括特定的工件版本、模块、依赖关系、系统属性、环境变量、用户信息、时间戳等等。有了这些信息,就很容易在任何时候忠实地重新生成一个构建。此外,使用内置的“Diff”工具,您可以比较构建,从而确切地知道从一个版本到另一个版本引入了哪些更改。当试图追踪发布的特定版本中报告的错误时,这些功能是非常宝贵的。
Artifactory还简化了发布管理。一系列简单的设置配置了一些事情,比如分期、构建推广、VCS标记等等,基本上自动化了发布管理过程。
但是,如果您使用的是基于云的CI系统,而不能应用插件,会发生什么呢?在这种情况下,Artifactory直接为构建工具本身提供插件,最终提供相同级别的构建自动化。本质上,由于Artifactory是平台不可知的,它可以与组织内所有构建生态系统中的通用工具集成。最后,一旦您的构建被自动化,Artifactory将根据您组织的维护策略清理旧的构建,从而使您的系统免于混乱。

05 |安全与访问控制
如果你想控制对你的pod的访问,你需要使用GitHub上的私有存储库。但这样工作的结果是,Podspecs Registry中的许多指针对于大多数用户来说都是空白的,因为它们指向其他人的私有存储库。然后,你真的想让你的私人GitHub存储库的指针公开可用吗?
Artifactory为CocoaPods提供了完整的安全解决方案。作为第一道防线,Artifactory允许您使用命名模式来定义“excluded”和“Includes”进行访问,这样您就可以控制哪些包甚至可以缓存在任何特定的远程存储库中。然后,您可以为用户和组分配不同的权限集,以控制对每个存储库的访问。您甚至可以使用Artifactory与LDAP、Active Directory、SAML、Crowd和其他组件的集成来控制对服务器的访问。实际上,Artifactory变成了您自己的私有和安全的内部CocoaPods存储库。
在您的组织中分发和共享pod
远程存储库代理CocoaPods规范存储库和GitHub上的其他pod存储库。这可以确保pod只下载一次,然后在整个组织中共享。同样的原则也适用于您自己的专有pod,您也希望能够安全地与组织中的其他人共享。
局部存储库
本地存储库是物理的、本地管理的存储库,您可以在其中部署构件。通常
它们用于部署内部和外部发布以及开发构建,但也可以用于存储在公共存储库(如第三方商业组件)中不能广泛使用的包。使用本地存储库,您的所有内部资源都可以通过一个公共URL从整个组织的单个访问点获得。2022世界杯阿根廷预选赛赛程
了解更多>
使用局部存储库, Artifactory为您提供了一个存储内部豆荚的中心位置。当所有团队都知道任何pod都可以从单个URL访问时,访问本地pod和管理不同团队之间的依赖关系就变得非常容易。但是,如果您希望与地理位置较远的组织站点的同事共享您的pod,该怎么办呢?
Artifactory支持将存储库复制到本地网络之外的另一个Artifactory实例。复制的存储库会定期自动与它们的源同步,这样您的pod就可以提供给世界各地的不同团队使用,无论他们位于哪里。
智能搜索和人工查询语言(AQL)
使用第三方pod可能会非常复杂。在不同开发人员下载的许多pod和您在自己的组织中开发的内部pod之间,找到特定的东西可能会成为一个相当大的挑战。
Checksum-based搜索
通过校验和搜索包是Artifactory支持的一个强大功能,这要归功于通过校验和存储文件的独特方法。即使二进制文件已被重命名、移动或甚至部署到组织外部,您也可以将其追溯到原始版本并获得其完整的构建信息。只需通过校验和工具(支持MD5和SHA1)运行包,并在Artifactory中运行“校验和”搜索来检索原始版本。
了解更多>人工查询语言(AQL)
AQL是一种灵活的查询语言,它提供了一种简单的方法来制定复杂的查询,使用任意数量的搜索条件、过滤器、排序选项和输出字段在存储库中进行搜索。它充分利用了Artifactory独特架构下的数据库,并为您提供了无限的自由度来精确地制定正确的查询,以找到您正在搜索的非常特定的包。这是其他二进制存储库所不能提供的。
了解更多>Artifactory为您提供灵活的搜索功能,以帮助您找到存储在系统中的pod。首先,Artifactory支持CocoaPods规范,因此最基本的包搜索是用与使用CocoaPods客户端完全相同的方式完成的。然后,你可以根据任何固有属性的组合来查找包,比如名称、版本、时间戳、校验和以及Artifactory存储的关于豆荚的各种其他属性。Artifactory还允许您为组件分配任意一组自定义属性,这些属性稍后可用于搜索。例如,您可以用“已发布”属性标记产品发布中使用的组件的所有特定版本,以便稍后轻松地重新生成已发布的版本。但是搜索的全部功能伴随着搜索的完全灵活性AQL.使用AQL,您可以将搜索查询定义为提取您正在寻找的正确pod所需的任何复杂级别。
08 |系统的稳定性和可靠性与Artifactory高可用性
在pod和其他包的管理中扮演如此核心的角色,您的存储库管理器可以成为组织的关键任务组件,这意味着任何停机都可能产生严重的后果。
高可用性系统
对于组织来说任务关键的系统可以部署在高可用性配置中,以增加稳定性和可靠性。这是通过复制系统中的节点并将它们部署为冗余集群来实现的,从而消除任何单个节点上的完全可靠性。在高可用性配置中,不存在单点故障。如果任何特定节点宕机,系统将通过剩余的冗余节点继续无缝地、透明地对其用户运行,而不会停机或降低整个系统的性能。
了解更多>Artifactory支持高可用性在同一个局域网上使用2个或更多Artifactory服务器集群的网络配置。冗余网络架构意味着不存在单点故障,只要Artifactory节点中至少有一个处于运行状态,您的系统就可以继续运行。这最大限度地提高了您的正常运行时间,并可以将其提高到“五个九”的可用性水平。此外,您的系统可以在不影响性能的情况下适应更大的负载突发。通过水平服务器可伸缩性,您可以轻松地增加容量,以满足组织增长时的任何负载需求。通过使用具有多个服务器的架构,Artifactory HA允许您在没有系统停机的情况下执行大多数维护任务。
09 |维护与监控
通过当前构建服务器和CI系统的使用,您生成的pod的数量可以快速增长。如果没有适当的管理,您的系统很快就会被旧的和不相关的工件阻塞。
Artifactory通过自动定时清理过程使您的系统有条理,没有杂乱。通过一些简单的设置,您可以安排任务来清理旧的构建和未使用的pod。您可以设置限制并监视磁盘空间使用情况,或者定义“监视”,以便在最重要的pod发生更改时接收警报。通过广泛的REST API, Artifactory几乎可以支持您希望在组织的脚本中实现的任何基于规则的清理协议。
10|所有二进制文件的通用端到端解决方案
没有单一的包装格式或技术足以支持现代组织中的开发。有大量的格式、各种各样的构建工具、不同的持续集成系统和其他技术用于构建灵活且可维护的软件开发生态系统。管理所有不同打包格式的二进制文件并与生态系统的所有移动部分集成可能成为维护的噩梦。
Artifactory从头开始设计,以适应任何开发生态系统。Artifactory独特地构建在基于校验和的存储上,支持任何存储库布局,因此可以为任何打包格式提供本地级支持。本质上,无论您使用何种打包格式,Artifactory都可以存储和管理二进制文件,并且对相应的打包客户端是透明的。客户端使用Artifactory的方式与使用本机存储库的方式完全相同。例如,如果你正在使用CocoaPods, Artifactory代理GitHub上的公共远程Podspecs和pod存储库,让你在本地CocoaPods存储库中存储自己的pod,并透明地与CocoaPods客户端一起工作。如果您正在使用Docker, Artifactory将代理Docker Hub(或任何其他远程公共Docker资源),让您在本地Docker存储库中存储和管理自己的映像,并透明地与Docker客户端一起工作。类似于npm, Vagrant, NuGet, Ruby, Debian, YUM, Python等。
但是开发只是软件交付管道的一端。在一个包成为一个产品之前,它需要经历构建和集成的过程。市场上有许多构建和集成工具,但只有一种产品可以与所有工具一起工作。通过一组插件,Artifactory提供了与当今流行的CI系统(如Jenkins、Bamboo和TeamCity)的紧密集成。这些系统在创建构建时使用Artifactory来提供工件和解决依赖关系,并且还将其作为部署构建输出的目标。为了支持您无法应用插件的基于云的CI系统,Artifactory为您使用的构建工具(如Maven和Gradle)提供了插件,这些工具最终提供了相同级别的构建自动化。这涉及到开发和部署,但是一旦软件准备好供使用,如何分发软件呢?这就是Bintray的用武之地。
Bintray是JFrog的云下载中心,提供快速的CDN下载,细粒度的访问控制,详细的统计数据和日志以及广泛的REST API。从Artifactory推广发行版本只是一个单击或API调用的问题。像Artifactory一样,Bintray与包无关,可以与所有不同的包客户端无缝地工作,因此它可以完全集成到任何持续集成/持续交付生态系统中。
Artifactory是一个通用存储库。它是位于开发生态系统中心的单一工具,与所有不同的技术“对话”,提高了生产力,减少了维护工作,并促进了不同部分之间的自动化集成。Artifactory和Bintray是一个完全自动化的软件分发管道的中心组件。
总结
Artifactory对CocoaPods的支持可以让您专注于为iOS、watchOS、tvOS或OS X设备编写代码,而不必担心CocoaPods主库或GitHub的安全性或可用性。其他功能,如智能搜索、AQL、高可用性、维护、监控等,可以帮助您更有效地工作,加快开发周期,最终将您的产品尽快推向市场。
欲了解更多关于Artifactory如何提高您的组织绩效的信息,请联系我们info@www.si-fil.com


