SlideShare una empresa de Scribd logo
1 de 10
Descargar para leer sin conexión
Quick guide to CPU
profiling Rails apps with
k/qcachegrind
Mike Auclair
@mikeauclair
github.com/mikeauclair
Step 1:
Acquire kcachegrind(KDE) or qcachegrind
(everything else)
● qcachegrind is available in homebrew
Step 2:
Grab development_profiler.rb or something
similar to asbtract away some of the profiling
configuration, plop it in lib/
development_profiler.rb
class DevelopmentProfiler
def self.prof(file_name)
if Rails.env.development?
RubyProf.start
yield
results = RubyProf.stop
File.open "#{Rails.root}/tmp/performance/callgrind.#{file_name}.clt", 'w' do |file|
RubyProf::CallTreePrinter.new(results).print(file)
end
else
yield
end
end
end
Step 3:
Wrap your suspect code in a .prof block:
DevelopmentProfiler.prof('junk') do
SlowThing.new(45000)
end
Step 4:
Run your code and bust open the file in
qcachegrind
Contrived Example
class Shitty
def initialize(some_int)
@symbols = (0..some_int).map(&:to_s).map(&:to_sym)
end
end
Improved Contrived Example
class Better
def initialize(some_int)
@symbols = (0..some_int).map{|i| i.to_s.to_sym}
end
end
Cpu profiling

Más contenido relacionado

La actualidad más candente

programming Langauge
programming Langaugeprogramming Langauge
programming Langauge
Venet Dheer
 
Server Development Workflow For PicCollage
Server Development Workflow For PicCollageServer Development Workflow For PicCollage
Server Development Workflow For PicCollage
Lin Jen-Shin
 
Ratpack - Classy and Compact Groovy Web Apps
Ratpack - Classy and Compact Groovy Web AppsRatpack - Classy and Compact Groovy Web Apps
Ratpack - Classy and Compact Groovy Web Apps
James Williams
 
Behaviour Testing and Continuous Integration with Drupal
Behaviour Testing and Continuous Integration with DrupalBehaviour Testing and Continuous Integration with Drupal
Behaviour Testing and Continuous Integration with Drupal
smithmilner
 

La actualidad más candente (20)

Building Web Apps in Ratpack
Building Web Apps in RatpackBuilding Web Apps in Ratpack
Building Web Apps in Ratpack
 
Python training-course-content
Python training-course-contentPython training-course-content
Python training-course-content
 
Gradle by Example
Gradle by ExampleGradle by Example
Gradle by Example
 
Gradle enabled android project
Gradle enabled android projectGradle enabled android project
Gradle enabled android project
 
SF JUG - Gradle Lint
SF JUG - Gradle LintSF JUG - Gradle Lint
SF JUG - Gradle Lint
 
Lisp Meet Up #31, Clake: a GNU make-like build utility in Common Lisp
Lisp Meet Up #31, Clake: a GNU make-like build utility in Common LispLisp Meet Up #31, Clake: a GNU make-like build utility in Common Lisp
Lisp Meet Up #31, Clake: a GNU make-like build utility in Common Lisp
 
Scaling Docker Registry
Scaling Docker RegistryScaling Docker Registry
Scaling Docker Registry
 
Ruby Tuesday May 22, 2012
Ruby Tuesday   May 22, 2012Ruby Tuesday   May 22, 2012
Ruby Tuesday May 22, 2012
 
Building Your (My) First Gem
Building Your (My) First GemBuilding Your (My) First Gem
Building Your (My) First Gem
 
Containers: Anti Pattern
Containers:  Anti PatternContainers:  Anti Pattern
Containers: Anti Pattern
 
programming Langauge
programming Langaugeprogramming Langauge
programming Langauge
 
How to add Fixtures into your Django app with Mixer
How to add Fixtures into your Django app with MixerHow to add Fixtures into your Django app with Mixer
How to add Fixtures into your Django app with Mixer
 
Breaking Bad Habits with GitLab CI
Breaking Bad Habits with GitLab CIBreaking Bad Habits with GitLab CI
Breaking Bad Habits with GitLab CI
 
Gluster Containerized Storage for Cloud Applications
Gluster Containerized Storage for Cloud ApplicationsGluster Containerized Storage for Cloud Applications
Gluster Containerized Storage for Cloud Applications
 
