20 Mar 2025 06:20 PM
Hello.
Is Segments a replacement for Management Zones?
If yes, when will Management Zones be deprecated?
Thank you.
Solved! Go to Solution.
21 Mar 2025 05:51 AM
Hi @ASE
For Dynatrace managed:
BR,
Peter
07 Jun 2025 06:34 PM
I share the view of Peter, Management Zones are your helicopter view of your infrastructure and application and they are strongly linked to tags. The Segments are you low level filters for distributed traces. It does not make sense to deprecate management zones. You will agree with my conclusion if you follow this presentatio so you fully understand the concept of segments. Analyze and filter trace data with Dynatrace | Dynatrace App Spotlights. No panic ASE, you have a good design in place in the MZ design.
08 Jun 2025 11:37 AM
Sadly, the option to filter dashboards based on Managment Zones is no longer there in the new verison. It seems to be going in that direction. I need to do more digging into this but here is the full documentation if you are interested. Segments — Dynatrace Docs
10 Jun 2025 07:24 AM
Hello Marwan
There are upcoming improvements for defining Segments (with improved support for tags) on the horizon.
Feel free to reach out in case you identify any blocker for your use cases - would love to understand your background in more detail.
Best Regards
Christian
10 Jun 2025 09:59 AM
Thanks Christian, Please connect via linkedIn, happy to connect and share. My linkedIn is in my profile. see also my input in the same topic which I contributed to support Segments as well as Management Zone. A new way to look at Management Zones and the new future design-segments. - Dynatrace Community - These two article need to link to each other as this topic is quite important and relevant. Thanks
21 Mar 2025 08:04 AM
Hi ASE,
As per my understanding, Segments are a lower level of separations for the environment, which can work on transactions, events, spans,..etc. you can consider it as a set of filters in one template. Management zone are mainly used for access controls across the environment.
Thanks,
Islam
22 Mar 2025 03:43 AM
I was told that "Segments is replacing Management Zones".
We are currently using Management Zones as different environments (PROD, TEST, STAGING, etc..).
We have many Management Zone Rules for each.
When it comes to Problem Alerts, Problem Alerting Profiles, and Slack Notification Integration, Management Zones play a big part in this. For example, if an entity does not have a Management Zone assigned to it (via MZ rules), the Problem Alert won't be associated with a Problem Alerting Profile, causing the alert to not get routed to the relevant Slack channel. It's all interconnected.
With our current Management Zone configuration, we can easily filter our Problem Alerts in the Problems app by Management Zone (Environment). Example: If I only want to see PROD Problem Alerts, I select the PROD Management Zone. It's so easy and works really well for our teams.
My concern is Management Zones being deprecated/replaced and then having to rework/migrate everything to Segments.
Will Segments be this interconnected with Problem Alerts, Problem Alerting Profiles, and Slack Notification Integration like Management Zones are?
I'm hoping I was just misinformed and we'll be able to keep Management Zone configurations as is. 😅
Thank you.
11 Jun 2025 11:42 PM
Update regarding this statement:
"With our current Management Zone configuration, we can easily filter our Problem Alerts in the Problems app by Management Zone (Environment). Example: If I only want to see PROD Problem Alerts, I select the PROD Management Zone. It's so easy and works really well for our teams."
I was able to create several Segments that we are now using in the new Problems app that allow us to quickly "filter" by environment (which mirrors what we were able to do in the Problems Classic app).
This is working great for now.
However, my concern still stands. I'm still waiting to see how interconnected Segments will be with our existing 200+ Metric Events, Problem Alerts, Problem Alerting Profiles, and Slack Notification Integrations.
When you create a custom Metric Event, the Management Zone field has a direct effect on whether or not the Problem Alert it generates will be routed to its respective Slack alerting channel.
24 Mar 2025 08:30 PM
Hello
The answer is "kind of" or "yes but no" 😁
With the introduction of latest Dynatrace we had to find a new way to structure and filter data, as the existing static concept of (rule-based) Management Zones was not capable of supporting the new requirements coming hand-in-hand with the new Grail architecture, as well as the new scalability demands.
As a result, there are three new concepts which all together help admins and users to organize data:
Please note: any app consuming data stored in Grail needs new IAM policies for defining access as well as Segments for filtering. Management Zones are only needed for classic apps and will be retired once we completely switch over to the latest Dynatrace.
So no, Segments are no direct replacement for Management Zones - but they take over a specific use case in a much more flexible and easier-to-manage way. And yes, also alerting profiles will be bound to Segments.
We know that this is a huge change for existing customers - we are therefor currently crafting guides that help you in transitioning existing Management Zone definitions into Segments to reduce the work needed to an absolute minimum. Expect an update within the next weeks.
If you have detailed questions feel free to reach out to your CSM.
28 Mar 2025 10:51 PM
Thank you, @christian_k.
Do you have any information on how this will impact Metric Events?
We have hundreds of custom Metric Events that are all tied to specific Management Zones.
12 May 2025 12:45 PM
Hello,
Is there an update regarding the guides ?
Regards,
Aquilain
22 May 2025 07:12 AM
Hello Aquilain
The doc team is currently working on adding the first guide. Will go live this or next sprint.
Regards
Christian
21 May 2025 10:26 PM - edited 21 May 2025 10:26 PM
Hi,
Is there an update regarding?
22 May 2025 07:13 AM
Hello Jeffrey
See my reply above - first documents are in the making.
Regards
Christian
12 Jun 2025 09:05 AM
Thanks @christian_k for insightful answer and organized content.
12 Jun 2025 03:42 PM
All, Please also vote for this one. Thank you. https://community.dynatrace.com/t5/Product-ideas/Management-Zone-filter-for-New-style-Dashboard/idi-...
12 Jun 2025 04:22 PM
Please see this:
Add in a conversion mechanism to convert the Management Zone to the new Segment Design
Also, you can do a Variable using dql to pull MZs.
Example of a service:
fetch dt.entity.service
| filter isNotNull(managementZones)
| fields managementZones
| dedup managementZones
I know not what most of us are use to but it helps.
12 Jun 2025 06:59 PM
Dynatrace has decided to change the model, so they are supposed to help us achieve the same result we have today using MZ and policies.
For now it is not the case, we are in an hybrid state with no clear idea of how to achieve that
12 Jun 2025 09:00 PM
Hello Nicolas
You can be assured that we 100% understand your point.
Please get in touch with your CSM and point him to this thread. In case they are not sure what to do, let them know they should contact me to support you in your transition journey.
Best Regards
Christian
22 Jun 2025 12:33 PM
Nicolas, please also vote for this:
01 Jul 2025 06:34 PM
Hello everyone, this is my solution to display problems based on the management zone.
export default async function () {
  const baseUrl = "https://{environmentid}.live.dynatrace.com/api/v2/problems";
  const headers = {
    "Authorization": "Api-Token YOUR_API_TOKEN",
    "Content-Type": "application/json"
  };
  async function fetchProblems() {
    const queryParams = new URLSearchParams({
      pageSize: "50",
      from: "now-30d",
      to: "now",
      problemSelector: 'status("OPEN")'
    });
    const response = await fetch(`${baseUrl}?${queryParams.toString()}`, {
      method: "GET",
      headers
    });
    const result = await response.json();
    return result.problems || [];
  }
  try {
    const problems = await fetchProblems();
    const filtered = problems
      .filter(p =>
        (p.managementZones || []).some(zone => zone.name === "YOUR_MANAGEMENT_ZONE")
      )
      .map(p => ({
        Problem: p.displayId,
        Title: p.title,
        ManagementZones: p.managementZones.map(mz => mz.name)
      }));
    return filtered;
  } catch (error) {
    console.error("❌ Error fetching problems:", error);
    return `Error: ${error.message}`;
  }
}02 Jul 2025 09:25 AM
This a useful function. You may consider protecting your token as you do not want to expose it when you save your code somewhere. It may be safer to extract the token from the header after the call or you do encrypt it using a fixed secret which you can extract from a meta fixed environment, use a local simple encrypt function. Let me know if you have a solution other wise I will provide my simple encrypt solution. The best is to extract the token from the header of the AppFunction call but I do not know how to do that at the moment, I can only extract the PayLoad, and I have no way to extract the header i-on its own. Hope this is helpful.
02 Jul 2025 02:11 PM
Yes, first you need to store the token in the Credential Vault, and then use it like this in your workflow code:
import { credentialVaultClient } from "@dynatrace-sdk/client-classic-environment-v2";
export default async function () {
  const credentialId = "ID_CREDENTIALS_VAULT"; 
  const credential = await credentialVaultClient.getCredentialsDetails({
    id: credentialId
  });
  const baseUrl = "https://{environmentid}.live.dynatrace.com/api/v2/problems";
  const headers = {
    "Authorization": credential.token,
    "Content-Type": "application/json"
  };
... rest of code
};02 Jul 2025 05:36 PM
Thanks for the above. I am not sure how the above is compiling for you? there is no .token you can extract, see above. 
02 Jul 2025 07:23 PM
I’m using Workflows and that way it works, however, you could try a .type?.token according to what the documentation says."
https://docs.dynatrace.com/docs/shortlink/api-credentials-vault-put-credentials
02 Jul 2025 08:59 PM
Thanks Jeffrey for sharing that you are workflow, mine is needed as system to system and I need to use platform api call. anyway, here is what I get, maybe someone can resolve this, I see the type but unfortunately nothing after for a token 🙂
10 Jul 2025 10:16 AM
Hello,
We are trying to apply segments to a basic dashboard (response time split by service). The segments are configured to split the data by environnement (prod, qual, preprod...). We are using tags on host, process and services.
Unfortunately, this configuration doesn't display anything on the dashboard when it is applied. Do you know what could be missing ?
14 Jul 2025 01:51 PM
hi @JMBMinint
You're assuming that filtering on entities would imply that the filter is also applied to the data that is linked to entities, as it is the case with management zones. With data stored in Grail, this is not the case. You have to include in the segment definition also the "data".
We just released a set of best practices on how to transition from management zones to segments. Please have a look at it to get some inspiration on what this can look like for you: https://docs.dynatrace.com/docs/shortlink/transition-guide-segments
Best,
Sini
15 Jul 2025 03:23 PM
Hi Sini,
Thanks for your reply, the application we are monitoring is in app only mode and run in a Heroku base environment. Is it a cloud-native scenario? If yes, which environment variables I have to set? Here is the one already setted => DT_CUSTOM_PROP_HEROKU_APP="app=CPERFRONT env=PROD"
Best regards,
JM
15 Jul 2025 04:27 PM
Hi JM,
Yes, your scenario is a cloud native one.
I am not sure where you found the DT_CUSTOM_PROP_HEROKU_APP environment variable; what we have in our documentation is DT_CUSTOM_PROP without the suffix. Having DT_CUSTOM_PROP or DT_TAGS environment variables causes host and process-level metrics sent by the particular OneAgent to have the defined key value combinations available in the environment variable as metric dimensions and values in Grail. 
Unfortunately, the environment variables don't enrich spans. But the OneAgent is picking up for spans the environment variable OTEL_RESOURCE_ATTRIBUTES. 
If you are using the traces on grail capability and want the span data to be enriched in grail with your custom fields then you can do this like follows.
OTEL_RESOURCE_ATTRIBUTES="app=CPERFRONT,env=PROD"The semantic is a bit different, comma instead of space.
We are currently working to streamline OneAgent side enrichment when using environment variables so in future setting one environment variable will be sufficient.
Best
Sini
16 Jul 2025 09:52 AM
Hi Sini,
I got this environnement variable from the DT support.
So if I put these two variables, I should be good ?
DT_CUSTOM_PROP="app=CPERFRONT,env=PROD"
OTEL_RESOURCE_ATTRIBUTES="app=CPERFRONT,env=PROD"
Best regards,
JM
16 Jul 2025 04:08 PM
Yes if you add those two environment variables, you should be good.
Please let me know the outcome.
Best,
Sini
23 Jul 2025 09:34 AM
Hi Sini,
We implemented the two variables, but I still don't know how to configure the data fields in the segment configuration. Nothing changes overthere. Do I need a variable?
Best regards,
JM
04 Aug 2025 09:34 AM
Hi JM,
Yes, you need a variable. This would be the definition of the segment variable
fetch metric.series
| filter isNotNull(app)
| fields app , metadata = concat("[ENVIRONMENT]app:",app)
And this is how the segment definition could look like
You have also to propagate your variables (app & env) to Davis problems. In settings, you need to configure your tag to be propagated to Davis problems.
Best,
Sini
04 Aug 2025 04:04 PM
Hi Sini,
Thanks for your reply ! The DQL request return nothing. Is there something I have to do to so that the environment variable are available in Grail ?
Regards
JM
Regards,
Jean-Michel
04 Aug 2025 04:46 PM
Can you try to set the environment variables without double quotes for the OTEL_RESOURCE_ATTRIBUES env var? In some deployment environments, double quotes might cause problems.
OTEL_RESOURCE_ATTRIBUTES=app=CPERFRONT,env=PROD
For the DT_CUSTOM_PROP one, you have to use "blank" as a field separator.
DT_CUSTOM_PROP="app=CPERFRONT env=PROD"
Currently, we're working on improving documentation about how to set these environment variables. Just looked up the first draft of this documentation.
Best,
Sini
11 Sep 2025 10:06 PM
Updated link is https://docs.dynatrace.com/docs/manage/segments/upgrade-guide-segments for those who need it since the shortlink doesn't work anymore.
08 Oct 2025 12:29 PM
Hi,
What would you suggest for a new customer to use to separate dev and prod environments by aws account id. He also wants to have access control - e.g. one group of people to access dev and other prod. - Management zones + Segments (for Notebooks and Dashbords), Segments + some specific configuration in Account Management, .... ?
Regards, Deni
