写点什么

Paket:一个面向.NET 的包管理器

  • 2016-01-15
  • 本文字数:1602 字

    阅读完需:约 5 分钟

Packet 是一个面向.NET 语言的包管理器,旨在作为广受欢迎的 NuGet 的一个替代选项。InfoQ 联系了项目联合创始人 Steffen Forkmann,了解更多有关 Paket 起源和特性的信息。

InfoQ:考虑到 NuGet 的广泛应用,你们主要出于什么目的创建一个新的.NET 包管理器?

Steffen Forkmann:虽然我们确实非常喜欢使用 NuGet 包,而且也为其生态系统做贡献,但在一些特殊的情况下,我们还是感觉很痛苦。大多数问题都是源于 NuGet“它只是一个 Visual Studio 宏”的理念。这意味着,nuget.exe 并没有被视为一个真正的依赖管理器,但作为一个宏,它允许开发人员下载包并 Visual Studio 项目内部引用它们。对于许多专业软件开发项目,这种隐藏依赖的理念带来了许多痛苦。加之 nuget.exe 存储包的路径里会带有版本号,而且没有全局概览,除非是在最简单的项目中,否则很快就会变得难以管理。

在我们开始 Paket 项目的时候,我们已经仔细进行过一些关于修改 NuGet 模型的讨论,但 NuGet 的团队明确表示,这不是他们想要的方式。由于 Paket 大多数新增功能都是破坏性的,他们无意将这些更改引入 nuget.exe。

所以,为了解决我们自己的依赖管理问题,Alexander Gross 和我就开始创建一个新的项目。项目的范围只是取代 nuget.exe,也就是取代 NuGet 的客户端。另外,我们还制定了以下项目原则:

  • 可以融入现有的 NuGet 生态系统
  • 使用最少的工具(纯文本文件)做事
  • 适用于所有平台
  • 一切都是自动化的
  • 创建一个优秀的社区

InfoQ:请您介绍下 Paket 中依赖解析的工作原理?它是如何处理冲突的?

SF:Paket 使用 paket.dependencies 文件指定项目依赖。通常仅指定直接依赖,而且所允许的包的版本范围常常很广。在“paket install”的过程中,Paket 需要指定特定包的具体版本,以及它们的传递性依赖。然后,这些版本会保存到 paket.lock 文件。

为了指定具体的版本,Paket 需要解决如下约束满足问题:对于 paket.dependencies 文件中的每一个包以及它们所有的传递性依赖,均选择最新的版本,这样,所有的版本约束就都得到了满足。

对于这个问题,通常存在不止一个解决方案,而解析器会选择它找到的第一个方案。Paket 的网站上有一篇文章更详细地解释了解析过程

如果解析器无法找到一个有效的解决方案,那么它需要向用户报告一个错误。由于搜索树可以非常大,而且可能包含许多不同种类的失败,所以它只会报告最后一个它无法解析的冲突,以及一些有关这个冲突的来源信息。

与 nuget.exe 不同,在整个解决方案中,相同的包,Paket 只允许用户使用一个版本。因此,用户不会无意中因为从不同的项目中引用同一个包的不同版本而引入版本冲突。如果实在需要同一个包的不同版本,那么可以通过依赖组来实现。

