Skip to main content

Guidewire Workqueue

Guidewire WorkQueues

WorkQueues in Guidewire are used to manage and process large volumes of tasks asynchronously. They help in distributing the workload across multiple servers, ensuring efficient processing without overloading any single server.

How WorkQueues are Used

1. Task Distribution: WorkQueues distribute tasks across multiple servers, ensuring balanced load and efficient processing.
2. Asynchronous Processing: Tasks are processed in the background, allowing the main application to continue functioning without delays.
3. Scalability: They enable the system to handle large volumes of tasks by scaling the processing across multiple servers.

Gosu Code Implementation

Here's a basic example of how to implement a WorkQueue in Guidewire using Gosu:

1. Create a New Typecode: Define a new typecode in `BatchProcessType` typekey.

```gosu
<typecode name="MyNewCode" desc="Description of MyNewCode">
  <categories>
    <category name="Schedulable"/>
  </categories>
</typecode>
```

2. Create a WorkQueue Class: Extend `WorkQueueBase` to create your custom WorkQueue class.

```gosu
class MyWorkQueue extends WorkQueueBase<Message, StandardWorkItem> {
  private final static var _batchProcessType = BatchProcessType.TC_MYNEWCODE

  construct() {
    super(_batchProcessType, StandardWorkItem, Message)
  }

  override function findTargets(): Iterator<Message> {
    return Query.make(Message).select().iterator()
  }

  override function processWorkItem(p0: StandardWorkItem) {
    var bean = extractTarget(p0)
    // Your processing logic here
  }
}

3. Register the WorkQueue: Register your WorkQueue class in `work-queue.xml`.

<work-queue workQueueClass="example.MyWorkQueue" progressinterval="600000">
  <worker instances="1" batchsize="5"/>
</work-queue>


4. Schedule the WorkQueue: Optionally, register the new `BatchProcessType` in `scheduler-config.xml`.


<ProcessSchedule process="MyNewCode">
  <CronSchedule minutes="*/10"/>
</ProcessSchedule>


This setup ensures that your WorkQueue is properly configured to handle tasks asynchronously, improving the overall performance and scalability of your Guidewire application¹.


Comments

Popular posts from this blog

Java Swing MySql JDBC: insert data into database

Program import javax.swing.*; import java.awt.*; import java.awt.event.*; import java.sql.*; public class insertswing implements ActionListener {   JFrame fr;JPanel po;   JLabel l1,l2,main;   JTextField tf1,tf2;   GridBagConstraints gbc;   GridBagLayout go;   JButton ok,exit; public insertswing(){ fr=new JFrame("New User Data "); Font f=new Font("Verdana",Font.BOLD,24); po=new JPanel(); fr.getContentPane().add(po); fr.setVisible(true); fr.setSize(1024,768); fr.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE); po.setBackground(Color.WHITE); go=new GridBagLayout(); gbc=new GridBagConstraints(); po.setLayout(go); main=new JLabel("Enter User Details "); main.setFont(f); l1=new JLabel("Name  :");tf1=new JTextField(20); l2=new JLabel("User Name  :");tf2=new JTextField(20); ok=new JButton("Accept"); exit=new JButton("Exit"); gbc.anchor=GridBagConstraints.NORTH;gbc.gridx=5;gbc.gridy=0; go.s...

Guidewire Policy - Spin Up Spin Off Transactions

Guidewire PolicyCenter - Spin Up and Spin Off Policy Job Transactions In Guidewire PolicyCenter, "spin up" and "spin off" refer to specific actions you can take with policy job transactions. These terms are related to how new policy transactions (such as renewals, endorsements, or cancellations) are created or modified. Here's an explanation of each: 1. Spin Up: "Spin up" refers to the process of creating a new policy job from an existing policy or transaction. When you "spin up" a policy job, you're essentially initiating a new transaction based on an existing policy. This new transaction could be a renewal, an endorsement, or any other type of policy change. For example: - Renewal : When a policy's term is about to expire, you might "spin up" a renewal job to create a new policy term based on the existing one. The new job will carry forward much of the existing policy's data but may allow for updates or cha...

JSP and Servlet Form Submission without page refresh show results on the same page using Jquery AJAX

Code Snippet HTML Form  <form id='ajaxform' name='ajaxform' action='ajaxformexample' method='post'>  First Name: <input type='text' id='firstname' name='firstname' size='30' required/><br/>  Last Name: <input type='text' id='lastname' name='lastname' size='30'required/><br/>  Email:  <input type='email' id='emailid' name='emailid' size='30'required/><br/>  Password:  <input type='password' id='pwd' name='pwd' size='30'required/><br/>  <input type='Submit'/>   <div id='content'> </div> </form> the above HTML Form uses post method and url servlet redirect to " ajaxformexample " Javascript Code  var form = $('#ajaxform'); // id of form tag  form.submit(function () {  $.ajax({  ...