ESXi prerequisites

Make sure you have performed the following prerequisites before you use audit features with ESXi servers.

Refer To the VMware ESXi hardening guides

The basis for the SA ESXi compliance check library is the set of VMware ESXi Hardening Guides, located at: http://www.vmware.com/security/hardening-guides. These guides explain how to deploy and operate VMware products securely. They also include script examples for enabling security automation.

Manage the vCenter

All vSphere ESXi servers are managed through a Windows-based vCenter Server. ESXi servers do not have their own SA agents. The vCenter Server must have an SA agent installed. The vCenter Server must also be integrated with SA Virtualization. To check if your vCenter Server is integrated, make sure it is visible in the server window when you select the Virtualization tab in the SA Client. For more information on virtualization integration, see "Virtualization management" in the SA 10.50 User Guide.

Download powerCLI installer

The PowerCLI Installer is available at the VMware Download site. Download the version that matches your vCenter Server.

Install or upgrade your PowerShell version

PowerCLI requires PowerShell 2.0 and above to run. If you do not have PowerShell installed, first install PowerShell 1.0, then upgrade to PowerShell 2.0 or higher.

To install PowerShell 1.0 on a vCenter server computer:

  1. In a vCenter Server Computer, launch the Server Manager component.
  2. Select Add Feature.
  3. In the Select Features panel, select Windows PowerShell 1.0.
  4. Click Install.

To upgrade PowerShell 1.0 to PowerShell 2.0 or higher:

  1. Use the following command to verify the installed PowerShell version:

    PS > $PSVersionTable.PSVersion

    The version number will be in the Major column of the screen display.

  2. Use Windows Update Manager to download and install PowerShell 2.0.
    Once you download it, the PowerShell2.0 Installer can be seen in the Windows Update application.
  3. To check if it is installed, click Install Updates.

Download and install the Windows Manager Framework

To use PowerShell 3.0, you can use Windows Manager Framework (WMF) 2.0, 3.0. or higher to download the PowerShell 3.0 Installer package.

To download and install Windows Manager Framework:

  1. Uninstall pre-release versions of WMF 3.0, if any.
  2. Close all PowerShell windows.
  3. Download the correct WMF 3.0 package for your operating system and architecture from the Microsoft Download site.

Set the PowerShell execution policy

PowerShell scripts can only run if the PowerShell Execution Policy is set in accordance with your company security policy (either RemoteSigned or Unrestricted).

To set the PowerShell execution policy:

  1. As Windows administrator, log in to the vCenter Server.
  2. Open the PowerShell console.
  3. Run the command.
  4. For example, to set the policy to Unrestricted, use the following command:

    PS > Set-ExecutionPolicy Unrestricted

Set the configuration value for InvalidCertificateAction

By default, the InvalidCertificateAction configuration item value is set to Warn. If the certificates are invalid, a message will be written to the script output, which will cause some compliance code to fail. To address this, fix the certificate issue in accordance with your company's security policy or set the configuration to ignore the invalid certificate.

If you choose to ignore the certificate, execute the following command from each vCenter:

Set-PowerCLIConfiguration -InvalidCertificateAction Ignore -Scope AllUsers 

For more information, see VMware documentation.

Set the configuration value for WebOperationTimeout

By default, the WebOperationTimeout configuration item value is set to 300 (seconds). Some PowerCLI commands may take longer than this to run, depending on the network and server load. The recommendation is to set this value to -1 (infinite). If that value is not feasible, test and adjust as needed.

Set-PowerCLIConfiguration -WebOperationTimeout -1 -Scope AllUsers 

For more information on this configuration item, see VMware documentation.

Run the XML Serializers script

Another preparatory step to run audits on ESXi servers is to execute the XML Serializers script.

To execute the script:

  1. Log in to the SA Client.
  2. In the Library tab, choose to select By Type.
  3. Expand the Scripts node.
  4. Select Windows.
  5. From the list of Windows scripts:
    1. Select the install-powercli-xmlserializers.ps1 script.
    2. Right-click the script and choose Run with PowerShell.
    3. In the Run Server Script window, select all vCenter servers (or add the servers, then select them).
    4. Click Start Job to execute the script on all vCenter servers.

Note To back out the change (that is, to reverse the changes that occurred when you ran the script), run the following script: uninstall-powercli-xmlserializers.ps1.

Disable Check for CertificateRevocation

Each ESXi check (script) runs in its own PowerShell process. We enable PowerCLI by using the Add-PSSnapin command in the scripts. There is a delay, however, of 7 to 9 seconds every time the process is launched, because PowerShell tries to download the Certificate Revocation List from the Internet and verify the digital signatures. To avoid this delay, change the following two registry entries to the indicated values.

Registry Keys Values
HKEY_USERS\.DEFAULT\Software\Microsoft\Windows\CurrentVersion\Internet Settings\CertificateRevocation dword:00000001
HKEY_USERS\.DEFAULT\Software\Microsoft\Windows\CurrentVersion\ WinTrust\Trust Providers\Software Publishing\State dword:00023c00

Note The keys or the path to this registry might change in future versions of Windows.

Tip After setting this up on one vCenter, use SA to take a snapshot (Snapshot Specification), then audit and remediate the change to other vCenters.

When users run commands against ESXi servers in the SA Client, the client searches the ESXi server device records, and routes an appropriate command to the SA Agent on the vCenter that manages that ESXi server. The SA Agent routes the command to the PowerCLI plugin on the PowerShell. The PowerCLI plugin then executes the command on the ESXi server.