mirror of
https://github.com/samba-team/samba.git
synced 2025-01-20 14:03:59 +03:00
961f07fb76
EnumDomainUsers currently takes too long, significantly slowing down calls to winbind's getpwent which is a core unix API. The time is taken up by a GUID lookup for every record in the cached result. The advantages of this approach are: 1. It meets the specified requirement that if a record yet to be returned by a search in progress (with a resume handle) is deleted or modified, the future returned results correctly reflect the new changes. 2. Memory footprint for a search in progress is only 16 bytes per record. But, those benefits are not worth the significant performance hit of the lookups, so this patch changes the function to run the search and cache the RIDs and names of all records matching the search when the request is made. This makes the memory footprint around 200 bytes per record or up to 2MB per concurrent search for a 100k user database. The speedup achieved by this change is around 50%, and in tandem with some winbindd improvements as part of the same task has achieved around 15x speedup for getpwent. The lost specification compliance is unlikely to cause a problem for any known usage of this RPC call. Signed-off-by: Aaron Haslett <aaronhaslett@catalyst.net.nz> Reviewed-by: Gary Lockyer <gary@catalyst.net.nz> Reviewed-by: Andrew Bartlett <abartlet@samba.org>
89 lines
2.0 KiB
C
89 lines
2.0 KiB
C
/*
|
|
Unix SMB/CIFS implementation.
|
|
|
|
endpoint server for the samr pipe - definitions
|
|
|
|
Copyright (C) Andrew Tridgell 2004
|
|
|
|
This program is free software; you can redistribute it and/or modify
|
|
it under the terms of the GNU General Public License as published by
|
|
the Free Software Foundation; either version 3 of the License, or
|
|
(at your option) any later version.
|
|
|
|
This program is distributed in the hope that it will be useful,
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
GNU General Public License for more details.
|
|
|
|
You should have received a copy of the GNU General Public License
|
|
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
*/
|
|
|
|
#include "param/param.h"
|
|
#include "libds/common/roles.h"
|
|
|
|
/*
|
|
this type allows us to distinguish handle types
|
|
*/
|
|
enum samr_handle {
|
|
SAMR_HANDLE_CONNECT,
|
|
SAMR_HANDLE_DOMAIN,
|
|
SAMR_HANDLE_USER,
|
|
SAMR_HANDLE_GROUP,
|
|
SAMR_HANDLE_ALIAS
|
|
};
|
|
|
|
|
|
/*
|
|
state asscoiated with a samr_Connect*() operation
|
|
*/
|
|
struct samr_connect_state {
|
|
struct ldb_context *sam_ctx;
|
|
uint32_t access_mask;
|
|
};
|
|
|
|
/*
|
|
* Cache of object GUIDS
|
|
*/
|
|
struct samr_guid_cache {
|
|
unsigned handle;
|
|
unsigned size;
|
|
struct GUID *entries;
|
|
};
|
|
|
|
enum samr_guid_cache_id {
|
|
SAMR_QUERY_DISPLAY_INFO_CACHE,
|
|
SAMR_ENUM_DOMAIN_GROUPS_CACHE,
|
|
SAMR_ENUM_DOMAIN_USERS_CACHE,
|
|
SAMR_LAST_CACHE
|
|
};
|
|
|
|
/*
|
|
state associated with a samr_OpenDomain() operation
|
|
*/
|
|
struct samr_domain_state {
|
|
struct samr_connect_state *connect_state;
|
|
void *sam_ctx;
|
|
uint32_t access_mask;
|
|
struct dom_sid *domain_sid;
|
|
const char *domain_name;
|
|
struct ldb_dn *domain_dn;
|
|
enum server_role role;
|
|
bool builtin;
|
|
struct loadparm_context *lp_ctx;
|
|
struct samr_guid_cache guid_caches[SAMR_LAST_CACHE];
|
|
struct samr_SamEntry *domain_users_cached;
|
|
};
|
|
|
|
/*
|
|
state associated with a open account handle
|
|
*/
|
|
struct samr_account_state {
|
|
struct samr_domain_state *domain_state;
|
|
void *sam_ctx;
|
|
uint32_t access_mask;
|
|
struct dom_sid *account_sid;
|
|
const char *account_name;
|
|
struct ldb_dn *account_dn;
|
|
};
|