Microsoft MVP성태의 닷넷 이야기
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 

Azure - Runbook에서 사용할 수 있는 다양한 메서드를 위한 부가 Module 추가

App Service(Web App)을 시작 또는 중지시키는 용도의 Azure PowerShell API를,

Start-Azure?RmWeb?App
; https://docs.microsoft.com/en-us/powershell/module/azurerm.websites/start-azurermwebapp?view=azurermps-6.11.0

Stop-Azure?RmWeb?App
; https://docs.microsoft.com/en-us/powershell/module/azurerm.websites/stop-azurermwebapp?view=azurermps-6.11.0

당연히 Runbook 스크립트에서 실행해도 잘 될 거라 생각했는데요. 가령 다음과 같이 스크립트를 만든 경우,

param (
    [Parameter(Mandatory=$true)][PSObject]$targetWebApp
)

$azureConnection = Get-AutomationConnection -Name AzureRunAsConnection
Add-AzureRmAccount -ServicePrincipal -Tenant $azureConnection.TenantID -ApplicationID $azureConnection.ApplicationID -CertificateThumbprint $azureConnection.CertificateThumbprint

if ($targetWebApp.Mode -Match "Start")
{
    Start-AzureRmWebApp -Name $targetWebApp.WebAppName -ResourceGroupName "MyGroup"
}
else
{
    Stop-AzureRmWebApp -Name $targetWebApp.WebappName -ResourceGroupName "MyGroup" -Force
}

실행해 보면 이렇게 오류가 발생합니다.

Stop-AzureRmWebApp : The term 'Stop-AzureRmWebApp' is not recognized as the name of a cmdlet, function, script file, or operable program. Check the spelling of the name, or if a path was included, verify that the path is correct and try again.
At line:14 char:5
+     Stop-AzureRmWebApp -Name $targetWebApp.WebappName -ResourceGroupN ...
+     ~~~~~~~~~~~~~~~~~~
    + CategoryInfo          : ObjectNotFound: (Stop-AzureRmWebApp:String) [], CommandNotFoundException
    + FullyQualifiedErrorId : CommandNotFoundException

말 그대로, 기본 Runbook 환경에서는 Start-AzureRmWebApp와 Stop-AzureRmWebApp 메서드를 포함한 모듈이 누락되어 있기 때문입니다. 해결책은 당연히 모듈을 추가해 주면 됩니다.

Azure Automation (RM Portal) - Powershell Runbook - List of CMDLT missing all xxxx-AzureRmWebApp CMDLT's
; https://social.msdn.microsoft.com/Forums/azure/en-US/1efee8fd-6897-448c-a565-f3e2da9cea9d/azure-automation-rm-portal-powershell-runbook-list-of-cmdlt-missing-all-xxxxazurermwebapp?forum=azureautomation

따라서, Azure Automation Account로 이동해 "Modules" 메뉴를 선택하고,

runbook_import_module_1.png

자신이 만든 모듈이 있다면 좌측의 "Add a module"을 이용해 모듈 파일을 직접 올리거나, 마이크로소프트가 제공하는 모듈은 대부분 "gallery"에 있으므로 우측의 "Browse gallery"를 이용해 추가할 수 있습니다. 일례로, Start-AzureRmWebApp와 Stop-AzureRmWebApp의 경우에는 다음의 2가지 모듈을 로드하면 됩니다.

  • AzureRM.Profile
  • AzureRM.Websites (AzureRM.Profile 모듈에 의존)

참고로 import 완료까지 시간이 좀 걸리므로 곧바로 Runbook 스크립트를 실행하면 동일한 오류가 발생합니다.




[이 글에 대해서 여러분들과 의견을 공유하고 싶습니다. 틀리거나 미흡한 부분 또는 의문 사항이 있으시면 언제든 댓글 남겨주십시오.]







[최초 등록일: ]
[최종 수정일: 10/25/2018]

Creative Commons License
이 저작물은 크리에이티브 커먼즈 코리아 저작자표시-비영리-변경금지 2.0 대한민국 라이센스에 따라 이용하실 수 있습니다.
by SeongTae Jeong, mailto:techsharer at outlook.com

비밀번호

댓글 작성자
 




... 76  77  78  79  80  81  82  83  84  [85]  86  87  88  89  90  ...
NoWriterDateCnt.TitleFile(s)
11812정성태2/11/201915718오류 유형: 511. Windows Server 2003 VM 부팅 후 로그인 시점에 0xC0000005 BSOD 발생
11811정성태2/11/201921029오류 유형: 510. 서버 운영체제에 NVIDIA GeForce Experience 실행 시 wlanapi.dll 누락 문제
11810정성태2/11/201918593.NET Framework: 808. .NET Profiler - GAC 모듈에서 GAC 비-등록 모듈을 참조하는 경우의 문제
11809정성태2/11/201920780.NET Framework: 807. ClrMD를 이용해 메모리 덤프 파일로부터 특정 인스턴스를 참조하고 있는 소유자 확인
11808정성태2/8/201922114디버깅 기술: 123. windbg - 닷넷 응용 프로그램의 메모리 누수 분석
11807정성태1/29/201920007Windows: 156. 가상 디스크의 용량을 복구 파티션으로 인해 늘리지 못하는 경우 [4]
11806정성태1/29/201919649디버깅 기술: 122. windbg - 덤프 파일로부터 PID와 환경 변수 등의 정보를 구하는 방법
11805정성태1/28/201921824.NET Framework: 806. C# - int []와 object []의 차이로 이해하는 제네릭의 필요성 [4]파일 다운로드1
11804정성태1/24/201919668Windows: 155. diskpart - remove letter 이후 재부팅 시 다시 드라이브 문자가 할당되는 경우
11803정성태1/10/201918573디버깅 기술: 121. windbg - 닷넷 Finalizer 스레드가 멈춰있는 현상
11802정성태1/7/201920238.NET Framework: 805. 두 개의 윈도우를 각각 실행하는 방법(Windows Forms, WPF)파일 다운로드1
11801정성태1/1/201921546개발 환경 구성: 427. Netsh의 네트워크 모니터링 기능 [3]
11800정성태12/28/201820625오류 유형: 509. WCF 호출 오류 메시지 - System.ServiceModel.CommunicationException: Internal Server Error
11799정성태12/19/201822411.NET Framework: 804. WPF(또는 WinForm)에서 UWP UI 구성 요소 사용하는 방법 [3]파일 다운로드1
11798정성태12/19/201821249개발 환경 구성: 426. vcpkg - "Building vcpkg.exe failed. Please ensure you have installed Visual Studio with the Desktop C++ workload and the Windows SDK for Desktop C++"
11797정성태12/19/201817237개발 환경 구성: 425. vcpkg - CMake Error: Problem with archive_write_header(): Can't create '' 빌드 오류
11796정성태12/19/201817570개발 환경 구성: 424. vcpkg - "File does not have expected hash" 오류를 무시하는 방법
11795정성태12/19/201820850Windows: 154. PowerShell - Zone 별로 DNS 레코드 유형 정보 조회 [1]
11794정성태12/16/201816918오류 유형: 508. Get-AzureWebsite : Request to a downlevel service failed.
11793정성태12/16/201819471개발 환경 구성: 423. NuGet 패키지 제작 - Native와 Managed DLL을 분리하는 방법 [1]
11792정성태12/11/201819187Graphics: 34. .NET으로 구현하는 OpenGL (11) - Per-Pixel Lighting파일 다운로드1
11791정성태12/11/201819227VS.NET IDE: 130. C/C++ 프로젝트의 시작 프로그램으로 .NET Core EXE를 지정하는 경우 닷넷 디버깅이 안 되는 문제 [1]
11790정성태12/11/201817720오류 유형: 507. Could not save daemon configuration to C:\ProgramData\Docker\config\daemon.json: Access to the path 'C:\ProgramData\Docker\config' is denied.
11789정성태12/10/201831418Windows: 153. C# - USB 장치의 연결 및 해제 알림을 위한 WM_DEVICECHANGE 메시지 처리 [2]파일 다운로드2
11788정성태12/4/201817633오류 유형: 506. SqlClient - Value was either too large or too small for an Int32.Couldn't store <2151292191> in ... Column
11787정성태11/29/201821811Graphics: 33. .NET으로 구현하는 OpenGL (9), (10) - OBJ File Format, Loading 3D Models파일 다운로드1
... 76  77  78  79  80  81  82  83  84  [85]  86  87  88  89  90  ...