Afinal, quanta memória minha aplicação está consumindo?

A pergunta do título, embora simples, não é fácil de responder. De qualquer forma, o conhecimento necessário para respondê-la é fundamental para conseguir resolver problemas comuns (e evitar algumas confusões) na utilização de memória.

Windows e Linux, embora adotem modelos semelhantes para gestão de memória, utilizam terminologias diferentes para indicar como ela está sendo utilizada. Nesse post, vamos utilizar a terminologia do Windows.

Como podemos classificar a memória (no Windows)

Sistemas operacionais modernos adotam um modelo de memória virtual. Ou seja, a memória alocada não está, necessariamente, ocupando RAM. Isso permite que o total de memória utilizada por todos os processos supere (largamente) a quantidade de memória fisicamente disponível. Além disso, muitos recursos podem ser compartilhados por diversos processos (fontes, DLLs, imagens, etc), logo, a memória correspondente também será compartilhada. Por fim, a alocação de memória ocorre sempre em blocos (páginas), geralmente de 64 KB, que precisam ser plenamente utilizados ou ficam sem uso (unused) e não acessíveis.

Para qualquer processo, podemos classificar a memória utilizada como:

  • Working Set – Toda memória alocada que está ocupando, fisicamente, a memória RAM. Há, três tipos de alocações:
    • Private Working Set – memória alocada e utilizada (commited), de uso exclusivo do processo, ocupando a RAM fisicamente;
    • Shareable Working Set – memória alocada e utilizada (commited), potencialmente compartilhada com outros processos (embora, não obrigatoriamente), ocupando a RAM fisicamente;
    • Shared Working Set – memória alocada e utilizada (commited), já compartilhada com outros processos, ocupando a RAM fisicamente.
  • Private bytes – Total de memória alocada e utilizada (commited), tanto na memória RAM, fisicamente, quanto em um dispositivo de persistência durável;
  • Paged bytes – montante de memória alocada e utilizada (commited) por um processo e armazenada em um dispositivo de persistência durável
  • Virtual bytes – montante total de memória alocada, não necessariamente utilizada (reserved ou commited), por um processo. Memória reservada funciona como uma preparação para a alocação em si.

Para aplicações .NET, podemos ainda classificar a memória como sendo:

  • gerenciada – alocada por meios comuns e desalocada pelo Garbage Collector.
  • não-gerenciada –  não monitoradas pelo Garbage Collector

Começando a investigar a quantidade de memória utilizada por uma aplicação

Tanto o Task Manager, na aba detalhes, quanto o Performance Monitor conseguem dar boas indicações de como a memória está sendo consumida.

O Task Manager consegue apresentar um bom instantâneo de como a memória está sendo alocada em um determinado momento. O Performance Monitor consegue indicar a progressão de consumo.

Há outras ferramentas que podemos, e vamos utilizar em outros posts.

Voltando ao cenário do post anterior

No post anterior, propus o seguinte cenário:

Você foi contratado, por uma grande instituição financeira, para resolver o problema de um Serviço Windows, escrito em .NET (não por você), que está disparando OutOfMemoryException com frequência. Você não tem autorização para fazer um dump completo da memória. Entretanto, você tem acesso aos fontes, ao “Performance Monitor” e ao “Gerenciador de Tarefas” da máquina onde esse serviço está rodando. Qual seria sua primeira medida? Por quê?

Gostei muito de todas as respostas compartilhadas. Vejamos se consigo gerar uma “continuação” a partir das respostas indicadas:

Seguindo a recomendação do Nicolas Tarzia:

Converso com as pessoas para descobrir se há um padrão (horário, tempo de uso, etc) para a ocorrência do problema. Infelizmente, não há um padrão definido. Também não há nada que chame a atenção no registro de eventos do windows.

Seguindo a recomendação do Alexsandro:

Observo, no Performance Monitor, há ocorrência de “picos” de consumo. Entretanto, nada chama a atenção além do fato do consumo total de memória (Private Bytes) crescer sem sinais de redução.

Seguindo a recomendação do Flávio Peinado:

Verifico no código, rapidamente, se há conexões com bancos de dados ou sockets que não estão sendo fechadas. Entretanto, tudo parece OK.

Seguindo a recomendação do Tiago Borba,

Verifico também se há algum recurso de IO (FileStream, por exemplo) sendo aberto e não encerrado. Novamente, tudo OK.

Por fim, seguindo a recomendação do Gustavo:

