2016-01-05 12:44:24 +03:00
Introduction
============
{pve} is a platform to run virtual machines and containers. It is
based on Debian Linux, and completely open source. For maximum
flexibility, we implemented two virtualization technologies -
Kernel-based Virtual Machine (KVM) and container-based virtualization
(LXC).
One main design goal was to make administration as easy as
possible. You can use {pve} on a single node, or assemble a cluster of
2016-09-27 12:36:52 +03:00
many nodes. All management tasks can be done using our web-based
2016-01-05 12:44:24 +03:00
management interface, and even a novice user can setup and install
{pve} within minutes.
image::images/pve-software-stack.svg["Proxmox Software Stack",align="center"]
2022-12-06 18:46:32 +03:00
[[intro_central_management]]
2016-01-05 12:44:24 +03:00
Central Management
------------------
While many people start with a single node, {pve} can scale out to a
large set of clustered nodes. The cluster stack is fully integrated
and ships with the default installation.
2016-09-27 11:58:51 +03:00
Unique Multi-Master Design::
2016-01-05 12:44:24 +03:00
The integrated web-based management interface gives you a clean
overview of all your KVM guests and Linux containers and even of your
whole cluster. You can easily manage your VMs and containers, storage
or cluster from the GUI. There is no need to install a separate,
2016-09-27 11:58:51 +03:00
complex, and pricey management server.
2016-01-05 12:44:24 +03:00
2016-01-06 19:27:16 +03:00
Proxmox Cluster File System (pmxcfs)::
2016-01-05 12:44:24 +03:00
2020-04-23 21:25:05 +03:00
{pve} uses the unique Proxmox Cluster file system (pmxcfs), a
2016-01-05 12:44:24 +03:00
database-driven file system for storing configuration files. This
enables you to store the configuration of thousands of virtual
machines. By using corosync, these files are replicated in real time
on all cluster nodes. The file system stores all data inside a
persistent database on disk, nonetheless, a copy of the data resides
2019-06-12 16:06:32 +03:00
in RAM which provides a maximum storage size of 30MB - more than
2016-01-05 12:44:24 +03:00
enough for thousands of VMs.
2016-01-06 19:27:16 +03:00
+
2020-04-23 21:25:05 +03:00
{pve} is the only virtualization platform using this unique
2016-01-05 12:44:24 +03:00
cluster file system.
2016-01-06 19:27:16 +03:00
Web-based Management Interface::
2016-01-05 12:44:24 +03:00
2020-04-23 21:25:05 +03:00
{pve} is simple to use. Management tasks can be done via the
2016-09-27 11:58:51 +03:00
included web based management interface - there is no need to install a
2016-01-05 12:44:24 +03:00
separate management tool or any additional management node with huge
databases. The multi-master tool allows you to manage your whole
cluster from any node of your cluster. The central web-based
management - based on the JavaScript Framework (ExtJS) - empowers
you to control all functionalities from the GUI and overview history
and syslogs of each single node. This includes running backup or
restore jobs, live-migration or HA triggered activities.
2016-01-06 19:27:16 +03:00
Command Line::
2016-01-05 12:44:24 +03:00
For advanced users who are used to the comfort of the Unix shell or
2023-07-03 15:04:34 +03:00
Windows Powershell, {pve} provides a command-line interface to
manage all the components of your virtual environment. This command-line
interface has intelligent tab completion and full documentation
2016-01-05 12:44:24 +03:00
in the form of UNIX man pages.
2016-01-06 19:27:16 +03:00
REST API::
2016-01-05 12:44:24 +03:00
2020-04-23 21:25:05 +03:00
{pve} uses a RESTful API. We choose JSON as primary data format,
2016-01-05 12:44:24 +03:00
and the whole API is formally defined using JSON Schema. This enables
fast and easy integration for third party management tools like custom
hosting environments.
2016-01-06 19:27:16 +03:00
Role-based Administration::
2016-01-05 12:44:24 +03:00
2016-09-27 11:58:51 +03:00
You can define granular access for all objects (like VMs, storages,
2016-01-05 12:44:24 +03:00
nodes, etc.) by using the role based user- and permission
management. This allows you to define privileges and helps you to
control access to objects. This concept is also known as access
control lists: Each permission specifies a subject (a user or group)
and a role (set of privileges) on a specific path.
2016-01-06 19:27:16 +03:00
Authentication Realms::
2016-01-05 12:44:24 +03:00
2020-04-23 21:25:05 +03:00
{pve} supports multiple authentication sources like Microsoft
2016-01-05 12:44:24 +03:00
Active Directory, LDAP, Linux PAM standard authentication or the
2020-04-23 21:25:05 +03:00
built-in {pve} authentication server.
2016-01-05 12:44:24 +03:00
2016-09-27 11:58:51 +03:00
Flexible Storage
2016-01-05 12:44:24 +03:00
----------------
2020-04-23 21:25:05 +03:00
The {pve} storage model is very flexible. Virtual machine images
2016-01-05 12:44:24 +03:00
can either be stored on one or several local storages or on shared
storage like NFS and on SAN. There are no limits, you may configure as
many storage definitions as you like. You can use all storage
technologies available for Debian Linux.
One major benefit of storing VMs on shared storage is the ability to
live-migrate running machines without any downtime, as all nodes in
the cluster have direct access to VM disk images.
We currently support the following Network storage types:
* LVM Group (network backing with iSCSI targets)
* iSCSI target
* NFS Share
2018-04-05 15:08:24 +03:00
* CIFS Share
2016-01-05 12:44:24 +03:00
* Ceph RBD
* Directly use iSCSI LUNs
* GlusterFS
Local storage types supported are:
* LVM Group (local backing devices like block devices, FC devices, DRBD, etc.)
* Directory (storage on existing filesystem)
* ZFS
2016-09-27 11:58:51 +03:00
2016-01-05 12:44:24 +03:00
Integrated Backup and Restore
-----------------------------
2016-09-27 11:58:50 +03:00
The integrated backup tool (`vzdump`) creates consistent snapshots of
2016-01-05 12:44:24 +03:00
running Containers and KVM guests. It basically creates an archive of
the VM or CT data which includes the VM/CT configuration files.
KVM live backup works for all storage types including VM images on
2019-03-15 16:03:16 +03:00
NFS, CIFS, iSCSI LUN, Ceph RBD. The new backup format is optimized for storing
VM backups fast and effective (sparse files, out of order data, minimized I/O).
2016-01-05 12:44:24 +03:00
2016-09-27 11:58:51 +03:00
2016-01-05 12:44:24 +03:00
High Availability Cluster
-------------------------
2020-04-23 21:25:05 +03:00
A multi-node {pve} HA Cluster enables the definition of highly
available virtual servers. The {pve} HA Cluster is based on
2016-01-05 12:44:24 +03:00
proven Linux HA technologies, providing stable and reliable HA
services.
2016-09-27 11:58:51 +03:00
2016-01-05 12:44:24 +03:00
Flexible Networking
-------------------
2020-04-23 21:25:05 +03:00
{pve} uses a bridged networking model. All VMs can share one
2016-01-05 12:44:24 +03:00
bridge as if virtual network cables from each guest were all plugged
into the same switch. For connecting VMs to the outside world, bridges
2019-06-12 16:06:32 +03:00
are attached to physical network cards and assigned a TCP/IP
2016-01-05 12:44:24 +03:00
configuration.
For further flexibility, VLANs (IEEE 802.1q) and network
bonding/aggregation are possible. In this way it is possible to build
2020-04-23 21:25:05 +03:00
complex, flexible virtual networks for the {pve} hosts,
2016-01-05 12:44:24 +03:00
leveraging the full power of the Linux network stack.
2016-09-27 11:58:50 +03:00
2016-01-05 12:44:24 +03:00
Integrated Firewall
-------------------
2016-09-27 11:58:51 +03:00
The integrated firewall allows you to filter network packets on
2016-09-27 11:58:50 +03:00
any VM or Container interface. Common sets of firewall rules can
be grouped into ``security groups''.
2019-04-18 12:49:57 +03:00
include::hyper-converged-infrastructure.adoc[]
2016-01-05 12:44:24 +03:00
Why Open Source
---------------
2020-04-23 21:25:05 +03:00
{pve} uses a Linux kernel and is based on the Debian GNU/Linux
Distribution. The source code of {pve} is released under the
2021-04-29 14:59:42 +03:00
https://www.gnu.org/licenses/agpl-3.0.html[GNU Affero General Public
2016-01-05 12:44:24 +03:00
License, version 3]. This means that you are free to inspect the
source code at any time or contribute to the project yourself.
At Proxmox we are committed to use open source software whenever
possible. Using open source software guarantees full access to all
functionalities - as well as high security and reliability. We think
that everybody should have the right to access the source code of a
software to run it, build on it, or submit changes back to the
project. Everybody is encouraged to contribute while Proxmox ensures
the product always meets professional quality criteria.
Open source software also helps to keep your costs low and makes your
core infrastructure independent from a single vendor.
2016-09-27 11:58:51 +03:00
2019-06-12 16:06:32 +03:00
Your benefits with {pve}
2019-06-14 11:19:03 +03:00
------------------------
2016-01-05 12:44:24 +03:00
* Open source software
* No vendor lock-in
* Linux kernel
* Fast installation and easy-to-use
* Web-based management interface
* REST API
* Huge active community
* Low administration costs and simple deployment
2016-10-03 14:45:39 +03:00
include::getting-help.adoc[]
2016-09-27 11:58:51 +03:00
2022-12-06 18:46:32 +03:00
[[intro_project_history]]
2016-01-05 12:44:24 +03:00
Project History
---------------
The project started in 2007, followed by a first stable version in
2016-09-27 11:58:51 +03:00
2008. At the time we used OpenVZ for containers, and KVM for virtual
2016-01-05 12:44:24 +03:00
machines. The clustering features were limited, and the user interface
was simple (server generated web page).
But we quickly developed new features using the
2021-04-29 14:59:42 +03:00
https://corosync.github.io/corosync/[Corosync] cluster stack, and the
2016-01-05 12:44:24 +03:00
introduction of the new Proxmox cluster file system (pmxcfs) was a big
step forward, because it completely hides the cluster complexity from
the user. Managing a cluster of 16 nodes is as simple as managing a
single node.
We also introduced a new REST API, with a complete declarative
2016-09-27 11:58:51 +03:00
specification written in JSON-Schema. This enabled other people to
integrate {pve} into their infrastructure, and made it easy to provide
2016-01-05 12:44:24 +03:00
additional services.
Also, the new REST API made it possible to replace the original user
interface with a modern HTML5 application using JavaScript. We also
replaced the old Java based VNC console code with
https://kanaka.github.io/noVNC/[noVNC]. So you only need a web browser
to manage your VMs.
The support for various storage types is another big task. Notably,
{pve} was the first distribution to ship ZFS on Linux by default in
2014. Another milestone was the ability to run and manage
2021-04-29 14:59:42 +03:00
https://ceph.com/[Ceph] storage on the hypervisor nodes. Such setups
2016-01-05 12:44:24 +03:00
are extremely cost effective.
When we started we were among the first companies providing
commercial support for KVM. The KVM project itself continuously
2016-09-27 11:58:51 +03:00
evolved, and is now a widely used hypervisor. New features arrive
2016-01-05 12:44:24 +03:00
with each release. We developed the KVM live backup feature, which
makes it possible to create snapshot backups on any storage type.
The most notable change with version 4.0 was the move from OpenVZ to
https://linuxcontainers.org/[LXC]. Containers are now deeply
integrated, and they can use the same storage and network features
as virtual machines.
2016-10-03 14:45:40 +03:00
2016-10-18 09:18:05 +03:00
include::howto-improve-pve-docs.adoc[]
2019-05-29 12:36:52 +03:00
include::translation.adoc[]
2016-10-18 09:18:05 +03:00