KEMBAR78
Introduction to DevOps slides-converted (1).pptx
Introduction to DevOps
Course Description
Course Description
The simultaneous needs for IT to 1) deploy new features and 2) keep systems up and running
creates a core conflict that challenges development, operations to the respond to business
needs customers in a timely manner. DevOps represents practices, tools, and a culture that
seeks to resolve this core conflict by enabling operations and development engineers to
participate together in the entire service life cycle, from design through the development
process to production support. This class will explore these practices, tools, and culture using
Gene Kim's "Three Ways of DevOps" as guideposts.
Course Audience
 Newcomers to Agile and DevOps will find this class a welcoming environment to learn the
basics on the DevOps mindset, The Three Ways, automation pipelines, common DevOps
systems and tools, and continuous integration / continuous delivery(CI/CD)
 Operations Engineers will appreciate the class focus on using DevOps to effectively
manage the large quantity and frequency of changes demanded in modern IT operations
while keeping systems stable
 Agile Teams already developing software using agile methods will find this class to be
a logical extension toward achieving synchronicity with operations and business using
DevOps
Learning Goals
Today
Experience the DevOps way of thinking
Form beliefs about how DevOps can work for you
Tomorrow
Identify actions for your project
Weeks/Months
See improved results
Create DevOps experiences for others
Years
Build a widespread DevOps Culture in our organization 3
Who are you?
What are you working on?
How do you plan to apply
DevOps?
Introductions
Let’s Review Our Progress with Agile So Far…
 Early and continuous delivery of
valuable software
 Rapid feedback
 Empirical decision-making
 Satisfied customers
 Business people and technical
people working together
 Measurement-based forecasting
 Harnessing change for competitive
advantage
The Agile Manifesto and the agile methods that followed focused on software
development – DevOps is a logical evolution of a maturing agile process
5
 Emergent design
 Technical excellence
 Empowered self-organizing teams
 Personal safety
 Sustainable pace
 High trust environments
 Lean processes
 Continuous improvement
We applied the agile empirical mindset and agile methods and observed
these results:
DevOps: Key Concepts
6
7
Leave class able to confidently answer these questions:
Who is Dev? Who is Ops?
What is DevOps?
“The beginning of wisdom
is the definition of terms”
- Socrates
The Basics
Traditional Development
The Inventors
 Create new features
and functionality in
“dev” environment
 Occasionally deliver
new product to
operators, along with
instructions
 May incorporate
feedback from
operators in future
deliveries
 Rewarded for
delivering new
features
The inventors are responsible for changing the system
8
Traditional Operations
The Mechanics
 Receive new product from
developers to be installed and
operated
 Expected to keep production
systems up and running
 Track problems, deployment
failures, and system outages
 May provide feedback to the
inventors for future consideration
 Penalized for downtime
9
The mechanics are responsible for keeping the system in operation
Differing Views on Change
10
Change Orientation Stability Orientation
Logical extremes
Alienate customers b/c system
doesn’t change
Alienate customers b/c system
constantly changes
Hero
Obstacle
We Have A LOT of Changes
Apoti Tech needs to update IT capabilities to support field users
AND
Apoti Tech needs to keep IT capabilities operational for use by field users
AND
Apoti Tech needs to keep IT capabilities compliant with security, regulatory, and
compatibility requirements
Can we
deploy new
patch for the
release?
Change?
deploy this
Change?
Prod is
running slow,
can you cycle
the server?
Can you
deploy this
one, small
Change?
Can you
upgrade the
operating
system?
Can we
deploy latest
version?
Can you
deploy this
one, small one, small
Change?
Can you
deploy this
one, small
CanCyhoaunge?
stage this
new
environment?
Can you
upgrade the
database
version?
Can you
deploy this
one, small
Can we apply
this security
patch? Canyou
Production
server is
down, fix it
now!!
Separation of Dev and Ops: A History
As computers became more complex, dev and ops
became necessarily specialized:
 Accelerating pace of technology
 Increased demand for turning around new features
 Huge amounts of data and number of calculations
 More and more specialized tools
 Increasingly abstract architectures and design
patterns
12
Nobody can be an expert in everything – your enterprise can’t rely on Brent!
Augusta Ada King,
Countess of Lovelace
(1815-1852)
And these were the problems in 1945!
The Reunification of Dev + Ops
13
DevOps in a Nutshell
DevOps is the practice of
operations and development
engineers participating together in
the entire service lifecycle, from
design through the development
process to production support
Monitoring,
Feedback, and
Action
Automated
Systems
People
Collaborating
Hmm… what would
happen if we extend
the core drivers of
successful agile
development to
operations?
What if we built a
bunch of great tools to
help us?
13
Breaking the Silos:
Communication, Collaboration, Integration
How can dev help system stability? How can ops help accelerate feature
delivery?
We can build cross-functional teams around “knowledge overlaps” – people
with experience on both sides and “Ops Devs”
Communication
Integration
Collaboration
Development Operations
14
Breaking the Silos: Dev and Ops
Development
Operations
Ops can
anticipate
how new
functionality
will effect
production Dev can respond
to bugs and
deployment
failures quickly
Dev and Ops can
work together to
permanently
remove root causes
of bugs and failures
 Ops trusts dev will provide good
code
15
 Dev trusts ops will put code in
prod quickly
 Visibility enables “trust but verify”
Dev and Ops Working Together
17
 Create feedback loops between
inventors and mechanics
 Expose real-time metrics from
ops enabling dev to learn from
the system running under real
world conditions
 Expose real-time metrics from
dev enabling ops to anticipate
production needs and provide
early input
 Cross-functional teams
collaborate to deliver whole
working systems including all
infrastructure, software code, and
configurations
Feature delivery + stability become shared goals
Matching IT Capacity to Business Demand
18
Breaking the Silos:
Communication, Collaboration, Integration
Communication
Integration
Collaboration
Development
Business
Operations
18
Breaking the Silos: Dev, Ops, and Business
Development
Business
Operations
Business
better
understands
capability for
changes to
features and
functionality
Dev can better
incorporate
needs of the
business and
customers into
new
development
19
Breaking the Silos: Dev, Ops, and Business
21
Development
Business
Operations
Business
better understands
operational
capabilities
Ops understands better how to
support business goals
Business Demand:
Continuously Deliver Valuable Software
Modern business is dependent on IT
deploying new features
Need very fast time-to-value in the
face of change
 Immigration policy can change
rapidly – IT capacity must keep up
 Immigration Executive Action
