Puede hacerlo con su
o sudo
, sin necesidad de ambos.
sudo -H -u otheruser bash -c 'echo "I am $USER, with uid $UID"'
Las 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
solo puede cambiar de usuario sin proporcionar una contraseña si es root. Ver la respuesta de Caleb
Puede modificar el /etc/pam.d/su
archivo para permitir su
sin contraseña. Ver esta respuesta .
Si modificó su archivo de autenticación a lo siguiente, cualquier usuario que fuera parte del grupo somegroup
podría su
hacerlo otheruser
sin una contraseña.
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
Luego prueba desde la terminal
rubo77@local$ su otheruser -c 'echo "hello from $USER"'
hello from otheruser
su
también?Si quieres usar su en lugar de sudo, creo que puedes usar algo como esto:
-
simulará un inicio de sesión del usuario especificado-c
le dice que desea ejecutar un comandoPD. Desafortunadamente, no puedo instalar ruby usando rvm con este método, pero eso probablemente no esté relacionado.
fuente
sudo
al principio, de lo contrario, me pidió mi contraseña.sudo
. con sudo funciona, por ejemplo:sudo su - www-data -c "touch /tmp/test"
creó con éxito un archivo como www-dataLas respuestas anteriores son realmente útiles para mí, pero para responder la pregunta real ...
Utilizar:
La salida debe incluir su script y el usuario real que lo ejecuta. Las personas en sistemas similares a BSD, por ejemplo, MAC pueden encontrar información similar con:
fuente
Yo tuve el mismo problema. Simplemente escriba el comando,
screen -dmS testscreen
esto creará una pantalla separada en su cuenta de usuario que no sea sudo y luego podrá iniciar sesión y verificar si esta pantalla está allíscreen -ls
.fuente