changed logic
This commit is contained in:
parent
ebe48565b3
commit
b4d709693c
|
@ -9,6 +9,8 @@ import (
|
|||
|
||||
|
||||
"strings"
|
||||
"loafle.com/overflow/agent_api/config_manager"
|
||||
"encoding/json"
|
||||
)
|
||||
|
||||
|
||||
|
@ -41,6 +43,49 @@ func callAdd(container *string, crawlerName *string, id *string) bool {
|
|||
}
|
||||
|
||||
|
||||
func callInitConfig(container *string, cl []*config_manager.Config) bool {
|
||||
|
||||
port := GetInstance().portMap[*container]
|
||||
|
||||
conn, err := grpc.Dial(address+port, grpc.WithInsecure())
|
||||
if err != nil {
|
||||
log.Fatalf("did not connect: %v", err)
|
||||
return false
|
||||
}
|
||||
defer conn.Close()
|
||||
|
||||
cc := g.NewConfigClient(conn)
|
||||
|
||||
inArr := &g.InputArray{}
|
||||
|
||||
for _, conf := range cl {
|
||||
|
||||
in := &g.Init{}
|
||||
in.Name = g.Crawlers(g.Crawlers_value[conf.Crawler.Name])
|
||||
|
||||
b, err := json.Marshal(conf)
|
||||
if err != nil {
|
||||
continue
|
||||
}
|
||||
|
||||
in.Path = string(b)
|
||||
|
||||
inArr.In = append(inArr.In, in)
|
||||
}
|
||||
|
||||
|
||||
outInit, errInit := cc.Init(context.Background(), inArr)
|
||||
if errInit != nil {
|
||||
log.Println(errInit)
|
||||
return false
|
||||
}
|
||||
log.Println("callInit:",outInit)
|
||||
|
||||
return true
|
||||
|
||||
}
|
||||
|
||||
|
||||
func callInit(container *string, paths *[]string) bool {
|
||||
|
||||
port := GetInstance().portMap[*container]
|
||||
|
@ -48,6 +93,9 @@ func callInit(container *string, paths *[]string) bool {
|
|||
return callInitAddress(address + port, paths)
|
||||
}
|
||||
|
||||
|
||||
|
||||
|
||||
func callInitAddress(address string, paths *[]string) bool {
|
||||
conn, err := grpc.Dial(address, grpc.WithInsecure())
|
||||
if err != nil {
|
||||
|
|
|
@ -1,8 +1,8 @@
|
|||
package crawler_manager
|
||||
|
||||
import (
|
||||
"loafle.com/overflow/crawler_go/config"
|
||||
"encoding/json"
|
||||
//"loafle.com/overflow/crawler_go/config"
|
||||
//"encoding/json"
|
||||
"io/ioutil"
|
||||
"google.golang.org/grpc"
|
||||
"strconv"
|
||||
|
@ -12,8 +12,9 @@ import (
|
|||
"log"
|
||||
|
||||
|
||||
"path/filepath"
|
||||
|
||||
"errors"
|
||||
"loafle.com/overflow/agent_api/config_manager"
|
||||
)
|
||||
|
||||
const (
|
||||
|
@ -22,7 +23,7 @@ const (
|
|||
defaultPort = 50000
|
||||
|
||||
rootFolder = "/home/cm2/"
|
||||
ConfigFolder = rootFolder + "/config/container/" // +container
|
||||
ConfigFolder = rootFolder + "/config/container/"
|
||||
BinaryFolder = rootFolder + "/container/"
|
||||
PidFolder = rootFolder + "/pids/"
|
||||
runFile = "ttnc"
|
||||
|
@ -34,23 +35,34 @@ type CrawlerManager struct {
|
|||
currentPort int
|
||||
portMap map[string]string
|
||||
pidMap map[string]string
|
||||
ConfigMgr config_manager.ConfigManager
|
||||
}
|
||||
|
||||
func init() {
|
||||
|
||||
GetInstance();
|
||||
|
||||
listenEvent()
|
||||
|
||||
//g_CrawlerMananger.init()
|
||||
}
|
||||
|
||||
func GetInstance() *CrawlerManager {
|
||||
|
||||
if g_CrawlerMananger == nil {
|
||||
g_CrawlerMananger = &CrawlerManager{portMap:make(map[string]string),pidMap:make(map[string]string), currentPort:defaultPort}
|
||||
}
|
||||
|
||||
g_CrawlerMananger.init()
|
||||
return g_CrawlerMananger;
|
||||
}
|
||||
|
||||
|
||||
func (c *CrawlerManager)GetClient(container string) (*grpc.ClientConn, error) {
|
||||
|
||||
b := c.checkContainer(&container)
|
||||
|
||||
if b == false {
|
||||
err := c.runAndInitContainer(&container)
|
||||
err := c.runAndInitContainerOne(&container)
|
||||
if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
|
@ -60,66 +72,23 @@ func (c *CrawlerManager)GetClient(container string) (*grpc.ClientConn, error) {
|
|||
return grpc.Dial(address+gport, grpc.WithInsecure())
|
||||
}
|
||||
|
||||
func GetInstance() *CrawlerManager {
|
||||
return g_CrawlerMananger;
|
||||
}
|
||||
|
||||
|
||||
|
||||
func readConfig(path string ) *config.Config {
|
||||
|
||||
bytes, err := ioutil.ReadFile(path)
|
||||
|
||||
if err != nil {
|
||||
return nil
|
||||
}
|
||||
|
||||
cc := config.Config{}
|
||||
|
||||
json.Unmarshal(bytes, &cc)
|
||||
|
||||
return &cc
|
||||
}
|
||||
|
||||
|
||||
|
||||
func (c *CrawlerManager)init() {
|
||||
|
||||
c.checkPid()
|
||||
|
||||
cs := c.isStartContainer()
|
||||
|
||||
for _, cc := range cs {
|
||||
|
||||
err := c.runAndInitContainer(&cc)
|
||||
|
||||
if err != nil {
|
||||
log.Println(err)
|
||||
continue
|
||||
}
|
||||
cmap := c.ConfigMgr.GetCrawlers()
|
||||
scm := sortContainer(cmap)
|
||||
|
||||
for ctn := range scm {
|
||||
c.runAndInitContainer(&ctn, scm[ctn])
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
func (c *CrawlerManager)isStartContainer() []string {
|
||||
|
||||
files, _ := ioutil.ReadDir(ConfigFolder)
|
||||
|
||||
var cs []string
|
||||
|
||||
for _,file := range files {
|
||||
|
||||
if file.IsDir() {
|
||||
b := existConfigFile(ConfigFolder, file.Name())
|
||||
if b {
|
||||
cs = append(cs, file.Name())
|
||||
}
|
||||
}
|
||||
|
||||
}
|
||||
return cs
|
||||
}
|
||||
|
||||
func (c *CrawlerManager)checkContainer(container *string) bool {
|
||||
return callStatus(container)
|
||||
|
@ -150,8 +119,7 @@ func (c *CrawlerManager)checkPid() {
|
|||
|
||||
}
|
||||
|
||||
|
||||
func (c *CrawlerManager)runAndInitContainer(container *string) error {
|
||||
func (c *CrawlerManager)runAndInitContainerOne(container *string) error {
|
||||
|
||||
err := c.runContainer(container)
|
||||
|
||||
|
@ -159,12 +127,30 @@ func (c *CrawlerManager)runAndInitContainer(container *string) error {
|
|||
return err
|
||||
}
|
||||
|
||||
dirs := getConfigPaths(container)
|
||||
cmap := c.ConfigMgr.GetCrawlers()
|
||||
scm := sortContainer(cmap)
|
||||
|
||||
if dirs == nil {
|
||||
return errors.New("not found config")
|
||||
b := callInitConfig(container, scm[*container])
|
||||
|
||||
if b == false {
|
||||
return errors.New("call init failed")
|
||||
}
|
||||
b := callInit(container, dirs)
|
||||
|
||||
return nil
|
||||
|
||||
}
|
||||
|
||||
|
||||
func (c *CrawlerManager)runAndInitContainer(container *string,cl []*config_manager.Config) error {
|
||||
|
||||
err := c.runContainer(container)
|
||||
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
|
||||
b := callInitConfig(container, cl)
|
||||
|
||||
if b == false {
|
||||
return errors.New("call init failed")
|
||||
}
|
||||
|
@ -173,6 +159,20 @@ func (c *CrawlerManager)runAndInitContainer(container *string) error {
|
|||
return nil
|
||||
}
|
||||
|
||||
func sortContainer(cm map[string]*config_manager.Config) map[string][]*config_manager.Config {
|
||||
|
||||
m := make(map[string][]*config_manager.Config)
|
||||
|
||||
var cn string;
|
||||
for key := range cm {
|
||||
cn = cm[key].Crawler.Container
|
||||
m[cn] = append(m[cn], cm[key])
|
||||
}
|
||||
|
||||
return m
|
||||
}
|
||||
|
||||
|
||||
func (c *CrawlerManager)runContainer(container *string) error {
|
||||
|
||||
b := c.checkContainer(container)
|
||||
|
@ -264,23 +264,3 @@ func (c *CrawlerManager)removeProcessFile(pid *string) {
|
|||
log.Println(err)
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
func (c *CrawlerManager)activeCrawler(container *string) []string {
|
||||
|
||||
var dirs []string
|
||||
existConfigFileDir(ConfigFolder,*container,&dirs)
|
||||
|
||||
if len(dirs) <= 0 {
|
||||
return nil
|
||||
}
|
||||
|
||||
var r []string
|
||||
for _, path := range dirs {
|
||||
r = append(r, filepath.Base(path))
|
||||
}
|
||||
|
||||
return r
|
||||
|
||||
}
|
||||
|
||||
|
|
45
crawler_manager_event.go
Normal file
45
crawler_manager_event.go
Normal file
|
@ -0,0 +1,45 @@
|
|||
package crawler_manager
|
||||
|
||||
import (
|
||||
"loafle.com/overflow/agent_api/observer"
|
||||
"loafle.com/overflow/agent_api/config_manager"
|
||||
"loafle.com/overflow/agent_api/observer/messages"
|
||||
|
||||
"fmt"
|
||||
)
|
||||
|
||||
|
||||
func listenEvent() {
|
||||
|
||||
go listenConfigLoaded();
|
||||
go listenAddSensor();
|
||||
|
||||
}
|
||||
|
||||
func listenConfigLoaded() {
|
||||
|
||||
ch := make(chan interface{}, 0)
|
||||
observer.Add(messages.CONFIGMANAGER_LOADED, ch)
|
||||
|
||||
o := <-ch
|
||||
|
||||
cm := o.(config_manager.ConfigManager)
|
||||
|
||||
GetInstance().ConfigMgr = cm;
|
||||
|
||||
GetInstance().init();
|
||||
|
||||
}
|
||||
|
||||
func listenAddSensor() {
|
||||
ch := make(chan interface{}, 0)
|
||||
observer.Add(messages.ADD_SENSOR_1, ch);
|
||||
|
||||
o := <-ch
|
||||
|
||||
str := o.(string)
|
||||
|
||||
fmt.Println(str)
|
||||
//GetInstance().Addconfig(str)
|
||||
}
|
||||
|
|
@ -12,7 +12,9 @@ import (
|
|||
"strings"
|
||||
"io/ioutil"
|
||||
|
||||
|
||||
"loafle.com/overflow/agent_api/config_manager"
|
||||
"encoding/json"
|
||||
"fmt"
|
||||
)
|
||||
|
||||
|
||||
|
@ -218,39 +220,39 @@ func TestInitCM(t *testing.T) {
|
|||
}
|
||||
|
||||
func TestCallStatus(t *testing.T) {
|
||||
c := "java"
|
||||
GetInstance().runAndInitContainer(&c)
|
||||
|
||||
callStatus(&c)
|
||||
|
||||
GetInstance().stopContainer(&c)
|
||||
//c := "java"
|
||||
//GetInstance().runAndInitContainer(&c)
|
||||
//
|
||||
//callStatus(&c)
|
||||
//
|
||||
//GetInstance().stopContainer(&c)
|
||||
}
|
||||
|
||||
func TestCallAdd(t *testing.T) {
|
||||
////
|
||||
//c := "java"
|
||||
//cn := "HEALTH_"+"MYSQL"
|
||||
//id := "id.json"
|
||||
//
|
||||
c := "java"
|
||||
cn := "HEALTH_"+"MYSQL"
|
||||
id := "id.json"
|
||||
|
||||
GetInstance().runAndInitContainer(&c)
|
||||
|
||||
callAdd(&c, &cn, &id)
|
||||
|
||||
GetInstance().stopContainer(&c)
|
||||
//GetInstance().runAndInitContainer(&c)
|
||||
//
|
||||
//callAdd(&c, &cn, &id)
|
||||
//
|
||||
//GetInstance().stopContainer(&c)
|
||||
|
||||
}
|
||||
|
||||
func TestCallRemove22(t *testing.T) {
|
||||
|
||||
c := "java"
|
||||
cn := "HEALTH_"+"MYSQL"
|
||||
id := "id.json"
|
||||
|
||||
GetInstance().runAndInitContainer(&c)
|
||||
|
||||
callRemove(&c, &cn, &id)
|
||||
|
||||
GetInstance().stopContainer(&c)
|
||||
//c := "java"
|
||||
//cn := "HEALTH_"+"MYSQL"
|
||||
//id := "id.json"
|
||||
//
|
||||
//GetInstance().runAndInitContainer(&c)
|
||||
//
|
||||
//callRemove(&c, &cn, &id)
|
||||
//
|
||||
//GetInstance().stopContainer(&c)
|
||||
|
||||
|
||||
}
|
||||
|
@ -268,14 +270,14 @@ func TestRunRun(t *testing.T) {
|
|||
|
||||
func TestActiveCrawler(t *testing.T) {
|
||||
|
||||
c := "java"
|
||||
GetInstance().runContainer(&c)
|
||||
|
||||
aa := GetInstance().activeCrawler(&c)
|
||||
|
||||
t.Log(aa)
|
||||
|
||||
GetInstance().stopContainer(&c)
|
||||
//c := "java"
|
||||
//GetInstance().runContainer(&c)
|
||||
//
|
||||
//aa := GetInstance().activeCrawler(&c)
|
||||
//
|
||||
//t.Log(aa)
|
||||
//
|
||||
//GetInstance().stopContainer(&c)
|
||||
|
||||
}
|
||||
|
||||
|
@ -289,4 +291,47 @@ func TestErer(t *testing.T) {
|
|||
|
||||
}
|
||||
|
||||
func TestStartContainer(t *testing.T) {
|
||||
|
||||
cs := GetStartContainer()
|
||||
|
||||
t.Log(cs)
|
||||
|
||||
}
|
||||
|
||||
|
||||
func GetStartContainer() []string {
|
||||
|
||||
files, _ := ioutil.ReadDir(ConfigFolder)
|
||||
|
||||
var cs []string
|
||||
|
||||
for _,file := range files {
|
||||
|
||||
if file.IsDir() {
|
||||
b := existConfigFile(ConfigFolder, file.Name())
|
||||
if b {
|
||||
cs = append(cs, file.Name())
|
||||
}
|
||||
}
|
||||
|
||||
}
|
||||
return cs
|
||||
}
|
||||
|
||||
func TestJson(t *testing.T) {
|
||||
|
||||
c := config_manager.Config{}
|
||||
|
||||
c.Crawler.Name = "wmi_crawler"
|
||||
c.Crawler.Container = "java_proxy";
|
||||
|
||||
c.Id = "WMI_TEST_ID_001"
|
||||
|
||||
|
||||
b, _ := json.Marshal(c)
|
||||
|
||||
fmt.Println(string(b))
|
||||
|
||||
}
|
||||
|
||||
|
|
Loading…
Reference in New Issue
Block a user