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

Azure - 일정(schedule)에 등록한 runbook이 1년 후 실행이 안 되는 문제(Reason - The key used is expired.)

이상하군요. 어느 순간부터 일정에 등록한 runbook 스크립트가 실행되지 않습니다.

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

대충 저 글을 쓴지 1년이 되어가는데요, 왜냐하면 "Automation Account"가 소유한 인증서가 1년 만기이기 때문에 다음과 같은 오류가 runbook 실행 시 발생하고 있었던 것입니다.

AADSTS700027: Client assertion contains an invalid signature. [Reason - The key used is expired., Thumbprint of key used by client: 'A9AFDC7BC047322F00AF034E24B63385898BB13D', Found key 'Start=10/22/2018 00:00:00, End=10/23/2019 00:00:00', Please visit 'https://developer.microsoft.com/en-us/graph/graph-explorer?WT.mc_id=DT-MVP-4038148' and query for 'https://graph.microsoft.com/beta/applications/83d348ba-3cd2-4ab2-9304-8b0736f7e3ad' to see configured keys] Trace ID: 8ee86b7b-cd1c-4413-b3de-6acd888d3101 Correlation ID: 4d03cd5e-325d-4175-a062-6c1d1485731a Timestamp: 2019-11-14 04:00:33Z
No subscription found in the context. Please ensure that the credentials you provided are authorized to access an Azure subscription, then run Connect-AzureRmAccount to login.


검색해 보면 정확히 저 문제를 설명한 글이 나옵니다. ^^

Azure Automation Fails to Start Machine
; https://www.mcbsys.com/blog/2017/06/azure-automation-fails-to-start-machine/

그런데 사실 이 문제를 인식하기 어려웠던 점이 있는데, runbook의 "Process Automation" / "Jobs" 로그를 보면 다음과 같이 STATUS가 "Completed"로 나오기 때문입니다.

[그림 출처: https://www.mcbsys.com/blog/2017/06/azure-automation-fails-to-start-machine/]
runbook_cert_expired_0.png

하지만 저 로그 항목 하나를 찍고 들어가면 그제서야 이 글의 처음에 실은 "AADSTS700027" 오류가 보입니다. ^^;




해결 방법은 "Azure Automation Fails to Start Machine" 글에도 나오지만, 문제가 되는 "Automation Account" 설정 화면으로 들어가면 아래의 화면과 같이,

runbook_cert_expired_1.png

친절하게 오류 메시지와 함께 링크를 제공하므로,

The certificates for the Run As account and Classic Run As account have expired. Click here to renew the certificate(s).

이것을 누르면 "Azure Run As Account"와 "Azure Classic Run As Account"에 대해 인증서를 갱신(renew)하는 버튼이 보이고, 그것을 눌러 실행하면 모든 문제가 해결됩니다. ^^ (그나저나... 이걸 1년마다 신경 써야 하는 것은 좀...!!!)




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







[최초 등록일: ]
[최종 수정일: 11/15/2019]

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

비밀번호

댓글 작성자
 




... 61  62  63  64  65  66  67  68  69  70  [71]  72  73  74  75  ...
NoWriterDateCnt.TitleFile(s)
11865정성태4/9/201911352오류 유형: 529. 제어판 - C:\ProgramData\Microsoft\Windows\Start Menu\Programs\Administrative Tools is not accessible.
11864정성태4/9/201910557오류 유형: 528. '...' could be '0': this does not adhere to the specification for the function '...'
11863정성태4/9/201910361디버깅 기술: 127. windbg - .NET x64 EXE의 EntryPoint
11862정성태4/7/201912431개발 환경 구성: 437. .NET EXE의 ASLR 기능을 끄는 방법
11861정성태4/6/201912192디버깅 기술: 126. windbg - .NET x86 CLR2/CLR4 EXE의 EntryPoint
11860정성태4/5/201915471오류 유형: 527. Visual C++ 컴파일 오류 - error C2220: warning treated as error - no 'object' file generated
11859정성태4/4/201912848디버깅 기술: 125. WinDbg로 EXE의 EntryPoint에서 BP 거는 방법
11858정성태3/27/201913287VC++: 129. EXE를 LoadLibrary로 로딩해 PE 헤더에 있는 EntryPoint를 직접 호출하는 방법파일 다운로드1
11857정성태3/26/201912193VC++: 128. strncpy 사용 시 주의 사항(Linux / Windows)
11856정성태3/25/201912173VS.NET IDE: 134. 마이크로소프트의 CoreCLR 프로파일러 리눅스 예제를 Visual Studio F5 원격 디버깅하는 방법 [1]파일 다운로드1
11855정성태3/25/201914185개발 환경 구성: 436. 페이스북 HTTPS 인증을 localhost에서 테스트하는 방법
11854정성태3/25/201910138VS.NET IDE: 133. IIS Express로 호스팅하는 사이트를 https로 접근하는 방법
11853정성태3/24/201912297개발 환경 구성: 435. 존재하지 않는 IP 주소에 대한 Dns.GetHostByAddress/gethostbyaddr/GetNameInfoW 실행이 느리다면? - 두 번째 이야기 [1]
11852정성태3/20/201912540개발 환경 구성: 434. 존재하지 않는 IP 주소에 대한 Dns.GetHostByAddress/gethostbyaddr/GetNameInfoW 실행이 느리다면?파일 다운로드1
11851정성태3/19/201915417Linux: 8. C# - 리눅스 환경에서 DllImport 대신 라이브러리 동적 로드 처리 [2]
11850정성태3/18/201913992.NET Framework: 813. C# async 메서드에서 out/ref/in 유형의 인자를 사용하지 못하는 이유
11849정성태3/18/201913802.NET Framework: 812. pscp.exe 기능을 C#으로 제어하는 방법파일 다운로드1
11848정성태3/17/201911207스크립트: 14. 윈도우 CMD - 파일이 변경된 경우 파일명을 변경해 복사하고 싶다면?
11847정성태3/17/201915096Linux: 7. 리눅스 C/C++ - 공유 라이브러리 동적 로딩 후 export 함수 사용 방법파일 다운로드1
11846정성태3/15/201913502Linux: 6. getenv, setenv가 언어/운영체제마다 호환이 안 되는 문제
11845정성태3/15/201914227Linux: 5. Linux 응용 프로그램의 (C++) so 의존성 줄이기(ReleaseMinDependency) [3]
11844정성태3/14/201915017개발 환경 구성: 434. Visual Studio 2019 - 리눅스 프로젝트를 이용한 공유/실행(so/out) 프로그램 개발 환경 설정 [1]파일 다운로드1
11843정성태3/14/201910790기타: 75. MSDN 웹 사이트를 기본으로 영문 페이지로 열고 싶다면?
11842정성태3/13/201910223개발 환경 구성: 433. 마이크로소프트의 CoreCLR 프로파일러 예제를 Visual Studio CMake로 빌드하는 방법 [1]파일 다운로드1
11841정성태3/13/201910193VS.NET IDE: 132. Visual Studio 2019 - CMake의 컴파일러를 기본 g++에서 clang++로 변경
11840정성태3/13/201911276오류 유형: 526. 윈도우 10 Ubuntu App 환경에서는 USB 외장 하드 접근 불가
... 61  62  63  64  65  66  67  68  69  70  [71]  72  73  74  75  ...