• 个人NuGet服务搭建,BaGet保姆及部署教程


    前言

    应该或许大概每个公司都会有自己的NuGet包仓库吧。

    不会吧!不会吧!不会吧!不会还没有自己的仓NuGet仓库吧!

    开个玩笑,虽然我觉得有没有无所谓,但是为了这篇博客它必须有所谓。

    在工具的选择上我了解到的其实也不多,除了本文要说的BaGet,还了解有Java开发的Nexus也支持NuGet

    为什么选择BaGet呢?因为他是asp.net core开发的。

    image

    上手

    1、下载

    下载地址:https://github.com/loic-sharma/BaGet/tags

    image

    下载后的项目:

    image

    然后我们发布项目,直接在项目的根目录执行:dotnet publish,发布的文件放在bin文件夹最深处。

    2、配置文件appsettings.json

    打开发布后的文件夹,找到appsettings.json文件。

    image

    主要是修改ApiKeyDatabase信息,我们这里ApiKey先默认为空。

    3、运行项目

    直接双击文件夹的baget.exe运行程序,dotnet run也是可以的。

    image

    在浏览器访问 http://localhost:5000 如果出现如下界面就表示启动成功了

    image

    运行成功后,你配置的数据库会新增一个库,我这边配置的是Mysql

    image

    3、推送包

    我们进到网页的 Upload tab栏可以看到不同工具上传所用的命令

    image

    我们就采用第一种.NET CLI的方式上传。

    在本地准备一个Nuget包,我这边已经准备好了(vs右键属性就有打包功能)。

    image

    image

    然后进到cmd命令行如下命令,由于我没有配置ApiKey,所以会提示

    复制
    dotnet nuget push -s http://localhost:5000/v3/index.json datatekoms.utils.3.4.4.nupkg

    image

    推送成功后的页面

    image

    数据库会生成如下几张表,Packages存放的就是包的基本信息。

    image

    image

    然后进到项目的根目录会看到我们上传的包文件(我这边项目懒得启动,所以用的是linux下的截图)

    image

    4、引用包

    找到我们自己的包管理器地址

    image

    进到vsNuGet包管理器配置包源

    image

    然后搜索就可以找到我们推送的包了

    image

    docker部署

    docker部署与正常部署asp.net core项目一样,唯一需要注意的是最好把包的地址挂载到本地,避免docker重启数据丢失。

    复制
    docker run -itd --name baget.server -p 3579:80 -v /usr/local/baget/package:/app/packages baget-img

    api-key

    上面我们演示的是没有设置ApiKey,如果设置了ApiKey我们再推送是会出现验证失败

    image

    image

    这时候我们需要在命令后面加上我们设置的ApiKey

    image

    删除包

    删除包的命令也很简单

    复制
    dotnet nuget delete -s http://localhost:50561/v3/index.json datatekoms.utils 3.4.4

    image

    由于我们对删除行为的配置默认是只删除列表,不删除文件,所以执行删除后文件还是存在

    image

    如果想连带文件一起删除,我们可以这样配置,启用硬删除:HardDelete

    image

    BaGet其他配置信息可以参考官方文档:https://loic-sharma.github.io/BaGet/

  • 相关阅读:
    机器学习期中考试
    python项目实战——银行取款机系统(七)
    14:Hadoop数据分析|节点管理|搭建NFS网关服务
    数据结构-顺序表操作
    go语言添加代理
    软考 系统架构设计师系列知识点之边缘计算(2)
    Vue+element-ui的el-cascader实现动态添加删除级联地点输入框
    1055 集体照(测试点3, 4, 5)
    大数据(9h)FlinkSQL之Lookup Join
    java计算机毕业设计停车场信息管理系统源码+系统+数据库+lw文档+mybatis+运行部署
  • 原文地址:https://www.cnblogs.com/cool-net/p/16267679.html