2007-06-04 13:53:19 +04:00
/*
ctdb tunables code
Copyright ( C ) Andrew Tridgell 2007
This program is free software ; you can redistribute it and / or modify
it under the terms of the GNU General Public License as published by
2007-07-10 09:29:31 +04:00
the Free Software Foundation ; either version 3 of the License , or
2007-06-04 13:53:19 +04:00
( at your option ) any later version .
This program is distributed in the hope that it will be useful ,
but WITHOUT ANY WARRANTY ; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE . See the
GNU General Public License for more details .
You should have received a copy of the GNU General Public License
2007-07-10 09:29:31 +04:00
along with this program ; if not , see < http : //www.gnu.org/licenses/>.
2007-06-04 13:53:19 +04:00
*/
# include "includes.h"
# include "../include/ctdb_private.h"
static const struct {
const char * name ;
2007-06-04 14:22:44 +04:00
uint32_t default_v ;
2011-12-22 15:46:04 +04:00
size_t offset ;
bool obsolete ;
2007-06-04 13:53:19 +04:00
} tunable_map [ ] = {
2011-12-22 15:46:04 +04:00
{ " MaxRedirectCount " , 3 , offsetof ( struct ctdb_tunable , max_redirect_count ) , false } ,
{ " SeqnumInterval " , 1000 , offsetof ( struct ctdb_tunable , seqnum_interval ) , false } ,
{ " ControlTimeout " , 60 , offsetof ( struct ctdb_tunable , control_timeout ) , false } ,
{ " TraverseTimeout " , 20 , offsetof ( struct ctdb_tunable , traverse_timeout ) , false } ,
{ " KeepaliveInterval " , 5 , offsetof ( struct ctdb_tunable , keepalive_interval ) , false } ,
{ " KeepaliveLimit " , 5 , offsetof ( struct ctdb_tunable , keepalive_limit ) , false } ,
2012-05-25 06:31:11 +04:00
{ " RecoverTimeout " , 120 , offsetof ( struct ctdb_tunable , recover_timeout ) , false } ,
2011-12-22 15:46:04 +04:00
{ " RecoverInterval " , 1 , offsetof ( struct ctdb_tunable , recover_interval ) , false } ,
{ " ElectionTimeout " , 3 , offsetof ( struct ctdb_tunable , election_timeout ) , false } ,
{ " TakeoverTimeout " , 9 , offsetof ( struct ctdb_tunable , takeover_timeout ) , false } ,
{ " MonitorInterval " , 15 , offsetof ( struct ctdb_tunable , monitor_interval ) , false } ,
{ " TickleUpdateInterval " , 20 , offsetof ( struct ctdb_tunable , tickle_update_interval ) , false } ,
{ " EventScriptTimeout " , 30 , offsetof ( struct ctdb_tunable , script_timeout ) , false } ,
2012-05-17 04:17:51 +04:00
{ " EventScriptTimeoutCount " , 20 , offsetof ( struct ctdb_tunable , script_timeout_count ) , false } ,
2011-12-22 15:46:04 +04:00
{ " EventScriptUnhealthyOnTimeout " , 0 , offsetof ( struct ctdb_tunable , script_unhealthy_on_timeout ) , true } ,
{ " RecoveryGracePeriod " , 120 , offsetof ( struct ctdb_tunable , recovery_grace_period ) , false } ,
{ " RecoveryBanPeriod " , 300 , offsetof ( struct ctdb_tunable , recovery_ban_period ) , false } ,
{ " DatabaseHashSize " , 100001 , offsetof ( struct ctdb_tunable , database_hash_size ) , false } ,
{ " DatabaseMaxDead " , 5 , offsetof ( struct ctdb_tunable , database_max_dead ) , false } ,
{ " RerecoveryTimeout " , 10 , offsetof ( struct ctdb_tunable , rerecovery_timeout ) , false } ,
{ " EnableBans " , 1 , offsetof ( struct ctdb_tunable , enable_bans ) , false } ,
{ " DeterministicIPs " , 0 , offsetof ( struct ctdb_tunable , deterministic_public_ips ) , false } ,
{ " LCP2PublicIPs " , 1 , offsetof ( struct ctdb_tunable , lcp2_public_ip_assignment ) , false } ,
{ " ReclockPingPeriod " , 60 , offsetof ( struct ctdb_tunable , reclock_ping_period ) , false } ,
{ " NoIPFailback " , 0 , offsetof ( struct ctdb_tunable , no_ip_failback ) , false } ,
{ " DisableIPFailover " , 0 , offsetof ( struct ctdb_tunable , disable_ip_failover ) , false } ,
{ " VerboseMemoryNames " , 0 , offsetof ( struct ctdb_tunable , verbose_memory_names ) , false } ,
{ " RecdPingTimeout " , 60 , offsetof ( struct ctdb_tunable , recd_ping_timeout ) , false } ,
{ " RecdFailCount " , 10 , offsetof ( struct ctdb_tunable , recd_ping_failcount ) , false } ,
{ " LogLatencyMs " , 0 , offsetof ( struct ctdb_tunable , log_latency_ms ) , false } ,
{ " RecLockLatencyMs " , 1000 , offsetof ( struct ctdb_tunable , reclock_latency_ms ) , false } ,
{ " RecoveryDropAllIPs " , 120 , offsetof ( struct ctdb_tunable , recovery_drop_all_ips ) , false } ,
{ " VerifyRecoveryLock " , 1 , offsetof ( struct ctdb_tunable , verify_recovery_lock ) , false } ,
{ " VacuumInterval " , 10 , offsetof ( struct ctdb_tunable , vacuum_interval ) , false } ,
2012-02-29 05:29:22 +04:00
{ " VacuumMaxRunTime " , 120 , offsetof ( struct ctdb_tunable , vacuum_max_run_time ) , false } ,
2011-12-22 15:46:04 +04:00
{ " RepackLimit " , 10000 , offsetof ( struct ctdb_tunable , repack_limit ) , false } ,
{ " VacuumLimit " , 5000 , offsetof ( struct ctdb_tunable , vacuum_limit ) , false } ,
{ " VacuumFastPathCount " , 60 , offsetof ( struct ctdb_tunable , vacuum_fast_path_count ) , false } ,
{ " MaxQueueDropMsg " , 1000000 , offsetof ( struct ctdb_tunable , max_queue_depth_drop_msg ) , false } ,
{ " UseStatusEvents " , 0 , offsetof ( struct ctdb_tunable , use_status_events_for_monitoring ) , false } ,
{ " AllowUnhealthyDBRead " , 0 , offsetof ( struct ctdb_tunable , allow_unhealthy_db_read ) , false } ,
{ " StatHistoryInterval " , 1 , offsetof ( struct ctdb_tunable , stat_history_interval ) , false } ,
{ " DeferredAttachTO " , 120 , offsetof ( struct ctdb_tunable , deferred_attach_timeout ) , false } ,
{ " AllowClientDBAttach " , 1 , offsetof ( struct ctdb_tunable , allow_client_db_attach ) , false } ,
2013-10-28 11:49:51 +04:00
{ " RecoverPDBBySeqNum " , 1 , offsetof ( struct ctdb_tunable , recover_pdb_by_seqnum ) , false } ,
2012-03-20 04:31:59 +04:00
{ " DeferredRebalanceOnNodeAdd " , 300 , offsetof ( struct ctdb_tunable , deferred_rebalance_on_node_add ) } ,
2012-03-20 05:20:55 +04:00
{ " FetchCollapse " , 1 , offsetof ( struct ctdb_tunable , fetch_collapse ) } ,
2012-03-20 09:58:35 +04:00
{ " HopcountMakeSticky " , 50 , offsetof ( struct ctdb_tunable , hopcount_make_sticky ) } ,
{ " StickyDuration " , 600 , offsetof ( struct ctdb_tunable , sticky_duration ) } ,
2012-03-22 04:00:27 +04:00
{ " StickyPindown " , 200 , offsetof ( struct ctdb_tunable , sticky_pindown ) } ,
2012-05-21 07:11:38 +04:00
{ " NoIPTakeover " , 0 , offsetof ( struct ctdb_tunable , no_ip_takeover ) , false } ,
{ " DBRecordCountWarn " , 100000 , offsetof ( struct ctdb_tunable , db_record_count_warn ) , false } ,
{ " DBRecordSizeWarn " , 10000000 , offsetof ( struct ctdb_tunable , db_record_size_warn ) , false } ,
2012-05-25 06:27:59 +04:00
{ " DBSizeWarn " , 100000000 , offsetof ( struct ctdb_tunable , db_size_warn ) , false } ,
2013-02-11 06:23:47 +04:00
{ " PullDBPreallocation " , 10 * 1024 * 1024 , offsetof ( struct ctdb_tunable , pulldb_preallocation_size ) , false } ,
2013-05-03 10:59:20 +04:00
{ " NoIPHostOnAllDisabled " , 0 , offsetof ( struct ctdb_tunable , no_ip_host_on_all_disabled ) , false } ,
2013-01-04 07:32:55 +04:00
{ " Samba3AvoidDeadlocks " , 0 , offsetof ( struct ctdb_tunable , samba3_hack ) , false } ,
2013-11-10 17:32:31 +04:00
{ " TDBMutexEnabled " , 0 , offsetof ( struct ctdb_tunable , mutex_enabled ) , false } ,
2014-07-15 10:41:31 +04:00
{ " LockProcessesPerDB " , 200 , offsetof ( struct ctdb_tunable , lock_processes_per_db ) , false } ,
2007-06-04 13:53:19 +04:00
} ;
2007-06-04 14:22:44 +04:00
/*
set all tunables to defaults
*/
void ctdb_tunables_set_defaults ( struct ctdb_context * ctdb )
{
int i ;
for ( i = 0 ; i < ARRAY_SIZE ( tunable_map ) ; i + + ) {
* ( uint32_t * ) ( tunable_map [ i ] . offset + ( uint8_t * ) & ctdb - > tunable ) = tunable_map [ i ] . default_v ;
}
}
2007-06-04 13:53:19 +04:00
/*
get a tunable
*/
int32_t ctdb_control_get_tunable ( struct ctdb_context * ctdb , TDB_DATA indata ,
TDB_DATA * outdata )
{
struct ctdb_control_get_tunable * t =
( struct ctdb_control_get_tunable * ) indata . dptr ;
char * name ;
uint32_t val ;
int i ;
if ( indata . dsize < sizeof ( * t ) | |
t - > length > indata . dsize - offsetof ( struct ctdb_control_get_tunable , name ) ) {
2008-02-04 12:07:15 +03:00
DEBUG ( DEBUG_ERR , ( " Bad indata in ctdb_control_get_tunable \n " ) ) ;
2007-06-04 13:53:19 +04:00
return - 1 ;
}
name = talloc_strndup ( ctdb , ( char * ) t - > name , t - > length ) ;
CTDB_NO_MEMORY ( ctdb , name ) ;
for ( i = 0 ; i < ARRAY_SIZE ( tunable_map ) ; i + + ) {
if ( strcasecmp ( name , tunable_map [ i ] . name ) = = 0 ) break ;
}
talloc_free ( name ) ;
if ( i = = ARRAY_SIZE ( tunable_map ) ) {
2013-05-21 09:41:56 +04:00
return - EINVAL ;
2007-06-04 13:53:19 +04:00
}
val = * ( uint32_t * ) ( tunable_map [ i ] . offset + ( uint8_t * ) & ctdb - > tunable ) ;
outdata - > dptr = ( uint8_t * ) talloc ( outdata , uint32_t ) ;
CTDB_NO_MEMORY ( ctdb , outdata - > dptr ) ;
* ( uint32_t * ) outdata - > dptr = val ;
outdata - > dsize = sizeof ( uint32_t ) ;
return 0 ;
}
/*
set a tunable
*/
int32_t ctdb_control_set_tunable ( struct ctdb_context * ctdb , TDB_DATA indata )
{
struct ctdb_control_set_tunable * t =
( struct ctdb_control_set_tunable * ) indata . dptr ;
char * name ;
int i ;
if ( indata . dsize < sizeof ( * t ) | |
t - > length > indata . dsize - offsetof ( struct ctdb_control_set_tunable , name ) ) {
2008-02-04 12:07:15 +03:00
DEBUG ( DEBUG_ERR , ( " Bad indata in ctdb_control_set_tunable \n " ) ) ;
2007-06-04 13:53:19 +04:00
return - 1 ;
}
name = talloc_strndup ( ctdb , ( char * ) t - > name , t - > length ) ;
CTDB_NO_MEMORY ( ctdb , name ) ;
for ( i = 0 ; i < ARRAY_SIZE ( tunable_map ) ; i + + ) {
if ( strcasecmp ( name , tunable_map [ i ] . name ) = = 0 ) break ;
}
2009-06-25 08:45:17 +04:00
if ( ! strcmp ( name , " VerifyRecoveryLock " ) & & t - > value ! = 0
& & ctdb - > recovery_lock_file = = NULL ) {
DEBUG ( DEBUG_ERR , ( " Can not activate tunable \" VerifyRecoveryLock \" since there is no recovery lock file set. \n " ) ) ;
talloc_free ( name ) ;
return - 1 ;
}
2007-06-04 13:53:19 +04:00
talloc_free ( name ) ;
if ( i = = ARRAY_SIZE ( tunable_map ) ) {
return - 1 ;
}
2009-06-25 08:45:17 +04:00
2007-06-04 13:53:19 +04:00
* ( uint32_t * ) ( tunable_map [ i ] . offset + ( uint8_t * ) & ctdb - > tunable ) = t - > value ;
return 0 ;
}
/*
list tunables
*/
int32_t ctdb_control_list_tunables ( struct ctdb_context * ctdb , TDB_DATA * outdata )
{
char * list = NULL ;
int i ;
struct ctdb_control_list_tunable * t ;
list = talloc_strdup ( outdata , tunable_map [ 0 ] . name ) ;
CTDB_NO_MEMORY ( ctdb , list ) ;
for ( i = 1 ; i < ARRAY_SIZE ( tunable_map ) ; i + + ) {
2011-12-22 15:52:55 +04:00
if ( tunable_map [ i ] . obsolete ) {
continue ;
}
2007-06-04 13:53:19 +04:00
list = talloc_asprintf_append ( list , " :%s " , tunable_map [ i ] . name ) ;
CTDB_NO_MEMORY ( ctdb , list ) ;
}
outdata - > dsize = offsetof ( struct ctdb_control_list_tunable , data ) +
strlen ( list ) + 1 ;
outdata - > dptr = talloc_size ( outdata , outdata - > dsize ) ;
CTDB_NO_MEMORY ( ctdb , outdata - > dptr ) ;
t = ( struct ctdb_control_list_tunable * ) outdata - > dptr ;
t - > length = strlen ( list ) + 1 ;
memcpy ( t - > data , list , t - > length ) ;
talloc_free ( list ) ;
return 0 ;
}