Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

delete from hostgroups and servicegroups is delayed of one minute #379

Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
5 changes: 3 additions & 2 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -41,15 +41,15 @@ with the Engine configuration file.
*core*

Unknown filters applied in the configuration file do not hang broker anymore.
Improve future usage

*log*

If a logger was at the 'off'/'disabled' state, then broker did not start.

*sql*

Hostgroups and servicegroups are no more deleted during an instance restart.
This could lead to issues when several pollers are restarted simultaneously.
Hostgroups and servicegroups are deleted 5s after the last instance restart.

Size of notes\_url, notes and action\_url columns are reviewed to match the
web configuration.
Expand All @@ -70,6 +70,7 @@ too much.
*lua*

New function `broker.bbdo_version()` implemented in broker streamconnector.
stream connector accepts empty parameters

### centreon-engine

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -199,6 +199,9 @@ class conflict_manager {
_metric_cache;
std::mutex _metric_cache_m;

std::mutex _group_clean_timer_m;
asio::system_timer _group_clean_timer;

std::unordered_set<uint32_t> _hostgroup_cache;
std::unordered_set<uint32_t> _servicegroup_cache;

Expand Down Expand Up @@ -333,6 +336,7 @@ class conflict_manager {
void _load_deleted_instances();
void _load_caches();
void _clean_tables(uint32_t instance_id);
void _clean_group_table();
void _prepare_hg_insupdate_statement();
void _prepare_sg_insupdate_statement();
void _finish_action(int32_t conn, uint32_t action);
Expand Down
5 changes: 5 additions & 0 deletions centreon-broker/storage/src/conflict_manager.cc
Original file line number Diff line number Diff line change
Expand Up @@ -87,6 +87,7 @@ conflict_manager::conflict_manager(database_config const& dbcfg,
_instance_timeout{instance_timeout},
_stats{stats::center::instance().register_conflict_manager()},
_ref_count{0},
_group_clean_timer{pool::io_context()},
_oldest_timestamp{std::numeric_limits<time_t>::max()} {
log_v2::sql()->debug("conflict_manager: class instanciation");
stats::center::instance().update(&ConflictManagerStats::set_loop_timeout,
Expand All @@ -98,6 +99,10 @@ conflict_manager::conflict_manager(database_config const& dbcfg,

conflict_manager::~conflict_manager() {
log_v2::sql()->debug("conflict_manager: destruction");
{
std::lock_guard<std::mutex> l(_group_clean_timer_m);
_group_clean_timer.cancel();
}
}

/**
Expand Down
35 changes: 35 additions & 0 deletions centreon-broker/storage/src/conflict_manager_sql.cc
Original file line number Diff line number Diff line change
Expand Up @@ -40,6 +40,12 @@ using namespace com::centreon::broker::storage;
* @param[in] instance_id Instance ID to remove.
*/
void conflict_manager::_clean_tables(uint32_t instance_id) {
// no hostgroup and servicegroup clean during this function
{
std::lock_guard<std::mutex> l(_group_clean_timer_m);
_group_clean_timer.cancel();
}

/* Database version. */

int32_t conn = _mysql.choose_connection_by_instance(instance_id);
Expand Down Expand Up @@ -167,6 +173,35 @@ void conflict_manager::_clean_tables(uint32_t instance_id) {
_mysql.run_query(query, database::mysql_error::clean_customvariables, false,
conn);
_add_action(conn, actions::custom_variables);

std::lock_guard<std::mutex> l(_group_clean_timer_m);
_group_clean_timer.expires_after(std::chrono::minutes(1));
_group_clean_timer.async_wait([this](const asio::error_code& err) {
if (!err) {
_clean_group_table();
}
});
}

void conflict_manager::_clean_group_table() {
int32_t conn = _mysql.choose_best_connection(-1);
/* Remove host groups. */
log_v2::sql()->debug("conflict_manager: remove empty host groups ");
_mysql.run_query(
"DELETE hg FROM hostgroups AS hg LEFT JOIN hosts_hostgroups AS hhg ON "
"hg.hostgroup_id=hhg.hostgroup_id WHERE hhg.hostgroup_id IS NULL",
database::mysql_error::clean_empty_hostgroups, false, conn);
_add_action(conn, actions::hostgroups);

/* Remove service groups. */
log_v2::sql()->debug("conflict_manager: remove empty service groups");

_mysql.run_query(
"DELETE sg FROM servicegroups AS sg LEFT JOIN services_servicegroups as "
"ssg ON sg.servicegroup_id=ssg.servicegroup_id WHERE ssg.servicegroup_id "
"IS NULL",
database::mysql_error::clean_empty_servicegroups, false, conn);
_add_action(conn, actions::servicegroups);
}

/**
Expand Down
56 changes: 56 additions & 0 deletions tests/broker-engine/hostgroups.robot
Original file line number Diff line number Diff line change
Expand Up @@ -90,3 +90,59 @@ EBNHG4

Stop Engine
Kindly Stop Broker


EBNHG5
[Documentation] New host group with several pollers and connections to DB with broker and delete this hostgroup
[Tags] Broker Engine hostgroup
Config Engine ${3}
Config Broker rrd
Config Broker central
Config Broker module ${3}

Broker Config Log central sql info
Broker Config Output Set central central-broker-master-sql connections_count 5
Broker Config Output Set central central-broker-master-perfdata connections_count 5
${start}= Get Current Date
Start Broker
Start Engine
Sleep 3s
Add Host Group ${0} ${1} ["host_1", "host_2", "host_3"]

Reload Broker
Reload Engine

${content}= Create List enabling membership of host 3 to host group 1 on instance 1 enabling membership of host 2 to host group 1

${result}= Find In Log With Timeout ${centralLog} ${start} ${content} 45
Should Be True ${result} msg=One of the new host groups not found in logs.

Sleep 10s
${start}= Get Current Date

Config Engine ${3}
Reload Broker
Reload Engine

Connect To Database pymysql ${DBName} ${DBUser} ${DBPass} ${DBHost} ${DBPort}
Sleep 5s
FOR ${index} IN RANGE 10
Log To Console SELECT count(*) FROM hosts_hostgroups
${output}= Query SELECT count(*) FROM hosts_hostgroups
Log To Console ${output}
Sleep 1s
EXIT FOR LOOP IF "${output}" == "((0,),)"
END
Should Be Equal As Strings ${output} ((0,),)

FOR ${index} IN RANGE 60
Log To Console SELECT count(*) FROM hostgroups
${output}= Query SELECT count(*) FROM hostgroups
Log To Console ${output}
Sleep 1s
EXIT FOR LOOP IF "${output}" == "((0,),)"
END
Should Be Equal As Strings ${output} ((0,),)

Stop Engine
Kindly Stop Broker
5 changes: 2 additions & 3 deletions tests/resources/Broker.py
Original file line number Diff line number Diff line change
Expand Up @@ -14,8 +14,6 @@
import glob
import os.path
import grpc
import broker_pb2
import broker_pb2_grpc
from google.protobuf import empty_pb2
from robot.libraries.BuiltIn import BuiltIn

Expand Down Expand Up @@ -441,7 +439,8 @@ def config_broker(name, poller_inst: int = 1):
f.close()
else:
f = open("/etc/centreon-broker/{}".format(filename), "w")
f.write(config[name].format(broker_id, broker_name, DB_HOST, DB_PORT, DB_USER, DB_PASS, DB_NAME_STORAGE))
f.write(config[name].format(broker_id, broker_name,
DB_HOST, DB_PORT, DB_USER, DB_PASS, DB_NAME_STORAGE))
f.close()


Expand Down
4 changes: 2 additions & 2 deletions tests/resources/Engine.py
Original file line number Diff line number Diff line change
Expand Up @@ -10,8 +10,6 @@
import stat

import grpc
import engine_pb2
import engine_pb2_grpc


CONF_DIR = "/etc/centreon-engine"
Expand Down Expand Up @@ -1082,6 +1080,7 @@ def schedule_service_downtime(hst: str, svc: str, duration: int):
f.write(cmd)
f.close()


def schedule_host_downtime(poller: int, hst: str, duration: int):
now = int(time.time())
cmd1 = "[{1}] SCHEDULE_HOST_DOWNTIME;{0};{1};{2};1;0;{3};admin;Downtime set by admin\n".format(
Expand All @@ -1093,6 +1092,7 @@ def schedule_host_downtime(poller: int, hst: str, duration: int):
f.write(cmd2)
f.close()


def delete_host_downtimes(poller: int, hst: str):
now = int(time.time())
cmd = "[{}] DEL_HOST_DOWNTIME_FULL;{};;;;;;;;\n".format(now, hst)
Expand Down