Multiyear lead time no longer
acceptable
Expectations for delivery times
continue to decrease
1st Way
Emphasize entire system
performance versus a specific
silo of work
2nd Way
Creating feedback
loops
3rd Way
Culture of continual experimentation
Understanding that mastery requires
practice
The Three Ways of DevOps by Gene Kim
The Three Ways describe the values that
frame the processes of DevOps and they
provide prescriptive steps
DevOps: The First Way
31
The First Way: Systems Thinking
32
Use systems thinking to ensure
work always flowsforward
“Work moving backwards, or standing still, is almost always indicative of
problems that need to be solved, and will span people, process and
technology.” –Gene Kim
What is a silo, really?
Disconnection from other people
No shared context
Different management
33
Barriers build up
Different incentives
Different objectives
Bad handoffs
Lack of understanding
Lack of empathy
“The nature of a large, complex organization is to fall out of alignment
without deliberate effort – inertia pulls it apart” –Damon Edwards
The First Way:
Bringing It All Together
40
Business
Dev
End Users
Ops
What is the minimum
viable product?
Is it profitable?
Do we have the
capability to build it
and maintain it?
DevOps: The First Way – Practices
41
Communication
Integration
Collaboration
DevOps Practice:
Deploy Shippable Environments
SHIPPABLECODE
AND SHIPPABLE
ENVIRONMENT
Communication
Integration
Collaboration
Traditionally, dev is responsible for applications while ops is responsible
for environments
In DevOps, we use a single repository for everything –functional code, test
code, environment configurations, and tool configurations
42
DevOps Practice:
Classify Ops Work by Four Types
Business Projects Internal IT Projects
Changes Unplanned Work
Types of
work
47
Systematically allocating time to the 4 types enables all the work to get
done and becomes routine
Communication
Integration
Collaboration
Exercise: Classify real Apoti Tech work according
to the
four types
DevOps: The Second Way
49
The Second Way: Amplify Feedback Loops
50
• Shorten and amplify “right to left” feedback loops
• Use feedback to create even higher quality at the
source
• Create and embed knowledge where it is needed to
provide immediate feedback
• Understand needs of all customers, internal and
external, and respond to their feedback
The goal of any process improvement is to shorten and amplify feedback loops
The Second Way:
Shorten and Amplify Feedback Loops
51
Develop
Commit
Test Build
Product Backlog
Issue Tracker
Manual tester
overloaded due
to end of sprint
Operations
End Users
Help Desk
Triage
Product Owner/
Value Team
10 steps to get
feedback & VERY long
delay
The Second Way:
Shorten and Amplify Feedback Loops (cont)
52
Develop
Commit
Test Build
Manual Test
Issue Tracker
5 steps to get
feedback
 Most users won’t call… some may just quit being customers
 Many defects remain latent for a long time
 By the time defects come back, dev forgets how the code works
53
The Second Way:
Shorten and Amplify Feedback Loops (cont)
Develop
Test Build
Commit
4 Steps to get
feedback – automated
and quick!
Failed
Automated Test
The Second Way:
Use Feedback to Create Quality at the Source
 Development is the source of quality – or problems
 As applications evolve, changes must not negatively impact end user
experiences
 Developers need access to deep diagnostics so they can incorporate
latest operational concerns and understand impact of their changes
Traces from slow transactions that
suggest performance bottlenecks in
distributed applications
Service-oriented architecture issues
spanning multiple application tiers
Correlation of application response
times on end-user satisfaction levels
Browser performance metrics
Application response times
Server usage
Performance data by technology
component
Runtime code diagnostics including
database queries
The Second Way:
Create and Embed Knowledge
• Ops and Security:
• Become part of the agile process – especially planning andprioritization
• Provide recommendations and requirements as new code developed
• Ensure relevant metrics are monitored early in the dev process
• Dev participates in incident handling to acquire knowledge to preventfuture
problems:
• Incident escalation
• Root cause analyses
• Post-mortems
• Ops receives cross training
by dev and security
• Extend agile practices to all
teams
• Visible work
• Open meetings
• Working agreements
• Explicit policies
Communication
Integration
Collaboration
36
The Second Way:
Respond to Needs of All Customers
 Use a service model for both internal and externalcustomers
 Agile encouraged dev and test to focus on customer collaboration withbusiness
stakeholders and end users
 DevOps extends the service model to Dev and Ops treating each other as
customers
Change Orientation Stability Orientation
Customer
Service
Provider
37
DevOps: The Second Way - Practices
57
Communication
Integration
Collaboration
DevOps Practice:
Deployment Automation
 Problems in deployment procedure will be found quickly and can be
permanently eliminated
 Runs fast “smoke test” to ensure system is running as expected
 Built-in automatic rollback and/or redeploy
 Build confidence through frequent repetition – the prospect of
deployments and rollback no longer instill fear
 Create a virtuous cycle of successful deployments, smaller
deployments, and lower risk
Communication
Integration
Collaboration
39
DevOps Practice:
Operations Monitoring
User Feedback Approach Monitored Approach
Field user calls Automatic alert about a problem when
it happens
Multiple people call Monitoring tools show me how
widespread the problem is
Users can’t tell me the real source of
the problem
I can see which component of the
application is generating errors
Monitoring gives us continuous, live feedback about how the system is running
“Tell me what is happening before the phone rings”
Communication
Integration
Collaboration
40
Operations Monitoring – Needs and Challenges
41
Monitoring Challenges
 Operators typically responsible for numerous applications
 Environments can be complex with unique or complicated application
stacks
 Visibility into different components can be vague or non-existent
 Quantity of logged data can be overwhelming
 Combining monitoring tools into a single view that provides insight
Monitoring Needs
 Active production monitoring, not just reacting to downtime
 Easily monitor critical areas of application stability with minimal tooling
 Tune dashboard to display key database, network, server, and
application performance measurements in a holistic view
 Ability to quickly share potential performance issues with your team
