py-reminders

module
v0.0.0-...-7888f86 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Oct 22, 2019 License: MIT

README

py-reminders

Overview

Sample microservice to manage reminders (tasks one seeks to remember).

Try it out

To try out the microservice, it must be built and executed in a suitable environment. Details are further below.

Prerequisites

There are some basic requirements in order build and use the py-reminders microservice:

  1. A kubernetes cluster sufficient to run py-reminders and its backing services (e.g., mysql);
  2. A Docker registry and relevant credentials for pushing and pulling containers;
  3. A backing service (generally mysql) running in the kubernetes cluster;
  4. A Pivotal Concourse setup in order to run the build and deploy processes;
  5. Helm for managing py-reminders deployments, also used by the ci/cd pipelines.
Kubernetes Cluster

Running py-reminders generally targets a kubenernetes cluster. It runs in the default namespace.

In addition, as with any kubernetes cluster, credentials should be setup. Secrets for pushing and pulling containers from the Docker registry must exist before building the microservice. The way to add such credentials is as follows:

kubectl create secret docker-registry py-reminders-registry-creds --docker-server=<your-registry-server> --docker-username=<your-name> --docker-password=<your-pword> --docker-email=<your-email>

As well, in one form or another, credentials for py-reminders to make use of a backing store like MySQL is required. Those can be obtained in various ways, such as described below. Another way is to use the concourse credential management facility if you want a more secure model. To do so, integrate your service of choice and set the environment variables or command line switches in the kubernetes deployment for running py-reminders.

Backing Service

The microservice needs a backing service in which to store the reminders. MySQL or internal facilities are common scenarios.

MySQL Backing Service

A working MySQL server can be used for the backing service. The microservice requires rights to create and drop databases, as well as normal CRUD on tables.

MemDB Backing Service

A memory only backing can be used for testing or demonstrative purposes. The MemDB service is purely in memory and provides no persistence at all, nor distribution of the reminders across py-reminder instances. It is intended mainly for testing and development purposes. To use that, invoke py-reminders similarly to the following:

DBTYPE=mem ./py-reminders.py

or use a similar environment setting in a kubernetes deployment.

Obtaining Backing Storage Secrets

It is possible to obtain MySQL secrets from a VMware vRealize Orchestrator backing service or an etd cluster.

Obtaining MySQL Creds from vRO

When utilizing the vRO capabilities, the service depends on the vRO workflow to provide a valid database host address, admin login and login password where the admin user has rights to create a database and tables. The vRO code may need to change based on various workflows, but the gist is in the vro.py file.

Obtaining MySQL Creds from Etcd

When using etcd support, the expectation is that the etcd service is deployed, and key/value pairs exist for:

  • /host
  • /port
  • /user
  • /passwd

All of these entries are required for py-reminders to successfully make a connection to the MySQL server to support stateful operations.

Build and Run

Building the code involves very few steps and there are some CI/CD options to help out.

  1. Get the code
  2. Build the code
  3. Optionally using CI/CD Pipelines
Get the Code

To get the code, get it similarly to the following:

git clone https://github.com/huxoll/py-reminders
cd py-reminders
Build the Code

The project includes a Makefile for use in building the py-reminders microservice. To build a Docker container, you must provide a container name for pushing to a registry.

export CONTAINER=myreponame/py-reminders
make

That will build and push the container image assuming you have already logged in to your registry with "docker login". If you are using concourse to perform your builds, you can issue the makefile as follows to preclude immediately pushing the Docker image, instead using the concourse resource to perform that task:

export CONTAINER=myreponame/py-reminders:version-tag
make prereqs
CI/CD Pipelines

The code includes various pipeines in the build/ci directory. They can be used assuming the appropriate tool (i.e., Jenkins, Concourse or the like) is in place. Some alteration to the configuration may be necessary depending on your setup.

Notes on Using Concourse

A set of pipelines and sample parameter files are provided in the build/ci/concourse directory. There is also a README therein to explain using Concourse with this project.

Notes on Using Jenkins

A set of config.xml files for jobs and the Gerrit trigger plugin exist in the jenkins directory. The config files can be used as templates to setup a flow that, from a merge, for example, of the sources triggers a full build, push of the py-reminders container to Docker hub, generate a HEAT template to run it on an OpenStack instance, and thereafter kick off the HEAT stack.

Run

The microservice will run standalone, in a container, or more often via kubernetes deployments. Whether by command line for testing or via kubernetes deployment, there are a number of options available to configure its operations. All options are available via the command line or environment, with the environment taking higher priority to lean a bit more towards 12 factor. All command line switches are looked up in the environment with the long form switch name in all capital letters.

