Requirements:
- Go 1.10+
You can install go directly or use gvm ( go version manager)
Install gvm:
bash < <(curl -s -S -L https://raw.githubusercontent.com/moovweb/gvm/master/binscripts/gvm-installer)
See all currently installed go versions:
gvm list
See all available go versions that can be installed using gvm:
gvm listall
Install a new go version:
gvm install go1.4 -B
gvm use go1.4
gvm install go1.11 --binary
gvm use go1.11 --default
Your GOPATH should be be set by now, check using
echo $GOPATH
should display something like /home/<userdir>/.gvm/pkgsets/go1.11/global
Clone operator repo:
cd $GOPATH
go get github.com:pravega/pravega-operator
This should clone operator code under $GOPATH/src/github.com/pravega/pravega-operator
curl https://raw.githubusercontent.com/golang/dep/master/install.sh | sh
This may prompt for creation of GOBIN
directory. Please create it and then issue this command again.
Use the make
command to build the Pravega operator image.
$ cd $GOPATH/src/github.com/pravega/pravega-operator
$ make dep
$ make build
That will generate a Docker image with the format
<latest_release_tag>-<number_of_commits_after_the_release>
(it will append-dirty if there are uncommitted changes). The image will also be tagged as latest
.
Example image after running make build
.
The Pravega Operator image will be available in your Docker environment.
$ docker images pravega/pravega-operator
REPOSITORY TAG IMAGE ID CREATED SIZE
pravega/pravega-operator 0.1.1-3-dirty 2b2d5bcbedf5 10 minutes ago 41.7MB
pravega/pravega-operator latest 2b2d5bcbedf5 10 minutes ago 41.7MB
Optionally push it to a Docker registry.
docker tag pravega/pravega-operator [REGISTRY_HOST]:[REGISTRY_PORT]/pravega/pravega-operator
docker push [REGISTRY_HOST]:[REGISTRY_PORT]/pravega/pravega-operator
where:
[REGISTRY_HOST]
is your registry host or IP (e.g.registry.example.com
)[REGISTRY_PORT]
is your registry port (e.g.5000
)
You can run the Operator locally to help with development, testing, and debugging tasks.
The following command will run the Operator locally with the default Kubernetes config file present at $HOME/.kube/config
. Use the --kubeconfig
flag to provide a different path.
$ make run-local
The Operator requires elevated privileges in order to watch for the custom resources.
According to Google Container Engine docs:
Ensure the creation of RoleBinding as it grants all the permissions included in the role that we want to create. Because of the way Container Engine checks permissions when we create a Role or ClusterRole.
An example workaround is to create a RoleBinding that gives your Google identity a cluster-admin role before attempting to create additional Role or ClusterRole permissions.
This is a known issue in the Beta release of Role-Based Access Control in Kubernetes and Container Engine version 1.6.
On GKE, the following command must be run before installing the Operator, replacing the user with your own details.
$ kubectl create clusterrolebinding your-user-cluster-admin-binding --clusterrole=cluster-admin [email protected]