×
Community Blog Drawing Outliers on Log Service (SLS)

Drawing Outliers on Log Service (SLS)

This article explains how to draw outliers step by step with diagrams.

By Wuming
Contributed by Alibaba Cloud Storage

Many people want to reflect the position of outliers in the index when drawing the dashboard for traffic, page view, delay, and other scenarios. It means drawing curves and marking points in one chart simultaneously should be supported in the SLS chart. Next, let's move to how to draw outliers step by step.

Draw a Sequence Diagram with Points First

Next, we draw the time series and abnormal metrics based on the latency per minute metrics in the access logs. We can obtain a time series by using the following SQL statement. At the same time, we draw a straight line in the following figure, trying to mark the points beyond this red line with a red point. We often say — if the value is greater than a certain threshold, we mark it as abnormal.

* and domain: "www.abb.mock-domain.com" |
select __time__ - __time__ % 60 as time,
       avg(request_time) / 1000.0 as request_time_avg
from log
group by time
order by time
limit 10000

1

Naturally, we can judge by giving a threshold in the subquery (such as the parameter 10 below), and we will label it if it exceeds 10:

*
and domain: "www.abb.mock-domain.com" |
select time,
       request_time_avg,
       request_time_avg > 10 as flag
from (
              select __time__ - __time__ % 60 as time,
                     avg(request_time) / 1000.0 as request_time_avg
              from log
              group by time
              order by time
       )
limit 10000

However, in the results of the preceding query, we will get an additional column of index flags in the table. The meaning of this column is that >10 is True and ≤ 10 is False. However, the results cannot be described on a single y-axis since the value ranges of the corresponding y-axis are different. We will naturally consider whether the results can be changed to the original value if they exceed 10. Those that do not exceed 10 are expressed as 0.0. With that, we can obtain the following Query and distinguish the meaning of the corresponding flag dimension through the case when in the subquery:

*
and domain: "www.abb.mock-domain.com" |
select time,
       request_time_avg,
       case
              when request_time_avg > 10 then request_time_avg
              else 0.0
       end as flag
from (
              select __time__ - __time__ % 60 as time,
                     avg(request_time) / 1000.0 as request_time_avg
              from log
              group by time
              order by time
       )
limit 10000

2
3

We have obtained the multi-curve graph through the preceding various configurations. Although we are close to the results, we find there are too many red dots. We wonder if it is possible to keep the 0.0 dots not displayed.

We can draw a point equal to 0.0 because we provide a 0.0 point on the Y axis. Can we substitute 0.0 with null to keep it undisplayed? Let’s modify the case when and try again.

*
and domain: "www.abb.mock-domain.com" |
select time,
       request_time_avg,
       case
              when request_time_avg > 10 then request_time_avg
              else null
       end as flag
from (
              select __time__ - __time__ % 60 as time,
                     avg(request_time) / 1000.0 as request_time_avg
              from log
              group by time
              order by time
       )
limit 10000

4

In the preceding figure, it is very close to the result we want. The red point whose Y axis is equal to 0.0 has disappeared, but each red point is linked together into a red curve. That must be something wrong with the configuration of our curve. We enter the [Field Configuration] part again and modify the corresponding [Graphic Configuration], thus obtaining the following figure that meets our needs.

5

Provide Custom Thresholds in the Dashboard

With the operations mentioned above, we finally got a time series diagram that can draw curves and specific points. Next, how can we modify the threshold that can change the number of red dots? We need to introduce the filter in the SLS dashboard.

We add a variable replacement named [Delay Threshold], and the corresponding Key value is latency_threshold. At the same time, we add some built-in parameter value sizes to the static list item.

6

At this point, we modify the Query statement of the time series in the dashboard. Note: The corresponding variable replacement variable is listed below:

${{latency_threshold|10}}

latency_threshold is the variable name, and 10 indicates the default value
*
and domain: "www.abb.mock-domain.com" |
select time,
       request_time_avg,
       case
              when request_time_avg > ${{latency_threshold|10}} then request_time_avg
              else null
       end as flag
