Help us improve your experience.

Let us know what you think.

Do you have time for a two-minute survey?

 
 

gNOI 시스템 서비스

요약 gNOI System 서비스를 사용하여 대상 네트워크 디바이스에서 디바이스 재부팅, 소프트웨어 업그레이드, 네트워크 문제 해결 등의 시스템 작업을 수행할 수 있습니다.

개요

gNOI System 서비스는 다음 작업을 포함하여 네트워크 디바이스에서 다양한 시스템 작업을 수행할 수 있는 RPC를 제공합니다.

  • 장치 재부팅
  • ping 및 traceroute 명령을 실행하여 네트워크 문제 해결
  • 소프트웨어 업그레이드
  • 라우팅 엔진 전환 수행

proto 정의 파일은 https://github.com/openconfig/gnoi/blob/master/system/system.proto 에 있습니다.

참고:

gnoi-system 시스템 오류가 발생할 경우 프로세스가 다시 시작됩니다. 수동으로 다시 시작하려면 명령을 사용합니다restart gnoi-system.

네트워크 디바이스 구성

시작하기 전에:

서비스 RPC를 System 사용하기 위해 추가 구성이 필요하지 않습니다.

핑 및 경로 추적

네트워크 디바이스에서 ping 및 traceroute 명령을 실행하여 네트워크 문제를 해결할 수 있습니다.

표 1: 네트워크 문제 해결을 위해 지원되는 system.proto RPC
릴리스에 도입된 RPC 설명
Ping()

장치를 ping합니다. RPC는 Ping() IPv4 및 IPv6 핑을 지원합니다. 이 RPC는 ping이 완료된 후 ping 결과를 다시 스트리밍합니다.

기본 패킷 수: 5

진화한 Junos OS 22.2R1

Traceroute()

대상 디바이스에서 traceroute 명령을 실행하고 결과를 다시 스트리밍합니다.

기본 홉 수: 30

진화한 Junos OS 22.2R1

예: Ping

이 예제에서 클라이언트는 Python 응용 프로그램을 gnoi_ping_request.py 실행합니다. 애플리케이션은 RPC를 Ping() 네트워크 디바이스로 전송한 다음, 네트워크에서 지정된 디바이스를 ping합니다.

응용 프로그램은 gnoi_ping_request.py 채널을 설정하기 위해 모듈을 가져옵니다 grpc_channel . 이 grpc_channel 모듈은 gNOI 서비스 구성에 설명되어 있습니다. 응용 프로그램의 인수는 gnoi_ping_request_args.txt 파일에 저장됩니다. 응용 프로그램 및 인수 파일이 여기에 표시됩니다.

gnoi_ping_request.py

gnoi_ping_request_args.txt

응용 프로그램 실행

클라이언트에서 RPC 호출 자격 증명에 대한 서버의 암호를 묻는 애플리케이션을 실행합니다. 은 PingResponse 디바이스가 5개의 ping을 보냈음을 나타냅니다. 최종 응답에는 ping 요청에 대한 요약 통계가 포함되며, 이는 디바이스가 5개의 ping을 전송하고 5개의 응답을 수신했음을 보여줍니다.

장치 재부팅

서비스 RPC를 System 사용하여 디바이스를 원격으로 재부팅하고, 재부팅 상태를 확인하고, 필요한 경우 재부팅을 취소합니다. 디바이스 또는 특정 하위 구성 요소에서 이러한 RPC를 실행할 수 있습니다. Junos 디바이스는 다음과 같은 재부팅 방법을 지원합니다.

  • COLD(1): 모든 유형의 재부팅에 사용할 수 있습니다.

  • POWERDOWN (2): FPC 재부팅에 사용합니다.

  • HALT (3): 활성 제어 프로세서 재부팅에 사용합니다.

  • POWERUP (7): FPC 재부팅에 사용합니다.

표 2: 재부팅에 지원되는 system.proto RPC
릴리스에 도입된 RPC 설명
Reboot()

