Implementar storaged

O Android 8 adiciona suporte ao storaged, um daemon nativo do Android que coleta e publica métricas de armazenamento em dispositivos Android.

  • Para Diskstats diários, storaged analisa periodicamente /sys/block/mmcblk0/stat (dispositivos de armazenamento eMMC) ou /sys/block/sda/stat (dispositivos não eMMC).
  • Para o ciclo de vida do eMMC, storaged analisa /d/mmc0/mmc0:001/ext_csd (se disponíveis).
  • Para apontar culpados por E/S de apps, o storaged é transferido periodicamente /proc/uid_io/stats e mantém dados analisados, que incluem dados de todos os aplicativos (não apenas aplicativos em execução). dumpsys sabe chame storaged para registrar o uso de E/S do app em um relatório do bug.

As informações de Diskstat (incluindo discostats parado) e eMMC são registradas no Log de eventos do Android, em que um serviço de check-in da plataforma coleta os registros.

As operações storaged ocorrem automaticamente e são totalmente processadas pelo Android para que você não precise fazer nenhum trabalho de implementação. Esta página descreve o design do storaged (incluindo novas interfaces) e como usá-lo para recebe o status de E/S do kernel.

design armazenado

Para flexibilidade de contabilidade e permissão, storaged é implementado como um kernel que retorna informações de E/S por UID (em vez de usar informações proc/PID/io). Os dados brutos de E/S de cada solicitação de E/S continuam é armazenado e atualizado no kernel task_struct, e o kernel mantém de quando um processo é encerrado para que ele não perca o uso de E/S que ocorre na último storaged evento de votação.

O módulo lê os dados brutos e os processa somente quando o framework os notifica de uma chave de primeiro/segundo plano do UID ou quando o daemon storaged solicita uma no relatório. Nesse momento, o módulo exporta um nó de arquivo do kernel para comunicação com o framework e o daemon storaged.

storaged introduz a interface /proc/uid_io/stats, que retorna uma lista de estatísticas de E/S para cada UID no sistema. O formato é:

<uid>: <foreground read bytes> <foreground write bytes> <foreground read chars> <foreground write chars> <background read bytes> <background write bytes> <background read chars> <background write chars>
  • bytes de leitura/gravação são eventos de E/S de um dispositivo de armazenamento.
  • os caracteres de leitura/gravação (também em bytes) são dados solicitados por leitura/gravação chamadas do sistema.

Receber o status de E/S do kernel

Para despejar o uso de E/S do kernel, use o comando storaged com a opção -u.

Comando: storaged -u

Formato de resposta ao comando: name/uid fg_rchar fg_wchar fg_rbytes fg_wbytes bg_rchar bg_wchar bg_rbytes bg_wbytes fg_fsync bg_fsync

Observação: essa saída é semelhante à saída de proc/uid_io/stats Isso ocorre porque o storaged processa dados dos /proc/uid_io/stats e gera os próprios dados.

Exemplo de saída:

com.google.android.backuptransport  2269  60  0  0  1719845663  143912573  149065728  184180736
com.android.vending  2170  60  0  0  219904796  38693092  174436352  18944000