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 / 411245
Accepted
j doe will do just fine
j doe will do just fine
Asked: 2017-12-17 04:51:52 +0800 CST2017-12-17 04:51:52 +0800 CST 2017-12-17 04:51:52 +0800 CST

não é possível executar scripts em uma VM Lubuntu (Xenial) Minimal (+LXDE) com shebangs

  • 772

Eu me envergonhei um pouco aqui com um simples erro de digitação e uma profunda ignorância. Salve-se de alguma dor:

  1. seus hasbangs/shebangs devem sempre ter um líder /, como#!/bin/bash
  2. seja preciso
  3. se você estiver trabalhando entre a máquina host e a máquina convidada (virtual) sem copiar e colar ativado, apenas pare. Erros de digitação matarão seu código e sua pergunta (o que pode irritar as pessoas). Descubra como copiar e colar funcionando ou trabalhe em uma única máquina. Redigitar manualmente é loucura.
  4. seja grato. Existem pessoas realmente muito úteis aqui.
  5. eles são todos linux, mas distros diferentes podem ter idiossincrasias quando se trata de shells e scripts. (Isso inclui versões completas e mínimas da distro). Verifique seu shell ( ps -p$$ -ocmd=funcionou para mim fonte ). Você precisa criar diretórios manualmente (especialmente em distribuições mínimas)?
  6. para mim, porque é o mais aplicável à maioria dos sistemas (ou seja, "portátil"), vou começar meus scripts com #!/usr/bin/env <SHELL>, onde SHELL é bash, shou qualquer outra coisa. Muitos sites de instruções parecem dizer "sempre inicie seu script com #!/bin/bash" sem nenhuma explicação ou advertência. Apenas não é verdade.
  7. Shellcheck . Esta ferramenta pode ser bastante útil. (Crédito - roaima )

Não consigo executar scripts em uma VM Lubuntu (Xenial) Minimal (+ LXDE) com shebangs - sem, eles estão bem.

Seguindo conselho de um post anterior , fiz um script bem simples, em 4 versões que diferem apenas no shebang:

echotest (sem linha shebang):

#blantantly simple test to figure out script problems

echo "this is working - type something for me to repeat it"
read input
echo $input

echotest-bin-bash

#!bin/bash

#blantantly simple test to figure out script problems

echo "this is working - type something for me to repeat it"
read input
echo $input

e mais dois, correspondentes a #!bin/dashe [EDIT: inserido "bin" a seguir, neste texto não no script] #!bin/sh.

Esses arquivos são salvos em ~/bin, um diretório que criei manualmente depois de ler um fórum em algum lugar.

Testar os scripts de lá produz:

x@computer:~$ echotest
this is working - type something for me to repeat it
test1
test1

ou seja, funciona sem nenhum shebang, mas

x@computer:~$ echotest-bin-bash
bash: /home/x/bin/echotest-bin-bash: bin/bash: bad interpreter: No such file or directory
x@computer:~$ echotest-bin-dash
bash: /home/x/bin/echotest-bin-dash: bin/bash: bad interpreter: No such file or directory
x@computer:~$ echotest-bin-sh
bash: /home/x/bin/echotest-bin-sh: bin/sh: bad interpreter: No such file or directory

Mais longe,

x@computer:~$ ./echotest-bin-bash
bash: ./echotest-bin-bash: No such file or directory

Para testar outra recomendação que li em um fórum/blog, removi os scripts ~/bine os experimentei enquanto salvos em /usr/local/bin.

x@computer:~$ echotest
bash: /home/x/bin/echotest: No such file or directory

E o mesmo para todas as outras variantes.

No entanto,

x@computer:~$ sudo /usr/local/bin/echotest
this is working - type something for me to repeat it
test
test

(ou seja, funciona)

x@computer:~$ sudo /usr/local/bin/echotest-bin-bash
sudo: unable to execute /usr/local/bin/echotest-bin-bash: No such file or directory
Hangup

Observe que todas as permissões foram concedidas com um chmod +x <filename>ou mais raramente, chmod 777 <filename>, e verificadas novamente com ls -l /rele/vant/directory.

x@computer:~$ echo $PATH
/home/x/bin:/home/x/.local/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin

Em resposta a uma resposta anterior em minha primeira tentativa nesta pergunta, o Lubuntu Minimal mostra estes instalados:

||/ Name           Version      Architecture Description
+++-==============-============-============-=================================
ii  dash           0.5.8-2.1ubu amd64        POSIX-compliant shell

ii  bash           4.3-14ubuntu amd64        GNU Bourne Again SHell

Usando comandos que não entendo completamente, obtidos em fóruns:

x@computer:~$ file "$(type -P bash)" 2>/dev/null
/bin/bash: ELF 64-bit LSB executable, x86-64, version 1 (SYSV), dynamically linked, interpreter /lib64/ld-linux-x86-64.so.2, for GNU/Linux 2.6.32, BuildID[sha1]=[redacted for the forum], stripped

x@computer:~$ type -p bash
/bin/bash 

Murphy, se você estiver lendo - não tenho sorte tentando chamar bin/bash, recebendo um prompt. Não sei como e meus termos de pesquisa trazem muito material fora do alvo.

Por fim, testei o script funcionando (ou seja, sem o shebang), em um arquivo .desktop, e funcionou perfeitamente ( Exec=echotest).

