Author's posts

Django, queryset 결과의 문자열을 변경하는 방법.

Django3.1, queryset 결과 문자열을 변경하는 방법. 아래의 모델에 저장된 MAC 주소는 ‘0021ccd3792f’ 같은 형식으로 일반적으로 표현되는 : 이나 – 이 제거된 형태다. models.py class MacTable(models.Model): … mac = models.CharField(max_length=32, verbose_name=’MAC Address.’) device = models.ForeignKey( ‘NetworkDevice’, on_delete=models.CASCADE, verbose_name=’Network Device’ ) interface = models.CharField(max_length=32, verbose_name=’Interface’) vlan = models.CharField(max_length=32, verbose_name=’VLAN’) dropped = models.BooleanField(default=False, verbose_name=’Dropped’) …. class Meta: verbose_name_plural …

Continue reading

익스트림 스위치 ssh/telnet 세션.

익스트림 스위치 ssh/telnet 세션. 익스트림 스위치에 ssh 접속시도했는데, 아래와 같은 접속 거부 메시지가 보였다. $ ssh wadmin@172.16.100.2 ssh_exchange_identification: read: Connection reset by peer 다행히 telnet 접속도 허용해 놓은 상태여서 일단 접속 가능했다. 현재 세션을 확인해 보면 아래 처럼 8개의 ssh 연결된 상태다. 익스트림 스위치의 ssh 최대 동시 접속은 8 이다. 아래는 8개의 ssh 접속이 있어서 …

Continue reading

mysql, 1040, ‘Too many connections’

mysql, 1040, ‘Too many connections’ mysql을 이용해서 스크립트 작성중 too many connections 오류가 발생했다. 스크립트 실행 전에 processlist를 확인해 보면 아래와 같다. ysql> show full processlist\g +——–+———-+—————–+———-+———+——+———-+———————–+ | Id | User | Host | db | Command | Time | State | Info | +——–+———-+—————–+———-+———+——+———-+———————–+ | 142415 | foxxipam | localhost:42880 | foxxipam | Sleep …

Continue reading

익스트림 스위치 로그 필터 (exos log filter)

익스트림 스위치 로그 필터 (exos log filter) 아래처럼 동일한 로그가 반복되어 발생(192.168.100.122 에서 5분단위로 mac 수집 스크립트를 실행하고 있는 상태로 로그인 로그아웃 로그가 발생)하는 상황이다. 192.168.100.22에서 로그인/로그아웃 되는 로그는 많기도 하고 불필요하기도 해서 기록에 남기지 않고 싶다. 이것은 log filter를 설정하여 해결 할 수 있다. Switch.5 # show log 08/27/2021 15:32:31.15 <Info:AAA.logout> User wadmin logout …

Continue reading

django admin 페이지에서 다른 모델의 필드값을 drop-down 리스트로 사용하기.

Django 관리자 페이지에서 다른 모델 필드값 drop-down list로 사용하기 모델은 아래와 같다. class Category(models.Model): name = models.CharField(max_length=64, unique=True) class NetworkDevice(models.Model): … category = models.CharField(max_length=64, null=True, blank=True, verbose_name=’Category’) 위의 모델에서, NetworkDevice 모델의 category 필드의 입력값을 Category 모델의 값에서 가져오기를 원하는경우, ForeignKey를 사용하면 되지만, 외래키를 사용하는경우 Category 쪽의 데이타를 삭제하는 경우 문제가 발생할 수도 있다. 그런 경우를 …

Continue reading

Nornir 네트워크 자동화 – 4 (nornir-napalm)

Nonir 네트워크 자동화 – 4 (nornir-napalm) 1. NAPALM NAPALM(Network Automation and Programmability Abstraction Layer with Multivendor support) NAPALM은 통합된 API를 사용하여 다양한 네트워크 장비의 OS와 상호작용하는 기능을 구현한 파이썬 라이브러리. 현재 버전(napalm 3)에서 지원하는 NOS는 Arista EOS, Cisco IOS, Cisco IOS-XR, Cisco NX-OS, Juniper JunOS이다. * NAPALM의 단점 지원되는 OS가 적다(하지만 지원되지 않는 장비들에 대한 …

Continue reading

Nornir 네트워크 자동화 – 3 (활용편)

Nornir 네트워크 자동화 – 3 (활용편) 이전 글(Nornir 네트워크 자동화 -2 (활용편))에서 nornir-netmiko 를 통해 시스코스위치에 명령을 내리고 결과를 가져오는 파이썬 스크립트를 작성했다. 이제, 남은것은 가져온 결과에서 원하는 부분을 추출하여 excel 에 저장하는 것이다. 만약, 결과를 눈으로 확인하기만 하면 된다고하면 print_result 사용만으로 충분할 수도 있겠지만, 장비의 시리얼 번호 추출이나 os 버전을 업그레이드 하기 위해 현재 …

Continue reading

Nornir 네트워크 자동화 -2 (활용편)

Nornir 네트워크 자동화 – 2 활용편 목표: Nornir를 이용하여 시스코 스위치 점검하는 파이썬 스크립트를 작성 사람이 장비점검을 한다고 하면 보통 아래 과정을 거쳐야한다. 1. 스위치의 목록 확인(ID, 비밀번호, 접속방법 등등) 2. 장비 접속, 보통 순서대로 접속하지만, 터미널 프로그램에 등록해서 한번에 여러대 접속이 가능하다. 3. 장비별로 명령을 내린다. 이것 역시 순서대로 하거나 여러 장비에 동시 가능. …

Continue reading

Nornir 네트워크 자동화 – 1

Nornir 네트워크 자동화 – 1 (기초편) 1. Nornir란 무엇인가? Nornir는 파이썬으로 작성된 자동화 프레임워크다. Ansible의 경우 파이썬으로 작성되었지만 프로그래밍을 몰라도 사용하는데 문제는 없지만, Nornir를 사용하려면 파이썬 프로그래밍을 알아야한다. Nornir는 파이썬 버전 3.6.2 이상에서 동작한다. 2. Nornir 설치 Nornir는 PyPI에 게시되며, 다른 파이썬 패키지들처럼 pip 명령으로 설치가 가능하다. 또한 개발단계에서는 virtual environment를 사용하는것이 좋다. 아래 명령으로 …

Continue reading

C3550, %SYS-2-MALLOCFAIL

C3550, %SYS-2-MALLOCFAIL 메시지 발생. 시스코 스위치에서 대략 30초 간격으로 아래 메시지 무한 반복. May 10 16:23:07: %SYS-2-MALLOCFAIL: Memory allocation of 1692 bytes failed from 0x153AE4, alignment 0 Pool: I/O Free: 57212 Cause: Memory fragmentation Alternate Pool: None Free: 0 Cause: No Alternate pool -Process= “Pool Manager”, ipl= 0, pid= 5 May 10 16:23:37: %SYS-2-MALLOCFAIL: Memory …

Continue reading