2017-09-12 74 views
3

我創建了一個名爲ODBCManager的二進制Powershell模塊。從Feed中安裝後,我可以成功使用它的功能,但Get-Module未找到名稱(Get-Module -Name ODBCManager返回null)。 2分鐘查詢後會顯示Get-Module -ListAvailable,所以肯定會安裝。另外安裝-Verbose表示成功。未找到Powershell二進制模塊但已安裝

C:\Users\xxxxx> Get-Module -ListAvailable 


    Directory: C:\Program Files\WindowsPowerShell\Modules 


ModuleType Version Name        ExportedCommands 
---------- ------- ----        ---------------- 
Script  1.0.1  Microsoft.PowerShell.Operation.V... {Get-OperationValidation, Invoke-OperationValidation} 
Binary  0.1.0.1 ODBCManager       {Add-OracleODBC, Get-ODBCDrivers, New-OracleODBC} 
Binary  1.0.0.1 PackageManagement     {Find-Package, Get-Package, Get-PackageProvider, Get-PackageSource...} 
Script  3.4.0  Pester        {Describe, Context, It, Should...} 
Script  1.0.0.1 PowerShellGet      {Install-Module, Find-Module, Save-Module, Update-Module...} 
Script  1.2  PSReadline       {Get-PSReadlineKeyHandler, Set-PSReadlineKeyHandler, Remove-PSReadlineKeyHandler, Get-PSReadlineOption...} 
Manifest 20.0  SqlServer       {Add-SqlColumnEncryptionKeyValue, Complete-SqlColumnMasterKeyRotation, Get-SqlColumnEncryptionKey, Get-SqlColumnMasterKey...} 


    Directory: C:\WINDOWS\system32\WindowsPowerShell\v1.0\Modules 


