MAVLink Shell 
The MAVLink Shell is an NSH console that can be accessed via MAVLink over serial (USB/Telemetry) or WiFi (UDP/TCP) links (in particular, on NuttX-based systems like: Pixhawk, Pixracer, etc.).
The shell can be used for running commands and modules, and displaying their output. While the shell cannot directly display the output of modules that it does not start, it can do so indirectly using the dmesg command (dmesg -f & can be used to display the output of other modules and tasks running on the work queue).
TIP
The QGroundControl MAVLink Console is the easiest way to access the console. If the system does not start properly you should instead use the System Console.
Opening the Shell 
QGroundControl MAVLink Console 
The easiest way to access shell is to use the QGroundControl MAVLink Console (see Analyze View > Mavlink Console).
mavlink_shell.py 
You can also access the shell in a terminal using the mavlink_shell.py script:
- Shut down QGroundControl. 
- Install dependencies: sh- pip3 install --user pymavlink pyserial
- Open terminal (in PX4-Autopilot directory) and start the shell: sh- # For serial port ./Tools/mavlink_shell.py /dev/ttyACM0sh- # For Wifi connection ./Tools/mavlink_shell.py 0.0.0.0:14550
Use mavlink_shell.py -h to get a description of all available arguments.
Using the MAVLink Shell 
For information see: PX4 Consoles/Shells > Using Consoles/Shells.