DevOps

in a Serverless World

Linda Nichols

@lynnaloo

Norfolk,VA

norfolk.js

Virginia is for Lovers

@lynnaloo

Serverless

^

#SerVAless
@lynnaloo
#SerVAless

Virginia is for Lovers

Serverless

^

But there are servers?

@lynnaloo
#Serverfull

Thank You Nashville!

@lynnaloo
@lynnaloo
@lynnaloo

Let's Talk About Serverless...

and Developers

@lynnaloo

with a little help from...

1988

@lynnaloo

Developers Have Lots of Opinions

@lynnaloo

They Love Process and Best Practices

@lynnaloo
  • Their favorite editor
  • Their favorite language
  • Their favorite frameworks
  • A code formatting tool
  • Formatting tool for code prettiness
  • Real-time static code analysis

Developers Want (need):

@lynnaloo

Vim

VS Code

Emacs

Atom

IntelliJ

Visual Studio

Eclipse

Notepad

Lint

Prettier

editorconfig

pylint

eslint

Mechanical Keyboard

Stack Overflow

Java

.Net

npm

nuget

Ruby

CoffeeScript

Python

Rust

TypeScript

yarn

@lynnaloo
  • Pair-programming
  • Very-opinionated testing framework
  • Unit tests
  • Integration tests
  • Code coverage up to 90%

Then Test the Code:

@lynnaloo

Wait, should we have written the tests before the code?!?

@lynnaloo
  • Very-opinionated revision control system
  • Current popular branching strategy
  • Squash those insignificant commits
  • Very detailed commit messages
  • Branch names match the task

Then Commit the Code:

@lynnaloo

Github

Gitlab

Visual Source Safe

Bitbucket

Gitflow

Github Flow

Subversion

CodeCommit

GitOps

@lynnaloo
  • Push the code to a dev branch
  • Issue a pull request
  • Make sure all of the tests are passing
  • Request a code review

Merge the Code into Master:

@lynnaloo

Your branch isn't up to date??

Why aren't the tests passing?

Why did you use tabs and not spaces?

Squash those commits!

The linter is failing!

@lynnaloo

Sometimes, reviewers can be tough.

@lynnaloo

OK, LGTM. Merged.

@lynnaloo

Cue the CI/CD Tool:

@lynnaloo

Travis CI

Azure Pipelines

Gitlab CI

Jenkins

Circle CI

Bamboo

CodeDeploy

Flux

Github Actions

LaunchDarkly

CodeBuild

@lynnaloo

Now the code is being deployed to a staging environment for more testing

@lynnaloo

What about Serverless?

@lynnaloo

Serverless is for Developers

@lynnaloo

Serverless is for Developers

  • Event-driven architecture
  • Support for most programming languages
  • Focus is on code, not infrastructure
  • Built-in services and libraries means less code
  • FaaS naturally map to microservices
@lynnaloo

What's the Development Process?

@lynnaloo

Pre-recorded Demo Time

@lynnaloo
@lynnaloo
@lynnaloo
@lynnaloo

Unfortunately, no service is fully-managed enough to format, test, and debug your messy code.

@lynnaloo

So, why do those who hold process so dear, throw it all away when they build cloud-native apps?

@lynnaloo

Because serverless application development is new and can be a little scary.

@lynnaloo

But all of the development practices that we love, still apply in a serverless world.

and there are many, many new tools and services to support your process.

@lynnaloo

Demo

@lynnaloo
@lynnaloo

My Toolset

Conclusion

  • No-ops does not mean no DevOps
  • FaaS is not revision control
  • Testing in prod isn't testing
  • Abstraction is not CI/CD
  • Don't abandon what's important
@lynnaloo

Conclusion

@lynnaloo

Thank you

@lynnaloo

Credits

Travis Webb

YOLO Programmer

DevOps in a Serverless World

By Linda Nichols

DevOps in a Serverless World

DevOps in a Serverless World - Serverless Days Nashville

  • 1,356