Skip to main content

Optimize Your Search with Partitions

What is a Partition?鈥�/a>

A partition stores your data in an index separate from the rest of your account's data so you can聽optimize searches,聽manage variable retention, and specify certain聽data to forward聽to S3.

Partitions route your data to an index becoming a separate subset of data in your account. Creating smaller and separate subsets of data is central to search optimization.聽When you run a search against an index, results are returned more quickly and efficiently because the search runs against a smaller data set.

This example shows a customer that created three additional Partitions to separate data by environment.

data-by-environment

Consider the following queries:

QueryPartition StatusPath
Query 1_sourceCategory=prod/security/snort
Query 2Partitions in place_index=prod AND _sourceCategory=prod/security/snort
Query 3Partitions in place_sourceCategory=prod/security/snort
Query 4Partitions in place_sourceCategory=stage/aws/cloudtrail OR _sourceCategory=prod/security/snort
  • Query 1. There are no custom Partitions created and you only have the Default Index, 100% of your data across all partitions is scanned in order to find all production log messages for the Snort security app.
  • Query 2. Partitions do exist, _index=prod limits the scope of the query and only about 40% of the data is scanned to get the same results as Query 1. But it is redundant.
  • Query 3. You can take advantage of Partitions without having to rewrite your existing queries. Sumo Logic's behind-the-scenes Query Rewriting, performed for queries run against data,聽is smart enough to understand that the scope of what you are looking for is included within _index=prod; therefore at runtime, it will rewrite the query as Query 2.
  • Query 4. We want to search for data that is in a custom Partition, as well as data that exists in the Default Index. However, query rewriting does not have the ability to OR indexes together.聽Instead, another behind-the-scenes feature, Inverse View Rewriting kicks in, we know that the data is NOT contained in the DEV and QA index, so those will be skipped. 聽This query will only scan the Prod index and the Default Index.

You can create partitions for both data tier and flex plans. By default, all data ingested into Sumo Logic will go to the continuous tier unless you specify a different data tier using the routing expression. Only data that goes to a partition can be assigned to Frequent or Infrequent Tier. Costs will be incurred for ingesting the data into Sumo Logic for continuous and frequent tier data ingestion. However, for infrequent tier data ingestion, no cost is incurred for ingesting the data, whereas pricing is determined by the scanned volume of insights and analytics. To learn more, refer to the Data Tier Partitions.

In contrast, the Flex plan does not involve configuring data into specific tiers. All data ingested under the Flex plan is classified as Flex data, and pricing is determined by the scanned volume of insights and analytics. This plan also provides access to additional default features, such as data forwarding, dashboards, monitors, scheduled searches, and scheduled views. To learn more about creating partitions with the Flex plan, refer to the Flex Partitions.

What is Query Rewriting?鈥�/a>

Whenever possible, we rewrite a user's queries to perform better. We'll illustrate this using a simple example below:.

This means that:

_sourceCategory=prod/security/snort

Will be rewritten as:

_index=prod AND _sourceCategory=prod/security/snort

This is possible because:

Therefore, defining a broad scope for your Partitions (for example,聽_sourceCategory=prod/*), and searching with _sourceCategory allows you to take advantage of query rewriting, and it allows you to potentially not have to manually rewrite your existing queries.

note

We have used a simple example of non-overlapping partitions all defined on _sourceCategory. Your data organization needs may be more complex, and in those cases we try to do a best effort query re-writing.

Create a Partition鈥�/a>

As an Admin, you create Partitions by specifying their routing expression. We recommend you use _sourceCategory to define your routing expressions to take full advantage of Query Rewriting.

The following example shows the routing expression for the three custom Partitions:

routing-expression.png

Here are simple steps to create a Partition named Dev:

  1. Classic UI. In the main Sumo Logic menu, select Manage Data > Logs > Partitions.
    New UI. In the top menu select Configuration, and then under Logs select Partitions. You can also click the Go To... menu at the top of the screen and select Partitions.
  2. Click Add Partition.
  3. In the Name field, enter Dev.
  4. In the Routing Expression field enter _sourceCategory=Dev.
  5. Select Apply the retention period of sumologic_default.
  6. Click Save.

How can my team use Partitions?鈥�/a>

Once created, Partitions can be used by anyone in your account, helping you reduce the scope of your searches and improve the performance for all users. Query 2 above takes advantage of our newly created Partition to scan only 40% of the data. As noted above, Query 3 is also a good option, because Query Rewriting will produce the same results as Query 1. This might eliminate the need to edit all your queries once your Partitions are in place.

reduce scope

Best Practices when using Partitions鈥�/a>

Avoid creating too many partitions to avoid fragmentation鈥�/a>

We recommend 20 as the maximum number of partitions. This is to avoid both index fragmentation and data management issues.

Optimal partitions are sized between 1% and 30% of total ingest鈥�/a>

Partitions that are too small may cause index fragmentation and degraded search performance. It is possible to create partitions larger than 30% without adverse effects, however the performance gains will be diminished.

Don鈥檛 create overlapping partitions鈥�/a>

This will lead to duplication of data (increasing your billed ingest rate), and degraded performance. Sumo Logic will not return duplicate results, but the process of de-duplication is time consuming and will increase query durations.

Do not use the NOT operator in partition definitions鈥�/a>

This will likely exclude data that should be contained within your partition and will reduce the chances that your partition will be reused by queries that are rewritten.

Do not use sourceHost to define your partitions鈥�/a>

It may prevent you from searching horizontally without OR鈥檌ng partitions together.

Use an intuitive naming scheme鈥�/a>

This helps users easily identify the correct partition to use.

Keep your partition broadly scoped with sourceCategory and avoid keywords鈥�/a>

Use sourceCategory in your partitions definitions and avoid keywords to keep your partition broadly scoped. You can always narrow down the scope of your search when you query your partition.

Group similar data together鈥�/a>

In the example above, we used prod/QA/Dev environment, as you will most often be searching across all your Prod data. If you need to search across environments, you can OR 2 or more Partitions.

More information鈥�/a>

See Manage Partitions.

Status
Legal
Privacy Statement
Terms of Use

Copyright 漏 2025 by Sumo Logic, Inc.