Hyper-V 2016 系列教程40 使用 PowerShell 实现虚拟机自动化和管理虚拟机

简介:

注:以下内容部分取自微软官网:


可以在 Hyper-V 主机上的 Windows 10 或 Windows Server 技术预览版虚拟机中使用 PowerShell Direct 运行任意 PowerShell,而无论网络配置或远程管理设置如何。

运行 PowerShell Direct 的方法:

  • 作为交互式会话 - 请单击此处以使用 Enter-PSSession 创建和退出交互式 PowerShell 会话。

  • 作为用以执行单个命令或脚本的单用途会话 - 请单击此处以使用 Invoke-Command 运行脚本或命令。

  • 作为持久性会话(版本 14280 及更高版本)-- 请单击此处以使用 New-PSSession 创建持久性会话。
    通过使用 Copy-Item 将文件复制到虚拟机或从其复制文件,然后使用 Remove-PSSession 断开连接来继续进行操作。

要求

操作系统要求:

  • 主机:可运行 Hyper-V 的 Windows 10 、Windows Server Technical Preview 2 或更高版本。

  • 来宾/虚拟机:Windows 10 、Windows Server Technical Preview 2 或更高版本。

如果要管理较旧的虚拟机,请使用虚拟机连接 (VMConnect) 或为虚拟机配置虚拟网络

配置要求:

  • 虚拟机必须在主机上本地运行。

  • 虚拟机必须开启,且运行时需至少具有一个配置的用户配置文件。

  • 必须以 Hyper-V 管理员身份登录主机计算机。

  • 必须为虚拟机提供有效用户凭据。


创建并退出交互式 PowerShell 会话

在虚拟机上运行 PowerShell 命令的最简单方法是启动交互会话。

会话启动时,所键入的命令会在虚拟机上运行,其效果就像直接在虚拟机上将其键入到 PowerShell 会话中那样。

启动交互会话:

  1. 在 HYPER-V 主机上以管理员身份打开 PowerShell。

  2. 运行以下命令之一以使用虚拟机名称或 GUID 创建交互会话:

    PowerShell

    Enter-PSSession -VMName <VMName>Enter-PSSession -VMId <VMId>

    出现提示时,提供虚拟机的凭据。

  3. 在虚拟机上运行命令。

    你应该会看到作为 PowerShell 提示符前缀的 VMName 显示如下:

    [VMName]: PS C:\ >

    所有运行的命令将会在虚拟机上进行。 若要测试,可运行 ipconfig 或 hostname 以确保这些命令正在虚拟机中运行。

  4. 完成后,运行以下命令来关闭会话:

    PowerShell

    Exit-PSSession

请注意:如果你的会话未连接,请参阅疑难解答了解可能的原因。

若要了解有关这些 cmdlet 的详细信息,请参阅 Enter-PSSession 和 Exit-PSSession


使用 Invoke-Command 运行脚本或命令

配合使用 PowerShell Direct 和 Invoke-Command 非常适合需要在虚拟机上运行一个命令或一个脚本但在这一点之外无需继续与虚拟机进行交互的情况。

运行单个命令:

  1. 在 HYPER-V 主机上以管理员身份打开 PowerShell。

  2. 通过使用虚拟机名称或 GUID 运行以下命令之一来创建会话:

    PowerShell

    Invoke-Command -VMName <VMName> -ScriptBlock { cmdlet } 
    Invoke-Command -VMId <VMId> -ScriptBlock { cmdlet }

    出现提示时,提供虚拟机的凭据。

    该命令将在虚拟机上执行,如果存在到控制台的输出,会把此输出打印到控制台。 命令一运行将会自动关闭连接。

运行脚本:

  1. 在 HYPER-V 主机上以管理员身份打开 PowerShell。

  2. 通过使用虚拟机名称或 GUID 运行以下命令之一来创建会话:

    PowerShell

    Invoke-Command -VMName <VMName> -FilePath C:\host\script_path\script.ps1 
    Invoke-Command -VMId <VMId> -FilePath C:\host\script_path\script.ps1

    出现提示时,提供虚拟机的凭据。

    该脚本将在虚拟机上执行。 命令一运行将会自动关闭连接。

