/k8s-service

Primary LanguageGoMIT LicenseMIT

Kubernetes application

A sample application that meets the requirements for successful execution in Kubernetes.

Deploy

Main application criteria

  • Implementation of health checks
  • Configuring the application through environment variables
  • Standard logging Interface
  • Processing of system interrupt signals and graceful shutdown
  • Continuous build of the application and whole CI/CD process
  • Helm charts for deploying an application in Kubernetes
  • SSL support in a secure connection, certificate integration
  • Integration of the official package manager dep
  • Versioning automation

Health checks

Kubernetes application must have two health checks for successful execution of the application. Integrated methods help correctly responding to Kubernetes queries.

Configuring

The twelve-factor app stores config in environment variables. The application has a built-in library for automatic recognition and placement the environment variables in struct with different types.

Logging

Provides a standard interface for a multi level logging. There is ability of choice of a logging library that supports a common interface.

type Logger interface {
    Debug(v ...interface{})
    Debugf(format string, v ...interface{})
    Info(v ...interface{})
    Infof(format string, v ...interface{})
    Warn(v ...interface{})
    Warnf(format string, v ...interface{})
    Error(v ...interface{})
    Errorf(format string, v ...interface{})
    Fatal(v ...interface{})
    Fatalf(format string, v ...interface{})
}

Just make your choice

func Run() (err error) {
    // log := xlog.New()
    // log := logrus.New()
    log := stdlog.New(&logger.Config{
        Level: logger.LevelDebug,
        Time:  true,
        UTC:   true,
    })
    ...
}

System signals

The application includes the ability to intercept system signals and transfer control to special methods for graceful shutdown.

type Signals struct {
    shutdown    []os.Signal
    reload      []os.Signal
    maintenance []os.Signal
}

Build automation

A series of commands for static cross-compilation of the application for any OS. Building the Docker image and loading it into the remote public/private repository. Optimal and compact docker image FROM SCRATCH

Testing

The command make test is running set of checks and tests:

  • run go tool fmt on package sources
  • run go linter on package sources
  • run go tool vet on packages
  • run tests on package sources excluding vendor
  • compile and check of Helm charts

Helm charts and Continuous Delivery

Prepared set of basic templates for application deployment in Kubernetes. Only one command make deploy is loading the application into Kubernetes. Just wait for the successful result and the application is ready to go.

Deploy

SSL support

Generating certificates to create a secure SSL connection in the Go client. Attaching the certificate to the Docker image.

FROM scratch

ENV K8S_SERVICE_LOCAL_HOST 0.0.0.0
ENV K8S_SERVICE_LOCAL_PORT 8080
ENV K8S_SERVICE_LOG_LEVEL 0

EXPOSE $K8S_SERVICE_LOCAL_PORT

COPY certs /etc/ssl/certs/
COPY bin/linux/k8s-service /

CMD ["/k8s-service"]

Package manager

To work correctly with the dependencies we should choose the package manager. dep is a prototype dependency management tool for Go.

Versioning automation

Using a special script to increase the release version

./bumper.sh
Current version 0.4.0.
Please enter bumped version [0.4.1]:

Contributing to the project

See the contribution guidelines for information on how to participate in the Kubernetes application project by submitting pull requests or issues.

License

MIT Public License