Skip to content

drycc/storage

Repository files navigation

Drycc Storage v3

Build Status

Drycc (pronounced DAY-iss) Workflow is an open source Platform as a Service (PaaS) that adds a developer-friendly layer to any Kubernetes cluster, making it easy to deploy and manage applications on your own servers.

For more information about the Drycc workflow, please visit the main project page at https://github.com/drycc/workflow.

We welcome your input! If you have feedback, please submit an issue. If you'd like to participate in development, please read the "Development" section below and submit a pull request.

About

The Drycc storage component provides an S3 API compatible object storage server, based on Seaweedfs, that can be run on Kubernetes. It's intended for use within the Drycc v2 platform as an object storage server, but it's flexible enough to be run as a standalone pod on any Kubernetes cluster.

Note that in the default Helm chart for the Drycc platform, this component is used as a storage location for the following components:

At least three physical nodes are required in production mode, otherwise data may be lost.

Development

The Drycc project welcomes contributions from all developers. The high level process for development matches many other open source projects. See below for an outline.

  • Fork this repository
  • Make your changes
  • Submit a pull request (PR) to this repository with your changes, and unit tests whenever possible.
  • If your PR fixes any issues, make sure you write Fixes #1234 in your PR description (where #1234 is the number of the issue you're closing)
  • The Drycc core contributors will review your code. After each of them sign off on your code, they'll label your PR with LGTM1 and LGTM2 (respectively). Once that happens, you may merge.

Container Based Development Environment

The preferred environment for development uses the go-dev Container image. The tools described in this section are used to build, test, package and release each version of Drycc.

To use it yourself, you must have make installed and Podman installed and running on your local development machine.

If you don't have Podman installed, please go to https://www.podman.io/ to install it.

After you have those dependencies, build your code with make build and execute unit tests with make test.

Testing

The Drycc project requires that as much code as possible is unit tested, but the core contributors also recognize that some code must be tested at a higher level (functional or integration tests, for example).

The end-to-end tests repository has our integration tests. Additionally, the core contributors and members of the community also regularly dogfood the platform.

Upgrade

Updating drycc storage csi daemonset will break processeses who implement fuse mount: newly created pods will not remount net device.

For safe update set node.updateStrategy.type: OnDelete for manual update. Steps:

  • delete daemonset pods on the node where there is no drycc storage pv
  • cordon or taint node
  • evict or delete pods with drycc storage pv
  • delete daemonset pod on node
  • uncordon or remove taint on node
  • repeat all steps on [all nodes]

Running End-to-End Tests

Please see README.md on the end-to-end tests reposotory for instructions on how to set up your testing environment and run the tests.

Dogfooding

Please follow the instructions on the official Drycc docs to install and configure your Drycc cluster and all related tools, and deploy and configure an app on Drycc.