GitHub Packages 是一个用于托管和管理包的平台,包括容器和其他依赖项。 GitHub Packages 将源代码和包组合在一起,以提供集成的权限管理和计费,使你能够在 GitHub 上专注于软件开发。
您可以将 GitHub Packages 与 GitHub API、GitHub Actions 以及 web 挂钩集成在一起,以创建端到端的 DevOps 工作流程,其中包括您的代码、CI 和部署解决方案。
GitHub Packages 为常用的包管理器提供不同的包仓库,例如 npm、RubyGems、Apache Maven、Gradle、Docker 和 Nuget。 GitHub 的 Container registry 针对容器进行了优化,支持 Docker 和 OCI 映像。
今天,我们尝试实现 Github Package npm 应用发布实践。
名字:github-packages-npm-demo
创建 index.js
文件,并添加指示“Hello world!”的基本警报
console.log("Hello, World!");
使用 npm init
初始化 npm 包。 在包初始化向导中,输入名称为 @YOUR-USERNAME/YOUR-REPOSITORY
的包,并将测试脚本设置为 exit 0
。 这将生成一个 package.json
文件,其中包含有关包的信息。
如何安装 npm,可以参考这篇文章。
$ npm init
This utility will walk you through creating a package.json file.
It only covers the most common items, and tries to guess sensible defaults.See `npm help init` for definitive documentation on these fields
and exactly what they do.Use `npm install ` afterwards to install a package and
save it as a dependency in the package.json file.Press ^C at any time to quit.
package name: (github-packages-npm-demo) @ghostwritten/github-packages-npm-demo
version: (1.0.0)
description: github packages npm demo
entry point: (index.js)
test command: exit 0
git repository: (https://github.com/Ghostwritten/github-packages-npm-demo.git)
keywords:
author: ghostwritten
license: (ISC)
About to write to /root/github/github-packages-npm-demo/package.json:{"name": "@ghostwritten/github-packages-npm-demo","version": "1.0.0","description": "github packages npm demo","main": "index.js","scripts": {"test": "exit 0"},"repository": {"type": "git","url": "git+https://github.com/Ghostwritten/github-packages-npm-demo.git"},"author": "ghostwritten","license": "ISC","bugs": {"url": "https://github.com/Ghostwritten/github-packages-npm-demo/issues"},"homepage": "https://github.com/Ghostwritten/github-packages-npm-demo#readme"
}Is this OK? (yes) yes$ ls
index.js package.json
运行 npm install
以生成 package-lock.json
文件,然后提交更改并将其推送到 GitHub。
$ npm install
npm notice created a lockfile as package-lock.json. You should commit this file.
up to date in 3.702s
found 0 vulnerabilities╭───────────────────────────────────────────────────────────────╮│ ││ New major version of npm available! 6.14.12 → 9.2.0 ││ Changelog: https://github.com/npm/cli/releases/tag/v9.2.0 ││ Run npm install -g npm to update! ││ │╰───────────────────────────────────────────────────────────────╯$ ls
index.js package.json package-lock.json$ git add index.js package.json package-lock.json
$ git commit -m "initialize npm package"
$ git push
创建 .github/workflows
目录。 在此目录中,创建名为 release-package.yml
的文件。
name: Node.js Packageon:push:branches:- mainjobs:build:runs-on: ubuntu-lateststeps:- uses: actions/checkout@v3- uses: actions/setup-node@v3with:node-version: 16- run: npm ci- run: npm testpublish-gpr:needs: buildruns-on: ubuntu-latestpermissions:packages: writecontents: readsteps:- uses: actions/checkout@v3- uses: actions/setup-node@v3with:node-version: 16registry-url: https://npm.pkg.github.com/- run: npm ci- run: npm publishenv:NODE_AUTH_TOKEN: ${{secrets.GITHUB_TOKEN}}
如何生成
TOKEN
,请参考这篇文章。
告诉 NPM 使用以下方法之一发布包的范围和仓库:
.npmrc
文件,为存储库添加 NPM 配置文件@YOUR-USERNAME:registry=https://npm.pkg.github.com
package.json
文件并指定 publishConfig
密钥:"publishConfig": {"@YOUR-USERNAME:registry": "https://npm.pkg.github.com"}
提交并推送更改到 GitHub。
$ git add .github/workflows/release-package.yml
# Also add the file you created or edited in the previous step.
$ git add .npmrc or package.json
$ git commit -m "workflow to publish package"
$ git push
只要您的仓库中创建新版本,您创建的工作流程就会运行。 如果测试通过,则包将发布到 GitHub Packages。
workflow 构建流程
发布的 npm 包
将默认的 private
包转为 public
包
参考: