Skip to content

A tool used to run kubectl command in web browser

License

Notifications You must be signed in to change notification settings

guoranaccp/webkubectl

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

91 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Web Kubectl - Run kubectl command in web browser

License Dockerized Version Total visitor Visitors in today

webkubectl

Benefit

Web Kubectl enables you to manage kubernetes credentials and run kubectl command in web browser, so that you don't have to install kubectl on your local PC or some other servers, furthermore Web Kubectl can be used for a team.

Advantage

  • Support multiple user and multiple Kubernetes clusters:A deployment of Web Kubectl can be used for a team, all of the team members can use Web Kubectl simultaneously although they are connecting different Kubernetes clusters or different privileges.
  • Session isolation:All of the online sessions are isolated, each session has its own namespace and storage which is invisible to the others.
  • Support Kubernetes config file and token:You can provide Kubernetes config file or token to connect Kubernetes cluster via Web Kubectl.
  • Easy to use and integrate:You can simply use the index page for a quick start, or integrate with your application using api.

Architecture

Web Kubectl use webkubectl/gotty to run a JavaScript based terminal on web browsers.
When opens a new session, a temporary Linux namespace will be created for the session, this make sure all sessions are isolated, each session has its own namespace and storage, meanwhile .kube/config file is generated for current session.
When session terminated, the provisioned namespace and storage are deleted.

Installation

$ docker run --name="webkubectl" -p 8080:8080 -d --privileged webkubectl/webkubectl

Advanced environment variables

ENV Type Default Value Description
SESSION_STORAGE_SIZE string 10M Storage size limit for single connection
KUBECTL_INSECURE_SKIP_TLS_VERIFY bool true whether to skip tls verify
WELCOME_BANNER string Welcome to Web Kubectl, try kubectl --help. Welcome banner after web terminal opened

Usage

Use index page

Open below url in web browser.

http://<webkubectl-address>:<port>

In the opened page you can manage your own kubernetes config files or tokens which are stored in local storage, then choose a session and click connect to use kubectl command in web terminal.

index

terminal

Use API

Get token by Kubernetes API server address and token

$ curl http://<webkubectl-address>:<port>/api/kube-token -X POST -d '{"name":"gks-hk-dev","apiServer":"https://k8s-cluster:6443","token":"token-content"}'
#response
$ {"success":true,"token":"mkolj4hgbutfgy1thgp1","message":""}

Request Json

key Type Description
name string session name
apiServer string API server address
token string Kubernetes token

Response Json

key Type Description
success bool the request is proceeded successfully or not
token string token used to open terminal
message string error message if success is false

Get token by Kubernetes config file

$ curl http://<webkubectl-address>:<port>/api/kube-config -X POST -d '{"name":"k8s-cluster-bj1","kubeConfig":"<Kubernetes config file content base64 encoded>"}'
#response
$ {"success":true,"token":"mkolj4hgbutfgy1thgp1","message":""}

Request Json

key Type Description
name string session name
kubeConfig string Kubernetes config file content base64 encoded

Response Json

key Type Description
success bool the request is proceeded successfully or not
token string token used to open terminal
message string error message if success is false

Open web terminal with token fetched from API

http://<webkubectl-address>:<port>/terminal/?token=<token fetched from api>

Security

  • Token validation:The token fetched from api will be invalid immediately after it's used once, and it expires after 5 minutes if not used.
  • Authentication:By default all resources can be accessed without any authentication, to restrict anonymous access, you can enable the basic authentication of gotty, see how to.
  • SSL/TLS:By default all traffic between the server and clients are NOT encrypted, we recommend you enable SSL/TLS option of gotty, see how to. Alternatively you can deploy Web Kubectl behind a proxy and enable SSL/TLS for the proxy, please note that the proxy should support WebSocket protocol.

Alternatives

License

Copyright (c) 2014-2019 FIT2CLOUD 飞致云

https://www.fit2cloud.com

Web Kubectl is licensed under the Apache License, Version 2.0.

About

A tool used to run kubectl command in web browser

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • Shell 52.2%
  • Dockerfile 47.8%