2017-05-26 04:48:44 +08:00
/*
* ThreadSafeTransaction . h
*
* This source file is part of the FoundationDB open source project
*
* Copyright 2013 - 2018 Apple Inc . and the FoundationDB project authors
2018-02-22 02:25:11 +08:00
*
2017-05-26 04:48:44 +08: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
2018-02-22 02:25:11 +08:00
*
2017-05-26 04:48:44 +08:00
* http : //www.apache.org/licenses/LICENSE-2.0
2018-02-22 02:25:11 +08:00
*
2017-05-26 04:48:44 +08:00
* 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 .
*/
# ifndef FDBCLIENT_THREADSAFETRANSACTION_H
# define FDBCLIENT_THREADSAFETRANSACTION_H
# pragma once
2018-10-20 01:30:13 +08:00
# include "fdbclient/ReadYourWrites.h"
2017-05-26 04:48:44 +08:00
# include "flow/ThreadHelper.actor.h"
2018-10-20 01:30:13 +08:00
# include "fdbclient/ClusterInterface.h"
# include "fdbclient/IClientApi.h"
2017-05-26 04:48:44 +08:00
class ThreadSafeDatabase : public IDatabase , public ThreadSafeReferenceCounted < ThreadSafeDatabase > {
public :
2021-01-26 09:55:43 +08:00
~ ThreadSafeDatabase ( ) override ;
2017-05-26 04:48:44 +08:00
static ThreadFuture < Reference < IDatabase > > createFromExistingDatabase ( Database cx ) ;
2021-01-26 09:55:43 +08:00
Reference < ITransaction > createTransaction ( ) override ;
2017-05-26 04:48:44 +08:00
2021-01-26 09:55:43 +08:00
void setOption ( FDBDatabaseOptions : : Option option , Optional < StringRef > value = Optional < StringRef > ( ) ) override ;
2017-05-26 04:48:44 +08:00
2018-09-22 06:58:14 +08:00
ThreadFuture < Void > onConnected ( ) ; // Returns after a majority of coordination servers are available and have reported a leader. The cluster file therefore is valid, but the database might be unavailable.
2021-01-26 09:55:43 +08:00
void addref ( ) override { ThreadSafeReferenceCounted < ThreadSafeDatabase > : : addref ( ) ; }
void delref ( ) override { ThreadSafeReferenceCounted < ThreadSafeDatabase > : : delref ( ) ; }
2017-05-26 04:48:44 +08:00
2021-01-26 09:55:43 +08:00
ThreadFuture < int64_t > rebootWorker ( const StringRef & address , bool check , int duration ) override ;
2021-01-26 10:26:18 +08:00
ThreadFuture < Void > forceRecoveryWithDataLoss ( const StringRef & dcid ) override ;
2020-08-22 05:30:52 +08:00
2017-05-26 04:48:44 +08:00
private :
friend class ThreadSafeTransaction ;
DatabaseContext * db ;
public : // Internal use only
2018-09-27 01:27:55 +08:00
ThreadSafeDatabase ( std : : string connFilename , int apiVersion ) ;
2017-05-26 04:48:44 +08:00
ThreadSafeDatabase ( DatabaseContext * db ) : db ( db ) { }
DatabaseContext * unsafeGetPtr ( ) const { return db ; }
} ;
class ThreadSafeTransaction : public ITransaction , ThreadSafeReferenceCounted < ThreadSafeTransaction > , NonCopyable {
public :
2019-03-26 07:11:50 +08:00
explicit ThreadSafeTransaction ( DatabaseContext * cx ) ;
2021-01-26 09:55:43 +08:00
~ ThreadSafeTransaction ( ) override ;
2017-05-26 04:48:44 +08:00
2019-06-26 07:32:27 +08:00
void cancel ( ) override ;
void setVersion ( Version v ) override ;
ThreadFuture < Version > getReadVersion ( ) override ;
ThreadFuture < Optional < Value > > get ( const KeyRef & key , bool snapshot = false ) override ;
ThreadFuture < Key > getKey ( const KeySelectorRef & key , bool snapshot = false ) override ;
ThreadFuture < Standalone < RangeResultRef > > getRange ( const KeySelectorRef & begin , const KeySelectorRef & end , int limit , bool snapshot = false , bool reverse = false ) override ;
ThreadFuture < Standalone < RangeResultRef > > getRange ( const KeySelectorRef & begin , const KeySelectorRef & end , GetRangeLimits limits , bool snapshot = false , bool reverse = false ) override ;
ThreadFuture < Standalone < RangeResultRef > > getRange ( const KeyRangeRef & keys , int limit , bool snapshot = false , bool reverse = false ) override {
2019-07-03 05:42:50 +08:00
return getRange ( firstGreaterOrEqual ( keys . begin ) , firstGreaterOrEqual ( keys . end ) , limit , snapshot , reverse ) ;
2017-05-26 04:48:44 +08:00
}
2019-06-26 07:32:27 +08:00
ThreadFuture < Standalone < RangeResultRef > > getRange ( const KeyRangeRef & keys , GetRangeLimits limits , bool snapshot = false , bool reverse = false ) override {
2017-05-26 04:48:44 +08:00
return getRange ( firstGreaterOrEqual ( keys . begin ) , firstGreaterOrEqual ( keys . end ) , limits , snapshot , reverse ) ;
}
2019-06-26 07:32:27 +08:00
ThreadFuture < Standalone < VectorRef < const char * > > > getAddressesForKey ( const KeyRef & key ) override ;
ThreadFuture < Standalone < StringRef > > getVersionstamp ( ) override ;
2020-01-17 09:39:23 +08:00
ThreadFuture < int64_t > getEstimatedRangeSizeBytes ( const KeyRangeRef & keys ) override ;
2020-06-19 00:41:50 +08:00
ThreadFuture < Standalone < VectorRef < KeyRef > > > getRangeSplitPoints ( const KeyRangeRef & range ,
int64_t chunkSize ) override ;
2017-05-26 04:48:44 +08:00
2019-06-26 07:32:27 +08:00
void addReadConflictRange ( const KeyRangeRef & keys ) override ;
2017-05-26 04:48:44 +08:00
void makeSelfConflicting ( ) ;
2019-06-26 07:32:27 +08:00
void atomicOp ( const KeyRef & key , const ValueRef & value , uint32_t operationType ) override ;
void set ( const KeyRef & key , const ValueRef & value ) override ;
void clear ( const KeyRef & begin , const KeyRef & end ) override ;
void clear ( const KeyRangeRef & range ) override ;
void clear ( const KeyRef & key ) override ;
2017-05-26 04:48:44 +08:00
2019-06-26 07:32:27 +08:00
ThreadFuture < Void > watch ( const KeyRef & key ) override ;
2017-05-26 04:48:44 +08:00
2019-06-26 07:32:27 +08:00
void addWriteConflictRange ( const KeyRangeRef & keys ) override ;
2017-05-26 04:48:44 +08:00
2019-06-26 07:32:27 +08:00
ThreadFuture < Void > commit ( ) override ;
Version getCommittedVersion ( ) override ;
2019-06-29 01:15:37 +08:00
ThreadFuture < int64_t > getApproximateSize ( ) override ;
2017-05-26 04:48:44 +08:00
2020-12-14 21:34:09 +08:00
ThreadFuture < uint64_t > getProtocolVersion ( ) ;
2020-10-20 00:57:11 +08:00
2019-06-26 07:32:27 +08:00
void setOption ( FDBTransactionOptions : : Option option , Optional < StringRef > value = Optional < StringRef > ( ) ) override ;
2017-05-26 04:48:44 +08:00
ThreadFuture < Void > checkDeferredError ( ) ;
2019-06-26 07:32:27 +08:00
ThreadFuture < Void > onError ( Error const & e ) override ;
2017-05-26 04:48:44 +08:00
// These are to permit use as state variables in actors:
2020-09-21 02:33:09 +08:00
ThreadSafeTransaction ( ) : tr ( nullptr ) { }
2020-06-10 08:33:41 +08:00
void operator = ( ThreadSafeTransaction & & r ) noexcept ;
ThreadSafeTransaction ( ThreadSafeTransaction & & r ) noexcept ;
2017-05-26 04:48:44 +08:00
2019-06-26 07:32:27 +08:00
void reset ( ) override ;
2017-05-26 04:48:44 +08:00
2019-06-26 07:32:27 +08:00
void addref ( ) override { ThreadSafeReferenceCounted < ThreadSafeTransaction > : : addref ( ) ; }
void delref ( ) override { ThreadSafeReferenceCounted < ThreadSafeTransaction > : : delref ( ) ; }
2017-05-26 04:48:44 +08:00
private :
ReadYourWritesTransaction * tr ;
} ;
class ThreadSafeApi : public IClientApi , ThreadSafeReferenceCounted < ThreadSafeApi > {
public :
2021-01-26 09:55:43 +08:00
void selectApiVersion ( int apiVersion ) override ;
const char * getClientVersion ( ) override ;
2020-10-20 00:57:11 +08:00
ThreadFuture < uint64_t > getServerProtocol ( const char * clusterFilePath ) override ;
2017-05-26 04:48:44 +08:00
2021-01-26 09:55:43 +08:00
void setNetworkOption ( FDBNetworkOptions : : Option option , Optional < StringRef > value = Optional < StringRef > ( ) ) override ;
void setupNetwork ( ) override ;
void runNetwork ( ) override ;
void stopNetwork ( ) override ;
2017-05-26 04:48:44 +08:00
2021-01-26 09:55:43 +08:00
Reference < IDatabase > createDatabase ( const char * clusterFilePath ) override ;
2017-05-26 04:48:44 +08:00
2021-01-26 09:55:43 +08:00
void addNetworkThreadCompletionHook ( void ( * hook ) ( void * ) , void * hookParameter ) override ;
2018-05-09 07:33:43 +08:00
2017-05-26 04:48:44 +08:00
static IClientApi * api ;
private :
ThreadSafeApi ( ) ;
int apiVersion ;
const std : : string clientVersion ;
uint64_t transportId ;
2018-05-09 07:33:43 +08:00
Mutex lock ;
std : : vector < std : : pair < void ( * ) ( void * ) , void * > > threadCompletionHooks ;
2017-05-26 04:48:44 +08:00
} ;
# endif