ps Pool Lookup
Problem this snippet solves:
This PowerShell application will do a reverse lookup for pools given a pool member definition.
Pool's are collections of pool members which are IP address and ports for a specific back end application server. Currently through the iControl API there is no direct way to do a reverse lookup of which pools a specified application server is a member of. This application will, given a pool member specification, do a reverse lookup and list all the associated pools that member is included in.
Code :
#---------------------------------------------------------------------------- # The contents of this file are subject to the "END USER LICENSE AGREEMENT FOR F5 # Software Development Kit for iControl"; you may not use this file except in # compliance with the License. The License is included in the iControl # Software Development Kit. # # Software distributed under the License is distributed on an "AS IS" # basis, WITHOUT WARRANTY OF ANY KIND, either express or implied. See # the License for the specific language governing rights and limitations # under the License. # # The Original Code is iControl Code and related documentation # distributed by F5. # # The Initial Developer of the Original Code is F5 Networks, # Inc. Seattle, WA, USA. Portions created by F5 are Copyright (C) 1996-2009 F5 Networks, # Inc. All Rights Reserved. iControl (TM) is a registered trademark of F5 Networks, Inc. # # Alternatively, the contents of this file may be used under the terms # of the GNU General Public License (the "GPL"), in which case the # provisions of GPL are applicable instead of those above. If you wish # to allow use of your version of this file only under the terms of the # GPL and not to allow others to use your version of this file under the # License, indicate your decision by deleting the provisions above and # replace them with the notice and other provisions required by the GPL. # If you do not delete the provisions above, a recipient may use your # version of this file under either the License or the GPL. #---------------------------------------------------------------------------- param ( $bigip = $null, $user = $null, $pass = $null, $poolmember = $null ); Set-PSDebug -strict; #------------------------------------------------------------------------- # function Write-Usage #------------------------------------------------------------------------- function Write-Usage() { Write-Host "Usage: PoolLookup.ps1 host uid pwd [poolmember]"; exit; } #------------------------------------------------------------------------- # function Write-Match #------------------------------------------------------------------------- function Write-Match() { param( [string]$pool = $null, [string]$address = $null, [int]$port = $null ); if ( $pool -and $address -and $port ) { $obj = 1 | select PoolMember, Pool $obj.PoolMember = "${address}:${port}"; $obj.Pool = $pool; $obj; } } #------------------------------------------------------------------------- # Lookup-Pool #------------------------------------------------------------------------- function Lookup-Pool() { param([string]$query = $null); $addr = "*"; $port = "*"; if ( $query ) { $addr = $query; $tokens = $query.Split(':'); if ( $tokens.Length -eq 2 ) { $addr = $tokens[0]; $port = $tokens[1]; } if ( !$addr ) { $addr = "*"; } if ( !$port ) { $port = "*"; } } $pool_list = (Get-F5.iControl).LocalLBPool.get_list(); $member_lists = (Get-F5.iControl).LocalLBPool.get_member($pool_list); for($i=0; $i-lt$pool_list.Length; $i++) { $pool = $pool_list[$i]; $member_list = $member_lists[$i]; for($j=0; $j-lt$member_list.Length; $j++) { $maddr = $member_list[$j].address; $mport = $member_list[$j].port; if ( !($query) -or ("${maddr}:${mport}" -like "${addr}:${port}") ) { Write-Match -pool $pool -address $maddr -port $mport; } } } } #------------------------------------------------------------------------- # Do-Initialize #------------------------------------------------------------------------- function Do-Initialize() { if ( (Get-PSSnapin | Where-Object { $_.Name -eq "iControlSnapIn"}) -eq $null ) { Add-PSSnapIn iControlSnapIn } $success = Initialize-F5.iControl -HostName $bigip -Username $user -Password $pass; return $success; } #------------------------------------------------------------------------- # Main Application Logic #------------------------------------------------------------------------- if ( ($bigip -eq $null) -or ($user -eq $null) -or ($pass -eq $null) ) { Write-Usage; } if ( Do-Initialize ) { if ( $poolmember ) { Lookup-Pool $poolmember; } else { Lookup-Pool; } } else { Write-Error "ERROR: iControl subsystem not initialized" }
Published Mar 09, 2015
Version 1.0CodeCentral_194
Cirrus
Joined May 05, 2019
CodeCentral_194
Cirrus
Joined May 05, 2019
No CommentsBe the first to comment