Skip to content

Latest commit

 

History

History
772 lines (530 loc) · 47.5 KB

CHANGELOG.md

File metadata and controls

772 lines (530 loc) · 47.5 KB

PVC Changelog

  • [API Daemon] Fixes a calculation bug when checking storage free space
  • [API Daemon/Provisioner] Corrects some small bugs with OVA handling
  • [API Daemon] Fixes a bug that failed uploading of RAW block devices in "storage volume upload"
  • [API Daemon/CLI Client] Adds support for VM automirrors, replicating the functionality of autobackup but for cross-cluster mirroring
  • [CLI Client] Improves the help output of several commands
  • [API Daemon/CLI Client] Moves VM snapshot age conversions to human-readable values out of the API and into the client to open up more programatic handling in the future
  • [Worker Daemon] Improves the Celery logging output clarity by including the calling function in any task output
  • [Provisioner] Fixes a bug with the change in storage_hosts to FQDNs affecting the VM Builder
  • [Monitoring] Fixes the Munin plugin to work properly with sudo
  • [API Daemon] Ensures that received config snapshots update storage hosts in addition to secret UUIDs
  • [CLI Client] Fixes several bugs around local connection handling and connection listings

New Feature: Adds VM snapshot sending (vm snapshot send), VM mirroring (vm mirror create), and (offline) mirror promotion (vm mirror promote). Permits transferring VM snapshots to remote clusters, individually or repeatedly, and promoting them to active status, for disaster recovery and migration between clusters. Breaking Change: Migrates the API daemon into Gunicorn when in production mode. Permits more scalable and performant operation of the API. Requires additional dependency packages on all coordinator nodes (gunicorn, python3-gunicorn, python3-setuptools); upgrade via pvc-ansible is strongly recommended. Enhancement: Provides whole cluster utilization stats in the cluster status data. Permits better observability into the overall resource utilization of the cluster. Enhancement: Adds a new storage benchmark format (v2) which includes additional resource utilization statistics. This allows for better evaluation of storage performance impact on the cluster as a whole. The updated format also permits arbitrary benchmark job names for easier parsing and tracking.

  • [API Daemon] Allows scanning of new volumes added manually via other commands
  • [API Daemon/CLI Client] Adds whole cluster utilization statistics to cluster status
  • [API Daemon] Moves production API execution into Gunicorn
  • [API Daemon] Adds a new storage benchmark format (v2) with additional resource tracking
  • [API Daemon] Adds support for named storage benchmark jobs
  • [API Daemon] Fixes a bug in OSD creation which would create split OSDs if --osd-count was set to 1
  • [API Daemon] Adds support for the mirror VM state used by snapshot mirrors
  • [CLI Client] Fixes several output display bugs in various commands and in Worker task outputs
  • [CLI Client] Improves and shrinks the status progress bar output to support longer messages
  • [API Daemon] Adds support for sending snapshots to remote clusters
  • [API Daemon] Adds support for updating and promoting snapshot mirrors to remote clusters
  • [Node Daemon] Improves timeouts during primary/secondary coordinator transitions to avoid deadlocks
  • [Node Daemon] Improves timeouts during keepalive updates to avoid deadlocks
  • [Node Daemon] Refactors fencing thread structure to ensure a single fencing task per cluster and sequential node fences to avoid potential anomalies (e.g. fencing 2 nodes simultaneously)
  • [Node Daemon] Fixes a bug in fencing if VM locks were already freed, leaving VMs in an invalid state
  • [Node Daemon] Increases the wait time during system startup to ensure Zookeeper has more time to synchronize
  • [API Daemon] Improves the handling of "detect:" disk strings on newer systems by leveraging the "nvme" command
  • [Client CLI] Update help text about "detect:" disk strings
  • [Meta] Updates deprecation warnings and updates builder to only add this version for Debian 12 (Bookworm)

