2017-04-19 20:44:31 +02:00
/* -------------------------------------------------------------------------- */
2018-01-02 18:27:37 +01:00
/* Copyright 2002-2018, OpenNebula Project, OpenNebula Systems */
2017-04-19 20:44:31 +02:00
/* */
/* Licensed under the Apache 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.apache.org/licenses/LICENSE-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. */
/* -------------------------------------------------------------------------- */
2017-04-27 01:03:44 +02:00
# ifndef REPLICA_REQUEST_H_
# define REPLICA_REQUEST_H_
2017-04-19 20:44:31 +02:00
2017-04-20 16:13:41 +02:00
# include "SyncRequest.h"
2017-04-19 20:44:31 +02:00
/**
* This class represents a log entry replication request . The replication request
* is synchronous : once it has been replicated in a majority of followers the
* client is notified ( SqlDB : : exec_wr ( ) call ) and DB updated .
*/
2017-04-27 01:03:44 +02:00
class ReplicaRequest : public SyncRequest
2017-04-19 20:44:31 +02:00
{
public :
2017-04-27 11:12:30 +02:00
ReplicaRequest ( unsigned int i ) : _index ( i ) , _to_commit ( - 1 ) , _replicas ( 1 ) { } ;
2017-04-19 20:44:31 +02:00
2017-04-27 01:03:44 +02:00
~ ReplicaRequest ( ) { } ;
2017-04-19 20:44:31 +02:00
/**
2017-04-27 01:03:44 +02:00
* This function updates the number of replicas of the record and decrement
* the number of servers left to reach majority consensus . If it reaches 0 ,
* the client is notified
* @ return number of replicas for this log
2017-04-19 20:44:31 +02:00
*/
2017-04-27 01:03:44 +02:00
int inc_replicas ( )
2017-04-20 16:13:41 +02:00
{
2017-04-27 01:03:44 +02:00
int __replicas ;
2017-04-19 20:44:31 +02:00
2017-04-27 01:03:44 +02:00
_replicas + + ;
2017-04-19 20:44:31 +02:00
2017-04-27 01:03:44 +02:00
if ( _to_commit > 0 )
{
_to_commit - - ;
}
__replicas = _replicas ;
if ( _to_commit = = 0 )
{
result = true ;
timeout = false ;
notify ( ) ;
}
2017-04-21 22:32:30 +02:00
2017-04-27 01:03:44 +02:00
return __replicas ;
}
/* ---------------------------------------------------------------------- */
/* Class access methods */
/* ---------------------------------------------------------------------- */
int index ( )
2017-04-20 16:13:41 +02:00
{
2017-04-27 01:03:44 +02:00
return _index ;
}
2017-04-19 20:44:31 +02:00
2017-04-25 11:49:52 +02:00
int replicas ( )
{
return _replicas ;
}
int to_commit ( )
{
return _to_commit ;
}
void to_commit ( int c )
{
_to_commit = c ;
}
2017-04-19 20:44:31 +02:00
private :
/**
* Index for this log entry
*/
2017-04-20 16:13:41 +02:00
unsigned int _index ;
2017-04-19 20:44:31 +02:00
/**
* Remaining number of servers that need to replicate this record to commit
* it . Initialized to ( Number_Servers - 1 ) / 2
*/
2017-04-25 11:49:52 +02:00
int _to_commit ;
2017-04-19 20:44:31 +02:00
/**
* Total number of replicas for this entry
*/
2017-04-25 11:49:52 +02:00
int _replicas ;
2017-04-19 20:44:31 +02:00
} ;
2017-04-27 01:03:44 +02:00
# endif /*REPLICA_REQUEST_H_*/
2017-04-19 20:44:31 +02:00