kubespray/docs/roadmap.md

95 lines
4.3 KiB
Markdown
Raw Normal View History

2017-06-17 01:25:46 +08:00
Kubespray's roadmap
2016-07-06 23:34:16 +08:00
=================
2016-10-18 19:51:36 +08:00
### Kubeadm
- Propose kubeadm as an option in order to setup the kubernetes cluster.
2017-06-17 01:25:46 +08:00
That would probably improve deployment speed and certs management [#553](https://github.com/kubespray/kubespray/issues/553)
2016-10-18 19:51:36 +08:00
2017-06-17 01:25:46 +08:00
### Self deployment (pull-mode) [#320](https://github.com/kubespray/kubespray/issues/320)
2016-07-08 15:40:12 +08:00
- the playbook would install and configure docker/rkt and the etcd cluster
2016-07-06 23:34:16 +08:00
- the following data would be inserted into etcd: certs,tokens,users,inventory,group_vars.
2017-06-24 00:35:10 +08:00
- a "kubespray" container would be deployed (kubespray-cli, ansible-playbook, kpm)
2016-07-06 23:34:16 +08:00
- to be discussed, a way to provide the inventory
2017-06-17 01:25:46 +08:00
- **self deployment** of the node from inside a container [#321](https://github.com/kubespray/kubespray/issues/321)
2016-07-06 23:34:16 +08:00
### Provisionning and cloud providers
2017-02-05 06:23:24 +08:00
- [ ] Terraform to provision instances on **GCE, AWS, Openstack, Digital Ocean, Azure**
- [ ] On AWS autoscaling, multi AZ
2017-06-17 01:25:46 +08:00
- [ ] On Azure autoscaling, create loadbalancer [#297](https://github.com/kubespray/kubespray/issues/297)
- [ ] On GCE be able to create a loadbalancer automatically (IAM ?) [#280](https://github.com/kubespray/kubespray/issues/280)
- [x] **TLS boostrap** support for kubelet [#234](https://github.com/kubespray/kubespray/issues/234)
(related issues: https://github.com/kubernetes/kubernetes/pull/20439 <br>
2016-07-06 23:34:16 +08:00
https://github.com/kubernetes/kubernetes/issues/18112)
### Tests
2017-02-05 06:23:24 +08:00
- [x] Run kubernetes e2e tests
- [x] migrate to jenkins
2016-07-06 23:34:16 +08:00
(a test is currently a deployment on a 3 node cluste, testing k8s api, ping between 2 pods)
2017-02-05 06:23:24 +08:00
- [x] Full tests on GCE per day (All OS's, all network plugins)
- [x] trigger a single test per pull request
2017-02-06 19:05:24 +08:00
- [ ] ~~single test with the Ansible version n-1 per day~~
2017-02-05 06:23:24 +08:00
- [x] Test idempotency on on single OS but for all network plugins/container engines
- [ ] single test on AWS per day
- [x] test different achitectures :
2016-07-06 23:34:16 +08:00
- 3 instances, 3 are members of the etcd cluster, 2 of them acting as master and node, 1 as node
- 5 instances, 3 are etcd and nodes, 2 are masters only
- 7 instances, 3 etcd only, 2 masters, 2 nodes
2017-02-05 06:23:24 +08:00
- [ ] test scale up cluster: +1 etcd, +1 master, +1 node
2016-07-06 23:34:16 +08:00
### Lifecycle
2017-06-17 01:25:46 +08:00
- [ ] Adopt the kubeadm tool by delegating CM tasks it is capable to accomplish well [#553](https://github.com/kubespray/kubespray/issues/553)
- [x] Drain worker node when upgrading k8s components in a worker node. [#154](https://github.com/kubespray/kubespray/issues/154)
2017-02-05 06:23:24 +08:00
- [ ] Drain worker node when shutting down/deleting an instance
- [ ] Upgrade granularity: select components to upgrade and skip others
2016-07-06 23:34:16 +08:00
### Networking
2017-06-17 01:25:46 +08:00
- [ ] romana.io support [#160](https://github.com/kubespray/kubespray/issues/160)
- [ ] Configure network policy for Calico. [#159](https://github.com/kubespray/kubespray/issues/159)
2017-02-05 06:23:24 +08:00
- [ ] Opencontrail
- [x] Canal
- [x] Cloud Provider native networking (instead of our network plugins)
2016-07-06 23:34:16 +08:00
2017-03-23 04:03:06 +08:00
### High availability
2016-07-06 23:34:16 +08:00
- (to be discussed) option to set a loadbalancer for the apiservers like ucarp/packemaker/keepalived
While waiting for the issue [kubernetes/kubernetes#18174](https://github.com/kubernetes/kubernetes/issues/18174) to be fixed.
2017-06-24 00:35:10 +08:00
### Kubespray-cli
2016-07-06 23:34:16 +08:00
- Delete instances
2017-06-24 00:35:10 +08:00
- `kubespray vagrant` to setup a test cluster locally
- `kubespray azure` for Microsoft Azure support
2016-07-06 23:34:16 +08:00
- switch to Terraform instead of Ansible for provisionning
2016-07-08 22:30:47 +08:00
- update $HOME/.kube/config when a cluster is deployed. Optionally switch to this context
2016-07-06 23:34:16 +08:00
2017-06-17 01:25:46 +08:00
### Kubespray API
2016-07-06 23:34:16 +08:00
- Perform all actions through an **API**
- Store inventories / configurations of mulltiple clusters
- make sure that state of cluster is completely saved in no more than one config file beyond hosts inventory
2016-07-06 23:34:16 +08:00
### Addons (with kpm)
Include optionals deployments to init the cluster:
##### Monitoring
- Heapster / Grafana ....
- **Prometheus**
##### Others
2017-03-23 04:03:06 +08:00
##### Dashboards:
2016-07-06 23:34:16 +08:00
- kubernetes-dashboard
- Fabric8
- Tectonic
- Cockpit
##### Paas like
- Openshift Origin
- Openstack
- Deis Workflow
### Others
- remove nodes (adding is already supported)
- being able to choose any k8s version (almost done)
2017-06-17 01:25:46 +08:00
- **rkt** support [#59](https://github.com/kubespray/kubespray/issues/59)
2016-07-06 23:34:16 +08:00
- Review documentation (split in categories)
- **consul** -> if officialy supported by k8s
2017-06-17 01:25:46 +08:00
- flex volumes options (e.g. **torrus** support) [#312](https://github.com/kubespray/kubespray/issues/312)
- Clusters federation option (aka **ubernetes**) [#329](https://github.com/kubespray/kubespray/issues/329)