-
Notifications
You must be signed in to change notification settings - Fork 377
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Add support for splitting Perfetto traces #951
Comments
Are you sure it's actually because the file is large? Have you tried with a smaller file and things work correctly? I would be a bit surprised if the file being large was an issue albeit it's not impossible I guess. Just to be clear, if you have an 8GB Perfetto file, that will turn into a 20GB or more systrace file. What are you planning on doing with that in the end? |
I want to capture a long-term trace and then divide it into smaller ones at certain time points, but perfetto trace seems unable to be directly divided, so I want to convert it into ftrace and use text processing to divide it. Do you have any good suggestions |
Why not just collect many small traces in the first place? Would be a lot easier than capturing a big trace and then trying to split it. |
I don't know when I need the trace,so I need to collect it all |
Fine I don't think it's worth discussing more in that direction. Back to the actual topic at hand: would still be useful to know if this is only an issue on big traces or also happening on smaller traces. Especially interesting is if the cut-off is 4GB. |
The small ones won't happen, the large ones will happen multiple times, and the converted files will be empty |
Do you have enough memory on your system to have the full trace in memory i.e. at least 20GB of free memory? Because systrace conversion works by first parsing the full trace into trace processor tables before then doing the conversion. |
Specifically, what happens if you just try and just parse the trace with trace_processor_shell? Does it work? |
I only have 16G,maybe its reason |
Then how can I do for this large trace? split it by time for some small trace |
There's not really a good solution for this today unfortunately. Everyone who needs this sort of thing today just collects smaller traces in the first place. |
ok ,thank you ! |
I've changed this bug to track a better implementation of trace splitting: we might implement it at some point but for us it's not a super high priority. |
Can I use trace_processor_shell query the trace such as "select * from slice where slice > start.ts and slice.ts<end.ts" to get the trace between them and save the new trace? |
Or whether it is possible to read in batches instead of all at once
|
No neither is possible. |
Also to use trace processor with such a large trace in the first place still requires you to have enough memory to hold the full trace in memory. |
When I use as ./traceconv.exe systrace 1.pftrace 2.ftrace,I get a empty 2.ftrace,
it seems because my 1.pftrace is too large as 8G,so How can I change so large perfetto trace to ftrace,
or how can I directly capture a ftrace by som command as large as 8G?
The text was updated successfully, but these errors were encountered: