-
-
Notifications
You must be signed in to change notification settings - Fork 202
Self‐hosting
Looking to host your own Suroi server to mess around or play against friends? This is the place for you.
Before diving into the setup instructions, make sure you have the correct tools for the job. Hosting a dedicated Suroi server requires two things:
- SSH access to a VPS (or some other form of dedicated hosting)
- The ability to open ports on said machine
You can find cheap VPS hosts at Linode, A2 Hosting, or Vultr.
NOTE: I am not endorsing or recommending any of the following hosts, they are just a few I have found people to use.
If you accept the risk, you can host a dedicated server on your home network. However, you will need to port forward the necessary ports via your router for others to access your server. Do not do this unless you understand what you are doing. Previous Linux knowledge required.
This tutorial is written assuming you are using Ubuntu 20.04. Follow accordingly based on the distribution you are using.
If you bought a VPS (or other form of hosting) from a hosting company, then these credentials should be accessible via their dashboard. Typically, they will consist of three things:
- IP: The IP of your server.
- Username The username (usually root), to log in with.
- Password: The password to log in with.
Optionally, if your VPS provides SSH access on a different port, that will also be listed.
Open a terminal (Command Prompt for Windows) and write the following command:
ssh username@hostreplacing username and host with your username and host.
If you have a custom SSH port (not 22), then use this instead:
ssh username@host -p portadditionally replacing port with the custom SSH port provided.
After writing this command, hit enter. You will be prompted for a password.
For security reasons, you cannot view your password as you type it. Type in the password, and hit enter.
If you see a notice notifying you of the machine you have just logged into, congratulations! You have succesfully SSH'd into your server.
Suroi requires a few dependencies:
If you are logged in as root, start by making sure sudo is installed:
apt -y install sudoThen install git and nginx with the following command.
sudo apt -y install git nginxTo install Node.js, install the appropriate package from your distro, or for Ubuntu:
curl -fsSL https://deb.nodesource.com/setup_20.x | sudo -E bash - &&\
sudo apt-get install -y nodejsAnd finally, install pnpm:
npm i -g pnpmNext, move into /opt, clone the repository and traverse into it:
cd /opt
git clone https://github.com/HasangerGames/suroi.git suroi
cd suroiInstall the necessary dependencies:
pnpm installUpdate the server config file's:
nano server/src/config.tsexport const Config = {
host: "0.0.0.0",
port: 8000,
// ...changing host to 0.0.0.0.
Update the client config:
nano client/src/scripts/config.tsexport const Config = {
regions: {
default: { name: "My cool server", address: "YOURPUBLICIPHERE", https: false }
},
defaultRegion: "default"
// ...Replace YOURPUBLICIPHERE with your public IP and set https to true if you have https
Build the client & server:
pnpm buildMake sure the build directory has the proper permissions:
sudo chown -R www-data:www-data /opt/suroi/client/distWe will now setup NGINX to serve the client, server API, and WebSocket server.
First, remove the default file:
sudo unlink /etc/nginx/sites-enabled/default
sudo rm /etc/nginx/sites-available/defaultCreate a new file:
nano /etc/nginx/sites-available/suroi.confAnd populate it with the following content:
server {
listen 80 default_server;
listen [::]:80 default_server;
server_name _;
# Client build
location / {
root /opt/suroi/client/dist;
}
# API server
location /api {
proxy_http_version 1.1;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-Host $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header X-Forwarded-Proto $scheme;
proxy_set_header Host $http_host;
proxy_pass "http://127.0.0.1:8000";
}
# WebSocket server
location /play {
proxy_http_version 1.1;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-Host $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header X-Forwarded-Proto $scheme;
proxy_set_header Host $http_host;
proxy_set_header Upgrade $http_upgrade;
proxy_set_header Connection "Upgrade";
proxy_pass "http://127.0.0.1:8000";
proxy_redirect off;
}
}Save the file using Ctrl + X, and press Y to confirm the file name.
To enable the configuration:
sudo ln -s /etc/nginx/sites-available/suroi.conf /etc/nginx/sites-enabled/suroi.conf
sudo systemctl restart nginxNext, we will create a systemd unit file, which will ensure our application starts at boot and won't terminate if we end our SSH session:
sudo nano /etc/systemd/system/suroi.serviceAnd populate it with the following content:
[Unit]
Description=Suroi dedicated server.
[Service]
Type=simple
WorkingDirectory=/opt/suroi
ExecStart=/usr/bin/pnpm start
[Install]
WantedBy=multi-user.targetSave the file using Ctrl + X, and press Y to confirm the file name.
Enable the unit:
sudo systemctl daemon-reload
sudo systemctl enable --now suroiIf you've done everything correctly, you should be able to access the server at http://youriphere (ex: http://1.1.1.1).
Congratulations! You can stop here.
Optionally, let's install a firewall to keep your server safe:
sudo apt -y install ufw fail2banAllow the correct ports.
sudo ufw limit 22/tcp
sudo ufw allow 80/tcpNOTE: If you are using an SSH port other than 22, adjust accordingly.
Enable the firewall.
sudo ufw enableAnd that's it! You're all good to go.