GameLiftAgent is a Java application that is used to launch game server processes on Amazon GameLift fleets.
This application registers a compute resource for an existing Amazon GameLift fleet using the RegisterCompute API. The application also calls the GetComputeAuthToken API to fetch an authorization token for the compute resource, using it to make a web socket connection to the Amazon GameLift service.
GameLiftAgent was built with Java 17 and will require (at least) this version to compile. Check the java version.
java -version
If the java version is not showing Java 17, then you will have to install Java 17.
The GameLiftAgent requires a minimum version of 3.2.5. for Maven to run. Check your maven version with the command:
mvn -version
If the Maven version is less than version 3.2.5, you will have to update the Maven version to be at least version 3.2.5.
- Navigate to the GameLiftAgent package root (directory including
pom.xml
file) - Execute the following to download dependencies, compile the project and generate a standalone jar using Maven:
mvn clean compile assembly:single
If this successfully compiles, then GameLiftAgent-1.0.jar will become available in the following path:
ls ./target/GameLiftAgent-1.0.jar
Make sure you have an active Anywhere fleet and an active compute for the fleet before running the JAR. The LaunchPath for the Server Process should be the in the same location as a game build executable or Realtime Servers script. Use the following commands to perform the setup:
- Copy the GameLiftAgent-1.0.jar to the directory (Example: /local/game or C:\game).
cp ./target/GameLiftAgent-1.0.jar /local/game
Copy-Item -Path .\target\GameLiftAgent-1.0.jar -Destination C:\game\
- Then move the game executable to the same directory (/local/game).
cp [GAME_EXECUTABLE] /local/game
Copy-Item -Path [GAME_EXECUTABLE] -Destination C:\game\
- Grant read and execute permissions to run the JAR and the game executable.
sudo chmod 755 /local/game/GameLiftAgent-1.0.jar
sudo chmod 755 /local/game/[GAME_EXECUTABLE]
Use the following instructions to run the application:
- The standalone jar will be located in
./target/
and can be launched with a command such as the following (There are some example launch commands listed at the end):
java -jar ./target/GameLiftAgent-1.0.jar <Command Line Options>
certificate-path
/cp
- Optional - path to TLS certificate on compute resource. The path and certificate are not validated by Amazon GameLift.
compute-name
/c
- Required - A descriptive label that is associated with the compute resource registered to your fleet.
- May also be provided using environment variable
GAMELIFT_COMPUTE_NAME
instead of specifying as a command line option. - For managed Amazon GameLift, this is set by Amazon GameLift to environment variable
GAMELIFT_COMPUTE_NAME
. No command line option required.
dns-name
/dns
- Optional - The DNS name of the compute resource. (this option is not yet available)
- This option is used with Amazon GameLift Anywhere fleets only. Either
dns-name
orip-address
is required.
fleet-id
/f
- Required - A unique identifier for the GameLift fleet on which the compute resource will be registered.
- May also be provided via environment variable
GAMELIFT_FLEET_ID
instead of specifying as a command line option. - For managed Amazon GameLift, this is set by Amazon GameLift to environment variable
GAMELIFT_FLEET_ID
. No command line option required.
gamelift-endpoint-override
/gleo
- Optional - For internal testing purposes. Using this option will likely result in errors.
gamelift-credentials
/glc
- Optional - The source of credentials, which are used by the Amazon GameLift client make the
RegisterCompute
andGetComputeAuthToken
API calls. - Options are as follows (default is
instance-profile
):instance-profile
- Uses credentials from the IAM profile associated with the Amazon GameLift EC2 fleet instance.container
- Uses credentials from an ECS container IAM profile.environment-variable
- Uses temporary IAM role credentials exported to environment variables.
- Optional - The source of credentials, which are used by the Amazon GameLift client make the
game-session-log-bucket
/gslb
- Optional - The name of an Amazon S3 bucket in the AWS account to upload game session logs.
- Using this option requires Amazon GameLift fleets to specify an
InstanceRoleArn
. The IAM role must includes3:PutObject
permission. - Using this option results in
InstanceRoleArn
credentials being fetched and cached via the web socketGetFleetRoleCredentials
route.
ip-address
/ip
- Optional - The IP address of the compute resource.
- This option is used with Amazon GameLift Anywhere fleets only. Either
dns-name
orip-address
is required.
location
/loc
- Optional - The location where the compute resource resides.
- Required for Amazon GameLift Anywhere fleets. Must match the custom location registered on the fleet.
- For Amazon GameLift EC2 fleets, this option is set by Amazon GameLift to environment variable
GAMELIFT_REGION
. No command line option required.
gamelift-agent-log-bucket
/galb
- Optional - The name of an Amazon S3 bucket in the AWS account to upload logs for GameLiftAgent.
- Using this option requires Amazon GameLift fleets to specify an
InstanceRoleArn
. The IAM role must includes3:PutObject
permission. - Using this option results in
InstanceRoleArn
credentials being fetched and cached via the web socketGetFleetRoleCredentials
route.
gamelift-agent-log-path
/galp
- Optional - The file path where GameLiftAgent logs are stored locally. During launch, parent directories are created as required for this path.
- Defaults are
/local/gameliftagent/logs
for Linux andC:\\GameLiftAgent\\Logs\\
for Windows.
log-credentials
/lc
- Optional - The credentials used to upload agent or session logs.
- Options are as follows (default is
fleet-role
)fleet-role
- Uses fleet role credentials.default-provider-chain
- Uses AWS default credential provider chain.
region
/r
- Required - The AWS region used when creating GameLift fleets.
- May also be provided using environment variable
GAMELIFT_REGION
instead of specifying as a command line option. - For managed Amazon GameLift, this is set by Amazon GameLift to environment variable
GAMELIFT_REGION
. No command line option required.
runtime-configuration
/rc
- Optional - A static RuntimeConfiguration provided as inline JSON.
- For managed Amazon GameLift Fleets, RuntimeConfiguration should set when creating or updating an Amazon GameLift fleet. No command line option required.
java -jar /<path>/<to>/GameLiftAgent-1.0.jar \
-c '<compute-name>' \
-f '<fleet id>' \
-loc 'custom-<custom location name>' \
-r '<region name>' \
-glc environment-variable \
-gslb 'gameliftgamesessionlogS3bucketname' \
-galb 'gameliftagentlogS3bucketname' \
-galp '/local/gameliftagent/logs/'
java -jar C:\\path\\to\\GameLiftAgent-1.0.jar `
-c '<compute-name>' \
-f '<fleet id>' \
-loc 'custom-<custom location name>' \
-r '<region name>' \
-glc environment-variable \
-gslb 'gameliftgamesessionlogS3bucketname' `
-galb 'gameliftagentlogS3bucketname' `
-galp 'C:\\GameLiftAgent\\logs\\'
export GAMELIFT_FLEET_ID=fleet-<id>
export GAMELIFT_COMPUTE_NAME=gamelift-compute-name
export GAMELIFT_REGION=us-west-2
export GAMELIFT_LOCATION=custom-<custom location name>
set GAMELIFT_FLEET_ID=fleet-<id>
set GAMELIFT_COMPUTE_NAME=gamelift-compute-name
set GAMELIFT_REGION=us-west-2
set GAMELIFT_LOCATION=custom-<custom location name>
See CONTRIBUTING for more information.
This project is licensed under the Apache-2.0 License.