คุณสามารถทำได้ด้วยsu
หรือsudo
ไม่จำเป็นต้องใช้ทั้งสองอย่าง
sudo -H -u otheruser bash -c 'echo "I am $USER, with uid $UID"'
ส่วนที่เกี่ยวข้องของ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
สามารถสลับผู้ใช้ได้โดยไม่ต้องระบุรหัสผ่านหากคุณเป็นรูท ดูคำตอบของ Caleb
คุณสามารถแก้ไข/etc/pam.d/su
ไฟล์เพื่ออนุญาตsu
โดยไม่ต้องใช้รหัสผ่าน ดูคำตอบนี้
หากคุณปรับเปลี่ยนไฟล์รับรองความถูกต้องของคุณต่อไปนี้ผู้ใช้ใด ๆ ที่เป็นส่วนหนึ่งของกลุ่มsomegroup
สามารถsu
ทำได้ในotheruser
โดยไม่ต้องใช้รหัสผ่าน
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
จากนั้นทดสอบจากเทอร์มินัล
rubo77@local$ su otheruser -c 'echo "hello from $USER"'
hello from otheruser
su
ด้วยได้ไหม