6.7 KiB
PT's Basic Modpack
一些最基础的功能的模组包,包括录制、光影、基本优化等。主打原版味道。
开发
分为服务端和客户端两部分。服务端会在不同时间,安装不同的娱乐性质的模组。客户端则会努力保持不变。
使用 packwiz 进行模组包管理。
首先你要安装 packwiz。建议的是用 Golang 技术栈来直接安装:
go install github.com/packwiz/packwiz@latest
然后,进入对应的目录开始工作。例如要更改客户端相关:
cd client
添加模组
packwiz add https://modrinth.com/mod/create
构建 .mrpack 文件
packwiz modrinth export
服务端部署
参见 该文档。
可以直接使用 Docker 来测试运行:
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,而不是自己手动管理模组列表。
它会自动完成这些事情:
- 选择一个具体服务端 pack(例如
server-01-random-block) - 读取该 pack 的
pack.toml中的 Minecraft / Fabric 版本 - 下载并执行 Fabric 官方 installer,生成服务端启动 jar
- 下载并执行
packwiz-installer-bootstrap - 用
packwiz-installer --side server根据远程pack.toml自动同步当前服务端需要的模组 - 自动写入
eula.txt - 最后启动服务端
这意味着以后仓库里新增更多目录,例如:
server-01-random-blockserver-02-xxxserver-03-yyy
都可以继续复用同一个启动脚本,只需要切换 PT_SERVER 即可。
方案一:你把整个仓库上传到面板服
上传后,最简单的执行方式就是:
PT_SERVER="server-01-random-block" bash start.sh
因为这时 start.sh 会直接使用仓库里的本地 server-01-random-block/pack.toml。
如果仓库里只有一个 server-* 目录,不传 PT_SERVER 也可以自动选择;但只要有多个,建议明确传。
常用示例
PT_SERVER="server-01-random-block" PT_JAVA_ARGS="-Xms1G -Xmx1G" bash start.sh
PT_SERVER="server-02-xxx" bash start.sh
什么时候需要 PT_REPO_URL / PT_REPO_REF
如果你希望 packwiz-installer 始终以远程仓库中的 pack.toml 为准,而不是当前本地文件,也可以额外传:
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 入口里粘贴脚本,那么可以直接粘贴下面这段:
#!/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,也可以改成某个分支或 tagPT_SERVER:你这次要开的服务端目录名INSTALL_DIR:解压后的安装目录PT_JAVA_ARGS:JVM 参数
例如切换到另一个服务端:
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-blockPT_REPO_URL:仓库地址,例如https://gitea.service.jazzwhom.top/Passthem/pt-minecraft-modpackPT_REPO_REF:仓库分支或 tag,例如mainPT_PACK_URL:如果你想完全手动指定远程pack.toml地址,也可以直接传这个PT_INSTALL_ROOT:实际运行目录,默认是脚本所在目录PT_JAVA_ARGS:Java 内存等参数,默认-Xms1G -Xmx1GPT_AUTO_EULA:默认TRUE,自动写入eula=truePT_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 -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"