Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/canonical/lxd
Powerful system container and virtual machine manager
https://github.com/canonical/lxd
containers criu go hacktoberfest lxc lxd
Last synced: 5 days ago
JSON representation
Powerful system container and virtual machine manager
- Host: GitHub
- URL: https://github.com/canonical/lxd
- Owner: canonical
- License: agpl-3.0
- Created: 2014-11-04T22:40:52.000Z (about 10 years ago)
- Default Branch: main
- Last Pushed: 2024-10-29T11:46:55.000Z (3 months ago)
- Last Synced: 2024-10-29T13:29:19.531Z (3 months ago)
- Topics: containers, criu, go, hacktoberfest, lxc, lxd
- Language: Go
- Homepage: https://canonical.com/lxd
- Size: 145 MB
- Stars: 4,366
- Watchers: 159
- Forks: 932
- Open Issues: 269
-
Metadata Files:
- Readme: README.md
- Contributing: CONTRIBUTING.md
- License: COPYING
- Code of conduct: CODE_OF_CONDUCT.md
- Security: SECURITY.md
- Support: .github/SUPPORT.md
- Authors: AUTHORS
Awesome Lists containing this project
- awesome-repositories - canonical/lxd - Powerful system container and virtual machine manager (Go)
- awesome-starred - canonical/lxd - Powerful system container and virtual machine manager (hacktoberfest)
- awesome - canonical/lxd - Powerful system container and virtual machine manager (Go)
- awesome - canonical/lxd - Powerful system container and virtual machine manager (Go)
README
# LXD
LXD is a modern, secure and powerful system container and virtual machine manager.
It provides a unified experience for running and managing full Linux systems inside containers or virtual machines. LXD supports images for a large number of Linux distributions (official Ubuntu images and images provided by the community) and is built around a very powerful, yet pretty simple, REST API. LXD scales from one instance on a single machine to a cluster in a full data center rack, making it suitable for running workloads both for development and in production.
LXD allows you to easily set up a system that feels like a small private cloud. You can run any type of workload in an efficient way while keeping your resources optimized.
You should consider using LXD if you want to containerize different environments or run virtual machines, or in general run and manage your infrastructure in a cost-effective way.
## Get started
See [Getting started](https://documentation.ubuntu.com/lxd/en/latest/getting_started/) in the LXD documentation for installation instructions and first steps.
- Release announcements: [`https://discourse.ubuntu.com/c/lxd/news/`](https://discourse.ubuntu.com/c/lxd/news/143)
- Release tarballs: [`https://github.com/canonical/lxd/releases/`](https://github.com/canonical/lxd/releases/)
- Documentation: [`https://documentation.ubuntu.com/lxd/en/latest/`](https://documentation.ubuntu.com/lxd/en/latest/)## Status
Type | Service | Status
--- | --- | ---
Tests | GitHub | [![Build Status](https://github.com/canonical/lxd/actions/workflows/tests.yml/badge.svg?branch=main)](https://github.com/canonical/lxd/actions?query=event%3Apush+branch%3Amain)
Go documentation | Godoc | [![GoDoc](https://godoc.org/github.com/canonical/lxd/client?status.svg)](https://godoc.org/github.com/canonical/lxd/client)
Static analysis | GoReport | [![Go Report Card](https://goreportcard.com/badge/github.com/canonical/lxd)](https://goreportcard.com/report/github.com/canonical/lxd)
Translations | Weblate | [![Translation status](https://hosted.weblate.org/widget/lxd/lxd/svg-badge.svg)](https://hosted.weblate.org/projects/lxd/lxd/)## Installing LXD from packages
The LXD daemon only works on Linux but the client tool (`lxc`) is available on most platforms.
OS | Format | Command
--- | --- | ---
Linux | [Snap](https://snapcraft.io/lxd) | `snap install lxd`
Windows | [Chocolatey](https://chocolatey.org/packages/lxc) | `choco install lxc`
macOS | [Homebrew](https://formulae.brew.sh/formula/lxc) | `brew install lxc`The LXD snap packaging repository is available [here](https://github.com/canonical/lxd-pkg-snap).
For more instructions on installing LXD for a wide variety of Linux distributions and operating systems, and to install LXD from source, see [How to install LXD](https://documentation.ubuntu.com/lxd/en/latest/installing/) in the documentation.
## Client SDK packages
The LXD project provides SDK client packages for interacting with LXD servers from your own software.
These SDKs are licensed as Apache-2.0.
Language | URL
--- | ---
Go | https://pkg.go.dev/github.com/canonical/lxd/client
Python | https://github.com/canonical/pylxdFor more information on using the LXD API, see [REST API](https://documentation.ubuntu.com/lxd/en/latest/restapi_landing/) in the documentation.
## Tools for managing LXD
If you are looking for tools (beyond `lxc` CLI) to manage LXD at scale (from single server to wide clusters), the following projects can be useful:
Tool | Link
--- | ---
Ansible - connection plugin | https://galaxy.ansible.com/ui/repo/published/community/general/content/connection/lxd/
Ansible - inventory plugin | https://galaxy.ansible.com/ui/repo/published/community/general/content/inventory/lxd/
Bolt - LXD transport | https://www.puppet.com/docs/bolt/latest/bolt_transports_reference.html#lxd
MicroCloud | https://canonical.com/microcloud
Packer - LXD builder | https://developer.hashicorp.com/packer/integrations/hashicorp/lxd/latest/components/builder/lxd
Terraform provider | https://registry.terraform.io/providers/terraform-lxd/lxd## Security
Consider the following aspects to ensure that your LXD installation is secure:
- Keep your operating system up-to-date and install all available security patches.
- Use only supported LXD versions (LTS releases or the latest feature release).
- Restrict access to the LXD daemon and the remote API.
- Configure your network interfaces to be secure.
- Do not use privileged containers unless required. If you use privileged containers, put appropriate security measures in place.
See [Container security](https://documentation.ubuntu.com/lxd/en/latest/explanation/security/#container-security) for more information.See [Security](https://documentation.ubuntu.com/lxd/en/latest/explanation/security/) for detailed information.
**IMPORTANT:**
Local access to LXD through the Unix socket always grants full access to LXD.
This includes the ability to attach file system paths or devices to any instance as well as tweak the security features on any instance.Therefore, you should only give such access to users who you'd trust with root access to your system.
## Support and community
The following channels are available for you to interact with the LXD community.
### Bug reports
You can file bug reports and feature requests at: [`https://github.com/canonical/lxd/issues/new`](https://github.com/canonical/lxd/issues/new)
### Forum
A discussion forum is available at: [`https://discourse.ubuntu.com/c/lxd/`](https://discourse.ubuntu.com/c/lxd/126)
### IRC
If you prefer live discussions, you can find us in [`#lxd`](https://web.libera.chat/#lxd) on `irc.libera.chat`. See [Getting started with IRC](https://discourse.ubuntu.com/t/getting-started-with-irc/37907) if needed.
### Commercial support
Commercial support for LXD is available through [Ubuntu Pro](https://ubuntu.com/support) (Ubuntu Pro (Infra-only) or full Ubuntu Pro).
The support covers all LTS versions for five years starting from the day of the release.See the [full service description](https://ubuntu.com/legal/ubuntu-pro-description) for detailed information about what support Ubuntu Pro provides.
## Documentation
The official documentation is available at: [`https://documentation.ubuntu.com/lxd/en/latest/`](https://documentation.ubuntu.com/lxd/en/latest/)
You can find additional resources on the [website](https://canonical.com/lxd), on [YouTube](https://www.youtube.com/channel/UCuP6xPt0WTeZu32CkQPpbvA) and in the [Tutorials section](https://discourse.ubuntu.com/c/lxd/tutorials/146) in the forum.
## Contributing
Fixes and new features are greatly appreciated. Make sure to read our [contributing guidelines](CONTRIBUTING.md) first!