实现文件分片合并功能并使用Github Actions自动编译Release

一、编译IOS镜像

1.1 编译

起因是公司电脑使用的Win11 23H2的预览版,这个预览版系统的生命周期只到2024-09-18,到期后就会强制每两小时重启。这是Windows强制升级系统的一种手段。

虽然公司里的台式电脑目前用不到,但是里面还保留许多旧项目的资料,所以为了保留数据,我需要尽快转为正式版。

目前Windows 11系统正式版已经更新到了24H2版本,不过总体体验并不好。很多自带功能是强制捆绑给用户使用的,且没有开放给用户关闭或者切换开关。

我需要保留新系统的新特性,并且我还不要强制捆绑给用户使用的那些功能。结合自己的使用经历、以及查阅官方文档,确定了要制作Win11 22H2 22621.2283这个版本的镜像。

访问UUPdump这个平台,根据自己的架构,选择对应的系统版本。

UUPdump 是一个社区驱动的网站和工具,旨在帮助用户下载和生成 Windows 更新包,注意这并不是由官方维护的!

下载工具后,完成IOS镜像的编译。

之后进行镜像的安装。

等待安装完毕即可。

1.2 参考致谢

2023 年 9 月 12 日 — KB5030219 (OS 内部版本 22621.2283) - Microsoft 支持

UUP dump

二、文件分片与合并

编译后的镜像,想从上海传给武汉的电脑,就需要一个不限速的服务作为媒介。我尝试了123网盘,但是这个盘下载时的网络经常断不稳定,故使用了小米云盘,但是小米云盘又限制单个文件大小。

由此我编写了文件分片与合并服务

  • 单线程顺序将文件进行分片与合并
  • 使用内存缓冲区技术。即使操作很大的文件,运行内存也只会在1MB左右
  • 通过命令行选项使用

放一张运行图。

这种工具使用Go来写会好很多,但是Go本身又不熟悉,用不精通。就比如如何在运行时,更精巧地压榨程序内存、发挥更大性能,在这一块上没有Java用得精。

想把Jar编译成EXE,发现JavaGraalvm好垃圾,居然不支持日志组件SLFJ,我排查了后,发现是因为SLFJ中用到了好多反射,导致Graalvm失效。

三、配置GithubActions

3.1 配置

我的需求是按照如下图实现功能。

直接放上Java with Maven测试通过的maven.yml

# This workflow will build a Java project with Maven, and cache/restore any dependencies to improve the workflow execution time
# For more information see: https://docs.github.com/en/actions/automating-builds-and-tests/building-and-testing-java-with-maven

# This workflow uses actions that are not certified by GitHub.
# They are provided by a third-party and are governed by
# separate terms of service, privacy policy, and support
# documentation.

name: Build, Package, and Release Java Project

on:
  push:
    tags:
      - 'v*' # Push events to matching v*, i.e. v1.0, v20.15.10

# 在push或者pull_request时触发
# on:
#   push:
#     branches: [ "master" ]
#   pull_request:
#     branches: [ "master" ]

jobs:
  build:
    runs-on: ubuntu-latest

    steps:
      - uses: actions/checkout@v4
      - name: Set up JDK 8
        uses: actions/setup-java@v3
        with:
          java-version: '8'
          distribution: 'temurin'
          cache: maven
      # 构建jar包
      - name: Build with Maven
        run: mvn package -DskipTests
      - run: mkdir staging && cp target/*.jar staging
      # 上传打包后内容到artifact
      - name: Upload JAR artifact
        uses: actions/upload-artifact@v4
        with:
          name: ${{ github.ref_name }}
          path: staging
          retention-days: 1  # 设置保留 artifact 天数
      # 创建release
      - name: Create GitHub Release
        id: create_release
        uses: actions/create-release@v1
        env:
          GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
        with:
          tag_name: ${{ github.ref }}
          release_name: Release-${{ github.ref }}
          draft: false
          prerelease: false
      # 将软件包打成zip压缩包
      - run: zip  ${{ github.ref_name }}.zip staging/*
      # 将zip压缩包上传至release
      - name: Upload JAR to Release
        uses: actions/upload-release-asset@v1
        env:
          GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
        with:
          upload_url: ${{ steps.create_release.outputs.upload_url }}
          asset_path:  ${{ github.ref_name }}.zip
          asset_name:  ${{ github.ref_name }}.zip
          asset_content_type: application/zip

最终执行结果

3.2 参考致谢

Quickstart for GitHub Actions - GitHub Docs

Contexts - GitHub Docs

Create Release Error in Github Actions - Developers: Plugin & API - Obsidian Forum

Building and testing Java with Maven - GitHub Docs

starter-workflows/ci at main · actions/starter-workflows

actions/upload-release-asset: An Action to upload a release asset via the GitHub Release API

actions/upload-release-asset: An Action to upload a release asset via the GitHub Release API

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值