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

(시리즈 글이 6개 있습니다.)
.NET Framework: 736. C# - API를 사용해 Azure에 접근하는 방법
; https://www.sysnet.pe.kr/2/0/11480

개발 환경 구성: 374. Azure - Runbook 기능 소개
; https://www.sysnet.pe.kr/2/0/11511

.NET Framework: 745. Azure runbook을 PowerShell 또는 C# 코드로 실행하는 방법
; https://www.sysnet.pe.kr/2/0/11516

.NET Framework: 746. Azure runbook 예제 - 6시간 동안 수행 중인 VM을 중지
; https://www.sysnet.pe.kr/2/0/11517

.NET Framework: 800. C# - Azure REST API 사용을 위한 인증 획득
; https://www.sysnet.pe.kr/2/0/11758

개발 환경 구성: 418. Azure - Runbook 내에서 또 다른 Runbook 스크립트를 실행
; https://www.sysnet.pe.kr/2/0/11760




Azure - Runbook 내에서 또 다른 Runbook 스크립트를 실행

Runbook 스크립트에서 또 다른 Runbook 스크립트를 당연히 호출할 수 있습니다. 가령 호출하고 싶은 기존 Runbook이 "appRunner"라는 이름으로 다음과 같이 정의한 경우,

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
}

새로운 Runbook에서 다음과 같이 호출할 수 있습니다. (실제로는 Azure 웹 편집 화면의 좌측에 Runbook 명령이 나열되므로 선택만 하면 됩니다.)

.\appRunner.ps1 -targetWebApp ...[인자]...

문제는 저 인자를 전달하는 방법인데요, 저 환경은 엄연히 PowerShell 스크립트이기 때문에 그 문법에 맞게 JSON 객체를 넘겨줘야 합니다. 그리고 이를 위해서는 다음과 같은 식으로 전처리를 해야 합니다.

$jsonText = @"
{ "WebAppName": "MyTestSite", "Mode": "Stop" }
"@

$jsonObj = $jsonText | ConvertFrom-Json
.\appRunner.ps1 -targetWebApp $jsonObj




참고로, Azure 편집 화면에서 인자를 전달하는 것처럼,

stop_vm_runbook_3.png

다음과 같은 식으로 전달하는 경우,

.\appRunner.ps1 -targetWebApp { "WebAppName": "MyTestSite", "Mode": "Stop" }
.\appRunner.ps1 -targetWebApp "{ 'WebAppName' : 'MyTestSite', 'Mode' : 'Stop' }"
.\appRunner.ps1 -targetWebApp '{ "WebAppName": "MyTestSite", "Mode": "Stop" }'

모두 이런 식의 오류가 발생합니다.

C:\Temp\jirtb0ff.nua\appRunner.ps1 : A positional parameter cannot be found that accepts argument 'WebAppName\ : \MyTestSite\, \Mode\ : \Stop\ }'.
At line:1 char:1
+ .\appRunner.ps1 -targetWebApp "{ \"WebAppName\" : \"MyTestSite ...
+ ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
    + CategoryInfo          : InvalidArgument: (:) [appRunner.ps1], ParameterBindingException
    + FullyQualifiedErrorId : PositionalParameterNotFound,appRunner.ps1

