"+::::::" at the end of /etc/passwd

Solution 1:

As Lukas Räpple pointed out in the comments, that line is a legacy entry for using NIS with ancient libc5.

If you want to keep using NIS but remove that line, change the passwd: compat line in /etc/nsswitch.conf to passwd: files nis first. You should also check the shadow: and group: lines (and /etc/group and /etc/shadow files) for similar legacy settings.

Solution 2:

I'm reposting the below from the following Unix stackexchange answer:

https://unix.stackexchange.com/questions/106215/whta-does-bin-bash-in-etc-passwd-mean

The answer lies in the nsswitch.conf(5) man page:

Interaction with +/- syntax (compat mode)

Linux libc5 without NYS does not have the name service switch but does allow the user some policy control. In /etc/passwd you could have entries of the form +user or +@netgroup (include the specified user from the NIS passwd map), -user or -@netgroup (exclude the specified user), and + (include every user, except the excluded ones, from the NIS passwd map).

You can override certain passwd fields for a particular user from the NIS passwd map by using the extended form of +user:::::: in /etc/passwd. Non-empty fields override information in the NIS passwd map.

Since most people only put a + at the end of /etc/passwd to include everything from NIS, the switch provides a faster alternative for this case (passwd: files nis) which doesn’t require the single + entry in /etc/passwd, /etc/group, and /etc/shadow. If this is not sufficient, the NSS compat service provides full +/- semantics. By default, the source is nis, but this may be overridden by specifying nisplus as source for the pseudo-databases passwd_compat, group_compat and shadow_compat. These pseudo-databases are only available in GNU C Library.

Tags:

Passwd