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 / 513411
Accepted
finefoot
finefoot
Asked: 2019-04-20 06:27:44 +0800 CST2019-04-20 06:27:44 +0800 CST 2019-04-20 06:27:44 +0800 CST

Como desabilitar temporariamente o tempo limite do timestamp de credenciais sudo?

  • 772

Digamos que eu tenha o seguinte script bash:

#!/bin/bash
sudo command1
command2
sudo command3

Eu não quero rodar command2como root, então não vou rodar o script em si com sudo. Portanto, assim que executo o script, sudo command1pede minha senha. Infelizmente, command2leva cerca de 2 horas para ser concluído. Portanto, o timestamp de credenciais sudo expirou e, quando o script atinge sudo command3, sou solicitado a inserir a senha novamente.

Não quero desabilitar permanentemente o tempo limite do timestamp de credenciais sudo, conforme descrito em https://superuser.com/a/149740 , por exemplo. Eu só quero desabilitar o tempo limite temporariamente, manter efetivamente as credenciais para esta sessão de bash até que ela termine.

sudo scripting
  • 4 4 respostas
  • 1578 Views

4 respostas

  • Voted
  1. Best Answer
    Jeff Schaller
    2019-04-20T08:50:09+08:002019-04-20T08:50:09+08:00

    Acho que sua melhor aposta é um loop de espera ocupada (em segundo plano) que atualiza o timestamp sudo, que você elimina quando não precisa mais de sudoprivilégios. Aqui está um script de exemplo; ele é executado sleep 6em vez de suas duas horas e executa comandos command2visíveis em vez de e :/bin/echocommand1command2

    #!/bin/sh
    sudo /bin/echo command 1
    while :; do sudo -v; sleep 1; done &
    infiloop=$!
    sleep 6
    sudo /bin/echo command 3
    kill "$infiloop"
    

    Para o seu script real, eu recomendaria um loop mais solto:

    #!/bin/sh
    sudo command1
    while :; do sudo -v; sleep 59; done &
    infiloop=$!
    command2
    sudo command3
    kill "$infiloop"
    

    Ajuste a sleep 59gosto, dependendo da timestamp_timeoutconfiguração existente nos sudoers; Eu escolhi 59 apenas para demonstrar uma escolha que você poderia fazer se o tempo limite do timestamp fosse de 60 segundos.

    • 4
  2. EmmaV
    2019-10-06T09:20:46+08:002019-10-06T09:20:46+08:00

    Devo estar faltando alguma coisa aqui, porque a solução parece muito óbvia para mim.

    Eu não quero rodar command2como root, então não vou rodar o script em si com sudo.

    Mas você pode executar o script inteiro sudosem executar command 2como root se alterar o script:

    #!/bin/bash
    command1
    sudo -u ${SUDO_USER:-$USER} command2
    command3
    
    • 2
  3. finefoot
    2019-04-20T08:45:53+08:002019-04-20T08:45:53+08:00

    Bem, seria possível combinar Como posso fazer o sudo esquecer a senha automaticamente após um comando? e Qual é o propósito de usar `sudo -S` explicitamente?

    1. Leia a senha do usuário, salve-a na variável de ambiente
    2. Execute sudocom -ksinalizador para ignorar credenciais para que sempre solicite a senha
    3. Passe a senha via stdinpara sudocom flag-S
    4. Remover variável de ambiente de senha

    Pode ser útil para certas situações, mas não tenho certeza se é uma boa ideia armazenar a senha do usuário em uma variável de ambiente.

    • 0
  4. Alberto Salvia Novella
    2021-02-16T22:51:01+08:002021-02-16T22:51:01+08:00

    Atualizando credenciais em segundo plano:

    #!/bin/bash
    
    
    configurePermissions () {
        sudo -v
        refreshPermissions "$$" &
    }
    
    
    refreshPermissions () {
        local pid="${1}"
    
        while kill -0 "${pid}" 2> /dev/null; do
            sudo -v
            sleep 10
        done
    }
    
    
    configurePermissions
    
    • 0

relate perguntas

  • Diferença entre sudo nautilus e sudo -E nautilus

  • Shell Script para encontrar string no arquivo de log

  • Execute um único comando como outro usuário; restrições ao sudo

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

  • Permitir que o usuário execute um comando como root

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