要在本地仓库中添加标签,你可以使用以下命令:
git tag
这将在当前所处的提交上创建一个轻量级标签(lightweight tag)。如果你想要创建一个带有附注信息的标签,可以使用 -a 选项:
git tag -a -m "tag message"
在这个命令中,-a 表示创建一个带附注的标签,-m 用来指定标签的消息内容。
如果要将标签推送到远程仓库(例如 GitHub 或 GitLab),需使用 git push 命令,并指定 --tags 选项来推送所有标签:
git push origin --tags
这样就可以将本地仓库中的标签推送到远程仓库中,从而与其他开发人员共享这些标签信息。
删除标签 例如删除 1.0.15标签
git tag -d 1.0.15
将上面删除操作推到远端
git push origin :refs/tags/1.0.15
撤回某个已经 push过的合并操作,只需两步
- git reset --hard <合并前的提交哈希值>
- git push origin <你的分支名> --force-with-lease
如果是npm包项目,且有gitlab CICD持续集成的还可以结合 .gitlab-ci.yml 做一些自动化发版,
例如
- before_script:
- - echo -e "registry=https://registry.example.com/" >> .npmrc
-
- sdk-build:
- stage: build
- only:
- - tags
- script:
- - node ./changeVersion.js
- - echo -e "\n//registry.example.com/:_authToken=$NPM_ACCESS_TOKEN" >> .npmrc
- - npm publish
这一段表示添加 .npmrc文件,内容为 registry=https://registry.example.com/
CICD监听到tags变化时,执行changeVersion.js 修改package.json中的版本version,
然后 npm publish进行发版。(注意上文NPM_ACCESS_TOKEN为gitlab中定义变量)
私有npm服务上面最后一步publish后面最好加源
- npm publish --registry=https://registry.example.com/
changeVersion.js内容如下
- const fs = require('fs');
-
- // 读取 package.json 文件
- fs.readFile('package.json', 'utf8', (err, data) => {
- if (err) {
- throw err;
- }
- // 解析 package.json 内容
- const packageJson = JSON.parse(data);
- // 将 CI_COMMIT_TAG 赋值给 version 字段
- packageJson.version = process.env.CI_COMMIT_TAG;
- // 将修改后的内容写回 package.json 文件
- fs.writeFile('package.json', JSON.stringify(packageJson, null, 2), 'utf8', (err) => {
- if (err) {
- throw err;
- }
- console.log('package.json 文件中的 version 已更新为 ' + process.env.CI_COMMIT_TAG);
- });
- });
这样即可实现tag标签变化后,自动发版,版本号=tag