Standalone

For instance To invoke py-reminders with a mysql database at mysql.corp.local:3306, with user credentials as root/rootpasswd, issue the following command:

HOST=mysql.corp.local:3306 USER=root PASSWD=rootpasswd DBTYPE=mysql ./py-reminders.py

Alternatively:

./py-reminders.py --host=mysql.corp.local:3306 --user=root --passwd=rootpasswd --dbtype=mysql

To run py-reminders stand-alone, execute it as follows with appropriate environment variables or command line switches:

./py-reminders.py ...

To get help on the available options, execute it as follows:

./py-reminders.py --help
In a Container

Once pushed to Docker, you can run the microservice similarly to:

docker run -p 8080:8080 -E DBTYPE=mem myregistryrepo/py-reminders
In Kubernetes

In a kubernetes environment, the command is part of the deployment manifest, for example:

...
env:
    - name: DBTYPE
      value: "mysql"
    - name: HOST
      value: "mysql.corp.local"
    - name: USER
      value: "root"
    - name: PASSWD
      value: "rootpasswd"
...
Sample Kubernetes Deployment Using kubectl

Sample deployment and service manifests are provided in the kubernetes directory. Run those similarly to the following:

cd deployments/kubernetes
cat >kustomization.yaml <<EOF
  resources:
  - service.yml
  - deployment.yml
  images:
  - name: docker-registry-repo
    newTag: 1.0.0
    newName: concourse.corp.local/py-reminders
EOF
kubectl kustomize . | kubectl apply -f -
Sample Kubernetes Deployment Using Helm

The facility generally used to deploy and manage py-reminders is Helm. If you are using the concourse pipelines to build and deploy, helm will be used automatically.

If you want to deploy manually using helm, switch to the [deployments/helm](deployment/helm] directory. There you will find the key files to fill out -- either of values-minikube.yml or values-pks.yml. Copy one of those files values.yml

cp values-minikube.yml values.yml

and edit the values.yml file to match your deployment requirements. The file values.yml is ignored by git, so will not be part of subequent commits unless forced (i.e., git will not track values.yml).

To deploy using helm, issue a command such as:

cd .../deployments/helm
helm install --name py-reminders .

and that should create the deployment, which you can check with

helm status py-reminders

Helm is a powerful tool for kubernetes deployment management and a good read of its documentation is in order for those not yet familiar.

Documentation

The microservice provides two mechanisms for interacting with the service:

  1. an API for creating, modifying and deleting reminders and checking stats.
  2. a web interface for visually doing the same.
The API

Upon running the service, e.g.:

  • etcd: docker run -d -p 8080:8080 py-reminders /py-reminders -cfgsrc etcd_host:2379

  • vRO: docker run -d -p 8080:8080 py-reminders /py-reminders -cfgtype vro -cfgsrc 172.16.78.227

and assuming that provided you a Docker generated container address as 172.17.0.1, the REST API exists at http://172.17.0.1:8080/api/reminders and paths further thereafter pursuant to the pattern:

  • GET /api/reminders: Returns all reminders currently in the database.

  • POST api/reminders: Given a JSON body similar to:

    { "message": "message text" }

creates a new reminder.

  • GET /api/reminders/:guid
  • GET /api/reminders/byid/:id

Gets the JSON representing the Reminder with Guid ":guid" or ":id" as appropriate. The :id value is the database record id.

  • PUT /api/reminders/:guid
  • PUT /api/reminders/byid/:id

Given a JSON body similar to:

{
  "message": "message text"
}

Updates the Reminder with Guid ":guid" or ":id" as appropriate. The :id value is the database record id.

  • DELETE /api/reminders/:guid
  • DELETE /api/reminders/byid/:id

Deletes the Reminder with Guid ":guid" or ":id" as appropriate. The :id value is the database record id.

The HTML Interface

To reach the HTML interface (given the same sample as above), browse to: http://172.17.0.1/index and the bulk of the HTML paths are available from that page or others as appropriate given traversal of the 'site.'

Another HTML area is the /stats/hits, which provides a view of hit counts on the various URLs involved in the service (API and HTML).

Releases & Major Branches

Contributing

The py-reminders project team welcomes contributions from the community.

License

Copyright (c) 2015-2019 John Gardner

SPDX-License-Identifier: https://spdx.org/licenses/MIT.html

Directories

Path Synopsis
internal
app
Package app is the entry point for the py-reminders application
Package app is the entry point for the py-reminders application

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL