MAVLink Router는 여러 엔드포인트(연결) 간에 MAVLink 메시지를 분배하는 애플리케이션입니다 . 대상 주소에 따라 패킷을 단일 포트 또는 여러 엔드포인트에 분배합니다. 연결은 UART, UDP 또는 TCP를 통해 이루어질 수 있습니다
1. 컴파일 및 설치
컴파일하려면 다음 패키지가 필요합니다.
- GCC 또는 Clang 컴파일러
- meson >= 0.57 및 ninja-build
- C 및 C++ 표준 라이브러리
종속성 가져오기
MAVLink Router는 현재 mavlink C 라이브러리에 의존하고 있습니다. 해당 하위 모듈을 가져와야 합니다.
$ git clone https://github.com/mavlink-router/mavlink-router.git
$ cd mavlink-router
$ git submodule update --init --recursive
빌드 종속성으로 몇 가지 추가 패키지가 필요합니다. 일부 배포판의 패키지:
Debian/Ubuntu:
$ sudo apt install git meson ninja-build pkg-config gcc g++ systemd
meson 패키지는 버전 0.55 이상이어야 합니다. 패키지 관리자에 이 버전이 없는 경우 pip를 통해 최신 버전을 다운로드할 수 있습니다.
$ sudo pip3 install meson
2. 빌드(Build)
빌드 시스템은 일반적인 구성/빌드/설치 순서를 따릅니다. 구성은 한 번만 수행하면 됩니다.
구성:
x86-64 시스템의 일반적인 구성은 다음과 같습니다.
$ meson setup build .
$ ninja -C build
$ sudo ninja -C build install
3. 실행
mavlink-router를 실행하는 방법은 Conf 파일을 이용하는 방법과 명령중 매개변수를 이용하는 방법 두가지가 있습니다.
Conf 파일
기본적으로 mavlink-routerd는 /etc/mavlink-router/main.conf 파일을 찾습니다.
파일 위치는 MAVLINK_ROUTERD_CONF_FILE환경 변수를 통해 재정의하거나 mavlink-routerd를 실행할 때 -c 옵션을 통해 재정의할 수 있습니다. 구성 파일 구문과 모든 매개변수에 대한 설명은 examples/config.sample파일 에서 찾을 수 있습니다 .
기본 conf 파일 외에도 추가 구성 파일을 넣을 디렉토리를 사용할 수도 있습니다. 이 디렉토리의 파일은 알파벳순으로 읽히고 이전 파일에서 찾은 구성을 추가하거나 재정의할 수 있습니다.
기본적으로 /etc/mavlink-router/config.d디렉토리이지만 MAVLINK_ROUTERD_CONF_DIR 환경 변수를 통해 재정의하거나 mavlink-routerd를 실행할 때 -d 옵션을통해 재정의할 수 있습니다.
.conf 파일 예시
로컬 PC의 UDP 14541 포트와 다른 PC(192.168.111.222)의 14542 UDP 포트로 라우팅 예시.
#test.conf
[UartEndpoint UAVTelemetry] # FC와 연결된 connect string
Device = /dev/ttyUSB0
Baud = 921600
[UdpEndpoint localDesktop] # Routing 할 Endpoint #1
Mode = Normal
Address = 127.0.0.1
Port = 14541 # 예시
[UdpEndpoint localDesktop2] # Routing 할 Endpoint #2
Mode = Normal
Address = 192.168.111.222 # 예시
Port = 14542 # 예시
실행
cd ~/mavlink-router
mavlink-routerd -c test.conf
CLI 매개변수
명령줄 옵션의 전체 목록은 mavlink-routerd --help 출력을 참조하세요. 가장 중요한 사실은 다음과 같습니다.
- TCP 서버는 기본적으로 활성화되어 있습니다
- TCP 및 UDP 엔드포인트는 여러 번 추가될 수 있습니다.
- – e 옵션 으로 추가된 UDP 엔드포인트는
normal모드(지정된 주소 및 포트로 데이터 전송)에서 시작됩니다 . - 마지막 매개변수(옵션 키 없음)는 하나의 UART 장치 또는 UDP 연결일 수 있습니다. 이 UDP 엔드포인트는
server모드에서 시작됩니다(수신 연결을 기다리는 중)!
ttyS1UART에서 다른 2개의 UDP 엔드포인트로 mavlink 패킷을 라우팅하려면 다음 명령을 사용하세요.
$ mavlink-routerd -e 192.168.7.1:14550 -e 127.0.0.1:14550 /dev/ttyS1:1500000
콜론 뒤에 있는 1500000는 /dev/ttyS1:1500000UART baudrate를 설정합니다.
mavlink-routerd --help로 더 많은 옵션을 확인하세요.
UART 대신 들어오는 UDP 연결에서 mavlinks 패킷을 라우팅하는 것도 가능합니다.
$ mavlink-routerd -e 192.168.7.1:14550 -e 127.0.0.1:14550 0.0.0.0:24550
또한 mavlink-router는 기본적으로 TCP 연결을 위해 포트 5760에서 수신 대기합니다. 해당 포트에 연결된 모든 클라이언트는 MAVLink 데이터를 보내고 받을 수 있습니다.
IPv6 주소는 다음과 같이 대괄호로 묶어야 합니다: [::1]. 포트 번호는 IPv4와 같은 방식으로 지정할 수 있습니다: [::1]:14550. 유니캐스트와 멀티캐스트 주소는 모두 적절하게 처리해야 하며 링크 로컬 주소의 인터페이스는 자동으로 감지됩니다.
MAVLink 라우터가 엔드포인트 간에 메시지를 전달하는 방식을 이해하려면 MAVLink 메시지에 발신자 주소가 있어야 하지만 일부 메시지에만 대상 주소가 있다는 것을 아는 것이 중요합니다(예: 매개변수 요청). 발신자 및 대상 주소는 각각 Mavlink System ID 및 Component ID로 구성되므로 하나의 UAV는 비행 컨트롤러와 개별 Component ID가 있는 동반 컴퓨터에서 실행되는 다른 서비스를 가질 수 있지만 동일한 System ID를 공유합니다. 대상 주소에서 Component ID 0은 시스템의 모든 구성 요소에 브로드캐스트하는 데 사용되고 sysID 0은 모든 시스템에 브로드캐스트합니다.
로깅(Logging)
비행 스택 로깅
Mavlink 라우터는 비행 스택 로그도 수집할 수 있습니다. PX4와 Ardupilot 비행 스택 로그를 모두 수집할 수 있습니다. 로깅을 시작하려면 config 파일의 섹션 Log에 있는 키 에 디렉토리를 설정합니다(또는 인수 옵션 사용 ). MAVLink 방언은 기본적으로 자동 감지되거나 키를 사용하여 명시적으로 설정할 수 있습니다. 예를 들어 Ardupilot 로그를 디렉토리에 수집하려면 conf 파일에 다음을 추가할 수 있습니다.General-lMavlinkDialect/var/log/flight-stack
[General]
Log=/var/log/flight-stack
MavlinkDialect=ardupilotmega
로그는 지정된 디렉토리의 .bin(Ardupilot의 경우) 또는 .ulgXXXXX-date-timeXXXXX(PX4의 경우) 파일에 수집됩니다.
원격 측정 로깅
flight stack 로깅과 비슷하게 General섹션의 LogTelemetry키를 사용하여 원시 원격 측정 데이터를 .tlog파일 로 쓸 수도 있습니다 (또는 -T인수 사용). flight stack 로깅을 사용하는 경로가 설정된 경우에만 작동합니다! flightstack 로깅의 모든 옵션이 여기에도 적용됩니다.
보다 자세한 내용은 MAVLink-Router github 페이지를 참고 하시기 바랍니다.
