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

(시리즈 글이 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 App Service - Kudu SSH 환경에서 FTP를 이용한 파일 전송

Azure App Service의 Kudu SSH 환경에서 ftp를 사용하려면 우선 클라이언트부터 설치해야 합니다.

# apt install ftp

참고로, SSH로 들어갈 때마다 매번 저렇게 설치를 해야 합니다. (해당 인스턴스 환경이 cache되는 동안만 유효한 듯!)

그다음 FTP 세션으로 들어가 연결을 하고 로그인까지 마칩니다.

# ftp
> open 100.10.5.1
220 Microsoft FTP Service
Name (100.10.5.1:root): testusr
331 Password required
Password:
230 User logged in.
Remote system type is Windows_NT.

이후 파일 전송을 하면 되는데 다음과 같은 식으로 오류가 발생할 수 있습니다.

ftp> put /home/site/wwwroot/logs/t1.log
local: /home/site/wwwroot/logs/t1.log remote: /home/site/wwwroot/logs/t1.log
501 Server cannot accept argument.
ftp: bind: Address already in use

ftp> put /home/site/wwwroot/logs/t1.log /t1.log
local: /home/site/wwwroot/logs/t1.log remote: /t1.log
501 Server cannot accept argument.

왜냐하면 기본적으로 Active 모드로 동작하기 때문입니다. 따라서 Passive 모드로 변경을 하고,

ftp> passive
Passive mode on.

다시 put 명령어로 파일 전송을 하면 됩니다.

ftp> put /home/site/wwwroot/logs/t1.log /t1.log
local: /home/site/wwwroot/logs/t1.log remote: /t1.log
227 Entering Passive Mode (100,10,5,1,191,115).
125 Data connection already open; Transfer starting.
226 Transfer complete.
19495005 bytes sent in 0.22 secs (86.4566 MB/s)

원하는 동작을 모두 완료했으면 quit 명령어로 세션을 나갑니다.

ftp> quit
221 Goodbye.




참고로, put 명령어에 파일의 full path를 적어주면 remote 측도 그렇게 경로 구성이 되어 있어야 합니다. 그렇지 않은 경우 다음과 같은 식으로 오류가 발생하는데요,

ftp> put /home/site/wwwroot/logs/t1.log
local: /home/site/wwwroot/logs/t1.log remote: /home/site/wwwroot/logs/t1.log
501 Server cannot accept argument.

이럴 때는 put 명령어의 2번째 인자에 원격 측의 경로를 함께 기입하면 됩니다.

ftp> put /home/site/wwwroot/logs/t1.log /t1.log
local: /home/site/wwwroot/logs/t1.log remote: /t1.log
227 Entering Passive Mode (100,10,5,1,191,115).
125 Data connection already open; Transfer starting.
226 Transfer complete.
19495005 bytes sent in 0.22 secs (86.4566 MB/s)




한 가지 주의할 점이 있는데요, Linux의 ftp도 기본적으로는 FTP over SSL 기능을 지원하지 않습니다. 따라서, 대상 FTP 서버에서 "over SSL" 기능을 풀어야 하는데요, 예를 들어 지난번의 글에 설정한 FTP 서비스라면,

Azure - 윈도우 VM에서 FTP 여는 방법
; https://www.sysnet.pe.kr/2/0/12854

IIS의 "FTP SSL Settings"를 통해 "Require SSL connections"로 지정된 기본값을 "Allow SSL connection"으로 낮춰야 합니다. 물론, 이렇게 하면 평문으로 암호가 전달되기 때문에 Azure App Service <-> Azure VM 간의 통신에는 그나마 안전할 수 있지만, 자칫 외부에서 접속을 한다거나 할 때 평문 암호 전달이 될 수 있으므로 심각한 보안 허점이 될 수 있습니다. 따라서 그런 경우에는 NSG의 설정을 통해,

Azure VM의 서비스를 Azure Web App Service에서만 접근하도록 NSG 설정을 제한하는 방법
; https://www.sysnet.pe.kr/2/0/12704

FTP 서비스 포트에 대해 Azure 내부에서만 통신을 허용하는 식으로 구성하는 것이 바람직합니다.




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







[최초 등록일: ]
[최종 수정일: 11/14/2021]

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

비밀번호

댓글 작성자
 




... 31  32  33  34  35  36  37  38  39  40  41  [42]  43  44  45  ...
NoWriterDateCnt.TitleFile(s)
12922정성태1/14/202216280개발 환경 구성: 625. AKS - Azure Kubernetes Service 생성 및 SLO/SLA 변경 방법
12921정성태1/14/202213198개발 환경 구성: 624. Docker Desktop에서 별도 서버에 설치한 docker registry에 이미지 올리는 방법
12920정성태1/14/202214579오류 유형: 786. Camtasia - An error occurred with the camera: Failed to Add Video Sampler.
12919정성태1/13/202214082Windows: 199. Host Network Service (HNS)에 의해서 점유되는 포트
12918정성태1/13/202214970Linux: 47. WSL - shell script에서 설정한 환경 변수가 스크립트 실행 후 반영되지 않는 문제
12917정성태1/12/202214322오류 유형: 785. C# - The type or namespace name '...' could not be found (are you missing a using directive or an assembly reference?)
12916정성태1/12/202213352오류 유형: 784. TFS - One or more source control bindings for this solution are not valid and are listed below.
12915정성태1/11/202214268오류 유형: 783. Visual Studio - We didn't find any interpreters
12914정성태1/11/202217751VS.NET IDE: 172. 비주얼 스튜디오 2022의 파이선 개발 환경 지원
12913정성태1/11/202218016.NET Framework: 1133. C# - byte * (바이트 포인터)를 FileStream으로 쓰는 방법 [1]
12912정성태1/11/202217391개발 환경 구성: 623. ffmpeg.exe를 사용해 비디오 파일의 이미지를 PGM(Portable Gray Map) 파일 포맷으로 출력하는 방법 [1]
12911정성태1/11/202213752VS.NET IDE: 171. 비주얼 스튜디오 - 더 이상 만들 수 없는 "ASP.NET Core 3.1 Web Application (.NET Framework)" 프로젝트
12910정성태1/10/202214930제니퍼 .NET: 30. 제니퍼 닷넷 적용 사례 (8) - CPU high와 DB 쿼리 성능에 문제가 함께 있는 사이트
12909정성태1/10/202215829오류 유형: 782. Visual Studio 2022 설치 시 "Couldn't install Microsoft.VisualCpp.Redist.14.Latest"
12908정성태1/10/202213100.NET Framework: 1132. C# - ref/out 매개변수의 IL 코드 처리
12907정성태1/9/202214815오류 유형: 781. (youtube-dl.exe) 실행 시 "This app can't run on your PC" / "Access is denied." 오류 발생
12906정성태1/9/202216865.NET Framework: 1131. C# - 네임스페이스까지 동일한 타입을 2개의 DLL에서 제공하는 경우 충돌을 우회하는 방법 [1]파일 다운로드1
12905정성태1/8/202216024오류 유형: 780. Could not load file or assembly 'Microsoft.VisualStudio.TextTemplating.VSHost.15.0, Version=16.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a' or one of its dependencies.
12904정성태1/8/202217995개발 환경 구성: 623. Visual Studio 2022 빌드 환경을 위한 github Actions 설정 [1]
12903정성태1/7/202217064.NET Framework: 1130. C# - ELEMENT_TYPE_INTERNAL 유형의 사용 예
12902정성태1/7/202215949오류 유형: 779. SQL 서버 로그인 에러 - provider: Shared Memory Provider, error: 0 - No process is on the other end of the pipe.
12901정성태1/5/202216809오류 유형: 778. C# - .NET 5+에서 warning CA1416: This call site is reachable on all platforms. '...' is only supported on: 'windows' 경고 발생
12900정성태1/5/202218939개발 환경 구성: 622. vcpkg로 ffmpeg를 빌드하는 경우 생성될 구성 요소 제어하는 방법
12899정성태1/3/202218498개발 환경 구성: 621. windbg에서 python 스크립트 실행하는 방법 - pykd (2)
12898정성태1/2/202219165.NET Framework: 1129. C# - ffmpeg(FFmpeg.AutoGen)를 이용한 비디오 인코딩 예제(encode_video.c) [1]파일 다운로드1
12897정성태1/2/202216351.NET Framework: 1128. C# - 화면 캡처한 이미지를 ffmpeg(FFmpeg.AutoGen)로 동영상 처리 [4]파일 다운로드1
... 31  32  33  34  35  36  37  38  39  40  41  [42]  43  44  45  ...