2021-06-09 20:11:02 +00:00
[![Build Status ](https://travis-ci.com/seaweedfs/seaweedfs-operator.svg?branch=master )](https://travis-ci.com/github/seaweedfs/seaweedfs-operator)
2021-06-09 20:07:56 +00:00
2020-08-02 01:01:15 +00:00
# SeaweedFS Operator
2021-06-10 17:03:55 +00:00
This [Kubernetes Operator ](https://kubernetes.io/docs/concepts/extend-kubernetes/operator/ ) is made to easily deploy SeaweedFS onto your Kubernetes-Cluster.
The difference to [seaweedfs-csi-driver ](https://github.com/seaweedfs/seaweedfs-csi-driver ) is that the infrastructure (SeaweedFS) itself runs on Kubernetes as well (Master, Filer, Volume-Servers) and can as such easily scale with it as you need. It is also by far more resilent to failures then a simple systemD service in regards to handling crashing services or accidental deletes.
2021-06-10 17:06:00 +00:00
By using `make deploy` it will deploy a Resource of type 'Seaweed' onto your current kubectl $KUBECONFIG target (the operator itself) which by default will do nothing unless you configurate it (see examples in config/samples/).
2021-06-10 17:03:55 +00:00
2020-10-27 07:37:07 +00:00
Goals:
2021-06-13 10:52:05 +00:00
- [x] Automatically deploy and manage a SeaweedFS cluster.
- [x] Ability to be managed by other Operators.
- [ ] Compability with [seaweedfs-csi-driver ](https://github.com/seaweedfs/seaweedfs-csi-driver )
2021-06-10 17:03:55 +00:00
- [x] Auto rolling upgrade and restart.
- [x] Ingress for volume server, filer and S3, to support HDFS, REST filer, S3 API and cross-cluster replication.
- [ ] Support all major cloud Kubernetes: AWS, Google, Azure.
- [ ] Scheduled backup to cloud storage: S3, Google Cloud Storage , Azure.
- [ ] Put warm data to cloud storage tier: S3, Google Cloud Storage , Azure.
- [ ] Grafana dashboard.
2020-10-27 07:37:07 +00:00
2020-08-02 01:01:15 +00:00
## Installation
2020-11-15 03:18:19 +00:00
This operator uses `kustomize` to deploy. The installation process will install one for you if you do not have one.
By default, the defaulting and validation webhooks are disabled. We strongly recommend that the webhooks be enabled.
First clone the repository:
```bash
$ git clone https://github.com/seaweedfs/seaweedfs-operator --depth=1
```
2020-11-28 01:26:47 +00:00
To deploy the operator with webhooks enabled, make sure you have installed the `cert-manager` (Installation docs: https://cert-manager.io/docs/installation/) in your cluster, then follow the instructions in the `config/default/kustomization.yaml` file to uncomment the components you need.
2020-11-15 03:18:19 +00:00
2020-11-28 01:31:41 +00:00
Lastly, change the value of `ENABLE_WEBHOOKS` to `"true"` in `config/manager/manager.yaml`
2020-11-28 01:31:24 +00:00
2021-06-10 17:03:55 +00:00
Afterwards fire up:
```bash
$ make install
```
2020-11-15 03:18:19 +00:00
Then run the command to deploy the operator into your cluster:
2021-06-10 17:03:55 +00:00
```bash
2020-11-15 03:18:19 +00:00
$ make deploy
```
2021-06-10 17:03:55 +00:00
Verify if it was correctly deployed with:
```bash
2021-07-15 20:58:16 +00:00
$ kubectl get pods --all-namespaces
2021-06-10 17:03:55 +00:00
```
2021-07-15 21:01:14 +00:00
Which may return:
2021-06-10 17:03:55 +00:00
```bash
2021-07-15 20:58:16 +00:00
NAMESPACE NAME READY STATUS RESTARTS AGE
kube-system coredns-f9fd979d6-68p4c 1/1 Running 0 34m
kube-system coredns-f9fd979d6-x992t 1/1 Running 0 34m
kube-system etcd-kind-control-plane 1/1 Running 0 34m
kube-system kindnet-rp7wr 1/1 Running 0 34m
kube-system kube-apiserver-kind-control-plane 1/1 Running 0 34m
kube-system kube-controller-manager-kind-control-plane 1/1 Running 0 34m
kube-system kube-proxy-dqfg2 1/1 Running 0 34m
kube-system kube-scheduler-kind-control-plane 1/1 Running 0 34m
local-path-storage local-path-provisioner-78776bfc44-7zvxx 1/1 Running 0 34m
seaweedfs-operator-system seaweedfs-operator-controller-manager-54cc768f4c-cwz2k 2/2 Running 0 34m
2021-06-10 17:03:55 +00:00
```
2021-06-25 09:06:25 +00:00
See the next section for example usage - **__at this point you only deployed the Operator itself!__**
### You need to also deploy an configuration to get it running (see next section)!
2021-06-13 10:52:05 +00:00
## Configuration Examples
2021-06-25 08:17:25 +00:00
- Please send us your use-cases / example configs ... this is currently empty (needs to be written)
2021-06-25 09:07:58 +00:00
- For now see: https://github.com/seaweedfs/seaweedfs-operator/blob/master/config/samples/seaweed_v1_seaweed.yaml
2021-06-25 09:12:19 +00:00
````
apiVersion: seaweed.seaweedfs.com/v1
kind: Seaweed
metadata:
name: seaweed1
namespace: default
spec:
# Add fields here
2022-02-27 20:50:25 +00:00
image: chrislusf/seaweedfs:2.91
2021-06-25 09:12:19 +00:00
volumeServerDiskCount: 1
hostSuffix: seaweed.abcdefg.com
master:
replicas: 3
volumeSizeLimitMB: 1024
volume:
replicas: 1
requests:
storage: 2Gi
filer:
replicas: 2
config: |
[leveldb2]
enabled = true
dir = "/data/filerldb2"
````
2021-06-13 10:52:05 +00:00
2021-06-25 08:17:25 +00:00
## Maintenance and Uninstallation
- TBD
2021-06-13 10:52:05 +00:00
2020-08-02 01:01:15 +00:00
## Development
2020-09-20 23:34:57 +00:00
Follow the instructions in https://sdk.operatorframework.io/docs/building-operators/golang/quickstart/
2020-08-02 01:01:15 +00:00
```
$ git clone https://github.com/seaweedfs/seaweedfs-operator
$ cd seaweedfs-operator
# register the CRD with the Kubernetes
2020-11-09 00:23:17 +00:00
$ make deploy
2020-08-02 01:01:15 +00:00
2020-11-09 00:23:17 +00:00
# build the operator image
$ make docker-build
# load the image into Kind cluster
2021-02-06 08:28:05 +00:00
$ kind load docker-image chrislusf/seaweedfs-operator:v0.0.1
2020-08-02 01:01:15 +00:00
# From another terminal in the same directory
2020-08-02 06:27:46 +00:00
$ kubectl apply -f config/samples/seaweed_v1_seaweed.yaml
2020-08-02 01:01:15 +00:00
```
2020-11-09 07:29:57 +00:00
2020-11-10 07:28:13 +00:00
### Update the operator
2020-11-09 07:29:57 +00:00
```
# delete the existing operator
$ kubectl delete namespace seaweedfs-operator-system
# rebuild the operator image
$ make docker-build
# load the image into Kind cluster
2021-02-06 08:28:05 +00:00
$ kind load docker-image chrislusf/seaweedfs-operator:v0.0.1
2020-11-09 07:29:57 +00:00
# register the CRD with the Kubernetes
$ make deploy
2020-11-10 07:28:13 +00:00
```
### develop outside of k8s
```
$ git clone https://github.com/seaweedfs/seaweedfs-operator
$ cd seaweedfs-operator
# register the CRD with the Kubernetes
$ make install
# run the operator locally outside the Kubernetes cluster
$ make run ENABLE_WEBHOOKS=false
# From another terminal in the same directory
$ kubectl apply -f config/samples/seaweed_v1_seaweed.yaml
2020-11-28 01:26:47 +00:00
```