00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022
00023
00024
00025
00026
00027
00028
00029
00030
00031 package org.objectweb.proactive.core.body.ft.protocols.pmlrb.servers;
00032
00033 import java.rmi.RemoteException;
00034
00035 import org.apache.log4j.Logger;
00036 import org.objectweb.proactive.core.UniqueID;
00037 import org.objectweb.proactive.core.body.ft.checkpointing.Checkpoint;
00038 import org.objectweb.proactive.core.body.ft.protocols.pmlrb.managers.FTManagerPMLRB;
00039 import org.objectweb.proactive.core.body.ft.servers.FTServer;
00040 import org.objectweb.proactive.core.body.ft.servers.recovery.RecoveryJob;
00041 import org.objectweb.proactive.core.body.ft.servers.recovery.RecoveryProcessImpl;
00042 import org.objectweb.proactive.core.node.Node;
00043 import org.objectweb.proactive.core.util.log.Loggers;
00044 import org.objectweb.proactive.core.util.log.ProActiveLogger;
00045
00046
00052 public class RecoveryProcessPMLRB extends RecoveryProcessImpl {
00053
00054 protected static Logger logger = ProActiveLogger.getLogger(Loggers.FAULT_TOLERANCE_PML);
00055
00060 public RecoveryProcessPMLRB(FTServer server) {
00061 super(server);
00062 }
00063
00067 protected void recover(UniqueID failed) {
00068 try {
00069 Checkpoint toSend = this.server.getLastCheckpoint(failed);
00070
00071
00072 Node node = this.server.getFreeNode();
00073
00074
00075 RecoveryJob job = new RecoveryJob(toSend,
00076 FTManagerPMLRB.DEFAULT_TTC_VALUE, node);
00077 this.submitJob(job);
00078 } catch (RemoteException e) {
00079 logger.error("[RECOVERY] **ERROR** Cannot contact other servers : ");
00080 e.printStackTrace();
00081 }
00082 }
00083 }