대상을 재부팅합니다. 대상에서 한 번에 하나의 재부팅 요청만 실행할 수 있습니다.

선택적으로 나중에 재부팅하도록 지연을 구성하고, 하위 구성 요소를 개별적으로 재부팅하고, 재부팅이 시작될 때 메시지를 추가할 수 있습니다. 지연은 나노초 단위로 구성됩니다.

Junos 디바이스는 다음과 같은 재부팅 방법을 지원합니다.

  • 콜드 (1)

  • 파워다운 (2)

  • 정지 (3)

  • 파워업 (7)

진화한 Junos OS 22.2R1

RebootStatus() 재부팅 상태를 반환합니다.

진화한 Junos OS 22.2R1

CancelReboot() 보류 중인 재부팅 요청을 취소합니다.

진화한 Junos OS 22.2R1

예: 재부팅

이 예제에서 클라이언트는 Python 응용 프로그램을 gnoi_reboot_request.py 실행합니다. 애플리케이션은 재부팅 요청을 보낸 다음 재부팅 상태를 확인합니다.

이 애플리케이션을 통해 사용자는 재부팅 지연을 초 단위로 설정할 수 있습니다. RebootRequest() 은(는) 지연을 나노초 단위로 해석하므로 애플리케이션은 요청에 대한 사용자 입력을 나노초로 변환합니다. 이 예에서 클라이언트는 재부팅 작업에 대해 60초 지연을 지정합니다.

응용 프로그램은 gnoi_reboot_request.py 채널을 설정하기 위해 모듈을 가져옵니다 grpc_channel . 이 grpc_channel 모듈은 gNOI 서비스 구성에 설명되어 있습니다. 응용 프로그램의 인수는 reboot_status_request_args.txt 파일에 저장됩니다. 응용 프로그램 및 인수 파일이 여기에 표시됩니다.

gnoi_reboot_status_request.py

reboot_status_request_args.txt

응용 프로그램 실행

클라이언트가 응용 프로그램을 실행할 때 응용 프로그램은 RPC 호출 자격 증명에 대한 서버의 암호를 묻는 메시지를 표시합니다. 그런 다음 애플리케이션은 60초 지연 후 서버를 다시 부팅하고 해당 다시 부팅 상태 메시지를 반환합니다. 아래 reason 설정된 메시지는 서버가 재부팅되기 직전에 서버에도 나타납니다. 이 예에서 서버에 로그인한 모든 사용자는 재부팅 직전에 "gNOI 재부팅 테스트"를 볼 수 있습니다.

소프트웨어 업그레이드

표 3 에는 소프트웨어 업그레이드를 지원하는 시스템 서비스 RPC가 나와 있습니다.

표 3: 소프트웨어 업그레이드를 위해 지원되는 system.proto RPC
릴리스에 도입된 RPC 설명
SetPackage()

대상 장치에 소프트웨어 이미지를 설치합니다.

진화한 Junos OS 22.2R1

RPC를 SetPackage() 사용하여 소프트웨어 이미지를 대상 디바이스에 복사하고 설치할 수 있습니다. 소스 소프트웨어 이미지는 로컬 네트워크 관리 시스템에 상주해야 합니다. 파일 복사 작업이 성공하고 대상 위치에 동일한 이름의 파일이 이미 있는 경우 파일을 덮어씁니다. RPC는 대상 위치가 없거나 데이터 쓰기 오류가 있는 경우 오류를 반환합니다.

기본적으로 은SetPackage()(는) 디바이스를 재부팅하고 소프트웨어를 활성화하지 않습니다. 새 소프트웨어를 활성화하려면 메시지에서 SetPackageRequest 옵션을 명시적으로 1로 설정해야 activate 합니다. 소프트웨어를 활성화하면 디바이스가 재부팅되고 새 소프트웨어 이미지가 사용됩니다. 소프트웨어를 활성화하지 않은 경우 관련 노드를 재부팅하여 설치를 완료하고 새 소프트웨어 이미지를 활성화해야 합니다.

예제: 소프트웨어 패키지 설치

