3.1.4.5 R_WinsDoScavenging (Opnum 4)
The R_WinsDoScavenging method queues a scavenging request on the target WINS server.
-
DWORD R_WinsDoScavenging( [in] handle_t ServerHdl );
ServerHdl: An RPC binding over IP address/HostName to the WINS server. RPC uses this binding internally to determine which WINS server the call is directed to.
Return Values: A 32 bit unsigned integer that indicates the return status. A return value of ERROR_SUCCESS (0x00000000) indicates that the operation completed successfully. A nonzero return value is a Win32 error code, as specified in [MS-ERREF]. The following Win32 error codes can be returned:
-
Return value/code
Description
0x00000000
ERROR_SUCCESS
The call was successful.
0x00000005
ERROR_ACCESS_DENIED
The caller doesn't have sufficient permissions.
Exceptions Thrown: No exceptions are thrown beyond those thrown by the underlying RPC protocol [MS-RPCE].
Processing and Response Requirements:
When R_WinsDoScanvenging is called, the server returns immediately without waiting for scavenging to start. The server just queues a request for the scavenging operation, and the internal state and configuration of the WINS server determine whether or not the scavenging occurs. Hence,callers to R_WinsDoScanvenging SHOULD NOT treat a return code of ERROR_SUCCESS as indicating a successful scavenging operation. Instead, callers SHOULD rely on WINS event logs to determine whether or not the scavenging operation succeeded. The following table lists the events that indicate the status of scavenging.
|
Event ID |
Event Name |
Event Description |
|---|---|---|
|
Informational events |
||
|
4143 |
WINS_EVT_SCV_RECS |
WINS scavenged its records in the WINS database. The number of records scavenged is given in the data section. |
|
4144 |
WINS_EVT_SCV_RPLTOMB |
WINS scavenged replica tombstones in the WINS database. The number of records scavenged is given in the data section. |
|
4247 |
WINS_EVT_SCV_EXC |
The WINS Scavenger thread encountered an error. |
|
4250 |
WINS_EVT_SCV_ERR |
The WINS Scavenger thread could not scavenge a record. This record will be ignored. The Scavenger will continue to the next available record. Check the application log for the Exchange component, ESENT. |
|
4269 |
WINS_EVT_UNABLE_TO_CHG_PRIORITY |
The Scavenger thread was unable to change its priority level. |
|
4288 |
WINS_EVT_CLEANUP_OWNADDTBL_EXC |
The Scavenger thread encountered an error while cleaning up the owner-address table. It will try again after the Verify interval has elapsed. |
|
4328 |
WINS_EVT_ADMIN_SCVENGING_INITIATED |
Administrator '%1' has initiated a scavenging operation. |
|
4329 |
WINS_EVT_SCVENGING_STARTED |
The WINS server has started a scavenging operation. |
|
4330 |
WINS_EVT_SCVENGING_COMPLETED |
The WINS server has completed the scavenging operation. |
|
5001 |
WINS_EVT_SCV_RANGE |
WINS is scavenging the locally owned records from the database. The version number range that is scavenged is given in the data section, in the second to fifth words, in the order: from_version_number (low word, high word) to_version_number (low word, high word). |
|
5002 |
WINS_EVT_SCV_CHUNK |
WINS is scavenging a chunk of N records in the version number range from X to Y. N, X and Y (low word, high word for version numbers) are given in the second to sixth words in the data section. |
|
Warning events |
||
|
4150 |
WINS_EVT_ADJ_TIME_INTVL_R |
WINS adjusted the scavenging-related time interval, %1, so that it is compatible with the replication time intervals. The adjusted value for this scavenging parameter is given in the data section (second DWORD). This value was computed by WINS using an algorithm that MAY use the maximum replication time interval specified. The current value achieves a good balance between consistency of databases across the network of WINS servers and the performance of the WINS servers. |
|
4151 |
WINS_EVT_ADJ_TIME_INTVL |
WINS adjusted the scavenging-related time interval, %1. The adjusted value for this scavenging parameter is given in the data section (second DWORD). This value was computed by WINS using an algorithm that tries to achieve a good balance between consistency of databases across the network of WINS servers and the performance of the WINS servers. |
|
4153 |
WINS_EVT_UNABLE_TO_VERIFY |
The Scavenger thread found active replicas that needed to be verified with the owning WINS server because they were older than the verify time interval. The table of owner-to-address mappings indicated the WINS was not active. |
|
4164 |
WINS_EVT_FORCE_SCV_R_T |
WINS was forced to scavenge replica tombstones of a WINS. The person with administrative rights on the computer forced the scavenging by using the winscl.exe. WINS does not scavenge replica tombstones unless they have timed out and WINS has been running for at least three days (this ensures that the tombstones have replicated to other WINS). In this case, the tombstones were timed out but the WINS had not been running for three days. The replica tombstones were deleted. This deletion does not constitute a problem unless there are WINS servers that are primary and backup to clients but not both Push and Pull partners of each other. With the preceding WINS scenario, there is a low probability that this action will result in database inconsistency but if it does, a consistent state can be achieved by initiating consistency checks by using the winscl.exe. |
The following requirements and recommendations apply to a WINS server that processes a call to R_WinsDoScavenging:
Callers to R_WinsDoScavenging SHOULD have control level access. If an RPC client with a lower access level calls R_WinsDoScavenging, the server SHOULD return ERROR_ACCESS_DENIED.
The WINS server queues a request on the target WINS server for the scavenging operation, and the method returns immediately with ERROR_SUCCESS as the status code.