Skip to content

Latest commit

 

History

History
94 lines (64 loc) · 3.34 KB

README.md

File metadata and controls

94 lines (64 loc) · 3.34 KB

Kubernetes-dialogflow

In this project I demonstred how you could integrate google assistance app using dialogflow to talk to the kubernetes api server.

For example:

    You : Talk to kubernetes cluster
    K8  : Ok, Talking to kubernetes cluster.

    You : What is my cluster status?
    k8  : Kubernetes cluster is running with 2 cpus and 1 Gis of RAM.

    You : How many pods are running in my cluster?
    k8  : There are 2 pods are running on your cluster.

    You : Create a deployment
    k8  : which docker image you want to use?
    You : matrix
    k8  : which tag you want to use?
    You : 1.0.0
    k8  : Creating matrix deployment in default namespace

    You : Scale a deployment or Scale a matrix deployment
    k8  : how many replicas you wants?
    You : 5
    k8  : Scaling matrix deployment to 5.

    You : Update deployment or Update matrix deployment
    k8  : which tag you want to use?
    You : 2.0.0
    k8  : updating matrix deployment to tag 2.0.0

Architecture

Architecture

Working

  • following are the components involved into architecture
  1. Kubernetes Cluster (minikube or docker-for-mac)
  2. Flask web server
  3. ngrok (secure tunnel between flask server and dialogflow server)
  4. Dialogflow
  5. Simulator (Google Assistance)

Request flow from simulator to kubernetes cluster

requstflow

Every time user interact with google assitance with speech, For ex.

talk to my test application?

It invokes a defualt intent in dialogflow.

Now all following interaction with google assistance is handled by this test application which is a machine learning model(Agent) trained by dialogflow.

  • Following are the two main elements to create model in dialogflow.

    1. Intents
    2. Entity

    You can learn more about those elements here.

    Following are intents from our app

    intents

    Every Invoked intent send POST request to webhook. This request contains intent name,metadata and also action.Now a python server running on your computer get this request through ngrok secure tunnel. Your server invokes particular function depending on action parameter from request and then this function invokes particular action in kubernetes cluser using kubernetes client.

    action = req.get('result').get('action')
    
    if action == "list_pod":
        return format_response(list_all_pods())
    
    if action == "cluster_status":
        return format_response(cluster_status())
    
    if action == "create_deployment":
        return format_response(create_deployment(parameters))
    
    if action == "scale_deployment":
        return format_response(scale_deployment(parameters))
        
    if action == "update_deployment":
        return format_response(update_deployment(parameters))
    

Response flow from kubernetes cluster to simulator

responseflow