Access file system on ESXi host from guest virtual machine

I'm researching if it is feasible to backup ESXi host by running rdiff-backup inside guest operating system on that host.

Is there a way for guest virtual machine to gain access to the host OS file system? If there is more than one way, which one would yield the best throughput?

EDIT: I would imagine, ideal would be to use the same interfaces as the console VM is using, if those are available for a guest OS


Solution 1:

Depending on what you mean by accessing the Host OS filesystem there are some mechanisms available but they all require you to use either VMware's own Management Tools (either the VI Client or the Perl\Powershell Remote CLI's) or third party tools that make use of the same remote management API's.

In all cases with ESXi AFAIK you are going to be connecting via some securely authenticated network protocol (e.g. WS-MAN, SCP) and you will need to authenticate with the appropriate credentials for root access to the Host in order to connect.

You can for example use the standard VI client to connect from a VM back to the ESXi Host that it is running on. Once connected you can open the DataStore Browser and explore the VMFS Datastores, copy\cut and paste files in and out if you like. VeemFastSCP provides for SCP connectivity from Windows clients to ESXi ( or even directly between ESXi Hosts) and it will happily run in a Guest VM while connecting to the Host it's running on.

Directly drilling up through the Hypervisor isn't possible to the best of my knowledge although in theory the VMWare Tools drivers could provide extensive interaction between the Hypervisor and the Guests if VMware wanted them to. That would be a major security problem though so I can't see that being very likely.

Apart from the ESXi Datastores there's not much else involved as far as the ESXi filesystem is concerned - it's designed as an embedded hypervisor so its footprint is pretty small and VMware do not support anyone messing about inside it (even though it is possible to get there).

Solution 2:

I would think that guest OSes being able to directly access the filesystem of the host is a huge security risk. As such, I doubt you're going to be able to do it. However, you can access the host filesystem the same way you would from any external computer such as using FTP, SFTP, etc.