cdk-gitlab-runner 2.1.393 → 2.2.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.jsii +93 -117
- package/API.md +28 -47
- package/README.md +49 -17
- package/lib/gitlab-runner-autoscaling.d.ts +5 -0
- package/lib/gitlab-runner-autoscaling.js +9 -4
- package/lib/gitlab-runner-instance.d.ts +8 -38
- package/lib/gitlab-runner-instance.js +14 -6
- package/lib/integ.api.js +3 -2
- package/lib/integ.gitlab-runner-autoscaling.js +2 -1
- package/node_modules/compare-versions/LICENSE +21 -0
- package/node_modules/compare-versions/README.md +133 -0
- package/node_modules/compare-versions/lib/esm/compare.d.ts +19 -0
- package/node_modules/compare-versions/lib/esm/compare.js +44 -0
- package/node_modules/compare-versions/lib/esm/compare.js.map +1 -0
- package/node_modules/compare-versions/lib/esm/compareVersions.d.ts +8 -0
- package/node_modules/compare-versions/lib/esm/compareVersions.js +29 -0
- package/node_modules/compare-versions/lib/esm/compareVersions.js.map +1 -0
- package/node_modules/compare-versions/lib/esm/index.d.ts +5 -0
- package/node_modules/compare-versions/lib/esm/index.js +5 -0
- package/node_modules/compare-versions/lib/esm/index.js.map +1 -0
- package/node_modules/compare-versions/lib/esm/satisfies.d.ts +14 -0
- package/node_modules/compare-versions/lib/esm/satisfies.js +66 -0
- package/node_modules/compare-versions/lib/esm/satisfies.js.map +1 -0
- package/node_modules/compare-versions/lib/esm/utils.d.ts +7 -0
- package/node_modules/compare-versions/lib/esm/utils.js +37 -0
- package/node_modules/compare-versions/lib/esm/utils.js.map +1 -0
- package/node_modules/compare-versions/lib/esm/validate.d.ts +28 -0
- package/node_modules/compare-versions/lib/esm/validate.js +31 -0
- package/node_modules/compare-versions/lib/esm/validate.js.map +1 -0
- package/node_modules/compare-versions/lib/umd/index.js +216 -0
- package/node_modules/compare-versions/lib/umd/index.js.map +1 -0
- package/node_modules/compare-versions/package.json +45 -0
- package/node_modules/compare-versions/src/compare.ts +54 -0
- package/node_modules/compare-versions/src/compareVersions.ts +31 -0
- package/node_modules/compare-versions/src/index.ts +5 -0
- package/node_modules/compare-versions/src/satisfies.ts +69 -0
- package/node_modules/compare-versions/src/utils.ts +50 -0
- package/node_modules/compare-versions/src/validate.ts +36 -0
- package/package.json +8 -2
package/API.md
CHANGED
|
@@ -302,6 +302,18 @@ import { GitlabContainerRunnerProps } from 'cdk-gitlab-runner'
|
|
|
302
302
|
const gitlabContainerRunnerProps: GitlabContainerRunnerProps = { ... }
|
|
303
303
|
```
|
|
304
304
|
|
|
305
|
+
##### `gitlabRunnerVersion`<sup>Required</sup> <a name="cdk-gitlab-runner.GitlabContainerRunnerProps.property.gitlabRunnerVersion"></a>
|
|
306
|
+
|
|
307
|
+
```typescript
|
|
308
|
+
public readonly gitlabRunnerVersion: string;
|
|
309
|
+
```
|
|
310
|
+
|
|
311
|
+
- *Type:* `string`
|
|
312
|
+
|
|
313
|
+
Gitlab Runner version Please give me gitlab runner version.
|
|
314
|
+
|
|
315
|
+
---
|
|
316
|
+
|
|
305
317
|
##### `gitlabtoken`<sup>Required</sup> <a name="cdk-gitlab-runner.GitlabContainerRunnerProps.property.gitlabtoken"></a>
|
|
306
318
|
|
|
307
319
|
```typescript
|
|
@@ -389,7 +401,7 @@ public readonly gitlabRunnerImage: string;
|
|
|
389
401
|
```
|
|
390
402
|
|
|
391
403
|
- *Type:* `string`
|
|
392
|
-
- *Default:* public.ecr.aws/gitlab/gitlab-runner:latest
|
|
404
|
+
- *Default:* public.ecr.aws/gitlab/gitlab-runner:latest !!! <--- latest now > 16.0 Gitlab Runner version
|
|
393
405
|
|
|
394
406
|
Image URL of Gitlab Runner.
|
|
395
407
|
|
|
@@ -473,51 +485,6 @@ Gitlab Runner instance Use Spot Fleet or not ?!.
|
|
|
473
485
|
|
|
474
486
|
---
|
|
475
487
|
|
|
476
|
-
##### ~~`tag1`~~<sup>Optional</sup> <a name="cdk-gitlab-runner.GitlabContainerRunnerProps.property.tag1"></a>
|
|
477
|
-
|
|
478
|
-
- *Deprecated:* - use tags ['runner', 'gitlab', 'awscdk']
|
|
479
|
-
|
|
480
|
-
```typescript
|
|
481
|
-
public readonly tag1: string;
|
|
482
|
-
```
|
|
483
|
-
|
|
484
|
-
- *Type:* `string`
|
|
485
|
-
- *Default:* tag1: gitlab .
|
|
486
|
-
|
|
487
|
-
Gitlab Runner register tag1 .
|
|
488
|
-
|
|
489
|
-
---
|
|
490
|
-
|
|
491
|
-
##### ~~`tag2`~~<sup>Optional</sup> <a name="cdk-gitlab-runner.GitlabContainerRunnerProps.property.tag2"></a>
|
|
492
|
-
|
|
493
|
-
- *Deprecated:* - use tags ['runner', 'gitlab', 'awscdk']
|
|
494
|
-
|
|
495
|
-
```typescript
|
|
496
|
-
public readonly tag2: string;
|
|
497
|
-
```
|
|
498
|
-
|
|
499
|
-
- *Type:* `string`
|
|
500
|
-
- *Default:* tag2: awscdk .
|
|
501
|
-
|
|
502
|
-
Gitlab Runner register tag2 .
|
|
503
|
-
|
|
504
|
-
---
|
|
505
|
-
|
|
506
|
-
##### ~~`tag3`~~<sup>Optional</sup> <a name="cdk-gitlab-runner.GitlabContainerRunnerProps.property.tag3"></a>
|
|
507
|
-
|
|
508
|
-
- *Deprecated:* - use tags ['runner', 'gitlab', 'awscdk']
|
|
509
|
-
|
|
510
|
-
```typescript
|
|
511
|
-
public readonly tag3: string;
|
|
512
|
-
```
|
|
513
|
-
|
|
514
|
-
- *Type:* `string`
|
|
515
|
-
- *Default:* tag3: runner .
|
|
516
|
-
|
|
517
|
-
Gitlab Runner register tag3 .
|
|
518
|
-
|
|
519
|
-
---
|
|
520
|
-
|
|
521
488
|
##### `tags`<sup>Optional</sup> <a name="cdk-gitlab-runner.GitlabContainerRunnerProps.property.tags"></a>
|
|
522
489
|
|
|
523
490
|
```typescript
|
|
@@ -527,7 +494,9 @@ public readonly tags: string[];
|
|
|
527
494
|
- *Type:* `string`[]
|
|
528
495
|
- *Default:* ['runner', 'gitlab', 'awscdk']
|
|
529
496
|
|
|
530
|
-
tags for the runner.
|
|
497
|
+
tags for the runner Unsupported Gitlab Runner 15.10 and later.
|
|
498
|
+
|
|
499
|
+
> - https://docs.gitlab.com/ee/ci/runners/new_creation_workflow.html
|
|
531
500
|
|
|
532
501
|
---
|
|
533
502
|
|
|
@@ -569,6 +538,18 @@ import { GitlabRunnerAutoscalingProps } from 'cdk-gitlab-runner'
|
|
|
569
538
|
const gitlabRunnerAutoscalingProps: GitlabRunnerAutoscalingProps = { ... }
|
|
570
539
|
```
|
|
571
540
|
|
|
541
|
+
##### `gitlabRunnerVersion`<sup>Required</sup> <a name="cdk-gitlab-runner.GitlabRunnerAutoscalingProps.property.gitlabRunnerVersion"></a>
|
|
542
|
+
|
|
543
|
+
```typescript
|
|
544
|
+
public readonly gitlabRunnerVersion: string;
|
|
545
|
+
```
|
|
546
|
+
|
|
547
|
+
- *Type:* `string`
|
|
548
|
+
|
|
549
|
+
Gitlab Runner version Please give me gitlab runner version.
|
|
550
|
+
|
|
551
|
+
---
|
|
552
|
+
|
|
572
553
|
##### `gitlabToken`<sup>Required</sup> <a name="cdk-gitlab-runner.GitlabRunnerAutoscalingProps.property.gitlabToken"></a>
|
|
573
554
|
|
|
574
555
|
```typescript
|
package/README.md
CHANGED
|
@@ -35,16 +35,38 @@ It will be used with AWS IAM Role, so you don't need to put AKSK in Gitlab envir
|
|
|
35
35
|
|
|
36
36
|
## Before start you need gitlab runner token in your `gitlab project` or `gitlab group`
|
|
37
37
|
|
|
38
|
-
|
|
39
|
-
|
|
38
|
+
## In Group before Gitlab 15.10
|
|
39
|
+
This registration process is only supported in GitLab Runner 15.10 or later
|
|
40
|
+
This registration process is not supported in GitLab Runner 15.9 or earlier and only available as an experimental feature in GitLab Runner 15.10 and 15.11. You should upgrade to GitLab Runner 16.0 or later to use a stable version of this registration process. [Check this issue](https://github.com/neilkuan/cdk-gitlab-runner/issues/1796)
|
|
41
|
+
|
|
40
42
|
Group > Settings > CI/CD
|
|
41
43
|

|
|
42
44
|
|
|
43
|
-
|
|
45
|
+
## In Group after Gitlab 15.10
|
|
46
|
+
This registration process is only supported in GitLab Runner 15.10 or later
|
|
47
|
+
This registration process is not supported in GitLab Runner 15.9 or earlier and only available as an experimental feature in GitLab Runner 15.10 and 15.11. You should upgrade to GitLab Runner 16.0 or later to use a stable version of this registration process. [Check this issue](https://github.com/neilkuan/cdk-gitlab-runner/issues/1796)
|
|
48
|
+
|
|
49
|
+
Group > Build > Runners
|
|
50
|
+

|
|
51
|
+

|
|
52
|
+

|
|
53
|
+

|
|
54
|
+
|
|
55
|
+
|
|
56
|
+
### In Project before Gitlab 15.10
|
|
57
|
+
This registration process is only supported in GitLab Runner 15.10 or later
|
|
58
|
+
This registration process is not supported in GitLab Runner 15.9 or earlier and only available as an experimental feature in GitLab Runner 15.10 and 15.11. You should upgrade to GitLab Runner 16.0 or later to use a stable version of this registration process. [Check this issue](https://github.com/neilkuan/cdk-gitlab-runner/issues/1796)
|
|
44
59
|
|
|
45
60
|
Project > Settings > CI/CD > Runners
|
|
46
61
|

|
|
47
62
|
|
|
63
|
+
### In Project after Gitlab 15.10
|
|
64
|
+
This registration process is only supported in GitLab Runner 15.10 or later
|
|
65
|
+
This registration process is not supported in GitLab Runner 15.9 or earlier and only available as an experimental feature in GitLab Runner 15.10 and 15.11. You should upgrade to GitLab Runner 16.0 or later to use a stable version of this registration process. [Check this issue](https://github.com/neilkuan/cdk-gitlab-runner/issues/1796)
|
|
66
|
+
|
|
67
|
+
Project > Settings > CI/CD > Runners
|
|
68
|
+

|
|
69
|
+
|
|
48
70
|
## Usage
|
|
49
71
|
|
|
50
72
|
Replace your gitlab runner token in `$GITLABTOKEN`
|
|
@@ -69,12 +91,12 @@ npm install cdk-gitlab-runner@cdkv1
|
|
|
69
91
|
import { GitlabContainerRunner } from 'cdk-gitlab-runner';
|
|
70
92
|
|
|
71
93
|
// If want change instance type to t3.large .
|
|
72
|
-
new GitlabContainerRunner(this, 'runner-instance', { gitlabtoken: '
|
|
94
|
+
new GitlabContainerRunner(this, 'runner-instance', { gitlabtoken: 'glrt-GITLABTOKEN', ec2type:'t3.large',gitlabRunnerVersion: '15.10' });
|
|
73
95
|
// OR
|
|
74
96
|
// Just create a gitlab runner , by default instance type is t3.micro .
|
|
75
97
|
import { GitlabContainerRunner } from 'cdk-gitlab-runner';
|
|
76
98
|
|
|
77
|
-
new GitlabContainerRunner(this, 'runner-instance', { gitlabtoken: '
|
|
99
|
+
new GitlabContainerRunner(this, 'runner-instance', { gitlabtoken: 'glrt-GITLABTOKEN', gitlabRunnerVersion: '15.10' });
|
|
78
100
|
```
|
|
79
101
|
|
|
80
102
|
### Gitlab Server Customize Url .
|
|
@@ -86,21 +108,23 @@ If you want change what you want tag name .
|
|
|
86
108
|
import { GitlabContainerRunner } from 'cdk-gitlab-runner';
|
|
87
109
|
|
|
88
110
|
new GitlabContainerRunner(this, 'runner-instance-change-tag', {
|
|
89
|
-
gitlabtoken: '
|
|
111
|
+
gitlabtoken: 'glrt-GITLABTOKEN',
|
|
90
112
|
gitlaburl: 'https://gitlab.my.com/',
|
|
113
|
+
gitlabRunnerVersion: '15.10'
|
|
91
114
|
});
|
|
92
115
|
```
|
|
93
116
|
|
|
94
117
|
### Tags
|
|
95
118
|
|
|
96
119
|
If you want change what you want tag name .
|
|
97
|
-
|
|
120
|
+
!!! Not support Gitlab Runner 15.10 and later !!!
|
|
98
121
|
```typescript
|
|
99
122
|
// If you want change what you want tag name .
|
|
100
123
|
import { GitlabContainerRunner } from 'cdk-gitlab-runner';
|
|
101
124
|
|
|
102
125
|
new GitlabContainerRunner(this, 'runner-instance-change-tag', {
|
|
103
|
-
gitlabtoken: '
|
|
126
|
+
gitlabtoken: 'glrt-GITLABTOKEN',
|
|
127
|
+
gitlabRunnerVersion: '15.10',
|
|
104
128
|
tags: ['aa', 'bb', 'cc'],
|
|
105
129
|
});
|
|
106
130
|
```
|
|
@@ -115,7 +139,8 @@ import { GitlabContainerRunner } from 'cdk-gitlab-runner';
|
|
|
115
139
|
import { ManagedPolicy } from 'aws-cdk-lib/aws-iam';
|
|
116
140
|
|
|
117
141
|
const runner = new GitlabContainerRunner(this, 'runner-instance-add-policy', {
|
|
118
|
-
gitlabtoken: '
|
|
142
|
+
gitlabtoken: 'glrt-GITLABTOKEN',
|
|
143
|
+
gitlabRunnerVersion: '15.10',
|
|
119
144
|
tags: ['aa', 'bb', 'cc'],
|
|
120
145
|
});
|
|
121
146
|
runner.runnerRole.addManagedPolicy(
|
|
@@ -133,7 +158,8 @@ import { GitlabContainerRunner } from 'cdk-gitlab-runner';
|
|
|
133
158
|
import { Port, Peer } from 'aws-cdk-lib/aws-ec2';
|
|
134
159
|
|
|
135
160
|
const runner = new GitlabContainerRunner(this, 'runner-add-SG-ingress', {
|
|
136
|
-
gitlabtoken: 'GITLABTOKEN',
|
|
161
|
+
gitlabtoken: 'glrt-GITLABTOKEN',
|
|
162
|
+
gitlabRunnerVersion: '15.10',
|
|
137
163
|
tags: ['aa', 'bb', 'cc'],
|
|
138
164
|
});
|
|
139
165
|
|
|
@@ -167,7 +193,8 @@ const newvpc = new Vpc(stack, 'VPC', {
|
|
|
167
193
|
});
|
|
168
194
|
|
|
169
195
|
const runner = new GitlabContainerRunner(this, 'testing', {
|
|
170
|
-
gitlabtoken: '
|
|
196
|
+
gitlabtoken: 'glrt-GITLABTOKEN',
|
|
197
|
+
gitlabRunnerVersion: '15.10',
|
|
171
198
|
ec2type: 't3.small',
|
|
172
199
|
selfvpc: newvpc,
|
|
173
200
|
});
|
|
@@ -189,7 +216,8 @@ const role = new Role(this, 'runner-role', {
|
|
|
189
216
|
});
|
|
190
217
|
|
|
191
218
|
const runner = new GitlabContainerRunner(stack, 'testing', {
|
|
192
|
-
gitlabtoken: '
|
|
219
|
+
gitlabtoken: 'glrt-GITLABTOKEN',
|
|
220
|
+
gitlabRunnerVersion: '15.10',
|
|
193
221
|
ec2iamrole: role,
|
|
194
222
|
});
|
|
195
223
|
runner.runnerRole.addManagedPolicy(
|
|
@@ -205,7 +233,8 @@ runner.runnerRole.addManagedPolicy(
|
|
|
205
233
|
import { GitlabContainerRunner } from 'cdk-gitlab-runner';
|
|
206
234
|
|
|
207
235
|
new GitlabContainerRunner(stack, 'testing', {
|
|
208
|
-
gitlabtoken: '
|
|
236
|
+
gitlabtoken: 'glrt-GITLABTOKEN',
|
|
237
|
+
gitlabRunnerVersion: '15.10',
|
|
209
238
|
ebsSize: 50,
|
|
210
239
|
});
|
|
211
240
|
```
|
|
@@ -218,7 +247,8 @@ new GitlabContainerRunner(stack, 'testing', {
|
|
|
218
247
|
import { GitlabRunnerAutoscaling } from 'cdk-gitlab-runner';
|
|
219
248
|
|
|
220
249
|
new GitlabRunnerAutoscaling(stack, 'testing', {
|
|
221
|
-
gitlabToken: '
|
|
250
|
+
gitlabToken: 'glrt-GITLABTOKEN',
|
|
251
|
+
gitlabRunnerVersion: '15.10',
|
|
222
252
|
minCapacity: 2,
|
|
223
253
|
maxCapacity: 2,
|
|
224
254
|
});
|
|
@@ -233,7 +263,8 @@ new GitlabRunnerAutoscaling(stack, 'testing', {
|
|
|
233
263
|
import { GitlabContainerRunner, BlockDuration } from 'cdk-gitlab-runner';
|
|
234
264
|
|
|
235
265
|
const runner = new GitlabContainerRunner(stack, 'testing', {
|
|
236
|
-
|
|
266
|
+
gitlabToken: 'glrt-GITLABTOKEN',
|
|
267
|
+
gitlabRunnerVersion: '15.10',
|
|
237
268
|
ec2type: 't3.large',
|
|
238
269
|
spotFleet: true,
|
|
239
270
|
});
|
|
@@ -248,7 +279,8 @@ runner.expireAfter(Duration.hours(1));
|
|
|
248
279
|
import { GitlabContainerRunner, BlockDuration } from 'cdk-gitlab-runner';
|
|
249
280
|
|
|
250
281
|
const runner = new GitlabContainerRunner(stack, 'testing', {
|
|
251
|
-
|
|
282
|
+
gitlabToken: 'glrt-GITLABTOKEN',
|
|
283
|
+
gitlabRunnerVersion: '15.10',
|
|
252
284
|
ec2type: 't3.large',
|
|
253
285
|
dockerVolumes: [
|
|
254
286
|
{
|
|
@@ -264,7 +296,7 @@ const runner = new GitlabContainerRunner(stack, 'testing', {
|
|
|
264
296
|

|
|
265
297
|
|
|
266
298
|
#### you can use tag `gitlab` , `runner` , `awscdk` ,
|
|
267
|
-
|
|
299
|
+
> !!!!! Not Support Gitlab Runner after 15.10 and later
|
|
268
300
|
## Example _`gitlab-ci.yaml`_
|
|
269
301
|
|
|
270
302
|
[gitlab docs see more ...](https://docs.gitlab.com/ee/ci/yaml/README.html)
|
|
@@ -8,6 +8,11 @@ import { DockerVolumes } from './gitlab-runner-interfaces';
|
|
|
8
8
|
* GitlabRunnerAutoscaling Props.
|
|
9
9
|
*/
|
|
10
10
|
export interface GitlabRunnerAutoscalingProps {
|
|
11
|
+
/**
|
|
12
|
+
* Gitlab Runner version
|
|
13
|
+
* Please give me gitlab runner version.
|
|
14
|
+
*/
|
|
15
|
+
readonly gitlabRunnerVersion: string;
|
|
11
16
|
/**
|
|
12
17
|
* Gitlab token.
|
|
13
18
|
*
|
|
@@ -15,6 +15,8 @@ const assets = require("aws-cdk-lib/aws-s3-assets");
|
|
|
15
15
|
const sns = require("aws-cdk-lib/aws-sns");
|
|
16
16
|
const subscriptions = require("aws-cdk-lib/aws-sns-subscriptions");
|
|
17
17
|
const cr = require("aws-cdk-lib/custom-resources");
|
|
18
|
+
// eslint-disable-next-line import/no-extraneous-dependencies
|
|
19
|
+
const compare_versions_1 = require("compare-versions");
|
|
18
20
|
const constructs_1 = require("constructs");
|
|
19
21
|
/**
|
|
20
22
|
* GitlabRunnerAutoscaling Construct for create Autoscaling Gitlab Runner.
|
|
@@ -35,6 +37,9 @@ class GitlabRunnerAutoscaling extends constructs_1.Construct {
|
|
|
35
37
|
],
|
|
36
38
|
};
|
|
37
39
|
const runnerProps = { ...defaultProps, ...props };
|
|
40
|
+
if ((0, compare_versions_1.compare)(props.gitlabRunnerVersion, '15.10', '>=') && props.gitlabToken.includes('glrt-') === false) {
|
|
41
|
+
throw new Error('If gitlabRunnerVersion >= 15.10, gitlabtoken please give glrt-xxxxxxx @see https://docs.gitlab.com/ee/ci/runners/new_creation_workflow.html');
|
|
42
|
+
}
|
|
38
43
|
const asset = new assets.Asset(this, 'GitlabRunnerUserDataAsset', {
|
|
39
44
|
path: path.join(__dirname, '../assets/userdata/amazon-cloudwatch-agent.json'),
|
|
40
45
|
});
|
|
@@ -230,15 +235,15 @@ class GitlabRunnerAutoscaling extends constructs_1.Construct {
|
|
|
230
235
|
'sleep 15 && amazon-linux-extras install docker && yum install -y amazon-cloudwatch-agent && systemctl start docker && usermod -aG docker ec2-user && chmod 777 /var/run/docker.sock',
|
|
231
236
|
'systemctl restart docker && systemctl enable docker && systemctl start amazon-cloudwatch-agent && systemctl enable amazon-cloudwatch-agent',
|
|
232
237
|
`docker run -d -v /home/ec2-user/.gitlab-runner:/etc/gitlab-runner -v /var/run/docker.sock:/var/run/docker.sock \
|
|
233
|
-
--name gitlab-runner-register ${props.gitlabRunnerImage} register --non-interactive --url ${props.gitlabUrl} --registration-token ${props.gitlabToken} \
|
|
238
|
+
--name gitlab-runner-register ${props.gitlabRunnerImage} register --non-interactive --url ${props.gitlabUrl} ${(0, compare_versions_1.compare)(props.gitlabRunnerVersion, '15.10', '>=') ? '--token' : '--registration-token'} ${props.gitlabToken} \
|
|
234
239
|
--docker-pull-policy if-not-present ${this.dockerVolumesList(props?.dockerVolumes)} \
|
|
235
240
|
--executor docker --docker-image "alpine:latest" --description "A Runner on EC2 Instance (${props.instanceType})" \
|
|
236
|
-
|
|
241
|
+
${(0, compare_versions_1.compare)(props.gitlabRunnerVersion, '15.10', '>=') ? undefined : `--tag-list "${props.tags?.join(',')}" `} --docker-privileged`,
|
|
237
242
|
`sleep 2 && docker run --restart always -d -v /home/ec2-user/.gitlab-runner:/etc/gitlab-runner -v /var/run/docker.sock:/var/run/docker.sock --name gitlab-runner ${props.gitlabRunnerImage}`,
|
|
238
243
|
];
|
|
239
244
|
}
|
|
240
245
|
}
|
|
241
246
|
_a = JSII_RTTI_SYMBOL_1;
|
|
242
|
-
GitlabRunnerAutoscaling[_a] = { fqn: "cdk-gitlab-runner.GitlabRunnerAutoscaling", version: "2.
|
|
247
|
+
GitlabRunnerAutoscaling[_a] = { fqn: "cdk-gitlab-runner.GitlabRunnerAutoscaling", version: "2.2.0" };
|
|
243
248
|
exports.GitlabRunnerAutoscaling = GitlabRunnerAutoscaling;
|
|
244
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"gitlab-runner-autoscaling.js","sourceRoot":"","sources":["../src/gitlab-runner-autoscaling.ts"],"names":[],"mappings":"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","sourcesContent":["import * as path from 'path';\nimport * as cdk from 'aws-cdk-lib';\nimport * as asg from 'aws-cdk-lib/aws-autoscaling';\nimport { FunctionHook } from 'aws-cdk-lib/aws-autoscaling-hooktargets';\nimport * as ec2 from 'aws-cdk-lib/aws-ec2';\nimport * as iam from 'aws-cdk-lib/aws-iam';\nimport * as lambda from 'aws-cdk-lib/aws-lambda';\nimport * as logs from 'aws-cdk-lib/aws-logs';\nimport * as assets from 'aws-cdk-lib/aws-s3-assets';\nimport * as sns from 'aws-cdk-lib/aws-sns';\nimport * as subscriptions from 'aws-cdk-lib/aws-sns-subscriptions';\nimport * as cr from 'aws-cdk-lib/custom-resources';\nimport { Construct } from 'constructs';\nimport { DockerVolumes } from './gitlab-runner-interfaces';\n\n/**\n * GitlabRunnerAutoscaling Props.\n */\nexport interface GitlabRunnerAutoscalingProps {\n  /**\n   * Gitlab token.\n   *\n   * @example\n   * new GitlabRunnerAutoscaling(stack, 'runner', { gitlabToken: 'GITLAB_TOKEN' });\n   */\n  readonly gitlabToken: string;\n\n  /**\n   * Image URL of Gitlab Runner.\n   *\n   * @example\n   * new GitlabRunnerAutoscaling(stack, 'runner', { gitlabToken: 'GITLAB_TOKEN', gitlabRunnerImage: 'gitlab/gitlab-runner:alpine' });\n   *\n   * @default public.ecr.aws/gitlab/gitlab-runner:latest\n   *\n   */\n  readonly gitlabRunnerImage?: string;\n\n  /**\n   * Runner default EC2 instance type.\n   *\n   * @example\n   * new GitlabRunnerAutoscaling(stack, 'runner', { gitlabToken: 'GITLAB_TOKEN', instanceType: 't3.small' });\n   *\n   * @default - t3.micro\n   *\n   */\n  readonly instanceType?: string;\n\n  /**\n   * VPC for the Gitlab Runner .\n   *\n   * @example\n   * const newVpc = new Vpc(stack, 'NewVPC', {\n   *   ipAddresses: IpAddresses.cidr('10.0.0.0/16'),\n   *   maxAzs: 2,\n   *   subnetConfiguration: [{\n   *     cidrMask: 26,\n   *     name: 'RunnerVPC',\n   *     subnetType: SubnetType.PUBLIC,\n   *   }],\n   *   natGateways: 0,\n   * });\n   *\n   * new GitlabRunnerAutoscaling(stack, 'runner', { gitlabToken: 'GITLAB_TOKEN', vpc: newVpc });\n   *\n   * @default - A new VPC will be created.\n   *\n   */\n  readonly vpc?: ec2.IVpc;\n\n  /**\n   * IAM role for the Gitlab Runner Instance .\n   *\n   * @example\n   * const role = new Role(stack, 'runner-role', {\n   *   assumedBy: new ServicePrincipal('ec2.amazonaws.com'),\n   *   description: 'For Gitlab Runner Test Role',\n   *   roleName: 'Runner-Role',\n   * });\n   *\n   * new GitlabRunnerAutoscaling(stack, 'runner', { gitlabToken: 'GITLAB_TOKEN', instanceRole: role });\n   *\n   * @default - new Role for Gitlab Runner Instance , attach AmazonSSMManagedInstanceCore Policy .\n   *\n   */\n  readonly instanceRole?: iam.IRole;\n\n  /**\n   * Run worker nodes as EC2 Spot\n   *\n   * @default - false\n   */\n  readonly spotInstance?: boolean;\n\n  /**\n   * Minimum capacity limit for autoscaling group.\n   *\n   * @example\n   * new GitlabRunnerAutoscaling(stack, 'runner', { gitlabToken: 'GITLAB_TOKEN', minCapacity: 2 });\n   *\n   * @default - minCapacity: 1\n   *\n   */\n  readonly minCapacity?: number;\n\n  /**\n   * Maximum capacity limit for autoscaling group.\n   *\n   * @example\n   * new GitlabRunnerAutoscaling(stack, 'runner', { gitlabToken: 'GITLAB_TOKEN', maxCapacity: 4 });\n   *\n   * @default - desiredCapacity\n   *\n   */\n  readonly maxCapacity?: number;\n\n  /**\n   * Desired capacity limit for autoscaling group.\n   *\n   * @example\n   * new GitlabRunnerAutoscaling(stack, 'runner', { gitlabToken: 'GITLAB_TOKEN', desiredCapacity: 2 });\n   *\n   * @default - minCapacity, and leave unchanged during deployment\n   *\n   */\n  readonly desiredCapacity?: number;\n\n  /**\n   * tags for the runner\n   *\n   * @default - ['runner', 'gitlab', 'awscdk']\n   */\n  readonly tags?: string[];\n\n  /**\n   * Gitlab Runner register url .\n   *\n   * @example\n   * const runner = new GitlabRunnerAutoscaling(stack, 'runner', { gitlabToken: 'GITLAB_TOKEN',gitlabUrl: 'https://gitlab.com/'});\n   *\n   * @default - https://gitlab.com/ , The trailing slash is mandatory.\n   *\n   */\n  readonly gitlabUrl?: string;\n\n  /**\n   * Gitlab Runner instance EBS size .\n   *\n   * @example\n   * const runner = new GitlabRunnerAutoscaling(stack, 'runner', { gitlabToken: 'GITLAB_TOKEN', ebsSize: 100});\n   *\n   * @default - ebsSize=60\n   *\n   */\n  readonly ebsSize?: number;\n\n  /**\n   * VPC subnet\n   *\n   * @example\n   * const vpc = new Vpc(stack, 'nat', {\n   * natGateways: 1,\n   * maxAzs: 2,\n   * });\n   * const runner = new GitlabRunnerAutoscaling(stack, 'testing', {\n   *   gitlabToken: 'GITLAB_TOKEN',\n   *   instanceType: 't3.large',\n   *   instanceRole: role,\n   *   ebsSize: 100,\n   *   vpc: vpc,\n   *   vpcSubnet: {\n   *     subnetType: SubnetType.PUBLIC,\n   *   },\n   * });\n   *\n   * @default - SubnetType.PRIVATE subnet\n   */\n  readonly vpcSubnet?: ec2.SubnetSelection;\n\n  /**\n   * add another Gitlab Container Runner Docker Volumes Path at job runner runtime.\n   *\n   * more detail see https://docs.gitlab.com/runner/configuration/advanced-configuration.html#the-runnersdocker-section\n   *\n   * @default - already mount \"/var/run/docker.sock:/var/run/docker.sock\"\n   *\n   * @example\n   * dockerVolumes: [\n   *   {\n   *     hostPath: '/tmp/cache',\n   *     containerPath: '/tmp/cache',\n   *   },\n   * ],\n   */\n  readonly dockerVolumes?: DockerVolumes[];\n\n  /**\n   * Parameters of put_metric_alarm function\n   *\n   * https://boto3.amazonaws.com/v1/documentation/api/latest/reference/services/cloudwatch.html#CloudWatch.Client.put_metric_alarm\n   *\n   * @default - [{\n   *     AlarmName: 'GitlabRunnerDiskUsage',\n   *     MetricName: 'disk_used_percent',\n   * }]\n   *\n   */\n  readonly alarms?: object[];\n}\n\n/**\n * GitlabRunnerAutoscaling Construct for create Autoscaling Gitlab Runner.\n */\nexport class GitlabRunnerAutoscaling extends Construct {\n  /**\n   * The IAM role assumed by the Runner instance.\n   */\n  public readonly instanceRole: iam.IRole;\n\n  /**\n   * This represents a Runner Auto Scaling Group\n   */\n  public readonly autoscalingGroup: asg.AutoScalingGroup;\n\n  /**\n   * The EC2 runner's VPC.\n   */\n  public readonly vpc: ec2.IVpc;\n\n  /**\n   * The EC2 runner's default SecurityGroup.\n   */\n  public readonly securityGroup: ec2.ISecurityGroup;\n\n  /**\n   * The SNS topic to suscribe alarms for EC2 runner's metrics.\n   */\n  public readonly topicAlarm: sns.ITopic;\n\n\n  constructor(scope: Construct, id: string, props: GitlabRunnerAutoscalingProps) {\n    super(scope, id);\n    const defaultProps = {\n      instanceType: 't3.micro',\n      tags: ['gitlab', 'awscdk', 'runner'],\n      gitlabUrl: 'https://gitlab.com/',\n      gitlabRunnerImage: 'public.ecr.aws/gitlab/gitlab-runner:latest',\n      alarms: [\n        {\n          AlarmName: 'GitlabRunnerDiskUsage',\n          MetricName: 'disk_used_percent',\n        },\n      ],\n    };\n    const runnerProps = { ...defaultProps, ...props };\n\n    const asset = new assets.Asset(this, 'GitlabRunnerUserDataAsset', {\n      path: path.join(__dirname, '../assets/userdata/amazon-cloudwatch-agent.json'),\n    });\n\n    const userData = ec2.UserData.forLinux();\n    userData.addS3DownloadCommand({\n      bucket: asset.bucket,\n      bucketKey: asset.s3ObjectKey,\n      localFile: '/opt/aws/amazon-cloudwatch-agent/etc/amazon-cloudwatch-agent.json',\n    });\n    userData.addCommands(...this.createUserData(runnerProps));\n\n    this.instanceRole =\n      runnerProps.instanceRole ??\n      new iam.Role(this, 'GitlabRunnerInstanceRole', {\n        assumedBy: new iam.ServicePrincipal('ec2.amazonaws.com'),\n        description: 'For EC2 Instance (Gitlab Runner) Role',\n        managedPolicies: [\n          iam.ManagedPolicy.fromAwsManagedPolicyName('AmazonSSMManagedInstanceCore'),\n          iam.ManagedPolicy.fromAwsManagedPolicyName('CloudWatchAgentServerPolicy'),\n          iam.ManagedPolicy.fromAwsManagedPolicyName('AmazonS3ReadOnlyAccess'),\n        ],\n      });\n\n    this.vpc = runnerProps.vpc ?? new ec2.Vpc(this, 'VPC');\n\n    this.securityGroup = new ec2.SecurityGroup(this, 'GitlabRunnerSecurityGroup', {\n      vpc: this.vpc,\n    });\n    const instanceProfile = new iam.CfnInstanceProfile(this, 'InstanceProfile', {\n      roles: [this.instanceRole.roleName],\n    });\n    const lt = new ec2.CfnLaunchTemplate(this, 'GitlabRunnerLaunchTemplate', {\n      launchTemplateData: {\n        imageId: ec2.MachineImage.latestAmazonLinux2().getImage(this).imageId,\n        instanceType: runnerProps.instanceType,\n        instanceMarketOptions: {\n          marketType: runnerProps.spotInstance ? 'spot' : undefined,\n          spotOptions: runnerProps.spotInstance ? {\n            spotInstanceType: 'one-time',\n          } : undefined,\n        },\n        userData: cdk.Fn.base64(userData.render()),\n        blockDeviceMappings: [\n          {\n            deviceName: '/dev/xvda',\n            ebs: {\n              volumeSize: runnerProps.ebsSize ?? 60,\n            },\n          },\n        ],\n        iamInstanceProfile: {\n          arn: instanceProfile.attrArn,\n        },\n        securityGroupIds: this.securityGroup.connections.securityGroups.map(\n          (m) => m.securityGroupId,\n        ),\n      },\n    });\n\n    this.autoscalingGroup = new asg.AutoScalingGroup(this, 'GitlabRunnerAutoscalingGroup', {\n      instanceType: new ec2.InstanceType(runnerProps.instanceType),\n      autoScalingGroupName: `Gitlab Runners (${runnerProps.instanceType})`,\n      vpc: this.vpc,\n      vpcSubnets: runnerProps.vpcSubnet,\n      machineImage: ec2.MachineImage.latestAmazonLinux2(),\n      minCapacity: runnerProps.minCapacity,\n      maxCapacity: runnerProps.maxCapacity,\n      desiredCapacity: runnerProps.desiredCapacity,\n    });\n\n    const cfnAsg = this.autoscalingGroup.node.tryFindChild('ASG') as asg.CfnAutoScalingGroup;\n    cfnAsg.addPropertyDeletionOverride('LaunchConfigurationName');\n    cfnAsg.addPropertyOverride('LaunchTemplate', {\n      LaunchTemplateId: lt.ref,\n      Version: lt.attrLatestVersionNumber,\n    });\n    this.autoscalingGroup.node.tryRemoveChild('LaunchConfig');\n\n    this.topicAlarm = new sns.Topic(this, 'GitlabRunnerAlarm');\n    const alarms = JSON.stringify(runnerProps.alarms);\n\n    // Put alarms at launch\n    const registerFunction = new lambda.Function(this, 'GitlabRunnerRegisterFunction', {\n      code: lambda.Code.fromAsset(path.join(__dirname, '../assets/functions')),\n      handler: 'autoscaling_events.register',\n      runtime: lambda.Runtime.PYTHON_3_8,\n      timeout: cdk.Duration.seconds(60),\n      logRetention: logs.RetentionDays.ONE_DAY,\n      environment: {\n        ALARMS: alarms,\n        SNS_TOPIC_ARN: this.topicAlarm.topicArn,\n      },\n    });\n    registerFunction.role?.addToPrincipalPolicy(\n      new iam.PolicyStatement({\n        effect: iam.Effect.ALLOW,\n        resources: ['*'],\n        actions: [\n          'cloudwatch:PutMetricAlarm',\n        ],\n      }),\n    );\n\n    this.autoscalingGroup.addLifecycleHook('GitlabRunnerLifeCycleHookLaunching', {\n      lifecycleTransition: asg.LifecycleTransition.INSTANCE_LAUNCHING,\n      notificationTarget: new FunctionHook(registerFunction),\n      defaultResult: asg.DefaultResult.CONTINUE,\n      heartbeatTimeout: cdk.Duration.seconds(60),\n    });\n\n    // Add an alarm action to terminate invalid instances\n    const alarmAction = new lambda.Function(this, 'GitlabRunnerAlarmAction', {\n      code: lambda.Code.fromAsset(path.join(__dirname, '../assets/functions')),\n      handler: 'autoscaling_events.on_alarm',\n      runtime: lambda.Runtime.PYTHON_3_8,\n      timeout: cdk.Duration.seconds(60),\n      logRetention: logs.RetentionDays.ONE_DAY,\n    });\n    alarmAction.role?.addToPrincipalPolicy(\n      new iam.PolicyStatement({\n        effect: iam.Effect.ALLOW,\n        resources: ['*'],\n        actions: [\n          'autoscaling:SetInstanceHealth',\n        ],\n      }),\n    );\n    const alarmSubscription = new subscriptions.LambdaSubscription(alarmAction);\n    this.topicAlarm.addSubscription(alarmSubscription);\n\n    // Unregister gitlab runners and remove alarms on instance termination or CFn stack deletion\n    const unregisterRole = new iam.Role(this, 'GitlabRunnerUnregisterRole', {\n      assumedBy: new iam.ServicePrincipal('lambda.amazonaws.com'),\n      description: 'For Gitlab Runner Unregistering Function Role',\n      managedPolicies: [\n        iam.ManagedPolicy.fromAwsManagedPolicyName('service-role/AWSLambdaBasicExecutionRole'),\n      ],\n    });\n    unregisterRole.addToPrincipalPolicy(\n      new iam.PolicyStatement({\n        effect: iam.Effect.ALLOW,\n        resources: ['*'],\n        actions: [\n          'ssm:SendCommand',\n          'autoscaling:DescribeAutoScalingGroups',\n          'cloudwatch:DeleteAlarms',\n        ],\n      }),\n    );\n\n    const unregisterFunction = new lambda.Function(this, 'GitlabRunnerUnregisterFunction', {\n      code: lambda.Code.fromAsset(path.join(__dirname, '../assets/functions')),\n      handler: 'autoscaling_events.unregister',\n      runtime: lambda.Runtime.PYTHON_3_8,\n      timeout: cdk.Duration.seconds(60),\n      role: unregisterRole,\n      logRetention: logs.RetentionDays.ONE_DAY,\n      environment: {\n        ALARMS: alarms,\n      },\n    });\n\n    this.autoscalingGroup.addLifecycleHook('GitlabRunnerLifeCycleHookTerminating', {\n      lifecycleTransition: asg.LifecycleTransition.INSTANCE_TERMINATING,\n      notificationTarget: new FunctionHook(unregisterFunction),\n      defaultResult: asg.DefaultResult.CONTINUE,\n      heartbeatTimeout: cdk.Duration.seconds(60),\n    });\n\n    const unregisterCustomResource = new lambda.Function(this, 'GitlabRunnerUnregisterCustomResource', {\n      code: lambda.Code.fromAsset(path.join(__dirname, '../assets/functions')),\n      handler: 'autoscaling_events.on_event',\n      runtime: lambda.Runtime.PYTHON_3_8,\n      role: unregisterRole,\n      logRetention: logs.RetentionDays.ONE_DAY,\n      environment: {\n        ALARMS: alarms,\n      },\n    });\n\n    const unregisterProvider = new cr.Provider(this, 'GitlabRunnerUnregisterProvider', {\n      onEventHandler: unregisterCustomResource,\n    });\n\n    const customResource = new cdk.CustomResource(this, 'GitlabRunnerCustomResource', {\n      serviceToken: unregisterProvider.serviceToken,\n      properties: {\n        AutoScalingGroupNames: [this.autoscalingGroup.autoScalingGroupName],\n      },\n    });\n    customResource.node.addDependency(unregisterProvider);\n\n    new cdk.CfnOutput(this, 'GitlabRunnerAutoScalingGroupArn', {\n      value: this.autoscalingGroup.autoScalingGroupArn,\n    });\n  }\n\n  private dockerVolumesList(dockerVolume: DockerVolumes[] | undefined): string {\n    let tempString: string = '--docker-volumes \"/var/run/docker.sock:/var/run/docker.sock\"';\n    if (dockerVolume) {\n      let tempList: string[] = [];\n      dockerVolume.forEach(e => {\n        tempList.push(`\"${e.hostPath}:${e.containerPath}\"`);\n      });\n      tempList.forEach(e => {\n        tempString = `${tempString} --docker-volumes ${e}`;\n      });\n    }\n    return tempString;\n  }\n  /**\n   * @param props\n   * @returns Array.\n   */\n  public createUserData(props: GitlabRunnerAutoscalingProps): string[] {\n    return [\n      'yum update -y',\n      'sleep 15 && amazon-linux-extras install docker && yum install -y amazon-cloudwatch-agent && systemctl start docker && usermod -aG docker ec2-user && chmod 777 /var/run/docker.sock',\n      'systemctl restart docker && systemctl enable docker && systemctl start amazon-cloudwatch-agent && systemctl enable amazon-cloudwatch-agent',\n      `docker run -d -v /home/ec2-user/.gitlab-runner:/etc/gitlab-runner -v /var/run/docker.sock:/var/run/docker.sock \\\n      --name gitlab-runner-register ${props.gitlabRunnerImage} register --non-interactive --url ${props.gitlabUrl} --registration-token ${props.gitlabToken} \\\n      --docker-pull-policy if-not-present ${this.dockerVolumesList(props?.dockerVolumes)} \\\n      --executor docker --docker-image \"alpine:latest\" --description \"A Runner on EC2 Instance (${props.instanceType})\" \\\n      --tag-list \"${props.tags?.join(',')}\" --docker-privileged`,\n      `sleep 2 && docker run --restart always -d -v /home/ec2-user/.gitlab-runner:/etc/gitlab-runner -v /var/run/docker.sock:/var/run/docker.sock --name gitlab-runner ${props.gitlabRunnerImage}`,\n    ];\n  }\n}\n"]}
|
|
249
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"gitlab-runner-autoscaling.js","sourceRoot":"","sources":["../src/gitlab-runner-autoscaling.ts"],"names":[],"mappings":"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","sourcesContent":["import * as path from 'path';\nimport * as cdk from 'aws-cdk-lib';\nimport * as asg from 'aws-cdk-lib/aws-autoscaling';\nimport { FunctionHook } from 'aws-cdk-lib/aws-autoscaling-hooktargets';\nimport * as ec2 from 'aws-cdk-lib/aws-ec2';\nimport * as iam from 'aws-cdk-lib/aws-iam';\nimport * as lambda from 'aws-cdk-lib/aws-lambda';\nimport * as logs from 'aws-cdk-lib/aws-logs';\nimport * as assets from 'aws-cdk-lib/aws-s3-assets';\nimport * as sns from 'aws-cdk-lib/aws-sns';\nimport * as subscriptions from 'aws-cdk-lib/aws-sns-subscriptions';\nimport * as cr from 'aws-cdk-lib/custom-resources';\n// eslint-disable-next-line import/no-extraneous-dependencies\nimport { compare } from 'compare-versions';\nimport { Construct } from 'constructs';\nimport { DockerVolumes } from './gitlab-runner-interfaces';\n\n/**\n * GitlabRunnerAutoscaling Props.\n */\nexport interface GitlabRunnerAutoscalingProps {\n  /**\n   * Gitlab Runner version\n   * Please give me gitlab runner version.\n   */\n  readonly gitlabRunnerVersion: string;\n  /**\n   * Gitlab token.\n   *\n   * @example\n   * new GitlabRunnerAutoscaling(stack, 'runner', { gitlabToken: 'GITLAB_TOKEN' });\n   */\n  readonly gitlabToken: string;\n\n  /**\n   * Image URL of Gitlab Runner.\n   *\n   * @example\n   * new GitlabRunnerAutoscaling(stack, 'runner', { gitlabToken: 'GITLAB_TOKEN', gitlabRunnerImage: 'gitlab/gitlab-runner:alpine' });\n   *\n   * @default public.ecr.aws/gitlab/gitlab-runner:latest\n   *\n   */\n  readonly gitlabRunnerImage?: string;\n\n  /**\n   * Runner default EC2 instance type.\n   *\n   * @example\n   * new GitlabRunnerAutoscaling(stack, 'runner', { gitlabToken: 'GITLAB_TOKEN', instanceType: 't3.small' });\n   *\n   * @default - t3.micro\n   *\n   */\n  readonly instanceType?: string;\n\n  /**\n   * VPC for the Gitlab Runner .\n   *\n   * @example\n   * const newVpc = new Vpc(stack, 'NewVPC', {\n   *   ipAddresses: IpAddresses.cidr('10.0.0.0/16'),\n   *   maxAzs: 2,\n   *   subnetConfiguration: [{\n   *     cidrMask: 26,\n   *     name: 'RunnerVPC',\n   *     subnetType: SubnetType.PUBLIC,\n   *   }],\n   *   natGateways: 0,\n   * });\n   *\n   * new GitlabRunnerAutoscaling(stack, 'runner', { gitlabToken: 'GITLAB_TOKEN', vpc: newVpc });\n   *\n   * @default - A new VPC will be created.\n   *\n   */\n  readonly vpc?: ec2.IVpc;\n\n  /**\n   * IAM role for the Gitlab Runner Instance .\n   *\n   * @example\n   * const role = new Role(stack, 'runner-role', {\n   *   assumedBy: new ServicePrincipal('ec2.amazonaws.com'),\n   *   description: 'For Gitlab Runner Test Role',\n   *   roleName: 'Runner-Role',\n   * });\n   *\n   * new GitlabRunnerAutoscaling(stack, 'runner', { gitlabToken: 'GITLAB_TOKEN', instanceRole: role });\n   *\n   * @default - new Role for Gitlab Runner Instance , attach AmazonSSMManagedInstanceCore Policy .\n   *\n   */\n  readonly instanceRole?: iam.IRole;\n\n  /**\n   * Run worker nodes as EC2 Spot\n   *\n   * @default - false\n   */\n  readonly spotInstance?: boolean;\n\n  /**\n   * Minimum capacity limit for autoscaling group.\n   *\n   * @example\n   * new GitlabRunnerAutoscaling(stack, 'runner', { gitlabToken: 'GITLAB_TOKEN', minCapacity: 2 });\n   *\n   * @default - minCapacity: 1\n   *\n   */\n  readonly minCapacity?: number;\n\n  /**\n   * Maximum capacity limit for autoscaling group.\n   *\n   * @example\n   * new GitlabRunnerAutoscaling(stack, 'runner', { gitlabToken: 'GITLAB_TOKEN', maxCapacity: 4 });\n   *\n   * @default - desiredCapacity\n   *\n   */\n  readonly maxCapacity?: number;\n\n  /**\n   * Desired capacity limit for autoscaling group.\n   *\n   * @example\n   * new GitlabRunnerAutoscaling(stack, 'runner', { gitlabToken: 'GITLAB_TOKEN', desiredCapacity: 2 });\n   *\n   * @default - minCapacity, and leave unchanged during deployment\n   *\n   */\n  readonly desiredCapacity?: number;\n\n  /**\n   * tags for the runner\n   *\n   * @default - ['runner', 'gitlab', 'awscdk']\n   */\n  readonly tags?: string[];\n\n  /**\n   * Gitlab Runner register url .\n   *\n   * @example\n   * const runner = new GitlabRunnerAutoscaling(stack, 'runner', { gitlabToken: 'GITLAB_TOKEN',gitlabUrl: 'https://gitlab.com/'});\n   *\n   * @default - https://gitlab.com/ , The trailing slash is mandatory.\n   *\n   */\n  readonly gitlabUrl?: string;\n\n  /**\n   * Gitlab Runner instance EBS size .\n   *\n   * @example\n   * const runner = new GitlabRunnerAutoscaling(stack, 'runner', { gitlabToken: 'GITLAB_TOKEN', ebsSize: 100});\n   *\n   * @default - ebsSize=60\n   *\n   */\n  readonly ebsSize?: number;\n\n  /**\n   * VPC subnet\n   *\n   * @example\n   * const vpc = new Vpc(stack, 'nat', {\n   * natGateways: 1,\n   * maxAzs: 2,\n   * });\n   * const runner = new GitlabRunnerAutoscaling(stack, 'testing', {\n   *   gitlabToken: 'GITLAB_TOKEN',\n   *   instanceType: 't3.large',\n   *   instanceRole: role,\n   *   ebsSize: 100,\n   *   vpc: vpc,\n   *   vpcSubnet: {\n   *     subnetType: SubnetType.PUBLIC,\n   *   },\n   * });\n   *\n   * @default - SubnetType.PRIVATE subnet\n   */\n  readonly vpcSubnet?: ec2.SubnetSelection;\n\n  /**\n   * add another Gitlab Container Runner Docker Volumes Path at job runner runtime.\n   *\n   * more detail see https://docs.gitlab.com/runner/configuration/advanced-configuration.html#the-runnersdocker-section\n   *\n   * @default - already mount \"/var/run/docker.sock:/var/run/docker.sock\"\n   *\n   * @example\n   * dockerVolumes: [\n   *   {\n   *     hostPath: '/tmp/cache',\n   *     containerPath: '/tmp/cache',\n   *   },\n   * ],\n   */\n  readonly dockerVolumes?: DockerVolumes[];\n\n  /**\n   * Parameters of put_metric_alarm function\n   *\n   * https://boto3.amazonaws.com/v1/documentation/api/latest/reference/services/cloudwatch.html#CloudWatch.Client.put_metric_alarm\n   *\n   * @default - [{\n   *     AlarmName: 'GitlabRunnerDiskUsage',\n   *     MetricName: 'disk_used_percent',\n   * }]\n   *\n   */\n  readonly alarms?: object[];\n}\n\n/**\n * GitlabRunnerAutoscaling Construct for create Autoscaling Gitlab Runner.\n */\nexport class GitlabRunnerAutoscaling extends Construct {\n  /**\n   * The IAM role assumed by the Runner instance.\n   */\n  public readonly instanceRole: iam.IRole;\n\n  /**\n   * This represents a Runner Auto Scaling Group\n   */\n  public readonly autoscalingGroup: asg.AutoScalingGroup;\n\n  /**\n   * The EC2 runner's VPC.\n   */\n  public readonly vpc: ec2.IVpc;\n\n  /**\n   * The EC2 runner's default SecurityGroup.\n   */\n  public readonly securityGroup: ec2.ISecurityGroup;\n\n  /**\n   * The SNS topic to suscribe alarms for EC2 runner's metrics.\n   */\n  public readonly topicAlarm: sns.ITopic;\n\n\n  constructor(scope: Construct, id: string, props: GitlabRunnerAutoscalingProps) {\n    super(scope, id);\n    const defaultProps = {\n      instanceType: 't3.micro',\n      tags: ['gitlab', 'awscdk', 'runner'],\n      gitlabUrl: 'https://gitlab.com/',\n      gitlabRunnerImage: 'public.ecr.aws/gitlab/gitlab-runner:latest',\n      alarms: [\n        {\n          AlarmName: 'GitlabRunnerDiskUsage',\n          MetricName: 'disk_used_percent',\n        },\n      ],\n    };\n    const runnerProps = { ...defaultProps, ...props };\n    if (compare(props.gitlabRunnerVersion, '15.10', '>=') && props.gitlabToken.includes('glrt-') === false) {\n      throw new Error('If gitlabRunnerVersion >= 15.10, gitlabtoken please give glrt-xxxxxxx @see https://docs.gitlab.com/ee/ci/runners/new_creation_workflow.html');\n    }\n    const asset = new assets.Asset(this, 'GitlabRunnerUserDataAsset', {\n      path: path.join(__dirname, '../assets/userdata/amazon-cloudwatch-agent.json'),\n    });\n\n    const userData = ec2.UserData.forLinux();\n    userData.addS3DownloadCommand({\n      bucket: asset.bucket,\n      bucketKey: asset.s3ObjectKey,\n      localFile: '/opt/aws/amazon-cloudwatch-agent/etc/amazon-cloudwatch-agent.json',\n    });\n    userData.addCommands(...this.createUserData(runnerProps));\n\n    this.instanceRole =\n      runnerProps.instanceRole ??\n      new iam.Role(this, 'GitlabRunnerInstanceRole', {\n        assumedBy: new iam.ServicePrincipal('ec2.amazonaws.com'),\n        description: 'For EC2 Instance (Gitlab Runner) Role',\n        managedPolicies: [\n          iam.ManagedPolicy.fromAwsManagedPolicyName('AmazonSSMManagedInstanceCore'),\n          iam.ManagedPolicy.fromAwsManagedPolicyName('CloudWatchAgentServerPolicy'),\n          iam.ManagedPolicy.fromAwsManagedPolicyName('AmazonS3ReadOnlyAccess'),\n        ],\n      });\n\n    this.vpc = runnerProps.vpc ?? new ec2.Vpc(this, 'VPC');\n\n    this.securityGroup = new ec2.SecurityGroup(this, 'GitlabRunnerSecurityGroup', {\n      vpc: this.vpc,\n    });\n    const instanceProfile = new iam.CfnInstanceProfile(this, 'InstanceProfile', {\n      roles: [this.instanceRole.roleName],\n    });\n    const lt = new ec2.CfnLaunchTemplate(this, 'GitlabRunnerLaunchTemplate', {\n      launchTemplateData: {\n        imageId: ec2.MachineImage.latestAmazonLinux2().getImage(this).imageId,\n        instanceType: runnerProps.instanceType,\n        instanceMarketOptions: {\n          marketType: runnerProps.spotInstance ? 'spot' : undefined,\n          spotOptions: runnerProps.spotInstance ? {\n            spotInstanceType: 'one-time',\n          } : undefined,\n        },\n        userData: cdk.Fn.base64(userData.render()),\n        blockDeviceMappings: [\n          {\n            deviceName: '/dev/xvda',\n            ebs: {\n              volumeSize: runnerProps.ebsSize ?? 60,\n            },\n          },\n        ],\n        iamInstanceProfile: {\n          arn: instanceProfile.attrArn,\n        },\n        securityGroupIds: this.securityGroup.connections.securityGroups.map(\n          (m) => m.securityGroupId,\n        ),\n      },\n    });\n\n    this.autoscalingGroup = new asg.AutoScalingGroup(this, 'GitlabRunnerAutoscalingGroup', {\n      instanceType: new ec2.InstanceType(runnerProps.instanceType),\n      autoScalingGroupName: `Gitlab Runners (${runnerProps.instanceType})`,\n      vpc: this.vpc,\n      vpcSubnets: runnerProps.vpcSubnet,\n      machineImage: ec2.MachineImage.latestAmazonLinux2(),\n      minCapacity: runnerProps.minCapacity,\n      maxCapacity: runnerProps.maxCapacity,\n      desiredCapacity: runnerProps.desiredCapacity,\n    });\n\n    const cfnAsg = this.autoscalingGroup.node.tryFindChild('ASG') as asg.CfnAutoScalingGroup;\n    cfnAsg.addPropertyDeletionOverride('LaunchConfigurationName');\n    cfnAsg.addPropertyOverride('LaunchTemplate', {\n      LaunchTemplateId: lt.ref,\n      Version: lt.attrLatestVersionNumber,\n    });\n    this.autoscalingGroup.node.tryRemoveChild('LaunchConfig');\n\n    this.topicAlarm = new sns.Topic(this, 'GitlabRunnerAlarm');\n    const alarms = JSON.stringify(runnerProps.alarms);\n\n    // Put alarms at launch\n    const registerFunction = new lambda.Function(this, 'GitlabRunnerRegisterFunction', {\n      code: lambda.Code.fromAsset(path.join(__dirname, '../assets/functions')),\n      handler: 'autoscaling_events.register',\n      runtime: lambda.Runtime.PYTHON_3_8,\n      timeout: cdk.Duration.seconds(60),\n      logRetention: logs.RetentionDays.ONE_DAY,\n      environment: {\n        ALARMS: alarms,\n        SNS_TOPIC_ARN: this.topicAlarm.topicArn,\n      },\n    });\n    registerFunction.role?.addToPrincipalPolicy(\n      new iam.PolicyStatement({\n        effect: iam.Effect.ALLOW,\n        resources: ['*'],\n        actions: [\n          'cloudwatch:PutMetricAlarm',\n        ],\n      }),\n    );\n\n    this.autoscalingGroup.addLifecycleHook('GitlabRunnerLifeCycleHookLaunching', {\n      lifecycleTransition: asg.LifecycleTransition.INSTANCE_LAUNCHING,\n      notificationTarget: new FunctionHook(registerFunction),\n      defaultResult: asg.DefaultResult.CONTINUE,\n      heartbeatTimeout: cdk.Duration.seconds(60),\n    });\n\n    // Add an alarm action to terminate invalid instances\n    const alarmAction = new lambda.Function(this, 'GitlabRunnerAlarmAction', {\n      code: lambda.Code.fromAsset(path.join(__dirname, '../assets/functions')),\n      handler: 'autoscaling_events.on_alarm',\n      runtime: lambda.Runtime.PYTHON_3_8,\n      timeout: cdk.Duration.seconds(60),\n      logRetention: logs.RetentionDays.ONE_DAY,\n    });\n    alarmAction.role?.addToPrincipalPolicy(\n      new iam.PolicyStatement({\n        effect: iam.Effect.ALLOW,\n        resources: ['*'],\n        actions: [\n          'autoscaling:SetInstanceHealth',\n        ],\n      }),\n    );\n    const alarmSubscription = new subscriptions.LambdaSubscription(alarmAction);\n    this.topicAlarm.addSubscription(alarmSubscription);\n\n    // Unregister gitlab runners and remove alarms on instance termination or CFn stack deletion\n    const unregisterRole = new iam.Role(this, 'GitlabRunnerUnregisterRole', {\n      assumedBy: new iam.ServicePrincipal('lambda.amazonaws.com'),\n      description: 'For Gitlab Runner Unregistering Function Role',\n      managedPolicies: [\n        iam.ManagedPolicy.fromAwsManagedPolicyName('service-role/AWSLambdaBasicExecutionRole'),\n      ],\n    });\n    unregisterRole.addToPrincipalPolicy(\n      new iam.PolicyStatement({\n        effect: iam.Effect.ALLOW,\n        resources: ['*'],\n        actions: [\n          'ssm:SendCommand',\n          'autoscaling:DescribeAutoScalingGroups',\n          'cloudwatch:DeleteAlarms',\n        ],\n      }),\n    );\n\n    const unregisterFunction = new lambda.Function(this, 'GitlabRunnerUnregisterFunction', {\n      code: lambda.Code.fromAsset(path.join(__dirname, '../assets/functions')),\n      handler: 'autoscaling_events.unregister',\n      runtime: lambda.Runtime.PYTHON_3_8,\n      timeout: cdk.Duration.seconds(60),\n      role: unregisterRole,\n      logRetention: logs.RetentionDays.ONE_DAY,\n      environment: {\n        ALARMS: alarms,\n      },\n    });\n\n    this.autoscalingGroup.addLifecycleHook('GitlabRunnerLifeCycleHookTerminating', {\n      lifecycleTransition: asg.LifecycleTransition.INSTANCE_TERMINATING,\n      notificationTarget: new FunctionHook(unregisterFunction),\n      defaultResult: asg.DefaultResult.CONTINUE,\n      heartbeatTimeout: cdk.Duration.seconds(60),\n    });\n\n    const unregisterCustomResource = new lambda.Function(this, 'GitlabRunnerUnregisterCustomResource', {\n      code: lambda.Code.fromAsset(path.join(__dirname, '../assets/functions')),\n      handler: 'autoscaling_events.on_event',\n      runtime: lambda.Runtime.PYTHON_3_8,\n      role: unregisterRole,\n      logRetention: logs.RetentionDays.ONE_DAY,\n      environment: {\n        ALARMS: alarms,\n      },\n    });\n\n    const unregisterProvider = new cr.Provider(this, 'GitlabRunnerUnregisterProvider', {\n      onEventHandler: unregisterCustomResource,\n    });\n\n    const customResource = new cdk.CustomResource(this, 'GitlabRunnerCustomResource', {\n      serviceToken: unregisterProvider.serviceToken,\n      properties: {\n        AutoScalingGroupNames: [this.autoscalingGroup.autoScalingGroupName],\n      },\n    });\n    customResource.node.addDependency(unregisterProvider);\n\n    new cdk.CfnOutput(this, 'GitlabRunnerAutoScalingGroupArn', {\n      value: this.autoscalingGroup.autoScalingGroupArn,\n    });\n  }\n\n  private dockerVolumesList(dockerVolume: DockerVolumes[] | undefined): string {\n    let tempString: string = '--docker-volumes \"/var/run/docker.sock:/var/run/docker.sock\"';\n    if (dockerVolume) {\n      let tempList: string[] = [];\n      dockerVolume.forEach(e => {\n        tempList.push(`\"${e.hostPath}:${e.containerPath}\"`);\n      });\n      tempList.forEach(e => {\n        tempString = `${tempString} --docker-volumes ${e}`;\n      });\n    }\n    return tempString;\n  }\n  /**\n   * @param props\n   * @returns Array.\n   */\n  public createUserData(props: GitlabRunnerAutoscalingProps): string[] {\n    return [\n      'yum update -y',\n      'sleep 15 && amazon-linux-extras install docker && yum install -y amazon-cloudwatch-agent && systemctl start docker && usermod -aG docker ec2-user && chmod 777 /var/run/docker.sock',\n      'systemctl restart docker && systemctl enable docker && systemctl start amazon-cloudwatch-agent && systemctl enable amazon-cloudwatch-agent',\n      `docker run -d -v /home/ec2-user/.gitlab-runner:/etc/gitlab-runner -v /var/run/docker.sock:/var/run/docker.sock \\\n      --name gitlab-runner-register ${props.gitlabRunnerImage} register --non-interactive --url ${props.gitlabUrl} ${compare(props.gitlabRunnerVersion, '15.10', '>=') ? '--token' : '--registration-token'} ${props.gitlabToken} \\\n      --docker-pull-policy if-not-present ${this.dockerVolumesList(props?.dockerVolumes)} \\\n      --executor docker --docker-image \"alpine:latest\" --description \"A Runner on EC2 Instance (${props.instanceType})\" \\\n      ${compare(props.gitlabRunnerVersion, '15.10', '>=') ? undefined : `--tag-list \"${props.tags?.join(',')}\" `} --docker-privileged`,\n      `sleep 2 && docker run --restart always -d -v /home/ec2-user/.gitlab-runner:/etc/gitlab-runner -v /var/run/docker.sock:/var/run/docker.sock --name gitlab-runner ${props.gitlabRunnerImage}`,\n    ];\n  }\n}\n"]}
|
|
@@ -7,6 +7,11 @@ import { DockerVolumes } from './gitlab-runner-interfaces';
|
|
|
7
7
|
* GitlabContainerRunner Props.
|
|
8
8
|
*/
|
|
9
9
|
export interface GitlabContainerRunnerProps {
|
|
10
|
+
/**
|
|
11
|
+
* Gitlab Runner version
|
|
12
|
+
* Please give me gitlab runner version.
|
|
13
|
+
*/
|
|
14
|
+
readonly gitlabRunnerVersion: string;
|
|
10
15
|
/**
|
|
11
16
|
* Gitlab token for the Register Runner .
|
|
12
17
|
*
|
|
@@ -23,7 +28,7 @@ export interface GitlabContainerRunnerProps {
|
|
|
23
28
|
* @example
|
|
24
29
|
* new GitlabRunnerAutoscaling(stack, 'runner', { gitlabToken: 'GITLAB_TOKEN', gitlabRunnerImage: 'gitlab/gitlab-runner:alpine' });
|
|
25
30
|
*
|
|
26
|
-
* @default public.ecr.aws/gitlab/gitlab-runner:latest
|
|
31
|
+
* @default public.ecr.aws/gitlab/gitlab-runner:latest !!! <--- latest now > 16.0 Gitlab Runner version
|
|
27
32
|
*
|
|
28
33
|
*/
|
|
29
34
|
readonly gitlabRunnerImage?: string;
|
|
@@ -74,45 +79,10 @@ export interface GitlabContainerRunnerProps {
|
|
|
74
79
|
*
|
|
75
80
|
*/
|
|
76
81
|
readonly ec2iamrole?: IRole;
|
|
77
|
-
/**
|
|
78
|
-
* Gitlab Runner register tag1 .
|
|
79
|
-
*
|
|
80
|
-
* @example
|
|
81
|
-
* new GitlabContainerRunner(stack, 'runner', { gitlabtoken: 'GITLAB_TOKEN', tag1: 'aa' });
|
|
82
|
-
*
|
|
83
|
-
* @deprecated - use tags ['runner', 'gitlab', 'awscdk']
|
|
84
|
-
*
|
|
85
|
-
* @default - tag1: gitlab .
|
|
86
|
-
*
|
|
87
|
-
*/
|
|
88
|
-
readonly tag1?: string;
|
|
89
|
-
/**
|
|
90
|
-
* Gitlab Runner register tag2 .
|
|
91
|
-
*
|
|
92
|
-
* @example
|
|
93
|
-
* new GitlabContainerRunner(stack, 'runner', { gitlabtoken: 'GITLAB_TOKEN', tag2: 'bb' });
|
|
94
|
-
*
|
|
95
|
-
* @deprecated - use tags ['runner', 'gitlab', 'awscdk']
|
|
96
|
-
*
|
|
97
|
-
* @default - tag2: awscdk .
|
|
98
|
-
*
|
|
99
|
-
*/
|
|
100
|
-
readonly tag2?: string;
|
|
101
|
-
/**
|
|
102
|
-
* Gitlab Runner register tag3 .
|
|
103
|
-
*
|
|
104
|
-
* @example
|
|
105
|
-
* new GitlabContainerRunner(stack, 'runner', { gitlabtoken: 'GITLAB_TOKEN', tag3: 'cc' });
|
|
106
|
-
*
|
|
107
|
-
* @deprecated - use tags ['runner', 'gitlab', 'awscdk']
|
|
108
|
-
*
|
|
109
|
-
* @default - tag3: runner .
|
|
110
|
-
*
|
|
111
|
-
*/
|
|
112
|
-
readonly tag3?: string;
|
|
113
82
|
/**
|
|
114
83
|
* tags for the runner
|
|
115
|
-
*
|
|
84
|
+
* Unsupported Gitlab Runner 15.10 and later
|
|
85
|
+
* @see - https://docs.gitlab.com/ee/ci/runners/new_creation_workflow.html
|
|
116
86
|
* @default - ['runner', 'gitlab', 'awscdk']
|
|
117
87
|
*/
|
|
118
88
|
readonly tags?: string[];
|