네트워킹

오늘:
1,278
어제:
1,849
전체:
2,916,688

고객센타 : 070-7752-2000
팩스 : 070-7752-2001
휴대폰 : 010-9513-0019
email : voipkorea@yahoo.co.kr

국민은행
(주)제이에스솔루션
047101-04-155519

Flag Counter
■ 무료 : 유선 집전화 휴대폰 ( 한국 미국 중국 카나다) ↔ (국내 해외 여행자 상사 주재원 유학생) / 가입무 무제한무료■

https://blog.asamaru.net/2016/04/07/how-to-protect-ssh-with-fail2ban-on-centos-6-7/


SSH 무작위 로그인 시도 막기(With Fail2Ban on CentOS 6/7 + selinux)



linux 서버를 공개망에서 사용하면서 방화벽을 사용하지 않는 경우 ssh 로그인을 지속적으로 시도하는 로그를 볼 수 있다. 대부분 외국 IP 대역에서 지속적으로 ssh 로그인을 시도하는데 무작위 비밀번호를 대입하는 것이다. 당연히 방화벽을 설정하는 것이 당연하나 특수한 목적으로 인해 접속 IP 대역을 제한할 수 없는 경우도 있을 수 있다. 이런 경우에 보안을 조금이나마 강화하기 위해 사용할 수 있는 것이 fail2ban 이다.

우선 실제로 해당 서버에 어떤 IP들이 ssh 로그인을 시도했는지 아래의 명령으로 확인 할 수 있다(이하는 CentOS 7 기준이다).

아래는 로그인 시도 IP를 확인하는 방법이다.

$ ls /var/log/secure | xargs grep -E "[[:digit:]]+\.[[:digit:]]+\.[[:digit:]]+\.[[:digit:]]+" -o | sort | uniq

공개망에 연결된 서버라면 생각보다 많은 IP가 나와 놀랄수도 있다. IP들 중 자신이 아는 IP를 제외하면 대부분이 위에 언급한 공격일 확률이 높다.

다른 방법으로 아래와 같이 최근 로그인 실패 기록을 확인하는 것도 가능하다.

$ last -f /var/log/btmp | more

20 Linux Log Files that are Located under /var/log Directory에 보면 /var/log/btmp에 대한 설명을 확인 할 수 있다.

상황을 확인 했으니 이제 본격적으로 fail2ban을 사용해 보자.


fail2ban 설치

fail2ban은 지정된 시간 내에 지정된 횟수 이상으로 ssh 로그인을 실패하면 해당 IP에서의 접근을 지정된 시간만큼 차단하는 역할을 한다.

아래의 설치 과정은 CentOS 7을 기준으로 한다. 이는 iptables 대신 firewalld가 사용되며 systemd를 사용하는 것을 기준으로 한다는 뜻이다. CentOS 6이라면 아래의 참고자료를 살펴보기 바란다.

# epel-release 추가
$ rpm -Uvh https://dl.fedoraproject.org/pub/epel/epel-release-latest-7.noarch.rpm

# fail2ban 설치
$ yum install -y fail2ban

# fail2ban 기본 설정
$ hostname=`/bin/hostname`
$ echo "[DEFAULT]" > /etc/fail2ban/jail.local
# 1시간 동안 접근 제한
$ echo "bantime = 3600" >> /etc/fail2ban/jail.local
# 결과 수신 메일 지정
$ echo "destemail = ~~~@~~~.com" >> /etc/fail2ban/jail.local
# 결과 발신 메일 지정
$ echo "sender = root@$hostname" >> /etc/fail2ban/jail.local
$ echo "" >> /etc/fail2ban/jail.local
# ssh 접근 검사 활성화
$ echo "[sshd]" >> /etc/fail2ban/jail.local
$ echo "enabled = true" >> /etc/fail2ban/jail.local
# nginx-http-auth 접근 검사 활성화 : 필요시에만 사용
$ echo "" >> /etc/fail2ban/jail.local
$ echo "[nginx-http-auth]" >> /etc/fail2ban/jail.local
$ echo "enabled = true" >> /etc/fail2ban/jail.local

fail2ban 서비스 활성

$ systemctl enable fail2ban.service

fail2ban 서비스 시작

$ systemctl start fail2ban.service

selinux 사용시 fail2ban 관련 설정

이하는 selinux 사용시에만 적용하면 된다.