DevOps Practice:
Operations Monitoring Dashboard
Application
Response
Time
Application
Performance
Index (User
Satisfaction)
Application
Throughput
Alerts
Transaction
Timings (drill down
capability to code
level, transaction
level)
Communication
Integration
Collaboration
DevOps Practice:
Communication
Operations Monitoring Drives Dev & Ops PriorCo
i
llab
t
orati
i
on
es
Integration
DevOps Practice:
Prioritize Fixing Production Defects
Prioritize fixing defects very fast
63
• Assume incidents will occur
• Ensure ops feedback will come
back rapidly
• Ensure developers will get the info
they need to fix the problem
• Add automated tests to ensure
problem cannot reoccur
• Get really good at fixing defects
very fast
Communication
Integration
Collaboration
DevOps Practice:
Reusable Ops and Security User Stories
Communication
Integration
Collaboration
As security I want cross-site
scripting attacks prevented so
that access controls cannot be
bypassed
Estimat
e
5 points
Priorit
y
1
(High)
• Verify all input is filtered
as potentially malicious
• Verify all output of the page is
encoded to the explicitly
defined character set
• Verify output is sanitized by
escaping dynamic content to
properly enforce separation of
code and data
Acceptance
Criteria
User
Story
On
back…
As an ops engineer I
want to monitor how many
people are listening to audio
feeds so I can tune playback
quality during spikes in demand
Estimat
e
3 points
Priorit
y
2
(Med)
• Verify the count of active
audio sessions is displayed
in the application’s admin
dashboard
• Verify the count is accurate
as playback sessions are
added or completed
Acceptance
Criteria
User
Story
45
On
back…
DevOps Practice:
Dev & Ops Common Communication System
Communication
Integration
Collaboration
46
Remove all barriers to internal communication, collaboration, and
integration
 Use common, intuitive dashboards combining information from all groups
 Key operational metrics
 Visible dev, ops, and security workflow (e.g. Kanban boards)
 List of recent and upcoming system changes
 Stability of the system
 Security status
 Schedules, planned release dates, and critical business dates
 Integrated alert policies
 Common internal note system – histories of defects and incidents can be
very useful
 Shared wikis, file repositories, chat spaces, specs, and documentation
DevOps Practice:
Track Dev & Ops Business Impact
 MTTR – Mean Time To Repair – How long is the system down?
 MTBF – Mean Time Between Failures – How often is the system down?
Apoti Tech Example:
Key Performance Parameter(KPP) Service Agreement
Low Threshold
Objective Actual
Reliability – uninterrupted correct
function
641 hours 712 hours 739 hours
Exceeded Objective
Availability – 24/7 operations 97.63 % 98.88% 99.32%
Exceeded Objective
Maintainability – prompt restoration
of service afteroutage
No more than 10 hours No more than 8 hours 5 hours
Exceeded Objective
Communication
Integration
Collaboration
Doing DevOps at Apoti Tech – Second
Way
 Demonstrated information integration and collaboration between dev, ops,
security, and business
 Partial or completely automated deployment – rapid, reliable, testable,
repeatable
 Operational Monitoring Plan – preferably a dashboard
 Defined business impact measurements and thresholds
See Team-Managed Deployment Management Instruction for more information
67
Automating an
Integrated DevOps
System
Systems to Make Software
Communication
System

Monitoring
System
Deploy
System


Documentation
System
Issue
 Version
Control
(CM)
 Requirements


Build
System

Code
Review
Test System

A good method of enabling DevOps
is to simply begin connecting and
automation the systems you use to
make software.
• Start where you are
• Identify possible
interconnections
• Research tools to automate
• Create future state roadmap
• Let pipeline emerge
• Continue to improve the
sequence of connections as
systems change
 System
Tracking
50
Version Control
Communication
System

Monitoring
System
Deploy
System

Issue

Documentation
System
 Version
Control
(CM)
 Requirements


Build
System

Code
Review
Test System

Version Control
Ensures you’re working on the right
version of something
 System
Tracking
51
Requirements System
Communication
System

Monitoring
System
Deploy
System


Issue
Documentation
System
 Version
Control
(CM)
 Requirements


Build
System

Code
Review
Test System

Requirements System
Houses project requirements in a
prioritized list and allows for item
allocation to sprint/team member;
Allows for traceability of
dependencies between stories
 System
Tracking
52
Build System
Communication
System

Monitoring
System
Deploy
System

Issue

Documentation
System
 Version
Control
(CM)
 Requirements


Build
System
Test System

Code
Review

Build System
Software tools designed to
automate the process of program
compilation to create a
deployable package
 System
Tracking
53
Test System
Communication
System

Monitoring
System
Deploy
System

Documentation
System 
Issue
 Version
Control
(CM)
 Requirements


Build
System
Test System

Code
Review

Test System
orchestrated set of tests, both
manual and automated that
ensure the functionality and
accuracy of code
 System
Tracking
54
Code Review System
Communication
System

Monitoring
System
Deploy
System

Documentation
System 
Issue
 Version
Control
(CM)
 Requirements


Build
System
Test System

Code
Review

Code Review System
Ensures that code complies with
standards and identifies low level
bugs and coding errors; Identifies
design and requirements
compliance
 System
Tracking
55
Issue Tracking System
Communication
System

Monitoring
System
Deploy
System

Issue

Documentation
System
 Version
Control
(CM)
 Requirements


Build
System

Code
Review
Test System

Issue Tracking System
Collects issues throughout the
cycle of the project and track
them through completion
 System
Tracking
56
Documentation System
Communication
System

Monitoring
System
Deploy
System

Issue

Documentation
System
 Version
Control
(CM)
 Requirements


Build
System

Code
Review
Test System

Documentation System
Repository of system information
throughout the lifecycle
 System
Tracking
57
Deploy System
Communication
System

Monitoring
System
Deploy
System

Documentation
System 
Issue
 Version
Control
(CM)
 Requirements


Build
System

Code
Review
Test System

Deploy System
Installs and configures the
package created by the build
system into appropriate
environments
 System
Tracking
58
Monitoring
Communication
System

Monitoring
System
Deploy
System

Issue

Documentation
System
 Version
Control
(CM)
 Requirements


Build
System

Code
Review
Test System

Monitoring System
Collects current-state data to
determine health of all
environments
 System
Tracking
59
Communication System
Communication
System

Monitoring
System
Deploy
System

Issue

Documentation
System
 Version
Control
(CM)
 Requirements


Build
System

Code
Review
Test System

Communication System
Method for conveying information
between systems
 System
Tracking
60
Automate All the Connections!
Communication
System

Monitoring
System
Deploy
System


Issue
Documentation
System
 Version
Control
(CM)
 Requirements


Build
System

Code
Review
Test System

 System
Tracking
61
Orchestrating Integration with a Pipeline
Pipelines
User Commits Merge code Build
Unit
test/coverage
Code Review Log Issues Deploy
63
A Pipeline is a chain of tasks that can be automated
 Integration tools use pipelines to perform tasks repetitively and
continuously
 The process is called Continuous Integration (CI)
 Pipelines keep work flowing forward in our DevOps system
Communication
System

Monitoring
System
Deploy
System

Issue

Documentation
System
 Version
Control
(CM)
 Requirements


Build
System

Code
Review
Test System

Pipeline
Orchestration
We Need Something to Integrate the Systems
 System
Tracking
64
Communication
System

Monitoring
System
Deploy
System


Documentation
System
Issue
 Version
Control
(CM)
 Requirements


Build
System
Test System

Code
Review

Pipeline
Orchestration
Development Pipeline Example
 System
Tracking
65
Communication
System

Monitoring
System
Deploy
System


Documentation
System
Issue
 Version
Control
(CM)
 Requirements


Build
System
Test System

Code
Review

Code is
committed and
Merged
Initiate Build
Initiate
Testing
Development Pipeline Example with Integration
System Commit code
 System
Tracking
66
Pipeline
Orchestration
Pipeline Stages
Code Done Unit Tests Integrate
Acceptance
Testing
Deploy to
Production
86
Continuous Delivery
Auto Manual
Auto Auto
Continuous Deployment
Code Done Unit Tests Integrate
Acceptance
Testing
Deploy to
Production
Auto Auto Auto Auto
Code Done Unit Tests Integrate
Continuous Integration
Auto Auto
CI Pipeline Example
87
CI Pipeline
CM
Repository
Staging
Integration
Master
Fail
STOP
Fail
STOP
Fail
STOP
Success Success Success
Commit
Commit
Commit
New Feature
(NF)
Legacy Feature
(LF)
Bad Feature
(BF)
Build gate
Compile Code
Code Quality
GatesApplied
Smoke Tests
If Successful,
Merge with
Staging
Staging gate
Compile Code
Functional
Tests
If Successful,
Merge with
Integration
Branch
Integration
gate
Compile Code
Merge with
Master
Fortify Scans
Release is
packaged
Using a CI/CD Pipeline for Team-
Managed Deployments at Apoti Tech
RRR eRRR TMD
Deploy
Manual
Test
Auto.
Test
Auto.
Build
OR
OR
Approval:
CI/CD Pipeline:
DevOps:
Development Operations
Team Managed Deployment (TMD) provides the approval step for a CI/CD
Pipeline. The CI/CD Pipeline provides the forward link from Development to
Operations.
Using a CI/CD Pipeline for Team-
Managed Deployments at Apoti Tech
(cont)
RRR Documents
VDD
Release Number
Source Code File List
List of Changes
Deployment
Instructions
TAS
Test Results
Test History
CI/CD Pipeline Artifacts
Pipeline
Release Number
Deployment Scripts
Version
Control
Source Code File List
List of Changes
Test Tools
Test Results
Test History
Automation used in a CI/CD pipeline allows data to be collected as true
artifacts. In an RRR approach, the information is manually collected into
documents.
DevOps: The Third Way
90
DevOps is Not…
91
A tool
A role
A team
Something that can be
purchased or simply switched
on
DevOps requires a culture of operations and development engineers participating
together in the entire service lifecycle
• Continual experimentation, taking risks, and learning
from failure
• Understanding that repetition is the prerequisite to
master
The Third Way: Culture of Improvement
The Third Way:
Experimentation, Risk-Taking, and Learning
93
Develop a culture that pushes into the
danger zone
Develop habits to survive danger
Build experimentation, risk-taking, and
learning into our way of doing business
Break things early and often
Intuit ran 165 experiments on their
TurboTax product in the 3 main months of
tax season – ideas made it to market a
year earlier and they increased customer
conversion rate by 50%
The Third Way:
Repetition for Mastery
94
• Do the hard parts often
• Work through pain points to make the
process easier
• Do painful things MORE frequently to make
it less painful
• Reduce anxiety about unexpected outcomes
• Automate!!!
DevOps: The Third Way - Practices
95
Communication
Integration
Collaboration
DevOps Practice:
Inject Failures
96
• Netflix services are hosted completely in
Amazon Web Services cloud
• Design each distributed system to expect
and tolerate failure
• Chaos Monkey randomly kills
services within architecture in order to
learn to tolerate and respond to failure
DevOps Approach
 How does this system react if I do
this?
 Can we continue operations
without this server?
 Will the users prefer option A or
option B?
Traditional Approach
 Not in my system, you don’t
 Not in my system, you don’t
 Not in my system, you don’t
Communication
Integration
Collaboration
DevOps Practice:
Make Your Improvement Work Visible
97
Along with regular user stories, use
colored cards to indicate:
• Technical debt
• Unplanned work
• Experiments
• Learning backlog
Allocate time to improve daily work
Track the work needed to maintain overall
health of the system
Communication
Integration
Collaboration
DevOps Practice:
Regularly Improve Technical Debt
98
Allocate 20% of cycles to Technical Debt Reduction
• Write tests to find misconfigurations – and fix them
• Constantly run automated static code analysis during
continuous integration and testing, and raise the bar in your
quality gates
• Enforce consistency in code, environments, and configurations
• Repeatedly tackle the hard stuff
Communication
Integration
Collaboration
DevOps Practice:
Regularly Improve Tools
 Good tools are key to enabling
DevOps collaboration, automation,
and visibility
 Provide teams the best tools available
 Regularly invest time researching and
piloting new tools
 Provide expert support
Communication
Integration
Collaboration
80
DevOps Practice:
Reward Contributions to a DevOps Culture
 Incentivize DevOps practices and behaviors
 Recognize experimentation and risk-taking that leads to valuable
learning
 Model honest self-assessment of organizational strengths and
weaknesses and use of improvement techniques such as Toyota
Kata
 Quantify and promote the link between DevOps practices and
organizational performance
Communication
Integration
Collaboration
81
DevOps Practice:
101
Org
Change
Patterns
Decentralized,
emergent
Protected,
dedicated
team
Organizational
baby steps
Champions/
advocates
Boss’ orders
Communication
Integration
Conduct Deliberate Culture Change Experimen
Collab
t
orati
s
on
Discussion: What are our biggest cultural challenges? What experiments
should we run?
DevOps Team Profiles
DevOps Team Member
 End-to-end viewpoint
 Contributes to and uses visibility
 Automator
 Collaborative, cross-functional,
friction reducer
 Participates in collective
ownership of code and code
delivery
 Personal success = team success
 Enjoys working this way 102
DevOps Expert Support Team
 Helps introduce DevOps-
supportive processes and tools
 Works with teams to automate
environment creation and
deployment
 Helps teams use operational
performance logs and
dashboards
 Provides infrastructure support
Food for Thought – Maturing DevOps Practices
Level 1 Level 2 Level 3 Level 4 Level 5
Culture &
Processes
 Frequent commits
 Prioritized work
 Defined & documented
process
 One backlog team anda
master backlog
 Adopt basicagile
methods
 Remove boundary ofdev
& test
 Team collaboration
 Remove boundary of
dev & ops
 Act on metrics
 Common processesfor
all changes
 Dedicated tools teamfor
automation
 Deploy disconnected
from Release
 Continuous improvement
 Cross functionalteams
 No rollbacks
Architecture
 Define Context View,
Logical Composition&
Physical Composition
 Stage SDD wiki with
Views in place
 Define related views
 Review process in place  ?  ?
