Matteo Scandolo | 1f5530b | 2019-12-17 10:12:31 -0800 | [diff] [blame] | 1 | Troubleshooting |
| 2 | =============== |
| 3 | |
| 4 | Here is a collection of useful commands and tools to troubleshoot VOLTHA. |
| 5 | The project is still in a very early phase, so this section of the guide is more focus |
| 6 | on how to collection information and packet dumps than it is on operations. |
| 7 | |
Andrea Campanella | 61fd666 | 2020-07-27 16:56:55 +0200 | [diff] [blame] | 8 | Depending on your issue useful tips and tricks can be found: |
Andrea Campanella | 764a3ce | 2021-07-19 21:55:02 +0200 | [diff] [blame] | 9 | |
Hardik Windlass | 702b5fa | 2022-06-29 17:27:01 +0530 | [diff] [blame] | 10 | - `No ONUs are discovered <https://guide.opencord.org/master/profiles/seba/troubleshoot/no-onus.html>`_ |
| 11 | - `Can't authenticate <https://guide.opencord.org/master/profiles/seba/troubleshoot/no-aaa.html>`_ |
| 12 | - `DHCP is not working <https://guide.opencord.org/master/profiles/seba/troubleshoot/no-dhcp.html>`_ |
| 13 | - `No Ping <https://guide.opencord.org/master/profiles/seba/troubleshoot/no-ping.html>`_ |
Andrea Campanella | 61fd666 | 2020-07-27 16:56:55 +0200 | [diff] [blame] | 14 | |
| 15 | |
Matteo Scandolo | 1f5530b | 2019-12-17 10:12:31 -0800 | [diff] [blame] | 16 | Trace Packets across components |
| 17 | ------------------------------- |
| 18 | |
| 19 | Given that ``VOLTHA`` is a collection of microservices we strongly suggest the usage of a log aggregator like |
Joey Armstrong | 1a9b7d1 | 2022-12-19 14:13:07 -0500 | [diff] [blame] | 20 | `stern <https://github.com/stern/stern>`_. Stern is able to aggregate logs from multiple containers in |
Joey Armstrong | a62c74a | 2022-11-23 13:16:34 -0500 | [diff] [blame] | 21 | a simple way, for example to track all the ``packet-ins`` and ``packet-outs``: |
Matteo Scandolo | 1f5530b | 2019-12-17 10:12:31 -0800 | [diff] [blame] | 22 | |
| 23 | .. code:: bash |
| 24 | |
Joey Armstrong | 1a9b7d1 | 2022-12-19 14:13:07 -0500 | [diff] [blame] | 25 | # Capture to a file |
Matteo Scandolo | 1f5530b | 2019-12-17 10:12:31 -0800 | [diff] [blame] | 26 | $ stern -n voltha "voltha|adapter" | grep -E "packet-out|packet-in" > packets.trace |
| 27 | |
Joey Armstrong | 1a9b7d1 | 2022-12-19 14:13:07 -0500 | [diff] [blame] | 28 | # Live streaming packet capture using the tee command: |
| 29 | $ stern -n voltha "voltha|adapter" | grep -E "packet-out|packet-in" | tee packets.trace |
| 30 | |
Matteo Scandolo | 1f5530b | 2019-12-17 10:12:31 -0800 | [diff] [blame] | 31 | Once you have captured the packets you need, you can see them in wireshark by transforming the logs with: |
| 32 | |
| 33 | .. code:: bash |
| 34 | |
| 35 | sed -n 's/.*packet":"\(.*\)",.*$/\1/p' packets.trace | sed -e 's/.\{2\}/& /g' | sed -e 's/^/000000 /' > packets.hex |
| 36 | |
| 37 | And then in wireshark select ``File -> Import from Hex Dump`` |
| 38 | |
| 39 | Or you can decode a single packet using this online tool: `https://hpd.gasmi.net <https://hpd.gasmi.net>`_ |
| 40 | |
Joey Armstrong | 1a9b7d1 | 2022-12-19 14:13:07 -0500 | [diff] [blame] | 41 | To get all the EAPOL packets: ``grep -e '888e' packets.trace`` |
Matteo Scandolo | 1f5530b | 2019-12-17 10:12:31 -0800 | [diff] [blame] | 42 | |
Joey Armstrong | 1a9b7d1 | 2022-12-19 14:13:07 -0500 | [diff] [blame] | 43 | or if you have the colorization program `hl <https://github.com/mbornet-hl/hl>`__ installed you can highlight with: |
Matteo Scandolo | 1f5530b | 2019-12-17 10:12:31 -0800 | [diff] [blame] | 44 | |
| 45 | .. code:: bash |
| 46 | |
| 47 | cat packets.trace | grep 888e | hl -m '.*packet-in.*' -g '.*packet-out.*' |
| 48 | |
| 49 | To get all the DHCP packets: ``cat packets.trace | grep 8100`` |
| 50 | |
| 51 | or if you have `hl <https://github.com/mbornet-hl/hl>`__ installed you can highlight with: |
| 52 | |
| 53 | .. code:: bash |
| 54 | |
| 55 | cat packets.trace | grep 8100 | hl -m '.*packet-in.*' -g '.*packet-out.*' |
| 56 | |
| 57 | OMCI Packet Dump |
| 58 | ---------------- |
| 59 | |
| 60 | In order to see OMCI packets in Wireshark you'll need to install ``omci.lua`` and ``BinDecHex.lua`` dissectors |
Joey Armstrong | 644fb65 | 2023-10-02 13:12:20 -0400 | [diff] [blame] | 61 | `wiki.wireshark.org/Contrib` ``http://wiki.wireshark.org/Contrib#protocol-dissectors`` |
Matteo Scandolo | 1f5530b | 2019-12-17 10:12:31 -0800 | [diff] [blame] | 62 | |
| 63 | To install them on Ubuntu: |
| 64 | |
| 65 | .. code:: bash |
| 66 | |
Joey Armstrong | 1a9b7d1 | 2022-12-19 14:13:07 -0500 | [diff] [blame] | 67 | mkdir -p "${HOME}/.local/lib/wireshark/plugins" |
| 68 | cd "${HOME}/.local/lib/wireshark/plugins" |
Matteo Scandolo | 1f5530b | 2019-12-17 10:12:31 -0800 | [diff] [blame] | 69 | wget "https://wiki.wireshark.org/Contrib?action=AttachFile&do=get&target=omci.lua" |
| 70 | wget "https://wiki.wireshark.org/Contrib?action=AttachFile&do=get&target=BinDecHex.lua" |
| 71 | |
Joey Armstrong | 1a9b7d1 | 2022-12-19 14:13:07 -0500 | [diff] [blame] | 72 | - IMPORTANT - Apply `this <https://ask.wireshark.org/question/4557/bindechexlua-error-bad-argument-to-module-packageseeall/?answer=4573#post-id-4573>`_ fix to BinDecHex.lua. |
| 73 | |
| 74 | - TODO NOTE - The BinDecHex.lua thread is 4 years old, is the patch still |
| 75 | required or has it been incorporated into the code base ? |
Matteo Scandolo | 1f5530b | 2019-12-17 10:12:31 -0800 | [diff] [blame] | 76 | |
| 77 | To capture the OMCI packets for all ONUs: |
| 78 | |
| 79 | .. code:: bash |
| 80 | |
Andrea Campanella | 9f534c7 | 2021-03-19 18:44:27 +0100 | [diff] [blame] | 81 | cat openonu.logs | grep -E "TxOmciMessage|RxOmciMessage" | grep msg > packets.trace |
Matteo Scandolo | 1f5530b | 2019-12-17 10:12:31 -0800 | [diff] [blame] | 82 | |
| 83 | To capture the OMCI packets for a particular ONU: |
| 84 | |
| 85 | .. code:: bash |
| 86 | |
Andrea Campanella | 9f534c7 | 2021-03-19 18:44:27 +0100 | [diff] [blame] | 87 | cat openonu.logs | grep -E "TxOmciMessage|RxOmciMessage" | grep msg | grep [deviceId] > packets.trace |
Matteo Scandolo | 1f5530b | 2019-12-17 10:12:31 -0800 | [diff] [blame] | 88 | |
| 89 | Once you have the ``omci.dump`` file you need to prepare it to be imported in wireshark with this command: |
| 90 | |
| 91 | .. code:: bash |
| 92 | |
Andrea Campanella | 9f534c7 | 2021-03-19 18:44:27 +0100 | [diff] [blame] | 93 | awk -F"OmciMessage" '/OmciMessage/{print $2}' packets.trace | cut -f3 -d'"' > rawdump |
| 94 | cat rawdump | sed -e 's/.\{2\}/& /g' | sed -e 's/^/000000 /' > omci.hex |
Matteo Scandolo | 1f5530b | 2019-12-17 10:12:31 -0800 | [diff] [blame] | 95 | |
| 96 | And then in wireshark: |
| 97 | |
| 98 | - select ``File -> Import from Hex Dump`` |
| 99 | - select ``Encapsulation Type -> Ethernet`` |
| 100 | - set ``Ethernet -> Ethertype (hex): 88b5`` |