the simplest way for developer
to deploy their application
data:image/s3,"s3://crabby-images/ba47f/ba47f2d0ce798b11f60098845ba56a70b23c2eb6" alt=""
data:image/s3,"s3://crabby-images/2892d/2892d91595e13840f7c189559052be0fffeee671" alt=""
Who am I?
fun getSpeaker(): User {
val romaric = User(
firstName = "Romaric",
lastName = "Philogène",
age = 31,
email = "romaric@qovery.com",
twitter = "@rophilogene",
description = "10 years of experience in IT infrastructure and backend development",
favoriteLanguages = setOf("PYTHON", "JAVA", "KOTLIN")
)
return romaric
}
fun main(args: Array<String>) {
println("Hello you! From ${getSpeaker().firstName}")
// Hello you! From Romaric
}
Are you a
Question
fullstack
frontend
developer?
backend
Do you use Git?
Question
How do you manage production, staging and feature code?
Question
How do you manage them
in a live environment? đ¤
Question
Our believe
-
Any developer should be able to deploy their application
-
Whatever their technical skills
-
No matter the language and framework used
Obviously... Qovery !
data:image/s3,"s3://crabby-images/cdc9f/cdc9fd84f6f1e4b14f2e91eb7e01b4bbbdf9548d" alt=""
Deploy Node.JS + PostgreSQL
$ pwd
~/my-nodejs-project
# Github, Bitbucket, Gitlab seamless authentication
$ qovery auth
Opening your browser, waiting for your authentication...
Authentication successful!
# Wizard to generate .qovery.yml
$ qovery init
# Git commit and push your code
$ git add .qovery.yml
$ git commit -m "add .qovery.yml file"
$ git push -u origin master
# App deployed!
Deploy Node.JS + PostgreSQL
$ qovery status
Environment
branch status endpoints applications databases brokers storage
master up and running https://xxx-main-gtw.qovery.io 1 1 0 0
Applications
name status endpoint databases brokers storage
backend-api up and running https://xxx.qovery.io 1 0 0
Databases
name status type version endpoint port username password application
my-pql up and running POSTGRESQL 11.5 xxx.eu-west-3.rds.amazonaws.com 5432 superuser ****** backend-api
application:
name: backend-api
project: my-nodejs-project
cloud_region: aws/eu-west-3
publicly_accessible: true
# required databases
databases:
- type: postgresql
version: "11.5"
name: my-pql
# one endpoint can target multiple applications
# here there is only one
routers:
- name: main
routes:
- application_name: backend-api
paths:
- /*
FROM node:13-alpine
# copy source to docker image
COPY . .
# download dependencies
RUN npm install
# application listen on port 3000
EXPOSE 3000
# run node
CMD node ./bin/www
Mandatory files
.qovery.yml
Dockerfile
//...
// PostgreSQL
const pool = new Pool({
connectionString: process.env.QOVERY_DATABASE_MY_PQL_CONNECTION_URI
});
// simple common NodeJS app
app.get('/', function (req, res, next) {
//...
});
app.get('/users', function (req, res, next) {
//...
});
Connect to PostgreSQL from Node.JS
Use environment variable !
Support most popular databases
- PostgreSQL
- MySQL
- MongoDB
- Elasticsearch
- Redis
- Memcached
- Cassandra
application:
name: backend-api
project: my-nodejs-project
cloud_region: aws/eu-west-3
publicly_accessible: true
databases:
- type: postgresql
version: "11.5"
name: my-pql
- type: redis
version: "5.0"
name: my-redis
routers:
- name: main
routes:
- application_name: backend-api
paths:
- /*
.qovery.yml
AWS
Designed for microservices
data:image/s3,"s3://crabby-images/fccf0/fccf0cdfdf68285e5e1382e554b48345d6fd42bb" alt=""
Better teamwork (isolated environments)
data:image/s3,"s3://crabby-images/d0d89/d0d8909e7e81563e4579419dc0eafcf9da4fb248" alt=""
git checkout master
git checkout -b staging
git push -u origin staging
# staging environment created
git checkout -b feat_1
git push -u origin feat_1
# feat_1 environment created
Mirror your production traffic to any environment (Shadowing)
data:image/s3,"s3://crabby-images/7f6df/7f6df637ccdf3a0562b0d363732daccce2ad2b25" alt=""
DEMO
APPLAUSE đ
e-mail: romaric@qovery.com
twitter: @rophilogene
Qovery @ AdmoTV
By Romaric Philogène
Qovery @ AdmoTV
- 315