本文整理匯總了Golang中loglib.Info函數的典型用法代碼示例。如果您正苦於以下問題:Golang Info函數的具體用法?Golang Info怎麽用?Golang Info使用的例子?那麽, 這裏精選的函數代碼示例或許可以為您提供幫助。
在下文中一共展示了Info函數的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Golang代碼示例。
示例1: runParse
func (this *MongoDbOutputer) runParse(routineId int, wg *sync.WaitGroup) {
var session *mgo.Session
//routine一般都要copy或clone session,clone能保證一致性
if this.session != nil {
session = this.session.Clone()
}
defer func() {
if session != nil {
session.Close()
}
wg.Done()
loglib.Info(fmt.Sprintf("mongodb outputer parse routine %d quit", routineId))
}()
loglib.Info(fmt.Sprintf("mongodb outputer parse routine %d start", routineId))
for b := range this.buffer {
r, packId, date, err := this.extract(&b)
if err == nil {
if !this.isUpsert {
this.bulkSave(&session, r, packId, date, routineId)
} else {
this.upsert(&session, r, packId, date, routineId)
}
r.Close()
}
}
}
示例2: reConnMongoDb
//用於檢驗session可用性並適時重連的routine func
//用於重連main session
func (this *MongoDbOutputer) reConnMongoDb() {
nPingFail := 0 //ping失敗次數
reDial := false
for {
reDial = false
if this.session == nil {
//session未初始化
reDial = true
} else if this.session.Ping() != nil {
//session連接丟失
nPingFail++
if nPingFail == 3 {
reDial = true
}
}
if reDial {
nPingFail = 0
this.session = initMongoDbSession(this.mongosAddr)
if this.session == nil {
loglib.Info("session re-dial failed!")
} else {
loglib.Info("session re-dial success!")
}
}
time.Sleep(time.Second)
}
}
示例3: saveBufferInChan
func (s *Sender) saveBufferInChan() {
loglib.Info(fmt.Sprintf("sender%d begin to save pack in chan", s.id))
i := 0
for b := range s.memBuffer {
s.writeToFile(b)
i++
}
loglib.Info(fmt.Sprintf("sender%d saved num of pack in chan: %d", s.id, i))
}
示例4: sendData
func (s Sender) sendData(data []byte, conn *net.TCPConn) bool {
if len(data) == 0 {
return true
}
if conn == nil {
return false
}
/*
lenBuf := make([]byte, 4)
nData := len(data)
binary.PutUvarint(lenBuf, uint64(nData))
data = append(lenBuf, data...)
*/
st := time.Now()
packId := tcp_pack.GetPackId(data)
conn.SetDeadline(time.Now().Add(5 * time.Minute)) //設置超時
loglib.Info(fmt.Sprintf("sender%d start sending pack:%s length:%d", s.id, packId, len(data)))
n, err := conn.Write(data)
ed := time.Now()
loglib.Info(fmt.Sprintf("sender%d end sending pack:%s length:%d elapse:%s", s.id, packId, n, ed.Sub(st)))
lib.CheckError(err)
//寫失敗了就不用等應答了,肯定拿不到
if err == nil {
conn.SetReadDeadline(time.Now().Add(8 * time.Minute)) //設置超時
time1 := time.Now()
var temp []byte = make([]byte, 128)
count, err := conn.Read(temp)
if err == nil {
loglib.Info(fmt.Sprintf("sender%d get anwser data len:%d for pack:%s elapse:%s", s.id, count, packId, time.Now().Sub(time1)))
} else {
loglib.Info(fmt.Sprintf("sender%d get anwser data len:%d for pack:%s elapse:%s, error:%s", s.id, count, packId, time.Now().Sub(time1), err.Error()))
}
temp = temp[:count]
if string(temp) == "ok" { //發送成功
return true
} else if string(temp) == "wrong header" {
//包頭錯誤,丟棄
loglib.Info(packId + " has wrong header, retry later!")
return false
} else { //發送失敗
//報警
return false
}
} else {
loglib.Warning(fmt.Sprintf("write pack %s error:%s", packId, err.Error()))
}
return false
}
示例5: handleRegister
//處理注冊請求
func (lr *LogReceiver) handleRegister(registerInfo map[string]string) map[string]string {
req, ok := registerInfo["req"]
m := map[string]string{"err": "-1", "msg": "unkown request <" + req + ">"}
ip, _ := registerInfo["ip"]
port, _ := registerInfo["port"]
hostname, _ := registerInfo["hostname"]
role, _ := registerInfo["role"]
addr := ip
loglib.Info(ip + ":" + port + " " + req)
if ok && (req == "register" || req == "unregister") {
if port != "" {
addr = ip + ":" + port
}
if req == "register" {
ret, err := lr.register(ip, port, role, hostname)
if ret {
lr.mutex.Lock()
lr.ipRoleMap[addr] = role
lr.mutex.Unlock()
m["err"] = "0"
m["msg"] = "success"
} else {
m["err"] = "1"
if err != nil {
m["msg"] = err.Error()
} else {
m["msg"] = "done"
}
}
} else if req == "unregister" {
ret, err := lr.unRegister(ip, port)
if ret {
lr.mutex.Lock()
delete(lr.ipRoleMap, addr)
lr.mutex.Unlock()
m["err"] = "0"
m["msg"] = "success"
} else {
m["err"] = "1"
if err != nil {
m["msg"] = err.Error()
} else {
m["msg"] = "done"
}
}
}
}
loglib.Info("[monitor] " + ip + ":" + port + " " + role + " " + req + ": " + m["msg"])
return m
}
示例6: doEtl
func (e *etlOutputer) doEtl(fkeyChan chan string, logDataDir string, etlDir string, etlDoneDir string, etlFailDir string, spiderList string, colsFile string, hostsList string, ipBlackList string, wg *sync.WaitGroup) {
defer func() {
if err := recover(); err != nil {
loglib.Error(fmt.Sprintf("doEtl() panic:%v", err))
}
wg.Done()
}()
loglib.Info("etl routine start")
for fkey := range fkeyChan {
sv := etl.NewFileSaver(colsFile, etlDir, fkey)
d := etl.NewDispatcher(sv, 6, hostsList, ipBlackList)
g := etl.NewGlobalHao123(spiderList, 100, 200, 8, d)
go g.Start(false)
fname := filepath.Join(logDataDir, fkey)
loglib.Info("start etl for " + fname)
err := g.ParseFile(fname)
g.Wait()
// etl success
// mark success
if err == nil {
//采用循環,增加打tag的成功率
for i := 0; i < 5; i++ {
fd, err := os.Create(filepath.Join(etlDoneDir, fkey))
if err == nil {
fd.Close()
loglib.Info("finish etl for " + fname)
break
} else {
loglib.Warning("mark etl done for " + fname + " failed! error: " + err.Error())
}
}
} else {
//采用循環,增加打tag的成功率
for i := 0; i < 5; i++ {
fd, err := os.Create(filepath.Join(etlFailDir, fkey))
if err == nil {
fd.Close()
loglib.Info("failed etl for " + fname)
break
} else {
loglib.Warning("mark etl fail for " + fname + " failed! error: " + err.Error())
}
}
}
}
loglib.Info("etl routine finish")
}
示例7: Quit
func (this *WaitQuit) Quit() bool {
ret := false
select {
case <-this.ch:
loglib.Info(this.name + " safe quit.")
ret = true
case <-time.After(2 * time.Second):
loglib.Info(this.name + " quit timeout")
this.nTimeout++
if this.allowTimeout > 0 && this.nTimeout >= this.allowTimeout {
ret = true
}
}
return ret
}
示例8: clearFootPrint
func (t *TcpReceiver) clearFootPrint(wg *sync.WaitGroup) {
defer wg.Done()
ch1 := make(chan bool) //用於安全退出
ch2 := time.After(time.Hour) //用於定時任務
go lib.HandleQuitSignal(func() {
ch1 <- true
})
loop:
for {
select {
//監聽一個chan以便安全退出
case <-ch1:
break loop
case <-ch2:
//若這個case未執行完,而ch1已可讀,select會保證這個case執行完
now := time.Now().Unix()
t.mutex.Lock()
for code, appear := range t.footPrint {
if now-appear.Time >= 86400 {
delete(t.footPrint, code)
}
}
t.saveFootPrint()
t.mutex.Unlock()
ch2 = time.After(time.Hour) //用於定時任務
}
}
loglib.Info("clear footprint quit!")
}
示例9: reloadFileCache
//載入cache文件列表
func (this *MongoDbOutputer) reloadFileCache() {
list := lib.GetFilelist(this.file_mem_folder_name)
for _, filename := range list {
loglib.Info("reloading:" + filename)
this.fileList.PushBack(filename)
}
}
示例10: reloadFileCache
//should be run by once
func (s *Sender) reloadFileCache() {
list := lib.GetFilelist(s.file_mem_folder_name)
for _, filename := range list {
// s.fileCacheList.PushBack(filename)
loglib.Info("reloading:" + filename)
fileList.PushBack(filename)
}
}
示例11: Start
func (t *TcpReceiver) Start() {
tcpAddr, err := net.ResolveTCPAddr("tcp4", t.receiveFromAddress)
lib.CheckError(err)
listener, err := net.ListenTCP("tcp", tcpAddr)
lib.CheckError(err)
wg := &sync.WaitGroup{}
wg.Add(1)
go t.clearFootPrint(wg)
//主routine信號處理
go lib.HandleQuitSignal(func() {
//接收到信號關閉listenner,此時Accept會馬上返回一個nil 的conn
listener.Close()
loglib.Info("close tcp receiver's listener.")
})
defer func() {
if err := recover(); err != nil {
loglib.Error(fmt.Sprintf("tcp receiver panic:%v", err))
}
loglib.Info("wait connections finish...")
wg.Wait()
loglib.Info("all connections have been processed. quit.")
close(t.buffer) //關閉chan
t.saveFootPrint()
t.wq.AllDone()
}()
for {
conn, err := listener.Accept()
if conn == nil {
break
}
lib.CheckError(err)
wg.Add(1)
go t.handleConnnection(conn, wg)
}
}
示例12: extract
func (f *fileOutputer) extract(bp *bytes.Buffer) {
buf := make([]byte, 4)
bp.Read(buf)
l, _ := binary.Uvarint(buf)
headerLen := int(l)
//get pack header
buf = make([]byte, headerLen)
bp.Read(buf)
header := tcp_pack.ParseHeader(buf)
r, err := zlib.NewReader(bp)
if err != nil {
loglib.Error("zlib reader Error: " + err.Error())
} else {
lines, _ := strconv.Atoi(header["lines"])
done := false
if header["done"] == "1" {
done = true
}
f.ic.Add(header["ip"], header["hour"], header["id"], lines, done)
writerKey := header["ip"] + "_" + header["hour"]
fout := f.getWriter(f.writers, f.dataDir, writerKey)
//一頭一尾寫頭信息,節省硬盤
buf = append(buf, '\n')
//fout.Write(buf)
nn, err := io.Copy(fout, r)
if err != nil {
loglib.Warning(fmt.Sprintf("save %s_%s_%s error:%s, saved:%d", header["ip"], header["hour"], header["id"], err, nn))
}
//fout.Write(buf)
//單獨存一份header便於查數
fout = f.getWriter(f.headerWriters, f.headerDir, writerKey)
n, err := fout.Write(buf)
if err != nil {
loglib.Info(fmt.Sprintf("writer header %s %d %s", writerKey, n, err.Error()))
}
if done || time.Now().Unix() > f.checkTime.Unix() {
hourFinish, _ := f.ic.Check()
for ip, hours := range hourFinish {
for _, hour := range hours {
writerKey = ip + "_" + hour
}
}
f.closeWriters(f.writers)
f.closeWriters(f.headerWriters)
f.checkTime.Add(2 * time.Minute)
}
r.Close()
}
}
示例13: sendData2
func (s *Sender) sendData2(data []byte) bool {
result := s.sendData(data, s.connection.getConn())
//發送失敗,tcp連接可能已經失效,重新建立tcp連接
if result == false {
s.connection.reconnect(s.connection.getConn())
*s.status = -1
loglib.Info(fmt.Sprintf("sender%d reconnected by sendData2(),status:%d", s.id, *s.status))
}
return result
}
示例14: pickPacks
//從公用的chan讀pack到私有的chan,若私有chan已滿則寫入文件緩存
//保證公用chan不會阻塞
func (s *Sender) pickPacks() {
for buf := range s.sBuffer {
select {
case s.memBuffer <- buf:
break
default:
loglib.Info(fmt.Sprintf("sender%d mem buffer is full, total %d, pub chan:%d", s.id, len(s.memBuffer), len(s.sBuffer)))
s.writeToFile(buf)
}
}
close(s.memBuffer)
}
示例15: tailerGo
func tailerGo(cfg map[string]map[string]string) {
qlst := lib.NewQuitList()
receiveChan := make(chan map[string]string, 10000) //非阻塞
sendBuffer := make(chan bytes.Buffer, 500)
recvBufferSize, _ := strconv.Atoi(cfg["tail"]["recv_buffer_size"])
tailler := NewTailler(cfg["tail"])
r := ReceiverInit(sendBuffer, receiveChan, recvBufferSize, tailler.GetLineNum())
//make a new log tailler
go tailler.Tailling(receiveChan)
//start receiver to receive log
go r.Start()
//一定要發送方先退出
qlst.Append(tailler.Quit)
qlst.Append(r.Quit)
// heart beat
port, _ := cfg["monitor"]["hb_port"]
monAddr, _ := cfg["monitor"]["mon_addr"]
if port != "" && monAddr != "" {
hb := heart_beat.NewHeartBeat(port, monAddr, "tail")
go hb.Run()
qlst.Append(hb.Quit)
}
addrs := strings.Split(cfg["tail"]["send_to"], ",")
addr := strings.Trim(addrs[0], " ")
bakAddr := addr
//有備用地址?
if len(addrs) > 1 {
bakAddr = strings.Trim(addrs[1], " ")
}
//加大發送並發,sender阻塞會影響tail的進度
nSenders := 2
senders, ok := cfg["tail"]["senders"]
if ok {
tmp, err := strconv.Atoi(senders)
if err == nil {
nSenders = tmp
}
}
for i := 1; i <= nSenders; i++ {
s := SenderInit(sendBuffer, addr, bakAddr, i)
go s.Start()
qlst.Append(s.Quit)
}
loglib.Info(fmt.Sprintf("total senders %d", nSenders))
qlst.HandleQuitSignal()
qlst.ExecQuit()
}