Quickstart: Create a Fleet Autoscaler
Prerequisites
It is assumed that you have followed the instructions to Create a Game Server Fleet and you have a running fleet of game servers.
Objectives
- Create a Fleet Autoscaler in Kubernetes using Code Blind custom resource.
- Watch the Fleet scale up when allocating GameServers
- Watch the Fleet scale down when shutting down allocated GameServers
- Edit the autoscaler specification to apply live changes
1. Create a Fleet Autoscaler
Let’s create a Fleet Autoscaler using the following command :
kubectl apply -f https://raw.githubusercontent.com/googleforgames/agones/release-1.38.0/examples/simple-game-server/fleetautoscaler.yaml
You should see a successful output similar to this :
fleetautoscaler.autoscaling.agones.dev/simple-game-server-autoscaler created
This has created a FleetAutoscaler record inside Kubernetes.
2. See the autoscaler status.
kubectl describe fleetautoscaler simple-game-server-autoscaler
It should look something like this:
Name: simple-game-server-autoscaler
Namespace: default
Labels: <none>
Annotations: kubectl.kubernetes.io/last-applied-configuration={"apiVersion":"au
toscaling.agones.dev/v1","kind":"FleetAutoscaler","metadata":{"annotations":{},
"name":"simple-game-server-autoscaler","namespace":"default"},...
API Version: autoscaling.agones.dev/v1
Kind: FleetAutoscaler
Metadata:
Cluster Name:
Creation Timestamp: 2018-10-02T15:19:58Z
Generation: 1
Owner References:
API Version: autoscaling.agones.dev/v1
Block Owner Deletion: true
Controller: true
Kind: Fleet
Name: simple-game-server
UID: 9960762e-c656-11e8-933e-fa163e07a1d4
Resource Version: 6123197
Self Link: /apis/autoscaling.agones.dev/v1/namespaces/default/fleetautoscalers/simple-game-server-autoscaler
UID: 9fd0efa1-c656-11e8-933e-fa163e07a1d4
Spec:
Fleet Name: simple-game-server
Policy:
Buffer:
Buffer Size: 2
Max Replicas: 10
Min Replicas: 2
Type: Buffer
Status:
Able To Scale: true
Current Replicas: 2
Desired Replicas: 2
Last Scale Time: <nil>
Scaling Limited: false
Events: <none>
You can see the status (able to scale, not limited), the last time the fleet was scaled (nil for never) and the current and desired fleet size.
The autoscaler works by changing the desired size, and the fleet creates/deletes game server instances to achieve that number. The convergence is achieved in time, which is usually measured in seconds.
3. Allocate a Game Server from the Fleet
If you’re interested in more details for game server allocation, you should consult the Create a Game Server Fleet page. In here we are only interested in triggering allocations to see the autoscaler in action.
kubectl create -f https://raw.githubusercontent.com/googleforgames/agones/release-1.38.0/examples/simple-game-server/gameserverallocation.yaml -o yaml
You should get in return the allocated game server details, which should end with something like:
status:
address: 34.94.118.237
gameServerName: simple-game-server-v6jwb-6bzkz
nodeName: gke-test-cluster-default-f11755a7-5km3
ports:
- name: default
port: 7832
state: Allocated
Note the address and port, you might need them later to connect to the server.
4. See the autoscaler in action
Now let’s wait a few seconds to allow the autoscaler to detect the change in the fleet and check again its status
kubectl describe fleetautoscaler simple-game-server-autoscaler
The last part should look something like this:
Spec:
Fleet Name: simple-game-server
Policy:
Buffer:
Buffer Size: 2
Max Replicas: 10
Min Replicas: 2
Type: Buffer
Status:
Able To Scale: true
Current Replicas: 3
Desired Replicas: 3
Last Scale Time: 2018-10-02T16:00:02Z
Scaling Limited: false
Events:
Type Reason Age From Message
---- ------ ---- ---- -------
Normal AutoScalingFleet 2m fleetautoscaler-controller Scaling fleet simple-game-server from 2 to 3
You can see that the fleet size has increased, the autoscaler having compensated for the allocated instance. Last Scale Time has been updated, and a scaling event has been logged.
Double-check the actual number of game server instances and status by running
kubectl get gs
This will get you a list of all the current GameServers
and their Status > State
.
NAME STATE ADDRESS PORT NODE AGE
simple-game-server-mzhrl-hz8wk Allocated 10.30.64.99 7131 minikube 5m
simple-game-server-mzhrl-k6jg5 Ready 10.30.64.100 7243 minikube 5m
simple-game-server-mzhrl-n2sk2 Ready 10.30.64.168 7658 minikube 5m
5. Shut the allocated instance down
Since we’ve only got one allocation, we’ll just grab the details of the IP and port of the
only allocated GameServer
:
kubectl get gameservers | grep Allocated | awk '{print $3":"$4 }'
This should output your Game Server IP address and port. (eg 10.130.65.208:7936
)
You can now communicate with the GameServer
:
nc -u {IP} {PORT}
Hello World !
ACK: Hello World !
EXIT
You can finally type EXIT
which tells the SDK to run the Shutdown command, and therefore shuts down the GameServer
.
6. See the fleet scaling down
Now let’s wait a few seconds to allow the autoscaler to detect the change in the fleet and check again its status
kubectl describe fleetautoscaler simple-game-server-autoscaler
It should look something like this:
Spec:
Fleet Name: simple-game-server
Policy:
Buffer:
Buffer Size: 2
Max Replicas: 10
Min Replicas: 2
Type: Buffer
Status:
Able To Scale: true
Current Replicas: 3
Desired Replicas: 2
Last Scale Time: 2018-10-02T16:09:02Z
Scaling Limited: false
Events:
Type Reason Age From Message
---- ------ ---- ---- -------
Normal AutoScalingFleet 9m fleetautoscaler-controller Scaling fleet simple-game-server from 2 to 3
Normal AutoScalingFleet 45s fleetautoscaler-controller Scaling fleet simple-game-server from 3 to 2
You can see that the fleet size has decreased, the autoscaler adjusting to game server instance being de-allocated, the Last Scale Time and the events have been updated. Note that simple-game-server game server instance you just closed earlier might stay a bit in ‘Unhealthy’ state (and its pod in ‘Terminating’ until it gets removed.
Double-check the actual number of game server instances and status by running
kubectl get gs
This will get you a list of all the current GameServers
and their Status > State
.
NAME STATE ADDRESS PORT NODE AGE
simple-game-server-mzhrl-k6jg5 Ready 10.30.64.100 7243 minikube 5m
simple-game-server-mzhrl-t7944 Ready 10.30.64.168 7561 minikube 5m
7. Change autoscaling parameters
We can also change the configuration of the FleetAutoscaler
of the running Fleet
, and have the changes
applied live, without interruptions of service.
Run kubectl edit fleetautoscaler simple-game-server-autoscaler
and set the bufferSize
field to 5
.
Let’s look at the list of game servers again. Run watch kubectl get gs
until you can see that are 5 ready server instances:
NAME STATE ADDRESS PORT NODE AGE
simple-game-server-mzhrl-7jpkp Ready 10.30.64.100 7019 minikube 5m
simple-game-server-mzhrl-czt8v Ready 10.30.64.168 7556 minikube 5m
simple-game-server-mzhrl-k6jg5 Ready 10.30.64.100 7243 minikube 5m
simple-game-server-mzhrl-nb8h2 Ready 10.30.64.168 7357 minikube 5m
simple-game-server-mzhrl-qspb6 Ready 10.30.64.99 7859 minikube 5m
simple-game-server-mzhrl-zg9rq Ready 10.30.64.99 7745 minikube 5m
Note
If you want to update a Fleet
which has RollingUpdate
replacement strategy and is controlled by a FleetAutoscaler
:
- With
kubectl apply
: you should omitreplicas
parameter in aFleet
Spec before re-applying theFleet
configuration. - With
kubectl edit
: you should not change thereplicas
parameter in theFleet
Spec when updating other field parameters.
If you follow the rules above, then the maxSurge
and maxUnavailable
parameters will be used as the RollingUpdate strategy updates your Fleet.
Otherwise the Fleet would be scaled according to Fleet replicas
parameter first and only after a certain amount of time it would be rescaled to fit FleetAutoscaler
BufferSize
parameter.
You could also check the behaviour of the Fleet with Fleetautoscaler on a test Fleet
to preview what would occur in your production environment.
Next Steps
Read the advanced Scheduling and Autoscaling guide, for more details on autoscaling.
If you want to use your own GameServer container make sure you have properly integrated the Code Blind SDK.
Feedback
Was this page helpful?
Glad to hear it! Please tell us how we can improve.
Sorry to hear that. Please tell us how we can improve.
Last modified February 28, 2024: initial publish (7818be8)