$ checkmodule -M -m -o fail2ban-syslog.mod fail2ban-syslog.te
$ semodule_package -o fail2ban-syslog.pp -m fail2ban-syslog.mod
$ semodule -r fail2ban-syslog
$ semodule -i fail2ban-syslog.pp
$ rm -f fail2ban-syslog.mod
$ rm -f fail2ban-syslog.pp
$ semodule -l|grep fail2ban-syslog

$ checkmodule -M -m -o logrotate-fail2ban.mod logrotate-fail2ban.te
$ semodule_package -o logrotate-fail2ban.pp -m logrotate-fail2ban.mod
$ semodule -r logrotate-fail2ban
$ semodule -i logrotate-fail2ban.pp
$ rm -f logrotate-fail2ban.mod
$ rm -f logrotate-fail2ban.pp
$ semodule -l|grep logrotate-fail2ban

아래의 2개의 파일은 위 스크립트 실행에 필요한 파일이므로 해당 파일명으로 저장해서 사용하면 된다.

fail2ban-syslog.te

module fail2ban-syslog 1.0;

require {
type syslogd_var_run_t;
type fail2ban_t;
class dir read;
class file read;
class file open;
class file getattr;
}

#============= fail2ban_t ==============
allow fail2ban_t syslogd_var_run_t:dir read;
allow fail2ban_t syslogd_var_run_t:file read;
allow fail2ban_t syslogd_var_run_t:file open;
allow fail2ban_t syslogd_var_run_t:file getattr;

logrotate-fail2ban.te

module logrotate-fail2ban 1.7;

require {
type fail2ban_client_exec_t;
type logrotate_t;
type init_var_lib_t;
class file { open read execute getattr write create execute_no_trans setattr unlink ioctl rename};
}

#============= logrotate_t ==============
allow logrotate_t fail2ban_client_exec_t:file execute_no_trans;
allow logrotate_t fail2ban_client_exec_t:file { open read execute ioctl };
allow logrotate_t init_var_lib_t:file { open read getattr write create unlink setattr rename };

설치가 다 되었다면 아래의 명령 실행시 다음과 비슷한 결과를 볼 수 있다.

$ firewall-cmd --direct --get-all-rules

ipv4 filter INPUT 0 -p tcp -m multiport --dports ssh -m set --match-set fail2ban-sshd src -j REJECT --reject-with icmp-port-unreachable

그리고 아래의 명령으로 적용 상황을 확인할 수 있다.

# fail2ban 상태 확인
$ fail2ban-client status sshd

