Tribes2-Server-Setup-Guide/serverGuide.cs
2025-09-12 18:18:16 -04:00

254 lines
7.9 KiB
C#

![Tribes 2 Server Setup Guide](https://cdn.discordapp.com/attachments/521797012014759970/678460505597149214/TacoServer.png)
# Tribes 2 Server Setup Guide by ChocoTaco
## A guide for setting up a Tribes 2 server via vps, ssh, and vnc
---
Discord: [Tribes 2 Discord](https://discord.gg/Y4muNvF)
Tacoserver: [Tacoserver Github](https://github.com/ChocoTaco1/TacoServer)
---
### Target Environment
- This guide is for Debian 12 (Bookworm)
- This could probably work on other distros varying packages and commands
---
### Choosing a host
- Any VPS host could probably run a t2 server depending on how much you want to pay...
- Vultr is probably to easiest to use - https://www.vultr.com/
- Linode probably a great option too (Now Akamai) - https://www.linode.com/
- GCE (Google Compute Engine) being probably the more difficult option - https://cloud.google.com/compute/
- I'm sure there's others
---
### Connecting to your vps
- SSH as root into your vps (Your root password can usually be found on your host vps website): https://www.linode.com/docs/guides/connect-to-server-over-ssh-on-windows/
- In Linux use
ssh root@ip.address -L 5901:localhost:5901
---
### Setting up Debian
- Once youre in... make a user and set a password. Change `t2server` as whatever username you want...
adduser t2server
- Then...
usermod -aG sudo t2server
- Update packages
sudo apt update && sudo apt upgrade
---
# Log out as root and log back in as t2server or your newly created user. This is very important...
---
- Install desktop
sudo apt install xfce4 xfce4-goodies tightvncserver xfonts-base firefox-esr synaptic file-roller git winetricks htop curl zenity
- Start vnc server, make password...8 characters
vncserver
- Kill vnc server
vncserver -kill :1
- Open vnc config file
nano ~/.vnc/xstartup
- Copy this inside xstartup at the end, `ctrl-o` save, `ctrl-x` to exit. This says to start our desktop when we start our vnc
#!/bin/bash
xrdb $HOME/.Xresources
startxfce4 &
- Repair permissions
sudo chmod +x ~/.vnc/xstartup
---
### Installing WINE
- Install the wine repo by following the directions here: https://wiki.winehq.org/Debian
sudo dpkg --add-architecture i386 &&
sudo mkdir -pm755 /etc/apt/keyrings &&
sudo wget -O /etc/apt/keyrings/winehq-archive.key https://dl.winehq.org/wine-builds/winehq.key &&
sudo wget -NP /etc/apt/sources.list.d/ https://dl.winehq.org/wine-builds/debian/dists/bookworm/winehq-bookworm.sources &&
sudo apt update
- This will install wine-development, typically theres no issues.
sudo apt install --install-recommends winehq-stable
- If you want the development branch install `winehq-devel`
### Get all the files
- Download:
wget https://www.the-construct.net/downloads/tribes2/tribes2gsi.exe &&
wget https://www.tribesnext.com/files/TribesNext_rc2a.exe &&
wget https://tribes2stats.com/files/mods/classic_v152.zip &&
git clone https://github.com/ChocoTaco1/TacoServer &&
git clone https://github.com/ChocoTaco1/TacoMaps &&
wget https://www.dropbox.com/s/bvh9631a4mtuisf/msvcrt-ruby190.zip &&
wget https://www.dropbox.com/s/tt4utbqkzh791y8/SetPerfCounter.zip
---
### Start your VNC Server
- Change `1800x950` to be whatever resolution you want
vncserver -geometry 1800x950
- Use Real VNC for windows - https://www.realvnc.com/en/
- Use Reminna for linux - https://remmina.org/
- Setup to use `localhost:5901` while youre logged into the server using ssh. Enter your 8 character vnc password. You should be greeted with a Debian desktop.
---
### Setup T2
- Install T2 in wine (Typically installs to `/home/t2server/.wine/drive_c/Dynamix`)
wine Tribes2gsi.exe
- Install Tribesnext_rc2a
wine TribesNext_rc2a.exe
- Update Classic to 1.5.2 (1.0 is included in Tribes2gsi) Just delete classic folder in Gamedata and extract classic 1.5.2 there
- Extract TacoServer to Classic (Overwriting any existing files)
- Extract Tacomaps to Classic/maps/
- Extract msvcrt-ruby190 to Gamedata (Overwriting any existing files)
- Extract Perf Counter to Classic/scripts/autoexec (This locks server to HighPerformanceCounter=0)
---
- Optional: Download Loop's sha1 fix (Extract Server.dll and wine-injector to GameData Folder, put t2csri_serverside_looped.cs in Gamedata/Classic/scripts/autoexec)
wget https://www.dropbox.com/scl/fi/gu5eixt8q078fnweahov3/t2-auth-faster.zip?rlkey=gy4u4789ylfhvr1iqi2zp30bz&st=ka7s1r74
- Loop's fix requires vcrun22 to work...
winetricks -q --force vcrun2022
---
### Firewall (Optional)
- Install iptables
sudo apt install iptables iptables-persistent
- Make sure iptable ports are open
sudo iptables -I INPUT -p tcp --dport 80 -j ACCEPT
sudo iptables -I INPUT -p udp --dport 80 -j ACCEPT
sudo iptables -I INPUT -p tcp --dport 28000 -j ACCEPT
sudo iptables -I INPUT -p udp --dport 28000 -j ACCEPT
- Also make sure ports are open within the host service youre using with their firewall. Make sure to open port 22 for your ssh port as well.
---
### Starting the Server
- Start t2 server (without loop's fix)
taskset -c 0 wineconsole Tribes2.exe -dedicated -mod Classic
- Start t2 server (with loop's fix)
taskset -c 0 wine wine_injector.exe Server.dll Tribes2.exe 28000 -dedicated -mod Classic
- `taskset -c 0` is locking the server process to one cpu only
---
### Using a bash script
- Ideally you can start your server with a bash script `ie: sh startserver.sh`
#!/bin/sh
BASEDIR=/home/t2server/.wine/drive_c/Dynamix/Tribes2/GameData/
cd ${BASEDIR}
while true; do
echo "Waiting 30 seconds for all wine processes to close..."
sleep 30
wineserver -k9 && killall wine && kill $(lsof -t -i:28000) && kill $(lsof -t -i:80) && killall winedevice.exe
echo "Removing dsos..."
find ${BASEDIR} -name \*.dso -execdir /bin/rm {} \;
echo "Starting Tribes2 server..."
WINEDEBUG=-all,-fixme taskset -c 0 wineconsole Tribes2.exe -dedicated -mod Classic
done
- Update the start command with whatever you choose to use regarding loop's fix
- You can create a shortcut to this start server script by right-clicking on the desktop and choosing create a launcher
Name: Start Server | Command: sh /home/t2server/startserver.sh | Click "Start in Terminal"
---
### Other Things
- For security you can use an ssh key to login
- Make sure to use Vultr Firewall or something to lock down all ports except 80, 28000, and 22 (ssh)
- Adding an ftp server can also help with file management, granted you locked down the ports
- Higher Priorty: To allow your user to set a higher priority use add at the end of... (I wouldnt recommend this on shared cpus)
sudo nano /etc/security/limits.conf
@t2server - nice -20
New startup would be something with `nice -n -5` added...
nice -n -5 taskset -c 0 wineconsole Tribes2.exe -dedicated -mod Classic
---
### Post Preview Patch
- Updating a server to the newly released preview:
Visit Thread: https://tribesnext.com/forum/discussion/4430/preview-qol-fixes-update
Back up your server T2 folder
Download the latest release
Use wine `TribesNEXT_XXXXXXXXX_preview.exe` to initiate the installer for wine
Or in windows execute the exe
Install to your server T2 GameData folder
If you're using Loops fix or anything like that, remove it from the launch parameters and t2csri_serverside_looped.cs from autoexec
When you patch make sure `T2csri.vl2` updates. Its around 1.3mb
- To take advantage of extra bandwidth set,
$pref::Net::PacketRateToClient = "64";
$pref::Net::PacketSize = "1000";
- To prevent the new UE box from popping up set,
$pref::Engine::ExitOnException = true;
- If you don't want the linux icon showing up use
$Host::Linux = 0;
- Loadingscreen Safeguards:
To ensure clients dont get stuck on the loading screen these changes need to be made
https://github.com/ChocoTaco1/TacoServer/commit/7cd1cb8815e19990ab5a0cf632aedc82726333ed
---
# Success!
## If everything is setup correctly your server should show up on the master server within a few minutes
Good Luck!