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

비밀번호

댓글 작성자
 




... 136  137  138  139  140  141  142  143  144  145  146  147  [148]  149  150  ...
NoWriterDateCnt.TitleFile(s)
1354정성태9/19/201224479.NET Framework: 338. .NET CLR GC 시간 측정하는 방법파일 다운로드1
1353정성태9/17/201225769.NET Framework: 337. Python의 생성기와 코루틴을 C#으로 표현하면. [2]파일 다운로드1
1352정성태9/13/201223824.NET Framework: 336. .NET Profiler가 COM 개체일까?
1351정성태9/13/201228251디버깅 기술: 49. windbg - .NET Framework 스레드 개체의 COM Apartment 유형 확인하는 방법
1350정성태9/12/201228905개발 환경 구성: 167. (실은) 무료가 아니었던 AWS EC2 서비스 [4]
1349정성태9/11/201260647VS.NET IDE: 74. Visual Studio의 '새 파일'을 UTF-8 인코딩으로 지정하는 방법 [4]
1348정성태9/11/201228083오류 유형: 164. Active Directory - Functional Level 승격이 안 되는 문제
1347정성태9/10/201230568Windows: 62. 윈도우 서버 2012 - Hyper-V 서버 마이그레이션 [1]
1346정성태9/10/201231412Windows: 61. 윈도우 서버 2012 - Active Directory 서버 마이그레이션
1345정성태9/10/201235460스크립트: 12. 파이썬 - Win32 DLL 연동 [2]
1344정성태9/10/201228579오류 유형: 163. .NET Framework 4.5 제거 후 Visual Studio 2010 실행 시 Unknown Error
1343정성태9/8/201242345스크립트: 11. 파이썬(Python) 윈도우 개발 환경 [7]
1342정성태9/6/201226554VS.NET IDE: 73. Visual Studio 2012 - XmlCodeGenerator 마이그레이션
1341정성태9/4/201235848Windows: 60. Hyper-V에서 RemoteFX 없이 DirectX 11 제공 [12]
1340정성태9/4/201228040개발 환경 구성: 166. DOS - ping 결과에서 평균 응답 시간값 추출하기 [3]
1339정성태9/4/201230481개발 환경 구성: 165. 새로운 Visual Studio 2012 원격 디버깅 툴 [5]
1338정성태9/4/201232299.NET Framework: 335. C# - (핸들을 이용하여) 모든 열린 파일을 열람 [6]파일 다운로드1
1337정성태8/30/201222082Phone: 7. 디버거로 실습해 보는 윈도우 폰의 Tombstone 상태파일 다운로드1
1336정성태8/30/201240149.NET Framework: 334. 스레드 비정상 종료로 발생하는 CLOSE_WAIT 소켓 상태 [2]파일 다운로드1
1335정성태8/30/201228898Windows: 59. Hyper-V Internal 네트워크 VM의 인터넷 접속
1334정성태8/29/201248194.NET Framework: 333. 코드로 재현하는 소켓 상태(FIN_WAIT1, FIN_WAIT2, TIME_WAIT, CLOSE_WAIT, LAST_WAIT) [6]
1333정성태8/27/201251621개발 환경 구성: 164. system32 폴더에 있는 파일의 권한 조정 [2]
1332정성태8/23/201223525Team Foundation Server: 48. TFS - Team Project Collection 이전하는 방법
1331정성태8/23/201226676오류 유형: 162. Database '...' already exists. Choose a different database name. (Microsoft SQL Server, Error: 1801)
1330정성태8/22/201227417Team Foundation Server: 47. 5인 이내의 팀, 또는 개인 로컬 소스 관리를 위한 무료 TFS Express
1329정성태8/21/201222903오류 유형: 161. Azure - Storage 삭제가 안되는 경우 [1]
... 136  137  138  139  140  141  142  143  144  145  146  147  [148]  149  150  ...