Table of Contents:
- Introduction
- Structure of Ansible Playbooks for SAP
- Minimum OS compatibility from Ansible Playbooks for SAP
- Available Scenarios with Ansible Playbooks for SAP
- Prepare to execute Ansible Playbooks for SAP
- Prepare Infrastructure Platform for Ansible Playbooks for SAP
- Customization of Ansible Playbooks for SAP
- Example execution of Ansible Playbooks for SAP
- Infrastructure Platform provisioned resources by Ansible Playbooks for SAP
Related documents:
There are multiple methods to executing the Ansible Playbook for SAP, it depends on user preference and the desired automation to be performed.
Each Ansible Playbook for SAP can use Interactive Prompts or Standard (Non-Interactive, variable files) for variable inputs, and can be executed as:
- Ansible with existing host/s: this executes using the Ansible Inventory to perform an SAP Software installation.
This requires prior setup of Infrastructure Platform.
- Ansible to provision hosts: this provisions host/s using Ansible Tasks and performs an SAP Software installation.
This requires prior setup of Infrastructure Platform.
- Ansible executes Terraform to provision hosts: this executes Terraform (v1.0.0-v1.5.5) to provision a minimal landing zone on the Infrastructure Platform, then provisions host/s and performs an SAP Software installation.
- Ideally suited for isolated Sandbox testing, as this provisions an isolated environment on the target Infrastructure Platform which can easily be destroyed with a re-run of the Ansible Playbook using variable
sap_vm_provision_terraform_state: absent
. NOTE:
Ansible to Terraform is only compatible with provisioning Sandboxes. This is a design decision, based upon Terraform BSL transition reducing developer interest and effort to provide equal functionality (e.g. HA) via Terraform.
- Ideally suited for isolated Sandbox testing, as this provisions an isolated environment on the target Infrastructure Platform which can easily be destroyed with a re-run of the Ansible Playbook using variable
These Ansible Playbooks for SAP are designed to be:
- simple to understand,
- highly reconfigurable and extendable,
- self-enclosed for a specific scenario,
- result in an equal installation performed to any Infrastructure Platform (Hyperscaler Cloud Service Providers and Hypervisor platforms),
- use either Ansible or Terraform to provision Infrastructure,
- use Ansible for configuration of OS and installation of SAP Software,
- and
licensed for corporate usage
by SAP Customers, SAP Service Partners and SAP Technology Partners
The Ansible Playbooks for SAP therefore assist SAP-run enterprises to achieve various outcomes, such as:
Business requirement | Potential activities assisted by this project |
---|---|
Migration to SAP S/4HANA AnyPremise: | Greenfield; perform a new installation from SAP Maintenance Planner |
Brownfield; perform a backup, execute a System Copy (Homogeneous) and execute DMO for SUM with System Move, begin testing activities, add to remediation plan, repeat until cutover plan completed | |
Selective Data Transition; perform a backup, execute a System Copy (Homogeneous), execute Shell Conversion or Mix&Match, begin testing activities, add to remediation plan, repeat until cutover plan completed | |
Datacenter Exit / Cloud Service Provider switch: | Compute Re-locate; perform a backup, execute a System Copy (Homogeneous) to a target infrastructure, begin testing activities, add to remediation plan, repeat until cutover plan completed |
Compute Re-locate and move to SAP HANA; perform a backup, execute a System Copy (Homogeneous), upgrade ECC EHP and SAP NetWeaver versions, then System Copy (Heterogeneous) using SWPM | |
Enterprise re-structures: | Spin-offs and Divestitures (Grow through focus on core value); define split-by action (e.g. Organizational Units such as Company Code, Plants, Controlling area, Profit centers), perform a backup, execute a System Copy (Homogeneous), perform carve-out activities, begin testing activities, add to remediation plan, repeat until cutover plan completed |
Mergers and Acquisitions (Grow through expansion); merge of SAP Systems, perform a backup of each, execute a System Copy (Homogeneous) of each, upgrade to ECC EHP and SAP NetWeaver versions to match, smoke test functionality of both post-upgrade, begin testing and identification of business process alterations with the corresponding creation of Transports (e.g. altered BC Sets) to manually move |
Each Ansible Playbook for SAP is for deployment of an SAP Software Solution Scenario to an Infrastructure Platform. The user is provided a choice whether to use:
- existing hosts
- provision hosts via Ansible to an existing Infrastructure Platform setup
- provision hosts and minimal setup of an Infrastructure Platform via Terraform Template (which leverages the Terraform Modules for SAP)
Segregation of definitions for the Host/s and SAP Software are:
- Ansible Dictionary for each Infrastructure Platform, with default sizes for sandboxes
- Ansible Dictionary for each SAP Software installation / SAP System templates
Within each Ansible Playbook, there are various Ansible Tasks for handling the infrastructure/hosts. Afterwards, the referenced Ansible Collection Role/s for configuration of OS and installation of SAP software is identical for each Infrastructure Platform.
For the execution process, please read the detailed Execution workflow structure for further details.
For the execution outcome, please read the Infrastructure Platform provisioned resources for further details:
The Ansible Playbooks for SAP are designed for Linux operating systems, the minimum compatible and tested versions are:
- SUSE Linux Enterprise Server for SAP Applications (SLES4SAP) 15 SP5 +
- Red Hat Enterprise Linux for SAP Solutions (RHEL4SAP) 8.4 +
Additional notes regarding OS Editions and Versions:
- SLES with HAE is not compatible due to missing OS Packages for SAP
- RHEL for SAP Applications may not have incompatibility, depending on selected scenario, due to missing OS Packages for SAP HANA, High Availability and extended patching (EUS/E4S)
- RHEL for SAP Solutions may be labelled 'RHEL for SAP with High Availability and Update Services (HA-US)' on Cloud Hyperscalers
Assumptions for executing the Ansible Roles from this Ansible Collection include:
- If using existing hosts, then the host is a Registered OS with an active license
- If using existing hosts, then the host has access to OS Package repositories (from the relevant content delivery network of the OS vendor)
SAP Software solution scenario: Ansible Playbook name |
Amazon Web Services (AWS) | Google Cloud | Microsoft Azure | IBM Cloud [x86_64] |
IBM Cloud [ppc64le] |
IBM PowerVC | KubeVirt | OVirt KVM | VMware vCenter |
---|---|---|---|---|---|---|---|---|---|
Deploy Scenario - Sandbox |
|||||||||
sap_bw4hana_sandbox | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | |
sap_ecc_hana_sandbox | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | |
sap_ecc_ibmdb2_sandbox | ✅ | ✅ | ✅ | ✅ | 🚫 | 🚫 | ✅ | ✅ | |
sap_ecc_oracledb_sandbox | ✅ | ✅ | ✅ | ✅ | 🚫 | 🚫 | ✅ | ✅ | |
sap_ecc_sapase_sandbox | ✅ | ✅ | ✅ | ✅ | 🚫 | 🚫 | ✅ | ✅ | |
sap_ecc_sapmaxdb_sandbox | ✅ | ✅ | ✅ | ✅ | 🚫 | 🚫 | ✅ | ✅ | |
sap_ides_ecc_hana_sandbox | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | |
sap_ides_ecc_ibmdb2_sandbox | ✅ | ✅ | ✅ | ✅ | 🚫 | 🚫 | ✅ | ✅ | |
sap_nwas_abap_hana_sandbox | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | |
sap_nwas_abap_ibmdb2_sandbox | ✅ | ✅ | ✅ | ✅ | 🚫 | 🚫 | ✅ | ✅ | |
sap_nwas_abap_oracledb_sandbox | ✅ | ✅ | ✅ | ✅ | 🚫 | 🚫 | ✅ | ✅ | |
sap_nwas_abap_sapase_sandbox | ✅ | ✅ | ✅ | ✅ | 🚫 | 🚫 | ✅ | ✅ | |
sap_nwas_abap_sapmaxdb_sandbox | ✅ | ✅ | ✅ | ✅ | 🚫 | 🚫 | ✅ | ✅ | |
sap_nwas_java_ibmdb2_sandbox | ✅ | ✅ | ✅ | ✅ | 🚫 | 🚫 | ✅ | ✅ | |
sap_nwas_java_sapase_sandbox | ✅ | ✅ | ✅ | ✅ | 🚫 | 🚫 | ✅ | ✅ | |
sap_s4hana_foundation_sandbox | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | |
sap_s4hana_sandbox | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | |
sap_s4hana_sandbox_maintplan | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | |
sap_solman_sapase_sandbox | ✅ | ✅ | ✅ | ✅ | 🚫 | 🚫 | ✅ | ✅ | |
sap_solman_saphana_sandbox | ✅ | ✅ | ✅ | ✅ | 🚫 | 🚫 | ✅ | ✅ | |
Deploy Scenario - Composites |
|||||||||
sap_bw4hana_standard_scaleout | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | |
sap_ecc_ibmdb2_distributed | ✅ | ✅ | ✅ | ✅ | 🚫 | 🚫 | ✅ | ✅ | |
sap_hana | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ |
sap_hana_ha | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | ||
sap_hana_scaleout | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | |
sap_landscape_s4hana_standard | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | |
sap_landscape_s4hana_standard_maintplan | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | |
sap_s4hana_distributed | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | |
sap_s4hana_distributed_ha | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | ||
sap_s4hana_distributed_ha_maintplan | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | ||
sap_s4hana_distributed_maintplan | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | |
sap_s4hana_foundation_standard | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ |
sap_s4hana_standard | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ |
sap_s4hana_standard_maintplan | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ |
Special Actions |
|||||||||
sap_download_install_media | N/A | N/A | N/A | N/A | N/A | N/A | N/A | N/A | N/A |
sap_sda | N/A | N/A | N/A | N/A | N/A | N/A | N/A | N/A | N/A |
sap_system_copy_export | N/A | N/A | N/A | N/A | N/A | N/A | N/A | N/A | N/A |
sap_system_copy_restore_hana_sandbox | N/A | N/A | N/A | N/A | N/A | N/A | N/A | N/A | N/A |
sap_webdispatcher_standalone | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | |
Provisioning via Ansible to Terraform |
|||||||||
✅ | ✅ | ✅ | ✅ | N/A | N/A |
Key:
- ✅ Ready and Tested
⚠️ Work in Progress- 🚫 Not provided by SAP
- N/A: Not Applicable
The following are the requirements for successful execution of an Ansible Playbook, please read these and configure accordingly on your Ansible execution/controller host.
-
Ensure Ansible Core 2.12+ and Python 3.9+ (i.e. CPython distribution) are available
- It is recommended to avoid using the default OS system Python. Instead the suggestion is to create and activate a Python virtual environment for the current shell session (e.g.
python -m venv /tmp/playbooks_sap && source /tmp/playbooks_sap/bin/activate && python -m pip install ansible-core
). - Ansible discovers the Python interpreter automatically, if a specific Python version is required on the host executing the Ansible Playbook then it is recommended to use Ansible special variable
ansible_python_interpreter
for the localhost in the Ansible Inventory file. This will avoid Ansible being instructed to look for the customized Python path on the target/remote hosts (which likely will be default /usr/bin/python) and cause errors such as/bin/sh: python3: command not found
.
- It is recommended to avoid using the default OS system Python. Instead the suggestion is to create and activate a Python virtual environment for the current shell session (e.g.
-
Ensure all Python Packages are available for Ansible to use:
- Required for all Ansible Playbooks, use
python -m pip install ansible-core beautifulsoup4 lxml requests passlib jmespath
- ansible-core 2.12.0+
- beautifulsoup4 4.0+
- lxml 4.0+
- requests 2.0+
- passlib 1.7+
- jmespath 1.0.1+
- If Ansible Playbook provisioning to AWS, use
python -m pip install boto3
- If Ansible Playbook provisioning to Google Cloud, use
python -m pip install google-auth
- If Ansible Playbook provisioning to MS Azure, use
python -m pip install -r https://raw.githubusercontent.com/ansible-collections/azure/dev/requirements-azure.txt
- If Ansible Playbook provisioning to IBM PowerVM, use
python -m pip install openstacksdk
- If Ansible Playbook provisioning to OVirt, use
python -m pip install ovirt-engine-sdk-python
- If Ansible Playbook provisioning to VMware, use
python -m pip install aiohttp
- Required for all Ansible Playbooks, use
-
Ensure Ansible Collections are installed (a requirements file is included with each Ansible Playbook)
ansible-galaxy collection install --requirements-file ./ansible_requirements.yml
-
Ensure OS Packages are installed and available for Ansible to call (for commands not provided by Ansible Collections/Roles/Modules):
- If Ansible Playbook provisioning to AWS, install AWS CLI to perform IAM activities for High Availability
- If Ansible Playbook provisioning to Google Cloud, install GCloud CLI to perform activities for High Availability
- If Ansible Playbook provisioning to IBM Cloud, install Terraform (v1.5.5 and below) to provision and install IBM Cloud CLI to perform activities for High Availability
- Terraform install is required, it is used on-the-fly by the legacy Ansible Collection
ibm.cloudcollection
- used until theibm.cloud
Ansible Collection full functionality is available
- Terraform install is required, it is used on-the-fly by the legacy Ansible Collection
-
The SSH Private Key files used by Ansible have the correct file permissions (
chmod 400
) for SSH connections. -
OPTIONAL: when running Ansible, you may silence warnings from Ansible which are irrelevant for this Ansible Playbook:
export ANSIBLE_LOCALHOST_WARNING=False
export ANSIBLE_INVENTORY_UNPARSED_WARNING=False
- OPTIONAL: by default, Ansible Core will output error or debug (-v) messages as a string. For easier readability, it is easy to configure Ansible Core to parse the error or debug messages and output as YAML that is easier to read, create/amend the
~/.ansible.cfg
file:
[defaults]
# Use the YAML callback plugin.
stdout_callback = yaml
# Use the stdout_callback when running ad-hoc commands.
bin_ansible_callbacks = True
SAP software installation media must be obtained from SAP directly, and requires valid license agreements with SAP in order to access these files.
An SAP Company Number (SCN) contains one or more Installation Number/s, providing licences for specified SAP Software. When an SAP User ID is created within the SAP Customer Number (SCN), the administrator must provide SAP Download authorizations for the SAP User ID.
When an SAP User ID (e.g. S-User) is enabled with and part of an SAP Universal ID, then the sap_launchpad
Ansible Collection must use:
- the SAP User ID
- the password for login with the SAP Universal ID
In addition, if a SAP Universal ID is used then the recommendation is to check and reset the SAP User ID ‘Account Password’ in the SAP Universal ID Account Manager, which will help to avoid any potential conflicts.
If selecting Ansible to perform provisioning of Infrastructure, please ensure the Infrastructure Platform is setup (e.g. relevant Subnets, SSH Keys etc); this is dependent on the target Infrastructure Platform. See below for the drop-down list of each Infrastructure Platform.
For further details on the output, please see Host provisioning via Ansible, under section Infrastructure Platform provisioned resources by Ansible Playbooks for SAP.
- For Hyperscaler Cloud Service Providers that use Resource Groups (IBM Cloud, Microsoft Azure):
- Virtual Machine and associated resources (Disks, Network Interfaces, Load Balancer etc.) will be provisioned to the same Resource Group as the targeted network/subnet.
- Optional: Private DNS may be allocated to another Resource Group, and an optional variable is provided for this.
Amazon Web Services (AWS):
- VPC
- VPC Access Control List (ACL)
- VPC Subnets
- VPC Security Groups
- Route53 (Private DNS)
- Internet Gateway (SNAT)
- EFS (NFS)
- Bastion host (AWS EC2 VS)
- Key Pair for hosts
Google Cloud (GCP):
- VPC Network
- VPC Subnetwork
- Compute Firewall
- Compute Router
- SNAT
- DNS Managed Zone (Private DNS)
- Filestore (NFS)
- Bastion host (GCP CE VM)
Microsoft Azure:
- Resource Group (optional: Private DNS may be allocated to separate Resource Group, see
sap_infrastructure
documentation) - VNet
- VNet Subnet
- VNet Network Security Group (NSG)
- Private DNS Zone
- NAT Gateway (SNAT)
- Storage Account
- Azure Files (aka. File Storage Share, NFS)
- Private Endpoint Connection
- Bastion host (MS Azure VM)
- Key Pair for hosts
IBM Cloud:
- Resource Group (optional: Private DNS may be allocated to separate Resource Group, see
sap_infrastructure
documentation) - VPC
- VPC Access Control List (ACL)
- VPC Subnets
- VPC Security Groups
- Private DNS
- Public Gateway (SNAT)
- File Share (NFS)
- Bastion host (IBM Cloud VS)
- Key Pair for hosts
IBM Cloud, IBM Power VS:
- Resource Group (optional: Private DNS may be allocated to separate Resource Group, see
sap_infrastructure
documentation) - IBM Power Workspace
- VLAN Subnet
- Cloud Connection (from secure enclave to IBM Cloud)
- Private DNS Zone
- Public Gateway (SNAT)
- Bastion host (IBM Cloud VS or IBM Power VS)
- Key Pair for hosts (in IBM Power Workspace)
IBM PowerVC:
- Host Group Shared Processor Pool
- Storage Template
- Network Configuration (for SEA or SR-IOV)
- VM OS Image
- Key Pair for hosts
KubeVirt:
TODO
OVirt:
TODO
VMware vCenter:
- Datacenter (SDDC)
- Cluster
- Hosts
- Cluster
- NSX
- Datastore
- Content Library
- VM Template
If selecting Terraform to perform provisioning of Infrastructure, please install Terraform v1.5.5 and below for the relevant Operating System.
The Ansible Playbooks for SAP use the sap_infrastructure
Ansible Collection, which for Ansible to Terraform make use of the Terraform Modules for SAP; these are backwards compatible down to Terraform v1.0.0.
For further details on the output, please see Infrastructure setup and Host provisioning via Terraform, under section Infrastructure Platform provisioned resources by Ansible Playbooks for SAP.
N.B. The Linux Foundation's OpenTofu and accompanying OpenTofu Registry have not been tested. It is anticipated that LF OpenTofu would work immediately - however, further testing of both the Ansible Role cloud.terraform to control the execution and the underlying Terraform Modules for SAP with LF OpenTofu is out-of-scope at this time. The suggestion remains to use Terraform v1.0.0 - v1.5.5 developed under the Mozilla Public License (MPL).
The Ansible Playbooks for SAP are designed to use limited delegated administration privileges, as much as possible. Particularly for Ansible to Terraform provisioning, the following are a recommended authorizations to a target Infrastructure Platform.
See below for the drop-down list of each Infrastructure Platform.
Amazon Web Services (AWS):
The AWS User and associated key/secret will need to be assigned, by the Cloud Account Administrator. A recommended minimum of AWS IAM user authorization is achieved with the following AWS CLI commands:
# Login
aws configure
# Create AWS IAM Policy Group
aws iam create-group --group-name 'ag-sap-automation'
aws iam attach-group-policy --group-name 'ag-sap-automation' --policy-arn arn:aws:iam::aws:policy/AmazonVPCFullAccess
aws iam attach-group-policy --group-name 'ag-sap-automation' --policy-arn arn:aws:iam::aws:policy/AmazonEC2FullAccess
aws iam attach-group-policy --group-name 'ag-sap-automation' --policy-arn arn:aws:iam::aws:policy/AmazonRoute53FullAccess
Google Cloud (GCP):
Google Cloud Platform places upper limit quotas for different resources and limits 'CPUS_ALL_REGIONS'
and 'SSD_TOTAL_GB'
may be too low if using a new GCP Account or a new target GCP Region. Please check gcloud compute regions describe us-central1 --format="table(quotas:format='table(metric,limit,usage)')"
before provisioning to a GCP Region, and manually request quota increases for these limits in the target GCP Region using instructions on https://cloud.google.com/docs/quota#requesting_higher_quota (from GCP Console or contact with GCP Support Team).
The Google Cloud User credentials (Client ID and Client Secret) JSON file with associated authorizations will need to be assigned, by the Cloud Account Administrator. Thereafter, please manually open and activate various APIs for the GCP Project to avoid HTTP 403 errors during provisioning:
- Enable the Compute Engine API, using https://console.cloud.google.com/apis/api/compute.googleapis.com/overview
- Enable the Cloud DNS API, using https://console.cloud.google.com/apis/api/dns.googleapis.com/overview
- Enable the Network Connectivity API, using https://console.cloud.google.com/apis/library/networkconnectivity.googleapis.com
- Enable the Cloud Filestore API, using https://console.cloud.google.com/apis/library/file.googleapis.com
- Enable the Service Networking API (Private Services Connection to Filestore), using https://console.cloud.google.com/apis/library/servicenetworking.googleapis.com
Microsoft Azure:
The Azure Application Service Principal and associated Client ID and Client Secret will need to be assigned, by the Cloud Account Administrator. A recommended minimum of Azure AD Role authorizations is achieved with the following MS Azure CLI commands:
# Login
az login
# Show Tenant and Subscription ID
export AZ_SUBSCRIPTION_ID=$(az account show | jq .id --raw-output)
export AZ_TENANT_ID=$(az account show | jq .tenantId --raw-output)
# Create Azure Application, includes Client ID
export AZ_CLIENT_ID=$(az ad app create --display-name ansible-terraform | jq .appId --raw-output)
# Create Azure Service Principal, instantiation of Azure Application
export AZ_SERVICE_PRINCIPAL_ID=$(az ad sp create --id $AZ_CLIENT_ID | jq .objectId --raw-output)
# Assign default Azure AD Role with privileges for creating Azure Virtual Machines
az role assignment create --assignee "$AZ_SERVICE_PRINCIPAL_ID" \
--subscription "$AZ_SUBSCRIPTION_ID" \
--role "Virtual Machine Contributor" \
--role "Contributor"
# Reset Azure Application, to provide the Client ID and Client Secret to use the Azure Service Principal
az ad sp credential reset --name $AZ_CLIENT_ID
Note: MS Azure VMs provisioned will contain Hyper-V Hypervisor virtual interfaces using eth* on the OS, and when Accelerated Networking (AccelNet) is enabled for the MS Azure VM then the Mellanox SmartNIC/DPU SR-IOV Virtual Function (VF) may use enP* on the OS. For further information, see MS Azure - How Accelerated Networking works. During High Availability executions, failures may occur and may require additional variable 'sap_ha_pacemaker_cluster_vip_client_interface' to be defined.
IBM Cloud:
The IBM Cloud Account User (or Service ID) and associated API Key will need to be assigned, by the Cloud Account Administrator. A recommended minimum of IBM Cloud IAM user authorization is achieved with the following IBM Cloud CLI commands:
# Login (see alternatives for user/password and SSO using ibmcloud login --help)
ibmcloud login --apikey=
# Create IBM Cloud IAM Access Group
ibmcloud iam access-group-create 'ag-sap-automation'
ibmcloud iam access-group-policy-create 'ag-sap-automation' --roles Editor --service-name=is
ibmcloud iam access-group-policy-create 'ag-sap-automation' --roles Editor,Manager --service-name=transit
ibmcloud iam access-group-policy-create 'ag-sap-automation' --roles Editor,Manager --service-name=dns-svcs
# Access to create an IBM Cloud Resource Group (Ansible to Terraform)
ibmcloud iam access-group-policy-create 'ag-sap-automation' --roles Administrator --resource-type=resource-group
# Assign to a specified Account User or Service ID
ibmcloud iam access-group-user-add 'ag-sap-automation' <<<IBMid>>>
ibmcloud iam access-group-service-id-add 'ag-sap-automation' <<<SERVICE_ID_UUID>>>
Alternatively, use the IBM Cloud web console:
- Open cloud.ibm.com - click Manage on navbar, click Access IAM, then on left nav menu click Access Groups
- Create an Access Group, with the following policies:
- IAM Services > VPC Infrastructure Services > click All resources as scope + Platform Access as Editor
- IAM Services > DNS Services > click All resources as scope + Platform Access as Editor + Service access as Manager
- IAM Services > Transit Gateway > click All resources as scope + Platform Access as Editor + Service access as Manager
[OPTIONAL]
IAM Services > All Identity and Access enabled services > click All resources as scope + Platform Access as Viewer + Resource group access as Administrator[OPTIONAL]
Account Management > Identity and Access Management > click Platform access as Editor[OPTIONAL]
Account Management > IAM Access Groups Service > click All resources as scope + Platform Access as Editor
IBM PowerVC:
The recommended IBM PowerVC Security Role is 'Administrator assistant' (admin_assist), because the 'Virtual machine manager' (vm_manager) role is not able to create IBM PowerVM Compute Template (required for setting OpenStack extra_specs specific to the IBM PowerVM hypervisor infrastructure platform, such as Processing Units). Note that the 'Administrator assistant' does not have the privilege to delete Virtual Machines.
VMware vCenter:
The VM Template must be prepared with cloud-init. This process is subjective to VMware, cloud-init and Guest OS (RHEL / SLES) versions; success will vary. This requires:
- Edit the default cloud-init configuration file, found at
/etc/cloud/cloud.cfg
. It must contain the data source for VMware (and not OVF), and force use of cloud-init metadata and userdata files. Note: appending keynetwork: {config: disabled}
may cause networkv1
to be incorrectly used instead of networkv2
in the cloud-init metadata YAML to follow.# Enable VMware VM Guest OS Customization with cloud-init (set to true for traditional customization) disable_vmware_customization: false # Use allow raw data to directly use the cloud-init metadata and user data files provided by the VMware VM Customization Specification # Wait 120 seconds for VMware VM Customization file to be available datasource: VMware: allow_raw_data: true vmware_cust_file_max_wait: 60
- Update
cloud-init
andopen-vm-tools
OS Package - Enable DHCP on the OS Network Interface (e.g. eth0, ens192 etc.)
- Prior to VM shutdown and marking as a VMware VM Template, run commands:
vmware-toolbox-cmd config set deployPkg enable-custom-scripts true
vmware-toolbox-cmd config set deployPkg wait-cloudinit-timeout 60
sudo cloud-init clean --seed --logs
to remove cloud-init logs, remove cloud-init seed directory /var/lib/cloud/seed.- If using cloud-init versions prior to 22.3.0 then do not use
--machine-id
parameter. - Reportedly, the
--machine-id
parameter which removes/etc/machine-id
may on first reboot cause the OS Network Interfaces to beDOWN
which causes the DHCP Request to silently error.
- If using cloud-init versions prior to 22.3.0 then do not use
- Once VM is shutdown, then run 'Clone > Clone as Template to Library'
- After provisioning the VM Template via Ansible, debug by checking:
/var/log/vmware-imc/toolsDeployPkg.log
/var/log/cloud-init-output.log
/var/log/cloud-init.log
/var/lib/cloud/instance/user-data.txt
/var/lib/cloud/instance/cloud-config.txt
/var/run/cloud-init/instance-data.json
/var/run/cloud-init/status.json
- See documentation for further information:
- VMware KB 59557 - How to switch vSphere Guest OS Customization engine for Linux virtual machine
- VMware KB 90331 - How does vSphere Guest OS Customization work with cloud-init to customize a Linux VM
- VMware KB 91809 - VMware guest customization key cloud-init changes
- VMware KB 74880 - Setting the customization script for virtual machines in vSphere 7.x and 8.x
- vSphere Web Services SDK Programming Guide - Guest Customization Using cloud-init
- cloud-init documentation - Reference - Datasources - VMware
In addition, the provisioned Virtual Machine must be accessible from the Ansible Controller (i.e. device where Ansible Playbook for SAP is executed must be able to reach the provisioned host).
When VMware vCenter and vSphere clusters with VMware NSX virtualized network overlays using Segments (e.g. 192.168.0.0/16) connected to Tier-0/Tier-1 Gateways (which are bound to the backbone network subnet, e.g. 10.0.0.0/8), it is recommended to:
- Use DHCP Server and attach to Subnet for the target VM. For example, create DHCP Server (e.g. NSX > Networking > Networking Profiles > DHCP Profile), set DHCP in the Gateway (e.g. NSX > Networking > Gateway > Edit > DHCP Config), then set for the Subnet (e.g. NSX > Networking > Segment > <> > Set DHCP Config) which the VMware VM Template is attached to; this allows subsequent cloned VMs to obtain an IPv4 Address
- Use DNAT configuration for any VMware NSX Segments (e.g. NSX-T Policy NAT Rule)
- For outbound internet connectivity, use SNAT configuration (e.g. rule added on NSX Gateway) set for the Subnet which the VMware VM Template is attached to. Alternatively, use a Web Forward Proxy.
N.B. When VMware vCenter and vSphere clusters with direct network subnet IP allocations to the VMXNet network adapter (no VMware NSX network overlays), the above actions may not be required.
Every Ansible Playbook for SAP is for a specific SAP Solution Scenario, each with an Ansible Dictionary which define the host specification plans for an Infrastructure Platform.
The host specification plan can contain multiple hosts, with different host specifications (cpu, memory, storage etc). These host specification plans are altered/customized to each Infrastructure Platform.
As a baseline infrastructure (hardware) host/s sizing, only the following are provided in each Ansible Playbooks for SAP:
Host Specification Plan | SAP Solution Scenarios applicable |
---|---|
xsmall_256gb |
SAP S/4HANA, SAP Business Suite on HANA (SoH, aka. ECC on HANA) and SAP HANA |
xsmall_anydb_32vcpu |
SAP Business Suite (ECC) and SAP AnyDB (SAP ASE, SAP MaxDB, IBM Db2, Oracle DB) |
xsmall_nwas_16vcpu |
SAP NetWeaver AS only |
tiny_64gb |
SAP HANA only (infrequent usage) |
For Hyperscaler Cloud Service Providers, the baseline infrastructure (hardware) host/s sizing use the following Profile/Types of Virtual Machines:
- 32 vCPU x 256GB DRAM for SAP HANA
- Amazon Web Services:
r7i.8xlarge
- Google Cloud Platform:
n2-highmem-32
- IBM Cloud, Intel:
mx2-32x256
- IBM Cloud, IBM Power:
ush1-4x256
- Microsoft Azure:
Standard_M32ls
- Amazon Web Services:
- 32 vCPU x 128GB DRAM for SAP AnyDB
- Amazon Web Services:
m7i.8xlarge
- Google Cloud Platform:
n2-standard-32
- IBM Cloud, Intel:
bx2-32x128
- Microsoft Azure:
Standard_D32s_v5
- Amazon Web Services:
- 16 vCPU x 32GB DRAM for SAP NetWeaver (minimum 1:2 ratio for vCPU:RAM)
- Amazon Web Services:
c6id.4xlarge
- Google Cloud Platform:
n2-standard-16
(lowest certified 16 vCPU uses 64 GB DRAM) - IBM Cloud, Intel:
cx2-16x32
- IBM Cloud, IBM Power:
cnp-2x32
- Microsoft Azure:
Standard_D16s_v5
(lowest certified 16 vCPU uses 64 GB DRAM)
- Amazon Web Services:
Note: See below for default swap sizes, with refereence to SAP Note 1597355 - Swap-space recommendation for Linux.
- For SAP HANA, swap is 2GiB.
- For SAP NetWeaver, swap is 64GiB.
- For SAP AnyDB, IBM Db2 swap is 128GiB (minimum) else swap is 96GiB.
- For Sandbox (OneHost DB and NWAS), swap is 96GiB.
It is easily possible to extend each Ansible Playbook for SAP with additional host specifications, such as:
Host Specification Plan | SAP Solution Scenarios applicable |
---|---|
small_512gb |
SAP HANA and SAP S/4HANA |
medium_1024gb |
SAP HANA and SAP S/4HANA |
large_2048gb |
SAP HANA and SAP S/4HANA |
xlarge_3072gb |
SAP HANA and SAP S/4HANA |
xxlarge_6144gb |
SAP HANA and SAP S/4HANA |
For example, the Ansible Playbook sap_s4hana_sandbox
appending a host specification plan small_512gb
on AWS could be defined as:
sap_vm_provision_aws_ec2_vs_host_specifications_dictionary:
small_512gb:
s4h01: # Hostname, must be 13 characters or less
sap_host_type: hana_primary # hana_primary, hana_secondary, nwas_ascs, nwas_ers, nwas_pas, nwas_aas
virtual_machine_profile: r5.16xlarge
disable_ip_anti_spoofing: true
sap_storage_setup_sid: "{{ sap_system_sid }}"
sap_storage_setup_nwas_abap_ascs_instance_nr: "{{ sap_system_nwas_abap_ascs_instance_nr }}"
sap_storage_setup_host_type:
- hana_primary
- nwas_abap_ascs
- nwas_abap_pas
storage_definition:
- name: hana_data
mountpoint: /hana/data
disk_size: 615 # size in GB, integer
filesystem_type: xfs # default: xfs
- name: hana_log
mountpoint: /hana/log
disk_size: 256 # size in GB, integer
filesystem_type: xfs # default: xfs
- name: hana_shared
mountpoint: /hana/shared
disk_size: 640 # size in GB, integer
filesystem_type: xfs # default: xfs
- name: usr_sap
mountpoint: /usr/sap
disk_size: 256 # size in GB, integer
filesystem_type: xfs # default: xfs
- name: sapmnt
mountpoint: /sapmnt
disk_size: 192 # size in GB, integer
filesystem_type: xfs # default: xfs
- name: swap
disk_size: 160
filesystem_type: swap # must be swap filesystem
- name: software
mountpoint: /software
disk_size: 100 # size in GB, integer
filesystem_type: xfs # default: xfs
The following execution examples are dependent on whether the desired outcome is using Existing Hosts, Hosts provisioned via Ansible to an existing environment, or using Ansible to Terraform to provision an environment and hosts.
Please ensure the tasks in the following section has been completed:
For first-time user how-to guidance, please also see:
- Execute the Ansible Playbook using the Ansible Extra Vars file (contains static definitions for filenames etc)
- Follow Ansible Variable input prompts; depending on selection, different variables will be prompted.
- Execution of host provisioning and SAP installation
Example:
ansible-playbook ansible_playbook.yml \
--extra-vars "@./ansible_extravars.yml"
- Execute the Ansible Playbook using:
- the Ansible Extra Vars file (contains static definitions for filenames etc)
- another Ansible Extra Vars file for all variables which would otherwise be prompted (such as S-User ID and Password)
- Execution of host provisioning and SAP installation
Note: samples of the non-interactive YAML files are provided in /optional
directory for each Ansible Playbook
Example:
ansible-playbook ansible_playbook.yml \
--extra-vars "@./ansible_extravars.yml" \
--extra-vars "@./cloud_credentials_extravars.yml" \
--extra-vars "@./sap_system_setup_extravars.yml"
Alternatively, to execute SAP installation to existing hosts use variable sap_vm_provision_iac_type: existing_hosts
in the Ansible Playbook to ignore provisioning. Then append the operator --inventory
.
- Execute the Ansible Playbook using:
- the Ansible Extra Vars file (contains static definitions for filenames etc)
- another Ansible Extra Vars file for all variables which would otherwise be prompted (such as S-User ID and Password)
- and an Ansible Inventory file
- Execution of host provisioning and SAP installation
Example:
ansible-playbook ansible_playbook.yml \
--inventory "./existing_inventory.yml" \
--extra-vars "@./ansible_extravars.yml" \
--extra-vars "@./sap_system_setup_extravars.yml"
Various SAP Software solution scenario and Infrastructure Platforms are available using the Ansible Playbooks for SAP.
When Ansible is used for provisioning hosts on an existing setup of an Infrastructure Platform, the following is an overview of the Infrastructure-as-Code (IaC) provisioning:
Infrastructure Platform | Amazon Web Services (AWS) | Google Cloud | Microsoft Azure | IBM Cloud | IBM Cloud | IBM PowerVC | KubeVirt | OVirt KVM | VMware vCenter |
---|---|---|---|---|---|---|---|---|---|
Product | EC2 Virtual Server | VM | VM | Virtual Server | IBM Power Virtual Server | VM (aka. LPAR) |
VM | VM | VM |
Host Provision |
|||||||||
Create DNS Records (i.e. A, CNAME, PTR) | ✅ | ✅ | ✅ | ✅ | ✅ | N/A | N/A | N/A | N/A |
Create Storage Volumes | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ |
Create Host/s | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ |
High Availability |
|||||||||
Create Resources (e.g. Load Balancer) | N/A | ✅ | ✅ | ✅ | N/A | N/A | N/A | N/A | N/A |
Key:
- ✅ Ready and Tested
⚠️ Work in Progress- 🚫 Capability not provided by vendor (or construct concept does not exist)
- N/A: Not Applicable
When Ansible uses Terraform to provision minimal landing zone and host/s, the following is an overview of the Infrastructure-as-Code (IaC) provisioning, for full details please see the underlying Terraform Modules for SAP documentation.
Infrastructure Platform | Amazon Web Services (AWS) | Google Cloud | Microsoft Azure | IBM Cloud | IBM Cloud | IBM PowerVC | KubeVirt | OVirt KVM | VMware vCenter |
---|---|---|---|---|---|---|---|---|---|
Product | EC2 Virtual Server | VM | VM | Virtual Server | IBM Power Virtual Server | LPAR | VM | VM | VM |
Account Init |
|||||||||
Create Resource Group. Or reuse existing Resource Group | 🚫 | 🚫 | ✅ | ✅ | ✅ | N/A | N/A | N/A | N/A |
Create Networks (VPC/VNet), Subnets, and Internet Access. Or reuse existing VPC/VNet | ✅ | ✅ | ✅ | ✅ | ✅ | N/A | N/A | N/A | N/A |
Account Bootstrap (aka. minimal landing zone) |
|||||||||
Create Private DNS, Network Security | ✅ | ✅ | ✅ | ✅ | ✅ | N/A | N/A | N/A | N/A |
Create Network Interconnectivity hub | ✅ | 🚫 | 🚫 | ✅ | ✅ | N/A | N/A | N/A | N/A |
Create TLS key pair for SSH and Import to Platform | ✅ | 🚫 | ✅ | ✅ | ✅ | ✅ | 🚫 | 🚫 | ✅ |
Bastion Injection |
|||||||||
Create Subnet and Network Security for Bastion | ✅ | ✅ | ✅ | ✅ | ✅ | N/A | N/A | N/A | N/A |
Create Bastion host and Public IP address | ✅ | ✅ | ✅ | ✅ | ✅ | N/A | N/A | N/A | N/A |
Host Network Access for SAP |
|||||||||
Append Network Security rules for SAP | ✅ | ✅ | ✅ | ✅ | ✅ | N/A | N/A | N/A | N/A |
Host Provision |
|||||||||
Create DNS Records (i.e. A, CNAME, PTR) | ✅ | ✅ | ✅ | ✅ | ✅ | N/A | N/A | N/A | N/A |
Create Storage Volumes (Profile or Custom IOPS) | ✅ | ✅ | ✅ | ✅ | no custom IOPS |
✅ | ✅ | ✅ | ✅ |
Create Host/s | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ |
High Availability |
|||||||||
Create Resources (e.g. Load Balancer) | N/A | ❌ | ❌ | ❌ | N/A | N/A | N/A | N/A | N/A |
Key:
- ✅ Ready and Tested
⚠️ Work in Progress- ❌ Not available
- 🚫 Capability not provided by vendor (or construct concept does not exist)
- N/A: Not Applicable