{"id":17992108,"url":"https://github.com/martinpankraz/distributed-sap-cloud-integration","last_synced_at":"2025-10-10T14:33:39.613Z","repository":{"id":86195010,"uuid":"314857235","full_name":"MartinPankraz/Distributed-SAP-Cloud-Integration","owner":"MartinPankraz","description":"Artifacts supporting failover and high availability examples for SAP Cloud Integration using Azure PaaS services.","archived":false,"fork":false,"pushed_at":"2021-09-23T15:09:42.000Z","size":316,"stargazers_count":3,"open_issues_count":0,"forks_count":0,"subscribers_count":1,"default_branch":"main","last_synced_at":"2025-04-04T04:29:50.561Z","etag":null,"topics":["azure","failover","high-availability","sap-cloud-integration","sap-cloud-platform-integration","scalability","traffic-manager"],"latest_commit_sha":null,"homepage":"","language":null,"has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":"apache-2.0","status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/MartinPankraz.png","metadata":{"files":{"readme":"README.md","changelog":null,"contributing":null,"funding":null,"license":"LICENSE","code_of_conduct":null,"threat_model":null,"audit":null,"citation":null,"codeowners":null,"security":null,"support":null,"governance":null,"roadmap":null,"authors":null,"dei":null,"publiccode":null,"codemeta":null}},"created_at":"2020-11-21T16:41:42.000Z","updated_at":"2022-11-01T18:34:08.000Z","dependencies_parsed_at":"2023-03-01T03:15:48.921Z","dependency_job_id":null,"html_url":"https://github.com/MartinPankraz/Distributed-SAP-Cloud-Integration","commit_stats":null,"previous_names":[],"tags_count":0,"template":false,"template_full_name":null,"purl":"pkg:github/MartinPankraz/Distributed-SAP-Cloud-Integration","repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/MartinPankraz%2FDistributed-SAP-Cloud-Integration","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/MartinPankraz%2FDistributed-SAP-Cloud-Integration/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/MartinPankraz%2FDistributed-SAP-Cloud-Integration/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/MartinPankraz%2FDistributed-SAP-Cloud-Integration/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/MartinPankraz","download_url":"https://codeload.github.com/MartinPankraz/Distributed-SAP-Cloud-Integration/tar.gz/refs/heads/main","sbom_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/MartinPankraz%2FDistributed-SAP-Cloud-Integration/sbom","scorecard":null,"host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":279004175,"owners_count":26083688,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2022-07-04T15:15:14.044Z","status":"online","status_checked_at":"2025-10-10T02:00:06.843Z","response_time":62,"last_error":null,"robots_txt_status":"success","robots_txt_updated_at":"2025-07-24T06:49:26.215Z","robots_txt_url":"https://github.com/robots.txt","online":true,"can_crawl_api":true,"host_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub","repositories_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories","repository_names_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repository_names","owners_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners"}},"keywords":["azure","failover","high-availability","sap-cloud-integration","sap-cloud-platform-integration","scalability","traffic-manager"],"created_at":"2024-10-29T19:27:00.261Z","updated_at":"2025-10-10T14:33:39.568Z","avatar_url":"https://github.com/MartinPankraz.png","language":null,"funding_links":[],"categories":[],"sub_categories":[],"readme":"# Distributed SAP Cloud Integration Scenarios\nArtifacts and SAP Community blog reference supporting failover and high availability examples for SAP Cloud Integration (formerly SCP Cloud Platform Integration) using Azure PaaS Services\n\n## 1. Failover with routing-based solution using Azure FrontDoor and API Management and cross-azure-region deployments\nFind more details on the SAP community [blog](https://blogs.sap.com/2020/11/23/how-to-crash-your-iflows-and-watch-them-failover-beautifully/) \n\nThe zip file \"DRDemo.zip\" contains the iFlows used in the blog.\n\nThis is useful to avoid the regular SAP CPI maintenance window for instance.\n\n## 2. Failover with DNS-based solution using Azure Traffic Manager\nFind more details on the SAP community [blog](https://blogs.sap.com/2021/01/18/second-round-of-crashing-iflows-in-cpi-and-failing-over-with-azure-even-simpler) \n\nThe zip file \"FailoverOnboarding.zip\" contains the iFlows used in the blog.\n\nSee also [SAP's Discovery Center Mission](https://github.com/SAP-samples/btp-cloud-integration-intelligent-routing) based upon my blog series.\n\n## 3. High availability concepts within same BTP and Azure region\nFind more details on the SAP community [blog](https://blogs.sap.com/2021/09/23/black-friday-will-take-your-cpi-instance-offline-unless/)\n\nSAP Docs for CPI API runtime setup can be found [here](https://help.sap.com/viewer/368c481cd6954bdfa5d0435479fd4eaf/Cloud/en-US/20e26a837a8449c4b8b934b07f71cb76.html). Required APIs to interact with CPI API runtime are described on the [SAP API Business Hub](https://api.sap.com/package/CloudIntegrationAPI?section=Artifacts).\n\nSecretSynchLogicApp.json contains the LogicApp template that integrates with Azure Event Grid. Find more detais on the required config and the Azure portal driven setup flow from your KeyVault on [Azure Docs](https://docs.microsoft.com/en-us/azure/key-vault/general/event-grid-logicapps). In order to use the template as is you need to fill the placeholders marked with \"\u003c\u003c\u003c\u003e\u003e\u003e\" and pre-provision Event Grid and KeyVault. I might provide a \"deploy to Azure\" button at a later point in time.\n\nThe LogicApp relies on a \"secret\" naming convention to pull the credentials for the CPI API call. \u003ccpi domain\u003e-usr or -pwd. That eases some of the configuration required and decouples the setting on the LogicApp.\n\nIn my example I am running two CPI instances. The first under domain dr-primary and the second under cpi-dr-secondary.\n\n![Secret list](/keyvault-secret-list.png)\n\nThe zip file \"ShowSharedSecret.zip\" contains an iFlow that reads the CPI credential \"CPI-AUTH-SHARED\" during runtime. I used to verify the approach and correct setup.\n\n\nReach out through the GitHub Issues or the comments section on blogs.sap.com.\n\nCheers\nMartin","project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fmartinpankraz%2Fdistributed-sap-cloud-integration","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Fmartinpankraz%2Fdistributed-sap-cloud-integration","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fmartinpankraz%2Fdistributed-sap-cloud-integration/lists"}