Skip to main content

 

Cisco Meraki Documentation

Advanced RADIUS and WPA2 Debugging using macOS

Overview

This article is meant to serve as a guideline for RADIUS issues that require more detailed debugging when requested by Meraki Support for more complex or hard-to-pin-down issues. It is meant to be used in conjunction with monitor-mode .pcaps for wireless clients, and with Support enabling verbose RADIUS logging on our hardware to form a complete picture of what all involved parties see during the transaction. This process should be considered when dealing with persistent log-in issues for large numbers of client devices, or when evaluating for potential bugs after other means of troubleshooting, such as server-side debugging, have been exhausted.

Requirements

An Apple laptop or desktop running macOS 10.12 or newer. This article was written in the context of macOS 10.12+ and will not work on older versions. 

Steps to Gather Debugging Logs

  1. Open up Wireless Diagnostics using Searchlight (default shortcut CMD+Space)
Screenshot of the Searchlight results for "Wireless Diagnostics" on a Mac.
  1. With the application open, press option-cmd-3 to open the logs window

Screenshot of the Logs popup that appears after opening Wireless Diagnostics and pressing "option-cmd-3".

 

  1. Ensure both "Wi-Fi" and "System" are selected, then hit "Collect Logs." This step is critical. If collect logs is not pressed, you will not get the required log data.
    1. On macOS 10.13 (High Sierra) and higher, "System" has been replaced with an option for "EAPOL"
  1. Make a note of the current time, then reproduce the issue you are attempting to troubleshoot
  1. After reproducing the issue, open up a terminal and run the following command:  sudo sysdiagnose -f ~/Desktop/ -A filename. This will save the sysdiagnose output to the current user's desktop with the specified filename.
  1. Wait - the operation can take several minutes to complete, and you'll see "Completed All Phases. Wrapping up." in the terminal window when it's finishing.  After a few moments, a new Finder window should open, containing the newly created Sysdiagnose archive.
Screenshot of the Finder window. The tmp folder is selected, which includes the sysdiagnose file.
  1. Double click on the appropriate archive file to unzip it, then open the resultant directory, then locate, and copy out the file system_logs.logarchive - it is not necessary to grab any other output from this directory.
    1. Please also make an explicit note of which version of macOS the .logarchive file was captured on, as older versions of the OS cannot view files that are generated on newer ones!
    2. (NOTE: these files are large, so a service like Dropbox, Google Drive, etc. is recommended)
Screenshot of the unzipped sysdiagnose file, which includes the sytem_logs_logarchive file.
  1. To view the relevant RADIUS details out of the .logarchive file, in the Console window that opens upon opening the file, go to the search field in the top right, and filter for "eapolclient"
Screenshot of the console window that appears after selecting the system_logs_log_archive file.
  1. The file may take several minutes to fully load, but eventually should start displaying the appropriate debug information. Note this with the previously given timestamps, and look for the appropriate EAPOL start messages to begin troubleshooting.
    1. The example in this screenshot tells us our test device is connecting to Meraki-Corp, using username/password-based auth. There is a lot more detail to it than just what this screenshot reveals, but the ending of a successful connection should usually result in a log noting "4-way handshake complete"
Screenshot of the system_logs_log_archive file, which includes numerous lines or various log entries.
  1. More filtering can be done on the PID level to limit output to only a specific exchange if you believe there are other events getting intermixed in the logging by right clicking on a message in the thread, and selecting 'Show PID XXXX'
    1. macOS 10.13 (High Sierra) also introduces the ability to filter by time ranges as well, which can help further reduce the amount of potential noise to wade through.
Screen Shot 2018-02-19 at 4.25.59 PM.png