English | 简体中文
HwameiStor is an HA local storage system for cloud-native stateful workloads. It creates a local storage resource pool for centrally managing all disks such as HDD, SSD, and NVMe. It uses the CSI architecture to provide distributed services with local volumes and provides data persistence capabilities for stateful cloud-native workloads or components.
HwameiStor is a cloud-native storage project listed in CNCF Landscape, with capabilities to support for your production environment.
At present, HwameiStor is still in the alpha stage.
The latest release of HwameiStor is
See current releases.
kubernetes | v0.4.3 | >=v0.5.0 |
---|---|---|
>=1.18&&<=1.20 | Yes | No |
1.21 | Yes | Yes |
1.22 | Yes | Yes |
1.23 | Yes | Yes |
1.24 | Yes | Yes |
1.25 | No | Yes |
HwameiStor contains several modules:
- local-disk-manager
- local-storage
- scheduler
- admission-controller
- Evictor
- Exporter
- HA module installer
local-disk-manager (LDM) is designed to hold the management of disks on nodes. Other modules such as local-storage can take advantage of the disk management feature provided by LDM. Learn more
local-storage (LS) provides a cloud-native local storage system. It aims to provision high-performance persistent LVM volume with local access to applications. Learn more
Scheduler is to automatically schedule a pod to a correct node which has the associated HwameiStor volumes. Learn more
admission-controller is a webhook that can automatically determine which pod uses the HwameiStor volume and, help to modify the schedulerName to hwameistor-scheduler. Learn more
Evictor is used to automatically migrate HwameiStor volumes in case of node or pod eviction. When a node or pod is evicted as either Planned or Unplanned, the associated HwameiStor volumes, which have a replica on the node, will be detected and migrated out this node automatically. Learn more
DRBD (Distributed Replicated Block Device) is one of third-party HA modules which the HwameiStor will leverage to provide HA volume. It composed of Linux kernel modules and related scripts to build high available clusters. It is implemented by mirroring the entire device over the network, which can be thought of as a kind of network RAID. This installer can directly install DRBD to a container cluster. Currently this module is only for testing purposes. Learn more
Exporter will collect the system metrics including nodes, storage pools, volumes, disks. It supports Prometheus.
For full documentation, please see our website hwameistor.io.
For detailed adopters that have HwameiStor deployed in a production environment or a user acceptance testing environment, please check the adopters list.
Features | Status | Release | Description |
---|---|---|---|
CSI for LVM volume | Completed | v0.3.2 | Provision volume with lvm |
CSI for disk volume | Completed | v0.3.2 | Provision volume with disk |
HA LVM Volume | Completed | v0.3.2 | Volume with HA |
LVM Volume expansion | Completed | v0.3.2 | Expand LVM volume capacity online |
LVM Volume conversion | Completed | v0.3.2 | Convert a non-HA LVM volume to the HA |
LVM Volume migration | Completed | v0.4.0 | Migrate a LVM volume replica to a different node |
Volume Group | Completed | v0.3.2 | Support volume group allocation |
Disk health check | Completed | v0.7.0 | Disk fault prediction, status reporting |
LVM HA Volume Recovery | Planed | Recover the LVM HA volume in problem | |
HwameiStor Operator | Completed | v0.9.0 | Operator for HwameiStor install, maintain, etc. |
Observability | Completed | v0.9.2 | Observability, such as metrics, logs, etc. |
Failover | Planed | Fail over the pod with HwameiStor volume | |
IO throttling | Completed | v0.11.0 | Limit IO bandwith to access the HwameiStor volume |
Disk replacement | Planed | Replace disk which fails or will fail soon | |
LVM volume auto-expansion | In Progress | Expand LVM volume automatically | |
LVM volume snapshot | In Progress | Snapshot of LVM volume | |
LVM volume clone | Planed | Clone LVM volume | |
LVM volume thin provision | Unplaned | LVM volume thin provision | |
LVM volume stripe mode | Unplaned | LVM volume stripe read/write | |
Data encryption | Unplaned | Data encryption | |
System Consistency | Planed | Consistent check and recovery from a disaster | |
Volume backup | Planed | Backup the volume data to remote server and restore |
We welcome contributions of any kind. If you have any questions about contributing, please consult the contributing documentation.
Please follow our weekly blogs.
Welcome to join our slack channel
HwameiStor tech-talk group:
Welcome to follow our roadmap discussions here
Please feel free to raise requests on chats or by a PR.
We will try our best to respond to every issue reported on community channels, but the issues reported here on this repo will be addressed first.
Copyright (c) 2014-2021 The HwameiStor Authors
Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at http://www.apache.org/licenses/LICENSE-2.0