All notable changes to this project will be documented in this file.
The format is based on Keep a Changelog and this project adheres to Semantic Versioning.
- Added: support custom docker machine distribution (#216) …
- Bugfix: disabled cache (#212)
- Bugfix: failing curl (#217) …
- Change: Drop supported to manage ec2 keys (#192)
- Add: Allow traffic from a list of security group IDs (#207) by @fliphess
- Bugfix: Fix missing policy for existing cache (#208, #206)
- Add: variables
cache_lifecycle_prefix
andcache_lifecycle_clear
to increase flexibility of the cache usages. - Add: Parametrize the AWS ARN for policies (#203) @ericamador
- Add: Allow ping to runners and agent from cidr range (#201 @fliphess
- Change: Refactor templatefile (#199)
- Change: Types of
runners_volumes_tmpfs
, andrunners_services_volumes_tmpfs
are changed, check README or default example for details.
- Add: Option for permissions boundary (#195) @mhulscher
- Bugfix: Fix cancel spot instance script from destroy provisioners are deprecate
- Change: Update default GitLab runner version to 12.8.0
- Bugfix: #187 - fix double comma in tag list for docker machine
- Change: Update terraform-docs to support 0.8.x #185
- Change: Support Amazon Linux #184 by @chludwig-haufe
- Change: Bump gitlab runner version to 12.7.1 from 12.6.0 #183 @loustler
- Fix: Fix error create bucket false #182 @katiatalh w
- Change: Add inputs for EBS-optimized #181 @chrizkim
- Change: Added agent- and runner-only tags #179 @Glen-Moonpig
- Change: Improving Spot Cancelation script. #174 @pshuman-heb
- Change: Forcing updates of Instances on Config change. #173 @pshuman-heb
- Change: default version of the runner to 12.6.0
- Fix: External references from destroy provisioners are deprecated (examples)
- Fix: typos cache bucket (#172) @@thorec
- Fix: missing double quotes (#171) ggrangia
- Change: default for gitlab_url to https://gitlab.com (#170) @riccardomc
- Change: Encrypt runner root device by default (#168) …
- Added: allow eip for runner (#166)
- Make use of on-demand instances in docker-machine #158 @skorfmann
- Allow log retention configuration #157 @geota
- Add option to encrypt logs via KMS #156 @npalm @hendrixroa
- Upgraded the runners (docker-machine) to ubuntu 18.04. You can stay on 16.04 by setting:
runner_ami_filter = ["ubuntu/images/hvm-ssd/ubuntu-xenial-16.04-amd64-server-*"]
- Upgraded GitLab runner to 12.4.1
- Upgraded terraform version, vpc version and provider versions for the examples
- fix type create cache bucket #151 @geota
- Delete unused create_runners_iam_instance_profile #147 @alexharv07
- Remove docker_machine_user variable #146 @alexharv074
- Fixing Docker Machine certificate Generation #143 #145 @npalm @roock
- Add option to limit docker machine ssh ingress access to only the runner #142 @bishtawi
- Add option for tmpfs #104 #141 #137
- Lock down docker port access to only the runner security group #140 @bishtawi
- Add variable docker_machine_docker_cidr_blocks allowing docker ingress restriction #139 @bishtawi
- Adding outputs for agent and runner security groups #138 @hatemosphere
- Add access_level option to registration call in runner template #134 @willychenchen
- Bump gitlab-runner default version to 12.3.0 #135 @loustler
- Set docker machine version by default to 0.16.2 #131 @npalm
- Add SSM session manager support #121 #126 @npalm
- Move to github actions #130 @npalm
- Enable s3 encryption #129 @hendrixroa
- Bump gitlab-runner to 12.2.0 #128 @mpsq
- Added
- Allow for configurable root block size #123 @bsuv
- Enable ASG scheduling #119 @bsuv
- Added
- Add MaxBuilds variable to gitlab runner config #122 @gertjanmaas
- Added
- Option to disable account id is used in bucket name #113 @Glen-Moonpig
- Cancel sport instances during destroy for example default and public.
- Changed:
- Fixed typos #118 @mpsq
- Changed:
- Runner tags namespaced with ":" are split wrong in userdata. #111 @ony-harverson-moonpig
Module is available as Terraform 0.12 module, pin to version 4.x. Please submit pull-requests to the develop
branch.
Migration from 0.11 to 0.12 is tested for the runner-default
example. To migrate the runner, execute the following steps.
- Update to Terraform 0.12
- Migrate your Terraform code via Terraform
terraform 0.12upgrade
. - Update the module from 3.10.0 to 4.0.0, next run
terraform init
- Run
terraform apply
. This should trigger only a re-creation of the the auto launch configuration and a minor change in the auto-scaling group.
Module is available as Terraform 0.11 module, pin module to version 3.x. Please submit pull-requests to the terraform011
branch.
- Chnaged
- THe user data script for the EC2 runner agent instance is not logging anymore on trace level. To enable bash xtrace set
enable_runner_user_data_trace_log
totrue
. #49 - Generate links for Readme during release, #63
- THe user data script for the EC2 runner agent instance is not logging anymore on trace level. To enable bash xtrace set
- Changed
- Update default runner version to 12.1.0 (#106)
- Added
- Add runners_volumes variable (#105) @kevinrambaud
- Added
- Variable
docker_machine_ssh_cidr_blocks
to set CIDR for ingress on docker machine SSH rules. @kevinrambaud #101 - Variable
docker_machine_role_json
allowing role policy customization #kevinrambaud #100
- Variable
- Changed
- Creation of multiple instances of the runner is now supported. Cache is therefore moved to an internal module. Pleas see the example
runner-public
for a concrete sample. The change should have no effect if you apply the state migration scriptmigragations/migration-state-3.7.x.sh
. - Examples are more generic by removing the time zone and AZ zone to variables. @@theBenForce
- Creation of multiple instances of the runner is now supported. Cache is therefore moved to an internal module. Pleas see the example
- Changed
- Add option to specify pull policy for docker images by the runner. @roock
- Docker machine AMI image will be by default latest ubuntu 16.06, can be overwritten via variables @roock
- Improved CI docs generation script @roock
- Changed
- Documentation #85: Misleading Variable-Description @solutionDrive-Alt
- Bugfix #70: docker-machine fails starting runners when
amazonec2-request-spot-instance=false
@philippefuentes - Bugfix #72: Detect and retry when docker machine installation fails @eliasdorneles
- Changed: Default version of GitLab runner set to 11.11.2
- Changed
- Creation of multiple instances of the runner is now supported. Cache is therefore moved to an internal module. Pleas see the example
runner-public
for a concrete sample. The change should have no effect if you apply the state migration scriptmigragations/migration-state-3.7.x.sh
. - Examples are more generic by removing the time zone and AZ zone to variables. @@theBenForce
- Creation of multiple instances of the runner is now supported. Cache is therefore moved to an internal module. Pleas see the example
- Changed
- Add option to specify pull policy for docker images by the runner. @roock
- Docker machine AMI image will be by default latest ubuntu 16.06, can be overwritten via variables @roock
- Improved CI docs generation script @roock
- Changed
- Documentation #85: Misleading Variable-Description @solutionDrive-Alt
- Bugfix #70: docker-machine fails starting runners when
amazonec2-request-spot-instance=false
@philippefuentes - Bugfix #72: Detect and retry when docker machine installation fails @eliasdorneles
- Changed: Default version of GitLab runner set to 11.11.2
3.4.0 - 2019-06-06
- Changed:
- Update default runner type, GitLab runner version, and versions in examples.
- Buffix #75 runner is not reachable when runners_use_private_address = false
- Buffix - Missing typ - @Orkin
- Bugfix #72 - Detect and retry when docker machine download fails eliasdorneles
- Bugfix #68 - add count to prevent resource creation failing @philippefuentes
- Bugfix #70 - update policy to allow runners to start when not using spot instances @philippefuentes
3.3.0 - 2019-05-20
- Changed: Default version of GitLab runner set to 11.10.1
- Added: Option to enable / disable SSH login
- Added: Option to use spot instances for runner instance
- Changed: Default instance type is now m5.large
- Added: Custom names for instance and security groups
3.2.0 - 2019-03-09
- Added: Option to set shm_size for the runners, default remains 0.
3.1.0 - 2019-03-09
- Added: Option to set environment variables for the runners, see the variable
runners_environment_vars
. An example added to thepublic-runner
example.
3.0.0 - 2019-03-29
- Changed: The runner will register itself based on the registration token. No need to preregister the runner before running terraform. See the README for configuration and migration. #33
2.3.0 - 2019-03-27
- Bugfix: Added a profile for the docker machine runners. #41
- Changed: Changed the name of runner instance, added
docker-machine
to the name.
2.2.1 - 2019-03-19
- Bugfix: Add tags to spot instances #39
- Changed: Updated terraform providers in examples and default terraform version
2.2.0 - 2019-03-08
- Changed: Upgrade default runner agent to 11.8.0 and docker machine to 0.16.1
- Bugfix: Correct example for docker_machine_options #36 (@declension)
- Added: AWS Zone variable #35 (@declension)
2.1.0 - 2019-02-28
- Bugfix: Shared cache is not working #33
- Bugfix: Missing documentation makes setup fail #31
- Added: Docker executor to run a single node runner, thanks to @msvechla
2.0.0 - 2019-01-13
- Changed: Replaced cache user by a instance profile to access the cache from the build
- Changed: Update gitlab toml cache section, removed deprecated usages of s3
- Changed: The variable
amazon_optimized_amis
is removed an replaced by a filter to select the AMI. To use the default of the latest AMI set the filterami_filter
toamzn-ami-hvm-2018.03.0.20180622-x86_64-ebs
. - Added: Option to set docker machine options via
docker_machine_optionns
. - Added: Several output variables.
1.8.0 - 2018-12-30
- Changed: Update default docker-machine version to 0.16.0
- Changed: Update default gitlab runner to 11.6.0
- Added: Configuration parameters for post_build_script, pre_clone_script, request_concurrency and output_limit. #22
- Added: Configurable docker image for runner #27
- Added: Add pre/post install user-data snippets for runners #26
1.7.0 - 2018-11-21
- Added option to configure instance-profile for runner pre build script. Thanks to @msvechla
1.6.0 - 2018-10-06
- Updated the default GitLab Runner to 11.3.1
1.5.0 - 2018-08-10
- Updated default AMI map to Amazon Linux AMI 2018.03 was released on 2018-06-28
1.4.0 - 2018-08-09
- Added an option to allow gitlab runner instance to create service linked roles, by default enabled.
- Added example for public subnet
1.3.0 - 2018-08-08
- Add option to run runners in public subnet
1.2.1 - 2018-08-02
- Add work around to README for missing service linked roles, see #15
1.2.0 - 2018-07-30
- Add a map for for a more flexible mechanism to tag.
- Set default gitlab runner to 11.1.0
- Replaced the dedicated docker machine user by an instance profile
- Limit the resources access for docker machine.
- Updated default docker build image to 18.03.1-ce
- Add fix for non correct ec2 instances starting, add retry to yum update
1.1.0 - 2018-07-14
- Add variable to enable cloudwatch monitoring for spot instances, by default disabled.
- Add off peak runner settings.
- Add file system root size for runners.
- Refactored example, key generation is part of terraform.
1.0.3 - 2018-07-14
- Add parameter for docker machine version
- Upgrade default gitlab runner version to 11.0.0
- Upgrade default docker-machine version to 0.15.0
1.0.2 - 2018-06-22
- Add link to blog for a detailed setup description
1.0.1 - 2018-06-21
- Moved example so it is shown in the registry
1.0.0 - 2018-06-19
- Default Gitlab runner version set to 10.8.0
- Update default AMI's to The latest Amazon Linux AMI 2017.09.1 - released on 2018-01-17.
- Minor updates in the example