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 / 410474
Accepted
Marinaio
Marinaio
Asked: 2017-12-13 09:43:13 +0800 CST2017-12-13 09:43:13 +0800 CST 2017-12-13 09:43:13 +0800 CST

Crie um script bash multi-script que seja compilado e mantenha um log

  • 772

Estou escrevendo um conjunto de scripts bash.

A primeira wrapperchama dois scripts: do_somethinge do_something_else.

Em pseudocódigo:

$ wrapper
do_something
if exitcode of do_something = 0 then 
    do_something_else
else
    exit with error
fi

exit success

Isso geraria um arquivo de log:

$ cat /var/logs/wrapper.log | tail -3
Deleting file 299
Deleting file 300
wrapper ran successfully on 01/01/18 00:01:00 GMT

Eu tenho dois objetivos:

  1. criar um log de todo o processo. Em outras palavras, tudo o que do_something, do_something_elsee wrapperenviar para stdout e stderr eu quero em um arquivo de log que mostre a execução diária deste script para que eu possa grep em busca de erros.
  2. Eu quero pré-compilar do_something, do_something_elsee wrapperassim posso colocá-los /usr/bine colocá- scplos em todos os meus sistemas. Dessa forma, tenho uma fonte em dev e um código não editável de execução rápida em prod.

Isso é possível?

shell-script compiling
  • 2 2 respostas
  • 177 Views

2 respostas

  • Voted
  1. Best Answer
    Lizardx
    2017-12-14T10:15:25+08:002017-12-14T10:15:25+08:00

    Aqui está uma amostra de como lidar com esse cenário em um script, sem perder a funcionalidade que o OP deseja, que é:

    1. capacidade de executar vários blocos de lógica, todos eles, de uma vez ou um de cada vez.

    2. Capacidade de registrar essas ações em um arquivo.

    Este é um exemplo simples. Se você tratar a linguagem de script como faria com qualquer outra linguagem e escrever um código organizado, de repente poderá fazer todo tipo de coisa com ela. O truque é não deixar blocos de lógica solta fora das funções, dessa forma você pode alternar as coisas facilmente, usar uma peça, não a outra, depurar seções, adicionar uma função de registro, que é o que eu faria normalmente, error_handler( ), e assim por diante. Com quase nenhum trabalho extra, ou seja, você acaba com um aplicativo simples, mas limpo e fácil de manter, não um monte de linhas de ações aleatórias empilhadas umas sobre as outras.

    arquivo: minhas_coisas

    #!/usr/bin/env bash
    
    logfile='logfile.log'
    
    function main() {
      case "$1" in
        run-all)
          block_1
          block_2
          ;;
        run-1)
          block_1
          ;;
        run-2)
          block_2
          ;;
        *)
          echo 'No start option provided. Exiting'
          exit 1
          ;;
      esac
    }
    function block_1(){
      do_something
    
      if [ "$?" == 0 ]; then 
        do_something_else
        echo "Deleting file 299" >> $logfile
        echo "Deleting file 300" >> $logfile
        echo "wrapper ran successfully on 01/01/18 00:01:00 GMT" >> $logfile
      else
        exit "$?"
      fi
    }
    function block_2(){
      do_something
    
      if [ "$?" == 0 ]; then 
        do_something_else
        echo "Deleting file 299" >> $logfile
        echo "Deleting file 300" >> $logfile
        echo "wrapper ran successfully on 01/01/18 00:01:00 GMT" >> $logfile
      else
        exit "$?"
      fi
    }
    # $@ is the list of start arguments, which main will use
    # with $1, $2, and so on.
    main $@
    

    Você executaria isso assim:

    ./my_stuff 'run-all'
    

    É claro que este é apenas um exemplo, mas na verdade tudo o que você faz é organizar a lógica, organizá-la da maneira que faria com qualquer linguagem e, em seguida, acionar as ações desejadas. Acho que se eu iniciar os scripts de shell assumindo que eles serão usados ​​e mantidos, e se eu os escrever usando funções, eles serão tão flexíveis e fáceis de manter quanto qualquer outra programação que eu fizer.

    • 0
  2. ilkkachu
    2017-12-14T13:49:13+08:002017-12-14T13:49:13+08:00

    Sobre a parte de tudo para um arquivo de log: use execpara redirecionar stdout & stderr, aqui dateé usado para colocar a data no nome do arquivo de log:

    #!/bin/bash
    exec > /somedir/somelog.$(date +%F)
    exec 2>&1
    
    # output goes to the log file even if this is an external command
    somecmd...     
    
    • 0

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

    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