-
Notifications
You must be signed in to change notification settings - Fork 24
/
Copy pathmanifest.yml
269 lines (236 loc) · 9.46 KB
/
manifest.yml
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
jpsType: install
jpsVersion: '1.7.4'
id: magento-cluster
homepage: https://github.com/jelastic-jps/magento-cluster/tree/v2.2.0
description:
text: Auto-scalable and highly-available cluster for Premium level Magento eCommerce hosting
with out-of-box auto-scaling, load and traffic distribution, database replication, page caching and user session storage.
short: Auto-scalable and highly-available Magento cluster with load balancing,
data replication, content caching and user session storage.
categories:
- apps/clusters
- apps/e-commerce
name: Auto-Scalable Magento Cluster v2
logo: /images/magento-enterprise-small-v2.png
baseUrl: https://raw.githubusercontent.com/jelastic-jps/magento-cluster/v2.2.0
onBeforeInstall: /scripts/beforeinstall.js?_r=${fn.random}
onBeforeInit: /scripts/beforeinit.js?_r=${fn.random}
nodes: definedInOnBeforeInstall
skipNodeEmails: true
settings:
fields:
- caption: Scaling Strategy
type: list
name: loadGrowth
default: slow
required: true
width: 225
tooltip: |
Configure auto-scaling triggers, i.e. how fast the system responds to load spikes by adding or removing nodes.
<p>Read more about <a href="https://docs.jelastic.com/automatic-horizontal-scaling">Automatic Horizontal Scaling</a></p>
values:
- value: slow
caption: Low Load
tooltip: <h2>Low load scaling strategy</h2>add 1 new node when CPU > 70% <p>remove when CPU < 20%</p>
- value: medium
caption: Medium Load
tooltip: <h3>Medium load scaling strategy</h3>add 1 new node when CPU > 50% <p>remove when CPU < 20%</p>
- value: fast
caption: High Load
tooltip: <h3>High load scaling strategy</h3>add 2 new nodes when CPU > 30% <p>remove when CPU < 10%</p>
- caption: Advanced Features
type: displayfield
name: displayfield
markup:
- caption: Web Application Firewall
type: checkbox
name: waf
value: true
disabled: false
tooltip: "Protect web sites with <a href='https://www.litespeedtech.com/support/wiki/doku.php/litespeed_wiki:waf' target='_blank'>LiteSpeed built-in WAF</a> based on Free ModSecurity Rules from Comodo"
- caption: Install Let's Encrypt SSL with Auto-Renewal
type: checkbox
name: le_addon
value: true
disabled: false
tooltip: "Advanced integration with Let's Encrypt certificate authority that simplifies and automates the process of issuing, configuring and updating trusted custom SSL certificates."
- caption: Install Lightning-Fast Premium CDN
type: checkbox
name: cdn_addon
value: false
hidden: true
disabled: false
tooltip: "Jelastic CDN is an HTTP/3 premium content delivery network of 160+ Super PoPs (points of presence) with bandwidth capacity up to 115 Tbps, advanced caching and acceleration strategies based on best-in-class IP Anycast technology."
- type: displayfield
hideLabel: true
hidden: true
name: bl_count
value: 1
markup:
mixins:
- https://raw.githubusercontent.com/jelastic-jps/magento-cluster/master/configs/vers.yaml
globals:
DB_USER: ${settings.DB_USER:user-[fn.random]}
DB_PASS: ${settings.DB_PASS:[fn.password(10)]}
DB_HOST: sqldb
ES_PASS: ${settings.ES_PASS:[fn.password(10)]}
PROTOCOL: http
MG_ADMIN_PASS: ${settings.MG_ADMIN_PASS:[fn.password(10)]}
LS_ADMIN_PASS: ${settings.LS_ADMIN_PASS:[fn.password(10)]}
SUCCESS: success
EMAIL: default
onInstall:
- addLimits
- setProtocol
- setDomain
- if (${settings.is_trigger:true}):
- log: Auto Scaling Triggers
- script: /scripts/addTriggers.js
nodeGroup: cp
resourceType: CPU
loadGrowth: ${settings.loadGrowth}
cleanOldTriggers: true
scaleDownLimit: ${nodes.cp.length}
- storageHealthCheck
- mountStorageByGroup: NFS4
- setupNodes
- setupOpenSearch
- initLEsettings
- installMagento
- if (('${settings.le_addon:false}' == 'true') || ('${settings.cdn_addon:false}' == 'true')):
- script: |
var actions = [];
if ('${settings.le_addon:false}' == 'true')
actions.push({
jps: "https://github.com/jelastic-jps/lets-encrypt/blob/master/manifest.jps?_r=${fn.random}?_r=${fn.random}",
nodeGroup: "bl",
skipEmail: "true",
settings: {
test: false,
customDomains: "${globals.DOMAIN}",
fallbackToX1: true,
webroot: true,
webrootPath: "/var/www/webroot/ROOT/pub"
}
});
if ('${settings.cdn_addon:false}' == 'true')
actions.push({
jps: "https://raw.githubusercontent.com/jelastic-jps/cdn/master/manifest.yml?_r=${fn.random}",
nodeGroup: "bl",
skipEmail: "true",
settings: {
note: "${settings.noteCDN:}"
}
});
return { result: 0, onAfterReturn: { install: actions } };
- if ('${settings.le_addon:false}' == 'true'): setupLEdomain
- if ('${settings.cdn_addon:false}' == 'true'): setupCDN
- install:
- jps: /scripts/events.jps?_r=${fn.random}
- jps: /scripts/addons.jps?_r=${fn.random}
actions:
addLimits:
- env.control.ApplyNodeGroupData [sqldb]:
data:
validation :
maxCount: 2
setProtocol:
- if (${settings.le_addon:false}):
setGlobals:
PROTOCOL: https
setDomain:
- script: /scripts/idna.js
domains: ${env.domain}
- setGlobals:
DOMAIN: ${response.domains}
setupNodes:
- log: Nodes configurations
- install:
- jps: https://raw.githubusercontent.com/jelastic/templates/master/config_v2.jps?_r=${fn.random}
settings:
targetGroup: bl
targetNodes: bl
optimization: magento
- jps: https://raw.githubusercontent.com/jelastic/templates/master/config_v2.jps?_r=${fn.random}
settings:
targetGroup: cp
targetNodes: cp
optimization: magento
- jps: https://raw.githubusercontent.com/jelastic/templates/master/config_v2.jps?_r=${fn.random}
settings:
targetGroup: sqldb
targetNodes: sqldb
optimization: magento
- cmd[cp, bl]: if test -f /usr/local/sbin/optimization.sh; then bash /usr/local/sbin/optimization.sh &>> /var/log/run.log; fi
- cmd[cp, bl]: jem passwd set -p ${globals.LS_ADMIN_PASS}
user: root
setupLEdomain:
- cmd[${nodes.cp.master.id}]: |-
source /opt/letsencrypt/settings;
bash ~/bin/japp.sh domain $domain;
bash ~/bin/japp.sh ssl on;
initLEsettings:
- cmd[cp, bl]: |-
[ ! -d /var/lib/jelastic/keys/letsencrypt ] && mkdir -p /var/lib/jelastic/keys/letsencrypt;
echo "webroot=true" > /var/lib/jelastic/keys/letsencrypt/settings-custom;
echo "webrootPath=/var/www/webroot/ROOT/pub" >> /var/lib/jelastic/keys/letsencrypt/settings-custom;
echo "test=false" >> /var/lib/jelastic/keys/letsencrypt/settings-custom;
user: root
setupCDN:
- script: return jelastic.dev.scripting.Eval("c05ffa5b45628a2a0c95467ebca8a0b4", session, "cdn.info", {partnerCode:1})
- setGlobals:
CDN: ${env.envName}-${response.response.partnerCode}.cdn.jelastic.net
SUCCESS: success-cdn
EMAIL: cdn
- cmd[${nodes.cp.master.id}]: bash ~/bin/japp.sh edgeportCDN --cdn-url ${globals.CDN}
installMagento:
- install: /scripts/install.jps
settings:
db_host: ${globals.DB_HOST}
db_user: ${globals.DB_USER}
db_pass: ${globals.DB_PASS}
es_host: nosqldb
es_pass: ${globals.ES_PASS}
mg_admin_pass: ${globals.MG_ADMIN_PASS}
mg_url: ${globals.PROTOCOL}://${globals.DOMAIN}/
version: ${globals.version_magento}
user_email: ${user.email}
- cmd[cp]: sudo jem service restart
updateTriggers:
if (!${event.params.auto:true}):
- log: update scaling trigger
- script: /scripts/updateTriggers.js
count: ${nodes.cp.length}
mountStorageByGroup:
- log: Mount Storage by Group
- api:
- method: jelastic.environment.file.AddMountPointByGroup
params:
nodeGroup: cp
sourceNodeId: ${nodes.storage.master.id}
sourcePath: /data
path: /var/www/webroot/ROOT
sourceAddressType: NODE_GROUP
protocol: ${this}
storageHealthCheck:
- cmd[cp]: |-
[ ! -d /var/www/webroot/ROOT/pub ] && mkdir /var/www/webroot/ROOT/pub;
echo "<?php http_response_code(500); ?>" > /var/www/webroot/ROOT/health_check.php;
echo "<?php http_response_code(500); ?>" > /var/www/webroot/ROOT/pub/health_check.php;
setupOpenSearch:
- cmd[nosqldb]: |-
jem passwd set -p ${globals.ES_PASS}
sed -i "s/plugins.security.ssl.http.enabled.*/plugins.security.ssl.http.enabled: false/" /etc/opensearch/opensearch.yml;
iptables -t nat -I PREROUTING -p tcp -m tcp --dport 4949 -j REDIRECT --to-ports 9200;
iptables-save > /etc/sysconfig/iptables4-jelastic-nat;
jem service restart
user: root
- env.control.ApplyNodeGroupData[nosqldb]:
data:
adminUrl: "http://node${nodes.nosqldb.master.id}-${env.domain}:4949"
validation :
maxCount: 1
success:
email: success/email/${nodes.cp.master.nodeType}/oneregion-${globals.EMAIL}.md?_r=${fn.random}
text: success/text/oneregion/${globals.SUCCESS}.md?_r=${fn.random}
startPage: ${globals.PROTOCOL}://${env.domain}/