# PT's Basic Modpack 一些最基础的功能的模组包,包括录制、光影、基本优化等。主打原版味道。 ## 开发 分为服务端和客户端两部分。服务端会在不同时间,安装不同的娱乐性质的模组。客户端则会努力保持不变。 使用 [packwiz](https://packwiz.infra.link) 进行模组包管理。 首先你要安装 packwiz。建议的是用 Golang 技术栈来直接安装: ```bash go install github.com/packwiz/packwiz@latest ``` 然后,进入对应的目录开始工作。例如要更改客户端相关: ```bash cd client ``` ### 添加模组 ```bash packwiz add https://modrinth.com/mod/create ``` ### 构建 .mrpack 文件 ```bash packwiz modrinth export ``` ## 服务端部署 参见 [该文档](https://packwiz.infra.link/tutorials/installing/packwiz-installer/)。 可以直接使用 Docker 来测试运行: ```bash docker run --pull=always \ -e TYPE=FABRIC \ -e "PACKWIZ_URL=https://gitea.service.jazzwhom.top/Passthem/pt-minecraft-modpack/raw/branch/main/server-01-random-block/pack.toml" \ -e "EULA=TRUE" \ -e "VERSION=1.21.10" \ -p 25565:25565 \ itzg/minecraft-server ``` 或者,需要从 [https://github.com/packwiz/packwiz-installer/releases](这里) 下载最新最热的 Installer,以安装需要的文件。 ## 面板服一键启动方案 仓库根目录提供了 `start.sh`,适合“只能上传文件、编辑文件,然后点一个固定 shell 脚本启动”的面板服环境。 这个脚本现在**直接复用官方 `packwiz-installer-bootstrap` / `packwiz-installer`**,而不是自己手动管理模组列表。 它会自动完成这些事情: 1. 选择一个具体服务端 pack(例如 `server-01-random-block`) 2. 读取该 pack 的 `pack.toml` 中的 Minecraft / Fabric 版本 3. 下载并执行 Fabric 官方 installer,生成服务端启动 jar 4. 下载并执行 `packwiz-installer-bootstrap` 5. 用 `packwiz-installer --side server` 根据远程 `pack.toml` 自动同步当前服务端需要的模组 6. 自动写入 `eula.txt` 7. 最后启动服务端 这意味着以后仓库里新增更多目录,例如: - `server-01-random-block` - `server-02-xxx` - `server-03-yyy` 都可以继续复用同一个启动脚本,只需要切换 `PT_SERVER` 即可。 ## 方案一:你把整个仓库上传到面板服 上传后,最简单的执行方式就是: ```bash PT_SERVER="server-01-random-block" bash start.sh ``` 因为这时 `start.sh` 会直接使用仓库里的本地 `server-01-random-block/pack.toml`。 如果仓库里只有一个 `server-*` 目录,不传 `PT_SERVER` 也可以自动选择;但只要有多个,建议明确传。 ### 常用示例 ```bash PT_SERVER="server-01-random-block" PT_JAVA_ARGS="-Xms1G -Xmx1G" bash start.sh ``` ```bash PT_SERVER="server-02-xxx" bash start.sh ``` ### 什么时候需要 `PT_REPO_URL / PT_REPO_REF` 如果你希望 `packwiz-installer` 始终以远程仓库中的 `pack.toml` 为准,而不是当前本地文件,也可以额外传: ```bash PT_REPO_URL="https://gitea.service.jazzwhom.top/Passthem/pt-minecraft-modpack" \ PT_REPO_REF="main" \ PT_SERVER="server-01-random-block" \ bash start.sh ``` ## 方案二:面板服里只粘贴一个“远程拉取并运行”的脚本 如果你的面板服不方便手动上传整个仓库,而是允许你在固定 `.sh` 入口里粘贴脚本,那么可以直接粘贴下面这段: ```bash #!/usr/bin/env bash set -Eeuo pipefail REPO_URL="https://gitea.service.jazzwhom.top/Passthem/pt-minecraft-modpack" REPO_REF="main" PT_SERVER="server-01-random-block" INSTALL_DIR="$(pwd)/pt-minecraft-modpack" PT_JAVA_ARGS="-Xms1G -Xmx1G" if command -v curl >/dev/null 2>&1; then DOWNLOAD() { curl -fL --retry 3 --retry-delay 2 -o "$1" "$2"; } elif command -v wget >/dev/null 2>&1; then DOWNLOAD() { wget -O "$1" "$2"; } else echo "缺少 curl 或 wget" >&2 exit 1 fi ARCHIVE_PATH="$INSTALL_DIR.tar.gz" TMP_DIR="$INSTALL_DIR.__tmp" rm -rf "$TMP_DIR" mkdir -p "$TMP_DIR" DOWNLOAD "$ARCHIVE_PATH" "$REPO_URL/archive/$REPO_REF.tar.gz" tar -xzf "$ARCHIVE_PATH" -C "$TMP_DIR" EXTRACTED_DIR="$(find "$TMP_DIR" -mindepth 1 -maxdepth 1 -type d | head -n 1)" [ -n "$EXTRACTED_DIR" ] || { echo "解压失败" >&2; exit 1; } rm -rf "$INSTALL_DIR" mv "$EXTRACTED_DIR" "$INSTALL_DIR" rm -rf "$TMP_DIR" "$ARCHIVE_PATH" cd "$INSTALL_DIR" PT_REPO_URL="$REPO_URL" \ PT_REPO_REF="$REPO_REF" \ PT_SERVER="$PT_SERVER" \ PT_JAVA_ARGS="$PT_JAVA_ARGS" \ bash start.sh ``` ### 这个远程脚本怎么改 你通常只需要改这几个变量: - `REPO_REF`:默认 `main`,也可以改成某个分支或 tag - `PT_SERVER`:你这次要开的服务端目录名 - `INSTALL_DIR`:解压后的安装目录 - `PT_JAVA_ARGS`:JVM 参数 例如切换到另一个服务端: ```bash PT_SERVER="server-02-xxx" ``` ## 环境要求 - 必须有 `bash` - 必须有 `java` - 必须有 `curl` 或 `wget` - 远程拉取方案还需要 `tar` - 建议有常见基础命令:`grep`、`sed`、`awk`、`find` - 服务器需要能联网下载: - 你的 Gitea 仓库归档 - Fabric installer - `packwiz-installer-bootstrap` - Modrinth 模组文件 ## `start.sh` 可选环境变量 - `PT_SERVER`:选择要安装/启动的服务端目录名,例如 `server-01-random-block` - `PT_REPO_URL`:仓库地址,例如 `https://gitea.service.jazzwhom.top/Passthem/pt-minecraft-modpack` - `PT_REPO_REF`:仓库分支或 tag,例如 `main` - `PT_PACK_URL`:如果你想完全手动指定远程 `pack.toml` 地址,也可以直接传这个 - `PT_INSTALL_ROOT`:实际运行目录,默认是脚本所在目录 - `PT_JAVA_ARGS`:Java 内存等参数,默认 `-Xms1G -Xmx1G` - `PT_AUTO_EULA`:默认 `TRUE`,自动写入 `eula=true` - `PT_FORCE_UPDATE=1`:强制重新下载 Fabric installer / bootstrap,并重新执行安装 - `PT_SERVER_JAR`:手动指定启动的服务端 jar 路径 - `PT_RUNTIME_DIR`:缓存下载内容与状态文件的目录,默认 `.pt-panel-runtime/` - `PT_PACKWIZ_BOOTSTRAP_NO_UPDATE=1`:禁用 bootstrap 自更新 - `PT_FABRIC_INSTALLER_VERSION`:手动指定 Fabric installer 版本 - `PT_PACKWIZ_BOOTSTRAP_URL`:手动指定 bootstrap 下载地址 ## 验证思路 本脚本已按真实链路验证过以下关键步骤: ```bash bash -n start.sh PT_DRY_RUN=1 PT_SERVER=server-01-random-block bash start.sh ``` 并且另外在独立测试目录里实际完成了端到端验证: - `packwiz-installer-bootstrap` 可以直接读取该仓库的 `server-01-random-block/pack.toml` - `--side server` 会正确安装服务端所需模组 - Fabric 官方 installer 能正确安装 `Minecraft 1.21.10 + Loader 0.18.5` - 使用 Java 21、`-Xms1G -Xmx1G` 成功启动服务器 - 服务器日志已出现:`Done (...)! For help, type "help"`