All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.hibernate.search.backend.jms.impl.JmsBackendQueueTask Maven / Gradle / Ivy

There is a newer version: 5.11.12.Final
Show newest version
/*
 * Hibernate Search, full-text search for your domain model
 *
 * License: GNU Lesser General Public License (LGPL), version 2.1 or later
 * See the lgpl.txt file in the root directory or .
 */
package org.hibernate.search.backend.jms.impl;

import java.util.ArrayList;
import java.util.Collection;
import java.util.List;
import java.util.UUID;

import javax.jms.JMSException;
import javax.jms.ObjectMessage;
import javax.jms.QueueConnection;
import javax.jms.QueueSender;
import javax.jms.QueueSession;
import javax.jms.Session;

import org.hibernate.search.backend.LuceneWork;
import org.hibernate.search.backend.OptimizeLuceneWork;
import org.hibernate.search.cfg.Environment;
import org.hibernate.search.indexes.serialization.spi.LuceneWorkSerializer;
import org.hibernate.search.util.logging.impl.Log;
import org.hibernate.search.util.logging.impl.LoggerFactory;

/**
 * @author Emmanuel Bernard
 * @author Sanne Grinovero (C) 2011 Red Hat Inc.
 * @author Yoann Gendre
 */
public class JmsBackendQueueTask implements Runnable {

	private static final Log log = LoggerFactory.make();

	private final Collection queue;
	private final JmsBackendQueueProcessor processor;
	private final String indexName;
	private final LuceneWorkSerializer luceneWorkSerializer;

	public JmsBackendQueueTask(String indexName, Collection queue,
			JmsBackendQueueProcessor jmsBackendQueueProcessor, LuceneWorkSerializer luceneWorkSerializer) {
		this.indexName = indexName;
		this.queue = queue;
		this.processor = jmsBackendQueueProcessor;
		this.luceneWorkSerializer = luceneWorkSerializer;
	}

	@Override
	public void run() {
		List filteredQueue = new ArrayList(queue);
		for ( LuceneWork work : queue ) {
			if ( work instanceof OptimizeLuceneWork ) {
				//we don't want optimization to be propagated
				filteredQueue.remove( work );
			}
		}
		if ( filteredQueue.size() == 0 ) {
			return;
		}
		byte[] data = luceneWorkSerializer.toSerializedModel( filteredQueue );
		QueueSender sender;
		QueueSession session = null;
		QueueConnection connection = null;
		try {
			connection = processor.getJMSConnection();
			session = connection.createQueueSession( processor.isTransactional(), Session.DUPS_OK_ACKNOWLEDGE );
			ObjectMessage message = session.createObjectMessage();
			message.setObject( data );
			message.setStringProperty( Environment.INDEX_NAME_JMS_PROPERTY, indexName );
			if ( log.isDebugEnabled() ) {
				attachDebugDetails( message, indexName );
			}

			sender = session.createSender( processor.getJmsQueue() );
			sender.send( message );
			sender.close();
			session.close();
		}
		catch (JMSException e) {
			throw log.unableToSendJMSWork( indexName, processor.getJmsQueueName(), e );
		}
		finally {
			processor.releaseJMSConnection( connection );
		}
	}

	private static void attachDebugDetails(ObjectMessage message, String indexName) throws JMSException {
		String randomUUID = UUID.randomUUID().toString();
		message.setStringProperty( "HSearchMsgId", randomUUID );
		log.debug( "Enqueueing List for index '" + indexName + "' having id " + randomUUID );
	}

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy