Upgrade to Pro
— share decks privately, control downloads, hide ads and more …
Speaker Deck
Features
Speaker Deck
PRO
Sign in
Sign up for free
Search
Search
Continuous Delivery in Motion
Search
Avinash Chugh
May 07, 2016
Programming
0
100
Continuous Delivery in Motion
The deck we used for the XConf Jaipur 2016.
Avinash Chugh
May 07, 2016
Tweet
Share
More Decks by Avinash Chugh
See All by Avinash Chugh
Platform Thinking - Bringing Agility to Business
avinashchugh
0
22
Embracing the changing technology paradigms
avinashchugh
0
16
product thinking is problem solving.
avinashchugh
0
120
The anatomy of a platform.
avinashchugh
0
84
Evolutionary Enterprise Architectures
avinashchugh
0
51
seven tips to effective writing
avinashchugh
0
160
clean code: four rules of simple design
avinashchugh
5
1.1k
micro services, yotta benefits
avinashchugh
1
160
managing build artifacts with nexus
avinashchugh
0
57
Other Decks in Programming
See All in Programming
RISC-V カスタムのためのツールチェーン拡張 ― GNU Binutils と GCC の拡張・コミュニティへの参加編 (未完成版)
a4lg
0
190
「プログラマーのためのCPU入門」は入り口として丁度よい!
forrep
25
22k
OpCode目線で眺める PHPコードのカバレッジ
o0h
PRO
2
470
Vue 3.4
kazupon
13
3.6k
生成 AI の中身を覗いてみよう〜基礎から医療現場での応用まで〜
soh9834
2
700
mandaRa: R言語ユーザのための新しい知識共有の場 / mandara_tokyor111
s_uryu
2
410
マイクロサービスがほしいと思ったときに本当に必要だったもの〜なぜ人は共通基盤の夢を見るのか〜 / why microservice
77web
5
840
PHP で読む楽しいコアダンプ
sji
0
220
Go1.22からの疑似乱数生成器について/go-122-pseudo-random-generator
convto
1
110
Material 3で Material 2ぽい見た目にする
numeroanddev
2
220
軽率にVue 3で リアルタイム3Dアプリを作れる ライブラリを作ってみた/vue-with-3d-app
drumath2237
3
1.2k
TerraformをやめてCDKでReStartしたあと、 CDKをやめてCDK for TerraformでReStartした話
tmiura0203
0
770
Featured
See All Featured
Designing for humans not robots
tammielis
247
25k
Optimizing for Happiness
mojombo
369
69k
Creating an realtime collaboration tool: Agile Flush - .NET Oxford
marcduiker
11
1.4k
The Invisible Side of Design
smashingmag
293
49k
Stop Working from a Prison Cell
hatefulcrawdad
265
19k
Faster Mobile Websites
deanohume
296
30k
Building Better People: How to give real-time feedback that sticks.
wjessup
350
18k
WebSockets: Embracing the real-time Web
robhawkes
59
6.9k
The Cost Of JavaScript in 2023
addyosmani
13
3.7k
Visualization
eitanlees
135
14k
Designing with Data
zakiwarfel
94
4.8k
Unsuck your backbone
ammeep
660
56k
Transcript
CONTINUOUS DELIVERY IN MOTION Avinash Chugh & Praveer Gupta 1
AGENDA 2 ▪The business case ▪A typical delivery pipeline ▪Putting
it into practice
THE BUSINESS CASE 3
WHAT DOES IT TAKE FOR A BUSINESS TO SUCCEED 4
Faster time to market Being responsive to customer needs
TRUE AGILITY MEANS 5 Collaboration Rapid response to change Working
software
CONTINUOUS DELIVERY 6 Frequent Releases Reliable Releases
PERILS OF LONG RELEASE CYCLES 7 1 1 2 1
2 3 4 1 2 3 Release Time Unreleased changes = risk Risk Value
BENEFITS OF FREQUENT RELEASES 8 1 2 3 4 1
1 2 1 2 3 Release Release Release Released changes = value
9 HOW CAN I FREQUENTLY RELEASE SOFTWARE HOW CAN I
BUILD SOFTWARE INCREMENTALLY HOW CAN I CONFIDENTLY RELEASE NEW SOFTWARE
10 Release Iteration Story Commit MODERN DEVELOPMENT CYCLE
11 Series of commits Release MANY COMMITS FORMING A RELEASE
Release candidates Series of commits WHAT IF EACH COMMIT WERE
A RELEASE Releases on demand
DELIVERY PIPELINE 13
A DELIVERY PIPELINE 14 App Service Library
2. CI server checks out & compiles code 4. Code
analysis 5. Create & publish artifact 15 3. Unit tests 1. Developer commits code to SCM Commit Stage COMMIT STAGE
16 2. Retrieve artifact 4. Run smoke tests 5. Run
acceptance tests 3. Deploy artifact 1. Prepare environment Acceptance Stage ACCEPTANCE STAGE
17 2. Retrieve artifacts 4. Run smoke tests 3. Deploy
artifacts 1. Prepare environment Deploy Stage DEPLOY STAGE One-click deployments
1 2 3 4 5 6 A LOT HAPPENS BEFORE
A RELEASE 18 Regression testing User Acceptance Integration Infrastructure Setup Performance testing Security Audit
Increasing confidence Faster feedback SHORTER RELEASE CYCLE 19 Commit Live
TESTING PYRAMID 20 End to end – business facing Localized
– technology facing ▪Slower feedback ▪Higher cost of change
DEVELOPMENT IN SILOS 21 Merge Merge Trunk Anti-pattern: Feature branching
LOW REUSE AND MERGE ISSUES 22 Merge Merge Trunk 2
2 3 4 2 3 1 1 1 1 4 5 2 3 1 2 1 3 2 1 1 4 3 2 1 4 3 2 1 4 5 2 3
COLLABORATIVE DEVELOPMENT 23 Trunk 1 2 3 4 5 1
1 3 4 2 4 5 2 1 3 2 4 3 Key principle: Continuous Integration
CONTINUOUS INTEGRATION PRACTICES 24 ▪ One component, one repository ▪
Everyone commits to trunk every day ▪ No branches
25 CD Tools IAAS PAAS Mobile Systems Delivering software CONTINUOUS
DELIVERY IN DIVERSE CONTEXTS
CD IN PRACTICE 26
MANAGING LARGE CODE BASES 27 ▪ Dependency management ▪ Service
Oriented Architectures ▪ Microservices
RELEASING INCOMPLETE WORK 28 [featureToggles] wobblyFoobars: true flightyForkHandles: false Config
File <toggle name=wobblyFoobars> ... various UI elements </toggle> some.jsp forkHandle = (featureConfig.isOn(‘flightlyForkHandles)) ? new FlightyForkHander(aCandle) : new ForkHandler(aCandle) other.java Pattern: Feature toggles
GUIDELINES FOR FEATURE TOGGLES 29 ▪ Use them only when
needed ▪ Prefer feature hiding ▪ Remove toggles once feature is live
MAKING BIG CHANGES 30 Application New Library Library Pattern: Branch
by abstraction
31 Interface implements Application New Library Library MAKING BIG CHANGES
32 Interface implements Application New Library Library MAKING BIG CHANGES
33 Interface implements Application New Library Library MAKING BIG CHANGES
34 Interface implements Application New Library MAKING BIG CHANGES
35 Application New Library MAKING BIG CHANGES
WRAPPING UP 36
WHAT WE COVERED 37 ▪Fast feedback, and short release cycles
▪Keeping WIPs to a minimum ▪If it’s hard, do it more often ▪Trunk-based development ▪The need for automation ▪Feature toggles ▪Branch by abstraction
SO MUCH MORE TO EXPLORE 38 ▪Deployment strategies ▪Automated deployments
▪Configuration management ▪Infrastructure provisioning ▪Cloud deployments ▪Virtualization ▪Tooling support
39 ADDITIONAL READING
@thoughtworks THANK YOU