forked from ExpediaGroup/apiary-lifecycle
-
Notifications
You must be signed in to change notification settings - Fork 0
/
variables.tf
566 lines (462 loc) · 14.4 KB
/
variables.tf
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
/**
* Copyright (C) 2019-2021 Expedia, Inc.
*
* Licensed under the Apache License, Version 2.0 (the "License");
*/
# Global
variable "instance_name" {
description = "Beekeeper instance name to identify resources in multi-instance deployments."
type = string
default = ""
}
variable "instance_type" {
description = "Service to run Beekeeper on. Supported services: `ecs` (default), `k8s`. Leaving this blank will still deploy auxiliary components (e.g. RDS, SQS etc.)."
type = string
default = "ecs"
}
variable "aws_region" {
description = "AWS region to use for resources."
type = string
}
variable "vpc_id" {
description = "VPC in which to install Beekeeper."
type = string
}
variable "subnets" {
description = "Subnets in which to install Beekeeper."
type = list(string)
}
variable "beekeeper_tags" {
description = "A map of tags to apply to resources."
type = map(string)
}
# RDS specific
variable "rds_subnets" {
description = "Subnets in which to provision Beekeeper RDS DB."
type = list(string)
}
variable "rds_allocated_storage" {
description = "RDS allocated storage in GBs."
default = 20
type = string
}
variable "rds_max_allocated_storage" {
description = "RDS max allocated storage (autoscaling) in GBs."
default = 100
type = string
}
variable "rds_storage_type" {
description = "RDS storage type."
default = "gp3"
type = string
}
variable "rds_instance_class" {
description = "RDS instance class."
default = "db.t2.micro"
type = string
}
variable "rds_engine_version" {
description = "RDS engine version."
default = "8.0"
type = string
}
variable "rds_parameter_group_name" {
description = "RDS parameter group."
default = "default.mysql8.0"
type = string
}
variable "db_username" {
description = "Username for the master DB user."
default = "beekeeper"
type = string
}
variable "db_password_key" {
description = "Key to acquire the database password for the strategy specified."
type = string
}
variable "db_backup_retention" {
description = "The number of days to retain backups for the RDS Beekeeper DB."
type = number
default = 10
}
variable "db_backup_window" {
description = "Preferred backup window for the RDS Beekeeper DB in UTC."
type = string
default = "02:00-03:00"
}
variable "db_maintenance_window" {
description = "Preferred maintenance window for the RDS Beekeeper DB in UTC."
type = string
default = "wed:03:00-wed:04:00"
}
variable "db_apply_immediately" {
description = "Specifies whether any database modifications are applied immediately, or during the next maintenance window."
type = bool
default = false
}
variable "db_performance_insights_enabled" {
description = "Specifies whether Performance Insights are enabled."
type = bool
default = true
}
# SQS specific
variable "queue_name" {
description = "Beekeeper SQS Queue name."
type = string
default = "apiary-beekeeper"
}
variable "message_retention_seconds" {
description = "SQS message retention (s)."
type = number
default = 604800
}
variable "receive_wait_time_seconds" {
description = "SQS receive wait time (s)."
type = number
default = 20
}
variable "apiary_metastore_listener_arn" {
description = "ARN of the Apiary Metastore Listener."
type = string
}
variable "queue_stale_messages_timeout" {
description = "Beekeeper SQS Queue Cloudwatch Alert timeout for messages older than this number of seconds."
type = number
default = 1209600
}
# ECS specific
variable "scheduler_apiary_docker_image" {
description = "Beekeeper Scheduler Apiary image."
type = string
default = "expediagroup/beekeeper-scheduler-apiary"
}
variable "scheduler_apiary_docker_image_version" {
description = "Beekeeper Scheduler Apiary image version."
type = string
default = "latest"
}
variable "scheduler_apiary_ecs_cpu" {
description = <<EOF
The amount of CPU used to allocate for the Beekeeper Scheduler Apiary ECS task.
Valid values: https://docs.aws.amazon.com/AmazonECS/latest/developerguide/task-cpu-memory-error.html
EOF
default = 2048
type = number
}
variable "scheduler_apiary_ecs_memory" {
description = <<EOF
The amount of memory (in MiB) used to allocate for the Beekeeper Scheduler Apiary container.
Valid values: https://docs.aws.amazon.com/AmazonECS/latest/developerguide/task-cpu-memory-error.html
EOF
default = 4096
type = number
}
variable "path_cleanup_docker_image" {
description = "Beekeeper Path Cleanup docker image."
type = string
default = "expediagroup/beekeeper-path-cleanup"
}
variable "path_cleanup_docker_image_version" {
description = "Beekeeper Path Cleanup docker image version."
type = string
default = "latest"
}
variable "path_cleanup_ecs_cpu" {
description = <<EOF
The amount of CPU used to allocate for the Beekeeper Path Cleanup ECS task.
Valid values: https://docs.aws.amazon.com/AmazonECS/latest/developerguide/task-cpu-memory-error.html
EOF
default = 2048
type = number
}
variable "path_cleanup_ecs_memory" {
description = <<EOF
The amount of memory (in MiB) used to allocate for the Beekeeper Path Cleanup container.
Valid values: https://docs.aws.amazon.com/AmazonECS/latest/developerguide/task-cpu-memory-error.html
EOF
default = 4096
type = number
}
variable "metadata_cleanup_docker_image" {
description = "Beekeeper Metadata Cleanup docker image."
type = string
default = "expediagroup/beekeeper-metadata-cleanup"
}
variable "metadata_cleanup_docker_image_version" {
description = "Beekeeper Metadata Cleanup docker image version."
type = string
default = "latest"
}
variable "docker_registry_secret_name" {
description = "Docker Registry authentication K8S secret name."
type = string
default = ""
}
variable "docker_registry_auth_secret_name" {
description = "Docker Registry authentication SecretManager secret name."
type = string
default = ""
}
variable "api_docker_image" {
description = "Beekeeper API image."
type = string
default = "expediagroup/beekeeper-api"
}
variable "api_docker_image_version" {
description = "Beekeeper API docker image version."
type = string
default = "latest"
}
# Application specific
variable "allowed_s3_buckets" {
description = "List of S3 Buckets to which Beekeeper will have read-write access."
type = list(string)
default = []
}
variable "scheduler_delay_ms" {
description = "Delay between each cleanup job that is scheduled in milliseconds."
type = number
default = 300000
}
variable "path_cleanup_dry_run_enabled" {
description = "Enable Path Cleanup to perform dry runs of deletions only."
default = "false"
type = string
}
variable "metadata_cleanup_dry_run_enabled" {
description = "Enable Metadata Cleanup to perform dry runs of deletions only."
default = "false"
type = string
}
# Monitoring
variable "graphite_enabled" {
description = "Enable to produce Graphite metrics - true or false."
default = "false"
type = string
}
variable "graphite_host" {
description = "Graphite metrics host."
default = "localhost"
type = string
}
variable "graphite_prefix" {
description = "Prefix for Graphite metrics."
default = ""
type = string
}
variable "graphite_port" {
description = "Graphite port."
default = 2003
type = number
}
variable "prometheus_enabled" {
description = "Enable to pull metrics using Prometheus - true or false."
default = "false"
type = string
}
variable "metastore_uri" {
description = "URI of the metastore where tables to be cleaned-up are located. Required for Beekeeper Metadata Cleanup"
default = ""
type = string
}
# K8S Configuration
variable "k8s_app_name" {
description = "Name to give to all Kubernetes resources that are deployed."
default = ""
type = string
}
variable "k8s_kiam_role_arn" {
description = "KIAM role arn to use for creating a K8S IAM role with the correct assume role permissions."
default = ""
type = string
}
variable "oidc_provider" {
description = "EKS cluster OIDC provider name, required for configuring IAM using IRSA."
type = string
default = ""
}
variable "k8s_db_password_secret" {
description = "Name of the Kubernetes secret that would store the db password for beekeeper."
default = "beekeeper-db-password"
type = string
}
variable "k8s_namespace" {
description = "Namespace to deploy all Kubernetes resources to."
default = "beekeeper"
type = string
}
variable "k8s_image_pull_policy" {
description = "Policy for the Kubernetes orchestrator to pull images."
default = "Always"
type = string
}
variable "k8s_node_affinity" {
description = "Full node_affinity object as per terraform/Kubernetes docs."
default = {}
type = object({})
}
variable "k8s_node_selector" {
description = "Full node_selector object as per terraform/Kubernetes docs."
default = {}
type = object({})
}
variable "k8s_node_tolerations" {
description = "Full k8s_node_tolerations object as per terraform/Kubernetes docs."
default = {}
type = object({})
}
variable "k8s_ingress_enabled" {
description = "Boolean flag to determine if we should create an ingress or not. (0 = off, 1 = on)."
default = 0
type = number
}
variable "k8s_ingress_tls_hosts" {
description = "List of hosts for TLS configuration of a Kubernetes ingress."
default = []
type = list(string)
}
variable "k8s_ingress_tls_secret" {
description = "Secret name for TLS configuration of a Kubernetes ingress."
default = ""
type = string
}
# K8S - path cleanup deployment
variable "k8s_path_cleanup_memory" {
description = "Total memory to allot to the Beekeeper Path Cleanup pod."
default = "2Gi"
type = string
}
variable "k8s_path_cleanup_cpu" {
description = "Total cpu to allot to the Beekeeper Path Cleanup pod."
default = "500m"
type = string
}
variable "k8s_path_cleanup_port" {
description = "Internal port that the Beekeeper Path Cleanup service runs on."
default = 8008
type = number
}
variable "k8s_path_cleanup_liveness_delay" {
description = "Liveness delay (in seconds) for the Beekeeper Path Cleanup service."
default = 60
type = number
}
variable "k8s_path_cleanup_ingress_host" {
description = "Ingress host name for Beekeeper Path Cleanup."
default = ""
type = string
}
variable "k8s_path_cleanup_ingress_path" {
description = "Ingress path regex for Beekeeper Path Cleanup."
default = ""
type = string
}
# K8S - metadata cleanup deployment
variable "k8s_metadata_cleanup_memory" {
description = "Total memory to allot to the Beekeeper Metadata Cleanup pod."
default = "2Gi"
type = string
}
variable "k8s_metadata_cleanup_cpu" {
description = "Total cpu to allot to the Beekeeper Metadata Cleanup pod."
default = "500m"
type = string
}
variable "k8s_metadata_cleanup_port" {
description = "Internal port that the Beekeeper Metadata Cleanup service runs on."
default = 9008
type = number
}
variable "k8s_metadata_cleanup_liveness_delay" {
description = "Liveness delay (in seconds) for the Beekeeper Metadata Cleanup service."
default = 60
type = number
}
variable "k8s_metadata_cleanup_ingress_host" {
description = "Ingress host name for Beekeeper Metadata Cleanup."
default = ""
type = string
}
variable "k8s_metadata_cleanup_ingress_path" {
description = "Ingress path regex for Beekeeper Metadata Cleanup."
default = ""
type = string
}
# K8S - API deployment
variable "k8s_api_memory" {
description = "Total memory to allot to the Beekeeper API pod."
default = "1Gi"
type = string
}
variable "k8s_api_cpu" {
description = "Total cpu to allot to the Beekeeper API pod."
default = "500m"
type = string
}
variable "k8s_beekeeper_api_port" {
description = "Internal port that the Beekeeper API service runs on."
default = 7008
type = number
}
variable "k8s_api_liveness_delay" {
description = "Liveness delay (in seconds) for the Beekeeper API service."
default = 60
type = number
}
variable "k8s_api_ingress_host" {
description = "Ingress host name for Beekeeper API."
default = ""
type = string
}
variable "k8s_api_ingress_path" {
description = "Ingress path regex for Beekeeper API."
default = ""
type = string
}
# K8S - Scheduler Apiary deployment
variable "k8s_scheduler_apiary_memory" {
description = "Total memory to allot to the Beekeeper Scheduler Apiary pod."
default = "2Gi"
type = string
}
variable "k8s_scheduler_apiary_cpu" {
description = "Total cpu to allot to the Beekeeper Scheduler Apiary pod."
default = "500m"
type = string
}
variable "k8s_scheduler_apiary_port" {
description = "Internal port that the Beekeeper Scheduler Apiary service runs on."
default = 8080
type = number
}
variable "k8s_scheduler_apiary_liveness_delay" {
description = "Liveness delay (in seconds) for the Beekeeper Scheduler Apiary service."
default = 60
type = number
}
variable "k8s_scheduler_apiary_ingress_host" {
description = "Ingress host name for Beekeeper Scheduler Apiary."
default = ""
type = string
}
variable "k8s_scheduler_apiary_ingress_path" {
description = "Ingress path regex for Beekeeper Scheduler Apiary."
default = ""
type = string
}
# Lambda slack notifier
variable "slack_lambda_enabled" {
description = "Boolean flag to determine if Beekeeper should create a Slack notifying Lambda for the dead letter queue. (0 = off, 1 = on)."
default = 0
type = number
}
variable "slack_channel" {
description = "Slack channel to which alerts about messages landing on the dead letter queue should be sent."
default = ""
type = string
}
variable "slack_webhook_url" {
description = "Slack URL to which alerts about messages landing on the dead letter queue should be sent."
default = ""
type = string
}