PalWolrd容器部署及第三方调优(手动操作替代OOS)Ubuntu 22.04

本文涉及的产品
无影云电脑个人版,黄金款:40核时/1个月有效
无影云电脑企业版,4核8GB 120小时 1个月
资源编排,不限时长
简介: 如果您是OSS已经部署了,请参考部署后的内容,如果您是打算使用容器部署方案,请看清楚地域选择自己最合适的安装方式,请注意该方案仅仅适用于Ubuntu

优惠购买链接:

https://developer.aliyun.com/topic/ecs/huanshou?userCode=qhtxv10l

https://developer.aliyun.com/topic/ecs/huanshou?userCode=qhtxv10l

https://developer.aliyun.com/topic/ecs/huanshou?userCode=qhtxv10l



容器部署引导

Docker安装(中国大陆外区域用户)

sudo apt update
sudo apt upgrade -y
sudo apt install lsb-release ca-certificates apt-transport-https software-properties-common -y
curl -fsSL https://download.docker.com/linux/ubuntu/gpg | sudo gpg --dearmor -o /usr/share/keyrings/docker-archive-keyring.gpg
echo "deb [arch=$(dpkg --print-architecture) signed-by=/usr/share/keyrings/docker-archive-keyring.gpg] https://download.docker.com/linux/ubuntu $(lsb_release -cs) stable" | sudo tee /etc/apt/sources.list.d/docker.list > /dev/null
sudo apt -y install docker.io
sudo systemctl enable docker --now

拉取镜像运行PalServer(中国大陆外区域用户)

sudo docker pull thijsvanloef/palworld-server-docker:latest
# 创建 /palworld 用于在 ECS 上存储服务器配置和存档
sudo groupadd steam && sudo useradd steam|| echo "ignore"
sudo mkdir /PalSaved && sudo chown -R steam:steam /PalSaved
docker run -d \
    --name palworld-server \
    -p 8211:8211/udp \
    -p 27015:27015/udp \
    -v /PalSaved:/palworld/Pal/Saved/ \
    -e PUID=1000 \
    -e PGID=1000 \
    -e PORT=8211 \
    -e PLAYERS=16 \
    -e MULTITHREADING=true \
    -e RCON_ENABLED=true \
    -e RCON_PORT=25575 \
    -e TZ=UTC \
    -e COMMUNITY=false \
    -e SERVER_NAME="World of Pals" \
    -e SERVER_DESCRIPTION="Awesome World of Pal" \
    --restart unless-stopped \
    --stop-timeout 30 \
    thijsvanloef/palworld-server-docker:latest

Docker安装及拉取镜像运行PalServer(中国大陆区域用户)

sudo dnf config-manager --add-repo=https://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo
sudo dnf -y install dnf-plugin-releasever-adapter --repo alinux3-plus
sudo dnf -y install docker-ce --nobest
sudo systemctl start docker
sudo systemctl enable docker
# 获取 Palworld 服务器 docker 镜像。
REGION=`curl -s 100.100.100.200/latest/meta-data/region-id`
# 某些地域没有镜像仓库,就近获取
if [ "$REGION" = "cn-nanjing" ] || [ "$REGION" = "cn-fuzhou" ]; then REGION=.cn-shanghai; elif [ "$REGION" = "cn-wuhan" ]; then REGION=.cn-chengdu; elif [ "$REGION" = "ap-northeast-2" ]; then REGION=.ap-northeast-1; elif [ "$REGION" = "ap-southeast-6" ] || [ "$REGION" = "ap-southeast-6" ]; then REGION=.ap-southeast-1; else REGION=-vpc.$REGION; fi
DOCKER_IMAGE_URL=registry${REGION}.aliyuncs.com/imbolo/palworld-server:latest
sudo docker pull $DOCKER_IMAGE_URL
# 创建 /PalSaved 用于在 ECS 上存储服务器配置和存档
sudo groupadd -g 1000 steam && sudo useradd -u 1000 -g steam -m steam || echo "ignore"
sudo mkdir /PalSaved && sudo chown -R 1000:1000 /PalSaved
sudo docker run --restart=always --user 1000:1000 -v /PalSaved:/home/steam/Steam/steamapps/common/PalServer/Pal/Saved/ --name palworld-server --net host -dit $DOCKER_IMAGE_URL
echo '运行成功'

游戏连接示例

备份及迁移

数据备份

全备份

# 备份到当前用户所在目录
zip -r PalWorld-$(date +"%Y-%m-%d_%H-%M-%S").zip /PalSaved/

仅备份用户数据

zip -r PalWorld-SaveGames-$(date +"%Y-%m-%d_%H-%M-%S").zip /PalSaved/SaveGames/

自动备份

