/**********************************************************************************
* $URL: https://source.sakaiproject.org/svn/search/trunk/search-impl/impl/src/java/org/sakaiproject/search/optimize/shared/impl/JournalOptimizationOperation.java $
* $Id: JournalOptimizationOperation.java 105078 2012-02-24 23:00:38Z ottenhoff@longsight.com $
***********************************************************************************
*
* Copyright (c) 2003, 2004, 2005, 2006, 2007, 2008, 2009 The Sakai Foundation
*
* Licensed under the Educational Community License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.opensource.org/licenses/ECL-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*
**********************************************************************************/
package org.sakaiproject.search.optimize.shared.impl;
import java.util.HashMap;
import java.util.Map;
import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
import org.sakaiproject.component.api.ServerConfigurationService;
import org.sakaiproject.search.indexer.api.LockTimeoutException;
import org.sakaiproject.search.journal.api.JournalErrorException;
import org.sakaiproject.search.journal.api.ManagementOperation;
import org.sakaiproject.search.optimize.api.NoOptimizationRequiredException;
import org.sakaiproject.search.optimize.shared.api.JournalOptimizationManager;
import org.sakaiproject.search.optimize.shared.api.JournalOptimizationTransaction;
import org.sakaiproject.search.transaction.api.IndexTransactionException;
/**
* Performs an optimize operation using an OptimizIndexManager to manage the
* 2PC.
*
* @author ieb
*/
public class JournalOptimizationOperation implements ManagementOperation
{
private static final Log log = LogFactory.getLog(JournalOptimizationOperation.class);
/**
* The manager that performs the optimization
*/
private JournalOptimizationManager journalOptimizationManager;
public void init()
{
}
public void destroy()
{
}
private ServerConfigurationService serverConfigurationService;
public void setServerConfigurationService(
ServerConfigurationService serverConfigurationService) {
this.serverConfigurationService = serverConfigurationService;
}
/**
* @see org.sakaiproject.search.journal.api.ManagementOperation#runOnce()
*/
public void runOnce()
{
if (!serverConfigurationService.getBoolean("search.sharedmerge", true))
return;
/*
* Run the optimizer transaction once
*/
JournalOptimizationTransaction journalOptimizationTransaction = null;
try
{
Map<String, Object> m = new HashMap<String, Object>();
journalOptimizationTransaction = (JournalOptimizationTransaction) journalOptimizationManager
.openTransaction(m);
journalOptimizationTransaction.prepare();
journalOptimizationTransaction.commit();
}
catch (NoOptimizationRequiredException nop)
{
log.debug("No Merge Performed " + nop.getMessage());
}
catch (LockTimeoutException jex)
{
log.info("Failed to perform optimise, pending Optimize on other node if cause is a DB lock timeout Cause:"+jex.getMessage());
try
{
journalOptimizationTransaction.rollback();
}
catch (Exception ex)
{
log.warn("Failed to rollback transaction ", ex);
}
}
catch (JournalErrorException jex)
{
if (journalOptimizationTransaction != null)
{
log.warn("Failed to complete Optimize ", jex);
}
else
{
log.warn("Failed to start merge operation ", jex);
}
try
{
if (journalOptimizationTransaction != null) {
journalOptimizationTransaction.rollback();
}
}
catch (Exception ex)
{
log.warn("Failed to rollback transaction ", ex);
}
}
catch (IndexTransactionException iupex)
{
log.warn("Failed to complete optimize ", iupex);
try
{
if (journalOptimizationTransaction != null) {
journalOptimizationTransaction.rollback();
}
}
catch (Exception ex)
{
log.warn("Failed to rollback transaction ", ex);
}
}
finally
{
try
{
if (journalOptimizationTransaction != null)
journalOptimizationTransaction.close();
}
catch (Exception ex)
{
log.debug(ex);
}
}
}
/**
* @return the journalOptimizationManager
*/
public JournalOptimizationManager getJournalOptimizationManager()
{
return journalOptimizationManager;
}
/**
* @param journalOptimizationManager
* the journalOptimizationManager to set
*/
public void setJournalOptimizationManager(
JournalOptimizationManager journalOptimizationManager)
{
this.journalOptimizationManager = journalOptimizationManager;
}
}