Microsoft MVP성태의 닷넷 이야기
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 
(연관된 글이 2개 있습니다.)

Azure Cloud Service 배포시 사용자 정의 작업을 추가하는 방법

Azure Cloud Service에 배포 시 해당 VM 머신에 또 다른 작업을 하고 싶을 수가 있습니다. 가령, 특정 S/W를 설치한다든지 환경 변수를 추가하는 등의 작업이 될텐데요.

이런 경우 "Azure Cloud Service" 프로젝트에 포함된 ServiceDefinition.csdef 파일의 "<Startup />" 노드를 이용할 수 있습니다.

How to configure and run startup tasks for a cloud service
; https://azure.microsoft.com/en-us/documentation/articles/cloud-services-startup-tasks/

대개의 경우 작업이 1개로 끝나지 않을 것이므로 예제에서 보이듯이,

<ServiceDefinition name="MyService" xmlns="http://schemas.microsoft.com/ServiceHosting/2008/10/ServiceDefinition">
    <WebRole name="WebRole1">
        ...
        <Startup>
            <Task commandLine="Startup.cmd" executionContext="limited" taskType="simple">
            </Task>
        </Startup>
    </WebRole>
</ServiceDefinition>

startup.cmd 파일로 .bat처럼 작업을 처리하면 됩니다.

수행할 명령어를 담은 startup.cmd 파일은 "Web Application" 프로젝트에 포함시키고 "Copy to Output Directory" 옵션을 "Copy if newer"로 설정해 반드시 /bin 폴더에 복사하도록 설정해야 합니다. (즉, Azure 배포 모듈은 "<Startup />"에 기술된 파일을 웹 응용 프로그램의 /bin 폴더에서 찾는다는 의미가 됩니다.)

그러고 보니, 예전에 이 방법을 통해 방화벽 포트를 여는 방법에 대해 소개했었죠. ^^

Azure - 네트워크 포트 여는 방법
; https://www.sysnet.pe.kr/2/0/1319

또한, <Task /> 노드는 1개 이상 설정할 수 있습니다. 그런 경우 위에서부터 차례대로 수행되지만 만약 선행 작업이 오류를 반환하는 경우 이후의 작업은 시도도 하지 않고 배포는 실패하게 됩니다.

당연하겠지만, Task/@commandLine의 인자로 .cmd 확장자 뿐만 아니라 .exe를 주는 것도 가능합니다.

<Startup>
    <Task commandLine="Installer.exe" executionContext="elevated" taskType="simple">
    </Task>
</Startup>

위의 설정은 installer.exe 파일을 /bin 폴더 하위에서 찾아 "elevated" 권한, 즉 관리자 권한으로 상승된 상태에서 실행하라는 것을 의미합니다.

.cmd나 .exe로 만들때 주의할 점은, 반드시 종료 코드가 0이어야만 다음 단계의 배포 작업으로 넘어간다는 것입니다. 이를 위해 .cmd 파일에서는 파일 마지막에 다음과 같이 명시적으로 종료 코드를 줄 수 있고,

EXIT /b 0

.exe의 경우 코드에서 반드시 0을 반환해야 합니다.

class Program
{
    static int Main(string[] args)
    {
        return 0;
    }
}

0이외의 값을 반환하면 웹 응용 프로그램 배포 단계까지 연결되지 않으므로, 만약 중요하지 않은 Task를 추가한 경우라면 필요 이상으로 오류 명시를 하지 않는 것이 좋습니다.




참고로, Task의 실행 환경에 적용되는 환경 변수를 설정하는 것도 가능합니다.

Define environment variables before a role starts
; https://azure.microsoft.com/en-us/documentation/articles/cloud-services-startup-tasks-common/

<Startup>
    <Task commandLine="Installer.exe"  executionContext="elevated" taskType="simple">
        <Environment>
            <Variable name="INSTALL_IN_AZURE" value="1" />
        </Environment>
    </Task>
</Startup>




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

[연관 글]






