SAP, DevOps && Cx
SAP InsideTrack Timisoara, April 2018
Prerequisites, current state and a look into the foreseeable future
data:image/s3,"s3://crabby-images/c958e/c958e97b0db24ac17033c2e391f0d4de5df7e1d0" alt=""
#sitTSR
About me
- Technical Guidance Unit @ msg systems
- organizer and speaker at #itconsapcj, now at it's 6th edition. www.itconferencesap.com
- Interests & Background:
- #CloudNative, #CloudFoundry
- #ABAP, #BOPF, #S4HANA
https://people.sap.com/victor.ionescu
@ivictor88 ( <-- look here for slides )
data:image/s3,"s3://crabby-images/f490a/f490aa9f00d87728220db959fda2f3db50f530b0" alt=""
data:image/s3,"s3://crabby-images/f44e6/f44e61a25ffe364f19cbd4e22b065e9d291fbc1d" alt=""
data:image/s3,"s3://crabby-images/3831b/3831bd7aab6d81397785c19cc221ff7ea27e60ef" alt=""
ionescuv.github.io
data:image/s3,"s3://crabby-images/13b1d/13b1df197ad565b39aea5812119a46657bc98cf6" alt=""
Why DevOps?
(A Developer Perspective)
How far into your project lifecycle are developers involved?
data:image/s3,"s3://crabby-images/7f196/7f1963d1761ddef7e54696e63910a4f448037434" alt=""
https://raygun.com/blog/software-testing/
The Result
data:image/s3,"s3://crabby-images/f185c/f185c116af8e7a6197a29f202876d851ba4b3b67" alt=""
Endless Documentation that is:
-
Always Incomplete
-
Never up-to-date
data:image/s3,"s3://crabby-images/96092/96092c44e4a3200d8477f2c833db6acd2e73d5db" alt=""
The Result
The Go-Live
data:image/s3,"s3://crabby-images/30009/30009bd1463eeca96f503cbd1235293317d5dbef" alt=""
a.k.a. High stress-levels, Weekend work & Emergency Conference Calls
An Alternative: Some Guiding Principles
data:image/s3,"s3://crabby-images/b3710/b3710b3cea4525a4d57be9ea2f6b67cad86c1b02" alt=""
Everybody is responsible for the delivery
- i.e. RUNNING software, in PRODUCTION
- not some KB of source code saved on a disk
data:image/s3,"s3://crabby-images/2b776/2b776d91344b212ebdc65415603bddee4095a93a" alt=""
Build quality in
- Test-Driven-Development
- Automated feature tests
data:image/s3,"s3://crabby-images/06006/06006fc321418eae966ebb5998feb84f16a6abbc" alt=""
data:image/s3,"s3://crabby-images/9de55/9de558316ef27f33715fb0df44ce84654164d567" alt=""
Automate everything
Reliable software delivery
- Practice the delivery
"If it hurts do it more often"
- Automate the recovery
- Infrastructure
- Configuration
- Tests
- Delivery Pipelines
Scenario 1: Continuous Delivery on the SAP Cloud Platform
What it looks like
- Develop locally
- Push to SCM
- Every change produces a releasable software version
git
CI/CD Pipeline
v.1.1.0
data:image/s3,"s3://crabby-images/dd6f1/dd6f1dc334497172e32bc222348f6d613d9463b3" alt=""
read that again:
Every change produces a releasable software version
"Trust is built in drops and lost in buckets"
DevOps principles..
..in practice
data:image/s3,"s3://crabby-images/b3710/b3710b3cea4525a4d57be9ea2f6b67cad86c1b02" alt=""
data:image/s3,"s3://crabby-images/2b776/2b776d91344b212ebdc65415603bddee4095a93a" alt=""
data:image/s3,"s3://crabby-images/9de55/9de558316ef27f33715fb0df44ce84654164d567" alt=""
data:image/s3,"s3://crabby-images/b6769/b6769fb244cbf7c2df394e1c0e8e4ed8d55ed3d7" alt=""
data:image/s3,"s3://crabby-images/94f0b/94f0bc910b9407926aa85b786cccd259b4523f73" alt=""
- no silos
- shared responsibility
data:image/s3,"s3://crabby-images/9ae98/9ae98030feaf1e23ebaee3b0001d935f957d0d7c" alt=""
data:image/s3,"s3://crabby-images/3bcb6/3bcb6f449942c077b85b46bfd665f1011e27c998" alt=""
Test Pyramid in Practice
data:image/s3,"s3://crabby-images/061c2/061c23191b8a772a41dd9043d5cd68135c462a75" alt=""
- unit tests
- integration tests
- contract tests
- e2e tests
data:image/s3,"s3://crabby-images/b6769/b6769fb244cbf7c2df394e1c0e8e4ed8d55ed3d7" alt=""
data:image/s3,"s3://crabby-images/9ae98/9ae98030feaf1e23ebaee3b0001d935f957d0d7c" alt=""
The Anatomy of a CD Pipeline
Scenario 2:
A look into the S/4 world
Constraints in a classical ABAP environment..
- No "offline" (or local) development
- heavyweight systems
- Constraints of the software delivery process (transports)
Dev
Prod
Transport Route
local IDE
Netweaver
Netweaver
Test
Netweaver
local IDE
local IDE
Unstable dev. environment, ill-suited for automated test execution (except unit test)
rigid software delivery
no rollback
snowflake environments
Stage?
on-the-fly environment creation not feasible
But newer solutions bring other opportunities
data:image/s3,"s3://crabby-images/31361/31361787b149388aa9a4470c3c520210c403afb9" alt=""
..and momentum is slowly rising..
data:image/s3,"s3://crabby-images/46dcb/46dcb65f8c31bfd76486745789a4861898371fc8" alt=""
One potential approach, many open questions...
Dev
Test
git
pull
static code check
unit tests / int. tests
deploy to staging
release
Staging
ABAP container
Transport Route
Netweaver
Netweaver
(or ABAP container?)
(or not?)
triggered by?
CI/CD Pipeline
local IDE
Full-stack support
Dev
Test
git
Staging
Netweaver
Netweaver
CI/CD Pipeline
local IDE
local IDE
(UI5)
ABAP & UI5 resources
end-to-end tests on the UI
data:image/s3,"s3://crabby-images/257d8/257d82e49034ba1f17f7e25443e8509461016ace" alt=""
Hybrid Scenarios
Given..
- S/4HANA On Premise
- Side-by-Side Extensions on SAP Cloud Platform
data:image/s3,"s3://crabby-images/3bcb6/3bcb6f449942c077b85b46bfd665f1011e27c998" alt=""
Netweaver
S/4HANA OnPremise
SAP Cloud Platform
Side-by-Side
Extensions
.. How is Cx still achievable?
CTS+ and MTAs
- OnPrem - Cloud "binding"
- MTAs attached to TRs
- CTS+ handles deployment
data:image/s3,"s3://crabby-images/3bcb6/3bcb6f449942c077b85b46bfd665f1011e27c998" alt=""
Netweaver
S/4HANA OnPremise
SAP Cloud Platform
Side-by-Side
Extensions
data:image/s3,"s3://crabby-images/0c8c3/0c8c3180a208cef45e2147e4a7278e4d1ddbf7e6" alt=""
Transport:
- ABAP
- UI5
- MTAs
data:image/s3,"s3://crabby-images/0c8c3/0c8c3180a208cef45e2147e4a7278e4d1ddbf7e6" alt=""
> ctsattach -a MTA -f archive.mtar -sid DEV
data:image/s3,"s3://crabby-images/3bcb6/3bcb6f449942c077b85b46bfd665f1011e27c998" alt=""
data:image/s3,"s3://crabby-images/3bcb6/3bcb6f449942c077b85b46bfd665f1011e27c998" alt=""
Prod
Clustered transports
Test
Test
Prod
data:image/s3,"s3://crabby-images/3bcb6/3bcb6f449942c077b85b46bfd665f1011e27c998" alt=""
Dev
Dev
Netweaver
Netweaver
Netweaver
SCP sub-account
SCP sub-account
SCP sub-account
DEV cluster
TEST cluster
PROD cluster
cCTS
Further reading: open SAP Course
"Cloud Native Operations"
data:image/s3,"s3://crabby-images/00303/0030303caa2a714322e5f41dea8462aedfd41420" alt=""
data:image/s3,"s3://crabby-images/00303/0030303caa2a714322e5f41dea8462aedfd41420" alt=""
ABAP
MTA
data:image/s3,"s3://crabby-images/1555c/1555c47742080d5d86ab9d295aa951258548e93e" alt=""
Conclusion
- Internalize the Principles
data:image/s3,"s3://crabby-images/b3710/b3710b3cea4525a4d57be9ea2f6b67cad86c1b02" alt=""
data:image/s3,"s3://crabby-images/2b776/2b776d91344b212ebdc65415603bddee4095a93a" alt=""
data:image/s3,"s3://crabby-images/9de55/9de558316ef27f33715fb0df44ce84654164d567" alt=""
2. Apply them to your context
3. Find the right tools to enable you
Further Reading
- SAP CI/CD Best Practices / Tutorial:
https://www.sap.com/germany/developer/tutorials/ci-best-practices-intro.html
- openSAP: Cloud-Native Operations
https://open.sap.com/courses/cp4
- SAP S/4 SDK Delivery Pipeline:
https://github.com/SAP/cloud-s4-sdk-pipeline
- abapGit:
https://github.com/larshp/abapGit
- Continuous Integration in ABAP:
https://blogs.sap.com/2017/11/11/continuous-integration-in-abap-using-jenkins/
Applying DevOps principles in SAP environments
By Victor Ionescu
Applying DevOps principles in SAP environments
- 3,111