Status for the jail: sshd
|- Filter
|  |- Currently failed: 1
|  |- Total failed: 153
|  `- File list:    /var/log/secure
`- Actions
   |- Currently banned: 0
   |- Total banned: 2
   `- Banned IP list:

# ipset에 설정(차단)된 내용 확인
$ ipset --list

Name: fail2ban-sshd
Type: hash:ip
Revision: 1
Header: family inet hashsize 1024 maxelem 65536 timeout 3600
Size in memory: 16656
References: 1
Members:

# fail2ban 로그 확인
$ cat /var/log/fail2ban.log

# 차단 IP 목록
$ awk '($(NF-1) = /Ban/){print $NF}' /var/log/fail2ban.log | sort | uniq -c | sort -n

참고자료

조회 수 :
1147
등록일 :
2017.09.12
20:28:02 (*.160.88.18)
엮인글 :
http://webs.co.kr/index.php?document_srl=3311868&act=trackback&key=3e9
게시글 주소 :
http://webs.co.kr/index.php?document_srl=3311868
List of Articles
번호 제목 글쓴이 날짜 조회 수
100 Lnux export how to new admin 2017-12-17  
99 What's the difference between “adduser” and “useradd”? admin 2017-12-15  
98 useradd Command 리눅스 admin 2017-12-15  
97 How To Install Java with Apt-Get on Ubuntu 16.04 oracle java admin 2017-10-13 865
96 우분투 Linux(Ubuntu)에 Java설치 및 환경 설정하는 방법 admin 2017-10-13 871
95 우분투 다운로드 사이트 주소 ubuntu download 16.04.3 17.04 site link admin 2017-10-13 871
94 How to install Java on linux with no Internet connectivity (using local repository) admin 2017-10-01 947
93 윈도우 ssh 접속 프로그램 admin 2017-09-29 964
92 openvpn Easy Windows Guide admin 2017-09-20 1010
91 OpenVPN - Getting started How-To admin 2017-09-20 1041
90 openssl 을 이용한 인증서 생성 절차를 정리한다. 개인키 CSR SSL 인증서 파일 생성 admin 2017-09-14 1121
89 How to Manually Unblock / Unban IP Address in fail2ban 차단풀기 admin 2017-09-12 1073
88 How To Protect SSH with fail2ban on Debian 7 데비안 ssh 방어 무작위 로그인 admin 2017-09-12 1089
» SSH 무작위 로그인 시도 막기(With Fail2Ban on CentOS 6/7 + selinux) admin 2017-09-12 1147
86 리눅스 데비안 네트워크 설정 유선랜 무선랜 linux debian network setting 설정 admin 2017-09-07 1227
85 linux debian 계열 network 설정 테트워크 데비안 admin 2017-09-07 1135
84 PUTTY DOWNLOAD - FREE SSH & TELNET CLIENT admin 2017-09-03 1566
83 debian 8.8 download cd1 cd2 cd3 etc admin 2017-09-03 1195
82 Debian Download 데비안 리눅스 다운로드 admin 2017-09-02 1547
81 데비안 리눅스 부팅시에 방화벽 서버에 자동실행 되게 설정 해보자 admin 2017-08-30 1219
80 리눅스 시작시에 부팅시 프로세스 프로그램 자동 실행 설정 admin 2017-08-30 1297
79 리눅스 시작시 부팅 시, 프로그램 자동실행 등록하기 admin 2017-08-30 1490
78 리눅스 부팅시 시작시 프로그램 명령어 실행하기 (Linux Init script) admin 2017-08-30 1337
77 리눅스 부팅시 자동 실행 명령스크립트 실행하기 만들기 이해 linux booting admin 2017-08-30 1331
76 부팅시 자동실행 명령어 스크립트, rc.local admin 2017-08-30 1430
75 the world’s most widely deployed RADIUS server document admin 2017-08-29 1315
74 네트워크 디바이스명 변경 리눅스 eth0 eth1 admin 2017-08-29 1495
73 Cloned VMware CentOS6 Server "device eth0 does not seem to be present, admin 2017-08-29 1281
72 VMWARE VM Error boot loader install grub - install /dev/sda or /dev/hda MBR linux admin 2016-01-27 1854
71 Linux and Unix touch command admin 2015-11-15 2174
70 Configuration of Red Hat 5.4 Xen for SR-IOV Support admin 2015-08-02 2419
69 apt-get install linux-image-2.6.26-2-686-bigmem admin 2015-06-27 2524
68 intel i210 driver install and compile debian admin 2015-06-27 3557
67 Debian / Ubuntu Linux Install Kernel Headers Package admin 2015-06-27 2500
66 mount -t auto /dev/sdb1 /mnt && ls /mnt admin 2015-06-27 2474
65 kali linux 해킹 hacking attack DDOS etc tools admin 2015-06-24 2939
64 sources.list lenny admin 2015-02-03 3280
63 Ubuntu 14.04 원격 접속(xrdp) 설정 admin 2014-12-21 9307
62 Remote Desktop Connection from Windows 7/8 to Ubuntu 14.04 admin 2014-12-21 3867
61 Using Windows RDP to Access your Ubuntu Instance admin 2014-12-21 3516
60 Install GUI on Ubuntu Server admin 2014-12-21 3727
59 How to start GUI from command line? admin 2014-12-21 3718
58 Download all files in a directory using WGET admin 2014-12-16 3729
57 문서 편집기 vi vim command 명령어 정리 admin 2014-10-29 5140
56 find 명령 사용 예제들 admin 2014-10-29 4258
55 특정 IP 엑세스 못하게 하는방법 admin 2014-10-29 4419
54 scp 명령어를 이용한 파일 복사 및 전송 admin 2014-10-29 5190
53 [리눅스] 소프트웨어 레이드의 리빌딩 및 리싱킹 속도를 높이는 5가지 방법 admin 2014-10-17 4678
52 /bin/false, /sbin/nologin 의 차이점 admin 2014-10-13 5540
51 리눅스 시스템 유저 추가 명령어 useradd 사용하기 admin 2014-08-09 4832
50 리눅스 시스템 시작시에 자동 실행할 파일 등록하기 admin 2014-03-22 22921
49 linux 에티터 명령어 정리 포그라운드 전환 : ctrl + z 다시 vi 모드로 돌아오려면 fg admin 2014-03-05 7481
48 Linux Memory Management – Virtual Memory and Demand Paging admin 2014-03-03 6635
47 iptables rules tcp drop all port except tcp 22 admin 2014-02-26 7977
46 seagate HD 시게이트 하드 디스크 A/S 에이에스 기간 조회 및 받는 3가지 방법 admin 2013-12-09 8382
45 SSH Without Authentication Using Key Files (CentOS 5.6) admin 2013-11-22 7390
44 Getting started with SSH public key cryptography admin 2013-09-05 11937
43 암호 없이 SSH 접속하기 admin 2013-09-05 7721
42 Linux Date Command Examples to Display and Set System Date Time admin 2013-07-11 9348
41 FreeRADIUS 설치(freeradius-sever-2.1.8) admin 2013-04-19 16378
40 Radius를 이용한 ssh 인증 서버 구축하기 admin 2013-04-19 12163
39 CentOS 5.4에서 RADIUS 서버 설치하기 admin 2013-04-19 20454
38 Event IP 20187 admin 2013-04-08 7649
37 리눅스에서 자바(JDK) 설치하기 admin 2013-04-08 8660
36 리눅스 네트워크 설정 멸령어 Linux admin 2013-04-08 8733
35 [linux]리눅스 버전및 CPU등 환경정보 확인하기 admin 2013-04-08 26621
34 Linux 시스템 백업과 복원 admin 2013-04-04 8008
33 tar로 전체시스템 백업 LINUX Backup admin 2013-04-04 18275
32 다운된 리눅스서버 응급복구 admin 2013-03-28 11334
31 Build a RADIUS server on Linux admin 2013-03-23 10381
30 Deploying FreeRADIUS with the MySQL Cluster Database file admin 2013-03-22 8274
29 FREE RADIUS 활용및 응용 admin 2013-02-23 18813
28 리눅스에 RADIUS 서버 구현하기 admin 2012-09-01 40514
27 Debian CD DVD 다운로드 링크 헤메지말고 바로 다운로드하지요 admin 2012-08-18 8907
26 Site builder shootout: Drupal vs. Joomla vs. WordPress admin 2012-07-15 28435
25 WinXP 부팅안되는 현상 NTLDR is missing 메세지 admin 2012-07-12 9531
24 윈도우XP 알면 정말 편한 숨겨진 기능 60가지 admin 2012-05-11 12111
23 한국인/국내기업은 얼마나 Linux Kernel에 기여할까? admin 2012-04-29 10313
22 scp, ssh, rsync등을 사용할때에 SSH 비밀번호 묻는것 피하기 admin 2012-04-15 10095
21 [Linux/SSL] 리눅스 서버에 Apache 2 설치 및 SSL 설정하기(mod_ssl, openssl) admin 2012-04-15 10899
20 리눅스의 막강한 네트워크 필터 iptables admin 2012-04-15 9257
19 Centos net install web http admin 2012-03-02 12883
18 Linux 시스템 백업과 복원 admin 2012-02-28 10215
17 검색 파일리스트 만든 다음 여러파일 한방에 압축하기 admin 2012-02-14 11016
16 linux 파티션 디렉토리 용량 확인방법 전체 폴더 크기 사이즈 admin 2012-01-05 11378
15 How to disable IPv6 in Debian Lenny and Squeeze admin 2011-12-29 9468
14 리눅스 네트워크 설정 LINUX admin 2011-12-19 10294
13 다양한 사운드 파일있는곳 admin 2011-12-19 8586
12 모든 CPU 벤치마크 수치 admin 2011-12-16 10459
11 Wireshark admin 2011-12-16 8832
10 스트리밍서버 / 윈도우서버 admin 2011-12-16 10078
9 무료백신 여러가지 분류해놓은곳 admin 2011-12-16 9081
8 윈도우 2003 작업 스케줄러 설정 admin 2011-12-16 13707
7 파이썬 설치 및 사용하기 admin 2011-12-16 11514
6 How to disable IPv6 in Debian , 리눅스 아이피설정 admin 2011-12-16 13800
5 리눅스 서버 이전시 고려할 사항들 admin 2011-12-16 12354
4 ftp 파일전송 여러파일을 한번에 통째로 전송 admin 2011-12-16 12033
3 리눅스 tar 압축 백업복원시 소유자 문제해결 admin 2011-12-16 11177
2 서버이전시 고려할 사항들 admin 2011-12-13 11880
1 Name Server 설정및 이해 admin 2011-12-13 8200