AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • Início
  • system&network
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • Início
  • system&network
    • Recentes
    • Highest score
    • tags
  • Ubuntu
    • Recentes
    • Highest score
    • tags
  • Unix
    • Recentes
    • tags
  • DBA
    • Recentes
    • tags
  • Computer
    • Recentes
    • tags
  • Coding
    • Recentes
    • tags
Início / unix / Perguntas / 537965
Accepted
Travis Griggs
Travis Griggs
Asked: 2019-08-29 14:03:32 +0800 CST2019-08-29 14:03:32 +0800 CST 2019-08-29 14:03:32 +0800 CST

Sincronizar ou não sincronizar em um ambiente incorporado?

  • 772

Eu tenho um dispositivo de placa única que executa o Debian 10 em um pedaço de flash. O UBIFS é usado e é dividido em dois volumes: um ro roots e um rw /var. Descobri que, em condições de ciclo de energia/redefinição, posso acabar com arquivos de 0 byte. Eu mantenho minhas "configurações" em /var/opt/myApp. Alterar a opção de montagem de /var para incluir syncparece fazer com que esses incidentes desapareçam.

Eu sei que o conselho usual é que o assíncrono é preferível à sincronização, mas geralmente é ressalvado com "geralmente, mas nem sempre" com pouca explicação sobre quais podem ser as exceções.

A solução alternativa seria modificar todo e qualquer site de chamadas onde eu escrevo dados no disco, para não apenas liberar o fechamento do arquivo, mas também sincronizar (faço muito disso com python). Por uma questão de codificação/completude, a montagem syncparecia menos trabalhosa e evitou que eu perdesse a adição dos guardas de sincronização em alguns lugares, pois é universal.

Além disso, permito que o dispositivo salve dados em pen drives USB. Acho que devo montar essa sincronização também, para reduzir a perda quando eles são retirados logo após os dados serem gravados neles.

Esta é uma configuração excepcionalmente adequada para justificar o uso sync? Ou devo usar a solução alternativa?

linux filesystems
  • 1 1 respostas
  • 1408 Views

1 respostas

  • Voted
  1. Best Answer
    HarshaD
    2019-10-19T06:39:09+08:002019-10-19T06:39:09+08:00

    Aqui está a minha opinião: Desculpe pela verbosidade com antecedência.

    Quando estamos falando especificamente ubifs, devemos sempre syncopções semelhantes.

    ubifsapoiawrite-back caching

    Isso significa que as alterações escritas nos arquivos não vão para o flash diretamente. Eles são armazenados no cache da página primeiro e depois gravados no flash. (Leia mais sobre write buffersflashes NAND no UBIFS)

    Isso melhora o desempenho do sistema de arquivos reduzindo o número de gravações.

    Observe que este é o asynchronouscomportamento de fs.

    Como você disse na pergunta, quando você monta o UBIFS com a opção -sync, ele fará com que o sistema de arquivos synchronous(as alterações sejam gravadas para piscar todas as vezes), mas ao custo da queda de desempenho.

    Se você estiver trabalhando com asynchronoussistemas de arquivos como ubifs, o ônus de garantir que as gravações sejam gravadas em flash é dos desenvolvedores de aplicativos. Aqui está o que a página man do write(2) diz:

    $ man 2 write
    NOTES
       A  successful return from write() does not make any guarantee that data
       has been committed to disk.  In fact, on some buggy implementations, it
       does  not  even guarantee that space has successfully been reserved for
       the data.  The only way to be sure is to call fsync(2)  after  you  are
       done writing all your data.
    

    Usando

    sync- sincroniza fs inteiros. Pode não ser o ideal

    fsync- Principalmente faz o trabalho

    fdatasync- Somente as alterações de dados são liberadas e não os metadados (permissões). Mais ideal do que fsynctalvez (não tenho certeza)

    Leia também Boa leitura sobre fsync

    Então, no final, suas opções:

    1. montar com 'sincronização' - com impacto no desempenho
    2. melhorar o aplicativo usando as syncopções acima.
    3. lidar com arquivos de 0 byte em aplicativos
    4. criando arquivos temporários e renomeando-os mais tarde

    Último pensamento, pode querer mudar para fs síncrono como jffs2(não totalmente síncrono se estiver usando flash NAND). Eu sei que esta não é a resposta para sua pergunta, mas eh, escrevi tanto, como escrever isso ....

    • 1

