lightning-monkey

module
v0.0.28 Latest Latest
Warning

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

Go to latest
Published: Aug 2, 2019 License: MIT

README

Build Status

Lightning Monkey

This project is currently in early development stage. Bug reports and pull requests are welcome.

Preface

The project Lightning Monkey is a key solution for helping you deploy an entire Kubernetes cluster as well as you expected. Typically, It's a core capability of PaaS(Platform as a Service). Rather than others technological solution(Such as Rancher), It has been designed to offer more flexibility for easier integrating to yours projects.

It are consist of 2 main components:

  • API Server
  • Agent

The API server has responsibility for managing & scheduling deployment resource during its whole lifecycle. It'll provide a group of RESTful APIs for representing those of capabilities what described above.

The agent is a background running service which has responsibility for interacting with local resource. such as generating certificates or shipping deployment metadata etc... And... the most important thing is that the Docker runtime is required before you go.

Supported Kubernetes Version

Kubernetes Version Supported Tested
v1.12.5

Usage

Run API Server

#STEP 1, you need to start up an ETCD instance.
docker run -d --name etcd-server \
    --publish 2379:2379 \
    --publish 2380:2380 \
    --env ALLOW_NONE_AUTHENTICATION=yes \
    --env ETCD_ADVERTISE_CLIENT_URLS=http://etcd-server:2379 \
    bitnami/etcd:latest

#STEP 2, run API-Server.
docker run --rm -p 8080:8080 -it \
    -e "BACKEND_STORAGE_ARGS=ENDPOINTS=http://YOUR-ETCD-CLUSTER-IP:2379;LOG_LEVEL=debug" 
    lm-apiserver:201907051406

Run Agent

export API_SERVER_ADDR=http://127.0.0.1:8080
export CLUSTER_ID=xxxxxxx
docker run -itd --restart=always --net=host \
    -v /etc:/etc \
    -v /var/run:/var/run \
    -v /var/lib:/var/lib \
    -v /opt/cni/bin:/opt/cni/bin \
    -e "LOG_LEVEL=debug" \
    --entrypoint=/opt/lm-agent \
    g0194776/lmagent:v0.1-8 \
      --server=$API_SERVER_ADDR \
      --address=$(ip addr show dev eth1 | grep "inet " | awk '{print $2}' | cut -f1 -d '/') \
      --cluster=$CLUSTER_ID \
      --etcd \
      --master \
      --cert-dir=/etc/kubernetes/pki

Clean Up

docker ps -aq | xargs -ti docker rm -f {}
rm -rf /etc/kubernetes/ && rm -rf /data/etcd/
rm -rf /opt/cni

Jump to

Keyboard shortcuts

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