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 / 418400
Accepted
anon777
anon777
Asked: 2018-01-20 22:31:07 +0800 CST2018-01-20 22:31:07 +0800 CST 2018-01-20 22:31:07 +0800 CST

Tempo de criação do processo, shell script e overhead de chamada do sistema

  • 772

Eu tenho uma máquina dual boot com Arch Linux e Ubuntu (16.04).

Recentemente, comecei a usar o editor de texto Kakoune e notei que seu tempo de inicialização é drasticamente diferente, dependendo de qual sistema operacional estou usando. No entanto, acredito que o problema subjacente não se deve diretamente a kakoune.

Na inicialização, kakoune executa vários scripts de shell para permitir a integração com x11 e tmux, git, realce de sintaxe/esquemas de cores, etc. Isso pode ser desativado para carregar apenas o editor 'vanilla' usando o -nsinalizador.

O comando: kak -e qiniciará o kakoune, executará todos os scripts de inicialização e sairá imediatamente.

No Arch:
time kak -e qleva 1 segundo
time kak -n -e q (sem scripts de shell) termina em menos de 20 milissegundos .

No Ubuntu:
time kak -e qleva cerca de 450 milissegundos
time kak -n -e q , novamente abaixo de 20 milissegundos

Depois de cortar a gordura e remover alguns dos scripts de inicialização, vi uma melhoria em ambos os sistemas operacionais proporcional à quantidade removida.

Executei alguns benchmarks com o UnixBench e descobri que as principais diferenças entre os dois sistemas são vistas nos testes de 'criação de processos' e 'scripts de shell'.

O teste de scripts de shell mede o número de vezes por minuto que um processo pode iniciar e obter um conjunto de uma, duas, quatro e oito cópias simultâneas de scripts de shell em que o script de shell aplica uma série de transformações a um arquivo de dados.

Aqui está a saída relevante. Unidades em 'loops por segundo' mais é melhor:

Process creation (1 parallel copy of tests)
Arch:    3,822
Ubuntu:  5,297
Process creation (4 parallel copies of tests)
Arch:   18,935
Ubuntu: 30,341

Shell Scripts (1 concurrent) (1 parallel copy of tests)
Arch:      972
Ubuntu:  5,141
Shell Scripts (1 concurrent) (4 parallel copies of tests)
Arch:    7,697
Ubuntu: 24,942

Shell Scripts (8 concurrent) (1 parallel copy of tests)
Arch:      807
Ubuntu:  2,257
Shell Scripts (8 concurrent) (4 parallel copies of tests)
Arch:    1,289
Ubuntu:  3,001

Como você pode ver, o sistema Ubuntu tem um desempenho muito melhor.

Eu testei usando diferentes shells de login, emuladores de terminal, recompilando kakoune, removendo software desnecessário para limpar o disco, etc. Tenho certeza de que esse é o gargalo.

Minha pergunta é: o que posso fazer para investigar melhor isso e melhorar o desempenho do sistema Arch Linux para corresponder ao Ubuntu? Devo procurar ajustar o kernel?

Notas Adicionais:

  • ambos os sistemas usam o mesmo tipo de sistema de arquivos (ext4)
  • Costumo usar mais o sistema Archlinux e notei uma degradação do desempenho com o tempo
  • Arch está em /dev/sda1 e tem ~200GB. Ubuntu está em /dev/sda2, ~500GB. HD de 1 TB.
  • Arco uname -a:Linux ark 4.14.13-1-ARCH #1 SMP PREEMPT Wed Jan 10 11:14:50 UTC 2018 x86_64 GNU/Linux
  • Ubuntu uname -a:Linux sierra 4.4.0-62-generic #83-Ubuntu SMP Wed Jan 18 14:10:15 UTC 2017 x86_64 x86_64 x86_64 GNU/Linux

Obrigado

shell-script performance
  • 3 3 respostas
  • 1275 Views

3 respostas

  • Voted
  1. Best Answer
    ilkkachu
    2018-01-20T23:43:07+08:002018-01-20T23:43:07+08:00

    Debian e Ubuntu usam traço como /bin/sh, é um pouco mais rápido que o Bash:

    $ time for x in {1..1000} ; do /bin/bash -c 'true' ; done                                                                                                                                                                                                                                                      
    real    0m1.894s
    
    $ time for x in {1..1000} ; do /bin/sh -c 'true' ; done 
    real    0m1.057s
    

    Isso é aproximadamente a mesma área (em proporção) dos seus números.

    Mudar /bin/shpara traço em vez de Bash no Debian e Ubuntu foi muito por causa do desempenho:

    O principal motivo para mudar o shell padrão foi a eficiência. O bash é um excelente shell completo ... No entanto, é bastante grande e lento para inicializar e operar em comparação com o dash.

    ( https://wiki.ubuntu.com/DashAsBinSh )

    • 1
  2. Stephen Kitt
    2018-01-21T02:06:42+08:002018-01-21T02:06:42+08:00

    Conforme explicado por ilkkachu, Arch usa bash para /bin/sh, enquanto o padrão do Ubuntu é traço.

    Para investigar melhor isso e determinar se isso explica a diferença, você pode configurar seu sistema Ubuntu para usar o bash e ver se os benchmarks relatam resultados semelhantes aos obtidos no Arch. Para fazer isso, execute

    sudo dpkg-reconfigure dash
    

    e selecione “Não”. Você pode então verificar se /bin/shaponta para bash, e executar seus testes.

    Para restaurar o padrão, execute o mesmo comando novamente e escolha “Sim”.

    Se esse for o motivo da diferença de desempenho, melhorar o Arch para igualar o Ubuntu será difícil. Você pode instalar o dash e usá-lo, mas provavelmente encontrará muitos scripts que assumem que /bin/shé bash e falham com o dash - o Debian e o Ubuntu levaram muito tempo para identificar e corrigir todos os problemas.

    • 1
  3. anon777
    2018-01-21T12:46:34+08:002018-01-21T12:46:34+08:00

    Adicionando minha própria resposta caso alguém tenha o mesmo problema:

    Ao executar os forloops na resposta de @ilkkachu a partir de um bash shell interativo com zsh ou fish como meu shell de login , o /bin/bashloop leva cerca de 13 segundos. Se eu executar o loop de um shell de login root ou alterar meu shell de login para /bin/bash, obtenho resultados semelhantes aos da resposta de @ilkkachu.

    Presumo que seja porque /bin/bashherda seu ambiente do shell de login (ou /bin/zshou /bin/fish), mas não tenho certeza.

    De qualquer forma, resolvi o problema alterando meu shell de login/bin/bash e configurando meu terminal para executar /bin/fishou /bin/zshcomo um shell interativo.

    • 1

relate perguntas

  • Subtraindo a mesma coluna entre duas linhas no awk

  • Um script que imprime as linhas de um arquivo com seu comprimento [fechado]

  • exportar variáveis ​​​​env programaticamente, via stdout do comando [duplicado]

  • Dividir por delimitador e concatenar problema de string

  • MySQL Select com função IN () com array bash

Sidebar

Stats

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

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

    • 4 respostas
  • Marko Smith

    ssh Não é possível negociar: "nenhuma cifra correspondente encontrada", está rejeitando o cbc

    • 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

    Como descarregar o módulo do kernel 'nvidia-drm'?

    • 13 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
    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
    Wong Jia Hau ssh-add retorna com: "Erro ao conectar ao agente: nenhum arquivo ou diretório" 2018-08-24 23:28:13 +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
  • Martin Hope
    Bagas Sanjaya Por que o Linux usa LF como caractere de nova linha? 2017-12-20 05:48:21 +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