# 全备份+用户备份,如果只需要一个,那么请在另一个命令行前加上 # 
cat > /root/pal-backup.sh << EOF
zip -r /root/PalWorld-\$(date +"%Y-%m-%d_%H-%M-%S").zip /PalSaved/
zip -r /root/PalWorld-SaveGames-\$(date +"%Y-%m-%d_%H-%M-%S").zip /PalSaved/SaveGames/
echo  `date` --- backup successful >> /root/pal-backup.log
EOF
chmod +x /root/pal-backup.sh
# 以每五分钟备份一次
echo "*/5 * * * * /root/pal-backup.sh" >> /var/spool/cron/crontabs/root
# 若是每小时备份一次
# echo "0 * * * * /root/pal-backup.sh" >> /var/spool/cron/crontabs/root

数据恢复

!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!

注意,导入备份数据千万不能在备份数据时,增加额外的文件层,例如
解压Save其层级为  xxx/Saved/Saved/

一定要是单纯的 Saved目录中的内容

!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!

全备份恢复(Saved)

sudo cat > /root/pal-restore.sh << EOF
echo "请输入Saved存档的绝对路径(eg: /root/pal-arch.zip): "
read ziploc
unzip -o \${ziploc} -d /PalSaved
LSN=\$(ls -tr /PalSaved/SaveGames/0/|awk 'NR==1{print \$1}')
sed -i "s/^DedicatedServerName=.*/DedicatedServerName=\$LSN/" /PalSaved/Config/LinuxServer/GameUserSettings.ini
sudo groupadd steam && sudo useradd steam|| echo "steam user or group already exists, ignore"
chown -R steam:steam /PalSaved
sudo docker restart palworld-server
docker ps 
EOF
chmod +x /root/pal-restore.sh
sudo bash /root/pal-restore.sh

用户数据恢复(SaveGames)

sudo cat > /root/pal-restore.sh << EOF
echo "请输入SaveGames存档的绝对路径(eg: /root/pal-arch.zip): "
read ziploc
unzip -o \${ziploc} -d /PalSaved/
LSN=\$(ls -tr /PalSaved/SaveGames/0/|awk 'NR==1{print \$1}')
sed -i "s/^DedicatedServerName=.*/DedicatedServerName=\$LSN/" /PalSaved/Config/LinuxServer/GameUserSettings.ini
sudo groupadd steam && sudo useradd steam|| echo "steam user or group already exists, ignore"
chown -R steam:steam /PalSaved
sudo docker restart palworld-server
docker ps 
EOF
chmod +x /root/pal-restore.sh
sudo bash /root/pal-restore.sh

第三方patch优化(1.3.0版本|中国大陆用户无法使用github)

风险操作,请备份后再操作

# 下载并替换文件
bindir=/palworld/Pal/Binaries/Linux/
docker exec palworld-server mv $bindir/PalServer-Linux-Test $bindir/PalServer-Linux-Test.bak
docker exec palworld-server wget -O $bindir/PalServer-Linux-Test https://github.com/VeroFess/PalWorld-Server-Unoffical-Fix/releases/download/1.3.0-Update-3/PalServer-Linux-Test-Patch-Update-3
docker exec palworld-server chmod 755 $bindir/PalServer-Linux-Test
sudo docker restart palworld-server

自动释放内存

cat > /root/auto-release-mem.sh << EOF
freemem=\$(free -m|awk 'NR==2{print \$7}')
if [ \$freemem -lt 100 ];then 
sudo docker restart palworld-server;
sudo echo \$(date +"%Y-%m-%d_%H-%M-%S")---auto release memory successfully ! >> /root/release-mem.log;
new_mem=\$(free -m|awk 'NR==2{print $7}')
sudo echo \$(date +"%Y-%m-%d_%H-%M-%S")---current free memory is: \${new_mem}MB  >> /root/release-mem.log;
fi
EOF
chmod +x /root/auto-release-mem.sh
echo "*/1 * * * * /root/auto-release-mem.sh" >> /var/spool/cron/crontabs/root

添加Swap内存

不建议操作,此设置有宕机风险,重启后开机过程会变长

