mirror of
https://github.com/cgrates/cgrates.git
synced 2026-02-12 18:46:24 +05:00
148 lines
4.4 KiB
Go
148 lines
4.4 KiB
Go
/*
|
|
Real-time Online/Offline Charging System (OCS) for Telecom & ISP environments
|
|
Copyright (C) ITsysCOM GmbH
|
|
|
|
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
|
|
the Free Software Foundation, either version 3 of the License, or
|
|
(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
|
|
along with this program. If not, see <http://www.gnu.org/licenses/>
|
|
*/
|
|
package main
|
|
|
|
import (
|
|
"fmt"
|
|
"net/rpc"
|
|
"os"
|
|
"os/signal"
|
|
"syscall"
|
|
|
|
"github.com/cgrates/cgrates/balancer2go"
|
|
"github.com/cgrates/cgrates/engine"
|
|
"github.com/cgrates/cgrates/scheduler"
|
|
"github.com/cgrates/cgrates/utils"
|
|
"github.com/cgrates/rpcclient"
|
|
)
|
|
|
|
/*
|
|
Listens for SIGTERM, SIGINT, SIGQUIT system signals and shuts down all the registered engines.
|
|
*/
|
|
func stopBalancerSignalHandler(bal *balancer2go.Balancer, exitChan chan bool) {
|
|
c := make(chan os.Signal)
|
|
signal.Notify(c, syscall.SIGTERM, syscall.SIGINT, syscall.SIGQUIT)
|
|
sig := <-c
|
|
utils.Logger.Info(fmt.Sprintf("Caught signal %v, sending shutdown to engines\n", sig))
|
|
bal.Shutdown("Responder.Shutdown")
|
|
exitChan <- true
|
|
}
|
|
|
|
func generalSignalHandler(internalCdrStatSChan chan rpcclient.RpcClientConnection, exitChan chan bool) {
|
|
c := make(chan os.Signal)
|
|
signal.Notify(c, syscall.SIGTERM, syscall.SIGINT, syscall.SIGQUIT)
|
|
|
|
sig := <-c
|
|
utils.Logger.Info(fmt.Sprintf("Caught signal %v, shuting down cgr-engine\n", sig))
|
|
var dummyInt int
|
|
select {
|
|
case cdrStats := <-internalCdrStatSChan:
|
|
cdrStats.Call("CDRStatsV1.Stop", dummyInt, &dummyInt)
|
|
default:
|
|
}
|
|
|
|
exitChan <- true
|
|
}
|
|
|
|
/*
|
|
Listens for the SIGTERM, SIGINT, SIGQUIT system signals and gracefuly unregister from balancer and closes the storage before exiting.
|
|
*/
|
|
func stopRaterSignalHandler(internalCdrStatSChan chan rpcclient.RpcClientConnection, exitChan chan bool) {
|
|
c := make(chan os.Signal)
|
|
signal.Notify(c, syscall.SIGTERM, syscall.SIGINT, syscall.SIGQUIT)
|
|
sig := <-c
|
|
|
|
utils.Logger.Info(fmt.Sprintf("Caught signal %v, unregistering from balancer\n", sig))
|
|
unregisterFromBalancer(exitChan)
|
|
var dummyInt int
|
|
select {
|
|
case cdrStats := <-internalCdrStatSChan:
|
|
cdrStats.Call("CDRStatsV1.Stop", dummyInt, &dummyInt)
|
|
default:
|
|
}
|
|
exitChan <- true
|
|
}
|
|
|
|
/*
|
|
Connects to the balancer and calls unregister RPC method.
|
|
*/
|
|
func unregisterFromBalancer(exitChan chan bool) {
|
|
client, err := rpc.Dial("tcp", cfg.RALsBalancer)
|
|
if err != nil {
|
|
utils.Logger.Crit("Cannot contact the balancer!")
|
|
exitChan <- true
|
|
return
|
|
}
|
|
var reply int
|
|
utils.Logger.Info(fmt.Sprintf("Unregistering from balancer %s", cfg.RALsBalancer))
|
|
client.Call("Responder.UnRegisterRater", cfg.RPCGOBListen, &reply)
|
|
if err := client.Close(); err != nil {
|
|
utils.Logger.Crit("Could not close balancer unregistration!")
|
|
exitChan <- true
|
|
}
|
|
}
|
|
|
|
/*
|
|
Connects to the balancer and rehisters the engine to the server.
|
|
*/
|
|
func registerToBalancer(exitChan chan bool) {
|
|
client, err := rpc.Dial("tcp", cfg.RALsBalancer)
|
|
if err != nil {
|
|
utils.Logger.Crit(fmt.Sprintf("Cannot contact the balancer: %v", err))
|
|
exitChan <- true
|
|
return
|
|
}
|
|
var reply int
|
|
utils.Logger.Info(fmt.Sprintf("Registering to balancer %s", cfg.RALsBalancer))
|
|
client.Call("Responder.RegisterRater", cfg.RPCGOBListen, &reply)
|
|
if err := client.Close(); err != nil {
|
|
utils.Logger.Crit("Could not close balancer registration!")
|
|
exitChan <- true
|
|
}
|
|
utils.Logger.Info("Registration finished!")
|
|
}
|
|
|
|
// Listens for the HUP system signal and gracefuly reloads the timers from database.
|
|
func reloadSchedulerSingnalHandler(sched *scheduler.Scheduler, getter engine.RatingStorage) {
|
|
for {
|
|
c := make(chan os.Signal)
|
|
signal.Notify(c, syscall.SIGHUP)
|
|
sig := <-c
|
|
|
|
utils.Logger.Info(fmt.Sprintf("Caught signal %v, reloading action timings.\n", sig))
|
|
sched.Reload(true)
|
|
}
|
|
}
|
|
|
|
/*
|
|
Listens for the SIGTERM, SIGINT, SIGQUIT system signals and shuts down the session manager.
|
|
*/
|
|
func shutdownSessionmanagerSingnalHandler(exitChan chan bool) {
|
|
c := make(chan os.Signal)
|
|
signal.Notify(c, syscall.SIGHUP, syscall.SIGTERM, syscall.SIGINT, syscall.SIGQUIT)
|
|
<-c
|
|
if smRpc != nil {
|
|
for _, sm := range smRpc.SMs {
|
|
if err := sm.Shutdown(); err != nil {
|
|
utils.Logger.Warning(fmt.Sprintf("<SessionManager> %s", err))
|
|
}
|
|
}
|
|
}
|
|
exitChan <- true
|
|
}
|