InfoQ:Paket 支持所有.NET 语言吗?(你们是否统计过它在 C#和 F#项目中的应用?)

SF:是的,Paket 基本上支持所有的.NET 语言——甚至是像 Nemerle 那样的东西。我们的大多数用户都是 C#企业型公司,但由于我们没有跟踪我们的用户,所以我们没有任何相关的统计数据。

InfoQ:您希望看到 Paket 未来增加什么特性?哪个特性是用户要求最多的?

SF:目前,我们正致力于 Paket 3.0 的开发,它会带来一项重要的新特性。基本的思路是,用户可以在 paket.dependencies 文件中引用一个 Git 库,Paket 会为用户克隆和构建项目。如果构建生成了 NuGet 包,那么用户可以把它们作为额外的包来源。

目前要求最多的特性是支持 CoreCLR/DNX 项目,但我们需要为此对 project.json 模型做些修改。遗憾的是,我们现在还没有想出一个满意的方案,但我们希望能够同微软的团队一起来解决这个问题。

InfoQ:您还有什么需要补充吗?

SF:我想谢谢所有的贡献者以及整个 Paket 社区,是他们让这个项目在如此短的时间内取得了如此巨大的成功。没有他们的帮助,这是不可能的。

Paket 是一个托管在 GitHub 上的开源项目。读者可以从 FsProjects 页面查看文档。

查看英文原文: Introducing Paket, a Package Manager for .NET

2016-01-15 18:003534
用户头像

发布了 1008 篇内容, 共 445.9 次阅读, 收获喜欢 346 次。

关注

评论

发布
暂无评论
发现更多内容

前端的你常用的编程语言有哪些?

小齐写代码

淘宝天猫详情接口API:快速实现商品信息查询和展示

联讯数据

软件测试学习笔记丨WebSocket原理&使用

测试人

软件测试 测试开发

广州孚瑞经营改善 企业经营持续增长方案提供商

广东孚瑞经营改善

精益生产

开发者分享:利用 EMQX Cloud 与 ESP32 微控制器实现智能液冷散热系统

EMQ映云科技

mqtt mqtt broker

Vocabulary

Echo!!!

如何做代币分析:以 USDC 币为例

Footprint Analytics

blockchain Token

Sermant运行流程学习笔记,速来抄作业

华为云开发者联盟

开发 华为云 华为云开发者联盟 sermant

钉钉如何通过AppLink快速连接仓储系统

谷云科技RestCloud

钉钉 APPlink 自动化集成 仓储系统

如何基于容器网络流量指标进行弹性伸缩

华为云开发者联盟

容器 开发 华为云 华为云开发者联盟

向“新”而行,以科技创新培育新质生产力!

天翼云开发者社区

人工智能 云计算 算力

SD-WAN: 灵活部署,助力云服务

Ogcloud

SD-WAN 企业网络 SD-WAN组网 SD-WAN服务商 SDWAN

Databend Labs 成立 3 周年!

Databend

释放全球互连的数字潜力!MWC 2024云网高峰论坛召开,中国电信天翼云扬帆起航!

天翼云开发者社区

云计算 峰会 世界移动通信大会

淘宝1688京东...商品详情API接口(属性,详情图,价格,sku评价等接口)可高并发批量采集

Anzexi58

API 文档

好物期刊#1:我每天都使用的在线工具

JavaPub

程序员 计算机 在线工具

IT外包对企业业务流程整合有什么帮助?

Ogcloud

IT IT外包 IT外包公司 IT外包服务

LLM 推理优化探微 (2) :Transformer 模型 KV 缓存技术详解

Baihai IDP

程序员 AI LLM 白海科技 KV缓存

如何做代币分析:以 LDO 币为例

Footprint Analytics

blockchain Token LDO

利用API接口进行竞品价格监控的综合指南

Noah

NineData云原生智能数据管理平台新功能发布|2024年2月版

NineData

MySQL 数据复制 tdsql NineData GaiaDB

IT外包提升企业灵活性与敏捷性

Ogcloud

IT IT外包 IT外包公司 IT外包服务

如何使用香山之香山工具详解:difftest应用及配合波形检验

源芯

芯片设计 risc-v 开源芯片 高性能处理器香山

金融信创湖仓一体数据平台架构实践

数新网络官方账号

金融 信创 数据平台 湖仓一体

从《繁花》看图数据库的关联力!

博文视点Broadview

数字先锋| 上云!让“媒”好“发声”

天翼云开发者社区

云计算 网络 上云

Paket:一个面向.NET的包管理器_.NET_Pierre-Luc Maheu_InfoQ精选文章