Sunday, September 20, 2009

Unknown id

Amazon EC2 のインスタンスとして起動している Ubuntu 9.04 にて、ログイン認証を OpenLDAP に対応させようとしている。

ldapadd

により john と mike を追加した。satoshiabe は、useradd で追加されている。


とろころ、getent コマンドを root で実行すると、以下のような出力を取得できるが、

root@domU-12-31-39-07-75-43:~# getent passwd
root:x:0:0:root:/root:/bin/bash
daemon:x:1:1:daemon:/usr/sbin:/bin/sh
bin:x:2:2:bin:/bin:/bin/sh
sys:x:3:3:sys:/dev:/bin/sh
sync:x:4:65534:sync:/bin:/bin/sync
games:x:5:60:games:/usr/games:/bin/sh
man:x:6:12:man:/var/cache/man:/bin/sh
lp:x:7:7:lp:/var/spool/lpd:/bin/sh
mail:x:8:8:mail:/var/mail:/bin/sh
news:x:9:9:news:/var/spool/news:/bin/sh
uucp:x:10:10:uucp:/var/spool/uucp:/bin/sh
proxy:x:13:13:proxy:/bin:/bin/sh
www-data:x:33:33:www-data:/var/www:/bin/sh
backup:x:34:34:backup:/var/backups:/bin/sh
list:x:38:38:Mailing List Manager:/var/list:/bin/sh
irc:x:39:39:ircd:/var/run/ircd:/bin/sh
gnats:x:41:41:Gnats Bug-Reporting System (admin):/var/lib/gnats:/bin/sh
nobody:x:65534:65534:nobody:/nonexistent:/bin/sh
libuuid:x:100:101::/var/lib/libuuid:/bin/sh
syslog:x:101:102::/home/syslog:/bin/false
klog:x:102:103::/home/klog:/bin/false
sshd:x:103:65534::/var/run/sshd:/usr/sbin/nologin
openldap:x:104:108:OpenLDAP Server Account,,,:/var/lib/ldap:/bin/false
satoshiabe:x:1000:1000::/home/satoshiabe:/bin/bash
root@domU-12-31-39-07-75-43:~#



一般ユーザが実行すると、以下のような出力を取得できる。

root:x:0:0:root:/root:/bin/bash
daemon:x:1:1:daemon:/usr/sbin:/bin/sh
bin:x:2:2:bin:/bin:/bin/sh
sys:x:3:3:sys:/dev:/bin/sh
sync:x:4:65534:sync:/bin:/bin/sync
games:x:5:60:games:/usr/games:/bin/sh
man:x:6:12:man:/var/cache/man:/bin/sh
lp:x:7:7:lp:/var/spool/lpd:/bin/sh
mail:x:8:8:mail:/var/mail:/bin/sh
news:x:9:9:news:/var/spool/news:/bin/sh
uucp:x:10:10:uucp:/var/spool/uucp:/bin/sh
proxy:x:13:13:proxy:/bin:/bin/sh
www-data:x:33:33:www-data:/var/www:/bin/sh
backup:x:34:34:backup:/var/backups:/bin/sh
list:x:38:38:Mailing List Manager:/var/list:/bin/sh
irc:x:39:39:ircd:/var/run/ircd:/bin/sh
gnats:x:41:41:Gnats Bug-Reporting System (admin):/var/lib/gnats:/bin/sh
nobody:x:65534:65534:nobody:/nonexistent:/bin/sh
libuuid:x:100:101::/var/lib/libuuid:/bin/sh
syslog:x:101:102::/home/syslog:/bin/false
klog:x:102:103::/home/klog:/bin/false
sshd:x:103:65534::/var/run/sshd:/usr/sbin/nologin
openldap:x:104:108:OpenLDAP Server Account,,,:/var/lib/ldap:/bin/false
satoshiabe:x:1000:1000::/home/satoshiabe:/bin/bash
john:x:10000:10000:John Doe:/home/john:/bin/bash
mike:x:20000:20000:Mike Davis:/home/mike:/bin/bash
satoshiabe@domU-12-31-39-07-75-43:~$


一般ユーザが実行した場合 john と mike を取得できるが root が実行すると取得できない。ちなみに su でスイッチしようとすると、以下のように unknown id となる。

satoshiabe@domU-12-31-39-07-75-43:~$ su - john
Unknown id: john
satoshiabe@domU-12-31-39-07-75-43:~$ su - mike
Unknown id: mike
satoshiabe@domU-12-31-39-07-75-43:~$


なぜだ!?

No comments: