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

비밀번호

댓글 작성자
 




... 91  92  93  94  95  96  97  98  99  100  101  102  103  104  [105]  ...
NoWriterDateCnt.TitleFile(s)
11300정성태9/10/201721116.NET Framework: 681. dotnet.exe - run, exec, build, restore, publish 차이점 [3]
11299정성태9/9/201719776개발 환경 구성: 330. Hyper-V VM의 Internal Network를 Private 유형으로 만드는 방법
11298정성태9/8/201723126VC++: 119. EnumProcesses / EnumProcessModules API 사용 시 주의점 [1]
11297정성태9/8/201719775디버깅 기술: 96. windbg - 풀 덤프에 포함된 모든 닷넷 모듈을 파일로 저장하는 방법
11296정성태9/8/201722921웹: 36. Edge - "이 웹 사이트는 이전 기술에서 실행되며 Internet Explorer에서만 작동합니다." 끄는 방법
11295정성태9/7/201720402디버깅 기술: 95. Windbg - .foreach 사용법
11294정성태9/4/201720072개발 환경 구성: 329. 마이크로소프트의 CoreCLR 프로파일러 예제 빌드 방법 [1]
11293정성태9/4/201720651개발 환경 구성: 328. Visual Studio(devenv.exe)를 배치 파일(.bat)을 통해 실행하는 방법
11292정성태9/4/201718878오류 유형: 419. Cannot connect to WMI provider - Invalid class [0x80041010]
11291정성태9/3/201720704개발 환경 구성: 327. 아파치 서버 2.4를 위한 mod_aspdotnet 마이그레이션
11290정성태9/3/201723952개발 환경 구성: 326. 아파치 서버에서 ASP.NET을 실행하는 mod_aspdotnet 모듈 [2]
11289정성태9/3/201721619개발 환경 구성: 325. GAC에 어셈블리 등록을 위해 gacutil.exe을 사용하는 경우 주의 사항
11288정성태9/3/201718380개발 환경 구성: 324. 윈도우용 XAMPP의 아파치 서버 구성 방법
11287정성태9/1/201727588.NET Framework: 680. C# - 작업자(Worker) 스레드와 UI 스레드 [11]
11286정성태8/28/201714947기타: 67. App Privacy Policy
11285정성태8/28/201723501.NET Framework: 679. C# - 개인 키 보안의 SFTP를 이용한 파일 업로드파일 다운로드1
11284정성태8/27/201721524.NET Framework: 678. 데스크톱 윈도우 응용 프로그램에서 UWP 라이브러리를 이용한 비디오 장치 열람하는 방법 [1]파일 다운로드1
11283정성태8/27/201717300오류 유형: 418. CSS3117: @font-face failed cross-origin request. Resource access is restricted.
11282정성태8/26/201719743Math: 22. 행렬로 바라보는 피보나치 수열
11281정성태8/26/201721553.NET Framework: 677. Visual Studio 2017 - NuGet 패키지를 직접 참조하는 PackageReference 지원 [2]
11280정성태8/24/201718575디버깅 기술: 94. windbg - 풀 덤프에 포함된 모든 모듈을 파일로 저장하는 방법
11279정성태8/23/201730179.NET Framework: 676. C# Thread가 Running 상태인지 아는 방법
11278정성태8/23/201718359오류 유형: 417. TFS - Warning - Unable to refresh ... because you have a pending edit. [1]
11277정성태8/23/201719608오류 유형: 416. msbuild - error MSB4062: The "TransformXml" task could not be loaded from the assembly
11276정성태8/23/201723916.NET Framework: 675. C# - (파일) 확장자와 연결된 실행 파일 경로 찾기 [2]파일 다운로드1
11275정성태8/23/201732916개발 환경 구성: 323. Visual Studio 설치 없이 빌드 환경 구성 - Visual Studio 2017용 Build Tools [1]
... 91  92  93  94  95  96  97  98  99  100  101  102  103  104  [105]  ...