欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

搭建私有 Nuget 服务器教程(1)

程序员文章站 2022-05-03 22:45:20
对于 .NET 开发者来说,nuget 是必不可少的程序包管理工具。相应地,大部分开发团队都需要在内部搭建 Nuget 服务器,以管理私有 nupkg 包。本文所使用的 Nuget 服务器,不是微软官方的,而是 Baget。 ......

本文摘自pzy,原文链接:

对于 .net 开发者来说,nuget 是必不可少的程序包管理工具。相应地,大部分开发团队都需要在内部搭建 nuget 服务器,以管理私有 nupkg 包。本教程所使用的 nuget 服务器,不是微软官方的,而是 baget。baget 是一款基于 .net 开发的轻量级的 nuget 服务器,它是开源、跨平台和云原生的。

nuget 服务器
baget - nuget 服务器

baget 可以运行的平台有:本地计算机、docker、aws、azure、google cloud 和阿里云。本文只谈在本地计算机上运行 baget。

运行(run)

由于 baget 是基于 .net 开发的,首先需要下载并安装 .net core sdk,然后下载并提取 baget 最新版本,再用 dotnet baget.dll 启动服务,最后在浏览器中浏览http://localhost:5000/。

运行 baget 成功后,可通过编辑 appsettings.json文件来修改 baget 的配置。 有关配置的完整列表,请参阅下文的 baget 配置。

配置(configure)

您可以通过编辑 appsettings.json 文件来修改 baget 的配置。

需要api密钥

您可以要求用户提供密码(称为api密钥)来发布程序包。 为此,您可以在 apikey 字段中设置所需的 api 密钥。

{    
"apikey": "nuget-server-api-key",    
... 
}

用户现在必须提供 api 密钥来推送软件包:

dotnet nuget push -s http://localhost:5000/v3/index.json -k nuget-server-api-key package.1.0.0.nupkg

启用直通缓存

直通缓存可以从上游源索引软件包,使用直通缓存需要执行以下操作:

如果从 nuget.org 还原的速度很慢,则可以加快构建速度
在离线情况下启用程序包还原

以下镜像设置将 baget 配置为从 nuget.org 索引包:

{    
...    "mirror": {        "enabled":  true,        "packagesource": "https://api.nuget.org/v3/index.json"    },    
... 
}

注意:packagesource 是 nuget 服务索引值。

启用包硬删除

为了防止出现“左键盘(left pad)”问题,baget的默认配置不允许删除程序包。 每当 baget 收到软件包删除请求时,它都会“取消列出”软件包。 未列出的软件包是无法发现的,但如果您知道该软件包的 id 和版本,仍可以下载。 您可以通过设置 packagedeletionbehavior 来覆盖此行为:

{    
...    
"packagedeletionbehavior": "harddelete",    
... 
}

启用包覆盖

通常,如果已经获取 id 和版本,baget 将拒绝软件包上传。 您可以通过设置allowpackageoverwrites将 baget 配置为覆盖现有的软件包:

{    
...    
"allowpackageoverwrites": true,    
... }

数据库配置

baget 支持多个数据库引擎来存储软件包信息,支持的数据库有:mysql、sqlite、sqlserver、postgresql、azuretable。每个数据库引擎都需要一个连接字符串来配置连接。 请访问 connectionstrings.com,以了解如何为每个数据库引擎创建正确的连接字符串。

您可以使用环境变量或通过编辑appsettings.json文件来配置所选的数据库引擎。

环境变量

有两个与数据库配置有关的环境变量。 它们是:

database__type: 要使用的数据库引擎,它应是上面列出的数据库之一,例如 postgresql 或 sqlite 。
database__connectionstring:数据库引擎的连接字符串。

appsettings.json

数据库设置位于 appsettings.json 配置文件中的 database 键下:

{    
...    
"database": {        
"type": "sqlite",        
"connectionstring": "data source=baget.db"    
},    
... 
}

有两个与数据库配置有关的设置:

类型:要使用的数据库引擎,它应是上面列出的数据库之一,例如 postgresql 或 sqlite。
connectionstring:数据库引擎的连接字符串。

由于时间关系,本文暂时写到这里,下文将叙述搭建私有 nuget 服务器教程后续内容,比如 docker 部署,包推送等等。