/********************************************************************************** * $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; } }