Je voudrais exécuter un script à partir du shell ubuntu principal en tant qu'utilisateur différent qui n'a pas de mot de passe.
J'ai plein de privilèges Sudo, alors j'ai essayé ceci:
Sudo su -c "Your command right here" -s /bin/sh otheruser
Ensuite, je dois entrer mon mot de passe, mais je ne suis pas sûr que ce script fonctionne maintenant sous cet utilisateur.
Comment puis-je confirmer que le script est réellement exécuté sous cet utilisateur maintenant?
Vous pouvez le faire avec su
ou Sudo
name__, vous n'avez pas besoin des deux.
Sudo -H -u otheruser bash -c 'echo "I am $USER, with uid $UID"'
Les parties pertinentes 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
ne peut changer d’utilisateur sans fournir de mot de passe si vous êtes root. Voir la réponse de Caleb
Vous pouvez modifier le fichier /etc/pam.d/su
pour autoriser su
sans mot de passe. Voir ceci réponse .
Si vous avez modifié votre fichier d'authentification comme suit, tout utilisateur faisant partie du groupe somegroup
pourrait su
à otheruser
sans mot de passe.
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
Puis testez depuis le terminal
rubo77@local$ su otheruser -c 'echo "hello from $USER"'
hello from otheruser
Si vous voulez utiliser su au lieu de Sudo, je pense que vous pouvez utiliser quelque chose comme ceci:
su - <username> -c "<commands>"
-
simulera une connexion de l'utilisateur spécifié-c
indique que vous voulez exécuter une commandeps. Malheureusement, je ne parviens pas à installer Ruby en utilisant rvm avec cette méthode, mais ce n'est probablement pas lié.
Les réponses ci-dessus me sont vraiment utiles mais pour répondre à la question réelle ...
Comment puis-je affirmer que le script fonctionne vraiment sous cet utilisateur maintenant? -
Utilisation:
ps -ef | grep <command-name>
La sortie doit inclure votre script et l'utilisateur qui l'exécute. Personnes sur des systèmes de type BSD, par exemple MAC peut trouver des informations similaires avec:
ps aux | grep <command-name>
J'ai eu le même problème. Il suffit de taper la commande screen -dmS testscreen
pour créer un écran détaché sur votre compte utilisateur non-Sudo. Vous pourrez ensuite le connecter et vérifier si cet écran est présent par screen -ls
.