2020-01-13

Cisco - Radius Active Directory Authentication




스위치를 여러대 혹은 수십대를 관리할 경우 접속 계정을 스위치마다 직접 등록을 한다면.. 
그리고 주기적으로 패스워드를 변경을 해 주어야 한다면.. 관리자로서 아주 골치아플 것이다..
스위치에서는 AAA(authentication, authorization, and accounting) 모드를 통해 Radius 서버나
Tacacs 서버를 통해서 외부에서 계정 인증을 받을 수 있는 방법이 있다. 
그리고 한가지 더 Windows 서버에서 Active Directory를 사용한다면 AD 도메인 계정을 통해서
사용자 인증을 할 수 있는 방법이 있다.
필자도 그동안 스위치에 직접 계정을 등록해서 사용하였는데 관리자가 변경되거나 퇴사등 
수정할 사항이 많아져 귀차니즘으로 인해 새로 구축했던 내용을 토대로 설명해 보도록 하겠다. 

1. AD 서버 네트워크 정책 및 액세스 서비스 역할 추가
● 서버 관리자에서 역할 추가
● 다음


● 
네트워크 정책 및 액세스 서비스 선택



● 
다음



● 네트워크 정책 서버 선택


● 
설치





● 
설치 완료


2. Radius Client 등록 및 NPS 정책 추가.
● 우선 NPS 서비스를 Active Directory에 등록한다.


● 
Raduis 클라이언트 새로 만들기를 선택하여 클라이언트를 등록.



● 
이름, IP주소, 공유 암호 설정


● 
아래와 같이 클라이언트 등록 완료.



● 네트워크 정책 - 새로만들기(N) 선택하여 정책 추가



● 네트워크 정책 이름 및 연결 형식 지정은 기본값(default)으로 하고 다음을 누른다.



● 조건 지정에서 추가를 선택.



● 사용자 그룹을 선택 후 추가버튼을 눌러서 Access 할 도메인 계정 그룹을 등록.



● 사용자 그룹 : 네트워크 엑세스할 특정 도메인 계정을 등록. 
    ex) domain\Domain Admins



● 엑세스 권한은 엑세스 허용으로 선택 후 다음.


● 인증 방법은 아래와 같이 암호와 안된 인증(PAP, SPAP)(S)를 선택.


● 제약조건은 기본값으로 사용하고 다음.


● 설정 구성 에서 기본 등록된 값을 제거하고 
    아래와 같이 표준 값으로 Service-Type, value : NAS Prompt 지정.


● 공급 업체는 Cisco를 선택하고 특정정보 값으로 Privileges Level 값을 지정해 준다.

 - shell:priv-lvl=15  :  로그인 시 privilege level 15 권한 획득.   - shell:priv-lvl=1    :  로그인 시 privilege level 1 권한 획득. enable password 입력 필요. 


● 등록 확인



● 정책 설정 완료 후 마침. 



● 등록한 정책이 처리 순서 1로 우선순위를 변경.




3. Cisco ISO Radius Configuration.

!
aaa new-model
!
!
aaa group server radius NPS
 server 192.168.0.100 auth-port 1812 acct-port 1813
! 
aaa authentication login default local enable
aaa authentication login radius_auth group NPS local
aaa authorization exec radius_auth group NPS local 
aaa authorization network radius_auth group NPS local 
aaa accounting exec default start-stop group NPS
aaa accounting system default start-stop group NPS
!
!
radius-server host 192.168.0.100 auth-port 1812 acct-port 1813 key sharesecretkey
radius-server host 192.168.0.100 auth-port 1645 acct-port 1646 key sharesecretkey
!  
line con 0
 login authenticacion default
!
line vty 0 4
 login authentication radius_auth
!

  Radius는 UDP 포트로 통신을 하며 1812/1813, 1645/1646 포트를 사용한다.(default)     NPS 서버와 switch config를 통해 포트를 변경하여 사용할 수도 있으니 내부 보안 정책
     에 맞게 수정해도 상관 없다.

 콘솔 접속시 로컬 계정 로그인 권한.   AAA 모드로 동작을 하게 되면 콘솔과 vty 세션 모두 AAA  인증이 자동 활성화가 된다.   만약 장애로 인해 radius 인증이 어려울 경우 아래와 같이 설정하여 콘솔 로그인시 로컬    계정으로 로그인 되도록 설정하면 된다.

!
aaa authentication login default local enable
!  
line con 0
 login authenticacion default
!

Dynamips Network device list 실행 오류 해결 방법



Dynamips를 통해 가상의 라우터를 올리고 Network Device list 를 실행하면 아래와 같은 에러가 발생하는 경우가 있다.


 .........
 VM defualt: unable to create instance!
 C7200: unable to create instance! 
 .........

 위와 같은 메세지가 나오면 

 제어판 - 사용자 계정 - 사용자 계정 컨트롤을 OFF 하면 해결 된다.


2019-12-20

EVE-NG #2. Use Cisco IOU (IOS on Linux) on EVE-NG

EVE-NG를 설치했다면 이번엔 Cisco IOU 이미지를 업로드 하여 EVE-NG 에서 Cisco 스위치를 사용하는 방법에 대해 작성해 보겠다.
  IOU는 IOS on Linux의 약자로 IOL이라고도 한다. Cisco 내부에서만 사용가능한 이미지로, i386 아키텍처로 컴파일된 리눅스 버전이다. 
EVE-NG에서 사용가능한 IOU 버전은 아래의 두가지이다.
 ( 참고 : https://www.eve-ng.net/index.php/documentation/howtos/howto-add-cisco-iol-ios-on-linux/ )




IOU 이미지는 반드시 .bin 확장자로 되어 있어야 하며, 라이선스 파일 또한 같은 경로에 있어야 한다.
1. IOU 이미지 업로드
 - 먼저 해당 이미지를 filezilla나 winscp 등을 통해 sftp 로 접속하여 파일을 업로드 한다. 



Winscp를 통한 EVE-NG 접속

 - /opt/unetlab/addons/iol/bin/ 경로 이동후 이미지 업로드




- 메시지 창이 나오면 확인 




2. Permission 수정.
 - EVE-NG SSH 접속 후 아래 Command 실행하여 Permission 수정.
/opt/unetlab/wrappers/unl_wrapper -a fixpermissions
 위 명령어 실행후 아래와 같이 permission_denied 오류가 발생할 경우 unl_wrapper 파일 권한을 수정해 주면 된다.
root@eve-ng:~# /opt/unetlab/wrappers/unl_wrapper -a fixpermissions 
  -bash: /opt/unetlab/wrappers/unl_wrapper: Permission denied
 root@eve-ng:~#chmod 755 /opt/unetlab/wrappers/unl_wrapper
3. 라이선스 파일 생성 및 등록.
 - IOUkeygen.py 키젠 파일을 같은 경로에 업로드한다. 



IOUkeygen.py 파일 업로드


- python IOUkeygen.py 실행하여 라이선스 생성.




 - iourc 파일 생성후 라이선스 생성
  생성된 라이선스 정보(노란색 표시)를 iourc 파일을 만든 후 입력하여 저장한다.  
 vi iourc 
 
 [license] 
 eve-ng = 972f30267ef51616;  
 
 :wq
4. EVE-NG에서 이미지 부팅 확인. - eve-ng 웹 접속후 신규 랩을 생성



원하는 이름 선택후 저장(Save)
Node Object 추가


 - Cisco IOL Template 에서 원하는 이미지 선택 후 , 이름, Icon, Ethernet portgroups 등 적절하게 설정 한 후 저장. 




  - 스위치 부팅 후 접속 확인



IOUkeygen.py

2019-11-11

EVE-NG #1. 네트워크 가상 에뮬레이터 EVE-NG 설치 및 소개 (Network Virtual Emulator - Introduce and Install)

네트워크 가상화 에뮬레이터중 대부분의 네트워크 실습이 가능한 EVE-NG를 설치해 보자.

필자는 패킷 트레이서, dynamips, gns3 등 네트워크 가상화 에뮬레이터를 여러종류를 사용해 본 경험이 있으며, 
그중 EVE-NG가 원하는 실습환경을 최대한 동일하게 구성할수 있었고, 주니퍼, 포티 등 방화벽 장비 지원 뿐만 아니라 리눅스 가상화 플랫폼도 지원하여 여러가지 시스템과 연동하여 구성할 수 있어서 에뮬레이터 중이 가장 강력한 도구라고 생각한다. 
EVE-NG는 VirtualBox 나 VMWare 등 가상 머신에 사용할 수 있는 OVA 이미지 와 ISO 설치 이미지를 제공하고 있으며, 원하는 방식으로 설치가 가능하다. 여기에서는 가상 머신에 설치할 수 있는 OVA 파일을 통해 설치해 본다. 
1. 설치 파일 다운로드 
   - EVE-NG 홈페이지(https://www.eve-ng.net/) 접속 후  - Downloads - EVE-NG Community 에서 EVE-NG OVA 파일 다운로드. 
     구글 다운로드 링크 :  구글 Mirror Download 





2. EVE-NG 설치 
   다운로드가 완료 되면  EVE Community VM.ova 라는 파일이 생성이 된다. 해당 파일은 가상머신에서 바로 사용이 가능한 VM 이미지 이다.  가상머신은 무료버전인 VMWare Workstation 15 Player를 사용하였다.

1) VMWare Player에서 가상 이미지 파일 열기 
    Player - File - Open => EVE Community VM.ova 파일 선택 후 열기.





2) VM 이름 및 저장 위치 변경 후 Import 





3) Virtual Machine Setting 에서 Processors의 Virtualize Intel VT-x/EPT or AMD-V/RVI 선택. 





4) Network Adapter 에서 Network Connetcion Nat 선택.





5) 부팅이 완료 되면 로그인 후 추가 세팅을 진행한다. 
   부팅이 되면 할당된 IP 정보 확인이 가능하며,  초기 로그인 정보는 ID : root  / PW : eve 이다. 세팅이 완료 되면 화면에 나와있는 IP URL로 접속하면 된다. 




Root 패스워드 설정 




Hostname 설정




도메인 이름 설정(옵션)




IP 주소 선택. Nat 모드로 구성하였으므로 DHCP 선택. 
( Bridge 모드사용시 PC의 인터페이스 설정과 동일하게 dhcp 나 Static 중 선택 후 사용하면 된다. )




NTP(시간동기화 프로토콜) 설정 ( 사용하는 NTP 서버가 있을경우 설정, 없으면 생략 가능)




프록시 서버 설정 ( 프록시 사용하지 않을 경우 direct connection 선택 ) 




설정이 완료 되면 다시 재부팅이 되며 부팅이 완료 되면 아래와 같이 로그인 창이 보이게 된다.




로그인창에 있는 URL(IP)로 접속하면 eve-ng 웹 UI 접속이 가능하다. ( id : admin / pw : eve )




다음에는 EVE-NG에 스위치 및 라우터 이미지 등록 및 토폴로지 구성하는 방법에 대한 포스팅을 하도록 하겠다. 

2019-05-21

Router EIGRP Summarzation(Auto,Manual Summary)




Distance vector 프로토콜은 전통적으로 Classfull 라우팅 프로토콜을 사용하며 라우팅 정보를 업데이트 할 때 mask 정보를 교환하지 않는다. 
EIGRP 라우팅 프로토콜은 Distance vector 계열 프로토콜 중의 하나이며(RIP,IGRP 등) 기본적으로 Classfull로 네트워크 정보를 자동 요약하여 전달을 한다.
 Auto-Summary의 장점은 더 작은 라우팅 테이블을 만들어서 라우팅 업데이트시에 더 적은 bandwidth를 사용하여 네트워크 Performance를 향상시켜 준다.
또한 EIGRP 라우팅 프로토콜은 VLSM/CIDR을 지원하여, summarization 하지 않고 실제 네트워크의 Subnetmask 정보를 전달할 수 있으며, 수동으로 summarization 할 수 있어서 자신의 네트워크 상황에 맞도록 장비를 구성할 수 있다.
네트워크 정보를 전달할때 기본값으로 auto-summary가 되어 classfull로 네트워크 정보를 전달하며, auto-summary를 사용하지 않을 경우 no auto-summary command를 사용하여 Eigrp 라우팅을 구성할 수 있다. 

I. Topology
 아래와 같이 네트워크를 구성하여 Eigrp로 라우팅을 구성하였고,  R1,R2는 summary 하지 않고 R3 에서만 summary를 구성하였다. 
그리고 외부 인터넷 라우터에는 172.16.0.0/16으로 라우팅 정보를 전달하도록 수동으로 구성하였다.


II. EIGRP Configuration
  1) R1, R2  Eigrp config.
conf t
router eigrp 100
network 10.0.0.0
network 172.16.0.0
no auto-summary
 ==> no auto-summary 로 summary 되지 않도록 구성하여 10.0.0.0 네트워크 대역에 172.16.1.0 서브넷과 
        172.16.2.0 서브넷이 전달되도록 구성.

  2) R3 Eigrp config.
conf t
router eigrp 100
network 10.0.0.0
network 192.168.4.0
 ==> 10.0.0.0 과 192.168.4.0 네트워크를 전달하고 기본값으로 auto-summary 되도록 구성. 

  3) WWW Eigrp config.
conf t
router eigrp 100
network 192.168.4.0

