Implementando armazenamento

O Android O adiciona suporte para 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 tempo de vida do eMMC, storaged analisa /d/mmc0/mmc0:001/ext_csd (se disponível).
  • Para culpar a E/S do aplicativo, o storaged percorre periodicamente o /proc/uid_io/stats e mantém os dados analisados, que incluem dados de todos os aplicativos (não apenas os aplicativos em execução). storaged pode chamar dumpsys para registrar o uso de E/S do aplicativo em um relatório de bug.

As informações do Diskstat (incluindo diskstats parados) e do eMMC são registradas no log de eventos do Android, onde um serviço de check-in da plataforma coleta os logs.

As operações de storaged ocorrem automaticamente e são tratadas inteiramente pela estrutura do Android, portanto, você não precisa fazer nenhum trabalho de implementação. Esta página descreve o design do storaged (incluindo novas interfaces) e como usá-lo para obter o status de E/S do kernel.

design armazenado

Para flexibilidade de contabilidade e permissão, storaged é implementado como um módulo de kernel que retorna informações de E/S por uid (em vez de usar proc/PID/io padrão). Os dados brutos de E/S para cada solicitação de E/S continuam sendo armazenados e atualizados no kernel task_struct , e o kernel acompanha quando um processo é encerrado para não perder o uso de E/S que ocorre desde o último evento de pesquisa storaged .

O módulo lê os dados brutos e os processa somente quando o framework o notifica sobre um switch uid foreground/background ou quando o daemon storaged solicita um 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 apresenta 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.
  • caracteres de leitura/gravação (também em bytes) são dados solicitados por syscalls de leitura/gravação.

Obtendo 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 saída do 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 para proc/uid_io/stats . Isso ocorre porque storaged processa dados de /proc/uid_io/stats e gera seus próprios dados.

Saída de exemplo:

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