- recommend to read first
- this post covers
- how to setup cross compile environment
- how to build linux server
- how to use client and server in cross platform
- environment
- Windows / 10
- Visual Studio IDE / 2017 Community
- Unreal Engine / 4.21 Built From Source Code
overview
- if you want to seperate the game into client and server
- mostly, the clients would be executed on windows
- as the server is up to you, you can select more efficient option
- in aws, linux server instead of windows to save cost
- so it is needed to build linux server, but you can use cross compilation
- this makes you can build linux server on windows
- in this post, I suppose you have already an unreal engine built from source code and test project
- especially, I used 4.21 version
setup
- download the proper toolchain from this document
- in my case,
clang-6.0.1-based
toolchain is needed
- in my case,
- execute the toolchain installer
- you do not have to do extra works when your engine version is equal to or over 4.14
- if not, reference the document mentioned for the details
data:image/s3,"s3://crabby-images/72249/72249ec1a2f6892e39d74244590c34a513edc663" alt=""
- in the test project, edit the
DefaultEngine.ini
of[ProjectRoot]/Config/DefaultEngine.ini
- add the code below
- the code will add configurations for linux version build
1 | [/Script/LinuxTargetPlatform.LinuxTargetSettings] |
data:image/s3,"s3://crabby-images/b6dfe/b6dfe8ffa66ed11fcda740acaa830f9d4e750183" alt=""
- right click
uproject
and selectGenerate Visual Studio project files
- open
sln
and build the test project withDevelopment Editor & Win64
- open
build
data:image/s3,"s3://crabby-images/f0a1a/f0a1a58ab54754652ad4d36fb6885406b46183fd" alt=""
- double click
uproject
and you would see the test project on unreal editor
data:image/s3,"s3://crabby-images/e25dd/e25dd2ce0c6058f1d8694c76b3f10d547ce477da" alt=""
- select
Development
inFile/Package Project/Build Configuration
data:image/s3,"s3://crabby-images/8a31e/8a31e6f7e18f45588593957e78576704d4762cfc" alt=""
- select
Linux
inFile/Package Project
- choose an arbitrary directory for saving the package
- in my case, I created
Packages
folder in project directory and use it
data:image/s3,"s3://crabby-images/6c17e/6c17ed06037b83b3cff05a0c2c7ddd393e772ef1" alt=""
- after packaging, you can see the directory like this
data:image/s3,"s3://crabby-images/55780/557800b132bd20fc5532563e2514449a95883fb9" alt=""
- open
sln
and build the test project withDevelopment Server & Linux
data:image/s3,"s3://crabby-images/e7151/e7151d7de6af58042ac441312e7fafdaa4b15dca" alt=""
- you can see the
[ProjectName]Server
build, which will be executed on linux
data:image/s3,"s3://crabby-images/19dc7/19dc7804f28a2053cff3236edf464ba7130c4b45" alt=""
- copy the
[ProjectName]Server
into package binary folder- now you can execute
[ProjectName]Server
on linux
- now you can execute
usage
- in this post, I will show you an example with wsl
- I recommend to make shared folder for sharing files
- if you do not know about it, read this post
data:image/s3,"s3://crabby-images/8ebf3/8ebf33ca9e5bfaf2cfda53408f5947bd18f8e680" alt=""
- I used a shared folder called
LinuxShare
for sharing the package files
data:image/s3,"s3://crabby-images/a0a8a/a0a8a7c888bb10db9476a1e2c83b6c81529d6870" alt=""
- there are build files in package binary folder
[ProjectName]
is build file fromGame
build target, which cannot be executed for absense of graphics api[ProjectName]Server
is build file fromServer
build target, which is copied by you
data:image/s3,"s3://crabby-images/2d95a/2d95aff4c722fe6b43f21a34ee8eb892f136fadd" alt=""
data:image/s3,"s3://crabby-images/64d53/64d53d4b8c88b19cea513024165f53b5f2d7ee4e" alt=""
- execute server build with option
127.0.0.1 -log
on wsl(linux)
data:image/s3,"s3://crabby-images/2da44/2da4409a7a2fcdfca4ec78fd39d1d3559d92a42a" alt=""
- execute client build twice with option
127.0.0.1 -log -windowed resx=720 resy=480
on windows- you can see the same result that we saw in previous post