diff options
author | Andrew Tridgell <tridge@samba.org> | 2002-06-26 12:17:11 +0000 |
---|---|---|
committer | Andrew Tridgell <tridge@samba.org> | 2002-06-26 12:17:11 +0000 |
commit | caeaa0acb02f681be6025e3eafded223983960a0 (patch) | |
tree | 392e7175718940eff1ebc0ba769a488494e4e9bb /source3/utils | |
parent | 38bd5bf9eb18bfd4312ff81d566b4e9c90d7e07d (diff) | |
download | samba-caeaa0acb02f681be6025e3eafded223983960a0.tar.gz samba-caeaa0acb02f681be6025e3eafded223983960a0.tar.bz2 samba-caeaa0acb02f681be6025e3eafded223983960a0.zip |
This commit finally gives us multiple wins server groups. We now
accept an extended syntax for 'wins server' like this:
wins server = group1:192.168.2.10 group2:192.168.3.99 group1:192.168.0.1
The tags before the IPs don't mean anything, they are just a way of
grouping IPs together. If you use the old syntax (ie. no ':') then
an implicit group name of '*' is used. In general I'd recommend people
use interface names for the group names, but it doesn't matter much.
When we register in nmbd we try to register all our IPs with each group
of WINS servers. We keep trying until all of them are registered with
every group, falling back to the failover WINS servers for each group
as we go.
When we do a WINS lookup we try each of the WINS servers for each group.
If a WINS server for a group gives a negative answer then we give up
on that group and move to the next group. If it times out then
we move to the next failover wins server in the group.
In either case, if a WINS server doesn't respond then we mark it dead
for 10 minutes, to prevent lengthy waits for dead servers.
(This used to be commit e125f06058b6b51382cf046b1dbb30728b8aeda5)
Diffstat (limited to 'source3/utils')
-rw-r--r-- | source3/utils/nmblookup.c | 4 |
1 files changed, 2 insertions, 2 deletions
diff --git a/source3/utils/nmblookup.c b/source3/utils/nmblookup.c index 2373beb0c9..8e4f5aab03 100644 --- a/source3/utils/nmblookup.c +++ b/source3/utils/nmblookup.c @@ -159,7 +159,7 @@ static BOOL query_one(char *lookup, unsigned int lookup_type) d_printf("querying %s on %s\n", lookup, inet_ntoa(bcast_addr)); ip_list = name_query(ServerFD,lookup,lookup_type,use_bcast, use_bcast?True:recursion_desired, - bcast_addr,&count, &flags); + bcast_addr,&count, &flags, NULL); } else { struct in_addr *bcast; for (j=iface_count() - 1; @@ -171,7 +171,7 @@ static BOOL query_one(char *lookup, unsigned int lookup_type) ip_list = name_query(ServerFD,lookup,lookup_type, use_bcast, use_bcast?True:recursion_desired, - *bcast,&count, &flags); + *bcast,&count, &flags, NULL); } } |