Microsoft MVP성태의 닷넷 이야기
개발 환경 구성: 371. Azure Web App 확장 예제 - Simple WebSite Extension [링크 복사], [링크+제목 복사],
조회: 20025
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 
(연관된 글이 2개 있습니다.)
(시리즈 글이 8개 있습니다.)
개발 환경 구성: 371. Azure Web App 확장 예제 - Simple WebSite Extension
; https://www.sysnet.pe.kr/2/0/11505

개발 환경 구성: 379. Azure Web App 확장 예제 제작
; https://www.sysnet.pe.kr/2/0/11540

개발 환경 구성: 380. Azure Web App 확장 배포 방법
; https://www.sysnet.pe.kr/2/0/11541

개발 환경 구성: 408. C# - REST API를 이용해 Azure Kudu 서비스 이용 - 파일 처리
; https://www.sysnet.pe.kr/2/0/11730

개발 환경 구성: 409. C# - REST API를 이용해 Azure Kudu 서비스 이용 - 웹 앱 확장 처리
; https://www.sysnet.pe.kr/2/0/11731

개발 환경 구성: 578. Azure - Java Web App Service를 위한 Site Extension 제작 방법
; https://www.sysnet.pe.kr/2/0/12711

개발 환경 구성: 579. Azure - 리눅스 호스팅의 Site Extension 제작 방법
; https://www.sysnet.pe.kr/2/0/12712

개발 환경 구성: 605. Azure App Service - Kudu SSH 환경에서 FTP를 이용한 파일 전송
; https://www.sysnet.pe.kr/2/0/12855




Azure Web App 확장 예제 - Simple WebSite Extension

Azure의 Web App(App Service)에는 '확장'이라는 것을 설치할 수 있습니다. 일례로 Let's encrypt 무료 인증서를 쉽게 설치/갱신해주는 확장도,

Azure Let's Encrypt 
; https://www.siteextensions.net/packages/letsencrypt/

Azure VM/App Services(Web Apps)에 Let's Encrypt 무료 인증서 적용 방법
; https://www.sysnet.pe.kr/2/0/11502

그 형식으로 만들어진 것입니다. 그럼, 이런 걸 우리도 만들 수 있지 않을까요? ^^ 이에 대해 다음의 글에서 자세하게 설명하고 있습니다.

Azure Web Sites Extensions
; https://azure.microsoft.com/en-us/blog/azure-web-sites-extensions/

그리고 그 시작으로 github에 확장 예제가 공개되어 있습니다.

Azure - Site Extensions
; https://github.com/projectkudu/FileCounterSiteExtension

빌드 및 배포 방법은 역시 README.md 파일에 다음과 같이 잘 소개하고 있습니다.

## To build it and directly upload it to a site

  1. Clone this repository.
  2. Run `build.cmd`.  This will zip the extension files in `artifacts\Release\zip` folder.
  3. Copy `Deployment Trigger Url` from Azure portal for your website (in CONFIGURE TAB when you have git enabled).
  4. Upload extension to your website by `artifacts\Release\zip\DeployExtension.cmd "<deploy-trigger-url>"`.
  5. Restart your site.  You may use Portal to do so.
  6. You can now access this simple extension via `<scm-url>/filecounter`.

이를 위해 nuget.exe를 다운로드해,

NuGet - Installing
; https://docs.nuget.org/consume/command-line-reference
; https://dist.nuget.org/win-x86-commandline/latest/nuget.exe

PATH 환경 변수의 연결된 경로에 복사하고 build.cmd 파일을 실행합니다.

E:\sample\FileCounterSite> build.cmd
Microsoft (R) Build Engine version 4.7.2556.0
[Microsoft .NET Framework, version 4.0.30319.42000]
Copyright (C) Microsoft Corporation. All rights reserved.

E:\sample\FileCounterSite\artifacts\Release\zip\SimpleWebSiteExtension.zip created.
Attempting to build package from 'FileCounter.nuspec'.
Successfully created package 'artifacts\Release\filecounter.1.0.21.nupkg'.

그다음 Azure Portal에서 해당 App Services의 "속성"으로 가면 다음과 같은 형식의 "Deployment Trigger Url(배포 트리거 URL)"을 구할 수 있습니다.

appservice_ext_deploy_url_1.png

https://...[생략]...xr6@[yoursitename].scm.azurewebsites.net/deploy

따라서, 저 경로를 DeployExtension.cmd의 인자로 넘겨 주면 내부에서 curl.exe를 이용해 서버로 전송합니다.

E:\sample\FileCounterSite> artifacts\Release\zip\DeployExtension.cmd https://...[생략]...xr6@[yoursitename].scm.azurewebsites.net/deploy

