Skip to content
TUWLAB.com
모든 게시물에 대하여 '링크'
방식의 퍼가기만 허용합니다.
한양대학교 전자통신컴퓨터공학부
바라미
  • 182
  • 2590120
DNS Powered by DNSEver.com
Linux

iptables 명령을 이용하여 특정 IP대역 접속 차단하기

Posted 2013. 01. 08 Updated 2014. 11. 17 Views 19038 Replies 0

auth.log 파일을 살펴봤는데, 하루에만도 셀 수 없이 많은 해킹 시도가 있다는 것을 알 수 있었습니다.

도대체 이 서버 털어서 돈이나오는 것도 아니고, 밥이 나오는 것도 아닌데 왜 그짓들을 시도 하는건지 이해를 할 수가 없었습니다. 악성코드를 심어서 DDOS공격에라도 사용하려고 그런건지..

포트스캐닝이나, 무작위 ID/PW 대입으로 SSH 접속을 시도하는 로그기록도 쉽게 찾아 볼 수 있었습니다.

http://www.ip-adress.com에 추린 IP들을 입력해보니 열이면 아홉 중국에서 시도한 접속이었습니다.

본래 오늘 저녁밥 먹고 나서부터는 개발용 웹 페이지를 구축하려고 했습니다. 하지만 가장 중요한 보안상의 문제가 발견된 이상, 다른 일을은 일단 미뤄 두고 해킹을 시도한 IP들을 차단하는 작업부터 하기로 하였습니다.



iptables 명령


한 개의 IP 차단

iptables -A INPUT -s xxx.xxx.xxx.xxx -j DROP


IP 대역 차단

iptables -A INPUT -t filter -s xxx.xxx.xxx.xxx/yy -j DROP


IP 차단 해제

iptables -D INPUT -s xxx.xxx.xxx.xxx -j DROP


IP 차단 목록 보기

iptables -L


목록 전체 삭제

iptables -F INPUT



특정 국가의 IP주소 일괄 차단하기

차단할 IP 주소들을 추리다보니 죄다 중국 IP들이었습니다. 이것들을 보일때마다 차단 등록 한다고 해도, 매번 다른 IP에서 공격이 들어올테니 부질 없는 헛짓일 것입니다.

잠시 명상(?)을 하며 스마트한 해결책을 찾다가 중국 IP대역을 모두 차단하기로 마음먹고 방법을 찾아 나섰습니다. 중국에서 이곳 서버로 접속하는 시도는 정보를 얻는 시도라기 보다는 악의적인 목적이 월등히 더 많을거라는 판단에서였습니다.

역시 구글신의 도움으로 쉽게 방법을 찾을 수가 있었습니다.

우선, IP 대역 DB 파일 얻기위해 다음 사이트에 접속해서 최신 버전의 GeoIPCountryCSV.zip을 다운받아 압축을 풀어둡니다.

http://dev.maxmind.com/geoip/legacy/geolite/

GeoIPCountryWhois.csv 파일이 나오는데, 이 파일이 각 국가의 IP 할당 정보가 들어 있는 DB 파일입니다.

그리고 다음과 같은 스크립트를 만들어 위 DB파일과 같은 디렉토리에 ipban.sh로 저장합니다.

여기서는 중국 IP 대역만 차단하기 위해 5번째 줄에 "China"라고 썼는데, 다른 국가를 차단하고 싶다면 이 부분을 해당 국가로 바꾸면 됩니다. 국가별 표기 방법은 csv파일을 열어서 찾아보면 알 수 있습니다.

#!/bin/sh

SRC=./GeoIPCountryWhois.csv

for BANIP in `egrep "China" $SRC | cut -d, -f1,2 | sed -e 's/"//g' | sed -e 's/,/-/g'`
	do
		/sbin/iptables -A INPUT -p all -m iprange --src-range $BANIP -j DROP
 	done

ipban.sh 파일에 실행 권한을 준 뒤, 터미널에서 실행하면 특정 IP 대역의 접속을 모조리 차단할 수 있습니다.


TAG •
서비스 선택
이용중인 SNS 버튼을 클릭하여 로그인 해주세요.
SNS 계정을 통해 로그인하면 회원가입 없이 댓글을 남길 수 있습니다.
댓글
?
Powered by SocialXE

List of Articles
번호 분류 제목 글쓴이 최근 수정일 조회 수
193 Linux 한글 입력기 나비(Nabi)에서 한/영 키가 인식되지 않는 경우 file TUW 2017.06.02 2409
192 Linux [VirtualBox] Windows 7 물리 디스크 부팅 (Raw Disk Booting or Native Booting) - 방법 1 file TUW 2017.06.14 2956
191 Linux [Linux] Screen 터미널 에뮬레이션 프로그램 사용하기 TUW 2015.08.19 3044
190 Linux Intelli Backup: File system 및 Database 백업 자동화 Bash 스크립트 TUW 2017.06.14 3257
189 Linux [VirtualBox] 가상머신 Windows 7 에서 Aero 기능 활성화하기 file TUW 2017.06.02 3312
188 Python VirtualEnv를 통한 Python Sandbox 개발환경 구축하기 file TUW 2017.06.02 3773
187 Python [Django Tutorial] 7. 백엔드 콘솔에 Custom Command 추가하기 file TUW 2017.06.16 3779
186 일반 GitLab 코드리뷰 페이지 탭 크기(Tab Size) 4칸으로 바꾸기 file TUW 2021.12.28 3896
185 일반 [TeraTerm] 명령줄 인수와 공개키 인증으로 간편하게 SSH 접속하기 TUW 2018.11.06 4581
184 일반 Linux에서 Code Composer Studio (CCS) - Ti ARM 개발환경 구축하기 file TUW 2017.06.02 4674
183 일반 [GIT] 임시 저장소 사용하기: stash TUW 2015.11.27 4775
182 Python [Django Tutorial] 8. Production - setting.py설정, Static파일 모으기 TUW 2017.06.16 5014
181 Linux [VirtualBox] Windows 7 물리 디스크 부팅 (Raw Disk Booting or Native Booting) - 배경 file TUW 2017.06.02 5429
180 AVR [전자동 커튼] 2차 설치, 또 다시 발견된 문제점 file TUW 2017.06.02 5897
179 일반 [WSL] Windows Subsystem for Linux - Bash.exe를 Ubuntu와 유사하게 설정하기 file TUW 2021.12.28 5921
178 Python [Django Tutorial] 2. 개발 환경 세팅하기 - pyenv 및 virtualenv 활용 TUW 2017.02.26 6081
목록
Board Pagination Prev 1 2 3 4 5 6 7 ... 13 Next
/ 13

Powered by Xpress Engine / Designed by Sketchbook

sketchbook5, 스케치북5

sketchbook5, 스케치북5