awesome-lego-universe/server-setup/google-cloud-setup.md

358 lines
17 KiB
Markdown
Raw Normal View History

# Setup Instructions for Darkflame Universe (Google Cloud Setup)
The following is a guide to setting up a functioning Darkflame Universe server instance running in the cloud, which has several key benefits:
2021-12-07 19:06:21 +00:00
- These steps don't vary based on what kind of computer you have. They're the same regardless if your home computer runs Windows, Mac, or Linux.
- You can easily start over if you mess up (just delete the instance and create a new one).
2021-12-07 16:02:02 +00:00
- You can easily change the server's settings and manage it from anywhere.
- The server can continue to run even if you turn off your PC.
2021-12-07 19:06:21 +00:00
The downside to this method is that it does technically cost money. You may have to provide a payment method with Google. However, there is a one-year trial which gives $300 in credits, and the smallest instance is only about $5 a month.
## Setup Client Files
2021-12-28 23:11:04 +00:00
The first step in this process is setting up your client files. You will need a LEGO Universe 1.10.64 client before continuing. Note that a link to a client cannot be provided in this guide for legal reasons, but Google should be able to help you.
2021-12-28 23:11:04 +00:00
Once you've obtained a client, [make sure it is good by validating the checksum](/verify-my-client.md).
## Unpack Client Files
If you downloaded an unpacked client, you may skip this section and move onto [creating the server 'res' directory](#setup-resource-directory).
Darkflame Universe requires an unpacked client, both for setup and for play. An unpacked client can be distinguished by containing extra files and folders in the `res` folder in the client, such as the `macros`, `names`, `maps`, and `scripts`.
If these folders are missing, you will need to extract them from the client resource data.
2021-12-07 19:06:21 +00:00
**TODO: Write really easy instructions on running [pkextractor](https://github.com/lcdr/utils/blob/master/utils/pkextractor.pyw)**
## Setup Resource Directory
2021-12-07 19:06:21 +00:00
Once you have an unpacked client, you will need to retrieve several files from it, that the DLU server needs in order for it to work. Create a folder called `server-resources` somewhere easy to remember, and follow these steps:
* Create a folder called `res`.
* Copy the `LEGO Universe/res/macros` folder into the `res` folder in your resource directory.
* Copy the `LEGO Universe/res/BrickModels` folder into the `res` folder in your resource directory.
* Copy the `LEGO Universe/res/names` folder into the `res` folder in your resource directory.
* Copy the `LEGO Universe/res/maps` folder into the `res` folder in your resource directory.
* Copy the `LEGO Universe/res/chatplus_en_us.txt` file into the `res` folder in your resource directory.
2021-12-07 19:06:21 +00:00
* Copy the `LEGO Universe/res/cdclient.fdb` folder into the `res` folder in your resource directory.
* Create a folder called `locale`.
* Copy the `LEGO Universe/locale/locale.xml` file into the `locale` folder in your resource directory.
You should have a directory containing the following file structure.
```
|
|-res
|-macros
|- ...
|-BrickModels
|- ...
|-names
|- ...
|-maps
|- ...
|-chatplus_en_us.txt
2021-12-07 19:06:21 +00:00
|-cdclient.fdb
|-locale
|-locale.xml
```
2021-12-07 19:06:21 +00:00
Finally, right click your `server-resources` folder, and select 'Send to...' > 'Compressed Folder'. This will compress the folder into a single ZIP file. You will need this ZIP file later.
## Getting Started with Google Cloud
2021-12-28 23:11:04 +00:00
Google makes it very easy to set up a server instance in the cloud.
2021-12-28 23:11:04 +00:00
1. First, [sign up for an account with Google Cloud](https://cloud.google.com/). You should see this popup to let you know you've received $300 in trial credits:
2021-12-07 16:02:02 +00:00
2021-12-28 23:11:04 +00:00
![](../images/google-cloud-trial.png)
2021-12-07 16:02:02 +00:00
2021-12-28 23:11:04 +00:00
2. Then, you can access your cloud account from the [Google Cloud Console](https://console.cloud.google.com/). Google has a LOT of powerful tools and resources, but most of them are designed for larger businesses and not relevant to this guide, so don't get overwhelmed.
2021-12-07 16:02:02 +00:00
2021-12-28 23:11:04 +00:00
3. Click on the `Compute Engine` tab, and then click on the `Create Instance` button to create a new VM instance.
2021-12-08 17:53:05 +00:00
2021-12-28 23:11:04 +00:00
![](../images/google-cloud-compute.png)
2021-12-08 17:53:05 +00:00
2021-12-28 23:11:04 +00:00
---
2021-12-07 16:02:02 +00:00
2021-12-28 23:11:04 +00:00
![](../images/google-cloud-create.png)
4. Name it `darkflame-instance`.
2022-01-01 21:29:53 +00:00
5. The default region and zone are fine.
2021-12-28 23:11:04 +00:00
6. Select the machine type. The default is a 2-core, 4GB memory machine, which is way overkill for what we want. Select the series N1, machine type `f1-micro`, which at time of writing is currently priced at $4.88/month or $0.01/hour. Even this is more than what you need for a DLU server but smaller instances aren't available.
7. Scroll to the bottom and click Create.
8. Once the instance is ready, click it, then click SSH to connect to your instance. You will then see a browser window containing a terminal.
2021-12-07 16:02:02 +00:00
Congratulations! What you've essentially done is reserve a tiny spot on Google's massive server farm, and created a Linux computer in it. We're going to build and install Darkflame Universe on here, and you and your friends will be able to connect and play the game.
## Setup the MySQL Database
2021-12-07 19:06:21 +00:00
Once you've opened the terminal, run these commands, one at a time, in order.
2021-12-07 16:02:02 +00:00
2021-12-07 19:48:37 +00:00
```bash
2021-12-07 19:06:21 +00:00
# Install almost every dependency we need.
2021-12-07 16:02:02 +00:00
sudo apt-get update
2021-12-07 19:23:40 +00:00
sudo apt-get install -y python3 python3-pip build-essential gcc libssl-dev zlib1g zlib1g-dev sqlite git gpg wget unzip screen
2021-12-07 19:06:21 +00:00
# This installs MariaDB
sudo apt-get install -y default-mysql-server
2021-12-07 16:02:02 +00:00
# Install the latest cmake
sudo apt remove -y --purge --auto-remove cmake
pip3 install cmake --upgrade
export PATH="$HOME/.local/bin:$PATH"
# Allocate swap space so we don't run out of memory while building.
sudo fallocate -l 2G /swapfile
sudo chmod 600 /swapfile
sudo mkswap /swapfile
sudo swapon /swapfile
sudo swapon -s
sudo mysql -u root
```
The last command will start a MariaDB shell. Enter the following commands one at a time (be sure to change the password on the first line to something more secure):
2021-12-07 19:48:37 +00:00
```sql
2021-12-07 19:06:21 +00:00
CREATE OR REPLACE USER 'darkflame'@'localhost' IDENTIFIED BY 'password';
2021-12-07 16:02:02 +00:00
CREATE OR REPLACE DATABASE darkflame;
2021-12-07 19:06:21 +00:00
GRANT ALL PRIVILEGES ON darkflame.* TO 'darkflame'@'localhost';
2021-12-07 16:02:02 +00:00
EXIT;
```
You will now have an empty database ready for later.
## Download and Build the Server
Next, run these commands one at a time to download and build the server:
2021-12-07 19:48:37 +00:00
```bash
2021-12-07 19:06:21 +00:00
git clone --recursive https://github.com/DarkflameUniverse/DarkflameServer ~/DarkflameServer
git clone https://github.com/lcdr/utils.git ~/lcdrutils
git clone https://github.com/DarkflameUniverse/AccountManager ~/AccountManager
2021-12-07 19:23:40 +00:00
wget -O ~/AccountManager/credentials.py https://raw.githubusercontent.com/MasterEric/awesome-lego-universe/master/server-setup/google-cloud-res/credentials.py
wget -O ~/AccountManager/resources.py https://raw.githubusercontent.com/MasterEric/awesome-lego-universe/master/server-setup/google-cloud-res/resources.py
pip3 install -r ~/AccountManager/requirements.txt
2021-12-07 19:06:21 +00:00
cd ~/DarkflameServer
2021-12-07 16:02:02 +00:00
chmod +x build.sh
./build.sh
```
2021-12-09 19:48:56 +00:00
Wait until the build process is complete. This will take a while. In the meantime, you can move on and complete the Upload Resources and Configuring the Server's Firewall sections below. Just don't close the window!
2021-12-07 16:02:02 +00:00
## Upload Resources
2021-12-07 19:06:21 +00:00
Next, we're going to upload the resources folder [we created earlier](#setup-resource-directory) to the proper location. In order to do this in a way that doesn't differ between computers, we're going to create a Google Cloud Storage bucket and upload the files to it.
2021-12-28 23:11:04 +00:00
1. Click 'Google Cloud Platform' at the top to move to the Google Cloud homepage.
2. Click 'Cloud Storage' on the left.
3. Click 'Create Bucket' at the top.
4. Pick a name that is easy to remember and easy to type. It needs to be GLOBALLY unique apparently.
5. Stick with the defaults for region, storage class, access control, and protection.
2021-12-07 19:06:21 +00:00
2021-12-28 23:11:04 +00:00
Now the bucket is created, you will see the details page for that bucket and a list of objects (i.e. files) in it.
2021-12-07 19:06:21 +00:00
2021-12-28 23:11:04 +00:00
6. Click 'Upload File', select your `server-resources` ZIP, and click upload. This process should take just a second.
2021-12-07 19:06:21 +00:00
## Configuring the Server's Firewall
Before we get started building the server, we need to configure the server's firewall. Follow these steps:
2021-12-28 23:11:04 +00:00
1. Click 'Compute Engine' to move back to the Compute Engine homepage.
2. Under Related Actions, click 'Set up Firewall rules'
3. Click 'Create Firewall Rule' at the top.
2021-12-07 19:06:21 +00:00
We're going to create a set of Firewall rules that allow access to the server.
2021-12-28 23:11:04 +00:00
1. Set the name to `darkflame-server`.
2. Add `darkflame-server` to the list of target tags. We're going to assign this tag to our server later.
3. Set the Source IPv4 ranges to `0.0.0.0/0`. This represents all IP addresses, meaning this rule will allow any incoming IP.
4. Under Protocols and ports, check `TCP` and enter the string `1001, 2000, 2005, 3000-4000, 3306, 5000`. This will allow access to the auth server, master server, chat server, world servers, database, and account manager.
5. Under Protocols and ports, check `UDP` and enter the string `1001, 2000, 2005, 3000-4000, 3306, 5000`.
2021-12-07 19:06:21 +00:00
Now lets assign these rules to the server.
2021-12-28 23:11:04 +00:00
1. Move back to the home of your Google Cloud project (which currently contains your cloud instance).
![](../images/google-cloud-back-to-home.png)
2021-12-09 19:59:58 +00:00
2021-12-28 23:11:04 +00:00
2. Click 'Compute Engine'. You should see your `darkflame-instance` listed. Click on it.
2021-12-09 19:59:58 +00:00
2021-12-28 23:11:04 +00:00
![](../images/google-cloud-compute.png)
2021-12-09 19:59:58 +00:00
2021-12-28 23:11:04 +00:00
---
2021-12-09 19:59:58 +00:00
2021-12-28 23:11:04 +00:00
![](../images/google-cloud-click-instance.png)
2021-12-09 19:59:58 +00:00
2021-12-28 23:11:04 +00:00
3. Click 'Edit' at the top.
2021-12-09 19:59:58 +00:00
2021-12-28 23:11:04 +00:00
![](../images/google-cloud-click-edit.png)
2021-12-09 19:59:58 +00:00
2021-12-28 23:11:04 +00:00
4. Scroll down to 'Network tags' and enter `darkflame-server`.
2021-12-09 19:59:58 +00:00
2021-12-28 23:11:04 +00:00
![](../images/google-cloud-add-network-tag.png)
2021-12-09 19:59:58 +00:00
2021-12-28 23:11:04 +00:00
5. Scroll to the bottom and click 'Save'.
2021-12-07 16:02:02 +00:00
## Setup the Server
2021-12-07 19:06:21 +00:00
Once the build is done, we're going to do the final configuration needed for the server.
2021-12-07 19:48:37 +00:00
Download the server-resources.zip file from Google Cloud Storage. Be sure to replace the bucket name.
```bash
2021-12-08 17:15:35 +00:00
gsutil cp gs://BUCKETNAME/server-resources.zip ~/server-resources.zip
2021-12-07 19:06:21 +00:00
```
2021-12-07 19:48:37 +00:00
Then run all these commands, one at a time, in order.
```bash
2021-12-07 19:23:40 +00:00
# Create a logs folder.
2021-12-08 19:06:32 +00:00
mkdir ~/DarkflameServer/build/logs
2021-12-07 19:23:40 +00:00
2021-12-07 19:06:21 +00:00
# Initialize the database. You will need to enter the password you chose earlier.
mariadb darkflame -u darkflame -p < ~/DarkflameServer/migrations/dlu/0_initial.sql;
2021-12-08 17:53:05 +00:00
# Unzip the server-resources.zip and move files to the proper location. This should spit out a lot of paths.
unzip ~/server-resources.zip -d ~/server-resources/
2021-12-07 19:06:21 +00:00
mv ~/server-resources/server-resources/* ~/DarkflameServer/build/
# Extract the navmeshes.
unzip ~/DarkflameServer/resources/navmeshes.zip -d ~/DarkflameServer/build/res/maps
# Convert the FDB file to an SQLite file.
python3 ~/lcdrutils/utils/fdb_to_sqlite.py --sqlite_path ~/DarkflameServer/build/res/CDServer.sqlite ~/DarkflameServer/build/res/cdclient.fdb
# Fix the SQLite file.
sqlite3 ~/DarkflameServer/build/res/CDServer.sqlite ".read ${HOME}/DarkflameServer/migrations/cdserver/0_nt_footrace.sql"
sqlite3 ~/DarkflameServer/build/res/CDServer.sqlite ".read ${HOME}/DarkflameServer/migrations/cdserver/1_fix_overbuild_mission.sql"
sqlite3 ~/DarkflameServer/build/res/CDServer.sqlite ".read ${HOME}/DarkflameServer/migrations/cdserver/2_script_component.sql"
2021-12-08 14:20:11 +00:00
# Perform additional networking setup.
EXTERNAL_IP=$(curl -H "Metadata-Flavor: Google" http://169.254.169.254/computeMetadata/v1/instance/network-interfaces/0/access-configs/0/external-ip)
sudo modprobe dummy
sudo ip link add eth10 type dummy
sudo ip addr add $EXTERNAL_IP brd + dev eth10 label eth10:
2021-12-07 19:06:21 +00:00
# Setup your config files.
2021-12-07 19:48:37 +00:00
sed -i "s/mysql_host=/mysql_host=localhost/g" ~/DarkflameServer/build/authconfig.ini
sed -i "s/mysql_host=/mysql_host=localhost/g" ~/DarkflameServer/build/chatconfig.ini
sed -i "s/mysql_host=/mysql_host=localhost/g" ~/DarkflameServer/build/masterconfig.ini
sed -i "s/mysql_host=/mysql_host=localhost/g" ~/DarkflameServer/build/worldconfig.ini
sed -i "s/mysql_database=/mysql_database=darkflame/g" ~/DarkflameServer/build/authconfig.ini
sed -i "s/mysql_database=/mysql_database=darkflame/g" ~/DarkflameServer/build/chatconfig.ini
sed -i "s/mysql_database=/mysql_database=darkflame/g" ~/DarkflameServer/build/masterconfig.ini
sed -i "s/mysql_database=/mysql_database=darkflame/g" ~/DarkflameServer/build/worldconfig.ini
sed -i "s/mysql_username=/mysql_username=darkflame/g" ~/DarkflameServer/build/authconfig.ini
sed -i "s/mysql_username=/mysql_username=darkflame/g" ~/DarkflameServer/build/chatconfig.ini
sed -i "s/mysql_username=/mysql_username=darkflame/g" ~/DarkflameServer/build/masterconfig.ini
sed -i "s/mysql_username=/mysql_username=darkflame/g" ~/DarkflameServer/build/worldconfig.ini
2021-12-08 14:20:11 +00:00
sed -i "s/external_ip=localhost/external_ip=$EXTERNAL_IP/g" ~/DarkflameServer/build/authconfig.ini
sed -i "s/external_ip=localhost/external_ip=$EXTERNAL_IP/g" ~/DarkflameServer/build/chatconfig.ini
sed -i "s/external_ip=localhost/external_ip=$EXTERNAL_IP/g" ~/DarkflameServer/build/masterconfig.ini
2021-12-07 19:48:37 +00:00
```
Now we need to fill in your password. Make sure to replace `PASSWORD` with the proper value on these lines.
```bash
sed -i "s/mysql_password=/mysql_password=PASSWORD/g" ~/DarkflameServer/build/authconfig.ini
sed -i "s/mysql_password=/mysql_password=PASSWORD/g" ~/DarkflameServer/build/chatconfig.ini
sed -i "s/mysql_password=/mysql_password=PASSWORD/g" ~/DarkflameServer/build/masterconfig.ini
sed -i "s/mysql_password=/mysql_password=PASSWORD/g" ~/DarkflameServer/build/worldconfig.ini
sed -i "s|DB_URL = 'mysql+pymysql://<mysql-user>:<mysql-password>@<mysql-host>/<mysql-database>'|DB_URL = 'mysql+pymysql://darkflame:PASSWORD@localhost/darkflame'|g" ~/AccountManager/credentials.py
2021-12-07 19:23:40 +00:00
```
## Run the Server
Now we are finally going to run the server.
2021-12-07 19:06:21 +00:00
2021-12-07 19:23:40 +00:00
First run the following command; you will be prompted to create a username and password. Make this secure, as it will be the credentials for a Mythran account with full server operator access.
```
cd ~/DarkflameServer/build/
./MasterServer -a
2021-12-07 19:06:21 +00:00
```
2021-12-07 19:23:40 +00:00
Now you can start the server and account manager. Run these commands:
```
2021-12-07 19:48:37 +00:00
screen -dmS darkflame-server bash -c "cd ~/DarkflameServer/build/; ./MasterServer"
2021-12-07 19:23:40 +00:00
screen -dmS darkflame-accounts bash -c "python3 ~/AccountManager/app.py"
```
2021-12-07 19:06:21 +00:00
2021-12-07 19:23:40 +00:00
These will start the server and account manager in the background.
You can view the logs of the server by running `screen -r darkflame-server` and of the account manager by running `screen -r darkflame-accounts`.
2021-12-08 19:12:00 +00:00
You can stop viewing the logs by pressing `CTRL+A` and then `D`. You can also close the window and the server will continue running in the background.
2021-12-07 16:02:02 +00:00
2021-12-08 17:53:05 +00:00
That's it! You're done! Your server is online. You can find your IP on the Cloud instances page.
![](../images/google-cloud-ip.png)
2021-12-07 19:48:37 +00:00
## Moderation
Now that you are running a server, you should follow these steps:
2021-12-28 23:11:04 +00:00
1. Go to your web browser, and navigate to `http://<IP-ADDRESS>:5000/dashboard`, where `<IP-ADDRESS>` is the IP address of your server.
2. You will see a login. Enter the Mythran credentials you entered earlier.
3. You will be redirected to the dashboard. Enter a number of keys to generate, and click `Generate`.
4. You will see a list of CD keys. Give one of these keys to each player you want to join.
2021-12-07 19:48:37 +00:00
To allow a player to join, give them one of these CD keys, and tell them to go to `http://<IP-ADDRESS>:5000/activate` and create an account.
Once they have an account, the player should be able to change their client's `boot.cfg` to use your IP address, and login with the account they just made, and play the game.
<!-- At the top of the dashboard, you will also see a `Name Approval` button. Click it to switch to a new tab where you can approve custom minifigure usernames. -->
2021-12-07 16:02:02 +00:00
## Updating Darkflame Universe
2021-12-28 23:11:04 +00:00
In the future, updates will be released to DarkflameServer that will include bug fixes and potentially even new features. To update the server, you can run the following commands, in order:
2021-12-07 19:06:21 +00:00
```
# Shut down the server.
2021-12-07 19:48:37 +00:00
screen -S darkflame-server kill
2021-12-07 19:06:21 +00:00
# Update the server.
cd ~/DarkflameServer
git pull
./build.sh
# Restart the server.
2021-12-07 19:48:37 +00:00
screen -dmS darkflame-server bash -c "cd ~/DarkflameServer/build/; ./MasterServer"
2021-12-07 19:06:21 +00:00
```
2021-12-07 16:02:02 +00:00
2021-12-12 21:18:47 +00:00
## Backup Your Database
Backing up your database is a good idea, as it will allow you to recover your data if you lose your server.
1. Run the following command on your server, then enter your database password.
2021-12-28 23:11:04 +00:00
```bash
mysqldump -u darkflame darkflame --result-file=$HOME/dump.sql -p
```
2021-12-12 21:18:47 +00:00
2. The complete contents of your server's database will be output to the file `~/dump.sql`. This is including, but not limited to:
2021-12-28 23:11:04 +00:00
* Accounts, including usernames and (encrypted) passwords.
* Characters, including their inventory, stats, mission progress, and other data.
* Activity logs, including login and logout times for each player.
* Minigame leaderboards, including scores and times for each player.
2021-12-12 21:18:47 +00:00
3. To get the dump file off the server, run the following command. This will place the file on the Google Cloud Storage instance you created to upload the server-resources file.
2021-12-28 23:11:04 +00:00
```bash
gsutil cp dump.sql gs://BUCKETNAME/dump.sql
```
2021-12-12 21:18:47 +00:00
If the last step fails, see the [Google Cloud Setup Troubleshooting](google-cloud-troubleshooting.md) page.
2021-12-07 19:06:21 +00:00
## Troubleshooting
2021-12-07 16:02:02 +00:00
2021-12-07 19:06:21 +00:00
If you have an issue with any of the above steps, visit the link below to review common questions and troubleshooting tips.
2021-12-07 16:02:02 +00:00
2021-12-07 19:48:37 +00:00
[Google Cloud Setup Troubleshooting](google-cloud-troubleshooting.md)
2021-12-08 14:20:11 +00:00
You can also get support on the `#questions` channel of the LUCH Discord server.