[최초 등록일: ]
[최종 수정일: 8/11/2016]

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)
11745정성태10/15/201818267오류 유형: 495. TFS 파일/폴더 삭제 - The item [...] could not be found in your workspace, or you do not have permission to access it.
11744정성태10/15/201819959개발 환경 구성: 410. msbuild로 .pubxml 설정에 따른 배포 파일을 만드는 방법
11743정성태10/15/201821028웹: 37. Bootstrap의 dl/dt/dd 조합에서 문자열이 잘리지 않도록 CSS 설정
11742정성태10/15/201826303스크립트: 13. 윈도우 배치(Batch) 스크립트에서 날짜/시간 문자열을 구하는 방법
11741정성태10/15/201820628Phone: 13. Android - LinearLayout 간략 설명
11740정성태10/15/201821850사물인터넷: 51. Synology NAS(DS216+II)를 이용한 원격 컴퓨터의 전원 스위치 제어
11739정성태10/15/201823591Windows: 151. 윈도우 10의 전원 관리가 "균형 조정(Balanced)"으로 바뀌는 문제
11738정성태10/15/201822070오류 유형: 494. docker - 윈도우에서 실행 시 "unknown shorthand flag" 오류 [1]
11737정성태10/13/201818356오류 유형: 493. Azure Kudu - There are ... items in this directory, but maxViewItems is set to 299
11736정성태10/12/201819915오류 유형: 492. Visual Studio 로딩 시 오류 - The 'Scc Display Information' package did not load correctly.
11735정성태10/12/201825770VS.NET IDE: 129. Visual Studio - 특정 문자(열)를 개행 문자로 바꾸는 방법
11734정성태10/10/201819351Linux: 4. Synology NAS(DS216+II)에 FTDI 장치 연결 후 C#(.NET Core)으로 DTR 제어파일 다운로드1
11733정성태10/10/201822795Linux: 3. Synology NAS(DS216+II)에서 FTDI 장치를 C/C++로 제어
11732정성태10/10/201822724디버깅 기술: 119. windbg 분석 사례 - 종료자(Finalizer)에서 예외가 발생한 경우 비정상 종료(Crash) 발생파일 다운로드1
11731정성태10/9/201821884개발 환경 구성: 409. C# - REST API를 이용해 Azure Kudu 서비스 이용 - 웹 앱 확장 처리파일 다운로드1
11730정성태10/9/201821338개발 환경 구성: 408. C# - REST API를 이용해 Azure Kudu 서비스 이용 - 파일 처리파일 다운로드1
11729정성태10/9/201823980Windows: 150. 윈도우에서 ARP Cache 목록 확인 및 삭제하는 방법
11728정성태10/9/201821655사물인터넷: 50. Audio Jack 커넥터의 IR 적외선 송신기 [1]
11727정성태10/8/201823046오류 유형: 491. Visual Studio의 리눅스 SSH 원격 연결 - "Connectivity Failure. Please make sure host name and port number are correct."
11726정성태10/7/201825667사물인터넷: 49. 라즈베리 파이를 이용해 원격 컴퓨터의 전원 스위치 제어파일 다운로드1
11724정성태10/5/201825551개발 환경 구성: 407. 유니코드와 한글 - "Hangul Compatibility Jamo"파일 다운로드1
11723정성태10/4/201818318개발 환경 구성: 406. "Docker for Windows" 컨테이너 내의 .NET Core 응용 프로그램에서 직렬 포트(Serial Port, COM Port) 사용 방법
11722정성태10/4/201822870.NET Framework: 798. C# - Hyper-V 가상 머신의 직렬 포트와 연결된 Named Pipe 간의 통신파일 다운로드1
11721정성태10/4/201823242.NET Framework: 797. Linux 환경의 .NET Core 응용 프로그램에서 직렬 포트(Serial Port, COM Port) 사용 방법파일 다운로드1
11720정성태10/4/201824726개발 환경 구성: 405. Hyper-V 가상 머신에서 직렬 포트(Serial Port, COM Port) 사용
11719정성태10/4/201825303.NET Framework: 796. C# - 인증서를 윈도우에 설치하는 방법
... 76  77  78  79  80  81  82  83  84  85  86  87  88  [89]  90  ...