New Project
If you already a project with an existing Dockerfile, you can use that. If you do not, kubes generates a starter Dockerfile that runs nginx. For this tutorial, we’ll start with an empty folder.
mkdir demo
cd demo
For this tutorial, here are examples of AWS ECR and Google GCR repos, though any repo will work.
AWS:
REPO=$(aws ecr describe-repositories --repository-name demo | jq -r '.repositories[].repositoryUri')
Google:
export GOOGLE_PROJECT=project-123
REPO=gcr.io/$GOOGLE_PROJECT/demo
Let’s initialize a starter kubes project. This is similar to a git init
.
$ kubes init --app demo --repo $REPO --type dsl
create .kubes/config.rb
create .kubes/config/env/dev.rb
create .kubes/config/env/prod.rb
create .kubes/resources/base/all.rb
create .kubes/resources/shared/namespace.rb
create .kubes/resources/web/deployment.rb
create .kubes/resources/web/deployment/dev.rb
create .kubes/resources/web/deployment/prod.rb
create .kubes/resources/web/service.rb
Initialized .kubes folder
$
The --type=dsl
option tells Kubes to generate DSL format files. To learn more about the generated structure, here are the Structure Docs.
Let’s explore some of the generated files.
Config
The config.rb
is where you can configure Kubes settings.
.kubes/config.rb
Kubes.configure do |config|
config.repo = "112233445566.dkr.ecr.us-west-2.amazonaws.com/demo" # may be gcr.io/project-123/demo
config.logger.level = "info"
# auto-switching
# config.kubectl.context = "dev-cluster"
end
This is where the --repo
from kubes init
got saved. The other options are covered in the Env Config Docs.
Dockerfile
The Dockerfile
is a simple starter example that just runs nginx
Dockerfile:
# Simple example starter
FROM nginx
EXPOSE 80
CMD ["nginx", "-g", "daemon off;"]
Note: If your project already has a Dockerfile, kubes will use that instead of generating a starter one.
Next, we’ll review the resources.