展墙
1011 字
5 分钟
git使用笔记
记一次coding代码提交时推送github
我在coding上有一个项目想要同步推送到github上,正好coding有持续集成,那就搞起来;
获取github的token
登录GitHub
⬇️
settings/profile
⬇️
Developer settings
⬇️
新建token (记得勾选repo
) ;
设置coding持续集成脚本
直接新建一个空的就可以,然后覆盖
pipeline {
agent any
stages {
stage('检出') {
steps {
checkout([
$class: 'GitSCM',
branches: [[name: env.GIT_BUILD_REF]],
userRemoteConfigs: [[url: env.GIT_REPO_URL, credentialsId: env.CREDENTIALS_ID]]
])
}
}
stage('推送部署') {
steps {
echo '正在推送文件...'
sh 'git fetch $FETCH'
sh 'git push -f $FETCH HEAD:master'
echo '已完成推送.'
}
}
}
}
然后设置环境变量
key : FETCH
value : https://用户名:token@github.com/用户名/仓库名.git
注意一下分支名称, git分支默认mian,coding 默认分支上master;
搞定~
coding持续部署高版本node
pipeline {
agent any
stages {
stage('检出') {
steps {
checkout([$class: 'GitSCM',
branches: [[name: GIT_BUILD_REF]],
userRemoteConfigs: [[
url: GIT_REPO_URL,
credentialsId: CREDENTIALS_ID
]]])
}
}
stage('安装node&依赖') {
agent {
docker {
reuseNode 'true'
registryUrl 'https://coding-public-docker.pkg.coding.net'
image 'public/docker/nodejs:23-2025.02'
}
}
steps {
sh 'npm install -g pnpm'
sh 'pnpm install'
sh 'pnpm build'
}
}
stage('压缩dist') {
steps {
echo '压缩中...'
sh 'tar -zcf dist.tar.gz dist/'
echo '压缩完成.'
sh 'ls'
}
}
stage('上传dist') {
steps {
echo '开始上传'
codingArtifactsGeneric(files: 'dist.tar.gz', repoName: 'blog', version: '${env.GIT_BUILD_REF}')
}
}
stage('部署至服务器') {
steps {
script {
def remote= [:]
remote.name = "my-remote-server"
remote.host = "1.1.1.1"
remote.allowAnyHosts = true
// 服务器远程地址
def remotePath = "/opt/1panel/apps/openresty/openresty/www/sites/blog/index"
// SSH 登陆用户名
remote.user = "root"
// SSH 登陆密码
remote.password = "xxxx"
stage("执行ssh脚本") {
echo '开始执行脚本'
sshCommand remote: remote, sudo: true, command: "rm -rf ${remotePath}/dist"
// SSH 上传文件到远端服务器
sshPut remote: remote, from: './dist.tar.gz', into:remotePath
// 解压缩
sshCommand remote: remote, command: "tar -zxf ${remotePath}/dist.tar.gz -C ${remotePath}/"
// 删除压缩文件
sshCommand remote: remote, sudo: true, command: "rm -f ${remotePath}/*.tar.gz"
echo '脚本执行结束'
}
}
}
}
}
}
删除长时间没更新的分支
新建个.sh文件
#!/bin/bash
git checkout master
beforeDay=150 # 天数修改
tarBranch=$(git branch -r )
for branch in $tarBranch
do
echo $branch
lastDate=$(git show -s --format=%ci origin/$branch)
convertDate=$(echo $lastDate | cut -d' ' -f 1)
Todate=$(date -d "$convertDate" +'%s')
current=$(date +'%s')
day=$(( ( $current - $Todate )/60/60/24 ))
echo "last commit on $branch branch was $day days ago"
if [ "$day" -gt $beforeDay ]; then
git push origin :$branch
echo "delete the old branch $branch"
fi
done
git checkout develop
#deleted merged branches on developer branch
tarBranch=$(git branch -r)
for branch in $tarBranch
do
echo $branch
lastDate=$(git show -s --format=%ci origin/$branch)
convertDate=$(echo $lastDate | cut -d' ' -f 1)
Todate=$(date -d "$convertDate" +'%s')
current=$(date +'%s')
day=$(( ( $current - $Todate )/60/60/24 ))
echo "last commit on $branch branch was $day days ago"
if [ "$day" -gt $beforeDay ]; then
git push origin :$branch
echo "delete the old branch $branch"
fi
done
导出提交记录
git log --pretty=format:"%ai , %an: %s" --encoding=“GBK” >> ./wxmaster-240904.csv
tauri github Action跨平台编译
先给项目中的action权限改成读写;
然后根目录新建 .github/workflows/release.yml
# 可选,将显示在 GitHub 存储库的“操作”选项卡中的工作流名称
name: Release CI
# 指定此工作流的触发器
on:
push:
# 匹配特定标签 (refs/tags)
tags:
- 'v*' # 推送事件匹配 v*, 例如 v1.0,v20.15.10 等来触发工作流
# 需要运行的作业组合
jobs:
# 任务:创建 release 版本
create-release:
runs-on: ubuntu-latest
outputs:
RELEASE_UPLOAD_ID: ${{ steps.create_release.outputs.id }}
steps:
- uses: actions/checkout@v2
# 查询版本号(tag)
- name: Query version number
id: get_version
shell: bash
run: |
echo "using version tag ${GITHUB_REF:10}"
echo ::set-output name=version::"${GITHUB_REF:10}"
# 根据查询到的版本号创建 release
- name: Create Release
id: create_release
uses: actions/create-release@v1
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
with:
tag_name: '${{ steps.get_version.outputs.VERSION }}'
release_name: 'SGP ${{ steps.get_version.outputs.VERSION }}'
body: '直接下载安装就可;'
# 编译 Tauri
build-tauri:
needs: create-release
strategy:
fail-fast: false
matrix:
platform: [macos-latest, ubuntu-latest, windows-latest]
runs-on: ${{ matrix.platform }}
steps:
- uses: actions/checkout@v2
# 安装 Node.js
- name: Setup node
uses: actions/setup-node@v1
with:
node-version: 21
# 安装 Rust
- name: Install Rust stable
uses: actions-rs/toolchain@v1
with:
toolchain: stable
# 使用 Rust 缓存,加快安装速度
- uses: Swatinem/rust-cache@v1
- name: install dependencies (ubuntu only)
if: matrix.platform == 'ubuntu-latest'
run: |
sudo apt-get update
sudo apt-get install -y libgtk-3-dev webkit2gtk-4.0 libappindicator3-dev librsvg2-dev patchelf
# 获取 yarn 缓存路径
- name: Get yarn cache directory path
id: yarn-cache-dir-path
run: echo "::set-output name=dir::$(yarn config get cacheFolder)"
# 使用 yarn 缓存
- name: Yarn cache
uses: actions/cache@v2
id: yarn-cache # use this to check for `cache-hit` (`steps.yarn-cache.outputs.cache-hit != 'true'`)
with:
path: ${{ steps.yarn-cache-dir-path.outputs.dir }}
key: ${{ runner.os }}-yarn-${{ hashFiles('**/yarn.lock') }}
restore-keys: |
${{ runner.os }}-yarn-
# 安装依赖执行构建,以及推送 github release
- name: Install app dependencies and build it
run: yarn && yarn tauri build
- uses: tauri-apps/tauri-action@v0.3
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
with:
releaseId: ${{ needs.create-release.outputs.RELEASE_UPLOAD_ID }}