Deprecation Warning: pvc vm backup commands are now deprecated and will be removed in a future version. Use pvc vm snapshot commands instead. Breaking Change: The on-disk format of VM snapshot exports differs from backup exports, and the PVC autobackup system now leverages these. It is recommended to start fresh with a new tree of backups for pvc autobackup for maximum compatibility. Breaking Change: VM autobackups now run in pvcworkerd instead of the CLI client directly, allowing them to be triggerd from any node (or externally). It is important to apply the timer unit changes from the pvc-ansible role after upgrading to 0.9.99 to avoid duplicate runs. Usage Note: VM snapshots are displayed in the pvc vm list and pvc vm info outputs, not in a unique "list" endpoint.

  • [API Daemon] Adds a proper error when an invalid provisioner profile is specified
  • [Node Daemon] Sorts Ceph pools properly in node keepalive to avoid incorrect ordering
  • [Health Daemon] Improves handling of IPMI checks by adding multiple tries but a shorter timeout
  • [API Daemon] Improves handling of XML parsing errors in VM configurations
  • [ALL] Adds support for whole VM snapshots, including configuration XML details, and direct rollback to snapshots
  • [ALL] Adds support for exporting and importing whole VM snapshots
  • [Client CLI] Removes vCPU topology from short VM info output
  • [Client CLI] Improves output format of VM info output
  • [API Daemon] Adds an endpoint to get the current primary node
  • [Client CLI] Fixes a bug where API requests were made 3 times
  • [Other] Improves the build-and-deploy.sh script
  • [API Daemon] Improves the "vm rename" command to avoid redefining VM, preserving history etc.
  • [API Daemon] Adds an indication when a task is run on the primary node
  • [API Daemon] Fixes a bug where the ZK schema relative path didn't work sometimes
  • [CLI Client] Fixed output when API call times out
  • [Node Daemon] Improves the handling of fence states
  • [API Daemon/CLI Client] Adds support for storage snapshot rollback
  • [CLI Client] Adds additional warning messages about snapshot consistency to help output
  • [API Daemon] Fixes a bug listing snapshots by pool/volume
  • [Node Daemon] Adds a --version flag for information gathering by update-motd.sh
  • [Client CLI] Ensures --lines is always an integer value
  • [Node Daemon] Fixes a bug if d_network changes during iteration
  • [Node Daemon] Moves to using allocated instead of free memory for node reporting
  • [API Daemon] Fixes a bug if lingering RBD snapshots exist when removing a volume (#180)
  • [API Daemon] Fixes a bug when reporting node stats
  • [API Daemon] Fixes a bug deleteing successful benchmark results
  • [API Daemon/CLI Client] Adds a flag to allow duplicate VNIs in network templates
  • [API Daemon] Ensures that storage template disks are returned in disk ID order
  • [Client CLI] Fixes a display bug showing all OSDs as split
  • [CLI Client] Fixes an incorrect ordering issue with autobackup summary emails
  • [API Daemon/CLI Client] Adds an additional safety check for 80% cluster fullness when doing volume adds or resizes
  • [API Daemon/CLI Client] Adds safety checks to volume clones as well
  • [API Daemon] Fixes a few remaining memory bugs for stopped/disabled VMs
  • [API Daemon] Fixes a bug where stuck zkhandler threads were not cleaned up on error
  • [CLI Client] Adds the new restore state to the colours list for VM status
  • [API Daemon] Fixes an incorrect variable assignment
  • [Provisioner] Improves the error handling of various steps in the debootstrap and rinse example scripts
  • [CLI Client] Fixes two bugs around missing keys that were added recently (uses get() instead direct dictionary refs)
  • [CLI Client] Improves API error handling via GET retries (x3) and better server status code handling
  • [Client CLI] Fixes a bug and improves output during cluster task events.
  • [Client CLI] Improves the output of the task list display.
  • [Provisioner] Fixes some missing cloud-init modules in the default debootstrap script.
  • [Client CLI] Fixes a bug with a missing argument to the vm_define helper function.
  • [All] Fixes inconsistent package find + rm commands to avoid errors in dpkg.
  • [Client CLI/API Daemon] Adds additional backup metainfo and an emailed report option to autobackups.
  • [All] Adds a live migration maximum downtime selector to help with busy VM migrations.
  • [API Daemon] Fixes a database migration bug on Debian 10/11.
  • [Node Daemon] Fixes a race condition when applying Zookeeper schema changes.
  • [API/Worker Daemons] Fixes a bug with the Celery result backends not being properly initialized on Debian 10/11.
  • [API Daemon] Fixes a bug if VM CPU stats are missing on Debian 10.
  • [API Daemon] Adds an additional Prometheus metrics proxy for Zookeeper stats.
  • [API Daemon] Adds a new configuration to enable or disable metric endpoints if desired, defaulting to enabled.
  • [API Daemon] Alters and adjusts the metrics output for VMs to complement new dashboard.
  • [CLI Client] Adds a "json-prometheus" output format to "pvc connection list" to auto-generate file SD configs.
  • [Monitoring] Adds a new VM dashboard, updates the Cluster dashboard, and adds a README.
  • [API Daemon] Adds cluster Prometheus resource utilization metrics and an updated Grafana dashboard.
  • [Node Daemon] Adds network traffic rate calculation subsystem.
  • [All Daemons] Fixes a printing bug where newlines were not added atomically.
  • [CLI Client] Fixes a bug listing connections if no default is specified.
  • [All Daemons] Simplifies debug logging conditionals by moving into the Logger instance itself.
  • [API Daemon] Significantly improves the performance of several commands via async Zookeeper calls and removal of superfluous backend calls.
  • [Docs] Improves the project README and updates screenshot images to show the current output and more functionality.
  • [API Daemon/CLI] Corrects some bugs in VM metainformation output.
  • [Node Daemon] Fixes resource reporting bugs from 0.9.81 and properly clears node resource numbers on a fence.
  • [Health Daemon] Adds a wait during pvchealthd startup until the node is in run state, to avoid erroneous faults during node bootup.
  • [API Daemon] Fixes an incorrect reference to legacy pvcapid.yaml file in migration script.
  • [Packaging] Fixes a dependency bug introduced in 0.9.84
  • [Node Daemon] Fixes an output bug during keepalives
  • [Node Daemon] Fixes a bug in the example Prometheus Grafana dashboard

Breaking Changes: This release features a major reconfiguration to how monitoring and reporting of the cluster health works. Node health plugins now report "faults", as do several other issues which were previously manually checked for in "cluster" daemon library for the "/status" endpoint, from within the Health daemon. These faults are persistent, and under each given identifier can be triggered once and subsequent triggers simply update the "last reported" time. An additional set of API endpoints and commands are added to manage these faults, either by "ack"(nowledging) them (keeping the alert around to be further updated but setting its health delta to 0%), or "delete"ing them (completely removing the fault unless it retriggers), both individually, to (from the CLI) multiple, or all. Cluster health reporting is now done based on these faults instead of anything else, and the default interval for health checks is reduced to 15 seconds to accomodate this. In addition to this, Promethius metrics have been added, along with an example Grafana dashboard, for the PVC cluster itself, as well as a proxy to the Ceph cluster metrics. This release also fixes some bugs in the VM provisioner that were introduced in 0.9.83; these fixes require a reimport or reconfiguration of any provisioner scripts; reference the updated examples for details.

  • [All] Adds persistent fault reporting to clusters, replacing the old cluster health calculations.
  • [API Daemon] Adds cluster-level Prometheus metric exporting as well as a Ceph Prometheus proxy to the API.
  • [CLI Client] Improves formatting output of "pvc cluster status".
  • [Node Daemon] Fixes several bugs and enhances the working of the psql health check plugin.
  • [Worker Daemon] Fixes several bugs in the example provisioner scripts, and moves the libvirt_schema library into the daemon common libraries.

Breaking Changes: This release features a breaking change for the daemon config. A new unified "pvc.conf" file is required for all daemons (and the CLI client for Autobackup and API-on-this-host functionality), which will be written by the "pvc" role in the PVC Ansible framework. Using the "update-pvc-daemons" oneshot playbook from PVC Ansible is required to update to this release, as it will ensure this file is written to the proper place before deploying the new package versions, and also ensures that the old entires are cleaned up afterwards. In addition, this release fully splits the node worker and health subsystems into discrete daemons ("pvcworkerd" and "pvchealthd") and packages ("pvc-daemon-worker" and "pvc-daemon-health") respectively. The "pvc-daemon-node" package also now depends on both packages, and the "pvc-daemon-api" package can now be reliably used outside of the PVC nodes themselves (for instance, in a VM) without any strange cross-dependency issues.

  • [All] Unifies all daemon (and on-node CLI task) configuration into a "pvc.conf" YAML configuration.
  • [All] Splits the node worker subsystem into a discrete codebase and package ("pvc-daemon-worker"), still named "pvcworkerd".
  • [All] Splits the node health subsystem into a discrete codebase and package ("pvc-daemon-health"), named "pvchealthd".
  • [All] Improves Zookeeper node logging to avoid bugs and to support multiple simultaneous daemon writes.
  • [All] Fixes several bugs in file logging and splits file logs by daemon.
  • [Node Daemon] Improves several log messages to match new standards from Health daemon.
  • [API Daemon] Reworks Celery task routing and handling to move all worker tasks to Worker daemon.
  • [API Daemon] Fixes a bug where the Celery result_backend was not loading properly on Celery <5.2.x (Debian 10/11).

Breaking Changes: This large release features a number of major changes. While these should all be a seamless transition, the behaviour of several commands and the backend system for handling them has changed significantly, along with new dependencies from PVC Ansible. A full cluster configuration update via pvc.yml is recommended after installing this version. Redis is replaced with KeyDB on coordinator nodes as a Celery backend; this transition will be handled gracefully by the pvc-ansible playbooks, though note that KeyDB will be exposed on the Upstream interface. The Celery worker system is renamed pvcworkerd, is now active on all nodes (coordinator and non-coordinator), and is expanded to encompass several commands that previously used a similar, custom setup within the node daemons, including "pvc vm flush-locks" and all "pvc storage osd" tasks. The previously-mentioned CLI commands now all feature "--wait"/"--no-wait" flags, with wait showing a progress bar and status output of the task run. The "pvc cluster task" command can now used for viewing all task types, replacing the previously-custom/specific "pvc provisioner status" command. All example provisioner scripts have been updated to leverage new helper functions in the Celery system; while updating these is optional, an administrator is recommended to do so for optimal log output behaviour.

  • [CLI Client] Fixes "--live" argument handling and duplicate restart prompts.
  • [All] Adds support for multiple OSDs on individual disks (NVMe workloads).
  • [All] Corrects and updates OSD replace, refresh, remove, and add functionality; replace no longer purges.
  • [All] Switches to KeyDB (multi-master) instead of Redis and adds node monitoring plugin.
  • [All] Replaces Zookeeper/Node Daemon-based message passing and task handling with pvcworkerd Celery workers on all nodes; increases worker concurrency to 3 (per node).
  • [All] Moves all task-like functions to Celery and updates existing Celery tasks to use new helpers and ID system.
  • [CLI Client] Adds "--wait/--no-wait" options with progress bars to all Celery-based tasks, "--wait" default; adds a standardized task interface under "pvc cluster task".
  • [Node Daemon] Cleans up the fencing handler and related functions.
  • [Node Daemon] Fixes bugs with VM memory reporting during keepalives.
  • [Node Daemon] Fixes a potential race condition during primary/secondary transition by backgrounding systemctl commands.
  • [API Daemon] Updates example provisioner plugins to use new Celery functions.
  • [CLI] Improves CLI performance by not loading "pkg_resources" until needed
  • [CLI] Improves the output of the audit log (full command paths)
  • [Node Daemon/API Daemon] Moves the sample YAML configurations to /usr/share/pvc instead of /etc/pvc and cleans up the old locations automatically
  • [CLI] Adds VM autobackup functionality to automate VM backup/retention and scheduling
  • [CLI] Handles the internal store in a better way to ensure CLI can be used as a module properly

API Changes: New endpoints /vm/{vm}/backup, /vm/{vm}/restore

  • [CLI Client] Fixes some storage pool help text messages
  • [Node Daemon] Increases the IPMI monitoring plugin timeout
  • [All] Adds support for VM backups, including creation, removal, and restore
  • [Repository] Fixes shebangs in scripts to be consistent
  • [Daemon Library] Improves the handling of VM list arguments (default None)
  • [API, Client CLI] Fixes several bugs around image uploads; adds a new query parameter for non-raw images
  • [API] Ensures RBD images are created with a raw bytes value to avoid rounding errors
  • [Client CLI] Fixes a bug from a bad library import
  • [API, Client CLI] Corrects some missing node states for fencing in status output
  • [Node Daemon] Adds a startup message about IPMI when succeeding
  • [Node Daemon] Fixes a bug in fencing allowing non-failing VMs to migrate
  • [Node Daemon] Adds rounding to load average in load plugin for consistency
  • [Docs] Removes docs from the main repo
  • [Client CLI] Ensures that "provision" VMs are shown in the right colour
  • [Node Daemon] Separates the node monitoring subsystem into its own thread with a longer, customizable update interval
  • [Node Daemon] Adds checks for PSU input power reundancy (psur) and hardware RAID (hwrd)
  • [Node Daemon] Updates when Keepalive start messages are printed (end of run, with runtime) to align with new monitoring messages
  • [Node Daemon] Fixes a bug creating monitoring instance
  • [CLI] Restores old functionality for default node value
  • [API] Adds API support for Debian Bookworm
  • [Node Daemon] Fixes several compatibility issues for Debian 12 "Bookworm"
  • [Node Daemon] Ensures that system load is always 2 decimal places on Bookworm
  • [Node Daemon] Fixes bug blocking primary takeover at DNS Aggregator start if Patroni is down
  • [CLI] Fixes another bug with network info view
  • [CLI] Fixes several more bugs in the refactored CLI
  • [CLI] Fixes a missing YAML import in CLI
  • [CLI] Fixes a bug in the node list filtering command
  • [CLI] Fixes a bug/default when no connection is specified

Breaking Change [CLI]: The CLI client root commands have been reorganized. The following commands have changed:

  • pvc cluster -> pvc connection (all subcommands)
  • pvc task -> pvc cluster (all subcommands)
  • pvc maintenance -> pvc cluster maintenance
  • pvc status -> pvc cluster status

Ensure you have updated to the latest version of the PVC Ansible repository before deploying this version or using PVC Ansible oneshot playbooks for management.

Breaking Change [CLI]: The --restart option for VM configuration changes now has an explicit --no-restart to disable restarting, or a prompt if neither is specified; --unsafe no longer bypasses this prompt which was a bug. Applies to most vm <cmd> set commands like vm vcpu set, vm memory set, etc. All instances also feature restart confirmation afterwards, which, if --restart is provided, will prompt for confirmation unless --yes or --unsafe is specified.

Breaking Change [CLI]: The --long option previously on some info commands no longer exists; use -f long/--format long instead.

  • [CLI] Significantly refactors the CLI client code for consistency and cleanliness
  • [CLI] Implements -f/--format options for all list and info commands in a consistent way
  • [CLI] Changes the behaviour of VM modification options with "--restart" to provide a "--no-restart"; defaults to a prompt if neither is specified and ignores the "--unsafe" global entirely
  • [API] Fixes several bugs in the 3-debootstrap.py provisioner example script
  • [Node] Fixes some bugs around VM shutdown on node flush
  • [Documentation] Adds mentions of Ganeti and Harvester
  • Mentions Ganeti in the docs
  • Increases API timeout back to 2s
  • Adds .update-* configs to dpkg plugin
  • Adds full/nearfull OSD warnings
  • Improves size value handling for volumes
  • [all] Adds an enhanced health checking, monitoring, and reporting system for nodes and clusters
  • [cli] Adds a cluster detail command
  • [provisioner] Fixes a bug in network comparison
  • [api] Fixes a bug being unable to rename disabled VMs
  • [Provisioner] Cleans up several remaining bugs in the example scripts; they should all be valid now
  • [Provisioner] Adjust default libvirt schema to disable RBD caching for a 2x+ performance boost
  • [API] Flips the mem(prov) and mem(free) selectors making mem(free) the default for "mem" and "memprov" explicit
  • [API] Fixes a bug where migration selector could have case-sensitive operational faults
  • [CLI] Removes an invalid reference to VXLAN
  • [CLI] Improves the handling of invalid networks in VM lists and on attach
  • [API] Modularizes the benchmarking library so it can be used externally too
  • [Daemon Library] Adds a module tag file so it can be used externally too

Breaking Change: Existing provisioner scripts are no longer valid; new example scripts are provided. Breaking Change: OVA profiles now require an ova or default_ova provisioner script (use example) to function.

  • [API/Provisioner] Fundamentally revamps the provisioner script framework to provide more extensibility
  • [API/Provisioner] Adds example provisioner scripts for noop, ova, debootstrap, rinse, and pfsense
  • [API/Provisioner] Enforces the use of the ova provisioner script during new OVA uploads; existing uploads will not work
  • [Documentation] Updates the documentation around provisioner scripts and OVAs to reflect the above changes
  • [Node] Adds a new pvcautoready.service oneshot unit to replicate the on-boot-ready functionality of old pvc-flush.service unit
  • Fixes a problem with the literal eval handler in the provisioner (again)
  • Fixes a potential log deadlock in Zookeeper-lost situations when doing keepalives

[CLI Client] Fixes a bad variable reference from the previous change [API Daemon] Enables TLSv1 with an SSLContext object for maximum compatibility

  • [API] Fixes sort order of VM list (for real this time)
  • [CLI] Fixes a bug with vm modify not requiring a cluster
  • [Docs] Adds a reference to the bootstrap daemon
  • [API] Adds sorting to node and VM lists for consistency
  • [Node Daemon/API] Adds kb_ stats values for OSD stats
  • [CLI Client] Fixes a faulty literal_eval when viewing task status
  • [CLI Client] Adds a confirmation flag to the vm disable command
  • [Node Daemon] Removes the pvc-flush service
  • [Node Daemon/API/CLI] Adds free memory node selector
  • [Node Daemon] Fixes bug sending space-containing detect disk strings
  • [Node Daemon] Fixes bugs with OSD stat population on creation
  • [Node Daemon/API] Adds additional information to Zookeeper about OSDs
  • [Node Daemon] Refactors OSD removal for improved safety
  • [Node Daemon/API/CLI] Adds explicit support for replacing and refreshing (reimporting) OSDs
  • [API/CLI] Fixes a language inconsistency about "router mode"
  • [CLI] Fixes situation where only a single cluster is available
  • [CLI/API/Daemon] Allows forcing of OSD removal ignoring errors
  • [CLI] Fixes bug where down OSDs are not displayed
  • [Node Daemon/API/CLI] Adds Ceph pool device class/tier support
  • [API] Fixes a bug returning values if a Ceph pool has not yet reported stats
  • [API/CLI] Adds PGs count to the pool list output
  • [API/CLI] Adds Ceph pool PGs count adjustment support
  • [API] Fixes bugs with legacy benchmark display
  • [API] Fixes a bug around cloned image sizes
  • [API] Removes extraneous message text in provisioner create command
  • [API] Corrects bugs around fuzzy matching
  • [CLI] Adds auditing for PVC CLI to local syslog
  • [CLI] Adds --yes bypass for benchmark command
  • [Node Daemon/API/CLI] Adds support for "detect" strings when specifying OSD or OSDDB devices
  • [Node Daemon] Fixes a bug when removing OSDs
  • [Node Daemon] Fixes a single-node cluster shutdown deadlock
  • [Node Daemon] Fixes an ordering issue with pvcnoded.service
  • [CLI Client] Fixes bad calls to echo() without argument
  • [Node Daemon] Adds a Munin plugin for Ceph utilization
  • [CLI] Fixes timeouts for long-running API commands
  • [CLI] Fixes timeout issues with long-running API commands
  • [Packaging] Fixes a bad test in postinst
  • [CLI] Adds support for removing VM interfaces by MAC address
  • [CLI] Modifies the default restart + live behaviour to prefer the explicit restart
  • [CLI] Adds support for adding additional VM interfaces in the same network
  • [CLI] Various ordering and message fixes
  • [Node Daemon] Adds additional delays and retries to fencing actions
  • [All] Adds Black formatting for Python code and various script/hook cleanups
  • [CLI/API] Adds automatic shutdown or stop when disabling a VM
  • [CLI] Adds support for forcing colourized output
  • [Docs] Remove obsolete Ansible and Testing manuals
  • [Documentation] Reworks and updates various documentation sections
  • [Node Daemon] Adjusts the fencing process to use a power off rather than a power reset for maximum certainty
  • [Node Daemon] Ensures that MTU values are validated during the first read too
  • [Node Daemon] Corrects the loading of the bridge_mtu value to use the current active setting rather than a fixed default to prevent unintended surprises
  • Fixes a bad conditional check in IPMI verification
  • Implements per-network MTU configuration; NOTE: Requires new keys in pvcnoded.yaml (bridge_mtu) and Ansible group_vars (pvc_bridge_mtu)
  • [Docs] Documentation updates for new Changelog file
  • [Node Daemon] Fixes bug with schema updates
  • [Documentation] Update several documentation sections
  • [API Daemon/CLI Client] Add negate flag for VM option limits (node, tag, state)
  • [Build] Add linting check to build-and-deploy.sh
  • [All] Significantly improve storage benchmark format and reporting
  • [All] Adds support for configurable OSD DB size ratios
  • [Node Daemon] Fixes bugs with OSD creation
  • [Node Daemon] Fixes exception bugs in CephInstance
  • [CLI Client] Adjusts descriptions around Ceph OSDs
  • [Node Daemon] Fixes ordering of pvc-flush unit
  • [Node Daemon] Fixes bugs in fence handling and libvirt keepalive
  • [Node Daemon] Simplifies locking for and speeds up VM migrations
  • [Node Daemon] Fixes bugs in queue get timeouts
  • [API Daemon] Adjusts benchmark test jobs configuration and naming
  • [Node Daemon] Fixes a bug during early cleanup
  • [All] Adds support for OSD database/WAL block devices to improve Ceph performance; NOTE: Applies only to new OSDs
  • [Node Daemon] Fixes several bugs and crashes in node daemon
  • [General] Updates linting rules for newer Flake8 linter
  • [Daemons/CLI client] Adds VM network and disk hot attach/detach support; NOTE: Changes the default behaviour of pvc vm network add/remove and pvc vm volume add/remove
  • [API Daemon] Adds checks for pool size when resizing volumes
  • [API Daemon] Adds checks for RAM and vCPU sizes when defining or modifying VMs
  • [Provisioner] Adds support for filesystem arguments containing =
  • [CLI Client] Fixes bug with pvc provisioner status output formatting
  • [Node Daemon] Fixes minor typo in startup message
  • [Node Daemon] A major refactoring of the node daemon
  • [CLI Client] Fixes output errors if a node has no provisioner data
  • [Packages] Fixes issues with including pycache directories in .deb files
  • [CLI Client] Fixes some incorrect colours in network lists
  • [Documentation] Adds documentation screenshots of CLI client
  • [Node Daemon] Fixes a bug if VM stats gathering fails
  • [Packages] Cleans up obsolete Suggests lines
  • [Node Daemon] Adjusts log text of VM migrations to show the correct source node
  • [API Daemon] Adjusts the OVA importer to support floppy RASD types for compatability
  • [API Daemon] Ensures that volume resize commands without a suffix get B appended
  • [API Daemon] Removes the explicit setting of image-features in PVC; defaulting to the limited set has been moved to the ceph.conf configuration on nodes via PVC Ansible
  • [Node Daemon] Fixes bug with schema validation
  • [Node Daemon] Corrects numerous bugs with node logging framework
  • [CLI Client] Revamp confirmation options for "vm modify" command
  • [CLI Client] Fixes a bug with vm modify command when passed a file
  • [Node Daemon] Corrects some bad assumptions about fencing results during hardware failures
  • [All] Implements VM tagging functionality
  • [All] Implements Node log access via PVC functionality
  • [Node Daemon] Returns to Rados library calls for Ceph due to performance problems
  • [Node Daemon] Adds a date output to keepalive messages
  • [Daemons] Configures ZK connection logging only for persistent connections
  • [API Provisioner] Add context manager-based chroot to Debootstrap example script
  • [Node Daemon] Fixes a bug where shutdown daemon state was overwritten
  • [Node Daemon] Removes Rados module polling of Ceph cluster and returns to command-based polling for timeout purposes, and removes some flaky return statements
  • [Node Daemon] Removes flaky Zookeeper connection renewals that caused problems
  • [CLI Client] Allow raw lists of clusters from pvc cluster list
  • [API Daemon] Fixes several issues when getting VM data without stats
  • [API Daemon] Fixes issues with removing VMs while disks are still in use (failed provisioning, etc.)
  • [Daemons] Fixes a critical overwriting bug in zkhandler when schema paths are not yet valid
  • [Node Daemon] Ensures the daemon mode is updated on every startup (fixes the side effect of the above bug in 0.9.22)
  • [API Daemon] Drastically improves performance when getting large lists (e.g. VMs)
  • [Daemons] Adds profiler functions for use in debug mode
  • [Daemons] Improves reliability of ZK locking
  • [Daemons] Adds the new logo in ASCII form to the Daemon startup message
  • [Node Daemon] Fixes bug where VMs would sometimes not stop
  • [Node Daemon] Code cleanups in various classes
  • [Node Daemon] Fixes a bug when reading node schema data
  • [All] Adds node PVC version information to the list output
  • [CLI Client] Improves the style and formatting of list output including a new header line
  • [API Worker] Fixes a bug that prevented the storage benchmark job from running
  • [API Daemon] Ensures VMs stop before removing them
  • [Node Daemon] Fixes a bug with VM shutdowns not timing out
  • [Documentation] Adds information about georedundancy caveats
  • [All] Adds support for SR-IOV NICs (hostdev and macvtap) and surrounding documentation
  • [Node Daemon] Fixes a bug where shutdown aborted migrations unexpectedly
  • [Node Daemon] Fixes a bug where the migration method was not updated realtime
  • [Node Daemon] Adjusts the Patroni commands to remove reference to Zookeeper path
  • [CLI Client] Adjusts several help messages and fixes some typos
  • [CLI Client] Converts the CLI client to a proper Python module
  • [API Daemon] Improves VM list performance
  • [API Daemon] Adjusts VM list matching critera (only matches against the UUID if it's a full UUID)
  • [API Worker] Fixes incompatibility between Deb 10 and 11 in launching Celery worker
  • [API Daemon] Corrects several bugs with initialization command
  • [Documentation] Adds a shiny new logo and revamps introduction text
  • [Daemons] Implemented a Zookeeper schema handler and version 0 schema
  • [Daemons] Completes major refactoring of codebase to make use of the schema handler
  • [Daemons] Adds support for dynamic chema changges and "hot reloading" of pvcnoded processes
  • [Daemons] Adds a functional testing script for verifying operation against a test cluster
  • [Daemons, CLI] Fixes several minor bugs found by the above script
  • [Daemons, CLI] Add support for Debian 11 "Bullseye"
  • [CLI] Corrects some flawed conditionals
  • [API] Disables SQLAlchemy modification tracking functionality (not used by us)
  • [Daemons] Implements new zkhandler module for improved reliability and reusability
  • [Daemons] Refactors some code to use new zkhandler module
  • [API, CLI] Adds support for "none" migration selector (uses cluster default instead)
  • [Daemons] Moves some configuration keys to new /config tree
  • [Node Daemon] Increases initial lock timeout for VM migrations to avoid out-of-sync potential
  • [Provisioner] Support storing and using textual cluster network labels ("upstream", "storage", "cluster") in templates
  • [API] Avoid duplicating existing node states
  • Adds VM rename functionality to API and CLI client
  • [CLI] Fixes bugs in log follow output
  • Improves some CLI help messages
  • Skips empty local cluster in CLI
  • Adjusts how confirmations happen during VM modify restarts
  • Fixes bug around corrupted VM log files
  • Fixes bug around subprocess pipe exceptions
  • [CLI] Adds additional verification (--yes) to several VM management commands
  • [CLI] Adds a method to override --yes/confirmation requirements via envvar (PVC_UNSAFE)
  • [CLI] Adds description fields to PVC clusters in CLI
  • Fixes bugs around cloned volume provisioning
  • Fixes some minor visual bugs
  • Minor license update (from GPL3+ to GPL3)
  • Adds qemu-guest-agent support to provisioner-created VMs by default
  • Adds nicer startup messages for daemons
  • Adds additional API field for stored_bytes to pool stats
  • Fixes sorting issues with snapshot lists
  • Fixes missing increment/decrement of snapshot_count on volumes
  • Fixes bad calls in pool element API endpoints
  • Fixes inconsistent bytes_tohuman behaviour in daemons
  • Adds validation and maximum volume size on creation (must be smaller than the pool free space)
  • Fixes a bug in the pvcnoded service unit file causing a Zookeeper startup race condition
  • Documentation updates
  • Adds VNC information to VM info
  • Goes back to external Ceph commands for disk usage
  • Moves OSD stats uploading to primary, eliminating reporting failures while hosts are down
  • Documentation updates
  • Significantly improves RBD locking behaviour in several situations, eliminating cold-cluster start issues and failed VM boot-ups after crashes
  • Fixes some timeout delays with fencing
  • Fixes bug in validating YAML provisioner userdata
  • Adds documentation updates
  • Removes single-element list stripping and fixes surrounding bugs
  • Adds additional fields to some API endpoints for ease of parsing by clients
  • Fixes bugs with network configuration
  • Adds support for cluster backup/restore
  • Moves location of init command in CLI to make room for the above
  • Cleans up some invalid help messages from the API
  • Fixes bug with provisioner system template modifications
  • Fixes bug with migrations
  • Fixes bug with line count in log follow
  • Fixes bug with disk stat output being None
  • Adds short pretty health output
  • Documentation updates
  • Fixes major bug in OVA parser
  • Fixes bugs with image & OVA upload parsing
  • Major linting of the codebase with flake8; adds linting tools
  • Implements CLI-based modification of VM vCPUs, memory, networks, and disks without directly editing XML
  • Fixes bug where pvc vm log -f would show all 1000 lines before starting
  • Fixes bug in default provisioner libvirt schema (drive -> driver typo)
  • Added per-VM migration method feature
  • Fixed bug with provisioner system template listing

Numerous small improvements and bugfixes. This release is suitable for general use and is pre-release-quality software.

This release introduces an updated version scheme; all future stable releases until 1.0.0 is ready will be made under this 0.9.z naming. This does not represent semantic versioning and all changes (feature, improvement, or bugfix) will be considered for inclusion in this release train.

Numerous improvements and bugfixes. This release is suitable for general use and is pre-release-quality software.

Numerous improvements and bugfixes, revamped documentation. This release is suitable for general use and is beta-quality software.

Numerous improvements and bugfixes, full implementation of the provisioner, full implementation of the API CLI client (versus direct CLI client). This release is suitable for general use and is beta-quality software.

First public release; fully implements the VM, network, and storage managers, the HTTP API, and the pvc-ansible framework for deploying and bootstrapping a cluster. This release is suitable for general use, though it is still alpha-quality software and should be expected to change significantly until 1.0 is released.

Full implementation of virtual management and virtual networking functionality. Partial implementation of storage functionality.

Basic implementation of virtual management functionality.