【发布时间】:2016-04-27 16:49:07
【问题描述】:
我在非标准路径下有一个模块 (MyModule),即不在$env:PSModulePath -split ";" 中列出的通常位置下。但是,我已将 MyModule 的“生产”路径添加到该环境变量中,同时继续处理“开发”副本。
在尝试调试某些东西时,我使用以下命令加载了模块(使用$VerbosePreference = "Continue"),并立即看到两条看似矛盾的详细输出行:
[D:\Dev\UserA\]> Import-Module D:\Dev\UserA\libs\PowerShell\MyModule
VERBOSE: Loading module from path 'D:\Dev\UserA\libs\PowerShell\MyModule\MyModule.psd1'.
VERBOSE: Loading module from path 'D:\Dev\usera\MyModule2\MyModule.psm1'.
我想了解为什么 Import-Module 似乎加载了两次模块,尤其是在第二个路径不正确的情况下。
更多细节:
模块的文件夹结构是:
MyModule\MyModule.psd1
MyModule\MyModule.Test-Module.xml
MyModule\MyModule1\MyModule.psm1
MyModule\MyModule2\MyModule.psm1
注意 (1) 我在 MyModule1 子文件夹中保留了该模块的旧“版本 1”,并将更新后的“版本 2”文件放在 MyModule2 子文件夹中,并且 (2) 使用了 .xml 文件通过自定义模块测试脚本列出测试用例。我很确定后者可以忽略。
我的模块清单 (.psd1) 文件包含以下内容,所有其他行均为空白或 cmets:
@{
RootModule = '.\MyModule2\MyModule.psm1'
ModuleVersion = '2.0.0.0'
GUID = 'aaaaaaaa-bbbb-cccc-dddd-eeeeeeeeeeee'
Author = 'Old Developer (v1.x) & New Developer (v2.x)'
CompanyName = 'MyCompany'
Copyright = '(c) 2013-2015 MyCompany. All rights reserved.'
Description = 'Really useful functions'
FileList = @(
'.\MyModule.psd1'
'.\MyModule.Test-Module.xml'
'.\MyModule1\MyModule.psm1'
'.\MyModule2\MyModule.psm1'
'.\MyModule2\Examples\Archive-FilesWithCompression.ps1'
)
}
很明显,我使用了文件的相对路径,尤其是。 RootModule 键;这是必要的,因为我无法确定共享模块时会将其复制到哪里。
回到 Verbose 输出,我可以看到两行显示 (1) PSD1 文件的正确路径和 (2) PSM1 文件的无效路径。我确实注意到第二个路径的用户名是小写的,这就是我在测试前Set-Location 时碰巧输入它的方式。因此,看起来第一个路径是通过将 MyModule.psd1 附加到给定给 Import-Module cmdlet 的路径而采用的,第二个是 (Get-Location) 和 RootModule 路径的串联。
这似乎只发生在这个模块上。我在同一个“根”文件夹下有其他人没有表现出这种行为。
【问题讨论】:
标签: powershell module relative-path verbose