Você pode fazer isso com su
ou sudo
, sem necessidade de ambos.
sudo -H -u otheruser bash -c 'echo "I am $USER, with uid $UID"'
As partes relevantes de man sudo
:
-H The -H (HOME) option requests that the security policy set
the HOME environment variable to the home directory of the
target user (root by default) as specified by the password
database. Depending on the policy, this may be the default
behavior.
-u user The -u (user) option causes sudo to run the specified
command as a user other than root. To specify a uid
instead of a user name, use #uid. When running commands as
a uid, many shells require that the '#' be escaped with a
backslash ('\'). Security policies may restrict uids to
those listed in the password database. The sudoers policy
allows uids that are not in the password database as long
as the targetpw option is not set. Other security policies
may not support this.
su
só pode mudar de usuário sem fornecer uma senha se você for root. Veja a resposta de Caleb
Você pode modificar o /etc/pam.d/su
arquivo para permitir su
sem senha. Veja esta resposta .
Se você modificou seu arquivo de autenticação para o seguinte, qualquer usuário que fazia parte do grupo somegroup
poderia fazê su
-lo otheruser
sem uma senha.
auth sufficient pam_rootok.so
auth [success=ignore default=1] pam_succeed_if.so user = otheruser
auth sufficient pam_succeed_if.so use_uid user ingroup somegroup
Depois teste a partir do terminal
rubo77@local$ su otheruser -c 'echo "hello from $USER"'
hello from otheruser
su
também?Se você quiser usar su em vez de sudo, acredito que você pode usar algo como isto:
-
simulará um login do usuário especificado-c
diz que você deseja executar um comandops. Infelizmente, não consigo instalar o ruby usando o rvm com esse método, mas isso provavelmente não está relacionado.
fonte
sudo
no início, caso contrário, ele me pedia minha senha.sudo
. com sudo ele funciona, por exemplo:sudo su - www-data -c "touch /tmp/test"
com sucesso criado um arquivo como www-dataAs respostas acima são realmente úteis para mim, mas para responder à pergunta real ...
Usar:
A saída deve incluir seu script e o usuário real que o está executando. Pessoas em sistemas similares a BSD, por exemplo, o MAC, podem encontrar informações semelhantes com:
fonte
Eu tive o mesmo problema. Basta digitar o comando
screen -dmS testscreen
para criar uma tela desanexada na sua conta de usuário não sudo e, em seguida, você poderá registrá-la e verificar se essa tela está láscreen -ls
.fonte