{[AzureChinaCloud, AzureChinaCloud], [AzureCloud, AzureCloud], [AzureGermanCloud, AzureGermanCloud], [AzureUSGovernme...
Stop-AzureRmWebApp : Cannot validate argument on parameter 'Name'. The argument is null or empty. Provide an argument that is not null or empty, and then try the command again.
At C:\Temp\jzibymnp.155\appRunner.ps1:14 char:30
+     Stop-AzureRmWebApp -Name $targetWebApp.WebappName -ResourceGroupN ...
+                              ~~~~~~~~~~~~~~~~~~~~~~~~
    + CategoryInfo          : InvalidData: (:) [Stop-AzureRmWebApp], ParameterBindingValidationException
    + FullyQualifiedErrorId : 
ParameterArgumentValidationError,Microsoft.Azure.Commands.WebApps.Cmdlets.WebApps.StopAzureWebAppCmdlet




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







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

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

비밀번호

댓글 작성자
 




... 181  182  183  184  185  186  187  188  [189]  190  191  192  193  194  195  ...
NoWriterDateCnt.TitleFile(s)
227정성태4/13/200617382Team Foundation Server: 2. TFS 빌드 오류 유형 - MSBUILD: warning : Specified cast is not valid
226정성태4/13/200615367Team Foundation Server: 1. TFS 오류 유형 - TF50608: Unable to retrieve information for security object
225정성태10/17/200614912.NET Framework: 67. VS.NET 2005 도구 상자에 있는 Workflow Activity 항목의 아이콘 변경
223정성태4/13/200626194.NET Framework: 66. Microsoft .NET Framework 2.0 Configuration 수동 설치파일 다운로드1
224정성태4/13/200619750    답변글 .NET Framework: 66.1. "Microsoft .NET Framework 2.0 Configuration" MSI 설치 파일 버전파일 다운로드1
222정성태4/13/200618772.NET Framework: 65. VS.NET 2005: 파일 기반 웹 프로젝트의 "Virtual Path" 제거
220정성태4/13/200616477.NET Framework: 64. ClickOnce - 배포 시 오류 : "Error: An unexpected error occurred -- The parameter is incorrect."
219정성태4/13/200631304.NET Framework: 63. ClickOnce - 최초 실행 시 보안 경고창 없애는 방법 [1]
216정성태4/13/200618343스크립트: 8. 3월 1일 ActiveX Patch 적용 후, JS 로 수정한 임베딩 컨트롤이 여전히 비활성화 되는 문제 [2]
215정성태4/13/200619687.NET Framework: 62. ASP.NET 웹 컨트롤 렌더링 가로채기
214정성태4/13/200619030.NET Framework: 61. DateTime - DateTime = 사이의 "Month" 수 계산 [2]
213정성태4/13/200621292.NET Framework: 60. localhost 이외의 컴퓨터에서 asmx 테스트 페이지 호출 [1]
218정성태4/13/200619648    답변글 .NET Framework: 60.1. asmx 테스트 페이지를 보여주고 싶지 않을 때
211정성태4/13/200617533VS.NET IDE: 38. VS.NET 2005 - "Export Template" 메뉴
210정성태4/13/200616996.NET Framework: 59. EXE 참조 가능 - VS.NET 2005 [2]
209정성태4/13/200616483스크립트: 7. 4월 12일 ActiveX 패치 문제를 해결할 수 있는 가장 간단한 방법 [6]파일 다운로드1
208정성태10/21/200616225Windows: 1. 성태도 ^^ Vista 설치 해봤습니다.
212정성태10/20/200615771    답변글 Windows: 1.1. Vista 에서 WinFX 런타임 구동
207정성태4/13/200624799VC++: 23. VC++ RGS 파일에 사용자 정의 파라미터 추가
205정성태4/13/200621864VS.NET IDE: 37. devenv.exe를 이용한 Command Line 컴파일 [1]
204정성태5/8/200617034웹: 2. Server Unavailable - Server Application Unavailable
203정성태4/13/200615914웹: 1. IIS 설정 옵션: Verify(Check) that file exists
202정성태4/13/200615632VS.NET IDE: 36. Automatically synchronize with an Internet time server
201정성태4/13/200618694기타: 12. XMLHTTP Failure and SUS Admin
200정성태4/13/200618058.NET Framework: 58. 웹 서비스 메서드 호출 오류 유형 - text/html; charset=xxx, but expected 'text/xml'
199정성태4/13/200619387스크립트: 6. XHTML or HTML 4.01 표준 준수
... 181  182  183  184  185  186  187  188  [189]  190  191  192  193  194  195  ...