Main Page | Packages | Class Hierarchy | Alphabetical List | Class List | File List | Class Members | Related Pages

BackendStateListener.java

00001 /**
00002  * C-JDBC: Clustered JDBC.
00003  * Copyright (C) 2002-2004 French National Institute For Research In Computer
00004  * Science And Control (INRIA).
00005  * Contact: c-jdbc@objectweb.org
00006  * 
00007  * This library is free software; you can redistribute it and/or modify it
00008  * under the terms of the GNU Lesser General Public License as published by the
00009  * Free Software Foundation; either version 2.1 of the License, or any later
00010  * version.
00011  * 
00012  * This library is distributed in the hope that it will be useful, but WITHOUT
00013  * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
00014  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License
00015  * for more details.
00016  * 
00017  * You should have received a copy of the GNU Lesser General Public License
00018  * along with this library; if not, write to the Free Software Foundation,
00019  * Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA.
00020  *
00021  * Initial developer(s): Nicolas Modrzyk.
00022  * Contributor(s): ______________________.
00023  */
00024 
00025 package org.objectweb.cjdbc.controller.backend;
00026 
00027 import java.sql.SQLException;
00028 
00029 import org.objectweb.cjdbc.common.log.Trace;
00030 import org.objectweb.cjdbc.controller.recoverylog.AbstractRecoveryLog;
00031 import org.objectweb.cjdbc.controller.recoverylog.BackendRecoveryInfo;
00032 
00033 /**
00034  * This class defines a BackendStateListener
00035  * 
00036  * @author <a href="mailto:Nicolas.Modrzyk@inrialpes.fr">Nicolas Modrzyk </a>
00037  * @version 1.0
00038  */
00039 public class BackendStateListener
00040 {
00041 
00042   Trace                       logger = Trace
00043                                          .getLogger(BackendStateListener.class
00044                                              .getName());
00045   private String              virtualDatabaseName;
00046   private AbstractRecoveryLog recoveryLog;
00047 
00048   /**
00049    * Creates a new <code>BackendStateListener</code> object
00050    * 
00051    * @param vdbName virtual database name
00052    * @param recoveryLog recovery log
00053    */
00054   public BackendStateListener(String vdbName, AbstractRecoveryLog recoveryLog)
00055   {
00056     this.virtualDatabaseName = vdbName;
00057     this.recoveryLog = recoveryLog;
00058   }
00059 
00060   /**
00061    * Update the persistent state of the backend in the recovery log
00062    * 
00063    * @param backend the backend to update information from
00064    */
00065   public synchronized void changeState(DatabaseBackend backend)
00066   {
00067     try
00068     {
00069       recoveryLog.storeBackendRecoveryInfo(virtualDatabaseName,
00070           new BackendRecoveryInfo(backend.getName(), backend
00071               .getLastKnownCheckpoint(), backend.getStateValue(),
00072               virtualDatabaseName));
00073     }
00074     catch (SQLException e)
00075     {
00076       logger.error("Could not store informatione for backend:"
00077           + backend.getName(), e);
00078     }
00079   }
00080 }

Generated on Mon Apr 11 22:01:29 2005 for C-JDBC by  doxygen 1.3.9.1