KR101448953B1 - 보안 장치 및 그것의 동작 방법 - Google Patents

보안 장치 및 그것의 동작 방법 Download PDF

Info

Publication number
KR101448953B1
KR101448953B1 KR1020120131716A KR20120131716A KR101448953B1 KR 101448953 B1 KR101448953 B1 KR 101448953B1 KR 1020120131716 A KR1020120131716 A KR 1020120131716A KR 20120131716 A KR20120131716 A KR 20120131716A KR 101448953 B1 KR101448953 B1 KR 101448953B1
Authority
KR
South Korea
Prior art keywords
address
management
packet
addresses
dns
Prior art date
Application number
KR1020120131716A
Other languages
English (en)
Other versions
KR20140064410A (ko
Inventor
임진우
Original Assignee
주식회사 시큐아이
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by 주식회사 시큐아이 filed Critical 주식회사 시큐아이
Priority to KR1020120131716A priority Critical patent/KR101448953B1/ko
Publication of KR20140064410A publication Critical patent/KR20140064410A/ko
Application granted granted Critical
Publication of KR101448953B1 publication Critical patent/KR101448953B1/ko

Links

Images

Classifications

    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L63/00Network architectures or network communication protocols for network security
    • H04L63/02Network architectures or network communication protocols for network security for separating internal from external traffic, e.g. firewalls
    • H04L63/0227Filtering policies
    • H04L63/0236Filtering by address, protocol, port number or service, e.g. IP-address or URL
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L61/00Network arrangements, protocols or services for addressing or naming
    • H04L61/30Managing network names, e.g. use of aliases or nicknames
    • H04L61/3015Name registration, generation or assignment
    • H04L61/3025Domain name generation or assignment
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L63/00Network architectures or network communication protocols for network security
    • H04L63/14Network architectures or network communication protocols for network security for detecting or protecting against malicious traffic
    • H04L63/1408Network architectures or network communication protocols for network security for detecting or protecting against malicious traffic by monitoring network traffic

Landscapes

  • Engineering & Computer Science (AREA)
  • Computer Networks & Wireless Communication (AREA)
  • Signal Processing (AREA)
  • Computer Security & Cryptography (AREA)
  • Computer Hardware Design (AREA)
  • Computing Systems (AREA)
  • General Engineering & Computer Science (AREA)
  • Data Exchanges In Wide-Area Networks (AREA)

Abstract

본 발명은 네트워크에 관한 것으로, 좀 더 구체적으로는 보안 장치 및 그것의 동작 방법에 관한 것이다. 본 발명의 실시 예에 따른 보안 장치의 동작 방법은 복수의 호스트 컴퓨터들과 인터넷 망 사이에서 통신되는 패킷을 모니터링하고, 패킷이 DNS 응답 패킷으로 판별될 때 도메인 네임에 대응하는 아이피 주소를 추출하고, 관리 아이피 주소들 중 추출된 아이피 주소와 일치하는 관리 아이피 주소의 시간 정보를 갱신하는 것을 포함한다. 그리고, 관리 아이피 주소들 중 설정된 시간을 경과할 때까지 미 갱신된 시간 정보를 갖는 관리 아이피 주소는 무효화(invalid)된다.

Description

보안 장치 및 그것의 동작 방법{SECURITY SYSTEM AND OPERATING METHOD THEREOF}
본 발명은 네트워크에 관한 것으로, 좀 더 구체적으로는 보안 장치 및 그것의 동작 방법에 관한 것이다.
인터넷 상에서 도메인 네임(예를 들면, Fully Qualified Domain Name, FQDN)을 관리하는 시스템으로서 도메인 네임 시스템(DNS: Domain Name System)이 이용되고 있다. 이를 이용하면, 도메인 네임과 해당 서버 컴퓨터의 아이피 주소(Internet Protocol Address)를 맵핑(mapping)시켜 DNS 서버(server)에 등록한 상태에서, 호스트 컴퓨터(예를 들면, 클라이언트 컴퓨터)의 사용자는 아이피 주소를 입력할 필요없이 도메인 네임을 입력하여 도메인 네임에 대응하는 아이피 주소가 무엇인지를 DNS 서버에 먼저 요청하고, DNS 서버로부터 해당 아이피 주소를 제공받으면 아이피 주소가 가리키는 서버 컴퓨터에 접속할 수 있게 된다. 도메인 네임 시스템을 이용함으로써, 기억하기 힘든 아이피 주소 대신에 도메인 네임을 입력함으로써 해당 서버 컴퓨터에 접속할 수 있다.
하나의 도메인 네임에는 복수의 아이피 주소들이 대응할 수 있다. 예를 들면, 하나의 도메인 네임에 대응하는 웹 사이트를 각각 제공하는 복수의 서버 컴퓨터들이 운용될 수 있다. 이러한 복수의 서버 컴퓨터들은, 예를 들면 동일한 운영자에 의해 관리되고, 동일한 내용의 웹 사이트를 제공할 수 있다.
보안 장치가 그것이 관리하는 호스트 컴퓨터들이 어떤 서버 컴퓨터들에 접속하는지 인지하고 관리하기 위해서는, 서버 컴퓨터들에 대응하는 아이피 주소들이 효율적으로 수집 및 업데이트될 필요가 있다.
본 발명은 호스트 컴퓨터들 의해 접속되는 서버들의 아이피 주소들을 효율적으로 수집하고, 수집된 아이피 주소들 중 불필요한 아이피 주소들을 삭제하여 내부 저장 공간을 효율적으로 확보하고 의도치 않은 동작을 방지하는 보안 장치 및 그것의 동작 방법을 제공하는 것이다.
본 발명의 실시 예에 따른 보안 장치의 동작 방법은 복수의 호스트 컴퓨터들과 인터넷 망 사이에서 통신되는 패킷을 모니터링하는 단계; 상기 패킷이 DNS 서버로부터 상기 인터넷 망을 통해 수신되는 DNS 응답 패킷으로 판별될 때, 상기 패킷으로부터 도메인 네임에 대응하는 아이피 주소를 추출하는 단계; 및 관리 아이피 주소들 중 상기 추출된 아이피 주소와 일치하는 관리 아이피 주소의 시간 정보를 갱신하는 단계를 포함하되, 상기 관리 아이피 주소들 중 설정된 시간을 경과할 때까지 미 갱신된 시간 정보를 갖는 관리 아이피 주소는 무효화(invalid)된다.
실시 예로서, 상기 동작 방법은 상기 패킷이 상기 DNS 응답 패킷이 아닌 노멀 패킷으로 판별될 때, 상기 패킷의 출발지 아이피 주소 또는 목적지 아이피 주소가 상기 관리 아이피 주소들 중 어느 하나의 유효한 관리 아이피 주소와 일치하는지 판별하는 단계; 상기 패킷의 출발지 아이피 주소 또는 목적지 아이피 주소가 상기 어느 하나의 유효한 관리 아이피 주소와 일치할 때 상기 패킷을 차단하는 단계; 및 상기 패킷의 출발지 아이피 주소 또는 목적지 아이피 주소가 상기 어느 하나의 유효한 관리 아이피 주소와도 일치하지 않을 때 상기 패킷을 허용하는 단계 더 포함할 수 있다.
실시 예로서, 상기 관리 아이피 주소의 시간 정보를 갱신하는 단계는 상기 관리 아이피 주소들 중 상기 추출된 아이피 주소와 일치하는 관리 아이피 주소가 존재할 때 수행된다. 이때, 상기 동작 방법은 상기 관리 아이피 주소들 중 상기 추출된 아이피 주소와 일치하는 관리 아이피 주소가 존재하지 않을 때, 상기 추출된 아이피 주소를 상기 관리 아이피 주소들에 포함시키는 단계를 더 포함한다. 그리고, 추출된 아이피 주소가 상기 관리 아이피 주소들에 포함될 때 상기 추출된 아이피 주소와 관련된 해당 시간 정보가 저장될 것이다.
실시 예로서, 상기 동작 방법은 상기 복수의 호스트 컴퓨터들로부터 상기 인터넷 망을 통해 상기 DNS 서버에 전송되는 복수의 DNS 쿼리 패킷들을 검출하고, 상기 복수의 DNS 쿼리 패킷들에 대한 정보를 저장하는 단계를 더 포함할 수 있다. 이때, 상기 아이피 주소를 추출하는 단계는 상기 복수의 DNS 쿼리 패킷들 중 상기 DNS 응답 패킷에 대응하는 DNS 쿼리 패킷이 존재하는지 여부를 판별하고, 판별 결과에 따라 상기 아이피 주소를 추출하는 단계를 포함한다.
본 발명의 다른 일면은 보안 장치에 관한 것이다. 본 발명의 실시 예에 따른 보안 장치의 동작 방법은 복수의 관리 아이피 주소들을 저장하는 저장 유닛;
상기 복수의 관리 아이피 주소들을 이용하여 인터넷 망에 연결된 복수의 호스트 컴퓨터들을 관리하는 보안 유닛; 및 상기 복수의 호스트 컴퓨터들과 상기 인터넷 망 사이에서 통신되는 패킷이 DNS 서버로부터 상기 인터넷 망을 통해 수신되는 DNS 응답 패킷으로 판별될 때, 상기 패킷으로부터 도메인 네임에 대응하는 아이피 주소를 추출하고 상기 관리 아이피 주소들 중 상기 추출된 아이피 주소와 일치하는 관리 아이피 주소의 시간 정보를 갱신하도록 구성되는 스니핑 유닛을 포함하되, 상기 스니핑 유닛은 상기 관리 아이피 주소들 중 설정된 시간을 경과할 때까지 미 갱신된 시간 정보를 갖는 관리 아이피 주소를 무효화하도록 구성된다.
본 발명의 실시 예에 따르면, 호스트 컴퓨터들 의해 접속되는 서버들의 아이피 주소들을 효율적으로 수집하고 수집된 아이피 주소들 중 불필요한 아이피 주소들을 삭제하여 내부 저장 공간을 효율적으로 확보하고 의도치 않은 동작을 방지하는 보안 장치 및 그것의 동작 방법이 제공된다.
도 1은 본 발명의 실시 예에 따른 보안 장치를 포함하는 네트워크를 보여주는 블록도이다.
도 2는 본 발명의 실시 예에 따른 도 1의 보안 장치의 동작 방법을 보여주는 순서도이다.
도 3은 DNS 응답 패킷의 헤더의 데이터 포맷을 예시적으로 보여주는 도면이다.
도 4는 아이피 주소 테이블을 보여주는 도면이다.
도 5는 아이피 주소 테이블의 관리 아이피 주소들을 관리하는 방법을 보여주는 순서도이다.
도 6은 본 발명의 다른 실시 예에 따른 도 1의 보안 장치의 동작 방법을 보여주는 순서도이다.
도 7은 DNS 쿼리 패킷을 획득하는 방법을 보여주는 순서도이다.
도 8은 본 발명의 또 다른 실시 예에 따른 도 1의 보안 장치의 동작 방법을 보여주는 순서도이다.
본 발명의 이점 및 특징, 그리고 그것을 달성하는 방법은 첨부되는 도면과 함께 상세하게 후술되어 있는 실시 예들을 통해 설명될 것이다. 그러나 본 발명은 여기에서 설명되는 실시 예들에 한정되지 않고 다른 형태로 구체화될 수도 있다. 단지, 본 실시 예들은 본 발명이 속하는 기술분야에서 통상의 지식을 가진 자에게 본 발명의 기술적 사상을 용이하게 실시할 수 있을 정도로 상세히 설명하기 위하여 제공되는 것이다.
명세서 전체에서, 어떤 부분이 다른 부분과 "연결"되어 있다고 할 때, 이는 "직접적으로 연결"되어 있는 경우뿐 아니라, 그 중간에 다른 소자를 사이에 두고 "간접적으로 연결"되어 있는 경우도 포함한다. 명세서 전체에서, 어떤 부분이 어떤 구성요소를 "포함"한다고 할 때, 이는 특별히 반대되는 기재가 없는 한 다른 구성요소를 제외하는 것이 아니라 다른 구성요소를 더 포함할 수 있는 것을 의미한다.
도 1은 본 발명의 실시 예에 따른 보안 장치(110)를 포함하는 네트워크(100)를 보여주는 블록도이다.
도 1을 참조하면, 네트워크(100)는 복수의 호스트 컴퓨터들(PC1~PCk), 보안 장치(110), 인터넷 망(120), DNS(Domain Name System) 서버(130) 및 복수의 서버 컴퓨터들(141~14n)을 포함한다.
복수의 호스트 컴퓨터들(PC1~PCk)은 보안 장치(110)를 통해 인터넷 망(120)에 연결된다. 복수의 호스트 컴퓨터들(PC1~PCk)은 도메인 네임에 대응하는 아이피 주소를 DNS 서버(130)로부터 제공받아, 복수의 서버 컴퓨터들(141~14n) 중 제공받은 아이피 주소에 대응하는 서버 컴퓨터에 접속할 수 있다.
먼저, 복수의 호스트 컴퓨터들(PC1~PCk) 중 어느 하나, 예를 들면 제 1 호스트 컴퓨터(PC1)는 도메인 네임에 대응하는 아이피 주소(Internet Protocol Address)를 요청하기 위한 DNS 쿼리 패킷을 DNS 서버(130)에 전송한다. 그리고, 제 1 호스트 컴퓨터(PC1)는 DNS 서버(130)로부터 제공된 DNS 응답 패킷을 수신하여, 수신된 DNS 응답 패킷으로부터 아이피 주소를 얻을 수 있다. 제 1 호스트 컴퓨터(PC1)는, 이후에 목적지 아이피 주소가 DNS 응답 패킷으로부터 얻어진 아이피 주소로서 정의되고 출발지 아이피 주소가 제 1 호스트 컴퓨터(PC1)에 대응하는 아이피 주소로서 정의된 노멀 패킷을 인터넷 망(120)을 통해 전송하고, 목적지 아이피 주소가 제 1 호스트 컴퓨터(PC1)에 대응하는 아이피 주소로서 정의되고 출발지 아이피 주소가 DNS 응답 패킷으로부터 얻어진 아이피 주소로서 정의된 노멀 패킷을 수신함으로써 해당 서버 컴퓨터에 접속할 것이다.
보안 장치(110)는 복수의 호스트 컴퓨터들(PC1~PCk)을 관리하도록 구성된다. 보안 장치(110)는 보안 유닛(111), 스니핑 유닛(112) 및 저장 유닛(113)을 포함한다. 보안 유닛(111)은 기 설정된 보안 정책들에 따라 복수의 호스트 컴퓨터들(PC1~PCk)에 송수신되는 패킷들을 관리하도록 구성될 것이다. 실시 예로서, 보안 유닛(111)은 기 설정된 보안 정책들에 따라 인터넷 망(120)과 복수의 호스트 컴퓨터들(PC1~PCk) 사이에서 전송되는 패킷들을 차단 또는 허용하도록 구성될 수 있다. 그러한 차단 또는 허용은 저장 유닛(113)에 저장된 아이피 주소 테이블(도 4의 T 참조)에 기반하여 수행될 것이다. 저장 유닛(113)에 저장된 아이피 주소 테이블을 참조하여, 보안 유닛(111)은 복수의 호스트 컴퓨터들(PC1~PCk)과 인터넷 망(120) 사이에서 통신되는 패킷들 각각의 출발지 아이피 주소 또는 목적지 아이피 주소가 아이피 주소 테이블 내의 관리 아이피 주소들 중 하나와 일치하는지 판별하고, 판별 결과에 따라 해당 패킷을 차단하도록 구성된다.
패킷들 각각의 출발지 아이피 주소 또는 목적지 아이피 주소가 아이피 주소 테이블 내의 관리 아이피 주소들 중 어느 하나와 일치할 때, 보안 유닛(111)은 해당 패킷을 차단할 것이다. 패킷들 각각의 출발지 아이피 주소 또는 목적지 아이피 주소가 아이피 주소 테이블 내의 관리 아이피 주소들과 일치하지 않을 때, 보안 유닛(111)은 해당 패킷을 허용할 것이다.
스니핑 유닛(112)은 각 호스트 컴퓨터가 도메인 네임과 관련하여 DNS 서버(130)로부터 부여받는 아이피 주소들을 수집하도록 구성된다. 즉, 스니핑 유닛(112)은 복수의 호스트 컴퓨터들(PC1~PCk)과 인터넷 망(120) 사이에서 통신되는 패킷이 DNS 응답 패킷인지 여부를 판별하고, DNS 응답 패킷으로부터 아이피 주소를 획득한다. 그리고, 스니핑 유닛(112)은 획득된 아이피 주소를 저장 유닛(113)의 아이피 주소 테이블에 관리 아이피 주소로서 갱신한다. 이에 따라, 보안 장치(110)는 호스트 컴퓨터들(PC1~PCk)에 의해 사용되는 아이피 주소들을 효율적으로 수집할 수 있다.
본 발명의 실시 예에 따르면, 스니핑 유닛(112)은 관리 아이피 주소를 저장할 때 해당 시간 정보를 더 저장한다. 이때, 시간 정보는 관리 아이피 주소가 갱신된 시점을 의미할 수 있다. 다른 실시 예로서, 시간 정보는 관리 아이피 주소가 저장된 시점으로부터 카운트되는 수일 수 있다.
만약, 획득된 아이피 주소가 아이피 주소 테이블 내에 이미 존재한다면, 존재하는 해당 관리 아이피 주소의 시간 정보가 갱신될 것이다. 만약, 획득된 아이피 주소가 아이피 주소 테이블 내에 존재하지 않는다면, 획득된 아이피 주소는 관리 아이피 주소로서 저장되고, 이때 해당 시간 정보도 함께 저장될 것이다.
본 발명의 실시 예에 따르면, 스니핑 유닛(112)은 아이피 주소 테이블의 관리 아이피 주소들 중 설정된 시간을 경과할 때까지 갱신되지 않은 시간 정보를 갖는 관리 아이피 주소를 검출한다. 그리고, 스니핑 유닛(112)은 검출된 관리 아이피 주소를 무효화할 수 있다. 예를 들면, 스니핑 유닛(112)은 검출된 관리 아이피 주소를 아이피 주소 테이블에서 삭제할 수 있다. 이러한 동작은 미리 정해진 시간 단위로 반복적으로 수행될 수 있다.
설정된 시간을 경과할 때까지 갱신되지 않은 시간 정보를 갖는 관리 아이피 주소는, 호스트 컴퓨터들(PC1~PCk)에 의해 더 이상 사용되지 않을 것으로 예측될 수 있다. 본 발명의 실시 예에 따른 스니핑 유닛(112)은 이러한 관리 아이피 주소를 삭제한다. 이에 따라, 호스트 컴퓨터의 삭제된 관리 아이피 주소에 대한 접속은 허용될 것이다. 즉, 본 발명의 실시 예에 따르면, 보안 장치(111)에 의한 의도치 않은 아이피 주소에 대한 차단은 방지될 것이다.
DNS 서버(130)는 인터넷 망(120)을 통하여 보안 장치(110) 및 복수의 호스트 컴퓨터들(PC1~PCk)에 연결된다. DNS 서버(130)는 각 호스트 컴퓨터로부터 수신된 DNS 쿼리 패킷에 응답하여 DNS 응답 패킷을 해당 호스트 컴퓨터에 제공하도록 구성된다.
DNS 서버(130)는 각 도메인 네임에 대응하는 아이피 주소들에 대한 정보를 저장할 것이다. 저장된 정보에 기반하여, DNS 서버(130)는 DNS 쿼리 패킷의 도메인 네임이 어떤 아이피 주소에 대응하는지 검색하고 검색된 아이피 주소를 포함하는 DNS 응답 패킷을 인터넷 망(120)을 통해 해당 호스트 컴퓨터에 제공한다.
하나의 도메인 네임에 복수의 아이피 주소들이 대응할 때, DNS 서버(130)는 동일한 목적지(예를 들면, 동일한 호스트 컴퓨터)로부터 반복적으로 DNS 쿼리 패킷들이 전송되더라도 한정된 개수의 아이피 주소들만을 해당 호스트 컴퓨터에 제공할 수 있다. 각 호스트 컴퓨터는 제 1 내지 제 n 서버 컴퓨터들(141~14n) 중 한정된 개수의 서버 컴퓨터들과 통신할 수 있다.
보안 장치(110)가 하나의 도메인 네임에 대응하는 아이피 주소들을 수집하기 위해 DNS 쿼리 패킷들을 반복적으로 DNS 서버(130)에 전송한다고 가정한다. DNS 서버(130)는 동일한 목적지인 보안 장치(110)로부터 수신되는 DNS 쿼리 패킷들에 응답하여 한정된 개수의 아이피 주소들만을 보안 장치(110)에 제공할 것이다. 이러한 방법에 따르면, 보안 장치(110)은 호스트 컴퓨터들(PC1~PCk)이 특정한 도메인 네임과 관련하여 통신하는 서버 컴퓨터들(141~14n)의 아이피 주소들을 획득하기 어렵다.
본 발명의 실시 예에 따르면, 스니핑 유닛(112)은 호스트 컴퓨터들(PC1~PCk)과 인터넷 망(120) 사이에서 통신되는 패킷들을 모니터링하고, 그러한 패킷들로부터 DNS 응답 패킷을 구별하고, 구별된 DNS 응답 패킷으로부터 아이피 주소를 획득한다. 획득된 아이피 주소는 저장 유닛(113)에 관리 아이피 주소로서 저장된다. 따라서, 적어도 호스트 컴퓨터들(PC1~PCk)이 해당 도메인 네임과 관련하여 통신하는 아이피 주소들은 스니핑 유닛(112)에 의해 효율적으로 수집될 수 있다.
또한, 본 발명의 실시 예에 따르면, 스니핑 유닛(112)은 저장 유닛(113)에 저장된 관리 아이피 주소를 삭제할 수 있다. 따라서, 보안 장치(111)에 의한 의도치 않은 아이피 주소에 대한 차단은 방지될 것이다.
제 1 내지 제 n 서버 컴퓨터들(141~14n)은 인터넷 망(120)을 통해 제 1 내지 제 k 호스트 컴퓨터들(PC1~PCk)과 통신하도록 구성된다. 제 1 내지 제 n 서버 컴퓨터들(141~14n)에 각각 대응하는 아이피 주소들은 상이하다. 그러나, 제 1 내지 제 n 서버 컴퓨터들(141~14n) 각각은 하나의 도메인 네임에 대응하는 웹 사이트를 제공한다.
도 1에서, 보안 유닛(111), 스니핑 유닛(112) 및 저장 장치(113)는 복수의 물리적인 장치들에 의해 구현될 수도 있고, 하나의 물리적인 장치에 의해 구현될 수 있음이 이해될 것이다. 예를 들면, 보안 유닛(111) 및 스니핑 유닛(112) 각각은 소프트웨어(software)를 이용하거나 펌웨어(firmware)를 이용하는 등 다양한 방식들을 이용하여 구현되고, 저장 장치(113)는 램(RAM, Random Access Memory)과 같은 저장 매체를 이용하여 구현될 수 있다.
도 2는 본 발명의 실시 예에 따른 도 1의 보안 장치(110)의 동작 방법을 보여주는 순서도이다.
도 2를 참조하면, S110단계에서, 스니핑 유닛(112)은 복수의 호스트 컴퓨터들(PC1~PCk)과 인터넷 망(120) 사이에서 통신되는 패킷을 모니터링한다. 복수의 호스트 컴퓨터들(PC1~PCk)과 DNS 서버(130) 사이에서 송수신되는 패킷은 DNS 패킷이라고 정의된다. 이때, 각 호스트 컴퓨터로부터 DNS 서버(130)에 전송되는 패킷은 DNS 쿼리 패킷으로 정의되고, DNS 서버(130)로부터 각 호스트 컴퓨터에 전송되는 패킷은 DNS 응답 패킷으로 정의된다. 한편, 복수의 호스트 컴퓨터들(PC1~PCk)은 인터넷 망(120)을 통해 서버 컴퓨터들(141~14n)과 통신할 수 있다. 복수의 호스트 컴퓨터들(PC1~PCk)과 서버 컴퓨터들(141~14n) 사이에서 송수신되는 패킷은 노멀 패킷으로 정의된다.
이하, 설명의 편의를 위해 도 2를 참조한 설명에서는 제 1 호스트 컴퓨터(PC1)가 DNS 서버(130)와 DNS 패킷을 송수신하는 경우를 일 예로서 설명한다.
S120단계에서, 스니핑 유닛(112)은 해당 패킷이 DNS 서버(130)로부터 전송되는 DNS 응답 패킷인지 여부를 판별한다. 해당 패킷이 DNS 응답 패킷인지 여부는 해당 패킷의 헤더에 기반하여 판별될 수 있다. 이는 도 3을 참조하여 더 상세히 설명된다.
만약 해당 패킷이 DNS 응답 패킷인 경우, S130단계가 수행된다.
S130단계에서, 스니핑 유닛(112)은 DNS 응답 패킷으로부터 도메인 네임에 대응하는 아이피 주소를 추출한다. DNS 응답 패킷은 도메인 네임에 대응하는 아이피 주소를 요청하는 DNS 쿼리 패킷에 응답하여 제공되는 것이고, 따라서 도메인 네임에 대응하는 아이피 주소를 포함한다. 추출된 아이피 주소는, 제 1 내지 제 n 서버 컴퓨터들(141~14n) 중 하나를 가리키는 주소일 것이다.
S140단계에서, 스니핑 유닛(112)은 아이피 주소 테이블에 추출된 아이피 주소와 일치하는 관리 아이피 주소들이 존재하는지 판별한다. 만약 그러한 경우, S150단계가 수행된다. 만약 그렇지 않은 경우, S160단계가 수행된다. 아이피 주소 테이블에 대해서는 도 4를 참조하여 더 상세히 설명된다.
S150단계에서, 스니핑 유닛(112)은 아이피 주소 테이블 내의 해당 관리 아이피 주소의 시간 정보를 갱신한다. S160단계에서, 스니핑 유닛(112)은 아이피 주소 테이블에 추출된 아이피 주소를 관리 아이피 주소로서 리스트시키고, 해당 시간 정보도 함께 아이피 주소 테이블에 저장될 것이다. 이에 따라, 아이피 주소 테이블은 호스트 컴퓨터들(PC1~PCk)이 언제 아이피 주소들에 접속하였는지에 대한 시간 정보를 포함할 수 있다.
도 3은 DNS 응답 패킷의 헤더(DNS_HD)의 데이터 포맷을 예시적으로 보여주는 도면이다.
도 3을 참조하면, DNS 응답 패킷의 헤더(DNS_HD)는 제 1 내지 제 3 플래그 정보(11~13), 목적지 아이피 주소(DP) 및 도메인 주소(DN)를 포함한다. 제 1 플래그 정보(11)는 해당 패킷이 DNS 패킷인지 또는 노멀(normal) 패킷인지 여부를 나타낸다. 실시 예로서, 제 1 플래그 정보(11)는 해당 패킷의 출발지 포트(source port)의 아이피 주소(도 1의 SP 참조)일 수 있다. 그리고, 제 1 플래그 정보(11)가 DNS 서버(130)를 가리키는지에 따라 해당 패킷이 DNS 패킷인지 판별될 수 있다.
목적지 아이피 주소(DP)는 DNS 응답 패킷이 전송될 목적지 포트(destination port)의 아이피 주소이다.
예를 들면, 제 1 플래그 정보(11), 목적지 아이피 주소(DP), 도메인 네임(DN)은 DNS 응답 패킷의 헤더(DNS_HD) 중 TCP(Transmission Control Protocol) 헤더에 포함될 수 있다.
제 2 플래그 정보(12)는 해당 패킷이 DNS 쿼리 패킷인지 또는 DNS 응답 패킷인지 여부를 나타낸다. 예를 들면, 제 2 플래그 정보(12)는 1 데이터 비트로 구성되고, 제 2 플래그 정보(12)가 논리 상태 "1"이면 해당 패킷이 DNS 응답 패킷이고, 제 2 플래그 정보(12)가 논리 상태 "0"이면 해당 패킷이 DNS 쿼리 패킷임을 의미할 수 있다.
제 3 플래그 정보(13)는 해당 패킷이 DNS 응답 패킷인 경우 해당 아이피 주소가 존재하는지 여부 및 해당 아이피 주소의 개수를 나타낸다.
DNS 응답 패킷은 복수의 호스트 컴퓨터들(PC1~PCk) 중 어느 하나로부터의 DNS 쿼리 패킷에 따라 제공되는 것이고, DNS 쿼리 패킷은 도메인 네임에 대응하는 아이피 주소를 묻는 패킷이므로, DNS 응답 패킷에는 아이피 주소(IP)가 포함된다.
예를 들면, 제 2 및 제 3 플래그 정보(12, 13), 그리고 아이피 주소(IP)는 DNS 응답 패킷의 헤더(DNS_HD) 중 DNS 헤더에 포함될 수 있다.
호스트 컴퓨터들(PC1~PCk)과 인터넷 망(120) 사이에서 통신되는 패킷들이 DNS 응답 패킷인지 여부는 제 1 내지 제 3 플래그 정보(11~13)에 기반하여 판별될 수 있다.
도 4는 아이피 주소 테이블(T)을 보여주는 도면이다.
도 4를 참조하면, 아이피 주소 테이블(T)은 도메인 네임들(DN1~DNn) 각각에 대응하는 관리 아이피 주소들을 포함한다. 스니핑 유닛(112)은 DNS 응답 패킷이 검출될 때마다 추출된 아이피 주소를 해당 도메인 네임과 매칭하여 관리 아이피 주소로서 아이피 주소 테이블(T)에 추가한다.
아이피 주소 테이블(T)에는 관리 아이피 주소들에 각각 대응하는 시간 정보들(t1~t9)이 포함된다. 시간 정보들(t1~t9) 각각은 해당 관리 아이피 주소가 검출될 때마다 갱신된다. 따라서, 시간 정보들(t1~t9) 각각은 해당 관리 아이피 주소가 가장 최근에 검출된 시간을 의미한다.
스니핑 유닛(112)은 설정된 시간을 경과할 때까지 갱신되지 않는 시간 정보를 갖는 관리 아이피 주소를 아이피 주소 테이블(T)에서 제외시킬 것이다. 이는 도 5를 참조하여 더 상세히 설명된다.
도 5는 아이피 주소 테이블(T)의 관리 아이피 주소들을 관리하는 방법을 보여주는 순서도이다.
도 5를 참조하면, 스니핑 유닛(112)은 임계 시간에 도달하는지 여부를 판별하고(S210), 임계 시간에 도달할 때 S220단계를 수행한다. 즉, S220단계는 임계 시간마다 반복하여 수행된다.
S220단계에서, 스니핑 유닛(112)은 관리 아이피 주소들 중 설정된 시간을 경과할 때까지 미 갱신된 시간 정보를 갖는 관리 아이피 주소를 무효화한다. 즉, 해당 관리 아이피 주소는 아이피 주소 테이블(T)에서 제외된다.
도 6은 본 발명의 다른 실시 예에 따른 도 1의 보안 장치(110)의 동작 방법을 보여주는 순서도이다.
도 6을 참조하면, S310, S320, S340~S370 단계들은 도 2의 S110~S160단계들과 각각 마찬가지로 설명된다. 이하, 중복되는 설명은 생략된다.
S330단계에서, 스니핑 유닛(112)은 DNS 응답 패킷에 대응하는 DNS 쿼리 패킷이 DNS 서버(130)에 전송되었는지 여부를 판별한다. 이를 위해, 스니핑 유닛(112)은 제 1 호스트 컴퓨터(PC1)로부터 DNS 서버(130)에 DNS 쿼리 패킷이 전송될 때, 이에 대한 정보를 저장한다. 이는, 도 6을 참조하여 더 상세히 설명된다.
공격 등의 다양한 목적들로서, DNS 쿼리 패킷이 발생하지 않았음에도 인터넷 망(120)을 통해 호스트 컴퓨터들(PC1~PCk) 중 적어도 하나, 예를 들면, 제 1 호스트 컴퓨터(PC1)로 DNS 응답 패킷이 전송될 수 있다. 이러한 DNS 응답 패킷은 DNS 서버(13)에 의해 발생되지 않고 다른 임의의 서버에 의해 발생될 것이다.
이러한 경우, DNS 응답 패킷의 신뢰성은 매우 낮다. 이러한 DNS 응답 패킷의 헤더(DNS_HD)에도 도 3을 참조하여 설명된 바와 동일한 제 1 내지 제 3 플래그 정보(11~13)가 포함될 수 있다. 따라서, 스니핑 유닛(112)이 해당 패킷이 DNS 응답 패킷인지 여부를 DNS 응답 패킷의 헤더(DNS_HD)만으로 판단하는 경우, 잘못된 아이피 주소를 수집할 수 있다.
이 실시 예에 따르면, 해당 패킷이 DNS 응답 패킷인지 여부가 DNS 응답 패킷의 헤더(HD)에 기반하여 판별되고, 제 1 호스트 컴퓨터(PC1)가 DNS 쿼리 패킷을 전송하였는지 여부를 추가적으로 체크한다. 만약 DNS 쿼리 패킷이 전송되었던 경우, S340단계가 수행된다.
도 7은 DNS 쿼리 패킷을 획득하는 방법을 보여주는 순서도이다.
도 7을 참조하면, 스니핑 유닛(112)은 복수의 호스트 컴퓨터들(PC1~PCk)과 인터넷 망(120) 사이에서 통신되는 패킷을 모니터링하고(S210), 해당 패킷이 DNS 쿼리 패킷인지 여부를 판별한다(S220). DNS 쿼리 패킷은 도메인 네임에 대응하는 아이피 주소를 묻는 패킷으로서, 제 1 호스트 컴퓨터(PC1)로부터 DNS 서버(130)로 전송된다. 예를 들면, 해당 패킷이 DNS 쿼리 패킷인지 여부는 해당 패킷의 헤더, 예를 들면 목적지 아이피 주소에 의해 판별될 수 있다. 해당 패킷이 DNS 쿼리 패킷이면, 스니핑 유닛(112)은 DNS 쿼리 패킷에 대한 정보를 저장한다(S230). 이러한 DNS 쿼리 패킷에 대한 정보는 도 6의 S330단계에서 사용될 것이다.
도 8은 본 발명의 또 다른 실시 예에 따른 도 1의 보안 장치(110)의 동작 방법을 보여주는 순서도이다.
도 8을 참조하면, S510~S550단계들은 각각 S110~S150단계들과 마찬가지로 설명된다. 이하, 중복되는 설명은 생략된다.
S570단계에서, 보안 유닛(111)은 해당 패킷이 노멀 패킷인 경우, 패킷의 출발지 또는 목적지 주소가 아이피 주소 테이블(T, 도 4 참조)의 유효한 관리 아이피 주소와 일치하는지 여부를 판별한다. 보인 유닛(111)은 저장 유닛(113)으로부터 아이피 주소 테이블에 해당하는 데이터를 수신하고, 수신된 데이터에 기반하여 판별을 수행할 것이다. 만약 그러한 경우, S580단계가 수행된다. 만약 그렇지 않은 경우, S590단계가 수행된다.
S580단계에서, 보안 유닛(111)은 해당 패킷을 차단한다. S590단계에서, 보안 유닛(111)은 해당 패킷을 허용한다.
본 발명의 실시 예에 따르면, 호스트 컴퓨터들 의해 접속되는 서버들의 아이피 주소들이 효율적으로 수집될 뿐만 아니라, 수집된 아이피 주소들 중 불필요한 아이피 주소들은 삭제된다. 이에 따라, 삭제된 아이피 주소에 접속하는 것은 허용되는 것과 동시에 내부 저장 공간이 효율적으로 확보될 수 있다.
본 발명의 상세한 설명에서는 구체적인 실시 예에 관하여 설명하였으나, 본 발명의 범위와 기술적 사상에서 벗어나지 않는 한도 내에서 다양한 변경이 가능하다. 그러므로 본 발명의 범위는 상술한 실시 예에 국한되어 정해져서는 안되며 후술하는 특허청구범위뿐만 아니라 이 발명의 특허청구범위와 균등한 것들에 의해 정해져야 한다.
PC1~PCk: 제 1 내지 제 k 호스트 컴퓨터들
110: 보안 장치
120: 인터넷 망
130: DNS 서버
141~14n: 제 1 내지 제 n 서버 컴퓨터들

Claims (12)

  1. 인터넷 망과 복수의 호스트 컴퓨터들을 사이에서, 상기 복수의 호스트 컴퓨터들을 관리하는 보안 장치의 동작 방법에 있어서:
    상기 복수의 호스트 컴퓨터들과 상기 인터넷 망 사이에서 통신되는 패킷을 모니터링하는 단계;
    상기 패킷이 DNS 서버로부터 상기 인터넷 망을 통해 수신되는 DNS 응답 패킷으로 판별될 때, 상기 패킷으로부터 도메인 네임에 대응하는 아이피 주소를 추출하는 단계; 및
    관리 아이피 주소들 중 상기 추출된 아이피 주소와 일치하는 관리 아이피 주소의 시간 정보를 갱신하는 단계를 포함하되,
    상기 관리 아이피 주소들 중 설정된 시간을 경과할 때까지 미 갱신된 시간 정보를 갖는 관리 아이피 주소는 무효화(invalid)되며,
    상기 설정된 시간을 경과할 때까지 미 갱신된 시간 정보를 갖는 상기 관리 아이피 주소는 삭제되는 동작 방법.
  2. 삭제
  3. 제 1 항에 있어서,
    상기 패킷이 상기 DNS 응답 패킷이 아닌 노멀 패킷으로 판별될 때, 상기 패킷의 출발지 아이피 주소 또는 목적지 아이피 주소가 상기 관리 아이피 주소들 중 어느 하나의 유효한 관리 아이피 주소와 일치하는지 판별하는 단계;
    상기 패킷의 출발지 아이피 주소 또는 목적지 아이피 주소가 상기 어느 하나의 유효한 관리 아이피 주소와 일치할 때 상기 패킷을 차단하는 단계; 및
    상기 패킷의 출발지 아이피 주소 또는 목적지 아이피 주소가 상기 어느 하나의 유효한 관리 아이피 주소와도 일치하지 않을 때 상기 패킷을 허용하는 단계를 더 포함하는 동작 방법.
  4. 제 1 항에 있어서,
    상기 도메인 네임에 대응하는 상기 아이피 주소를 요청하기 위한 DNS 쿼리 패킷에 따라, 상기 DNS 응답 패킷은 상기 DNS 서버로부터 상기 복수의 호스트 컴퓨터들 중 어느 하나에 제공되고,
    상기 DNS 쿼리 패킷은 상기 복수의 호스트 컴퓨터들 중 어느 하나에서 발생되는 동작 방법.
  5. 제 1 항에 있어서,
    상기 관리 아이피 주소의 시간 정보를 갱신하는 단계는 상기 관리 아이피 주소들 중 상기 추출된 아이피 주소와 일치하는 관리 아이피 주소가 존재할 때 수행되며,
    상기 관리 아이피 주소들 중 상기 추출된 아이피 주소와 일치하는 관리 아이피 주소가 존재하지 않을 때, 상기 추출된 아이피 주소를 상기 관리 아이피 주소들에 포함시키는 단계를 더 포함하는 동작 방법.
  6. 제 5 항에 있어서,
    상기 추출된 아이피 주소가 상기 관리 아이피 주소들에 포함될 때 상기 추출된 아이피 주소와 관련된 해당 시간 정보가 저장되는 동작 방법.
  7. 제 1 항에 있어서,
    상기 복수의 호스트 컴퓨터들로부터 상기 인터넷 망을 통해 상기 DNS 서버에 전송되는 복수의 DNS 쿼리 패킷들을 검출하고, 상기 복수의 DNS 쿼리 패킷들에 대한 정보를 저장하는 단계를 더 포함하고,
    상기 아이피 주소를 추출하는 단계는 상기 복수의 DNS 쿼리 패킷들 중 상기 DNS 응답 패킷에 대응하는 DNS 쿼리 패킷이 존재하는지 여부를 판별하고, 판별 결과에 따라 상기 아이피 주소를 추출하는 단계를 포함하는 동작 방법.
  8. 복수의 관리 아이피 주소들을 저장하는 저장 유닛;
    상기 복수의 관리 아이피 주소들을 이용하여 인터넷 망에 연결된 복수의 호스트 컴퓨터들을 관리하는 보안 유닛; 및
    상기 복수의 호스트 컴퓨터들과 상기 인터넷 망 사이에서 통신되는 패킷이 DNS 서버로부터 상기 인터넷 망을 통해 수신되는 DNS 응답 패킷으로 판별될 때, 상기 패킷으로부터 도메인 네임에 대응하는 아이피 주소를 추출하고 상기 관리 아이피 주소들 중 상기 추출된 아이피 주소와 일치하는 관리 아이피 주소의 시간 정보를 갱신하도록 구성되는 스니핑 유닛을 포함하되,
    상기 스니핑 유닛은 상기 관리 아이피 주소들 중 설정된 시간을 경과할 때까지 미 갱신된 시간 정보를 갖는 관리 아이피 주소를 무효화(invalid)하도록 구성되며,
    상기 스니핑 유닛은 상기 설정된 시간을 경과할 때까지 미 갱신된 시간 정보를 갖는 상기 관리 아이피 주소를 삭제하도록 구성되는 보안 장치.
  9. 삭제
  10. 제 8 항에 있어서,
    상기 패킷이 상기 DNS 응답 패킷이 아닌 노멀 패킷으로 판별될 때, 상기 보안 장치는 상기 패킷의 출발지 아이피 주소 또는 목적지 아이피 주소가 상기 관리 아이피 주소들 중 어느 하나의 유효한 관리 아이피 주소와 일치하는지 판별하고, 판별 결과에 따라 상기 패킷을 차단 또는 허용하도록 구성되는 보안 장치.
  11. 제 8 항에 있어서,
    상기 관리 아이피 주소의 시간 정보가 갱신되는 것은 상기 관리 아이피 주소들 중 상기 추출된 아이피 주소와 일치하는 관리 아이피 주소가 존재할 때 수행되며,
    상기 스니핑 유닛은 상기 관리 아이피 주소들 중 상기 추출된 아이피 주소와 일치하는 관리 아이피 주소가 존재하지 않을 때, 상기 추출된 아이피 주소를 상기 저장 유닛에 저장하여 상기 관리 아이피 주소들에 포함시키도록 구성되는 보안 장치.
  12. 제 11 항에 있어서,
    상기 스니핑 유닛은 상기 추출된 아이피 주소가 상기 저장 유닛에 저장될 때 상기 저장 유닛에 상기 추출된 아이피 주소와 관련된 시간 정보를 더 저장하도록 구성되는 보안 장치.
KR1020120131716A 2012-11-20 2012-11-20 보안 장치 및 그것의 동작 방법 KR101448953B1 (ko)

Priority Applications (1)

Application Number Priority Date Filing Date Title
KR1020120131716A KR101448953B1 (ko) 2012-11-20 2012-11-20 보안 장치 및 그것의 동작 방법

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
KR1020120131716A KR101448953B1 (ko) 2012-11-20 2012-11-20 보안 장치 및 그것의 동작 방법

Publications (2)

Publication Number Publication Date
KR20140064410A KR20140064410A (ko) 2014-05-28
KR101448953B1 true KR101448953B1 (ko) 2014-10-13

Family

ID=50891849

Family Applications (1)

Application Number Title Priority Date Filing Date
KR1020120131716A KR101448953B1 (ko) 2012-11-20 2012-11-20 보안 장치 및 그것의 동작 방법

Country Status (1)

Country Link
KR (1) KR101448953B1 (ko)

Families Citing this family (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN107534690A (zh) 2015-08-31 2018-01-02 慧与发展有限责任合伙企业 采集域名系统流量

Citations (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
KR100732689B1 (ko) * 2005-05-13 2007-06-27 (주)트리니티소프트 웹 보안방법 및 그 장치

Patent Citations (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
KR100732689B1 (ko) * 2005-05-13 2007-06-27 (주)트리니티소프트 웹 보안방법 및 그 장치

Also Published As

Publication number Publication date
KR20140064410A (ko) 2014-05-28

Similar Documents

Publication Publication Date Title
JP6564937B2 (ja) コンテンツ指向ネットワーキング(ccn)ネットワークにおいてデータをプッシュするための方法および装置
US8539577B1 (en) System and method for fast flux detection
KR101416523B1 (ko) 보안 시스템 및 그것의 동작 방법
US20100138921A1 (en) Countering Against Distributed Denial-Of-Service (DDOS) Attack Using Content Delivery Network
WO2018107784A1 (zh) 检测网页后门的方法和装置
US11696110B2 (en) Distributed, crowdsourced internet of things (IoT) discovery and identification using Block Chain
CN105610867B (zh) 一种dns防劫持方法和装置
EP2336890A1 (en) Root cause analysis method targeting information technology (it) device not to acquire event information, device and program
US20120297478A1 (en) Method and system for preventing dns cache poisoning
WO2017148158A1 (zh) 一种家庭网关利用云平台识别接入设备类型的系统
EP3306900B1 (en) Dns routing for improved network security
CN106453229B (zh) 用于检测对域名系统记录系统的更新的方法、系统和介质
CN102137111A (zh) 一种防御cc攻击的方法、装置和内容分发网络服务器
CN110430188A (zh) 一种快速url过滤方法及装置
CN101325553B (zh) Iscsi数据穿越nat的方法和内网存储系统
KR101448953B1 (ko) 보안 장치 및 그것의 동작 방법
KR101429107B1 (ko) 서브 도메인 네임을 수집하는 보안 장치 및 그것의 동작 방법
KR101429120B1 (ko) 서브 도메인 네임을 수집하는 보안 시스템 및 그것의 동작 방법
KR101645222B1 (ko) 어드밴스드 도메인 네임 시스템 및 운용 방법
KR101603694B1 (ko) 공유 단말 식별 방법 및 그 시스템
KR101603692B1 (ko) 공유 단말 식별 방법 및 그 시스템
CN109257453B (zh) 在多租户保护存储部署中防止数据泄露企图的基于本地数据ip的网络安全的系统和方法
KR101400136B1 (ko) 보안 시스템 및 그것의 동작 방법
KR20150061350A (ko) 공유 단말 식별 방법 및 그 시스템
JP2010206411A (ja) Dnsサーバー装置

Legal Events

Date Code Title Description
A201 Request for examination
E902 Notification of reason for refusal
E601 Decision to refuse application
AMND Amendment
X701 Decision to grant (after re-examination)
GRNT Written decision to grant
FPAY Annual fee payment

Payment date: 20170927

Year of fee payment: 4

FPAY Annual fee payment

Payment date: 20181002

Year of fee payment: 5

FPAY Annual fee payment

Payment date: 20191001

Year of fee payment: 6