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

314 lines
16 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
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.
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-07 16:02:02 +00:00
Google makes it very easy to set up a server instance in the cloud. 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
![](../images/google-cloud-trial.png)
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.
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
![](../images/google-cloud-compute.png)
![](../images/google-cloud-create.png)
2021-12-07 16:02:02 +00:00
* Name it if you like. The default regon and zone are fine.
* 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.
* Scroll to the bottom and click Create.
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.
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-07 19:06:21 +00:00
Wait until the build process is complete. This will take a while. In the meantime, you can move on to the next steps. 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.
* Click 'Google Cloud Platform' at the top to move to the Google Cloud homepage.
* Click 'Cloud Storage' on the left.
* Click 'Create Bucket' at the top.
* Pick a name that is easy to remember and easy to type. It needs to be GLOBALLY unique apparently.
* Stick with the defaults for region, storage class, access control, and protection.
Now the bucket is created, you will see the details page for that bucket and a list of objects (i.e. files) in it.
Click 'Upload File', select your `server-resources` ZIP, and click upload. This process should take just a second.
## Configuring the Server's Firewall
Before we get started building the server, we need to configure the server's firewall. Follow these steps:
* Click 'Compute Engine' to move back to the Compute Engine homepage.
* Under Related Actions, click 'Set up Firewall rules'
* Click 'Create Firewall Rule' at the top.
We're going to create a set of Firewall rules that allow access to the server.
* Set the name to `darkflame-server`.
* Add `darkflame-server` to the list of target tags. We're going to assign this tag to our server later.
* Set the Source IPv4 ranges to `0.0.0.0/0`. This represents all IP addresses, meaning this rule will allow any incoming IP.
2021-12-08 19:06:32 +00:00
* 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.
* 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.
* Move back to the home of your Google Cloud project (which currently contains your cloud instance).
* Click 'Compute Engine'. You should see your `darkflame-instance` listed. Click on it.
* Click 'Edit' at the top.
* Scroll down to 'Network tags' and enter `darkflame-server`.
* 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
```
2021-12-07 19:48:37 +00:00
Make sure to go back to the Cloud Storage page and delete the bucket you created, since you don't need it anymore.
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.
```
~/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`.
You can stop viewing the logs by pressing `CTRL+A` and then `D`.
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:
* Go to your web browser, and navigate to `http://<IP-ADDRESS>:5000/dashboard`, where `<IP-ADDRESS>` is the IP address of your server.
* You will see a login. Enter the Mythran credentials you entered earlier.
* You will be redirected to the dashboard. Enter a number of keys to generate, and click `Generate`.
* You will see a list of CD keys. Give one of these keys to each player you want to join.
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-07 19:06:21 +00:00
In the future, updates will be release to DarkflameServer that will include bug fixes and potentially even new features. To update the server, you can run the following commands, in order:
```
# 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-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.