440 lines
18 KiB
XML
440 lines
18 KiB
XML
<workflow>
|
|
|
|
<rule match="$.services[?(@.type == 'msSqlClusterServer' and @.domain)].units[*]"
|
|
desc="Units of SQL Server Cluster services which are part of the domain">
|
|
<set path="domain">
|
|
<select path="::domain"/>
|
|
</set>
|
|
<mute/>
|
|
</rule>
|
|
|
|
<rule match="$.services[?(@.type == 'msSqlClusterServer' and @.osImage.name)].units[?(@.state.hostname and not @.temp.instanceName)]"
|
|
desc="Units of SQL Server Cluster services having hostname and image names assigned but without instances">
|
|
<report entity="unit">
|
|
<parameter name="id"><select path="id"/></parameter>
|
|
<parameter name="text">Creating instance <select path="state.hostname"/> (<select path="name"/>)</parameter>
|
|
</report>
|
|
<update-cf-stack template="Windows" error="exception">
|
|
<parameter name="mappings">
|
|
<map>
|
|
<mapping name="instanceName"><select path="state.hostname"/></mapping>
|
|
<mapping name="instancePort">port-<select path="state.hostname"/></mapping>
|
|
<mapping name="networkName">network-<select path="/id"/></mapping>
|
|
<mapping name="userData">
|
|
<prepare-user-data>
|
|
<parameter name="hostname"><select path="state.hostname"/></parameter>
|
|
<parameter name="unit"><select path="id"/></parameter>
|
|
<parameter name="service"><select path="::id"/></parameter>
|
|
</prepare-user-data>
|
|
</mapping>
|
|
<mapping name="instanceType"><select path="::flavor" default="m1.medium"/></mapping>
|
|
<mapping name="imageName"><select path="::osImage.name"/></mapping>
|
|
<mapping name="availabilityZone"><select path="::availabilityZone" default="nova"/></mapping>
|
|
</map>
|
|
</parameter>
|
|
<success>
|
|
<set path="temp.instanceName"><select path="name"/></set>
|
|
<report entity="unit">
|
|
<parameter name="id"><select path="id"/></parameter>
|
|
<parameter name="text">Instance <select path="state.hostname"/> (<select path="name"/>) created</parameter>
|
|
</report>
|
|
</success>
|
|
<failure>
|
|
<report entity="unit" level="error">
|
|
<parameter name="id"><select path="id"/></parameter>
|
|
<parameter name="text">Unable to deploy instance <select path="state.hostname"/> (<select path="name"/>) due to <format-error error="exception"/></parameter>
|
|
</report>
|
|
<stop/>
|
|
</failure>
|
|
</update-cf-stack>
|
|
|
|
<report entity="unit">
|
|
<parameter name="id"><select path="id"/></parameter>
|
|
<parameter name="text">Applying address pair and opening SQL ports on <select path="state.hostname"/> (<select path="name"/>)</parameter>
|
|
</report>
|
|
<update-cf-stack template="SQLCluster" error="exception">
|
|
<parameter name="mappings">
|
|
<map>
|
|
<mapping name="instancePort">port-<select path="state.hostname"/></mapping>
|
|
<mapping name="clusterIp"><select path="::clusterIp"/></mapping>
|
|
</map>
|
|
</parameter>
|
|
<success>
|
|
<report entity="unit">
|
|
<parameter name="id"><select path="id"/></parameter>
|
|
<parameter name="text">Address pair and SQL ports are open on <select path="state.hostname"/> (<select path="name"/>)</parameter>
|
|
</report>
|
|
</success>
|
|
<failure>
|
|
<report entity="unit" level="error">
|
|
<parameter name="id"><select path="id"/></parameter>
|
|
<parameter name="text">Unable to assign address pair and open SQL ports on instance <select path="state.hostname"/> (<select path="name"/>) due to <select source="exception" path="message" default="unknown Heat error"/> </parameter>
|
|
</report>
|
|
<stop/>
|
|
</failure>
|
|
</update-cf-stack>
|
|
</rule>
|
|
|
|
<rule match="$.services[?(@.type == 'msSqlClusterServer' and @.domain and not @.domainAdminUserName and not @.domainAdminPassword)]"
|
|
desc="SQL Server Cluster service instance with domain configured but without admin account name/password">
|
|
<set path="#service">
|
|
<select/>
|
|
</set>
|
|
<rule desc="Domain controller exists with the assigned DNS IP">
|
|
<parameter name="match">/$.services[?(@.type == 'activeDirectory' and @.domain == '<select path="domain"/>')]</parameter>
|
|
<set path="domainAdminUserName" target="service"><select path="adminAccountName" default="Administrator"/></set>
|
|
<set path="domainAdminPassword" target="service"><select path="adminPassword"/></set>
|
|
</rule>
|
|
</rule>
|
|
|
|
<rule match="$.services[?(@.type == 'msSqlClusterServer' and @.adminPassword and @.adminPassword != @.state.adminPassword)].units[?(@.temp.instanceName)]"
|
|
desc="Units of SQL Server Cluster services which have got an instance deployed but has not got a correct admin password">
|
|
<send-command template="SetPassword" error="exception">
|
|
<parameter name="unit">
|
|
<select path="id"/>
|
|
</parameter>
|
|
<parameter name="service">
|
|
<select path="::id"/>
|
|
</parameter>
|
|
<parameter name="mappings">
|
|
<map>
|
|
<mapping name="adminPassword">
|
|
<select path="::adminPassword"/>
|
|
</mapping>
|
|
</map>
|
|
</parameter>
|
|
<success>
|
|
<set path="::state.adminPassword">
|
|
<select path="::adminPassword"/>
|
|
</set>
|
|
</success>
|
|
<failure>
|
|
<report entity="unit" level="warning">
|
|
<parameter name="id"><select path="id"/></parameter>
|
|
<parameter name="text">Unable to set admin password on unit <select path="state.hostname"/> (<select path="name"/>) due to <format-error error="exception"/></parameter>
|
|
</report>
|
|
<mute/>
|
|
</failure>
|
|
</send-command>
|
|
</rule>
|
|
|
|
<rule match="$.services[?(@.type == 'msSqlClusterServer')].units[?(@.state.domain and not @.state.failoverClusterPrerequisitesInstalled)]"
|
|
desc="Units of SQL Server Cluster services that are already joined AD domain">
|
|
<send-command template="SqlServerCluster/FailoverClusterPrerequisites" error="exception">
|
|
<parameter name="unit">
|
|
<select path="id"/>
|
|
</parameter>
|
|
<parameter name="service">
|
|
<select path="::id"/>
|
|
</parameter>
|
|
<parameter name="mappings">
|
|
<map>
|
|
<mapping name="domainAdminAccountName">
|
|
<select path="::domainAdminUserName"/>
|
|
</mapping>
|
|
<mapping name="domainAdminAccountPassword">
|
|
<select path="::domainAdminPassword"/>
|
|
</mapping>
|
|
<mapping name="domainName">
|
|
<select path="state.domain"/>
|
|
</mapping>
|
|
</map>
|
|
</parameter>
|
|
<success>
|
|
<set path="state.failoverClusterPrerequisitesInstalled"><true/></set>
|
|
<report entity="unit">
|
|
<parameter name="id"><select path="id"/></parameter>
|
|
<parameter name="text">Failover cluster prerequisites installed on unit <select path="state.hostname"/> (<select path="name"/>)</parameter>
|
|
</report>
|
|
</success>
|
|
<failure>
|
|
<report entity="unit" level="error">
|
|
<parameter name="id"><select path="id"/></parameter>
|
|
<parameter name="text">Unable to install prerequisites on unit <select path="state.hostname"/> (<select path="name"/>) due to <format-error error="exception"/></parameter>
|
|
</report>
|
|
<stop/>
|
|
</failure>
|
|
</send-command>
|
|
</rule>
|
|
|
|
<rule match="$.services[?(@.type == 'msSqlClusterServer' and not @.state.failoverClusterCreated)].units[?(@.state.failoverClusterPrerequisitesInstalled)]" limit="1"
|
|
desc="First unit of SQL Server Cluster services that is already has failover cluster prerequisites installed">
|
|
<send-command template="SqlServerCluster/FailoverCluster" error="exception">
|
|
<parameter name="unit">
|
|
<select path="id"/>
|
|
</parameter>
|
|
<parameter name="service">
|
|
<select path="::id"/>
|
|
</parameter>
|
|
<parameter name="mappings">
|
|
<map>
|
|
<mapping name="clusterName">
|
|
<select path="::clusterName"/>
|
|
</mapping>
|
|
<mapping name="clusterNodes">
|
|
<select-all path=":$[*].state.hostname"/>
|
|
</mapping>
|
|
<mapping name="domainName">
|
|
<select path="state.domain"/>
|
|
</mapping>
|
|
<mapping name="domainAdminAccountName">
|
|
<select path="::domainAdminUserName"/>
|
|
</mapping>
|
|
<mapping name="domainAdminAccountPassword">
|
|
<select path="::domainAdminPassword"/>
|
|
</mapping>
|
|
<mapping name="clusterIP">
|
|
<select path="::clusterIP"/>
|
|
</mapping>
|
|
<mapping name="shareServer">
|
|
<select path="state.domainIp"/>
|
|
</mapping>
|
|
</map>
|
|
</parameter>
|
|
<success>
|
|
<set path="::state.failoverClusterCreated"><true/></set>
|
|
<report entity="service">
|
|
<parameter name="id"><select path="::id"/></parameter>
|
|
<parameter name="text">Failover cluster created for SQL Server Cluster service (<select path="::name"/>)</parameter>
|
|
</report>
|
|
</success>
|
|
<failure>
|
|
<report entity="Service" level="error">
|
|
<parameter name="id"><select path="::id"/></parameter>
|
|
<parameter name="text">Unable to create failover cluster for SQL Server Service <select path="::name"/> due to <format-error error="exception"/></parameter>
|
|
</report>
|
|
<stop/>
|
|
</failure>
|
|
</send-command>
|
|
</rule>
|
|
|
|
<rule match="$.services[?(@.type == 'msSqlClusterServer' and @.state.failoverClusterCreated and not @.state.agEnvironmentConfigured)].units[*]"
|
|
desc="First unit of SQL Server Cluster services that is already has failover cluster created">
|
|
<send-command template="SqlServerCluster/ConfigureEnvironmentForAOAG" error="exception">
|
|
<parameter name="unit">
|
|
<select path="id"/>
|
|
</parameter>
|
|
<parameter name="service">
|
|
<select path="::id"/>
|
|
</parameter>
|
|
<parameter name="mappings">
|
|
<map>
|
|
<mapping name="primaryNode">
|
|
<select-single path=":$[?(@.isMaster)].state.hostname"/>
|
|
</mapping>
|
|
</map>
|
|
</parameter>
|
|
<success>
|
|
<set path="::state.agEnvironmentConfigured"><true/></set>
|
|
<report entity="service">
|
|
<parameter name="id"><select path="::id"/></parameter>
|
|
<parameter name="text">Environment for AlwaysOn Availability Group of SQL Server Cluster service (<select path="::name"/>) configured</parameter>
|
|
</report>
|
|
</success>
|
|
<failure>
|
|
<report entity="service" level="error">
|
|
<parameter name="id"><select path="::id"/></parameter>
|
|
<parameter name="text">Unable to configure the environment for AlwaysOn Availability Group of SQL Server Cluster service (<select path="::name"/>) due to <format-error error="exception"/></parameter>
|
|
</report>
|
|
<stop/>
|
|
</failure>
|
|
</send-command>
|
|
</rule>
|
|
|
|
<rule match="$.services[?(@.type == 'msSqlClusterServer' and @.state.agEnvironmentConfigured)].units[?(@.state.failoverClusterPrerequisitesInstalled and not @.state.sqlServerInstalled)]"
|
|
desc="All units of SQL Server Cluster services that is already has environment configured">
|
|
<send-command template="SqlServerCluster/InstallSqlServerForAOAG" error="exception">
|
|
<parameter name="unit">
|
|
<select path="id"/>
|
|
</parameter>
|
|
<parameter name="service">
|
|
<select path="::id"/>
|
|
</parameter>
|
|
<parameter name="mappings">
|
|
<map>
|
|
<mapping name="sqlServiceAccountName">
|
|
<select path="::sqlServiceUserName"/>
|
|
</mapping>
|
|
<mapping name="sqlServiceAccountPassword">
|
|
<select path="::sqlServicePassword"/>
|
|
</mapping>
|
|
<mapping name="domainAdminAccountName">
|
|
<select path="::domainAdminUserName"/>
|
|
</mapping>
|
|
<mapping name="domainAdminAccountPassword">
|
|
<select path="::domainAdminPassword"/>
|
|
</mapping>
|
|
<mapping name="domainName">
|
|
<select path="state.domain"/>
|
|
</mapping>
|
|
</map>
|
|
</parameter>
|
|
<success>
|
|
<set path="state.sqlServerInstalled"><true/></set>
|
|
<report entity="unit">
|
|
<parameter name="id"><select path="id"/></parameter>
|
|
<parameter name="text">SQL Server installed on unit <select path="state.hostname"/> (<select path="name"/>)</parameter>
|
|
</report>
|
|
</success>
|
|
<failure>
|
|
<report entity="unit" level="error">
|
|
<parameter name="id"><select path="id"/></parameter>
|
|
<parameter name="text">Unable to install SQL Server on unit <select path="state.hostname"/> (<select path="name"/>) due to <format-error error="exception"/></parameter>
|
|
</report>
|
|
<stop/>
|
|
</failure>
|
|
</send-command>
|
|
</rule>
|
|
|
|
<rule match="$.services[?(@.type == 'msSqlClusterServer')].units[?(@.state.sqlServerInstalled and not @.state.alwaysOnInitialized)]"
|
|
desc="All units of SQL Server Cluster services that has SQL Server installed">
|
|
<send-command template="SqlServerCluster/InitializeAlwaysOn" error="exception">
|
|
<parameter name="unit">
|
|
<select path="id"/>
|
|
</parameter>
|
|
<parameter name="service">
|
|
<select path="::id"/>
|
|
</parameter>
|
|
<parameter name="mappings">
|
|
<map>
|
|
<mapping name="domainAdminAccountName">
|
|
<select path="::domainAdminUserName"/>
|
|
</mapping>
|
|
<mapping name="domainAdminAccountPassword">
|
|
<select path="::domainAdminPassword"/>
|
|
</mapping>
|
|
<mapping name="nodeList">
|
|
<select-all path=":$[*].state.hostname"/>
|
|
</mapping>
|
|
<mapping name="primaryNode">
|
|
<select-single path=":$[?(@.isMaster)].state.hostname"/>
|
|
</mapping>
|
|
<mapping name="domainName">
|
|
<select path="state.domain"/>
|
|
</mapping>
|
|
</map>
|
|
</parameter>
|
|
<success>
|
|
<set path="state.alwaysOnInitialized"><true/></set>
|
|
<report entity="unit">
|
|
<parameter name="id"><select path="id"/></parameter>
|
|
<parameter name="text">AlwaysOn AG initialized for <select path="state.hostname"/> (<select path="name"/>)</parameter>
|
|
</report>
|
|
</success>
|
|
<failure>
|
|
<report entity="unit" level="error">
|
|
<parameter name="id"><select path="id"/></parameter>
|
|
<parameter name="text">Unable to initialize AlwaysOn AG for <select path="state.hostname"/> (<select path="name"/>) due to <format-error error="exception"/></parameter>
|
|
</report>
|
|
<stop/>
|
|
</failure>
|
|
</send-command>
|
|
</rule>
|
|
|
|
<rule match="$.services[?(@.type == 'msSqlClusterServer')].units[?(@.state.alwaysOnInitialized and not @.state.primaryReplicaInitialized)]"
|
|
desc="All units of SQL Server Cluster services that has AlwaysOn initialized">
|
|
<send-command template="SqlServerCluster/InitializeAOAGPrimaryReplica" error="exception">
|
|
<parameter name="unit">
|
|
<select path="id"/>
|
|
</parameter>
|
|
<parameter name="service">
|
|
<select path="::id"/>
|
|
</parameter>
|
|
<parameter name="mappings">
|
|
<map>
|
|
<mapping name="domainAdminAccountName">
|
|
<select path="::domainAdminUserName"/>
|
|
</mapping>
|
|
<mapping name="domainAdminAccountPassword">
|
|
<select path="::domainAdminPassword"/>
|
|
</mapping>
|
|
<mapping name="groupName">
|
|
<select path="::agGroupName"/>
|
|
</mapping>
|
|
<mapping name="nodeList">
|
|
<select-all path=":$[*].state.hostname"/>
|
|
</mapping>
|
|
<mapping name="primaryNode">
|
|
<select-single path=":$[?(@.isMaster)].state.hostname"/>
|
|
</mapping>
|
|
<mapping name="domainName">
|
|
<select path="state.domain"/>
|
|
</mapping>
|
|
<mapping name="syncModeNodeList">
|
|
<select-all path=":$[?(@.isSync)].state.hostname"/>
|
|
</mapping>
|
|
<mapping name="listenerIP">
|
|
<select path="::agListenerIP"/>
|
|
</mapping>
|
|
<mapping name="listenerName">
|
|
<select path="::agListenerName"/>
|
|
</mapping>
|
|
<mapping name="databaseList">
|
|
<select path="::databases"/>
|
|
</mapping>
|
|
</map>
|
|
</parameter>
|
|
<success>
|
|
<set path="state.primaryReplicaInitialized"><true/></set>
|
|
<report entity="unit">
|
|
<parameter name="id"><select path="id"/></parameter>
|
|
<parameter name="text">Primary replica for SQL Server AG initialized for <select path="state.hostname"/> (<select path="name"/>)</parameter>
|
|
</report>
|
|
</success>
|
|
<failure>
|
|
<report entity="unit" level="error">
|
|
<parameter name="id"><select path="id"/></parameter>
|
|
<parameter name="text">Unable to initialize primary replica for SQL Server AG for <select path="state.hostname"/> (<select path="name"/>) due to <format-error error="exception"/></parameter>
|
|
</report>
|
|
<stop/>
|
|
</failure>
|
|
</send-command>
|
|
</rule>
|
|
|
|
<rule match="$.services[?(@.type == 'msSqlClusterServer')].units[?(@.state.primaryReplicaInitialized and not @.state.secondaryReplicaInitialized)]"
|
|
desc="All units of SQL Server Cluster services that has primary replica initialized">
|
|
<send-command template="SqlServerCluster/InitializeAOAGSecondaryReplica" error="exception">
|
|
<parameter name="unit">
|
|
<select path="id"/>
|
|
</parameter>
|
|
<parameter name="service">
|
|
<select path="::id"/>
|
|
</parameter>
|
|
<parameter name="mappings">
|
|
<map>
|
|
<mapping name="domainAdminAccountName">
|
|
<select path="::domainAdminUserName"/>
|
|
</mapping>
|
|
<mapping name="domainAdminAccountPassword">
|
|
<select path="::domainAdminPassword"/>
|
|
</mapping>
|
|
<mapping name="nodeList">
|
|
<select-all path=":$[*].state.hostname"/>
|
|
</mapping>
|
|
<mapping name="primaryNode">
|
|
<select-single path=":$[?(@.isMaster)].state.hostname"/>
|
|
</mapping>
|
|
<mapping name="domainName">
|
|
<select path="state.domain"/>
|
|
</mapping>
|
|
</map>
|
|
</parameter>
|
|
<success>
|
|
<set path="state.secondaryReplicaInitialized"><true/></set>
|
|
<report entity="unit">
|
|
<parameter name="id"><select path="id"/></parameter>
|
|
<parameter name="text">Secondary replica for SQL Server AG initialized for <select path="state.hostname"/> (<select path="name"/>)</parameter>
|
|
</report>
|
|
</success>
|
|
<failure>
|
|
<report entity="unit" level="error">
|
|
<parameter name="id"><select path="id"/></parameter>
|
|
<parameter name="text">Unable to initialize secondary replica for SQL Server AG for <select path="state.hostname"/> (<select path="name"/>) due to <format-error error="exception"/></parameter>
|
|
</report>
|
|
<stop/>
|
|
</failure>
|
|
</send-command>
|
|
</rule>
|
|
|
|
</workflow>
|