logo

English

이곳의 프로그래밍관련 정보와 소스는 마음대로 활용하셔도 좋습니다. 다만 쓰시기 전에 통보 정도는 해주시는 것이 예의 일것 같습니다. 질문이나 오류 수정은 siseong@gmail.com 으로 주세요. 감사합니다.

Ubuntu 18.04 에서 vsftpd 설치하기

by lizard2019 posted Mar 02, 2021
?

Shortcut

PrevPrev Article

NextNext Article

Larger Font Smaller Font Up Down Go comment Print
?

Shortcut

PrevPrev Article

NextNext Article

Larger Font Smaller Font Up Down Go comment Print

먼저 Ubuntu 버전부터 확인하겠습니다. $ lsb_release -a
No LSB modules are available.
Distributor ID: Ubuntu
Description: Ubuntu 18.04.1 LTS
Release: 18.04
Codename: bionic

그다음 package를 업데이트하고 vsftpd 데몬을 설치 합니다. $ sudo apt-get update $ sudo apt-get install vsftpd

vsftpd를 다시 시작해 줍니다. 그리고 ubuntu가 재시작 될때 같이 실행되도록 해줍니다.$ sudo systemctl stop vsftpd.service
$ sudo systemctl start vsftpd.service
$ sudo systemctl enable vsftpd.service

ftp에 사용할 계정을 만들어 줍니다. 저는 simon이라고 계정을 추가했습니다.$ sudo adduser simon

 

 

계정에 대한 home 디렉토리에 ftp폴더를 만들어 주고 권한을 변경합니다.$ sudo mkdir /home/simon/ftp
$ sudo chown nobody:nogroup /home/simon/ftp
$ sudo chmod a-w /home/simon/ftp/

 

ftp폴더 안에 files폴더를 만들고 테스트용 파일을 추가해 봅니다.$ sudo mkdir /home/simon/ftp/files
$ sudo chown tongchun:tongchun /home/simon/ftp/files
$ echo "vsftpd test file" | sudo tee /home/simon/ftp/files/test.txt

 

이제 vsftpd를 설정할 차례입니다.
설정하기 전 설정파일을 백업 카피 합니다.

$ sudo cp /etc/vsftpd.conf /etc/vsftpd.conf.orig

 

vsftpd.conf 파일을 열고 설정을 수정합니다.

$ sudo vim /etc/vsftpd.conf

 

default 설정이 있는데 모두 지워줍니다.
vim에서 모든 내용을 지우려면, gg 로 첫번째 줄로 이동합니다. 그리고 dG 로 현재 줄 이하의 내용을 지웁니다.그리고 아래 내용을 작성합니다.

listen=NO
listen_ipv6=YES
anonymous_enable=NO
local_enable=YES
write_enable=YES
local_umask=022
dirmessage_enable=YES
use_localtime=YES
xferlog_enable=YES
connect_from_port_20=YES
chroot_local_user=YES
secure_chroot_dir=/var/run/vsftpd/empty
pam_service_name=vsftpd
pasv_enable=Yes
pasv_min_port=10000
pasv_max_port=11000
user_sub_token=$USER
local_root=/home/$USER/ftp

userlist_enable=YES
userlist_file=/etc/vsftpd.userlist
userlist_deny=NO

 

설정과 같이 userlist를 만들어 줍니다.$ sudo vim /etc/vsftpd.userlist

 

vsftpd.userlist 파일에 앞서 만들었던 tongchun을 추가합니다.simon


vsftpd를 재시작 해줍니다.$ sudo systemctl restart vsftpd
 

 

이번엔 ssl/tls 설정을 하겠습니다.
cert 폴더를 만들고 pem 파일을 만들어 줍니다.
$ sudo openssl req -x509 -nodes -days 365 -newkey rsa:2048 -keyout /etc/cert/vsftpd.pem -out /etc/cert/vsftpd.pem

 

 

pem 파일을 만들때 Distinguished Name를 작성하라고 합니다. 자신의 정보를 입력하면 됩니다.

이제 ssl/tcl에 대한 설정을 추가해야 합니다.
vsftpd.conf 파일을 열고 아래와 같이 추가합니다.

$ sudo vim /etc/vsftpd.conf

rsa_cert_file=/etc/cert/vsftpd.pem
rsa_private_key_file=/etc/cert/vsftpd.pem
ssl_enable=YES
allow_anon_ssl=NO
force_local_data_ssl=YES
force_local_logins_ssl=YES
ssl_tlsv1=YES
ssl_sslv2=NO
ssl_sslv3=NO
require_ssl_reuse=NO
ssl_ciphers=HIGH


설정을 저장하고 vsftpd를 재시작 해줍니다.$ sudo systemctl restart vsftpd

 

 

이제 설정이 다 완료되었습니다.
서버에 방화벽이 설정되어 있다면 포트 포워딩을 설정해 주어야 합니다.
20,21 번 포트와 10000~11000 번 TCP 포트를 오픈해야 합니다.

이제 FileZilla를 실행시키고 접속해 보겠습니다.
호스트 IP와 추가한 계정/비번 그리포 21 포트로 연결합니다.
연결후 인증서가 보인다면 '이후 세션에서 항상 인증서 신뢰'를 체크해 줍니다.

접속 후 먼저 만들었던 test.txt 파일도 잘 보입니다.

TAG •

List of Articles
No. Subject Author Date Views
94 프로세스 능력 성숙도 모델(CMMI)의 적용 digipine 2017.10.28 456
93 포렌식을 활용한 정보보호 digipine 2017.11.02 335
92 초고속망 통신사 DNS 서버 주소 모음 - DNS 설정 digipine 2017.11.03 2228
91 임베디드SW 개발자센터 이용안내(성남시 분당구, 개발공간 무료제공) digipine 2017.11.02 323
90 유닉스/리눅스 명령어 레퍼런스 digipine 2017.11.03 471
89 윈도우즈 도스 커멘드(Command) 네트워크 관련 명령어 lizard2019 2019.02.07 827
88 윈도우 한영 전환 쉬프트 스페이스로 변경 digipine 2017.11.03 286
87 우분투 Nabi 한글 입력기 Tray(트레이) 상단 메뉴바로 옮기기 digipine 2017.11.03 667
86 우분투 18.04 MongoDB 설치 및 구성 lizard2019 2021.02.26 244
85 언어 IDE 별로 git ignore 파일을 자동으로 만들어 주는 사이트 엉뚱도마뱀 2018.12.17 8658
84 악성코드 종류 구분 digipine 2017.11.13 814
83 수학적 구조물 모델링 만들기 소개 비디오 엉뚱도마뱀 2018.09.24 951
82 소프트웨어 테스팅 전문가들을 위한 사이트 digipine 2017.11.02 286
81 비밀번호 해쉬에 Salt(소금) 첨가하기 file 엉뚱도마뱀 2017.11.23 3466
80 리눅스 커널의 Swap Memory에 대해서 digipine 2017.11.02 370
79 리눅스 /dev/random을 이용한 랜덤값 생성 엉뚱도마뱀 2017.11.22 964
78 대칭키 암호화관련 개념 정리 digipine 2017.11.09 1347
77 난수발생기 개론 엉뚱도마뱀 2017.11.22 2781
76 공짜 무료 C/C++ 컴파일러들 file digipine 2017.10.28 3869
75 [ubuntu, 우분투] sendmail 설치 digipine 2017.11.02 1827
Board Pagination Prev 1 2 3 4 5 Next
/ 5