Monitoro a quantidade em Private Bytes (total de memória “commited” para o sistema) e verifico o volume alocado em Heaps gerenciados. Aqui, percebo que o volume de memória alocada em Heaps Gerenciados está estável, embora Private Bytes continue crescendo. 

Procuro por objetos sem Dispose no código e… não encontro nada.

O que pode estar acontecendo?

Compartilhe este insight:

Elemar Júnior

Sou fundador e CEO da EximiaCo e atuo como tech trusted advisor ajudando diversas empresas a gerar mais resultados através da tecnologia.

Elemar Júnior

Sou fundador e CEO da EximiaCo e atuo como tech trusted advisor ajudando diversas empresas a gerar mais resultados através da tecnologia.

Mais insights para o seu negócio

Veja mais alguns estudos e reflexões que podem gerar alguns insights para o seu negócio:

Como consultor, tenho a oportunidade de ajudar desenvolvedores, arquitetos e executivos a desenvolver soluções em TI que atendam os objetivos...
No modelo C4, o diagrama de contexto descreve, com um nível de abstração bem elevado, um sistema de software indicando...
Estamos, a maioria, em casa. Nossas rotinas não são as mesmas. Boa parte das atividades econômicas estão paradas. Aqueles que...
Quando estamos desenvolvendo aplicações distribuídas, não devemos nos perguntar se teremos problemas de conectividade. No lugar disso, devemos nos perguntar...
The following works as expected when building in Debug – the execution is done after three seconds. But, for some...
Sabemos que é  inevitável que diferentes áreas da empresa busquem e utilizem mais de uma solução de software, com frequência...

Curso Reputação e Marketing Pessoal

Masterclasses

01

Introdução do curso

02

Por que sua “reputação” é importante?

03

Como você se apresenta?

04

Como você apresenta suas ideias?

05

Como usar Storytelling?

06

Você tem uma dor? Eu tenho o alívio!

07

Escrita efetiva para não escritores

08

Como aumentar (e manter) sua audiência?

09

Gatilhos! Gatilhos!

10

Triple Threat: Domine Produto, Embalagem e Distribuição

11

Estratégias Vencedoras: Desbloqueie o Poder da Teoria dos Jogos

12

Análise SWOT de sua marca pessoal

13

Soterrado por informações? Aprenda a fazer gestão do conhecimento pessoal, do jeito certo

14

Vendo além do óbvio com a Pentad de Burkle

15

Construindo Reputação através de Métricas: A Arte de Alinhar Expectativas com Lag e Lead Measures

16

A Tríade da Liderança: Navegando entre Líder, Liderado e Contexto no Mundo do Marketing Pessoal

17

Análise PESTEL para Marketing Pessoal

18

Canvas de Proposta de Valor para Marca Pessoal

19

Método OKR para Objetivos Pessoais

20

Análise de Competências de Gallup

21

Feedback 360 Graus para Autoavaliação

22

Modelo de Cinco Forças de Porter

23

Estratégia Blue Ocean para Diferenciação Pessoal

24

Análise de Tendências para Previsão de Mercado

25

Design Thinking para Inovação Pessoal

26

Metodologia Agile para Desenvolvimento Pessoal

27

Análise de Redes Sociais para Ampliar Conexões

Lições complementares

28

Apresentando-se do Jeito Certo

29

O mercado remunera raridade? Como evidenciar a sua?

30

O que pode estar te impedindo de ter sucesso

Recomendações de Leituras

31

Aprendendo a qualificar sua reputação do jeito certo

32

Quem é você?

33

Qual a sua “IDEIA”?

34

StoryTelling

35

Você tem uma dor? Eu tenho o alívio!

36

Escrita efetiva para não escritores

37

Gatilhos!

38

Triple Threat: Domine Produto, Embalagem e Distribuição

39

Estratégias Vencedoras: Desbloqueie o Poder da Teoria do Jogos

40

Análise SWOT de sua marca pessoal

Inscrição realizada com sucesso!

No dia da masterclass você receberá um e-mail com um link para acompanhar a aula ao vivo. Até lá!

A sua subscrição foi enviada com sucesso!

Aguarde, em breve entraremos em contato com você para lhe fornecer mais informações sobre como participar da mentoria.

Crie sua conta

Preencha os dados para iniciar o seu cadastro no plano anual do Clube de Estudos:

Crie sua conta

Preencha os dados para iniciar o seu cadastro no plano mensal do Clube de Estudos:

× Precisa de ajuda?