ModuleType Version Name        ExportedCommands 
---------- ------- ----        ---------------- 
Manifest 1.0.0.0 ActiveDirectory      {Add-ADCentralAccessPolicyMember, Add-ADComputerServiceAccount, Add-ADDomainControllerPasswordReplicationPolicy, Add-ADFineGrainedPasswordPolicySu... Manifest 1.0.0.0 AppBackgroundTask     {Disable-AppBackgroundTaskDiagnosticLog, Enable-AppBackgroundTaskDiagnosticLog, Set-AppBackgroundTaskResourcePolicy, Unregister-AppBackgroundTask...} Manifest 2.0.0.0 AppLocker       {Get-AppLockerFileInformation, Get-AppLockerPolicy, New-AppLockerPolicy, Set-AppLockerPolicy...} 
Manifest 1.0.0.0 AppvClient       {Add-AppvClientConnectionGroup, Add-AppvClientPackage, Add-AppvPublishingServer, Disable-Appv...} 
Manifest 2.0.0.0 Appx        {Add-AppxPackage, Get-AppxPackage, Get-AppxPackageManifest, Remove-AppxPackage...} 
Script  1.0.0.0 AssignedAccess      {Clear-AssignedAccess, Get-AssignedAccess, Set-AssignedAccess} 
Manifest 1.0  BestPractices      {Get-BpaModel, Get-BpaResult, Invoke-BpaModel, Set-BpaResult} 

...................... 


    Directory: C:\Program Files (x86)\Microsoft SQL Server\120\Tools\PowerShell\Modules 


ModuleType Version Name        ExportedCommands 
---------- ------- ----        ---------------- 
Manifest 1.0  SQLASCMDLETS      {Add-RoleMember, Backup-ASDatabase, Invoke-ASCmd, Invoke-ProcessCube...} 
Manifest 1.0  SQLPS        {Backup-SqlDatabase, Add-SqlAvailabilityDatabase, Add-SqlAvailabilityGroupListenerStaticIp, Disable-SqlAlwaysOn...} 


    Directory: C:\Program Files (x86)\Microsoft SQL Server\130\Tools\PowerShell\Modules 


ModuleType Version Name        ExportedCommands 
---------- ------- ----        ---------------- 
Manifest 2.0  SQLASCMDLETS      {Add-RoleMember, Backup-ASDatabase, Invoke-ASCmd, Invoke-ProcessCube...} 
Manifest 1.0  SQLPS        {Add-SqlColumnEncryptionKeyValue, Complete-SqlColumnMasterKeyRotation, Get-SqlColumnEncryptionKey, Get-SqlColumnMasterKey...} 


C:\Users\xxxxxx> Install-Module -Name ODBCManager -Scope AllUsers -Force -ErrorAction Stop -Verbose 
VERBOSE: Using the provider 'PowerShellGet' for searching packages. 
VERBOSE: The -Repository parameter was not specified. PowerShellGet will use all of the registered repositories. 
VERBOSE: Getting the provider object for the PackageManagement Provider 'NuGet'. 
VERBOSE: The specified Location is 'https://www.powershellgallery.com/api/v2/' and PackageManagementProvider is 'NuGet'. 
VERBOSE: An error occurred while sending the request. 
VERBOSE: Retry downloading 'https://www.powershellgallery.com/api/v2/' for '2' more times 
VERBOSE: An error occurred while sending the request. 
VERBOSE: Retry downloading 'https://www.powershellgallery.com/api/v2/' for '1' more times 
VERBOSE: An error occurred while sending the request. 
VERBOSE: Retry downloading 'https://www.powershellgallery.com/api/v2/' for '0' more times 
WARNING: Unable to resolve package source 'https://www.powershellgallery.com/api/v2/'. 
VERBOSE: Total package yield:'0' for the specified package 'ODBCManager'. 
VERBOSE: Getting the provider object for the PackageManagement Provider 'NuGet'. 
VERBOSE: The specified Location is 'http://srv-proget/nuget/QASolutions-PS/' and PackageManagementProvider is 'NuGet'. 
VERBOSE: Searching repository 'http://srv-proget/nuget/QASolutions-PS/FindPackagesById()?id='ODBCManager'' for ''. 
VERBOSE: Total package yield:'1' for the specified package 'ODBCManager'. 
VERBOSE: Performing the operation "Install-Module" on target "Version '0.1.0.1' of module 'ODBCManager'". 
VERBOSE: The installation scope is specified to be 'AllUsers'. 
VERBOSE: The specified module will be installed in 'C:\Program Files\WindowsPowerShell\Modules'. 
VERBOSE: The specified Location is 'NuGet' and PackageManagementProvider is 'NuGet'. 
VERBOSE: Downloading module 'ODBCManager' with version '0.1.0.1' from the repository 'http://srv-proget/nuget/QASolutions-PS/'. 
VERBOSE: Searching repository 'http://srv-proget/nuget/QASolutions-PS/FindPackagesById()?id='ODBCManager'' for ''. 
VERBOSE: InstallPackage' - name='ODBCManager', version='0.1.0.1',destination='C:\Users\xxxxxxx\AppData\Local\Temp\191916' 
VERBOSE: DownloadPackage' - name='ODBCManager', version='0.1.0.1',destination='C:\Users\xxxxxx\AppData\Local\Temp\191916\ODBCManager\ODBCManager.nupkg', 
uri='http://srv-proget/nuget/QASolutions-PS/package/ODBCManager/0.1.0.1' 
VERBOSE: Downloading 'http://srv-proget/nuget/QASolutions-PS/package/ODBCManager/0.1.0.1'. 
VERBOSE: Completed downloading 'http://srv-proget/nuget/QASolutions-PS/package/ODBCManager/0.1.0.1'. 
VERBOSE: Completed downloading 'ODBCManager'. 
VERBOSE: Hash for package 'ODBCManager' does not match hash provided from the server. 
VERBOSE: InstallPackageLocal' - name='ODBCManager', version='0.1.0.1',destination='C:\Users\xxxxxx\AppData\Local\Temp\191916' 
VERBOSE: Catalog file 'ODBCManager.cat' is not found in the contents of the module 'ODBCManager' being installed. 
VERBOSE: For publisher validation, current module 'ODBCManager' with version '0.1.0.1' with publisher name ''. Is this module signed by Microsoft: 'False'. 
VERBOSE: For publisher validation, using the previously-installed module 'ODBCManager' with version '0.1.0.1' under 'C:\Program Files\WindowsPowerShell\Modules\ODBCManager\0.1.0.1' with publisher name ''. Is this module signed by Microsoft: 'False'. 
VERBOSE: Module 'ODBCManager' was installed successfully to path 'C:\Program Files\WindowsPowerShell\Modules\ODBCManager\0.1.0.1'. 
  • 我有它在ProGet主持下PowerShell模塊訂閱
  • 上發佈,文件夾名稱和DLL名稱是相同
  • 清單已創建
  • 功能導出和按預期執行

清單:

@{ 
    RootModule = 'ODBCManager.dll' 
    ModuleVersion = '0.1.0.1' # filled in by cake-build process 
    CmdletsToExport = '*' 
    GUID = 'xxx-xxx-xxx-xx-xx' 
    DotNetFrameworkVersion = '4.0' 
    Author = 'xxx' 
    Description = 'PowerShell Binary Module for manipulating ODBCs.' 
    CompanyName = 'xxx' 
    Copyright = '(c) 2017 xxx. All rights reserved.' 
    PrivateData = @{ 
     PSData = @{ 
      ProjectUri = 'xxxxxxxxxx' 
      LicenseUri = '' 
      ReleaseNotes = 'First Release' 
     } 
    } 
} 

我忘記了什麼嗎?因爲我已經嘗試了一切。


編輯:從@BenH幫助後,我才得以進一步的研究和發現,你可以調用Get-Module -ListAvailable -Name ODBCManager可快速顯示安裝在你的模塊,而不是進口。 - 供將來參考!

回答

2

Install-ModuleImport-Module是不同的。 Get-Module返回所有導入的模塊,並且Get-Module -ListAvailable返回所有已安裝的模塊。

因此,您的模塊是「安裝」,但不是「導入」。

對於更高版本的PowerShell,如果在.psd1的導出函數/ cmdlet中定義了它們的函數/ cmdlet,則會動態導入模塊。但是,直到它們被導入後,Get-Module纔會列出它們。

試試這個:

Import-Module ODBCManager 
Get-Module ODBCManager 
+0

是啊!謝謝:) - 真的很奇怪的功能仍然工作,無需導入雖然.. – HyTC

+1

@HyTC他們工作,因爲當你調用一個函數,PowerShell動態導入模塊。在PowerShell 1和2中,這沒有發生。 – BenH