# LOGO _____ _ ____ __ |_ _(_)_ __ _ _ | _ \ _ __ ___ / _| | | | | '_ \| | | | | |_) | '__/ _ \| |_ | | | | | | | |_| | | __/| | | (_) | _| |_| |_|_| |_|\__, | |_| |_| \___/|_| |___/ # NAME Tiny::Prof - Perl profiling made simple to use. # SYNOPSIS use Tiny::Prof; my $profiler = Tiny::Prof->run; ... # $profiler goes out of scope and # then builds the results page. # DESCRIPTION This module is a tool that is designed to make profiling perl code as easy as can be. ## Run Stages When profiling, keep in mind: - The stages described below. - the scope of what should be captured/recorded. Flow of Code Execution: |== <-- Stage 1: Setup environment. | |==== <-- Stage 2: Beginning of code. | |======== <-- Stage 3: Start profiling. | | (Data is collected/recorded ONLY here!) | |======== <-- Stage 4: Stop profiling. | |==== <-- Stage 5: End of code. | |== <-- Stage 6: Restore environment | v ### Stage 1: Setup Environment These environmental variables should be setup. Failure to do so may result in missing links and/or data in the results! export PERL5OPT=-d:NYTProf export NYTPROF='trace=0:start=no:slowops=0:addpid=1' # Trace - Set to a higher value like '1' for more details. # Start - Put profiler into "standby" mode # (ready, but not running). # AddPid - Important when there are multiple processes. # SlowOps - Disabled to avoid profiling say # sleep or print. If running as a service, the environmental variables should be stored in the service file instead. On a Debian-based machine/box that may mean: systemctl status MY_SERVICE sudo vi /etc/systemdsystem/MY_SERVICE.service Add this line: Environment="PERL5OPT=-d:NYTProf" "NYTPROF='trace=0:start=no:slowops=0:addpid=1'" Then restsrt the service: systemctl restart MY_SERVICE ### Stage 2: Beginning of Code The C<profiler> at this point is in "standby" mode: - Aware of source files (important for later). - Not actually recording anything yet. ### Stage 3: Start Profiling To start profiling is like pressing a global record button. Anything after starting to profile will be stored in a file in a data format (which is mostly in machine-readable format). ### Stage 4: Stop Profiling Similary, to stop profiling is to press the global stop button. NOTE: It is important to stop the profile correctly since the results would otherwise be useless. As stated in [Devel::NYTProf](https://metacpan.org/pod/Devel%3A%3ANYTProf): "NYTProf writes some important data to the data file when finishing profiling." ### Stage 5: End of Code The C<profiler> at this point returns again to "standby" mode: - Aware of source files (maybe important for later). - Not actually recording anything anymore. ### Stage 6: Restore Environment Once profiling is done, the environment should be restored by using: unset PERL5OPT unset NYTPROF # METHODS ## run Run the `profiler` and return a special object. my $profiler = Tiny::Prof->run( %Options ); Will automatically close the recording data file when the object goes out of scope (by default). ### Options name => "my", # Name/title of the results. use_flame_graph => 0, # Generate the flame graph (very slow). root_dir => "mytprof", # Folder with results and work data work_dir => "$root_dir/work", # Folder for active work.. log => "$work_dir/log", # Proflier log. # BUGS None ... and then came along Ron :) # SUPPORT You can find documentation for this module with the perldoc command. perldoc Tiny::Prof You can also look for information at: [https://metacpan.org/pod/Tiny::Prof](https://metacpan.org/pod/Tiny::Prof) [https://github.com/poti1/tiny-prof](https://github.com/poti1/tiny-prof) # AUTHOR Tim Potapov, `<tim.potapov[AT]gmail.com>` 🐪🥷 # LICENSE AND COPYRIGHT This software is Copyright (c) 2024 by Tim Potapov. This is free software, licensed under: The Artistic License 2.0 (GPL Compatible)