이 예제에서 클라이언트는 다음 작업을 수행하는 Python 응용 프로그램을 실행합니다 gnoi_system_set_package.py .

  • 소프트웨어 패키지를 로컬 네트워크 관리 시스템에서 네트워크 디바이스로 복사합니다.
  • 네트워크 장치에 패키지를 설치합니다.
  • 네트워크 디바이스를 재부팅하여 새 소프트웨어 이미지를 활성화합니다.

응용 프로그램은 적절한 매개 변수를 사용하여 메시지를 구성 SetPackageRequest 하여 복사 및 설치 작업에 대한 요청을 정의합니다. 그런 다음 애플리케이션은 RPC를 SetPackage() 호출하여 네트워크 디바이스에 요청을 보냅니다. 메시지에는 SetPackageRequest 다음 구성 요소가 포함되어 있습니다.

  • 소프트웨어 이미지의 경로 및 파일 정보가 들어 있는 초기 Package 메시지입니다. 인수는 activate 장치를 재부팅하고 소프트웨어를 활성화하기 위해 1(True)로 설정됩니다.
  • 64KB를 초과하지 않는 순차적 메시지의 소프트웨어 이미지 파일 콘텐츠 스트림입니다.
  • 파일 내용의 무결성을 확인하기 위한 파일 체크섬이 포함된 최종 메시지입니다.

응용 프로그램은 gnoi_system_set_package.py 채널을 설정하기 위해 모듈을 가져옵니다 grpc_channel . 이 grpc_channel 모듈은 gNOI 서비스 구성에 설명되어 있습니다. 응용 프로그램의 인수는 파일에 저장됩니다 args_system_set_package.txt . 응용 프로그램 및 인수 파일은 다음과 같습니다.

gnoi_system_set_package.py

args_system_set_package.txt

응용 프로그램 실행

클라이언트가 응용 프로그램을 실행하면 응용 프로그램은 로컬 장치에서 네트워크 장치로 패키지를 복사하고 설치한 다음 장치를 다시 부팅하여 설치를 완료합니다.

라우팅 엔진 스위치오버

RPC를 SwitchControlProcessor() 사용하여 라우팅 엔진 전환을 수행할 수 있습니다.

참고:

연속적인 라우팅 엔진 전환 이벤트는 두 라우팅 엔진이 모두 등장한 후 최소 400초 간격으로 발생해야 합니다.

표 4: 라우팅 엔진 전환을 위해 지원되는 system.proto RPC
릴리스에 도입된 RPC 설명
SwitchControlProcessor()

현재 라우팅 엔진에서 지정된 라우팅 엔진으로 전환합니다. 현재 라우팅 엔진과 지정된 라우팅 엔진이 동일하면 NOOP입니다. 대상이 없으면 RPC에서 오류를 반환합니다.

참고:

Junos 디바이스는 를 지원하지 control_processor SwitchControlProcessorResponse않습니다.

진화한 Junos OS 22.2R1

예: 라우팅 엔진 스위치오버

이 예에서 gNOI 클라이언트는 라우팅 엔진 전환을 gnoi_system_switch_control_processor.py 수행하기 위해 애플리케이션을 실행합니다. 클라이언트는 인수를 포함하여 control_processor 어떤 스위치 제어 프로세서 또는 라우팅 엔진이 기본 라우팅 엔진이 되어야 하는지 지정합니다. 대상 라우팅 엔진이 존재하지 않는 경우, RPC는 INVALID_ARGUMENT 오류를 반환합니다.

응용 프로그램은 채널을 설정하기 위해 모듈을 가져옵니다 grpc_channel . 이 grpc_channel 모듈은 gNOI 서비스 구성에 설명되어 있습니다.

gnoi_system_switch_control_processor.py

응용 프로그램 실행

클라이언트는 애플리케이션을 실행하고 인수를 control_processorre1 설정하여 re1이 기본 라우팅 엔진이 되도록 합니다.

작업을 실행한 후 re1은 대상 디바이스의 기본 라우팅 엔진입니다.