Build / Deploy
 Versioned code base
 Scripted builds
 Basic scheduledbuilds
 Dedicated build server
 Documentedmanual
deploy
 Poling builds
 Build are stored
 Manual Tag & Versioning
 First steptowards
standardizeddeploys
 Auto triggered builds
 Automated tag&
versioning
 Automated bulk ofDB
changes
 Basic pipelinewith
deploy to prod
 Scripted configuration
changes
 Standard process forall
environments
 Zero downtime deploy
 Multiple buildmachines
 Full automated DB
deploys
 Zero touch continuous
deployments
Test & Verification
 Automated Unit Tests
(Coverage <50%)
 Separate test
environment
 Automated Unit Tests
(Coverage >50% & <
80%)
 Automated Integration
Tests (Coverage ??)
 Automated Functional
tests
 Automatedacceptance
criteria (<40%)
 Automated acceptance
criteria (80%)
 Automated performance
tests
 Automated Security
Tests
 Automated Section508
tests
 All tests automated
 Coverage 100%
Collaboration &
Information
Sharing
 Baseline process metrics
 Manual reporting
 Static code analysis
 Quality reports
 History ofreports
available
 Traceability builtinto
pipeline
 Report trend analysis
 Graphing as a service
 Reports accessiblevia
commondashboard
 Dynamic graphing
103
Wrap Up
104
Any Questions?

