-
Notifications
You must be signed in to change notification settings - Fork 6
/
Copy pathprod.ts
82 lines (73 loc) · 2.36 KB
/
prod.ts
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
import { InstanceType } from "aws-cdk-lib/aws-ec2";
import { KubernetesVersion } from "aws-cdk-lib/aws-eks";
import { PostgresEngineVersion } from "aws-cdk-lib/aws-rds";
import { DESTROY_WHEN_REMOVE, EC2_INSTANCE_MAP, RDS_INSTANCE_MAP, REDIS_NODE_MAP } from "./constants";
import { StackConfig } from "./stackConfig";
export interface ProdStackConfig extends StackConfig {
}
export const prodConfig: ProdStackConfig = {
environment: 'Prod',
region: process.env.CDK_PROD_REGION || process.env.CDK_DEFAULT_REGION || '',
account: process.env.CDK_PROD_ACCOUNT || process.env.CDK_DEFAULT_ACCOUNT || '',
cluster: {
version: KubernetesVersion.V1_30,
tags: { "marketplace": "dify" },
// at least 2 ids
vpcSubnetIds: process.env.EKS_CLUSTER_SUBNETS?.trim().split(',').filter(id => id.length > 0) || [],
managedNodeGroups: {
app: {
desiredSize: 3,
minSize: 1,
maxSize: 6,
instanceType: new InstanceType(EC2_INSTANCE_MAP['8c32m']),
diskSize: 100,
// at least 2 ids
workerNodeSubnetIds: process.env.EKS_NODES_SUBNETS?.trim().split(',').filter(id => id.length > 0) || []
}
},
},
s3: {
removeWhenDestroyed: DESTROY_WHEN_REMOVE || false,
},
postgresSQL: {
version: PostgresEngineVersion.VER_14_9,
instanceType: new InstanceType(RDS_INSTANCE_MAP['4c32m']),
dbName: 'postgres',
dbCredentialUsername: 'clusteradmin',
backupRetention: 0,
storageSize: 512,
removeWhenDestroyed: DESTROY_WHEN_REMOVE,
// at least 2 ids
subnetIds: process.env.RDS_SUBNETS?.trim().split(',').filter(id => id.length > 0) || [],
multiAz: {
enabled: false,
subnetGroupName: ''
}
},
redis: {
engineVersion: "6.2",
parameterGroup: "default.redis6.x",
nodeType: REDIS_NODE_MAP['12.93m'],
readReplicas: 1,
subnetIds: process.env.REDIS_SUBNETS?.trim().split(',').filter(id => id.length > 0) || [],
multiAZ: {
enabled: false,
subnetGroupName: ''
},
},
openSearch: {
enabled: true,
multiAz: {
enabled: false,
azCount: 2
},
subnetIds: process.env.OPENSEARCH_SUBNETS?.trim().split(',').filter(id => id.length > 0) || [],
capacity: {
dataNodes: 2,
dataNodeInstanceType: 'r6g.large.search',
// masterNodes: 2,
// masterNodeInstanceType: 'r6g.xlarge.search'
},
dataNodeSize: 100
}
}