# 根据自己的需求调整大小 此处为8G
fallocate -l 8G /swapfile
mkswap /swapfile && swapon /swapfile
echo "/swapfile none swap sw 0 0" >> /etc/fstab
相关实践学习
借助OSS搭建在线教育视频课程分享网站
本教程介绍如何基于云服务器ECS和对象存储OSS,搭建一个在线教育视频课程分享网站。
7天玩转云服务器
云服务器ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,可降低 IT 成本,提升运维效率。本课程手把手带你了解ECS、掌握基本操作、动手实操快照管理、镜像管理等。了解产品详情:&nbsp;https://www.aliyun.com/product/ecs
目录
相关文章
|
20天前
|
Kubernetes Cloud Native Java
云原生之旅:从容器到微服务的演进之路Java 内存管理:垃圾收集器与性能调优
【8月更文挑战第30天】在数字化时代的浪潮中,企业如何乘风破浪?云原生技术提供了一个强有力的桨。本文将带你从容器技术的基石出发,探索微服务架构的奥秘,最终实现在云端自由翱翔的梦想。我们将一起见证代码如何转化为业务的翅膀,让你的应用在云海中高飞。
|
15天前
|
存储 关系型数据库 文件存储
Ubuntu22.04LTS基于cephadm快速部署Ceph Reef(18.2.X)集群
这篇文章是关于如何在Ubuntu 22.04LTS上使用cephadm工具快速部署Ceph Reef(18.2.X)存储集群的详细教程,包括ceph的基本概念、集群的搭建步骤、集群管理以及测试集群可用性等内容。
75 8
Ubuntu22.04LTS基于cephadm快速部署Ceph Reef(18.2.X)集群
|
15天前
|
Ubuntu 数据安全/隐私保护
Ubuntu22.04LTS环境部署实战
这篇文章提供了Ubuntu 22.04 LTS操作系统的详细安装步骤,包括选择语言、键盘布局、网络配置、软件源设置、磁盘分区、安装OpenSSH服务以及完成安装和首次登录系统的过程。
59 6
Ubuntu22.04LTS环境部署实战
|
16天前
|
NoSQL 关系型数据库 Redis
mall在linux环境下的部署(基于Docker容器),Docker安装mysql、redis、nginx、rabbitmq、elasticsearch、logstash、kibana、mongo
mall在linux环境下的部署(基于Docker容器),docker安装mysql、redis、nginx、rabbitmq、elasticsearch、logstash、kibana、mongodb、minio详细教程,拉取镜像、运行容器
mall在linux环境下的部署(基于Docker容器),Docker安装mysql、redis、nginx、rabbitmq、elasticsearch、logstash、kibana、mongo
|
17天前
|
Linux pouch 容器
CentOS7部署阿里巴巴开源的pouch容器管理工具实战
关于如何在CentOS 7.6操作系统上安装和使用阿里巴巴开源的Pouch容器管理工具的实战教程。
52 2
CentOS7部署阿里巴巴开源的pouch容器管理工具实战
|
6天前
|
运维 Cloud Native Devops
云原生架构的崛起与实践云原生架构是一种通过容器化、微服务和DevOps等技术手段,帮助应用系统实现敏捷部署、弹性扩展和高效运维的技术理念。本文将探讨云原生的概念、核心技术以及其在企业中的应用实践,揭示云原生如何成为现代软件开发和运营的主流方式。##
云原生架构是现代IT领域的一场革命,它依托于容器化、微服务和DevOps等核心技术,旨在解决传统架构在应对复杂业务需求时的不足。通过采用云原生方法,企业可以实现敏捷部署、弹性扩展和高效运维,从而大幅提升开发效率和系统可靠性。本文详细阐述了云原生的核心概念、主要技术和实际应用案例,并探讨了企业在实施云原生过程中的挑战与解决方案。无论是正在转型的传统企业,还是寻求创新的互联网企业,云原生都提供了一条实现高效能、高灵活性和高可靠性的技术路径。 ##
16 3
|
15天前
|
存储 Kubernetes Ubuntu
Ubuntu 22.04LTS版本二进制部署K8S 1.30+版本
这篇文章详细介绍了在Ubuntu 22.04 LTS系统上使用VMware Fusion虚拟化软件部署Kubernetes 1.30+版本的完整过程,包括环境准备、安装containerd、配置etcd、生成证书、部署高可用组件、启动Kubernetes核心组件以及网络插件的部署和故障排查。
50 4
|
16天前
|
Kubernetes Ubuntu 网络安全
Ubuntu基于kubeadm快速部署K8S实战
关于如何在Ubuntu系统上使用kubeadm工具快速部署Kubernetes集群的详细实战指南。
70 2
|
19天前
|
运维 Kubernetes 负载均衡
震惊!容器化运维竟藏如此大招,容器调度与服务编排让你的软件部署 “逆天改命”
【8月更文挑战第31天】在数字化时代,容器化技术革新了软件开发与运维方式,其高效、灵活及可移植的特点为企业应用部署提供了全新方案。容器调度与服务编排作为核心环节,通过优化资源分配、提升系统可靠性和可扩展性,实现了自动化管理。Kubernetes 等工具不仅简化了容器调度,还通过 Deployment、Service、Ingress 等资源对象实现了复杂应用架构的自动化运维,大幅提高了资源利用率和系统稳定性,减少了人工干预,加速了企业数字化转型。
27 2
|
13天前
|
存储 Ubuntu 网络安全
在Ubuntu系统下通过Caddy实现LXD的安装与部署
通过上述步骤,您可以在Ubuntu系统下通过Caddy实现LXD的安装与部署。这种方法不仅可以提高容器管理的效率,还可以借助Caddy的自动SSL管理功能提升安全性。
11 0