Troubleshooting (“I don’t see my clients”)
Debugging the client installation
If the installer is failing to run, it should output a log file which will help you debug. The location of the logfile is configurable, but by default should be:
Linux/Mac OSX: /tmp/grr_installer.txt
Once you have done this, you can download the new binary from the Web UI. It should have the same configuration, but will output detailed progress to the console, making it much easier to debug.
Note that the binary is also a zipfile, you can open it in any capable zip reader. Unfortunately this doesn’t include the built in Windows zip file handler but does include winzip or 7-zip. Opening the zip is useful for reading the config or checking that the right dependencies have been included.
Repacking the Windows client in verbose mode enables console output for both the installer and for the application itself. It does so by updating the header of the binary at PE_HEADER_OFFSET + 0x5c from value 2 to 3. This is at 0x144 on 64 bit and 0x134 on 32 bit Windows binaries. You can do this manually with a hex editor as well.
Interactively Debugging the Client
On each platform, the client binary should support the following options:
–verbose: This will set higher logging allowing you to see what is going on.
–pdb_post_mortem: If set, and an unhandled error occurs in the client, the client will break into a pdb debugging shell.
C:\Windows\system32>net stop "grr monitor" The GRR Monitor service is stopping. The GRR Monitor service was stopped successfully. C:\Windows\system32>c:\windows\system32\grr\220.127.116.11\grr.exe --config grr.exe.yaml --verbose
Note that on Windows, the GRR client is running completely in the background so starting it from the console will not give you any output. For this reason, we always also build a dbg_GRR[…].exe client that is a console application and can be used for this kind of debugging.
Changing Logging For Debugging
On all platforms, by default only hard errors are logged. A hard error is defined as anything level ERROR or above, which is generally reserved for unrecoverable errors. But because temporary disconnections are normal, an client failing to talk to the server doesn’t actually count as a hard error.
In the client you will likely want to set:
And depending on your configuration, you can play with syslog, log file
and Windows EventLog logging using parameters
Proxies and Connectivity
If an client can’t connect to the server, there can be a number of reasons such as:
Server Isn’t Listening Confirm you can connect to the server and retrieve the server.pem file. E.g.
Proxy Required For Access If the environment doesn’t allow direct connections GRR may need to use a proxy. GRR currently doesn’t support Proxy Autoconfig or Proxy Authentication. GRR will attempt to guess your proxy configuration, or you can explicitly set proxies in the config file, e.g.
On Windows systems GRR will try a direct connection, and then search for configured proxies in all users profiles on the system trying to get a working connection. On Linux GRR should obey system proxy settings, and it will also obey environment variables. e.g.
$ export http_proxy=http://cache.example.com:3128
Outbound Firewall Blocking Connections GRR doesn’t do anything to bypass egress firewalling by default. However, if you have a restrictive policy you could add this as an installer plugin.
If you look at the running config, the first time the client
successfully connects to the server a variable
Client.server_serial_number will be written to the config. If that
exists, the client successfully made a connection.
The client shouldn’t ever crash… but it does because making software is hard. There are a few ways in which this can happen, all of which we try and catch, record and make visible to allow for debugging. In the UI they are visible in two ways, in “Crashes” when a client is selected, and in “All Client Crashes”. These have the same information but the client view only shows crashes for the specific client.
Each crash should contain the reason for the crash, optionally it may contain the flow or action that caused the crash. In some cases this information is not available because the client may have crashed when it wasn’t doing anything or in a way where we could not tie it to the action.
This data is also emailed to the email address configured in the config
Crashed while executing an action
Often seen with an error “Client killed during transaction”. This means that while handling a specific action, the client died. The nanny knows this because the client recorded the action it was about to take in the Transaction Log before starting it. When the client restarts it picks up this log and notifies the server of the crash.
Client segfaults, could happen in native code such as Sleuth Kit or psutil.
Hard reboot while the machine was running an action where the client service didn’t have a chance to exit cleanly.
Unexpected child process exit!
This means the client exited, but the nanny didn’t kill it.
Uncaught exception in python, very unlikely due to the fact that we catch Exception for all client actions.
Memory limit exceeded, exiting
This means the client exited due to exceeding the soft memory limit.
Client hits the soft memory limit. Soft memory limit is when the client knows it is using too much memory but will continue operation until it finishes what it is doing.
Nanny Message - No heartbeat received
This means that the Nanny killed the client because it didn’t receive a Heartbeat within the allocated time.
The client has hung, e.g. locked accessing network file
The client is performing an action that is taking longer than it should.
I don’t see my clients
Here are common client troubleshooting steps you can work through to diagnose client install and communications problems.
Check that the client got installed
You should have something like:
/usr/lib/grr/grr_18.104.22.168_amd64/grrdon linux; and
with variations based on the GRR version and architecture you installed. If you didn’t get this far, then there is a problem with your installer binary.
Check the client is running
On linux and OS X you should see two processes, something like:
$ ps aux | grep grr root 957 0.0 0.0 11792 944 ? Ss 01:12 0:00 /usr/sbin/grrd --config=/usr/lib/grr/grr_22.214.171.124_amd64/grrd.yaml root 1015 0.2 2.4 750532 93532 ? Sl 01:12 0:01 /usr/sbin/grrd --config=/usr/lib/grr/grr_126.96.36.199_amd64/grrd.yaml
On windows you should see a
GRR Monitor service and a
process in taskmanager.
If it isn’t running check the install logs and other logs in the same directory:
and then try running it interactively as below.
Check the client machine can talk to the server
The URL here should be the server address and port you picked when you
set up the server and listed in
Client.control_urls in the client’s
wget http://yourgrrserver.yourcompany.com:8080/server.pem # Check your config settings, note that clients earlier than 188.8.131.52 used Client.control_urls $ sudo cat /usr/lib/grr/grr_184.108.40.206_amd64/grrd.yaml | grep Client.server_urls Client.server_urls: http://yourgrrserver.yourcompany.com:8080/
If you can’t download that server.pem, the common causes are that your server isn’t running or there are firewalls in the way.
Run the client in verbose mode
Linux: Stop the daemon version of the service and run it in verbose mode:
$ sudo service grr stop $ sudo /usr/sbin/grrd --config=/usr/lib/grr/grr_220.127.116.11_amd64/grrd.yaml --verbose
OS X: Unload the service and run it in verbose mode:
$ sudo launchctl unload /Library/LaunchDaemons/com.google.code.grr.plist $ sudo /usr/local/lib/grr_18.104.22.168_amd64/grrd --config=/usr/local/lib/grr_22.214.171.124_amd64/grrd.yaml --verbose
Windows: The normal installer isn’t a terminal app, so you don’t get any output if you run it interactively.
Install the debug
dbg_GRR_126.96.36.199_amd64.exeversion to make it a terminal app.
GRR Monitorservice in task manager
Then run in a terminal as Administrator
cd C:\Windows\System32\GRR\188.8.131.52\ GRR.exe --config=GRR.exe.yaml --verbose
If this is a new client you should see some 406’s as it enrols, then they stop and are replaced with sending message lines with increasing sleeps in between. The output should look similar to this:
Starting client aff4:/C.a2be2a27a8d69c61 aff4:/C.a2be2a27a8d69c61: Could not connect to server at http://somehost:port/, status 406 Server PEM re-keyed. sending enrollment request aff4:/C.a2be2a27a8d69c61: Could not connect to server at http://somehost:port/, status 406 Server PEM re-keyed. sending enrollment request aff4:/C.a2be2a27a8d69c61: Could not connect to server at http://somehost:port/, status 406 Server PEM re-keyed. aff4:/C.a2be2a27a8d69c61: Sending 3(1499), Received 0 messages in 0.771058797836 sec. Sleeping for 0.34980125 aff4:/C.a2be2a27a8d69c61: Sending 0(634), Received 0 messages in 0.370272874832 sec. Sleeping for 0.4022714375 aff4:/C.a2be2a27a8d69c61: Sending 0(634), Received 0 messages in 0.333703994751 sec. Sleeping for 0.462612153125 aff4:/C.a2be2a27a8d69c61: Sending 0(634), Received 0 messages in 0.345727920532 sec. Sleeping for 0.532003976094 aff4:/C.a2be2a27a8d69c61: Sending 0(634), Received 0 messages in 0.346176147461 sec. Sleeping for 0.611804572508 aff4:/C.a2be2a27a8d69c61: Sending 0(634), Received 8 messages in 0.348709106445 sec. Sleeping for 0.2
If enrolment isn’t succeeding (406s never go away), make sure you’re
running a worker process and check logs in