Introduction to DevOps slides-converted (1).pptx

  • 1.
  • 2.
    Course Description Course Description Thesimultaneous needs for IT to 1) deploy new features and 2) keep systems up and running creates a core conflict that challenges development, operations to the respond to business needs customers in a timely manner. DevOps represents practices, tools, and a culture that seeks to resolve this core conflict by enabling operations and development engineers to participate together in the entire service life cycle, from design through the development process to production support. This class will explore these practices, tools, and culture using Gene Kim's "Three Ways of DevOps" as guideposts. Course Audience  Newcomers to Agile and DevOps will find this class a welcoming environment to learn the basics on the DevOps mindset, The Three Ways, automation pipelines, common DevOps systems and tools, and continuous integration / continuous delivery(CI/CD)  Operations Engineers will appreciate the class focus on using DevOps to effectively manage the large quantity and frequency of changes demanded in modern IT operations while keeping systems stable  Agile Teams already developing software using agile methods will find this class to be a logical extension toward achieving synchronicity with operations and business using DevOps
  • 3.
    Learning Goals Today Experience theDevOps way of thinking Form beliefs about how DevOps can work for you Tomorrow Identify actions for your project Weeks/Months See improved results Create DevOps experiences for others Years Build a widespread DevOps Culture in our organization 3 Who are you? What are you working on? How do you plan to apply DevOps? Introductions
  • 4.
    Let’s Review OurProgress with Agile So Far…  Early and continuous delivery of valuable software  Rapid feedback  Empirical decision-making  Satisfied customers  Business people and technical people working together  Measurement-based forecasting  Harnessing change for competitive advantage The Agile Manifesto and the agile methods that followed focused on software development – DevOps is a logical evolution of a maturing agile process 5  Emergent design  Technical excellence  Empowered self-organizing teams  Personal safety  Sustainable pace  High trust environments  Lean processes  Continuous improvement We applied the agile empirical mindset and agile methods and observed these results:
  • 5.
  • 6.
    7 Leave class ableto confidently answer these questions: Who is Dev? Who is Ops? What is DevOps? “The beginning of wisdom is the definition of terms” - Socrates The Basics
  • 7.
    Traditional Development The Inventors Create new features and functionality in “dev” environment  Occasionally deliver new product to operators, along with instructions  May incorporate feedback from operators in future deliveries  Rewarded for delivering new features The inventors are responsible for changing the system 8
  • 8.
    Traditional Operations The Mechanics Receive new product from developers to be installed and operated  Expected to keep production systems up and running  Track problems, deployment failures, and system outages  May provide feedback to the inventors for future consideration  Penalized for downtime 9 The mechanics are responsible for keeping the system in operation
  • 9.
    Differing Views onChange 10 Change Orientation Stability Orientation Logical extremes Alienate customers b/c system doesn’t change Alienate customers b/c system constantly changes Hero Obstacle
  • 10.
    We Have ALOT of Changes Apoti Tech needs to update IT capabilities to support field users AND Apoti Tech needs to keep IT capabilities operational for use by field users AND Apoti Tech needs to keep IT capabilities compliant with security, regulatory, and compatibility requirements Can we deploy new patch for the release? Change? deploy this Change? Prod is running slow, can you cycle the server? Can you deploy this one, small Change? Can you upgrade the operating system? Can we deploy latest version? Can you deploy this one, small one, small Change? Can you deploy this one, small CanCyhoaunge? stage this new environment? Can you upgrade the database version? Can you deploy this one, small Can we apply this security patch? Canyou Production server is down, fix it now!!
  • 11.
    Separation of Devand Ops: A History As computers became more complex, dev and ops became necessarily specialized:  Accelerating pace of technology  Increased demand for turning around new features  Huge amounts of data and number of calculations  More and more specialized tools  Increasingly abstract architectures and design patterns 12 Nobody can be an expert in everything – your enterprise can’t rely on Brent! Augusta Ada King, Countess of Lovelace (1815-1852) And these were the problems in 1945!
  • 12.
  • 13.
    DevOps in aNutshell DevOps is the practice of operations and development engineers participating together in the entire service lifecycle, from design through the development process to production support Monitoring, Feedback, and Action Automated Systems People Collaborating Hmm… what would happen if we extend the core drivers of successful agile development to operations? What if we built a bunch of great tools to help us? 13
  • 14.
    Breaking the Silos: Communication,Collaboration, Integration How can dev help system stability? How can ops help accelerate feature delivery? We can build cross-functional teams around “knowledge overlaps” – people with experience on both sides and “Ops Devs” Communication Integration Collaboration Development Operations 14
  • 15.
    Breaking the Silos:Dev and Ops Development Operations Ops can anticipate how new functionality will effect production Dev can respond to bugs and deployment failures quickly Dev and Ops can work together to permanently remove root causes of bugs and failures  Ops trusts dev will provide good code 15  Dev trusts ops will put code in prod quickly  Visibility enables “trust but verify”
  • 16.
    Dev and OpsWorking Together 17  Create feedback loops between inventors and mechanics  Expose real-time metrics from ops enabling dev to learn from the system running under real world conditions  Expose real-time metrics from dev enabling ops to anticipate production needs and provide early input  Cross-functional teams collaborate to deliver whole working systems including all infrastructure, software code, and configurations Feature delivery + stability become shared goals
  • 17.
    Matching IT Capacityto Business Demand 18
  • 18.
    Breaking the Silos: Communication,Collaboration, Integration Communication Integration Collaboration Development Business Operations 18
  • 19.
    Breaking the Silos:Dev, Ops, and Business Development Business Operations Business better understands capability for changes to features and functionality Dev can better incorporate needs of the business and customers into new development 19
  • 20.
    Breaking the Silos:Dev, Ops, and Business 21 Development Business Operations Business better understands operational capabilities Ops understands better how to support business goals
  • 21.
    Business Demand: Continuously DeliverValuable Software Modern business is dependent on IT deploying new features Need very fast time-to-value in the face of change  Immigration policy can change rapidly – IT capacity must keep up  Immigration Executive Action Multiyear lead time no longer acceptable Expectations for delivery times continue to decrease
  • 22.
    1st Way Emphasize entiresystem performance versus a specific silo of work 2nd Way Creating feedback loops 3rd Way Culture of continual experimentation Understanding that mastery requires practice The Three Ways of DevOps by Gene Kim The Three Ways describe the values that frame the processes of DevOps and they provide prescriptive steps
  • 23.
  • 24.
    The First Way:Systems Thinking 32 Use systems thinking to ensure work always flowsforward “Work moving backwards, or standing still, is almost always indicative of problems that need to be solved, and will span people, process and technology.” –Gene Kim
  • 25.
    What is asilo, really? Disconnection from other people No shared context Different management 33 Barriers build up Different incentives Different objectives Bad handoffs Lack of understanding Lack of empathy “The nature of a large, complex organization is to fall out of alignment without deliberate effort – inertia pulls it apart” –Damon Edwards
  • 26.
    The First Way: BringingIt All Together 40 Business Dev End Users Ops What is the minimum viable product? Is it profitable? Do we have the capability to build it and maintain it?
  • 27.
    DevOps: The FirstWay – Practices 41 Communication Integration Collaboration
  • 28.
    DevOps Practice: Deploy ShippableEnvironments SHIPPABLECODE AND SHIPPABLE ENVIRONMENT Communication Integration Collaboration Traditionally, dev is responsible for applications while ops is responsible for environments In DevOps, we use a single repository for everything –functional code, test code, environment configurations, and tool configurations 42
  • 29.
    DevOps Practice: Classify OpsWork by Four Types Business Projects Internal IT Projects Changes Unplanned Work Types of work 47 Systematically allocating time to the 4 types enables all the work to get done and becomes routine Communication Integration Collaboration Exercise: Classify real Apoti Tech work according to the four types
  • 30.
  • 31.
    The Second Way:Amplify Feedback Loops 50 • Shorten and amplify “right to left” feedback loops • Use feedback to create even higher quality at the source • Create and embed knowledge where it is needed to provide immediate feedback • Understand needs of all customers, internal and external, and respond to their feedback The goal of any process improvement is to shorten and amplify feedback loops
  • 32.
    The Second Way: Shortenand Amplify Feedback Loops 51 Develop Commit Test Build Product Backlog Issue Tracker Manual tester overloaded due to end of sprint Operations End Users Help Desk Triage Product Owner/ Value Team 10 steps to get feedback & VERY long delay
  • 33.
    The Second Way: Shortenand Amplify Feedback Loops (cont) 52 Develop Commit Test Build Manual Test Issue Tracker 5 steps to get feedback
  • 34.
     Most userswon’t call… some may just quit being customers  Many defects remain latent for a long time  By the time defects come back, dev forgets how the code works 53 The Second Way: Shorten and Amplify Feedback Loops (cont) Develop Test Build Commit 4 Steps to get feedback – automated and quick! Failed Automated Test
  • 35.
    The Second Way: UseFeedback to Create Quality at the Source  Development is the source of quality – or problems  As applications evolve, changes must not negatively impact end user experiences  Developers need access to deep diagnostics so they can incorporate latest operational concerns and understand impact of their changes Traces from slow transactions that suggest performance bottlenecks in distributed applications Service-oriented architecture issues spanning multiple application tiers Correlation of application response times on end-user satisfaction levels Browser performance metrics Application response times Server usage Performance data by technology component Runtime code diagnostics including database queries
  • 36.
    The Second Way: Createand Embed Knowledge • Ops and Security: • Become part of the agile process – especially planning andprioritization • Provide recommendations and requirements as new code developed • Ensure relevant metrics are monitored early in the dev process • Dev participates in incident handling to acquire knowledge to preventfuture problems: • Incident escalation • Root cause analyses • Post-mortems • Ops receives cross training by dev and security • Extend agile practices to all teams • Visible work • Open meetings • Working agreements • Explicit policies Communication Integration Collaboration 36
  • 37.
    The Second Way: Respondto Needs of All Customers  Use a service model for both internal and externalcustomers  Agile encouraged dev and test to focus on customer collaboration withbusiness stakeholders and end users  DevOps extends the service model to Dev and Ops treating each other as customers Change Orientation Stability Orientation Customer Service Provider 37
  • 38.
    DevOps: The SecondWay - Practices 57 Communication Integration Collaboration
  • 39.
    DevOps Practice: Deployment Automation Problems in deployment procedure will be found quickly and can be permanently eliminated  Runs fast “smoke test” to ensure system is running as expected  Built-in automatic rollback and/or redeploy  Build confidence through frequent repetition – the prospect of deployments and rollback no longer instill fear  Create a virtuous cycle of successful deployments, smaller deployments, and lower risk Communication Integration Collaboration 39
  • 40.
    DevOps Practice: Operations Monitoring UserFeedback Approach Monitored Approach Field user calls Automatic alert about a problem when it happens Multiple people call Monitoring tools show me how widespread the problem is Users can’t tell me the real source of the problem I can see which component of the application is generating errors Monitoring gives us continuous, live feedback about how the system is running “Tell me what is happening before the phone rings” Communication Integration Collaboration 40
  • 41.
    Operations Monitoring –Needs and Challenges 41 Monitoring Challenges  Operators typically responsible for numerous applications  Environments can be complex with unique or complicated application stacks  Visibility into different components can be vague or non-existent  Quantity of logged data can be overwhelming  Combining monitoring tools into a single view that provides insight Monitoring Needs  Active production monitoring, not just reacting to downtime  Easily monitor critical areas of application stability with minimal tooling  Tune dashboard to display key database, network, server, and application performance measurements in a holistic view  Ability to quickly share potential performance issues with your team
  • 42.
    DevOps Practice: Operations MonitoringDashboard Application Response Time Application Performance Index (User Satisfaction) Application Throughput Alerts Transaction Timings (drill down capability to code level, transaction level) Communication Integration Collaboration
  • 43.
    DevOps Practice: Communication Operations MonitoringDrives Dev & Ops PriorCo i llab t orati i on es Integration
  • 44.
    DevOps Practice: Prioritize FixingProduction Defects Prioritize fixing defects very fast 63 • Assume incidents will occur • Ensure ops feedback will come back rapidly • Ensure developers will get the info they need to fix the problem • Add automated tests to ensure problem cannot reoccur • Get really good at fixing defects very fast Communication Integration Collaboration
  • 45.
    DevOps Practice: Reusable Opsand Security User Stories Communication Integration Collaboration As security I want cross-site scripting attacks prevented so that access controls cannot be bypassed Estimat e 5 points Priorit y 1 (High) • Verify all input is filtered as potentially malicious • Verify all output of the page is encoded to the explicitly defined character set • Verify output is sanitized by escaping dynamic content to properly enforce separation of code and data Acceptance Criteria User Story On back… As an ops engineer I want to monitor how many people are listening to audio feeds so I can tune playback quality during spikes in demand Estimat e 3 points Priorit y 2 (Med) • Verify the count of active audio sessions is displayed in the application’s admin dashboard • Verify the count is accurate as playback sessions are added or completed Acceptance Criteria User Story 45 On back…
  • 46.
    DevOps Practice: Dev &Ops Common Communication System Communication Integration Collaboration 46 Remove all barriers to internal communication, collaboration, and integration  Use common, intuitive dashboards combining information from all groups  Key operational metrics  Visible dev, ops, and security workflow (e.g. Kanban boards)  List of recent and upcoming system changes  Stability of the system  Security status  Schedules, planned release dates, and critical business dates  Integrated alert policies  Common internal note system – histories of defects and incidents can be very useful  Shared wikis, file repositories, chat spaces, specs, and documentation
  • 47.
    DevOps Practice: Track Dev& Ops Business Impact  MTTR – Mean Time To Repair – How long is the system down?  MTBF – Mean Time Between Failures – How often is the system down? Apoti Tech Example: Key Performance Parameter(KPP) Service Agreement Low Threshold Objective Actual Reliability – uninterrupted correct function 641 hours 712 hours 739 hours Exceeded Objective Availability – 24/7 operations 97.63 % 98.88% 99.32% Exceeded Objective Maintainability – prompt restoration of service afteroutage No more than 10 hours No more than 8 hours 5 hours Exceeded Objective Communication Integration Collaboration
  • 48.
    Doing DevOps atApoti Tech – Second Way  Demonstrated information integration and collaboration between dev, ops, security, and business  Partial or completely automated deployment – rapid, reliable, testable, repeatable  Operational Monitoring Plan – preferably a dashboard  Defined business impact measurements and thresholds See Team-Managed Deployment Management Instruction for more information 67
  • 49.
  • 50.
    Systems to MakeSoftware Communication System  Monitoring System Deploy System   Documentation System Issue  Version Control (CM)  Requirements   Build System  Code Review Test System  A good method of enabling DevOps is to simply begin connecting and automation the systems you use to make software. • Start where you are • Identify possible interconnections • Research tools to automate • Create future state roadmap • Let pipeline emerge • Continue to improve the sequence of connections as systems change  System Tracking 50
  • 51.
    Version Control Communication System  Monitoring System Deploy System  Issue  Documentation System  Version Control (CM) Requirements   Build System  Code Review Test System  Version Control Ensures you’re working on the right version of something  System Tracking 51
  • 52.
    Requirements System Communication System  Monitoring System Deploy System   Issue Documentation System  Version Control (CM) Requirements   Build System  Code Review Test System  Requirements System Houses project requirements in a prioritized list and allows for item allocation to sprint/team member; Allows for traceability of dependencies between stories  System Tracking 52
  • 53.
    Build System Communication System  Monitoring System Deploy System  Issue  Documentation System  Version Control (CM) Requirements   Build System Test System  Code Review  Build System Software tools designed to automate the process of program compilation to create a deployable package  System Tracking 53
  • 54.
    Test System Communication System  Monitoring System Deploy System  Documentation System  Issue Version Control (CM)  Requirements   Build System Test System  Code Review  Test System orchestrated set of tests, both manual and automated that ensure the functionality and accuracy of code  System Tracking 54
  • 55.
    Code Review System Communication System  Monitoring System Deploy System  Documentation System Issue  Version Control (CM)  Requirements   Build System Test System  Code Review  Code Review System Ensures that code complies with standards and identifies low level bugs and coding errors; Identifies design and requirements compliance  System Tracking 55
  • 56.
    Issue Tracking System Communication System  Monitoring System Deploy System  Issue  Documentation System Version Control (CM)  Requirements   Build System  Code Review Test System  Issue Tracking System Collects issues throughout the cycle of the project and track them through completion  System Tracking 56
  • 57.
    Documentation System Communication System  Monitoring System Deploy System  Issue  Documentation System  Version Control (CM) Requirements   Build System  Code Review Test System  Documentation System Repository of system information throughout the lifecycle  System Tracking 57
  • 58.
    Deploy System Communication System  Monitoring System Deploy System  Documentation System  Issue Version Control (CM)  Requirements   Build System  Code Review Test System  Deploy System Installs and configures the package created by the build system into appropriate environments  System Tracking 58
  • 59.
  • 60.
    Communication System Communication System  Monitoring System Deploy System  Issue  Documentation System  Version Control (CM) Requirements   Build System  Code Review Test System  Communication System Method for conveying information between systems  System Tracking 60
  • 61.
    Automate All theConnections! Communication System  Monitoring System Deploy System   Issue Documentation System  Version Control (CM)  Requirements   Build System  Code Review Test System   System Tracking 61
  • 62.
  • 63.
    Pipelines User Commits Mergecode Build Unit test/coverage Code Review Log Issues Deploy 63 A Pipeline is a chain of tasks that can be automated  Integration tools use pipelines to perform tasks repetitively and continuously  The process is called Continuous Integration (CI)  Pipelines keep work flowing forward in our DevOps system
  • 64.
  • 65.
  • 66.
    Communication System  Monitoring System Deploy System   Documentation System Issue  Version Control (CM)  Requirements   Build System TestSystem  Code Review  Code is committed and Merged Initiate Build Initiate Testing Development Pipeline Example with Integration System Commit code  System Tracking 66 Pipeline Orchestration
  • 67.
    Pipeline Stages Code DoneUnit Tests Integrate Acceptance Testing Deploy to Production 86 Continuous Delivery Auto Manual Auto Auto Continuous Deployment Code Done Unit Tests Integrate Acceptance Testing Deploy to Production Auto Auto Auto Auto Code Done Unit Tests Integrate Continuous Integration Auto Auto
  • 68.
    CI Pipeline Example 87 CIPipeline CM Repository Staging Integration Master Fail STOP Fail STOP Fail STOP Success Success Success Commit Commit Commit New Feature (NF) Legacy Feature (LF) Bad Feature (BF) Build gate Compile Code Code Quality GatesApplied Smoke Tests If Successful, Merge with Staging Staging gate Compile Code Functional Tests If Successful, Merge with Integration Branch Integration gate Compile Code Merge with Master Fortify Scans Release is packaged
  • 69.
    Using a CI/CDPipeline for Team- Managed Deployments at Apoti Tech RRR eRRR TMD Deploy Manual Test Auto. Test Auto. Build OR OR Approval: CI/CD Pipeline: DevOps: Development Operations Team Managed Deployment (TMD) provides the approval step for a CI/CD Pipeline. The CI/CD Pipeline provides the forward link from Development to Operations.
  • 70.
    Using a CI/CDPipeline for Team- Managed Deployments at Apoti Tech (cont) RRR Documents VDD Release Number Source Code File List List of Changes Deployment Instructions TAS Test Results Test History CI/CD Pipeline Artifacts Pipeline Release Number Deployment Scripts Version Control Source Code File List List of Changes Test Tools Test Results Test History Automation used in a CI/CD pipeline allows data to be collected as true artifacts. In an RRR approach, the information is manually collected into documents.
  • 71.
  • 72.
    DevOps is Not… 91 Atool A role A team Something that can be purchased or simply switched on DevOps requires a culture of operations and development engineers participating together in the entire service lifecycle
  • 73.
    • Continual experimentation,taking risks, and learning from failure • Understanding that repetition is the prerequisite to master The Third Way: Culture of Improvement
  • 74.
    The Third Way: Experimentation,Risk-Taking, and Learning 93 Develop a culture that pushes into the danger zone Develop habits to survive danger Build experimentation, risk-taking, and learning into our way of doing business Break things early and often Intuit ran 165 experiments on their TurboTax product in the 3 main months of tax season – ideas made it to market a year earlier and they increased customer conversion rate by 50%
  • 75.
    The Third Way: Repetitionfor Mastery 94 • Do the hard parts often • Work through pain points to make the process easier • Do painful things MORE frequently to make it less painful • Reduce anxiety about unexpected outcomes • Automate!!!
  • 76.
    DevOps: The ThirdWay - Practices 95 Communication Integration Collaboration
  • 77.
    DevOps Practice: Inject Failures 96 •Netflix services are hosted completely in Amazon Web Services cloud • Design each distributed system to expect and tolerate failure • Chaos Monkey randomly kills services within architecture in order to learn to tolerate and respond to failure DevOps Approach  How does this system react if I do this?  Can we continue operations without this server?  Will the users prefer option A or option B? Traditional Approach  Not in my system, you don’t  Not in my system, you don’t  Not in my system, you don’t Communication Integration Collaboration
  • 78.
    DevOps Practice: Make YourImprovement Work Visible 97 Along with regular user stories, use colored cards to indicate: • Technical debt • Unplanned work • Experiments • Learning backlog Allocate time to improve daily work Track the work needed to maintain overall health of the system Communication Integration Collaboration
  • 79.
    DevOps Practice: Regularly ImproveTechnical Debt 98 Allocate 20% of cycles to Technical Debt Reduction • Write tests to find misconfigurations – and fix them • Constantly run automated static code analysis during continuous integration and testing, and raise the bar in your quality gates • Enforce consistency in code, environments, and configurations • Repeatedly tackle the hard stuff Communication Integration Collaboration
  • 80.
    DevOps Practice: Regularly ImproveTools  Good tools are key to enabling DevOps collaboration, automation, and visibility  Provide teams the best tools available  Regularly invest time researching and piloting new tools  Provide expert support Communication Integration Collaboration 80
  • 81.
    DevOps Practice: Reward Contributionsto a DevOps Culture  Incentivize DevOps practices and behaviors  Recognize experimentation and risk-taking that leads to valuable learning  Model honest self-assessment of organizational strengths and weaknesses and use of improvement techniques such as Toyota Kata  Quantify and promote the link between DevOps practices and organizational performance Communication Integration Collaboration 81
  • 82.
    DevOps Practice: 101 Org Change Patterns Decentralized, emergent Protected, dedicated team Organizational baby steps Champions/ advocates Boss’orders Communication Integration Conduct Deliberate Culture Change Experimen Collab t orati s on Discussion: What are our biggest cultural challenges? What experiments should we run?
  • 83.
    DevOps Team Profiles DevOpsTeam Member  End-to-end viewpoint  Contributes to and uses visibility  Automator  Collaborative, cross-functional, friction reducer  Participates in collective ownership of code and code delivery  Personal success = team success  Enjoys working this way 102 DevOps Expert Support Team  Helps introduce DevOps- supportive processes and tools  Works with teams to automate environment creation and deployment  Helps teams use operational performance logs and dashboards  Provides infrastructure support
  • 84.
    Food for Thought– Maturing DevOps Practices Level 1 Level 2 Level 3 Level 4 Level 5 Culture & Processes  Frequent commits  Prioritized work  Defined & documented process  One backlog team anda master backlog  Adopt basicagile methods  Remove boundary ofdev & test  Team collaboration  Remove boundary of dev & ops  Act on metrics  Common processesfor all changes  Dedicated tools teamfor automation  Deploy disconnected from Release  Continuous improvement  Cross functionalteams  No rollbacks Architecture  Define Context View, Logical Composition& Physical Composition  Stage SDD wiki with Views in place  Define related views  Review process in place  ?  ? Build / Deploy  Versioned code base  Scripted builds  Basic scheduledbuilds  Dedicated build server  Documentedmanual deploy  Poling builds  Build are stored  Manual Tag & Versioning  First steptowards standardizeddeploys  Auto triggered builds  Automated tag& versioning  Automated bulk ofDB changes  Basic pipelinewith deploy to prod  Scripted configuration changes  Standard process forall environments  Zero downtime deploy  Multiple buildmachines  Full automated DB deploys  Zero touch continuous deployments Test & Verification  Automated Unit Tests (Coverage <50%)  Separate test environment  Automated Unit Tests (Coverage >50% & < 80%)  Automated Integration Tests (Coverage ??)  Automated Functional tests  Automatedacceptance criteria (<40%)  Automated acceptance criteria (80%)  Automated performance tests  Automated Security Tests  Automated Section508 tests  All tests automated  Coverage 100% Collaboration & Information Sharing  Baseline process metrics  Manual reporting  Static code analysis  Quality reports  History ofreports available  Traceability builtinto pipeline  Report trend analysis  Graphing as a service  Reports accessiblevia commondashboard  Dynamic graphing 103
  • 85.