Por que os shebangs não funcionam? Scripts equivalentes #!bin/bashfuncionam bem no meu host Ubuntu Mate (Xenial).

Tenho certeza de que este é um erro muito básico, mas estou perplexo. Este é meu segundo roteiro, então estou feliz por ser direcionado para materiais básicos relevantes.

desde já, obrigado

Editar

Obrigado Jesse_b.

Edit1.1 - não, estou errado. #!/bin/bash funciona. Procurei no histórico do terminal e não consigo encontrar a entrada a que me referi anteriormente.

Além disso, #!/usr/bin/env bashfunciona perfeitamente.

Editar 2

Obrigado Murphy

Usando um hashbang #!/bin/she #!/bin/bashfunciona muito bem.

Mais longe

x@computer:~$ ls -l /bin/bash
-rwxr-xr-x 1 root root 1037528 May 16  2017 /bin/bash

x@computer:~$ /usr/bin/env | grep bash
SHELL=/bin/bash

x@computer::~$ ls -l /bin/*sh
-rwxr-xr-x 1 root root 1037528 May 16  2017 /bin/bash
-rwxr-xr-x 1 root root  154072 Feb 17  2016 /bin/dash
lrwxrwxrwx 1 root root       4 May 16  2017 /bin/rbash -> bash
lrwxrwxrwx 1 root root       4 Feb 17  2016 /bin/sh -> dash

Uma edição final - diferentes distribuições serão mais ou menos rígidas em como seus hashbangs/shebangs são formatados. Encontrei esta postagem em que alguém descreve problemas semelhantes com versões anteriores do Mint/Xfce e Lubuntu/LXDE.

(Tive problemas quando redigitei manualmente um script em meu host Ubuntu Mate em um convidado Lubuntu Minimal/LXDE. Achei ter observado um comportamento diferente entre as distros, mas a) não entendi o significado do formato shebang, b) existem sites que oferecem conselhos talvez não tão bons ec) estou propenso a erros de digitação. Como experiência, veja se seu script funcionará sem problemas.)

scripting lubuntu
  • 1 1 respostas
  • 468 Views

1 respostas

  • Voted
  1. Best Answer
    jesse_b
    2017-12-17T04:54:11+08:002017-12-17T04:54:11+08:00

    Seu hash bang deve começar com a barra inicial/

    #!bin/bashquase certamente não é um caminho de diretório/arquivo válido e deve ser#!/bin/bash

    Se você não tiver certeza de que existe um shell, sempre poderá usar lsou algo para garantir que o caminho esteja correto ou uma maneira mais portátil de escrevê-lo seria:

    #!/usr/bin/env bash

    Isso fará com que o sistema procure automaticamente o caminho bash(ou qualquer outro interpretador que você escolher) via enve use o primeiro que encontrar.

    • 4

relate perguntas

  • Verifique o histórico de login do usuário root

  • Uma maneira rápida de duplicar um site (Wordpress) no meu ambiente de servidor Nginx?

  • problema ao iniciar aplicativos: linha de comando vs. gui

  • Shell Script para encontrar string no arquivo de log

  • Renomeie (acrescentar) arquivos CSV em massa com base em um valor dentro

Sidebar

Stats

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

    Matriz JSON para bash variáveis ​​usando jq

    • 4 respostas
  • Marko Smith

    A data pode formatar a hora atual para o fuso horário GMT? [duplicado]

    • 2 respostas
  • Marko Smith

    bash + lê variáveis ​​e valores do arquivo pelo script bash

    • 4 respostas
  • Marko Smith

    Como posso copiar um diretório e renomeá-lo no mesmo comando?

    • 4 respostas
  • Marko Smith

    conexão ssh. Conexão X11 rejeitada devido a autenticação incorreta

    • 3 respostas
  • Marko Smith

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

    • 7 respostas
  • Marko Smith

    comando systemctl não funciona no RHEL 6

    • 3 respostas
  • Marko Smith

    rsync porta 22 e 873 uso

    • 2 respostas
  • Marko Smith

    snap /dev/loop em 100% de utilização -- sem espaço livre

    • 1 respostas
  • Marko Smith

    chave de impressão jq e valor para todos no subobjeto

    • 2 respostas
  • Martin Hope
    EHerman Matriz JSON para bash variáveis ​​usando jq 2017-12-31 14:50:58 +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
    Drux A data pode formatar a hora atual para o fuso horário GMT? [duplicado] 2017-12-26 11:35:07 +0800 CST
  • Martin Hope
    AllisonC Como posso copiar um diretório e renomeá-lo no mesmo comando? 2017-12-22 05:28:06 +0800 CST
  • Martin Hope
    Steve Como as permissões de arquivo funcionam para o usuário "root"? 2017-12-22 02:46:01 +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
  • Martin Hope
    Cbhihe Altere o editor padrão para vim para _ sudo systemctl edit [unit-file] _ 2017-12-03 10:11:38 +0800 CST
  • Martin Hope
    showkey Como baixar o pacote não instalá-lo com o comando apt-get? 2017-12-03 02:15:02 +0800 CST
  • Martin Hope
    youxiao Por que os diretórios /home, /usr, /var, etc. têm o mesmo número de inode (2)? 2017-12-02 05:33:41 +0800 CST
  • Martin Hope
    user223600 gpg — o comando list-keys gera uid [ desconhecido ] depois de importar a chave privada para uma instalação limpa 2017-11-26 18:26:02 +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