Logs Explorer
When entities are configured for SolarWinds Observability, logs may be detected or brought in alongside the other data. For example, if a host is monitored, logs on the host may be detected and sent to SolarWinds Observability. Logs can also be sent directly to SolarWinds Observability, whether or not they correspond to a monitored entity. See Collect logs.
All logs are shown in the Logs Explorer.
In order to get the best results and to ensure that the host, app, and severity are correctly parsed, it is recommended to format logs sent to the HTTP collector as syslog.
Open the Logs Explorer
In the left pane, click Logs. The Logs Explorer lists the logs received for all of your observed entities.
Search logs
Use the Search box to search for a specific log or to filter the logs. The Search field uses simple text search.
When you enter syntax into the Search box, the Logs Explorer displays only the logs that match the syntax.
Search term examples | Explanation |
---|---|
status error
|
Logs Explorer displays only events that contain "status" and "error" in any part of the message. |
"status code"
|
Logs Explorer displays only events that contain "status code". |
"eventVersion":"1.08"
|
Logs Explorer displays only events that contain an exact match to "eventVersion" followed by "1.08". |
The search syntax is similar to Google search. For example, you can use phrases (in single or double quotes), logical operators (AND, OR), and exclusion (-).
For more information on search syntax, see Use advanced search syntax or Use JSON search syntax.
Perform time/date searches
Click the clock icon to the right of the search field to jump to logs received on a specific date and time in the searchable history.
In the Seek To field, enter a time, date, or combination. Use the International Organization for Standardization (ISO) date format: YYYY-MM-DDTHH:MM:SS.
For example: 2021-09-30T12:00:00.
The contents of Logs Explorer display logs received at the specified time.
Understand timezones as they relate to time/date searches
Display preferences affect the way time/date searches display results. For example, if user's display preference is set to Use UTC Timestamps, the timezone is always interpreted as UTC. If the display preference is not set, the following occurs.
-
When searching by time in the Logs Explorer, the searched-for timestamp is interpreted in the timezone set in the user profile.
-
SolarWinds Observability tracks the time a log message was received, and automatically displays it in the profile timezone. Users can have different timezones within the same organization, so there is less need to perform mental timezone conversions.
Save searches
Save searches for future use by clicking the folder icon inside the search bar, and then clicking Save Search. Provide a name, and optionally, select Private to make the saved search visible only to you.
Reuse saved searches by clicking the folder icon inside the search bar, and then selecting your saved search.
Create a quick alert based on a search
Create an alert based on a search by clicking the Alert button. Conditions of the current search will auto-populate to the new alert configuration. For more information, see Alerts.
Click-to-Search
When viewing logs, it is possible to enable the Click-to-Search functionality, turning specific fragments of your log messages into Click-to-Search elements. When you click those elements in the event viewer, a filter is applied and all messages that match that element will be displayed.
The click-to-search functionality in SolarWinds Observability includes the following patterns:
-
key=value pairs
-
JSON fields
-
UUIDs
To enable Click-to-Search, go to the Display Preferences tab (the cogwheel icon at the bottom of the Log Viewer) and click "Click-to-Search".
View log item details
Click the purple plus (+) or minus (-) button within a log item to expand or contract it.
Pause/restart live log events
By default, Logs Explorer shows events as they happen. The Logs Explorer is updated all the time. Logs are live.
-
To pause the live tail, click the Pause button in the top-right of the Logs Explorer. If you have live tail paused and you open a specific log for viewing, a downward facing arrow displays to the far right of the search field.
-
To resume the live tail, click the Play button.
Show details for a logged entity
Click the three vertical dots at the beginning of a log item line and click the IP address or sender's hostname to show only log entries related to the selected IP address or sender's hostname.
Share or bookmark logs
Click the three vertical dots at the beginning of a log item line, and then click the option you want to use:
- Copy Log Line Text (helpful if you need to paste text elsewhere)
- Copy Permalink (helpful if you need to bookmark a log or share with users who can log in to SolarWinds Observability)
Show velocity graph
Click the graph button to see patterns in the number of logs received at specific times.
Velocity graphs help identify patterns or anomalies, reducing time spent identifying trends or troubleshooting errors. You can also use them to seek to a particular time by clicking a point on the graph.
By default, the graph shows logs received in the past hour. You can change the time setting in the drop-down list in the top-right of the graph. The number to the left of the time setting drop-down list shows the total number of logs received for the selected period.
-
To see the number of logs received at a specific time in the graph, hover over the graph.
-
To refresh the graph, use the refresh button in the top left of the graph to refresh manually, or select Auto refresh.
Set display preferences
Setting display preferences lets you determine what display best meets your needs. Click the cog button to set your preferences. You can:
-
Change the font or set the density of text displayed in logs.
-
Enable Highlight Matches if you want the text that matches your search to be highlighted.
-
Enable Truncate Message to display each message on one line only. This is great for vertically aligning messages so you can view patterns. Click on a line to expand it.
-
Enable Use UTC Timestamps to convert your log timestamps to UTC (Universal Time Coordinated) without the need to modify the time zone in your Profile.
-
Use the other options to hide information, collapse information to a colored bullet you can hover over to see the full set of information, or show extra information, such as time, system, and severity. Severity represents the severity of events as identified by the application that sent them.
Use advanced search syntax
The search query can be constructed using the following operators:
Operator | Search results |
---|---|
term1 | containing term 1 |
term1 and term2 | containing both term1 and term2 |
term1 or term2 | one or more from either term1 or term2 (exclusively) |
~term1 | a partial match |
!~term1 | exclude a partial match (negation) |
(term1, term2, term3) OR (term4, term5, term6) | one group of terms or other group of terms |
Attributes in SolarWinds Observability are used in key:value
fashion. An example search that constrains results to those from the ssh program containing “something bad” but not “noise”, or those with an error severity, is:
("something bad" program:ssh -noise) OR severity:error
It is possible to include more than one valid value for an attribute. Messages matching either one (OR) are returned:
program:(raid5toolsethtool)
Severity and facility attributes are those from the syslog specification. If severity is a part of the displayed log message, use a text search like error or INFO to find those messages.
Use attributes:
-
To constrain matching to only a single field, either to eliminate false positives or search less data (and increase speed)
-
To search facility or severity, which are not normally examined
Attributes and attribute-less constraints can be used together, and can be combined with negation.
All attributes except message can only have a single value per message, so AND is never relevant. Because of this, all attributes default to OR, as in the program: example above. Program:(a b) means program:(a OR b).
You can use the following operators when searching for attributes:
Operator: | Search results: |
---|---|
key IS EMPTY | all entities without an attribute |
key IS NOT EMPTY | all entities with an attribute |
key:value | attribute with an indicated value |
key IN (a, b, c) / key:[1, 2, 3] |
attribute's key that is one of the members of the group |
key NOT in (a, b, c) / key:![1, 2, 3] | attribute's key that is not a member of the group |
Other recommendations
If the searched item contains the colon symbol (:), make sure to wrap the searched term in double quotes ("). It is also recommended to preface the search with "(message:<searched_term>)".
Punctuation
Other than quotes, you do not need special adaptations to use punctuation in a term or phrase. For example, to see all occurrences of IP addresses within the range 10.20.30.0 to 10.20.30.255, use this query:
10.20.30.
The dots (periods) are interpreted as part of the string. Other punctuation works the same way, and no adaptation or escaping is needed.
Similarly, the entire log message is considered for matching. The search:
bcd
will match lines containing any of these:
abcde 123bcd456 456bcd 456abcde
Sender name and program name
While sender name and program name/filename can be used in searches, they aren’t part of the phrase that SolarWinds Observability matches against. For example, this log message:
www42 httpd: GET / HTTP/1.0
would be matched by any of these queries:
www42 GET
httpd GET
www42 httpd GET
www42 httpd "GET /"
www42 OR "GET /"
However, that message would not be matched by this phrase query because the program name and separating colon are not included in the phrase:
"httpd: GET"
Use JSON search syntax
In addition to using the Google-like search syntax to find things in your logs, Logs Explorer can parse a JSON object that appears at the end of a log line. Each line can contain arbitrary string data before the JSON. For example:
2019-12-02 03:04:05 DEBUG {"a":123,"b":456}
Root level search
json.orgId:1193
Example matches:
Exact match | { "orgId": 1193 }
|
Substring match | { "orgId": 11933962 }
|
Nested search
json.user.name:pete
Example matches:
Exact match | { "user": {"name": "Pete"} }
|
Substring match | { "user": {"name": "Peter" } }
|
Exact Match
json.orgId:"11933962"
Example matches:
Exact match | { "orgId": 11933962 }
|
Negation
json.cursor.tail:false AND -json.orgId:15884562
Example matches:
Different value for orgId |
{ "orgId": 11933962, "cursor": {"tail": false} }
|
orgId not present |
{ "cursor": {"tail": false} }
|