【问题标题】:ImportPSModule Failure DetectionImportPSModule 故障检测
【发布时间】:2012-12-05 10:36:37
【问题描述】:

我正在尝试使用 InitialSessionState.ImportPSModule 来导入 Powershell 模块。

我很想知道模块的导入是否由于任何原因(例如找不到文件等)而失败。将此类代码放在 try 块中不会在失败的情况下引发异常,并且该函数似乎会静默失败并在无法导入模块时继续。

如果导入失败,是否有办法在代码中发出警报?

我正在尝试执行以下操作。在下面的代码中,模块“TestModule1234”不存在。 catch 块不会捕获异常。

注意:这只是原型测试代码,所以请忽略任何与生产代码相关的违规行为。

try
{
    //Initializing the PowerShell runspace
    InitialSessionState psSessionInitialState = InitialSessionState.CreateDefault();


    LogFile.Log("Importing Module TestModule1234");
    psSessionInitialState.ImportPSModule(new[] { "TestModule1234" });

    LogFile.Log("Creating Powershell Runspace");
    m_PoshRunspace = RunspaceFactory.CreateRunspace(psSessionInitialState);
}
catch (System.Exception ex)
{
    LogFile.Log("Failed to create a Powershell Runspace");
    LogFile.Log(ex.ToString());
    throw;
}

【问题讨论】:

  • 如果我运行import-module xyz,我会得到Import-Module : The specified module 'xyz' was not loaded because no valid module file was found in any module directory.。你能告诉我们你是如何尝试导入模块的吗?
  • 编辑原始问题以显示我正在尝试做的示例。

标签: c# .net powershell pssnapin runspace


【解决方案1】:

由于某些原因,缺少模块不会被视为致命错误。但他们是 仍然记录错误。为了解决这个问题:

  1. 通过Open() 打开您的运行空间。仍然在 try 块中执行此操作以捕获其他异常,它们是可能的,我在实践中遇到过这种情况。
  2. 获取标准错误列表($Error)并在打开后分析特定的“缺少模块”错误或其他错误。

这是 PowerShell 中仅使用 .NET 方法的工作示例,因此它被直译为 C#。此脚本不会失败(不会引发异常),但会将错误显示为变量 Error:

$psSessionInitialState = [System.Management.Automation.Runspaces.InitialSessionState]::CreateDefault();

"Importing Module TestModule1234"
$psSessionInitialState.ImportPSModule(@("TestModule1234"))

"Creating PowerShell Runspace"
$PoshRunspace = [System.Management.Automation.Runspaces.RunspaceFactory]::CreateRunspace($psSessionInitialState)

"Opening PowerShell Runspace"
$PoshRunspace.Open()

"Getting Runspace Error"
$PoshRunspace.SessionStateProxy.PSVariable.GetValue('Error')

输出

导入模块 TestModule1234 创建 Powershell 运行空间打开 Powershell 运行空间获取运行空间错误导入模块: 未加载指定的模块“TestModule1234”,因为没有有效 在任何模块目录中找到模块文件。 + CategoryInfo : ResourceUnavailable: (TestModule1234:String) [Import-Module], FileNotFoundException + FullyQualifiedErrorId : Modules_ModuleNotFound,Microsoft.PowerShell.Commands.ImportModuleCommand

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 2018-01-23
    • 2014-11-22
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2012-02-11
    • 1970-01-01
    相关资源
    最近更新 更多