amd64/173657: strange UID map with nfsuserd

Alex tomefrom at list.ru
Fri Nov 16 10:20:01 UTC 2012


>Number:         173657
>Category:       amd64
>Synopsis:       strange UID map with nfsuserd
>Confidential:   no
>Severity:       non-critical
>Priority:       low
>Responsible:    freebsd-amd64
>State:          open
>Quarter:        
>Keywords:       
>Date-Required:
>Class:          sw-bug
>Submitter-Id:   current-users
>Arrival-Date:   Fri Nov 16 10:20:00 UTC 2012
>Closed-Date:
>Last-Modified:
>Originator:     Alex
>Release:        9.0-RELEASE-p4
>Organization:
>Environment:
FreeBSD storage.dns.local 9.0-RELEASE-p4 FreeBSD 9.0-RELEASE-p4 #0: Thu Nov  8 15:55:51 2012     user at storage.dns.local:/usr/obj/usr/src/sys/ST_KERNEL  amd64

>Description:
I use nfsv4 with nfsuserd. My /etc/exports

/storage/backup_pool/ports/ports -mapall=nobody -ro -network 10.10.100.0 -mask 255.255.255.0
#/storage/backup_pool/ports/distfiles -mapall=nobody -network 10.10.100.0 -mask 255.255.255.0
/storage/backup_pool/ports/distfiles 	-maproot=root	 -network 10.10.100.0 -mask 255.255.255.0
V4: /storage/backup_pool/ports -sec=sys		-network 10.10.100.0 -mask 255.255.255.0

Domain was set to dns.local on both client and server
Stopping nfsuserd.
Waiting for PIDS: 1491.
Starting nfsuserd.
nfsuserd: domain=dns.local usermax=200 usertimeout=60

Users u1 and u2 exist on the client (with UID 3071 and 3072 respectively), but don`t on the server.

On the client I do
[client:/var/distfiles]#chown u1 test
No name and/or group mapping for uid,gid:(3071,-1)
chown: test: Operation not permitted
[client:/var/distfiles]#chown u1 test
[client:/var/distfiles]#chown u2 test

In messages on client
Nov 16 09:59:01 drweb nfsuserd:[1061]: Added gid=0 name=wheel
Nov 16 09:59:01 drweb nfsuserd:[1059]: Added uid=3071 name=nobody
Nov 16 09:59:01 drweb kernel: No name and/or group mapping for uid,gid:(3071,-1)
Nov 16 09:59:15 drweb nfsuserd:[1060]: Added uid=3071 name=u1
Nov 16 09:59:20 drweb nfsuserd:[1061]: Added uid=3072 name=u2

In messages on server
Nov 16 09:59:01 storage nfsuserd:[1053]: Added uid=32767 name=nobody
Nov 16 09:59:01 storage nfsuserd:[1055]: Added gid=0 name=wheel
Nov 16 09:59:15 storage nfsuserd:[1054]: Added uid=32767 name=u1
Nov 16 09:59:20 storage nfsuserd:[1052]: Added uid=32767 name=u2

If user does not exists on the server, it mapped to  32767 UID on the server. Then I add users u1 and u2 to the server with the same UID. Mapping works correctly. Server log:
Nov 16 10:11:50 storage nfsuserd:[1432]: Added uid=3072 name=u2
Nov 16 10:12:07 storage nfsuserd:[1433]: Added uid=3071 name=u1

The same problem with the client. If user does not exists on the client but exists on the server, it maps to UID   32767 on the client (I do chown on the server). 
>How-To-Repeat:

>Fix:


>Release-Note:
>Audit-Trail:
>Unformatted:


More information about the freebsd-amd64 mailing list