Add nginx wait-for-service block for waiting srv-salt-pki.mount service
In case if /srv/salt/pki mounted by GlusterFS Nginx are getting failed
during boot because doesn't have require for srv-salt-pki.mount service.
Change-Id: I73b41df6f0a9e23a674059d0371902495fcf30a5
Related-Prod: PROD-32284
diff --git a/upgrade-mcp-release.groovy b/upgrade-mcp-release.groovy
index fbac400..5cd74ea 100644
--- a/upgrade-mcp-release.groovy
+++ b/upgrade-mcp-release.groovy
@@ -188,6 +188,26 @@
}
+def wa32284(String clusterName) {
+ def clientGluster = salt.getPillar(venvPepper, 'I@salt:master', "glusterfs:client:enabled").get("return")[0].values()[0]
+ def pkiGluster = salt.getPillar(venvPepper, 'I@salt:master', "glusterfs:client:volumes:salt_pki").get("return")[0].values()[0]
+ def nginxEnabledAtMaster = salt.getPillar(venvPepper, 'I@salt:master', 'nginx:server:enabled').get('return')[0].values()[0]
+ if (nginxEnabledAtMaster.toString().toLowerCase() == 'true' && clientGluster.toString().toLowerCase() == 'true' && pkiGluster) {
+ def nginxRequires = salt.getPillar(venvPepper, 'I@salt:master', 'nginx:server:wait_for_service').get('return')[0].values()[0]
+ if (nginxRequires.isEmpty()) {
+ def nginxRequiresClassName = "cluster.${clusterName}.infra.config.nginx_requires_wa32284"
+ def nginxRequiresClassFile = "/srv/salt/reclass/classes/cluster/${clusterName}/infra/config/nginx_requires_wa32284.yml"
+ def nginxRequiresBlock = ['parameters': ['nginx': ['server': ['wait_for_service': ['srv-salt-pki.mount'] ] ] ] ]
+ def _tempFile = '/tmp/wa32284_' + UUID.randomUUID().toString().take(8)
+ writeYaml file: _tempFile , data: nginxRequiresBlock
+ def nginxRequiresBlockString = sh(script: "cat ${_tempFile}", returnStdout: true).trim()
+ salt.cmdRun(venvPepper, 'I@salt:master', "cd /srv/salt/reclass/classes/cluster/${clusterName} && " +
+ "sed -i '/^parameters:/i - ${nginxRequiresClassName}' infra/config/init.yml")
+ salt.cmdRun(venvPepper, 'I@salt:master', "echo '${nginxRequiresBlockString}' > ${nginxRequiresClassFile}", false, null, false)
+ }
+ }
+}
+
def archiveReclassInventory(filename) {
def _tmp_file = '/tmp/' + filename + UUID.randomUUID().toString().take(8)
// jenkins may fail at overheap. Compress data with gzip like WA
@@ -351,6 +371,8 @@
"grep -r --exclude-dir=aptly -l 'jenkins_security_ldap_server: .*' * | xargs --no-run-if-empty sed -i 's|jenkins_security_ldap_server: .*|jenkins_security_ldap_server: \"ldaps://${jenkinsldapURI}\"|g'")
}
+ wa32284(cluster_name)
+
salt.cmdRun(venvPepper, 'I@salt:master', "cd /srv/salt/reclass/classes/system && git checkout ${reclassSystemBranch}")
// Add kubernetes-extra repo
if (salt.testTarget(venvPepper, "I@kubernetes:master")) {