from (
              select __time__ - __time__ % 60 as time,
                     avg(request_time) / 1000.0 as request_time_avg
              from log
              group by time
              order by time
       )
limit 10000

7
8

After saving, we get the abnormal content in the dashboard and can achieve the results under different filter conditions by modifying [Delay Threshold].

Methods of Generating Different Outliers

There are two ways to generate outliers in the SLS platform: one is through the machine learning syntax and functions in SLS, and the other is through the Alert OpsCenter.

The basic differences between the two methods:

  1. Machine Learning Function: It is currently stateless, and only the input data is processed. The accuracy of the processing is ordinary, and each function has many parameters to learn.
  2. Intelligent Anomaly Analysis: The bottom layer is a stateful resident job, which can be modeled by real-time input data. What's more, it can simultaneously complete model inspection and model inference. The configuration is relatively simple and direct.

Use ts_predicate_arma to Generate Different Outliers

1. Use the Algorithm Directly to Generate Outliers

*
and domain: "www.abb.mock-domain.com" |
select unixtime,
       src,
       predict,
       upper_val,
       lower_val,
       case
              when prob = 0.0 then null
              else src
       end as prob
from (
              select t1 [1] as unixtime,
                     t1 [2] as src,
                     t1 [3] as predict,
                     t1 [4] as upper_val,
                     t1 [5] as lower_val,
                     t1 [6] as prob
              from (
                            select ts_predicate_arma(time, request_time_avg, 10, 1, 1) as res
                            from (
                                          select time,
                                                 request_time_avg
                                          from (
                                                        select __time__ - __time__ % 60 as time,
                                                               avg(request_time) / 1000.0 as request_time_avg
                                                        from log
                                                        group by time
                                                        order by time
                                                 )
                                   )
                     ),
                     unnest(res) as t(t1)
       )
limit 100000

9

2. Generate Custom Outliers Relying on the Algorithm

Generate outliers that exceed the threshold upward:

*
and domain: "www.abb.mock-domain.com" |
select unixtime,
       src,
       predict,
       upper_val,
       lower_val,
       case
              when prob > 0.0 and src > upper_val then src
              else null
       end as prob
from (
              select t1 [1] as unixtime,
                     t1 [2] as src,
                     t1 [3] as predict,
                     t1 [4] as upper_val,
                     t1 [5] as lower_val,
                     t1 [6] as prob
              from (
                            select ts_predicate_arma(time, request_time_avg, 10, 1, 1) as res
                            from (
                                          select time,
                                                 request_time_avg
                                          from (
                                                        select __time__ - __time__ % 60 as time,
                                                               avg(request_time) / 1000.0 as request_time_avg
                                                        from log
                                                        group by time
                                                        order by time
                                                 )
                                   )
                     ),
                     unnest(res) as t(t1)
       )
limit 100000

10

Generate outliers that exceed the threshold downward:

(*
and domain: "www.abb.mock-domain.com")| select unixtime,
       src,
       predict,
       upper_val,
       lower_val,
       case
              when prob > 0.0 and src < lower_val then src
              else null
       end as prob
from (
              select t1 [1] as unixtime,
                     t1 [2] as src,
                     t1 [3] as predict,
                     t1 [4] as upper_val,
                     t1 [5] as lower_val,
                     t1 [6] as prob
              from (
                            select ts_predicate_arma(time, request_time_avg, 10, 1, 1) as res
                            from (
                                          select time,
                                                 request_time_avg
                                          from (
                                                        select __time__ - __time__ % 60 as time,
                                                               avg(request_time) / 1000.0 as request_time_avg
                                                        from log
                                                        group by time
                                                        order by time
                                                 )
                                   )
                     ),
                     unnest(res) as t(t1)
       )
limit 100000

11

References

Disclaimer: The views expressed herein are for reference only and don't necessarily represent the official views of Alibaba Cloud.

0 1 0
Share on

Alibaba Cloud Community

1,083 posts | 273 followers

You may also like

Comments