wp-cli and plugin development with future and past compatibility (Word Camp P...
wp-cli and plugin development with future and past compatibility (Word Camp P...wp-cli and plugin development with future and past compatibility (Word Camp P...
wp-cli and plugin development with future and past compatibility (Word Camp P...
 
Server Development Workflow For PicCollage
Server Development Workflow For PicCollageServer Development Workflow For PicCollage
Server Development Workflow For PicCollage
 
Ratpack - Classy and Compact Groovy Web Apps
Ratpack - Classy and Compact Groovy Web AppsRatpack - Classy and Compact Groovy Web Apps
Ratpack - Classy and Compact Groovy Web Apps
 
Gluster containers!
Gluster containers!Gluster containers!
Gluster containers!
 
Behaviour Testing and Continuous Integration with Drupal
Behaviour Testing and Continuous Integration with DrupalBehaviour Testing and Continuous Integration with Drupal
Behaviour Testing and Continuous Integration with Drupal
 
給 RD 的 Kubernetes 初體驗 (EKS version)
給 RD 的 Kubernetes 初體驗 (EKS version)給 RD 的 Kubernetes 初體驗 (EKS version)
給 RD 的 Kubernetes 初體驗 (EKS version)
 

Destacado

DEPFST_CoverFinal_A4 [66694]
DEPFST_CoverFinal_A4 [66694]DEPFST_CoverFinal_A4 [66694]
DEPFST_CoverFinal_A4 [66694]
Ray Lau
 
Sept Plant table
Sept Plant tableSept Plant table
Sept Plant table
Debi Domby
 
Karalee Scott Résumé
Karalee Scott RésuméKaralee Scott Résumé
Karalee Scott Résumé
Karalee Scott
 
Christine Stitchman2015_Applicant
Christine Stitchman2015_ApplicantChristine Stitchman2015_Applicant
Christine Stitchman2015_Applicant
Christine Stitchman
 
You've Earned It - Volkswagen
You've Earned It - VolkswagenYou've Earned It - Volkswagen
You've Earned It - Volkswagen
Mika
 

Destacado (20)

Presentacion tiara pineda
Presentacion tiara pinedaPresentacion tiara pineda
Presentacion tiara pineda
 
Recordando un camino juntos
Recordando un camino juntosRecordando un camino juntos
Recordando un camino juntos
 
Small biz party with a purpose
Small biz party with a purposeSmall biz party with a purpose
Small biz party with a purpose
 
DEPFST_CoverFinal_A4 [66694]
DEPFST_CoverFinal_A4 [66694]DEPFST_CoverFinal_A4 [66694]
DEPFST_CoverFinal_A4 [66694]
 
Sept Plant table
Sept Plant tableSept Plant table
Sept Plant table
 
Afa.may.recruting
Afa.may.recrutingAfa.may.recruting
Afa.may.recruting
 
Government Help To Avoid Foreclosure
Government Help To Avoid ForeclosureGovernment Help To Avoid Foreclosure
Government Help To Avoid Foreclosure
 
Gestão de Projetos e Empreendedorismo: SIN-NA7 (20/11/2013)
Gestão de Projetos e Empreendedorismo: SIN-NA7 (20/11/2013)Gestão de Projetos e Empreendedorismo: SIN-NA7 (20/11/2013)
Gestão de Projetos e Empreendedorismo: SIN-NA7 (20/11/2013)
 
Mlde project
Mlde projectMlde project
Mlde project
 
Kazakhstan regulatory codes 124
Kazakhstan regulatory codes 124Kazakhstan regulatory codes 124
Kazakhstan regulatory codes 124
 
Hermeneutika al-qur'an
Hermeneutika al-qur'anHermeneutika al-qur'an
Hermeneutika al-qur'an
 
arabic ACTFL
arabic ACTFLarabic ACTFL
arabic ACTFL
 
Karalee Scott Résumé
Karalee Scott RésuméKaralee Scott Résumé
Karalee Scott Résumé
 
Presentación1
Presentación1Presentación1
Presentación1
 
Christine Stitchman2015_Applicant
Christine Stitchman2015_ApplicantChristine Stitchman2015_Applicant
Christine Stitchman2015_Applicant
 
You've Earned It - Volkswagen
You've Earned It - VolkswagenYou've Earned It - Volkswagen
You've Earned It - Volkswagen
 
Stamp exhibit double pages
Stamp exhibit double pagesStamp exhibit double pages
Stamp exhibit double pages
 
Rostechnadzor 1150
Rostechnadzor 1150Rostechnadzor 1150
Rostechnadzor 1150
 
Russia import 1227
Russia import 1227Russia import 1227
Russia import 1227
 
Scarborough_resume15-12
Scarborough_resume15-12Scarborough_resume15-12
Scarborough_resume15-12
 

Similar a Cpu profiling

Gradle - small introduction
Gradle - small introductionGradle - small introduction
Gradle - small introduction
Igor Popov
 
10 Cool Facts about Gradle
10 Cool Facts about Gradle10 Cool Facts about Gradle
10 Cool Facts about Gradle
Evgeny Goldin
 

Similar a Cpu profiling (20)

Gradle - small introduction
Gradle - small introductionGradle - small introduction
Gradle - small introduction
 
Leiningen2 - humane build management for clojure
Leiningen2 - humane build management for clojureLeiningen2 - humane build management for clojure
Leiningen2 - humane build management for clojure
 
ContainerDayVietnam2016: Django Development with Docker
ContainerDayVietnam2016: Django Development with DockerContainerDayVietnam2016: Django Development with Docker
ContainerDayVietnam2016: Django Development with Docker
 
Writing a Gem with native extensions
Writing a Gem with native extensionsWriting a Gem with native extensions
Writing a Gem with native extensions
 
Docker perl build
Docker perl buildDocker perl build
Docker perl build
 
10 Cool Facts about Gradle
10 Cool Facts about Gradle10 Cool Facts about Gradle
10 Cool Facts about Gradle
 
Leiningen 2 - Humane build management for Clojure
Leiningen 2 - Humane build management for ClojureLeiningen 2 - Humane build management for Clojure
Leiningen 2 - Humane build management for Clojure
 
GradleFX
GradleFXGradleFX
GradleFX
 
Developing with-devstack
Developing with-devstackDeveloping with-devstack
Developing with-devstack
 
Toolbox of a Ruby Team
Toolbox of a Ruby TeamToolbox of a Ruby Team
Toolbox of a Ruby Team
 
Developing with the Go client for Apache Kafka
Developing with the Go client for Apache KafkaDeveloping with the Go client for Apache Kafka
Developing with the Go client for Apache Kafka
 
MobileConf 2021 Slides: Let's build macOS CLI Utilities using Swift
MobileConf 2021 Slides:  Let's build macOS CLI Utilities using SwiftMobileConf 2021 Slides:  Let's build macOS CLI Utilities using Swift
MobileConf 2021 Slides: Let's build macOS CLI Utilities using Swift
 
Gradle in 45min
Gradle in 45minGradle in 45min
Gradle in 45min
 
Buildr In Action @devoxx france 2012
Buildr In Action @devoxx france 2012Buildr In Action @devoxx france 2012
Buildr In Action @devoxx france 2012
 
Docker Basics & Alfresco Content Services
Docker Basics & Alfresco Content ServicesDocker Basics & Alfresco Content Services
Docker Basics & Alfresco Content Services
 
Bangpypers april-meetup-2012
Bangpypers april-meetup-2012Bangpypers april-meetup-2012
Bangpypers april-meetup-2012
 
파이썬 개발환경 구성하기의 끝판왕 - Docker Compose
파이썬 개발환경 구성하기의 끝판왕 - Docker Compose파이썬 개발환경 구성하기의 끝판왕 - Docker Compose
파이썬 개발환경 구성하기의 끝판왕 - Docker Compose
 
Настройка окружения для кросскомпиляции проектов на основе docker'a
Настройка окружения для кросскомпиляции проектов на основе docker'aНастройка окружения для кросскомпиляции проектов на основе docker'a
Настройка окружения для кросскомпиляции проектов на основе docker'a
 
Control your deployments with Capistrano
Control your deployments with CapistranoControl your deployments with Capistrano
Control your deployments with Capistrano
 
Us 17-krug-hacking-severless-runtimes
Us 17-krug-hacking-severless-runtimesUs 17-krug-hacking-severless-runtimes
Us 17-krug-hacking-severless-runtimes
 

Último

Cloud Frontiers: A Deep Dive into Serverless Spatial Data and FME
Cloud Frontiers:  A Deep Dive into Serverless Spatial Data and FMECloud Frontiers:  A Deep Dive into Serverless Spatial Data and FME
Cloud Frontiers: A Deep Dive into Serverless Spatial Data and FME
Safe Software
 
Why Teams call analytics are critical to your entire business
Why Teams call analytics are critical to your entire businessWhy Teams call analytics are critical to your entire business
Why Teams call analytics are critical to your entire business
panagenda
 
Artificial Intelligence: Facts and Myths
Artificial Intelligence: Facts and MythsArtificial Intelligence: Facts and Myths
Artificial Intelligence: Facts and Myths
Joaquim Jorge
 

Último (20)

Axa Assurance Maroc - Insurer Innovation Award 2024
Axa Assurance Maroc - Insurer Innovation Award 2024Axa Assurance Maroc - Insurer Innovation Award 2024
Axa Assurance Maroc - Insurer Innovation Award 2024
 
Polkadot JAM Slides - Token2049 - By Dr. Gavin Wood
Polkadot JAM Slides - Token2049 - By Dr. Gavin WoodPolkadot JAM Slides - Token2049 - By Dr. Gavin Wood
Polkadot JAM Slides - Token2049 - By Dr. Gavin Wood
 
TrustArc Webinar - Stay Ahead of US State Data Privacy Law Developments
TrustArc Webinar - Stay Ahead of US State Data Privacy Law DevelopmentsTrustArc Webinar - Stay Ahead of US State Data Privacy Law Developments
TrustArc Webinar - Stay Ahead of US State Data Privacy Law Developments
 
Powerful Google developer tools for immediate impact! (2023-24 C)
Powerful Google developer tools for immediate impact! (2023-24 C)Powerful Google developer tools for immediate impact! (2023-24 C)
Powerful Google developer tools for immediate impact! (2023-24 C)
 
Cloud Frontiers: A Deep Dive into Serverless Spatial Data and FME
Cloud Frontiers:  A Deep Dive into Serverless Spatial Data and FMECloud Frontiers:  A Deep Dive into Serverless Spatial Data and FME
Cloud Frontiers: A Deep Dive into Serverless Spatial Data and FME
 
Connector Corner: Accelerate revenue generation using UiPath API-centric busi...
Connector Corner: Accelerate revenue generation using UiPath API-centric busi...Connector Corner: Accelerate revenue generation using UiPath API-centric busi...
Connector Corner: Accelerate revenue generation using UiPath API-centric busi...
 
presentation ICT roal in 21st century education
presentation ICT roal in 21st century educationpresentation ICT roal in 21st century education
presentation ICT roal in 21st century education
 
Bajaj Allianz Life Insurance Company - Insurer Innovation Award 2024
Bajaj Allianz Life Insurance Company - Insurer Innovation Award 2024Bajaj Allianz Life Insurance Company - Insurer Innovation Award 2024
Bajaj Allianz Life Insurance Company - Insurer Innovation Award 2024
 
Boost PC performance: How more available memory can improve productivity
Boost PC performance: How more available memory can improve productivityBoost PC performance: How more available memory can improve productivity
Boost PC performance: How more available memory can improve productivity
 
Apidays New York 2024 - Scaling API-first by Ian Reasor and Radu Cotescu, Adobe
Apidays New York 2024 - Scaling API-first by Ian Reasor and Radu Cotescu, AdobeApidays New York 2024 - Scaling API-first by Ian Reasor and Radu Cotescu, Adobe
Apidays New York 2024 - Scaling API-first by Ian Reasor and Radu Cotescu, Adobe
 
Apidays New York 2024 - The Good, the Bad and the Governed by David O'Neill, ...
Apidays New York 2024 - The Good, the Bad and the Governed by David O'Neill, ...Apidays New York 2024 - The Good, the Bad and the Governed by David O'Neill, ...
Apidays New York 2024 - The Good, the Bad and the Governed by David O'Neill, ...
 
Apidays New York 2024 - The value of a flexible API Management solution for O...
Apidays New York 2024 - The value of a flexible API Management solution for O...Apidays New York 2024 - The value of a flexible API Management solution for O...
Apidays New York 2024 - The value of a flexible API Management solution for O...
 
A Domino Admins Adventures (Engage 2024)
A Domino Admins Adventures (Engage 2024)A Domino Admins Adventures (Engage 2024)
A Domino Admins Adventures (Engage 2024)
 
Bajaj Allianz Life Insurance Company - Insurer Innovation Award 2024
Bajaj Allianz Life Insurance Company - Insurer Innovation Award 2024Bajaj Allianz Life Insurance Company - Insurer Innovation Award 2024
Bajaj Allianz Life Insurance Company - Insurer Innovation Award 2024
 
Strategies for Landing an Oracle DBA Job as a Fresher
Strategies for Landing an Oracle DBA Job as a FresherStrategies for Landing an Oracle DBA Job as a Fresher
Strategies for Landing an Oracle DBA Job as a Fresher
 
Partners Life - Insurer Innovation Award 2024
Partners Life - Insurer Innovation Award 2024Partners Life - Insurer Innovation Award 2024
Partners Life - Insurer Innovation Award 2024
 
HTML Injection Attacks: Impact and Mitigation Strategies
HTML Injection Attacks: Impact and Mitigation StrategiesHTML Injection Attacks: Impact and Mitigation Strategies
HTML Injection Attacks: Impact and Mitigation Strategies
 
Why Teams call analytics are critical to your entire business
Why Teams call analytics are critical to your entire businessWhy Teams call analytics are critical to your entire business
Why Teams call analytics are critical to your entire business
 
ProductAnonymous-April2024-WinProductDiscovery-MelissaKlemke
ProductAnonymous-April2024-WinProductDiscovery-MelissaKlemkeProductAnonymous-April2024-WinProductDiscovery-MelissaKlemke
ProductAnonymous-April2024-WinProductDiscovery-MelissaKlemke
 
Artificial Intelligence: Facts and Myths
Artificial Intelligence: Facts and MythsArtificial Intelligence: Facts and Myths
Artificial Intelligence: Facts and Myths
 

Cpu profiling