Percona Everest backend uses two types of methods:
- "own" methods, such as registering a Kubernetes cluster in Everest and listing the clusters.
- proxy methods for the Kubernetes API, including all resource-related methods like database-cluster, database-cluster-restore, and database-engine.
The API server basic code is generated using oapi-codegen from the docs/spec/openapi.yml file. The proxy methods align with Everest operator methods but don't support all original parameters, because these are not required. You can find the definition of the custom resources in the Everest operator repo.
- Prerequisites:
- Golang 1.20.x
- Make 3.x
- Docker 20.x
- Git 2.x
- Check out the repo:
git clone https://github.com/percona/percona-everest-backend
- Navigate to the repo folder:
cd percona-everest-backend
- Check out a particular branch if needed:
git checkout <branch_name>
- Install the project dependencies:
make init
- Run the dev environment:
make local-env-up
- Run the build:
make run
-
Copy the corresponding k8s spec to the openapi.yml. For information on observing your cluster API, see Kubernetes: How to View Swagger UI blog post, which details the operator-defined methods (if the everest operator is installed).
-
Make necessary spec modifications. When designing new methods:
- follow the Restful API guidelines. - - use kebab-case instead of everest operator API.
- determine parameters to expose via proxy.
-
If needed, copy the custom resources schema from the Everest operator config to the Components section of the openapi.yml file.
-
Run the following command to generate the code:
$ make init
$ make gen
- Implement the missing
ServerInterface
methods. - Run
make format
to format the code and group the imports. - Run
make check
to verify that your code works and meets all style requirements.
To run integration tests, see Percona Everest API integration tests.
When working with local Kubernetes clusters, Everest backend cannot connect to them because they often use 127.0.0.1
or localhost
addresses. However, it is possible to connect to the host machine using host.docker.internal
hostname since Everest backend runs inside a Docker container.
To do this, add the following host to the /etc/hosts
file on your local machine:
127.0.0.1 host.docker.internal
-
Spin up a Minikube cluster, using
--apiserver-names host.docker.internal
, depending on your operating system. -
Run the
make local-env-up
command from everest-operator. This command works fine on MacOS. -
Once the Minikube cluster's kubeconfig is available, update the server address in the kubeconfig file from
127.0.0.1
tohost.docker.internal
, while maintaining the same port. -
Use Everest by initiating the provisioning procedure through the command line interface.
Here are some commands that can help you fix potential issues:
kubectl -n namespace get sub # Check that subscription was created for an operator
kubectl -n namespace get ip # Check that install plan was created and approved for an operator
kubectl -n namespace get csv # Check that Cluster service version was created and phase is Installed
kubectl -n namespace get deployment # Check that deployment exist
kubectl -n namespace get po # Check that pods for an operator is running
kubectl -n namespace logs <podname> # Check logs for a pod
kubectl -n namespace get db # Get list of database clusters
kubectl -n namespace get po # Get pods for a database cluster
kubectl -n namespace describe db # Describe database cluster. Provides useful information about conditions or messages
kubectl -n namespace describe pxc # Describe PXC cluster
kubectl -n namespace describe psmdb # Describe PSMDB cluster
kubectl -n namespace describe pg # Describe PG cluster
kubectl -n namespace logs <podname> # Check logs for a pod
kubectl -n namespace get pvc # PVCs should be Bound