Code Monkey home page Code Monkey logo

pprof-example's Introduction

PPROF - Golang tool example

Doc de como utilizar profiling no Golang

Pré requisitos

  1. Instale a ferramenta para testes de carga: GO-WRK https://github.com/tsliwowicz/go-wrk

Identificando gargalos

As funções CPUIntensitve e MemoryIntensive intensionalmente ocasionam gargalos na aplicação. Nos exemplos abaixo, utilizaremos o PPROF para identificar pontos de melhoria.

  1. Suba os servidores com o comando: go run main.go
  2. Em outra aba no terminal, execute o teste de carga com o comando: ./go-wrk -c 15 -d 15 http://localhost:8080/cpu.
  3. Enquanto o teste de carga acima estiver sendo executado, execute um dos comandos abaixo, de acordo com a necessidade:

PProf

Após a execução dos comandos acima, no terminal de execução do profiling, a tool pprof estará habilitada. Dessa forma, alguns comandos podem ser executados para identificar os pontos problemáticos no código.

>> TOP
  • Uso: top n (top 10, top 20, etc...)

Com este comando é possível visualizar os itens que mais gargalaram sua aplicação.

Para o caso de CPU, certamente, o main.fib estará entre os primeiros. Na imagem abaixo, é possível identificar que a função levou 37.42s para ser finalizada. alt text

Já para a memória, certamente, é possível identificar a função main.MemoryIntensive como a que se destaca pelo seu consumo. alt text

>> LIST
  • Uso: list "text" (ex: list CPUIntensitve)

Se houver interesse em saber o quanto determinada função está gastando de recursos, é possível realizar buscas por Regex, com o comando List.

Observe que o trecho de código "result := fib(n)" da minha função main.CPUIntensitve levou 37.54s para ser executado. alt text

Informações relevantes sobre qual trecho de código está consumindo mais memória, podem ser observados também. alt text

>> WEB
  • Uso: web

O comando web trás uma interface visual sobre o passo a passo e o consumo de cada um desses alt text

pprof-example's People

Contributors

wenlopes avatar

Watchers

 avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.