[Samba] winbind causing huge timeouts/delays since 4.8

Rowland Penny rpenny at samba.org
Mon Feb 25 09:20:12 UTC 2019


On Mon, 25 Feb 2019 09:24:24 +0100
Viktor Trojanovic via samba <samba at lists.samba.org> wrote:



> >> I'm confused.. how is the choice of the idmap backend related to an
> >> AD DC use case?
> > Only in the case of wanting the same ID everywhere.
> In my understanding, the idmap backend only needs to be specified in
> the smb.conf for member servers. That's why I still don't see how it
> is related to a AD DC use case. I take it I'm missing something
> crucial here.

A Samba AD DC uses idmap.ldb by default, this means that you get
xidNumbers in the '3000000' range, but if you use the 'ad' backend on
Unix domain members, these xidNumbers get overridden by the uidNumber's
and gidNumber's set in AD. It also turns some groups from being both
users and groups into just groups.


> > If your users never log into a Unix domain member or store files on
> > one, then do not even need to consider a winbind backend.
> 
> In a Windows clients only environment, I thought that having AD
> member servers implied that files were stored on them.
> 
> But I take it from what you write that as soon as some kind of access
> is needed, we are actually speaking about a "login", even if it's
> just on the share level and the user never sees a shell.
> 
> In which case, yet again, the question comes up which back end to
> use. I'll get to that further below.

Then I will answer it below ;-)

> 
> >> I assume that most readers of the wiki will, like me, find that
> >> "central administration of ID's inside the AD" and "ID's not stored
> >> in a local database that can corrupt with lost file ownership" seem
> >> like really important arguments (btw, the last point is not stated
> >> as a disadvantage for the rid/autorid backend in the wiki). Reading
> >> this, it just seems that the ad backend is always the right one
> >> except that it's a headache to manage.
> > It isn't really a headache to manage, once you get your head around
> > it ;-)
> 
> For very large environments, I guess you would just script it either 
> with samba-tool or powershell. But having to do it manually and
> remember that for every user, computer, and group 1-2 attributes need
> to be set, and kept track of, does seem like a nuisance.

Ah, that type of headache, what do I need to ad and what was the last
uidNumber I used.

> 
> 
> >> To put it differently, if Samba was improved in such a way that we
> >> could use the ad backend without having to manually manage the
> >> rfc2307 attributes, wouldn't this be the best if not only solution
> >> we needed?
> > I think you are mistaking using a subset of the RFC2307 attributes
> > with using most of them. If you use any backend other than
> > 'ad' (and I include a DC here) all you get is a uidNumber for a
> > user, or a gidNumber for a group. Using the 'ad' backend gets an ID
> > number that you set, plus individual login shells, Unix home dirs
> > etc
> >
> I guess I was. Are you saying, then, that if I have no need for 
> individual login shells and *nix home dirs (which in a pure Windows 
> client environment I clearly have not), the ad back end isn't really 
> offering any advantage for me?

If your users do not need to actually log into a Unix machine, then
there is no need to set a login shell, they will get the default
'bin/false'. If your users do not store anything in a Unix homedir
(only really needed if they log in) then you don't need to set the
template homedir, though there is the default /home/DOMAIN/user.

> 
> What still confuses me here is how the wiki states that in case of 
> rid/autorid information about file ownership is lost if the local tdb 
> fails and cannot be restored. 

Where does it say that ?

>I assume this does not mean that the 
> actual ownership information is stored in tdb (or in the AD, for that 
> matter) but that the user ID used in the ACL needs to be retrieved
> from somewhere, and in case of the ad back end this ID is being
> retrieved from the AD directly, in case of the rid back end it's
> retrieved from the local store only. And yet you said that on member
> servers with identical smb.conf files (I assume you were talking
> about the global section only), IDs would always be the same.

The 'DOMAIN' ID's on Unix domain members are always stored in AD, just
not always in a way you expect ;-)

For the 'ad' backend, the uidNumber & gidNumber attributes are used,
most others calculate the ID from the 'RID'. This means that if
something goes wrong and AD is okay, recreating the Unix domain member
should be enough. If the '*' tdb gets corrupt, you can delete it and it
will get recreated and whilst I cannot totally guarantee the ID's will
be the same, it doesn't really matter because the users and groups in
there are from the Well Known SIDs and are not used by the normal
users.
 
> Naturally, two questions come up:
> 
> 1) If one member server fails, wouldn't it be possible and sufficient
> to just regenerate the tdb using the same smb.conf? If this yields
> the same results every time, then why would I even worry about a
> corrupted tdb?

Yes and, on a Unix domain member, you don't have to worry

> 
> 2) If IDs were the same on all member servers, wouldn't that also
> mean that I should be able to restore the corrupted tdb on one member
> server using a valid tdb from another member server? And how would I
> go about that in practice?

Never even thought of doing that, probably because you don't need to.

> 
> I hope this makes sense.

Perfect sense to myself.

Rowland




More information about the samba mailing list