The documentation set for this product strives to use bias-free language. For the purposes of this documentation set, bias-free is defined as language that does not imply discrimination based on age, disability, gender, racial identity, ethnic identity, sexual orientation, socioeconomic status, and intersectionality. Exceptions may be present in the documentation due to language that is hardcoded in the user interfaces of the product software, language used based on RFP documentation, or language that is used by a referenced third-party product. Learn more about how Cisco is using Inclusive Language.
This chapter provides an overview of a batch, the commands contained in a batch, and how a batch is processed in Prime Cable Provisioning.
A command represents an operation that is performed on an object in the RDU database. For example, to add a new device, the client issues an add command from the API to the RDU.
The batch lifecycle (create, post, execute, return results) demands two entities to communicate over a network. For this communication, a provisioning client in Prime Cable Provisioning submits API requests to the RDU in the form of batches that contain single or multiple commands.
Figure 4-1 illustrates the concept of batch processing.
Batches are atomic units; either all the commands in the batch succeed or none of the commands succeeds. If the batch fails, the RDU restores changes that were made to its database. The RDU executes the commands in the same sequence in which they are added to the batch. For more information on batch identification, see Identifying a Batch. For more information on batch flags, see Batch Processing Flags.
To execute a batch successfully, ensure that you follow rules listed below:
Note Commands that perform device operations are write commands.
Every batch that the RDU executes has a unique batch identifier. The batch identifier that the RDU Java client library generates includes the hostname of the local client server and a random number that increments.
The batch identifier helps you to:
While the RDU Java client library automatically generates a batch identifier, you can specify your own batch identifier based on your requirements.
Note We recommend that you use the batch identifiers that the RDU Java client library generates for you.
If you generate your own batch identifier, ensure that you clearly identify the local client server.
Tip If you have a global transaction identifier, it can be a good idea to include it in the batch identifier in order to monitor the transaction throughout the entire system.
If the RDU detects a duplicate batch identifier, it rejects that batch. Submitting batches with batch identifiers that have already been processed may lead to failure and unexpected results.
You can generate a batch identifier in one of two following ways:
Use the following code to generate a batch identifier using a RDU Java client library:
Use the following code to generate a batch identifier by specifying your own identifier:
Batch processing flags control:
Prime Cable Provisioning supports the following processing flags, each of which is described in subsequent sections:
Communication between the client and the RDU breaks if:
To handle such issues, Prime Cable Provisioning provides a reliable batch flag. When you enable the reliable flag for a batch, the RDU stores the batch on receiving it, and even if the RDU restarts, the batch is guaranteed to be executed after the restart.
Note You can enable the reliable batch flag for batches that contain write commands, such as add, change, or delete. The get operation is not supported in the reliable mode.
After the batch is executed, the RDU stores the results in its database. Subsequently, the client can obtain results for the batches even after an RDU restart. To obtain the results, the client uses a join operation and the thread blocks till the results are returned or a timeout occurs. If the RDU did not receive the batch, or cleared the results from its database, an error appears. At a time, the RDU stores the results of 1000 reliable batches that were last executed.
Note We recommend that you store all batch identifiers of reliable batches to the disk, before you post a batch. By storing the batch identifiers, the RDU Java client library can query for results even if a client restart occurs.
Note We recommend that you use a timeout value when using the join feature for reliable batches. Also, because reliable batches add a significant load to the RDU, use it only when client and network reliability outweigh the performance impact.
For information on synchronous and asynchronous batches, see Batch Processing Modes.
You can use the activation flag in batches that contain write commands and operate on a single device. The activation flag is of two types:
Batches that include commands for on-connect device operations must use the no-activation flag.
Batches that include commands for all immediate device operations must use the automatic-activation flag.
Note Activation flag is not applicable for batches that contain delete commands.
You can mark a batch using the no-activation flag or the automatic-activation flag.
For example, consider a batch that contains a change Class of Service command for a device. If you execute the batch with the no-activation flag, the Class of Service of the device is changed, and the resulting new configuration is sent to the DPEs in the provisioning group. The new data is available in the appropriate DPEs for the next device session. On the other hand, if you execute the same batch with an automatic-activation flag, the RDU sends the new configuration to the provisioning group.
Activation does not verify if the configuration was successfully applied on the device. When you execute a batch with the automatic-activation flag, the batch becomes reliable. Also, activation involves updating the RDU database and pushing the updated configuration for the device to the DPE, automatically. For details on controlling this behavior using the Confirmation flag, see Setting the Confirmation Flag.
Note You can augment or replace the activation logic in the RDU during deployment using an extension. For more information, see the Cisco Prime Cable Provisioning 6.0 User Guide.
– Without specifying the flag. Because no-activation is the default, batches are created with the no-activation flag.
– By explicitly setting the flag.
You can use the confirmation flag to control the behavior of batch activation. You must use the confirmation flag only in batches that have the automatic-activation flag set.
The confirmation flag communicates with the RDU on how the processing of a batch should proceed if there are warnings or errors during activation. For more information on warnings or errors during activation, see Batch Warnings.
Prime Cable Provisioning supports two types of confirmation flags:
Unless you specify otherwise, a batch is created with the no confirmation flag.
When you execute a batch with the no-confirmation flag, warnings or errors during activation do not cause the batch to fail. Instead, the batch results contain a warning indicating that activation issues occurred. The batch proceeds and database updates are committed.
When you execute a batch with the custom-confirmation flag and a warning occurs during activation, the batch results contain the warning. The batch proceeds, committing the database updates. However, if an error occurs during activation, and the batch results contain the error, the batch fails, and the database updates get rolled back.
Note You can replace or augment the activation code in the RDU so that the errors or warnings that appear depend on the code in use.
You can create a batch with a no-confirmation flag or a custom-confirmation flag.
You can use publishing plug-ins to include custom code that helps notify the external entities of changes the batch make to the RDU database. For information on creating publishing plug-ins in the RDU, see the Cisco Prime Cable Provisioning 6.0 User Guide.
You can set the publishing flag in one of three ways:
Note When you mark a batch with the publishing with confirmation flag, the batch automatically becomes reliable.
You must explicitly specify if a batch is to be created with publishing; otherwise, batches are created using the no-publishing flag.
– Without setting any flag. Because the no-publishing flag is the default setting, a batch is thus created:
– By explicitly setting the no-publishing flag:
Because the API client executes in a client-server model, a time interval occurs between a get and a modify cycle. You can use the optimistic locking flag to prevent inconsistent changes being made to devices by different clients, simultaneously.
When you perform a get operation for an object (such as a device), the details map contains the GenericObjectKeys.OID_REVISION_NUMBER key. The value for this key is an object identifier that is encoded with the current revision number for the object. You can add this revision number to the batch to ensure that the object is not changed before the changes in your batch are applied. If the object has changed, as indicated by a different revision number, the batch returns the following error: BatchStatusCodes.BATCH_NOT_CONSISTENT
.
For example, consider a batch that retrieves a device and change its Class of Service using optimistic locking:
Note This example uses the MAC address 1,6,00:11:22:33:44:55 as device ID.
The API client submits batches to the RDU synchronously or asynchronously. The API submits batches to the RDU in two modes:
When the API client submits a synchronous batch, the batch blocks the current thread till:
If the RDU Java client library does not receive a response from the RDU within the specified timeout, a ProvTimeoutException
is thrown. The error message in the exception indicates that the RDU Java client library did not receive the batch result in the specified time but that the batch execution did not necessarily fail.
You can submit your batch to the RDU in synchronous mode with or without a timeout.
Note We recommend that you post a batch in synchronous mode with a timeout configured. For batches that read or update the database, you can configure a timeout of 30,000 milliseconds (msec). For batches that perform operations on live devices, you can configure a timeout of 60,000 msec.
When the client submits an asynchronous batch, the RDU Java client library thread that posts a batch to the RDU becomes active again. The RDU Java client library obtains the results using the batch events or, if preferred, does not obtain results at all.
You can submit an asynchronous batch on a PACE connection object, using:
To obtain batch results from batch events, the RDU Java client library registers a listener class that implements batch listener through the PACE connection with an appropriate qualifier. The batch listener interface exposes a completed method that has a batch event as its argument, and this method is called for each qualified batch when it completes. The batch event, in turn, provides access to the batch status object, which contains the results of the batch. To correlate between the submitted batch and the results, use the batch identifier.
To receive the results, ensure that the listener is registered before the batch is submitted. See Events to view the various events posted by Prime Cable Provisioning.
Depending on the commands contained in the batch, the RDU executes the batch in one of two following modes:
The concurrent and nonconcurrent modes provide higher throughput at the RDU, without losing data integrity.
When the RDU receives a batch, the commands in the batch determine the mode in which a batch is executed. The RDU executes most batches in concurrent mode. A batch must include either concurrent or nonconcurrent commands; the RDU does not process a mix of concurrent and nonconcurrent commands in a single batch. When running one concurrent batch, you can execute other concurrent batches as well.
If the RDU has to process a batch in nonconcurrent mode, all the batches currently being run in the RDU must have completed execution, and no new batches must have started. Batches you submit at this time are queued. The RDU executes the new batches in the mode in which they are marked, after completing the processing of the nonconcurrent batch; by so doing, the RDU avoids lock conflicts and consistency issues.
Only a few commands cause a batch to run in nonconcurrent mode. These commands relate to the following system configuration operations:
A batch result is the outcome of a batch that the RDU executes. Results are returned either as exceptions or as batch status objects.
When posting a batch, an exception is thrown if:
Note These exceptions are rare and are raised as a ProvisioningException
object.
If there is no ProvisioningException
thrown, a batch status object is returned. Similar to batches and commands, there are batch status objects and command status objects. A batch status object contains command status entries for each of the commands in the corresponding batch object that was executed. The order of the command status entries matches that of the commands in the batch object.
Figure 4-2 illustrates the structure of a batch status object.
Figure 4-2 Batch Status Object
The batch status object, like a batch, serves as a container. If a single command fails, you can query the batch status to determine if there was a failure and to obtain the command status that contains the details. You can also check the batch status to determine if all the commands succeeded.
Note A batch status object does not always contain a command status. An invalid batch construction, for example, one with a combination of read and write commands, returns a batch status object without command status objects.
– If a single command in a batch failed.
– The success of all commands in the batch.
To check whether the batch successfully passes, and to handle errors, if any, use the following code:
If a batch successfully passed and you want to view the results before retrieving the details of a device, use the following code.
When the RDU receives a batch from a client, it queues the batch for execution. The priority of a batch determines the queue that the RDU uses for a successful execution of the batch. In case the selected queue is full, the batch is dropped, and the client is notified.
There are ten batch queues, each with the capacity to hold 1000 batches in the order that they were received. Each queue has a different priority. Each queue could contain batches that originate internally or externally. Internal batches are those designated from the DPE and the RDU, and the batches submitted to the RDU Java client library. External batches are those designated from the API client.
– Configuration generation of CPNR DHCP extensions
– Prime Cable Provisioning server registration
– DPE configuration regeneration
– Posted by RDU itself to coordinate access to the database
The RDU has 100 threads dedicated to execute batches. At a time, the server can execute a maximum number of threads as defined in Table 4-1 .
PACE also processes batches from the Configuration Regeneration Service (CRS) and a maximum of one CRS batch is executed for every five batches from the RDU batch queues.
Table 4-1 lists the various batch queues, with the maximum executing threads for each queue.
|
|
|
---|---|---|
If you are unable to receive results, you have to retry the batch posting. You not receive results if:
Though the RDU Java client library allows you to submit batches only once, you can create a copy of the original batch and re-post it.
There are four basic groups of commands for retrying a batch. Commands that:
Note While batches support running commands across groups, mixing commands from different groups adversely impacts batch retrying.
Table 4-2 describes the four different command groups for retrying a batch.
Troubleshooting integration issues involve handling errors and warnings.
Integration errors may occur because of a:
When the connection between the RDU Java client library and the RDU fails, the RDU Java client library tries to reconnect to the RDU. When a batch fails, all database changes are rolled back; a batch status object is returned, indicating that an error occurred.
Batch warnings indicate that the batch succeeded and the changes were committed to the database.
The two types of errors that occur while integrating the OSS and BSS components to Prime Cable Provisioning are:
Connection errors are those that occur when the API client library tries to restore a broken connection with the RDU. In general, you can ignore connection errors because the RDU Java client library tries to reconnect to the RDU until the connection is restored. After a connection is restored, processing continues as usual.
You must, however, explicitly address authentication connection errors, such as an AuthenticationException
. Prime Cable Provisioning does not automatically recover from an authentication error. As an administrator, you must confirm the authentication credentials of the user (username and password).
To check batch and command errors, see Step 5 in Getting Started with the Prime Cable Provisioning API .
The status objects, BatchStatus and CommandStatus, have methods to return the error code along with a detailed error message. See the API constants BatchStatusCodes.java and CommandStatusCodes.java in the API Javadocs in the installation directory of the product for the methods that return the error code along with the detailed error message.
The RDU may return warnings for successful batches in two instances:
When you execute a batch with the custom-confirmation flag and a warning occurs during activation, the batch results contain the warning. The batch proceeds, committing the database updates. However, if an error occurs during activation, and the batch results contain the error, the batch fails, and the database updates get rolled back.