Como encontrar a causa do alto uso de CPU do gnome-shell?

11

Estou em um Linux Fedora 23 e recentemente notei que meu processo gnome-shell usa constantemente 100% de uma CPU (reportado por htop , nenhum aplicativo visível sendo executado). Há algumas dicas que cobrem algumas soluções alternativas para bugs no gnome-shell (desativando o logotipo de plano de fundo, realinhando os monitores), mas nenhuma delas ajuda.

Eu tentei executar

perf top

que reporta mais trabalho nos seguintes símbolos:

22.55%  [kernel]                            [k] acpi_ns_search_one_scope
11.41%  [kernel]                            [k] acpi_ex_system_memory_space_h
 5.27%  [kernel]                            [k] _raw_spin_lock_irqsave
 5.23%  [kernel]                            [k] _raw_write_unlock_irqrestore
 3.52%  [kernel]                            [k] acpi_ut_update_object_referen
 ...

Depois tentei olhar mais de perto o processo gnome-shell com

perf record -g -p PID
perf report -g

mas a saída parece ser inútil:

  Children      Self  Command      Shared Object                 Symbol       
-   29.08%     0.00%  gnome-shell  [unknown]                     [.] 000000000
   - 0                                                                        
      + 55.88% 0                                                              
      + 8.25% 0x85a81                                                         
      + 6.87% 0x2                                                             
      + 5.94% 0x4                                                             
      + 4.60% 0x889fc                                                         
        3.32% 0x656c6261                                                      
      + 2.39% 0x8feab                                                         
        2.23% 0x88467                                                         
      + 1.26% 0x190800002800                                                  
      + 1.24% 0xffad7fa800100008                                              
        1.23% 0xc82ca96051913c58                                              
        1.20% 0x5602c82afa00                                                  
      + 1.18% 0x1                                                             
        1.16% 0x89e84                                                         
        1.10% 0x5602c7c68830                                                  
        1.08% 0x5602c900736e                                                  
      + 1.08% 0x7ffe4bfd1001                                                  
-   21.48%     0.00%  gnome-shell  [kernel.kallsyms]             [k] entry_SYS
   - entry_SYSCALL_64_fastpath                                                
      + 43.62% __GI___ioctl                                                   
      + 18.92% 0xf6fdd                                                        
      + 12.90% __GI___libc_open                                               
      + 5.21% 0xfb4d                                                          
      + 3.92% __GI___libc_recvmsg                                             
      + 2.89% _IO_file_read                                                   
      + 2.75% __socket                                                        
      + 2.74% __GI___libc_read                                                
      + 1.41% __GI___mmap64                                                   
      + 1.39% __GI___libc_recvmsg                                             
        1.30% 0x103b73                                                        
      + 0.77% __GI___writev                                                   
        0.74% __statfs                                                        
      + 0.74% _IO_file_open                                                   
        0.71% __GI___munmap                                                   
+    9.37%     0.00%  gnome-shell  libc-2.22.so                  [.] __GI___io
+    9.37%     0.00%  gnome-shell  [kernel.kallsyms]             [k] sys_ioctl

Você tem uma dica para mim sobre o que eu poderia fazer para inspecionar o que está acontecendo no meu sistema?

Estou em um Skylake i5 6260u com Intel Iris 540 com Fedora executando o kernel 4.3.3-300.fc23.x86_64

    
por frans 28.02.2016 / 21:45

3 respostas

4

Talvez tente usar o auditd, que seria aproximadamente algo como:

$ sudo yum install auditd
$ sudo auditctl -a exit,always -S all -F pid=1234 & sleep 15
$ sudo auditctl -d exit,always -S all -F pid=1234
$ less /var/log/audit/audit.log

Isso instalará e iniciará o auditd, definirá uma política para capturar informações de chamada do sistema para seu PID (1234 no exemplo), aguardará por um curto período para capturar uma quantidade decente de informações e, em seguida, removerá a política de auditoria. Dê uma boa olhada no auditd.log para o seu PID gnome-terminal, você pode ter uma idéia melhor do que ele está fazendo.

Outra ferramenta rápida para identificar o que um processo está gastando, é hora de fazer, é só strace, espere um pouco, então pressione CTRL-c:

$ sudo strace -c -p 1234
strace: Process 1234 attached
^Cstrace: Process 1234 detached
% time     seconds  usecs/call     calls    errors syscall
------ ----------- ----------- --------- --------- ----------------
 56.98    0.003496         388         9           clone
 17.19    0.001055           8       135           rt_sigprocmask
  6.19    0.000380          21        18         9 wait4
  4.58    0.000281          16        18           close
  3.80    0.000233          26         9           read
  3.47    0.000213          24         9           stat
  3.37    0.000207          23         9         9 rt_sigsuspend
  3.08    0.000189          21         9           pipe
  1.34    0.000082           9         9         9 rt_sigreturn
------ ----------- ----------- --------- --------- ----------------
100.00    0.006136                   225        27 total

Então, se você quiser saber mais, confira a página do manual apropriada para a chamada do sistema que você está vendo:

$ man -s2 clone

Boa sorte!

    
por 01.05.2018 / 18:38
0

apt install inxi inxi -t cm

Processes: CPU - % used - top  5 active
           1: cpu: 100% command: gnome-shell pid: 1980
           2: cpu: 1.1% command: java pid: 1425
           3: cpu: 0.1% command: java pid: 2949
           4: cpu: 0.0% command: bash pid: 32516
           5: cpu: 0.0% command: su pid: 32515
           Memory - MB / % used - top  5 active
           1: mem: 5613.34MB (35.2%) command: gnome-shell pid: 1980
           2: mem: 3256.19MB (20.4%) command: gnome-settings-daemon pid: 1647
           3: mem: 2305.28MB (14.4%) command: java pid: 1425
           4: mem: 1048.82MB (6.5%) command: java pid: 2949
           5: mem: 225.59MB (1.4%) command: java pid: 2619
    
por 01.10.2018 / 12:32
-1

Para quem encontrar um problema semelhante. Verifique se você está usando. Xorg ou caminho. Se o caminho é alterado para xorg e tudo fica bem.

    
por 05.09.2018 / 04:24