若要了解有关此 cmdlet 的详细信息,请参阅 Invoke-Command


使用 New-PSSession 和 Copy-Item 复制文件

注意:PowerShell Direct 仅支持 Windows 版本 14280 及更高版本中的持久性会话

在编写用于跨一个或多个远程计算机协调操作的脚本时,持久性 PowerShell 会话会非常有用。 一经创建后,持久性会话会一直存在于后台,直到你决定将其删除。 这意味着你可以使用 Invoke-Command 或 Enter-PSSession 反复引用同一个会话而无需传递凭据。

通过使用相同的令牌,会话将保持原有状态。 由于持久性会话具有持久性,在会话中创建的或传递给会话的任何变量将跨多个调用被保留。 有多种工具可用于持久性会话。 在此示例中,我们将使用 New-PSSession和 Copy-Item 在主机和虚拟机之间移动数据。

创建会话,然后复制文件:

  1. 在 HYPER-V 主机上以管理员身份打开 PowerShell。

  2. 运行以下命令之一使用 New-PSSession 将持久性 PowerShell 会话创建到虚拟机。

    PowerShell

    $s = New-PSSession -VMName <VMName> -Credential (Get-Credential)$s = New-PSSession -VMId <VMId> -Credential (Get-Credential)

    出现提示时,提供虚拟机的凭据。

    警告:
    14500 之前的版本中存在一个 Bug。 如果不使用 -Credential 标志显式指定凭据,来宾操作系统中的服务将崩溃,并且将需要重新启动。 如果点击此问题,可在此处获取解决方法说明。

  3. 将文件复制到虚拟机内。

    要将 C:\host_path\data.txt 从主机复制到虚拟机内,运行:

    PowerShell

    Copy-Item -ToSession $s -Path C:\host_path\data.txt -Destination C:\guest_path\
  4. 从虚拟机复制文件(到主机)。

    要将 C:\guest_path\data.txt 从虚拟机复制到主机,运行:

    PowerShell

    Copy-Item -FromSession $s -Path C:\guest_path\data.txt -Destination C:\host_path\
  5. 使用 Remove-PSSession 停止持久性会话。

    PowerShell

    Remove-PSSession $s

疑难解答

PowerShell Direct 显示了一小部分的常见错误消息。 以下是最常见的错误消息、一些原因和诊断问题的工具。

-VMName 或 -VMID 参数不存在

问题:
Enter-PSSession``Invoke-Command 或 New-PSSession 不具有 -VMName 或 -VMId 参数。

可能的原因:
最可能的问题是你的主机操作系统不支持 PowerShell Direct。

可以运行以下命令检查你的 Windows 版本:

PowerShell

[System.Environment]::OSVersion.Version

如果你运行的是支持的版本,则有可能你的 PowerShell 版本不运行 PowerShell Direct。 对于 PowerShell Direct 和 JEA,主版本必须为 5 或更高版本。

可以运行以下命令检查你的 PowerShell 版本:

PowerShell

$PSVersionTable.PSVersion

错误:远程会话可能已结束

注意:
对于主机版本在 10240 与 12400 之间的 Enter-PSSession,下面的所有错误都报告为“一个远程会话可能已结束”。

错误消息:

Enter-PSSession : An error has occurred which Windows PowerShell cannot handle. A remote session might have ended.

