Skip to content

Building Valheim Dedicated Server using GCP and Terraform Infrastructure as Code

Notifications You must be signed in to change notification settings

ElijahGartin/valheim-dedicated-server-gcp

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

24 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Valheim Dedicated Server Google Cloud Platform IaaS Build

Terraform

2021 AUG 09

Disclaimer/Legal

All use of these tools are the sole responsibility of the user applying the build in their own Cloud Environments. Elijah Gartin/Falkon, Thunder Rock Gaming, ZeroBandwidth/And All Aliases, and any affiliated associates assume no liability for any issues or costs associated with utilizing these tools. You accept these terms and assume all responsibility by using and deploying any asset or artifact in this repository.

About

This repository is to build a Valheim Dedicated Server from Google Cloud Platform. We assume you know how to use Google Cloud Platform.

Pulling from Ubuntu Server immutable images and a dynamic Valheim Build library created by ZeroBandwidth and associates. Application Build Github.

All critiques are welcome via the Github Project or through Discord in the Valheim or Science and Technology areas. To access those areas in discord, click on the 🌲 and/or 🚀 emoji reactions to gain access to those respective channel groups in the #channel-picker after accepting the terms of service discord prompt.

Repositories

Repository
Valheim Terraform AWS
Valheim Terraform Azure
Valheim Terraform Google Cloud Platform
Valheim Terraform Digital Ocean

Prerequisites

Additional References

Steps

You'll be editing some lines in the ROOT:vars.tf file for the local variables between line 8 and 28. Steps described below. Mileage may vary depending on what data center you try to push to.

You'll notice some of the taxonomy in referring to files such as ROOT:filename. Root will be the root of the folder structure. Any modules will change the name of ROOT to NETWORK for example where there is another grouping of similarily named files. This is a Terraform thing that some people may not be familiar with.

  1. ROOT:vars.tf: Use curl https://ipinfo.io/ip to obtain your IP and input it in the locals variable for your_ip in the this file. This is essential for you to be able to SSH from your box. If you intend to use a bastion host, make sure you're putting in the ip for the bastion host.

    Required:

    • your_ip
    • project

    Optional:

    • region
    • zone
    • account_id
    • display_name
  2. In your CLI:

    • Execute gcloud compute ssh valheim-server
    • Choose 64 for region if you didn't change it
      • It should auto-generate a key for you
  3. Once you've saved all your changes, open a terminal/command prompt to the location of this repository and run the following commands in succession:

    • terraform init

    • terraform apply

      You can destroy all assets when you are completed using terraform destroy

  4. Connect to server using OS Login:

    • Like the previous step, with the automations, it should have picked up the autogenerated ssh key and associated it to your authenticated gcloud account.
    • Execute gcloud compute ssh valheim-server again to get to the server and begin building your valheim server

WARNING Make sure you backup your game if you've made progress and want to keep it. If it becomes additionally requested I may add more functionality to play with the backup functionality that ZeroBandwidth and crew have developed.

Alternatively you can just backup with their scripts and then use SCP to download the backup.

Example: scp -i KEYNAME ubuntu@IPADDRESS:/home/steam/backups/valheim-backup-DATEUUID.tgz ~/Downloads/valheim-backup-DATEUUID.tgz

You can then reupload this to Data Blobs and have it download from the /scripts/bootstrap.sh script if you care to if you have to rebuild a server.

Network Schema

10.10.10.0/24 - Main Subnet (Server will build here as 10.10.10.69 (Nice))

The server will currently build as a e2-standard-2 (2vCPU 8GB RAM). Depending on the size of the world and how many users, you may need to adjust the size. With Terraform, it should be as simple as updating the line of code in ROOT:main.tf line 41 with the new sizing and re-running terraform apply. Make sure you stop the server and backup before doing it, just in case.

f1-micro - for testing

Support for Infrastructure as Code

Author: Elijah Gartin (Falkon)

Support for Valheim Server Scripts

Author: ZeroBandwith (And Many More)

About

Building Valheim Dedicated Server using GCP and Terraform Infrastructure as Code

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published