그런데 DeployExtension.cmd 안의 내용을 보면 curl.exe가 "%ProgramFiles(x86)%\git\bin" 폴더에 있다고 가정하기 때문에 curl.exe를 그 폴더에 넣어 두어야 합니다. 또는, 그냥 다음과 같이 curl.exe를 직접 실행해도 무방합니다.

[형식]
curl.exe -k -v -T "[업로드할 zip 파일 경로]" "[마지막 deploy 경로를 자른 Deployment Trigger Url]/zip"

curl로 실행할 때 주의할 것은 "Deployment Trigger Url"로 구한 "https://...[생략]...xr6@[yoursitename].scm.azurewebsites.net/deploy" 경로에서 마지막 "/deploy"를 "/zip"으로 교체해야 한다는 것입니다. 따라서 다음과 같이 실행하면 됩니다.

E:\sample\FileCounterSite> curl.exe -k -v -T "E:\sample\FileCounterSite\artifacts\Release\zip\SimpleWebSiteExtension.zip" "https://...[생략]...@[yoursitename].scm.azurewebsites.net/zip"

*   Trying 52.231.32.120...
* Connected to [yoursitename].scm.azurewebsites.net (52.231.32.120) port 443 (#0)
* schannel: SSL/TLS connection with [yoursitename].scm.azurewebsites.net port 443 (step 1/3)
...[생략]...
* schannel: decrypted data returned 409
* schannel: decrypted data buffer: offset 0 length 16384
< HTTP/1.1 200 OK
< Cache-Control: no-cache
< Pragma: no-cache
< Expires: -1
< Server: Microsoft-IIS/10.0
< x-ms-request-id: 834c7086-4afc-4c8a-a252-36294aa19b99
< X-AspNet-Version: 4.0.30319
< X-Powered-By: ASP.NET
< Set-Cookie: ARRAffinity=661589...[생략]...f0bb;Path=/;HttpOnly;Domain=[yoursitename].scm.azurewebsites.net
< Date: Wed, 18 Apr 2018 06:42:39 GMT
< Content-Length: 0
<
* Connection #0 to host [yoursitename].scm.azurewebsites.net left intact

위와 같이 배포 후 Azure Portal을 통해 해당 App Service를 재시작한 후 다음의 경로로 방문하면,

https://[yoursitename].scm.azurewebsites.net/filecounter

여러분들의 Web App 사이트에 몇 개의 파일이 있는지 보여주는 페이지가 뜨게 됩니다. 참고로, App Service를 재시작하지 않으면 다음과 같은 오류 화면만 보게 됩니다.

"No route registered for '/filecounter'"




curl.exe로 "Deployment Trigger Url(배포 트리거 URL)"에 배포하면 다음의 경로에 확장 파일들이 풀립니다.

%HOME%\SiteExtensions\filecounter
                            \applicationHost.xdt
                            \default.aspx

(%HOME% == d:\home)

2개의 배포 파일 내용은 다음과 같습니다.

[applicationHost.xdt 파일]

<?xml version="1.0"?>
<configuration xmlns:xdt="http://schemas.microsoft.com/XML-Document-Transform">
  <system.applicationHost>
    <sites>
      <site name="%XDT_SCMSITENAME%" xdt:Locator="Match(name)">
        <application path="/filecounter" xdt:Locator="Match(path)" xdt:Transform="Remove" />
        <application path="/filecounter" applicationPool="%XDT_APPPOOLNAME%" xdt:Transform="Insert">
          <virtualDirectory path="/" physicalPath="%XDT_EXTENSIONPATH%" />
        </application>
      </site>
    </sites>
  </system.applicationHost>
</configuration>

[default.aspx 파일]

<%@ language="C#" Debug="true" %>
<%@ Import Namespace="System.IO" %>

<%
    // Find the site's web root
    string folder = Environment.ExpandEnvironmentVariables(@"%HOME%\site\wwwroot");
    
    int fileCount = Directory.GetFiles(folder, "*.*", SearchOption.AllDirectories).Length;
%>

<h1>World's most amazing file counter</h1>
<h2>Your site has <%= fileCount %> files!</h2>

대충 감이 오시죠? ^^ 그러니까, Azure Web App 확장도 역시 하나의 웹 사이트일 뿐입니다. 참고로 FileCounter 확장에 대한 좀 더 자세한 설명은 다음의 글에서 읽어볼 수 있습니다.

Writing a Site Extension for Azure Websites
; https://azure.microsoft.com/en-us/blog/writing-a-site-extension-for-azure-websites/




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

[연관 글]






[최초 등록일: ]
[최종 수정일: 4/19/2018]

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)
11391정성태12/7/201721904개발 환경 구성: 340. WSL을 이용해 윈도우 PC 1대에서 openSUSE 응용 프로그램을 Visual Studio로 개발하는 방법 [1]
11390정성태12/7/201730799개발 환경 구성: 339. WSL을 이용해 윈도우 PC 1대에서 Linux 응용 프로그램을 Visual Studio로 개발하는 방법 [6]
11389정성태12/7/201719440오류 유형: 440. .NET Core 오류 - 0x80131620 Unable to load DLL 'libuv'
11388정성태12/6/201723239개발 환경 구성: 338. WSL 또는 Ubuntu에 닷넷 코어 설치 [3]
11387정성태12/6/201723205오류 유형: 439. 이벤트 로그 - Data Sharing Service 서비스의 %%3239247874 오류 메시지
11386정성태12/5/201719187오류 유형: 438. Hyper-V - '...' failed to add device 'Virtual CD/DVD Disk'
11385정성태12/5/201732355VC++: 121. DXGI를 이용한 윈도우 화면 캡처 소스 코드(Visual C++) [16]파일 다운로드1
11384정성태12/5/201721757오류 유형: 437. Visual C++ - Cannot open include file: 'SDKDDKVer.h'
11383정성태12/4/201724479디버깅 기술: 110. 비동기 코드 실행 중 예외로 인한 ASP.NET 프로세스 비정상 종료 현상 [1]
11382정성태12/4/201723165오류 유형: 436. System.Data.SqlClient.SqlException (0x80131904): Connection Timeout Expired 예외 발생 시 "[Pre-Login] initialization=48; handshake=1944;" 값의 의미
11381정성태11/30/201719722.NET Framework: 702. 한글이 포함된 바이트 배열을 나눈 경우 한글이 깨지지 않도록 다시 조합하는 방법(두 번째 이야기)파일 다운로드1
11380정성태11/30/201719829디버깅 기술: 109. windbg - (x64에서의 인자 값 추적을 이용한) Thread.Abort 시 대상이 되는 스레드를 식별하는 방법
11379정성태11/30/201719804오류 유형: 435. System.Web.HttpException - Session state has created a session id, but cannot save it because the response was already flushed by the application.
11378정성태11/29/201721632.NET Framework: 701. 한글이 포함된 바이트 배열을 나눈 경우 한글이 깨지지 않도록 다시 조합하는 방법 [1]파일 다운로드1
11377정성태11/29/201721212.NET Framework: 700. CommonOpenFileDialog 사용 시 사용자가 선택한 파일 목록을 구하는 방법 [3]파일 다운로드1
11376정성태11/28/201725797VS.NET IDE: 123. Visual Studio 편집기의 \r\n (crlf) 개행을 \n으로 폴더 단위로 설정하는 방법
11375정성태11/28/201719718오류 유형: 434. Visual Studio로 ASP.NET 디버깅 중 System.Web.HttpException - Could not load type 오류
11374정성태11/27/201725569사물인터넷: 14. 라즈베리 파이 - (윈도우의 NT 서비스처럼) 부팅 시 시작하는 프로그램 설정 [1]
11373정성태11/27/201724598오류 유형: 433. Raspberry Pi/Windows 다중 플랫폼 지원 컴파일 관련 오류 기록
11372정성태11/25/201727258사물인터넷: 13. 윈도우즈 사용자를 위한 라즈베리 파이 제로 W 모델을 설정하는 방법 [4]
11371정성태11/25/201721008오류 유형: 432. Hyper-V 가상 스위치 생성 시 Failed to connect Ethernet switch port 0x80070002 오류 발생
11370정성태11/25/201721203오류 유형: 431. Hyper-V의 Virtual Switch 생성 시 "External network" 목록에 특정 네트워크 어댑터 항목이 없는 경우
11369정성태11/25/201722928사물인터넷: 12. Raspberry Pi Zero(OTG)를 다른 컴퓨터에 연결해 가상 키보드 및 마우스로 쓰는 방법 (절대 좌표, 상대 좌표, 휠) [1]
11368정성태11/25/201728372.NET Framework: 699. UDP 브로드캐스트 주소 255.255.255.255와 192.168.0.255의 차이점과 이를 고려한 C# UDP 서버/클라이언트 예제 [2]파일 다운로드1
11367정성태11/25/201728890개발 환경 구성: 337. 윈도우 운영체제의 route 명령어 사용법
11366정성태11/25/201720806오류 유형: 430. 이벤트 로그 - Cryptographic Services failed while processing the OnIdentity() call in the System Writer Object.
... 91  92  93  94  95  96  97  98  99  100  101  102  [103]  104  105  ...