III. Confirm Routing Table
 auto-summary로 라우팅 정보를 전달하게 되면 Eigrp는 즉시 summary된 라우팅 정보를 만들고 interface가 null0로 향하도록 설정을 하게 된다. ( 즉 Drop이 되게 된다.)
 이는 라우팅 정보 전달시 Looping을 예방하기 위한 메커니즘이다.

 <R3 EIGRP Routing table>

  

 그리고 위와 같이 구성할 경우 R3에서는 172.16.1.0과 172.16.2.0은 summary 되지 않는다. 왜냐하면 R3가 auto-summary로 구성되었다고 하더라도 172.16.0.0 서브넷이 R3에 속해 있지 않기 때문이다.
 즉 위와 같이 구성하게 되면 WAN 구간으로 172.16.1.0/24 서브넷과 172.16.2.0/24 서브넷이 전달되게 된다.

<WWW Eigrp routing table> 

   
  라우팅 테이블에 172.16.1.0과 172.16.2.0 이 summary 되지 않고 전달되는 것을 확인할 수 있다.

  만약 R1 구간과 R2 구간에 수십개 이상의 사설 네트워크 구간이 있다고 가정한다면 Wan 구간 라우터의 라우팅 테이블은 수십개 이상 늘어나게 되어 라우팅 업데이트시에 더 많은 트래픽을 사용하게 되고, 라우터의 성능을 저하시키는 문제가 발생하게 된다.
  혹, R1과 R2에서 auto-summary로 네트워크 정보를 전달하는 것을 생각할 수 있겠지만, 그럴 경우에 172.16.1.0 과 172.16.2.0 이 R1, R2에서 모두 172.16.0.0/16 으로 라우팅 정보를 전달하게 되어 결과적으로 자신과 동일한 라우팅 정보를 받게 되고 루핑 방지를 위한 split-Horizon에 의해서 전달된 라우팅 정보를 받지 않게 되어 통신이 불가능하게 된다.

< R1,R2에서 auto-summary 구성할 경우>

  
라우팅 테이블 정보를 보면 172.16.0.0/16으로 summary 된 정보가 확인이 되며 interface는 null로 Drop 된다.

R1에서 172.16.2.0/24 라우팅 정보가 있어야 하지만 172.16.0.0/16으로 전달을 받게되었고, 172.16.0.0/24는 자기 자신의 네트워크여서 실제적으로 정보를 받지 않게 되어 라우팅 테이블에는 아무런 정보도 나타나지 않게 된다.
그리고 R3에서는 R1과 R2로부터 172.16.0.0/16을 동시에 받게 되어 172.16.0.0/16으로 로드밸런싱이 된다.

 이에 대한 해결 방법으로 앞에서 간단히 설명한 manual summary 이라는 방법이 있다. 

IV. Manual Summarization config.
  Manual Summurization 은 말 그대로 수동으로 네트워크 정보를 요약하여 전달하는 것을 의미한다. 
  첫째, 네트워크 정보를 전달할 Interface를 선택한다.
  둘째, ip summary-address eigrp as-number address mask [admin-distance]  로 summarization.

<Command>
   interface select interface   ip summary-address eigrp as-number address mask [admin-distance]  
     
[admin-distance] : (Optional) Administrative distance. A value from 0 to 255
conf t
int serial 3/0
ip summary-address eigrp 100 172.16.0.0 255.255.0.0

==> 결과
<WWW routing table>

   

172.16.0.0/16으로 Summary 되어 라우팅 테이블에 저장이 되었다.

 Manual Class의 장점은 Eigrp가 CIDR을 지원하기 때문에 /23, /20 등으로 슈퍼넷팅이 가능하다는 것이다. 
위의 예문에서는 172.16.1.0과 172.16.2.0을 172.16.0.0/16으로 Major Network로 Summarization 하였지만,
만약 172.16.0.0 ~ 172.16.7.255 까지의 네트워크 대역을 사용 할 경우에는 172.16.0.0 255.255.248.0 으로
Summarization 할 수도 있다.

NSClient - ERROR: Could not get data for 5 perhaps we dont collect data this far back?


NSClient - ERROR: Could not get data for 5 perhaps we dont collect data this far back?


Nagios 모니터링시 위와 같은 메시지 나올 경우 해결 방법. 


에러가 발생하는 서버에 접속.
CMD 창 모드에서 아래와 같은 메시지 입력..



lodctr /R





위와 같은 에러는 윈도우 서버 성능 카운터 관련된 문제로 명령어로 성능 카운터 설정을 다시 해 주면 된다.


Elasticsearch Heap Size

  Elasticsearch는 Java 기반으로 동작을 합니다. Java는 가비시 컬렉터 (garbage-collected)에 의해서 관리가 되며, Java 객체는 힙(Heap) 이라고하는 메모리의 런타임 영역에 상주합니다.  Elasticsear...