func (s *Server) parseNode(cfg config.NodeConfig) (*backend.Node, error) { n := new(backend.Node) //n.server = s n.Cfg = cfg n.DownAfterNoAlive = time.Duration(cfg.DownAfterNoAlive) * time.Second if len(cfg.Master) == 0 { return nil, fmt.Errorf("must setting master MySQL node.") } var err error if n.Master, err = n.OpenDB(cfg.Master); err != nil { return nil, err } //n.db = n.Master if len(cfg.Slave) > 0 { if n.Slave, err = n.OpenDB(cfg.Slave); err != nil { golog.Error("ClientConn", "handleShowProxy", err.Error(), 0) n.Slave = nil } } go n.Run() return n, nil }
func (s *Server) parseNode(cfg config.NodeConfig) (*backend.Node, error) { var err error n := new(backend.Node) n.Cfg = cfg n.DownAfterNoAlive = time.Duration(cfg.DownAfterNoAlive) * time.Second err = n.ParseMaster(cfg.Master) if err != nil { return nil, err } err = n.ParseSlave(cfg.Slave) if err != nil { return nil, err } go n.CheckNode() return n, nil }