relate perguntas

  • du/df e ls relatando diferentes usos de disco

  • Necessidade de algumas chamadas de sistema

  • astyle não altera a formatação do arquivo de origem

  • Como os desenvolvedores do kernel Linux lidam com seu trabalho com milhões de linhas de código? É um método? [fechado]

  • Passe o sistema de arquivos raiz por rótulo para o kernel do Linux

Sidebar

Stats

  • Perguntas 205573
  • respostas 270741
  • best respostas 135370
  • utilizador 68524
  • Highest score
  • respostas
  • Marko Smith

    Possível firmware ausente /lib/firmware/i915/* para o módulo i915

    • 3 respostas
  • Marko Smith

    Falha ao buscar o repositório de backports jessie

    • 4 respostas
  • Marko Smith

    Como exportar uma chave privada GPG e uma chave pública para um arquivo

    • 4 respostas
  • Marko Smith

    Como podemos executar um comando armazenado em uma variável?

    • 5 respostas
  • Marko Smith

    Como configurar o systemd-resolved e o systemd-networkd para usar o servidor DNS local para resolver domínios locais e o servidor DNS remoto para domínios remotos?

    • 3 respostas
  • Marko Smith

    apt-get update error no Kali Linux após a atualização do dist [duplicado]

    • 2 respostas
  • Marko Smith

    Como ver as últimas linhas x do log de serviço systemctl

    • 5 respostas
  • Marko Smith

    Nano - pule para o final do arquivo

    • 8 respostas
  • Marko Smith

    erro grub: você precisa carregar o kernel primeiro

    • 4 respostas
  • Marko Smith

    Como baixar o pacote não instalá-lo com o comando apt-get?

    • 7 respostas
  • Martin Hope
    user12345 Falha ao buscar o repositório de backports jessie 2019-03-27 04:39:28 +0800 CST
  • Martin Hope
    Carl Por que a maioria dos exemplos do systemd contém WantedBy=multi-user.target? 2019-03-15 11:49:25 +0800 CST
  • Martin Hope
    rocky Como exportar uma chave privada GPG e uma chave pública para um arquivo 2018-11-16 05:36:15 +0800 CST
  • Martin Hope
    Evan Carroll status systemctl mostra: "Estado: degradado" 2018-06-03 18:48:17 +0800 CST
  • Martin Hope
    Tim Como podemos executar um comando armazenado em uma variável? 2018-05-21 04:46:29 +0800 CST
  • Martin Hope
    Ankur S Por que /dev/null é um arquivo? Por que sua função não é implementada como um programa simples? 2018-04-17 07:28:04 +0800 CST
  • Martin Hope
    user3191334 Como ver as últimas linhas x do log de serviço systemctl 2018-02-07 00:14:16 +0800 CST
  • Martin Hope
    Marko Pacak Nano - pule para o final do arquivo 2018-02-01 01:53:03 +0800 CST
  • Martin Hope
    Kidburla Por que verdadeiro e falso são tão grandes? 2018-01-26 12:14:47 +0800 CST
  • Martin Hope
    Christos Baziotis Substitua a string em um arquivo de texto enorme (70 GB), uma linha 2017-12-30 06:58:33 +0800 CST

Hot tag

linux bash debian shell-script text-processing ubuntu centos shell awk ssh

Explore

  • Início
  • Perguntas
    • Recentes
    • Highest score
  • tag
  • help

Footer

AskOverflow.Dev

About Us

  • About Us
  • Contact Us

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve