VMware.CloudFoundation.Reporting
is a PowerShell module that has been written to support the ability to provide insight to the operational state of VMware Cloud Foundation through the use of PowerShell cmdlets. These cmdlets provide quick access to information from the PowerShell console as well as the ability to publish pre-defined HTML reports.
- VMware Cloud Foundation 4.2.1 or later
- vSAN ReadyNodes
- DellEMC VxRail
- Microsoft Windows Server 2019 and 2022
- Microsoft Windows 10 and 11
- VMware Photon OS 3.0 and 4.0
VMware.PowerCLI
12.7.0 or laterVMware.vSphere.SsoAdmin
1.3.8 or laterPowerVCF
2.2.0 or laterPowerValidatedSolutions
2.0.1 or later
For the best experience, use one of the following browsers to view generated HTML reports.
- Microsoft Edge
- Google Chrome
- Mozilla Firefox
Verify that your system has a supported edition and version of PowerShell installed.
Install the supporting PowerShell modules from the PowerShell Gallery by running the following commands:
Set-PSRepository -Name PSGallery -InstallationPolicy Trusted
Install-Module -Name VMware.PowerCLI -MinimumVersion 12.7.0
Install-Module -Name VMware.vSphere.SsoAdmin -MinimumVersion 1.3.8
Install-Module -Name PowerVCF -MinimumVersion 2.2.0
Install-Module -Name PowerValidatedSolutions -MinimumVersion 2.0.1
Install-Module -Name VMware.CloudFoundation.Reporting
If using PowerShell Core, import the modules before proceeding:
For example:
Import-Module -Name VMware.PowerCLI
Import-Module -Name VMware.vSphere.SsoAdmin
Import-Module -Name PowerVCF
Import-Module -Name PowerValidatedSolutions
Import-Module -Name VMware.CloudFoundation.Reporting
To verify the modules are installed, run the following command in the PowerShell console.
Test-VcfReportingPrereq
Once installed, any cmdlets associated with VMware.CloudFoundation.Reporting
and the supporting PowerShell modules will be available for use.
To view the cmdlets for available in the module, run the following command in the PowerShell console.
Get-Command -Module VMware.CloudFoundation.Reporting
To view the help for any cmdlet, run the Get-Help
command in the PowerShell console.
For example:
Get-Help -Name Invoke-VcfHealthReport
Get-Help -Name Invoke-VcfHealthReport -Examples
Update the PowerShell module from the PowerShell Gallery by running the following commands:
Update-Module -Name VMware.CloudFoundation.Reporting
To verify that the PowerShell module is updated, run the following command in the PowerShell console.
Get-InstalledModule -Name VMware.CloudFoundation.Reporting
To verify that the dependencies meet the minimum requirements, run the following command in the PowerShell console.
Test-VcfReportingPrereq
If a dependency does not meet the minimum requirements, run the appropriate Update-Module
command for the dependency in the PowerShell console.
Update-Module -Name VMware.PowerCLI
Update-Module -Name VMware.vSphere.SsoAdmin
Update-Module -Name PowerVCF
Update-Module -Name PowerValidatedSolutions
Each cmdlet may provide one or more usage examples. Many of the cmdlets require that credentials are provided to output to the PowerShell console or a report.
The cmdlets in this module, and its dependencies, return data from multple platform components. The credentials for most of the platform components are returned to the cmdlets by retrieving credentials from the SDDC Manager inventory and using these credentials, as needed, within cmdlet operations.
For the best expereince, for cmdlets that connect to SDDC Manager, use the VMware Cloud Foundation API user admin@local
or an account with the ADMIN role in SDDC Manager (e.g., [email protected]
).
The PowerShell module provides the ability to generate the following reports:
- Overview Report
- Health Report
- Alert Report
- Password Policy Report
- Configuration Report
- Upgrade Precheck Report
Reports default to a light-mode theme. If you prefer a dark-mode theme, you can use the -darkMode
parameter with each Invoke-Vcf*Report
cmdlets. Each report is self-contained and will retain formatting if the resulting HTML output is shared.
Example:
The Invoke-VcfOverviewReport
cmdlet generates a system overview report. This report contains high-level information about the VMware Cloud Foundation system. This report may be used to provide a quick system overview of the system to your VMware representative.
-
Start PowerShell (Run as Administrator).
-
Replace the values in the sample code with values for the instance of VMware Cloud Foundation to generate a system overview report for SDDC Manager instance and run the commands in the PowerShell console.
Example: Windows
$sddcManagerFqdn = "sfo-vcf01.sfo.rainpole.io" $sddcManagerUser = "admin@local" $sddcManagerPass = "VMw@re1!VMw@re1!" $reportPath = "F:\Reporting"
Example: Linux
$sddcManagerFqdn = "sfo-vcf01.sfo.rainpole.io" $sddcManagerUser = "admin@local" $sddcManagerPass = "VMw@re1!VMw@re1!" $reportPath = "/home/vmware/reporting"
-
Generate the report by running the command in the PowerShell console.
Invoke-VcfOverviewReport -sddcManagerFqdn $sddcManagerFqdn -sddcManagerUser $sddcManagerUser -sddcManagerPass $sddcManagerPass -reportPath $reportPath
If you prefer to anonymize the data, you can use the
-anonymized
parameter.Invoke-VcfOverviewReport -sddcManagerFqdn $sddcManagerFqdn -sddcManagerUser $sddcManagerUser -sddcManagerPass $sddcManagerPass -reportPath $reportPath -anonymized
-
Review the generated HTML report.
The Invoke-VcfHealthReport
cmdlet generates a health report. This report combines the SoS Utility health checks with additional health checks not presently available in the SoS Utility for previous VMware Cloud Foundation releases. The report contains detailed information about the health of the VMware Cloud Foundation system and its components.
-
Start PowerShell (Run as Administrator).
-
Replace the values in the sample code with values for the instance of VMware Cloud Foundation to generate a health report for SDDC Manager instance and run the commands in the PowerShell console.
Example: Windows
$sddcManagerFqdn = "sfo-vcf01.sfo.rainpole.io" $sddcManagerUser = "admin@local" $sddcManagerPass = "VMw@re1!VMw@re1!" $sddcManagerRootPass = "VMw@re1!" $reportPath = "F:\Reporting"
Example: Linux
$sddcManagerFqdn = "sfo-vcf01.sfo.rainpole.io" $sddcManagerUser = "admin@local" $sddcManagerPass = "VMw@re1!VMw@re1!" $sddcManagerRootPass = "VMw@re1!" $reportPath = "/home/vmware/reporting"
-
Generate the report which only displays issues by running the command in the PowerShell console.
Invoke-VcfHealthReport -sddcManagerFqdn $sddcManagerFqdn -sddcManagerUser $sddcManagerUser -sddcManagerPass $sddcManagerPass -sddcManagerRootPass $sddcManagerRootPass -reportPath $reportPath -allDomains -failureOnly
-
Review the generated HTML report and perform remediation of any identified issues.
-
Start PowerShell (Run as Administrator).
-
Replace the values in the sample code with values for the instance of VMware Cloud Foundation to generate a health report for SDDC Manager instance and run the commands in the PowerShell console.
Example: Windows
$sddcManagerFqdn = "sfo-vcf01.sfo.rainpole.io" $sddcManagerUser = "admin@local" $sddcManagerPass = "VMw@re1!VMw@re1!" $sddcManagerRootPass = "VMw@re1!" $workloadDomain = "sfo-w01" $reportPath = "F:\Reporting"
Example: Linux
$sddcManagerFqdn = "sfo-vcf01.sfo.rainpole.io" $sddcManagerUser = "admin@local" $sddcManagerPass = "VMw@re1!VMw@re1!" $sddcManagerRootPass = "VMw@re1!" $workloadDomain = "sfo-w01" $reportPath = "/home/vmware/reporting"
-
Generate the report which only displays issues by running the command in the PowerShell console.
Invoke-VcfHealthReport -sddcManagerFqdn $sddcManagerFqdn -sddcManagerUser $sddcManagerUser -sddcManagerPass $sddcManagerPass -sddcManagerRootPass $sddcManagerRootPass -reportPath $reportPath -workloadDomain $workloadDomain -failureOnly
-
Review the generated HTML report and perform remediation of any identified issues.
-
Start PowerShell (Run as Administrator).
-
Replace the values in the sample code with values for the instance of VMware Cloud Foundation to generate a health report for SDDC Manager instance and run the commands in the PowerShell console.
Example: Windows
$sddcManagerFqdn = "sfo-vcf01.sfo.rainpole.io" $sddcManagerUser = "admin@local" $sddcManagerPass = "VMw@re1!VMw@re1!" $sddcManagerRootPass = "VMw@re1!" $reportPath = "F:\Reporting"
Example: Linux
$sddcManagerFqdn = "sfo-vcf01.sfo.rainpole.io" $sddcManagerUser = "admin@local" $sddcManagerPass = "VMw@re1!VMw@re1!" $sddcManagerRootPass = "VMw@re1!" $reportPath = "/home/vmware/reporting"
-
Generate the report by running the command in the PowerShell console.
Invoke-VcfHealthReport -sddcManagerFqdn $sddcManagerFqdn -sddcManagerUser $sddcManagerUser -sddcManagerPass $sddcManagerPass -sddcManagerRootPass $sddcManagerRootPass -reportPath $reportPath -allDomains
-
Review the generated HTML report and perform remediation of any identified issues.
-
Start PowerShell (Run as Administrator).
-
Replace the values in the sample code with values for the instance of VMware Cloud Foundation to generate a health report for SDDC Manager instance and run the commands in the PowerShell console.
Example: Windows
$sddcManagerFqdn = "sfo-vcf01.sfo.rainpole.io" $sddcManagerUser = "admin@local" $sddcManagerPass = "VMw@re1!VMw@re1!" $sddcManagerRootPass = "VMw@re1!" $workloadDomain = "sfo-w01" $reportPath = "F:\Reporting"
Example: Linux
$sddcManagerFqdn = "sfo-vcf01.sfo.rainpole.io" $sddcManagerUser = "admin@local" $sddcManagerPass = "VMw@re1!VMw@re1!" $sddcManagerRootPass = "VMw@re1!" $workloadDomain = "sfo-w01" $reportPath = "/home/vmware/reporting"
-
Generate the report by running the command in the PowerShell console.
Invoke-VcfHealthReport -sddcManagerFqdn $sddcManagerFqdn -sddcManagerUser $sddcManagerUser -sddcManagerPass $sddcManagerPass -sddcManagerRootPass $sddcManagerRootPass -reportPath $reportPath -workloadDomain $workloadDomain
-
Review the generated HTML report and perform remediation of any identified issues.
The Invoke-VcfSystemAlertReport
cmdlet generates a system alert report. This report collects information about the system alerts that are currently active in the VMware Cloud Foundation system for the platform components. This report reduces the need to login to multiple product interfaces to collect information about the system alerts.
-
Start PowerShell (Run as Administrator).
-
Replace the values in the sample code with values for the instance of VMware Cloud Foundation to generate a system alert report for SDDC Manager instance and run the commands in the PowerShell console.
Example: Windows
$sddcManagerFqdn = "sfo-vcf01.sfo.rainpole.io" $sddcManagerUser = "admin@local" $sddcManagerPass = "VMw@re1!VMw@re1!" $reportPath = "F:\Reporting"
Example: Linux
$sddcManagerFqdn = "sfo-vcf01.sfo.rainpole.io" $sddcManagerUser = "admin@local" $sddcManagerPass = "VMw@re1!VMw@re1!" $reportPath = "/home/vmware/reporting"
-
Generate the report which only displays issues by running the command in the PowerShell console.
Invoke-VcfAlertReport -sddcManagerFqdn $sddcManagerFqdn -sddcManagerUser $sddcManagerUser -sddcManagerPass $sddcManagerPass -reportPath $reportPath -allDomains -failureOnly
-
Review the generated HTML report and perform remediation of any identified issues.
-
Start PowerShell (Run as Administrator).
-
Replace the values in the sample code with values for the instance of VMware Cloud Foundation to generate a system alert report for SDDC Manager instance and run the commands in the PowerShell console.
Example: Windows
$sddcManagerFqdn = "sfo-vcf01.sfo.rainpole.io" $sddcManagerUser = "admin@local" $sddcManagerPass = "VMw@re1!VMw@re1!" $workloadDomain = "sfo-w01" $reportPath = "F:\Reporting"
Example: Linux
$sddcManagerFqdn = "sfo-vcf01.sfo.rainpole.io" $sddcManagerUser = "admin@local" $sddcManagerPass = "VMw@re1!VMw@re1!" $workloadDomain = "sfo-w01" $reportPath = "/home/vmware/reporting"
-
Generate the report which only displays issues by running the command in the PowerShell console.
Invoke-VcfAlertReport -sddcManagerFqdn $sddcManagerFqdn -sddcManagerUser $sddcManagerUser -sddcManagerPass $sddcManagerPass -reportPath $reportPath -workloadDomain $workloadDomain -failureOnly
-
Review the generated HTML report and perform remediation of any identified issues.
-
Start PowerShell (Run as Administrator).
-
Replace the values in the sample code with values for the instance of VMware Cloud Foundation to generate a system alert report for SDDC Manager instance and run the commands in the PowerShell console.
Example: Windowa
$sddcManagerFqdn = "sfo-vcf01.sfo.rainpole.io" $sddcManagerUser = "admin@local" $sddcManagerPass = "VMw@re1!VMw@re1!" $reportPath = "F:\Reporting"
Example: Linux
$sddcManagerFqdn = "sfo-vcf01.sfo.rainpole.io" $sddcManagerUser = "admin@local" $sddcManagerPass = "VMw@re1!VMw@re1!" $reportPath = "/home/vmware/reporting"
-
Generate the report by running the command in the PowerShell console.
Invoke-VcfAlertReport -sddcManagerFqdn $sddcManagerFqdn -sddcManagerUser $sddcManagerUser -sddcManagerPass $sddcManagerPass -reportPath $reportPath -allDomains
-
Review the generated HTML report and perform remediation of any identified issues.
-
Start PowerShell (Run as Administrator).
-
Replace the values in the sample code with values for the instance of VMware Cloud Foundation to generate a system alert report for SDDC Manager instance and run the commands in the PowerShell console.
Example: Windowa
$sddcManagerFqdn = "sfo-vcf01.sfo.rainpole.io" $sddcManagerUser = "admin@local" $sddcManagerPass = "VMw@re1!VMw@re1!" $workloadDomain = "sfo-w01" $reportPath = "F:\Reporting"
Example: Linux
$sddcManagerFqdn = "sfo-vcf01.sfo.rainpole.io" $sddcManagerUser = "admin@local" $sddcManagerPass = "VMw@re1!VMw@re1!" $workloadDomain = "sfo-w01" $reportPath = "/home/vmware/reporting"
-
Generate the report by running the command in the PowerShell console.
Invoke-VcfAlertReport -sddcManagerFqdn $sddcManagerFqdn -sddcManagerUser $sddcManagerUser -sddcManagerPass $sddcManagerPass -reportPath $reportPath -workloadDomain $workloadDomain
-
Review the generated HTML report and perform remediation of any identified issues.
The Invoke-VcfPasswordPolicyReport
cmdlet generates a password policy report. This report collects information about the password policy settings in a VMware Cloud Foundation system for the platform components. This report reduces the need to login to multiple product interfaces and endpoints to collect information about the password policy.
-
Start PowerShell (Run as Administrator).
-
Replace the values in the sample code with values for the instance of VMware Cloud Foundation to generate a password policy report for SDDC Manager instance and run the commands in the PowerShell console.
Example: Windows
$sddcManagerFqdn = "sfo-vcf01.sfo.rainpole.io" $sddcManagerUser = "admin@local" $sddcManagerPass = "VMw@re1!VMw@re1!" $sddcManagerRootPass = "VMw@re1!" $reportPath = "F:\Reporting"
Example: Linux
$sddcManagerFqdn = "sfo-vcf01.sfo.rainpole.io" $sddcManagerUser = "admin@local" $sddcManagerPass = "VMw@re1!VMw@re1!" $sddcManagerRootPass = "VMw@re1!" $reportPath = "/home/vmware/reporting"
-
Generate the report by running the command in the PowerShell console.
Invoke-VcfPasswordPolicy -sddcManagerFqdn $sddcManagerFqdn -sddcManagerUser $sddcManagerUser -sddcManagerPass $sddcManagerPass -sddcRootPass $sddcManagerRootPass -reportPath $reportPath -allDomains
-
Review the generated HTML report.
-
Start PowerShell (Run as Administrator)
-
Replace the values in the sample code with values for the instance of VMware Cloud Foundation to generate a password policy report for SDDC Manager instance and run the commands in the PowerShell console.
Example: Windows
$sddcManagerFqdn = "sfo-vcf01.sfo.rainpole.io" $sddcManagerUser = "admin@local" $sddcManagerPass = "VMw@re1!VMw@re1!" $sddcManagerRootPass = "VMw@re1!" $workloadDomain = "sfo-w01" $reportPath = "F:\Reporting"
Example: Linux
$sddcManagerFqdn = "sfo-vcf01.sfo.rainpole.io" $sddcManagerUser = "admin@local" $sddcManagerPass = "VMw@re1!VMw@re1!" $sddcManagerRootPass = "VMw@re1!" $workloadDomain = "sfo-w01" $reportPath = "/home/vmware/reporting"
-
Generate the report by running the command in the PowerShell console.
Invoke-VcfPasswordPolicy -sddcManagerFqdn $sddcManagerFqdn -sddcManagerUser $sddcManagerUser -sddcManagerPass $sddcManagerPass -sddcRootPass $sddcManagerRootPass -reportPath $reportPath -workloadDomain $workloadDomain
-
Review the generated HTML report.
The Invoke-VcfConfigurationReport
cmdlet generates a configuration report. This report collects information about the configuration settings in a VMware Cloud Foundation system for the platform components. This report reduces the need to login to multiple product interfaces and endpoints to collect information about the configuration.
-
Start PowerShell (Run as Administrator).
-
Replace the values in the sample code with values for the instance of VMware Cloud Foundation to generate a configuration report for SDDC Manager instance and run the commands in the PowerShell console.
Example: Windows
$sddcManagerFqdn = "sfo-vcf01.sfo.rainpole.io" $sddcManagerUser = "admin@local" $sddcManagerPass = "VMw@re1!VMw@re1!" $reportPath = "F:\Reporting"
Example: Linux
$sddcManagerFqdn = "sfo-vcf01.sfo.rainpole.io" $sddcManagerUser = "admin@local" $sddcManagerPass = "VMw@re1!VMw@re1!" $reportPath = "/home/vmware/reporting"
-
Generate the report by running the command in the PowerShell console.
Invoke-VcfConfigReport -sddcManagerFqdn $sddcManagerFqdn -sddcManagerUser $sddcManagerUser -sddcManagerPass $sddcManagerPass -reportPath $reportPath -allDomains
-
Review the generated HTML report.
-
Start PowerShell (Run as Administrator).
-
Replace the values in the sample code with values for the instance of VMware Cloud Foundation to generate a configuration report for SDDC Manager instance and run the commands in the PowerShell console.
Example: Windows
$sddcManagerFqdn = "sfo-vcf01.sfo.rainpole.io" $sddcManagerUser = "admin@local" $sddcManagerPass = "VMw@re1!VMw@re1!" $workloadDomain = "sfo-w01" $reportPath = "F:\Reporting"
Example: Linux
$sddcManagerFqdn = "sfo-vcf01.sfo.rainpole.io" $sddcManagerUser = "admin@local" $sddcManagerPass = "VMw@re1!VMw@re1!" $workloadDomain = "sfo-w01" $reportPath = "/home/vmware/reporting"
-
Generate the report by running the command in the PowerShell console.
Invoke-VcfConfigReport -sddcManagerFqdn $sddcManagerFqdn -sddcManagerUser $sddcManagerUser -sddcManagerPass $sddcManagerPass -reportPath $reportPath -workloadDomain $workloadDomain
-
Review the generated HTML report.
The upgrade precheck report, initiates an upgrade precheck of a workload domain using the REST API and presents the results in an HTML report. This allows you to start the precheck from the PowerShell console.
-
Start PowerShell (Run as Administrator).
-
Replace the values in the sample code with values for the instance of VMware Cloud Foundation to generate an upgrade precheck report for SDDC Manager instance and run the commands in the PowerShell console.
Example: Windows
$sddcManagerFqdn = "sfo-vcf01.sfo.rainpole.io" $sddcManagerUser = "admin@local" $sddcManagerPass = "VMw@re1!VMw@re1!" $workloadDomain = "sfo-w01" $reportPath = "F:\Reporting"
Example: Linux
$sddcManagerFqdn = "sfo-vcf01.sfo.rainpole.io" $sddcManagerUser = "admin@local" $sddcManagerPass = "VMw@re1!VMw@re1!" $workloadDomain = "sfo-w01" $reportPath = "/home/vmware/reporting"
-
Generate the report by running the command in the PowerShell console.
Invoke-VcfUpgradePrecheck -sddcManagerFqdn $sddcManagerFqdn -sddcManagerUser $sddcManagerUser -sddcManagerPass $sddcManagerPass -reportPath $reportPath -workloadDomain $workloadDomain
-
Review the generated HTML report.
The project team welcomes contributions from the community. Before you start working with PowerValidatedSolutions, please read our Developer Certificate of Origin. All contributions to this repository must be signed as described on that page. Your signature certifies that you wrote the patch or have the right to pass it on as an open-source patch.
For more detailed information, refer to the contribution guidelines to get started.
This PowerShell module is not supported by VMware Support.
We welcome you to use the GitHub issues tracker to report bugs or suggest features and enhancements.
When filing an issue, please check existing open, or recently closed, issues to make sure someone else hasn't already reported the issue.
Please try to include as much information as you can. Details like these are incredibly useful:
- A reproducible test case or series of steps.
- Any modifications you've made relevant to the bug.
- Anything unusual about your environment or deployment.
Copyright 2022-2023 VMware, Inc.
Redistribution and use in source and binary forms, with or without modification, are permitted provided that the following conditions are met:
-
Redistributions of source code must retain the above copyright notice, this list of conditions and the following disclaimer.
-
Redistributions in binary form must reproduce the above copyright notice, this list of conditions and the following disclaimer in the documentation and/or other materials provided with the distribution.
THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.