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

비밀번호

댓글 작성자
 




... 46  47  48  49  50  51  52  53  [54]  55  56  57  58  59  60  ...
NoWriterDateCnt.TitleFile(s)
12585정성태4/5/202116873개발 환경 구성: 563. 기본 생성된 kubeconfig 파일의 내용을 새롭게 생성한 인증서로 구성하는 방법
12584정성태4/1/202118030개발 환경 구성: 562. kubeconfig 파일 없이 kubectl 옵션만으로 실행하는 방법
12583정성태3/29/202118976개발 환경 구성: 561. kubectl 수행 시 다른 k8s 클러스터로 접속하는 방법
12582정성태3/29/202118350오류 유형: 709. Visual C++ - 컴파일 에러 error C2059: syntax error: '__stdcall'
12581정성태3/28/202118332.NET Framework: 1031. WinForm/WPF에서 Console 창을 띄워 출력하는 방법 (2) - Output 디버깅 출력을 AllocConsole로 우회 [2]
12580정성태3/28/202116176오류 유형: 708. SQL Server Management Studio - Execution Timeout Expired.
12579정성태3/28/202116756오류 유형: 707. 중첩 가상화(Nested Virtualization) - The virtual machine could not be started because this platform does not support nested virtualization.
12578정성태3/27/202117199개발 환경 구성: 560. Docker Desktop for Windows 기반의 Kubernetes 구성 (2) - WSL 2 인스턴스에 kind가 구성한 k8s 서비스 위치
12577정성태3/26/202118859개발 환경 구성: 559. Docker Desktop for Windows 기반의 Kubernetes 구성 - WSL 2 인스턴스에 kind 도구로 k8s 클러스터 구성
12576정성태3/25/202116875개발 환경 구성: 558. Docker Desktop for Windows에서 DockerDesktopVM 기반의 Kubernetes 구성 (2) - k8s 서비스 위치
12575정성태3/24/202115453개발 환경 구성: 557. Docker Desktop for Windows에서 DockerDesktopVM 기반의 Kubernetes 구성 [1]
12574정성태3/23/202120974.NET Framework: 1030. C# Socket의 Close/Shutdown 동작 (동기 모드)
12573정성태3/22/202118353개발 환경 구성: 556. WSL 인스턴스 초기 설정 명령어 [1]
12572정성태3/22/202117704.NET Framework: 1029. C# - GC 호출로 인한 메모리 압축(Compaction)을 확인하는 방법파일 다운로드1
12571정성태3/21/202115750오류 유형: 706. WSL 2 기반으로 "Enable Kubernetes" 활성화 시 초기화 실패 [1]
12570정성태3/19/202121061개발 환경 구성: 555. openssl - CA로부터 인증받은 새로운 인증서를 생성하는 방법
12569정성태3/18/202121416개발 환경 구성: 554. WSL 인스턴스 export/import 방법 및 단축 아이콘 설정 방법
12568정성태3/18/202114776오류 유형: 705. C# 빌드 - Couldn't process file ... due to its being in the Internet or Restricted zone or having the mark of the web on the file.
12567정성태3/17/202116827개발 환경 구성: 553. Docker Desktop for Windows를 위한 k8s 대시보드 활성화 [1]
12566정성태3/17/202116635개발 환경 구성: 552. Kubernetes - kube-apiserver와 REST API 통신하는 방법 (Docker Desktop for Windows 환경)
12565정성태3/17/202113387오류 유형: 704. curl.exe 실행 시 dll not found 오류
12564정성태3/16/202114237VS.NET IDE: 160. 새 프로젝트 창에 C++/CLI 프로젝트 템플릿이 없는 경우
12563정성태3/16/202117127개발 환경 구성: 551. C# - JIRA REST API 사용 정리 (3) jira-oauth-cli 도구를 이용한 키 관리
12562정성태3/15/202117916개발 환경 구성: 550. C# - JIRA REST API 사용 정리 (2) JIRA OAuth 토큰으로 API 사용하는 방법파일 다운로드1
12561정성태3/12/202116633VS.NET IDE: 159. Visual Studio에서 개행(\n, \r) 등의 제어 문자를 치환하는 방법 - 정규 표현식 사용
12560정성태3/11/202117683개발 환경 구성: 549. ssh-keygen으로 생성한 PKCS#1 개인키/공개키 파일을 각각 PKCS8/PEM 형식으로 변환하는 방법
... 46  47  48  49  50  51  52  53  [54]  55  56  57  58  59  60  ...