2017-09-12 1 views
3

J'ai créé un module appelé binaire Powershell ODBCManager. Après l'installation à partir d'un flux, je suis en mesure d'utiliser ses fonctions avec succès, mais Get-Module ne le trouve pas par son nom (Get-Module -Name ODBCManager renvoie null). Get-Module -ListAvailable va le montrer après une requête de 2 minutes, donc c'est définitivement installé. Aussi -Verbose sur l'installation dit le succès.Powershell binaire Module introuvable mais installé

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'. 
  • Je l'ai hébergé dans PROGET sous un Modules Powershell Flux
  • Sur Publish, le nom du dossier et le nom DLL sont les mêmes
  • Manifest a été créé
  • Fonctions d'exportation et d'exécuter comme prévu

Manifest:

@{ 
    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' 
     } 
    } 
} 

Ai-je oublié quelque chose? Parce que j'ai tout essayé.


EDIT: Après l'aide de @BenH j'ai pu faire des recherches plus loin et trouvé, vous pouvez appeler Get-Module -ListAvailable -Name ODBCManager montrer rapidement votre module installé, mais pas importé. -- Pour référence future!

Répondre

2

Install-Module et Import-Module sont différents. Get-Module renvoie tous les modules importés et Get-Module -ListAvailable renvoie tous les modules installés.

Ainsi votre module est « installé » mais pas « importés ».

Avec les versions ultérieures de PowerShell, les modules sont dynamiquement importés si leurs fonctions/cmdlets sont définies dans les fonctions exportées/cmdlets du .psd1. Mais jusqu'à ce qu'ils soient importés, Get-Module ne les listera pas.

Essayez ceci:

Import-Module ODBCManager 
Get-Module ODBCManager 
+0

Eh oui! Merci :) - Vraiment bizarre les fonctions fonctionnent encore sans importer cependant .. – HyTC

+1

@HyTC Ils fonctionnent parce que lorsque vous appelez une fonction, PowerShell importe dynamiquement le module. Dans PowerShell 1 et 2, cela ne s'est pas produit. – BenH