可能的原因:

  • 虚拟机存在但未运行。

  • 来宾操作系统不支持 PowerShell Direct(请参阅要求

  • PowerShell 尚不可用于来宾

    • 操作系统没有完成启动

    • 操作系统无法正常启动

    • 某些启动时事件需要用户输入

可使用 Get-VM cmdlet 进行检查以查看主机上正在运行哪些虚拟机。

错误消息:

New-PSSession : An error has occurred which Windows PowerShell cannot handle. A remote session might have ended.

可能的原因:

  • 上面列出的原因之一 - 它们都同等适用于 New-PSSession

  • 当前版本中的一个 Bug,在这些版本中,必须使用 -Credential 显式传递凭据。 发生这种情况时,整个服务将在来宾操作系统中挂起,并需要重新启动。 可以检查是否仍可通过 Enter-PSSession 使用会话。

若要解决凭据问题,使用 VMConnect 登录到虚拟机,打开 PowerShell,并使用以下 PowerShell 重新启动 vmicvmsession 服务:

PowerShell

Restart-Service -Name vmicvmsession

错误:无法解析参数集

错误消息:

Enter-PSSession : Parameter set cannot be resolved using the specified named parameters.

可能的原因:

  • -RunAsAdministrator 在连接到虚拟机时,不受支持。

    连接到 Windows 容器时,-RunAsAdministrator 标志将允许管理员连接,而无需显式凭据。 由于虚拟机未授予主机默示的管理员访问权限,因此你需要显式输入凭据。

使用 -Credential 参数或通过在系统提示时手动输入,可将管理员凭据传递给虚拟机。

错误:凭据无效。

错误消息:

Enter-PSSession : The credential is invalid.

可能的原因:

  • 无法验证来宾凭据

    • 提供的凭据不正确。

    • 来宾操作系统中没有任何用户帐户(操作系统以前未启动)

    • 如果以管理员身份进行连接:管理员还未设置为活动用户。 在此处了解详细信息。

错误:输入的 VMName 参数未解析为任何虚拟机。

错误消息:

Enter-PSSession : The input VMName parameter does not resolve to any virtual machine.

可能的原因:

  • 你不是 HYPER-V 管理员。

  • 虚拟机不存在。

你可以使用 Get-VM cmdlet 检查使用中的凭据是否具有 Hyper-V 管理员角色并查看哪些 VM 在主机上本地运行并已启动。



本文转自成杭 51CTO博客,原文链接:http://blog.51cto.com/hangtc/1965725,如需转载请自行联系原作者

相关文章
|
20天前
|
Web App开发 Java 测试技术
《手把手教你》系列技巧篇(五十六)-java+ selenium自动化测试-下载文件-上篇(详细教程)
【5月更文挑战第20天】本文介绍了自动化测试中如何实现无弹窗下载文件,主要针对Firefox浏览器。作者指出,通常的下载操作包括点击下载按钮,但这里讨论的是避免下载弹窗直接保存文件的方法。文章详细讲解了通过设置Firefox参数(如`browser.download.dir`、`browser.helperApps.neverAsk.saveToDisk`等)来实现这一功能,并给出了Java Selenium的示例代码,展示了如何创建FirefoxProfile并进行相关设置,以及如何启动浏览器和执行下载操作。
32 0
《手把手教你》系列技巧篇(五十六)-java+ selenium自动化测试-下载文件-上篇(详细教程)
|
1天前
|
XML 存储 测试技术
《手把手教你》系列基础篇(七十四)-java+ selenium自动化测试-框架设计基础-TestNG实现DDT - 上篇(详解教程)
【6月更文挑战第15天】本文介绍了TestNG的数据驱动测试(Data Driven Testing, DDT)概念和好处,并提供了两个实战示例。数据驱动测试允许使用不同的测试数据执行相同的测试用例,这些数据可以从外部文件或数据库获取。这种方法提高了测试效率,减少了冗余代码,并便于应对应用程序变更。
8 0
|
2天前
|
Web App开发 XML 安全
《手把手教你》系列基础篇(七十三)-java+ selenium自动化测试-框架设计基础-TestNG实现启动不同浏览器(详解教程)
【6月更文挑战第14天】本文介绍了如何使用TestNg进行自动化测试,特别是通过变量参数启动不同浏览器的步骤。
14 5
|
3天前
|
监控 Java 测试技术
《手把手教你》系列基础篇(七十二)-java+ selenium自动化测试-框架设计基础-TestNG简单介绍(详解教程)
【6月更文挑战第13天】本文介绍了TestNG单元测试框架,它是一个灵感来源于JUnit和NUnit的测试框架,支持多种级别的测试,如单元测试、集成测试等。TestNG的特点包括丰富的注解、数据驱动测试、变量支持、自动生成HTML测试报告等。与JUnit和NUnit相比,TestNG在某些功能上更为强大。文章还详细讲解了如何在Eclipse中安装TestNG插件,提供了在线安装、更新站点安装和离线安装三种方法,并展示了安装成功的验证步骤。最后,通过一个项目实战案例展示了如何使用TestNG编写和运行测试代码。
13 2
|
4天前
|
JavaScript Java 测试技术
《手把手教你》系列技巧篇(七十一)-java+ selenium自动化测试-自定义类解决元素同步问题(详解教程)
【6月更文挑战第12天】本文介绍了如何创建一个自定义类库来解决自动化测试中的元素同步问题。作者指出,大部分错误源于元素因时间不同步而引发,为此提供了一种解决方案。在项目实践中,首先在`library`包下创建名为`MyWait`的类,包含一个方法`isElementPresent`,该方法通过循环尝试并等待指定元素出现,避免了直接使用时间等待可能导致的不准确性。之后,在测试类中调用此自定义方法,成功实现了元素同步。代码示例展示了如何在Java+Selenium自动化测试中应用这个自定义类。
27 2
|
5天前
|
XML Web App开发 Java
《手把手教你》系列技巧篇(七十)-java+ selenium自动化测试-Java中如何读取properties配置文件内容(详解教程)
【6月更文挑战第11天】本文介绍了Java自动化测试中读取properties配置文件的方法。文章首先说明了为何要将配置参数放在properties文件中,然后简述了properties文件的作用和常用的读取方式,包括通过`java.util.Properties`类和`java.util.ResourceBundle`类。接着详细列举了`Properties`类的主要方法,如`getProperty()`、`load()`、`setProperty()`和`store()`等。
14 1
|
6天前
|
存储 Java 测试技术
《手把手教你》系列技巧篇(六十九)-java+ selenium自动化测试 - 读取csv文件(详细教程)
【6月更文挑战第10天】本文介绍了如何在Java中读取CSV文件。首先解释了CSV是逗号分隔值的文本文件,常用于数据交换。接着,在项目实战部分,详细说明了如何通过下载并引入opencsv库来读取CSV文件:包括下载jar包、添加到Eclipse项目、创建CSV文件、编写Java代码读取文件内容,并展示了代码执行后的输出结果。文章以一个简单的代码示例展示了如何使用opencsv读取CSV文件中的数据。
10 0
|
7天前
|
Java 测试技术 Apache
《手把手教你》系列技巧篇(六十八)-java+ selenium自动化测试 - 读写excel文件 - 下篇(详细教程)
【6月更文挑战第9天】本文介绍了如何使用Java处理Excel文件中的不同数据类型,包括日期、数字、布尔值和标签(常规字符串)。文章提供了两个示例,分别使用JXL库和Apache POI库来读取Excel文件。
9 1
|
8天前
|
XML Java 测试技术
《手把手教你》系列技巧篇(六十七)-java+ selenium自动化测试 - 读写excel文件 - 中篇(详细教程)
【6月更文挑战第8天】本文介绍了Java中操作Excel的工具,包括POI和JXL。POI支持处理Office 2003及以下的OLE2格式(.xls)和2007以上的OOXML格式(.xlsx)。而JXL只能处理2003版本的Excel文件。文章详细讲解了如何下载和使用JXL库,并给出了一个简单的Java代码示例,展示如何读取2003版Excel文件中的数据。在实际项目中,由于JXL对新版本Excel的支持限制,通常推荐使用POI。
24 5
|
9天前
|
Java 测试技术 Apache
《手把手教你》系列技巧篇(六十六)-java+ selenium自动化测试 - 读写excel文件 - 上篇(详细教程)
【6月更文挑战第7天】本文介绍了在Java自动化测试中如何操作Excel数据。文章提到了当测试数据存储在Excel文件时,可以使用Apache的POI库来读写Excel。POI提供了对OLE2(.xls)和OOXML(.xlsx)格式的支持,比JXL库功能更全面。文章还详细讲解了如何下载和添加POI库到项目中,以及准备测试用的Excel文件。最后,给出了一个简单的Java代码示例,演示如何读取Excel文件的内容。
14 1