一、功能

  lua log方法能够自动发现同一网段下面的log服务器

  lua log方法能够主动将log发给服务器

  lua 客户端进程重启服务端不存在影响

二、实现

  服务器使用python编写:

    启动一个线程,用UDP监听特定端口,接受客户端的扫描,反馈日志的端口

    启动一个线程,监听特定端口,接受TCP连接,分派新的日志线程处理log

  客户端使用lua 编写:

    打印log之前使用UDP套节字扫描服务器的日志端口,然后创建TCP套节字发送日志

三、源代码:

  服务器:

  

import socket
import time
import re
import thread udp_listen_port = 31500
tcp_listen_port = 31501
stop_udp_server = False def getLocalIP():
myname = socket.getfqdn(socket.gethostname())
myaddr = socket.gethostbyname(myname)
return myaddr; def getTime():
return time.strftime('%Y-%m-%d %H:%M:%S',time.localtime(time.time())) def Log(content):
print("[%s]: %s" % (getTime() ,content)) def startUDPServer(): address = (getLocalIP(), udp_listen_port)
s = socket.socket(socket.AF_INET, socket.SOCK_DGRAM)
s.bind(address) print('listen broadcast %s:%s' % address)
Log('listen broadcast %s:%s' % address)
while not stop_udp_server:
data, addr = s.recvfrom(2048)
if not data:
Log("client not existed!")
continue
Log('received %s from %s' % (data, addr)) client_ip_port = '{0}:{1}'.format(addr[0],addr[1]) pat = re.compile("^(\d{1,3}\.\d{1,3}\.\d{1,3}\.\d{1,3}):(\d+)$")
for ip,port in pat.findall(client_ip_port):
Log('Got iphone addr:port = %s %s' % (ip, port))
local_addr_port = (getLocalIP(), tcp_listen_port)
Log('Rsp server addr:port = %s %s' % local_addr_port)
rsp_data = '{0}'.format(local_addr_port[1])
s.sendto(rsp_data,addr)
break; s.close() def startTCPLogServer(sock,client):
while(True): try:
data = sock.recv(4096)
if data:
pat = re.compile('\[(.*?)\]')
for log in pat.findall(data):
Log(log)
else:
break;
except socket.error:
sock.close()
break
Log('client (%s,%s) close' % client);
sock.close() def startTCPListenServer():
#create tcp socket
sock = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
#bind local ip-port
server_addr = (getLocalIP(), tcp_listen_port)
Log('start tcp server on %s port %s' % server_addr)
sock.bind(server_addr)
sock.listen(5) #print recv data
while(True):
ss,addr = sock.accept()
Log('Got log client from (%s,%s)' % addr)
thread.start_new_thread(startTCPLogServer,(ss,addr,))
sock.close() if __name__ == '__main__':
t_udp = thread.start_new_thread(startUDPServer, ())
t_tcp = thread.start_new_thread(startTCPListenServer, ()) while (True):
time.sleep(1)

  客户端:

 

udp_listen_port = 

tcp_server_ip = ""
tcp_server_port = function getLocalIP()
local socket = require("socket")
local ip, v = socket.dns.toip(socket.dns.gethostname())
for k,v in pairs(v.ip) do
return v
end
return nil
end function tryFindLogServer() local ip = getLocalIP();
local ipTable = {}
local socket = require("socket")
local udp = socket.udp() if ip ~= nil then
for i in string.gmatch(ip, "%d+") do
print(i)
table.insert(ipTable,i)
end
end
local length = table.getn(ipTable)
local findip = nil
local findport = nil
if length > then
for i = , do
local desIP = string.format("%s.%s.%s.%s",ipTable[], ipTable[], ipTable[], tostring(i))
print(desIP)
udp:setpeername(desIP, udp_listen_port)
udp:settimeout(0.5)
udp:send("Hello")
data = udp:receive()
if data ~= nil then
print(string.format("find server %s:%s", desIP,data))
tcp_server_ip = desIP
tcp_server_port = tonumber(data)
return true;
end
end
end
return false
end tcp = nil function Log( content )
-- body
if tcp == nil then
local socket = require("socket")
tcp = socket.tcp()
tcp:connect(tcp_server_ip,tcp_server_port)
end
tcp:send(string.format("[%s]",tostring(content)))
end if tryFindLogServer() then for i = , do
Log("find server")
end end

四、客户端lua中加载luasocket的方式如下:

local sz = require("sz")
local http = require("szocket.http")
local res, code = http.request("http://www.baidu.com");
if code == then
Log("start")
Log(res)
dialog(res,);
Log("end")
end

触动精灵远程Log模块的更多相关文章

  1. Android架构分析之LOG模块

    作者:刘昊昱 博客:http://blog.csdn.net/liuhaoyutz Android版本:2.3.7_r1 Linux内核版本:android-goldfish-2.6.29 Andro ...

  2. go: 一个通用log模块的实现

    在go里面,虽然有log模块,但是该模块提供的功能并不强,譬如就没有我们常用的level log功能,但是自己实现一个log模块也并不困难. 对于log的level,我们定义如下: const ( L ...

  3. frp源码剖析-frp中的log模块

    前言&引入 一个好的log模块可以帮助我们排错,分析,统计 一般来说log中需要有时间.栈信息(比如说文件名行号等),这些东西一般某些底层log模块已经帮我们做好了.但在业务中还有很多我们需要 ...

  4. 基于Lua语言的触动精灵脚本开发

    工具下载 官网地址 连接模拟器 studio连接 首先要先下载ADB模拟器连接IDE,注意,这里一定要用官网提供的ADB,安卓开发的adb不行!!! 下载好之后,打开studio,输入Access K ...

  5. 使用Python中的log模块将loss输出到终端与保存到文件

    记得之前对深度学习中得loss输出,经常自己会将输出流重新定向到一个文件中, 比如 python main.py > & | tee log.txt 对于caffe这种c++框架而言,用 ...

  6. Python远程连接模块-Telnet

    Python远程连接模块-Telnet 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 虽然现在主流的python版本还是2.7,相信2020年python程序员都会偏向Python ...

  7. log 模块使用 (直接用的方法)

    前情提要: 生活中经常用到log 模块. 但是原生的log 模块复杂或者有许多不好用得地方, 在此记录一个经常用的log 的基本操作方法 一:首先导入模块 import logging.config ...

  8. Python log 模块介绍

    刚用Python log模块写了一个例子,记录一下. import logging import logging.handlers import os from datetime import dat ...

  9. Go Log模块生成日志文件

    使用log模块示例代码: package main import ( "fmt" "time" "log" "os" ) ...

随机推荐

  1. js分页模板

    /** *参数说明: *currentPage:当前页数 *countPage:总页数 *changeMethod:执行java后台代码的js函数,即是改变分页数据的js函数 */ function  ...

  2. springMVC实现文件上传下载

    上传文件和下载文件是个常用的技能,在哪里开发几乎都能遇见,而所有的上传控件各不相同,插件很多,后台也有很多,这里我只尝试过这个方法觉的还够简洁.具体如下实现: 1.spring-mvc.xml配置   ...

  3. console.dir()和console.log()的区别

    console.log()可以取代alert()或document.write(),在网页脚本中使用console.log(data)时,会在控制台打印出数据. console.dir()可以显示一个 ...

  4. GridControl/GridView的分组操作

    今天在模块编写中碰到了对表格的分组,特意在这里把它记录下来. 一.背景:Dev14.1.3,GridControl,.NET4.0+C# 二.过程 1.GridControl设计 一共添加4列:在下面 ...

  5. OllyDBG V1.10聆风听雨汉化版

    软件名称:OllyDBG V1.10聆风听雨汉化版 软件语言: 简体中文 授权方式: 免费软件 运行环境: Win 32位/64位 软件大小: 3.84MB 图片预览: 软件简介: Ollydbg2. ...

  6. Apache 关于 mod_rewrite 遇到 %2F或%5C (正反斜杠)等特殊符号导致URL重写失效出现404的问题

    .htaccess 文件 <IfModule mod_rewrite.c> RewriteEngine on RewriteCond %{REQUEST_FILENAME} !-d Rew ...

  7. CodeForces 669C Little Artem and Matrix GNU

    模拟. 把操作记录一下,倒着复原回去. #pragma comment(linker, "/STACK:1024000000,1024000000") #include<cs ...

  8. openstack私有云布署实践【11.3 计算nova - compute节点-nova用户免密登录(用于云主机冷迁移+扩展云主机大小)】

    云主机迁移+扩展云主机大小 ,官方说它依赖nova用户之间的免密登录.确保每个resion区域的compute节点服务器他们可以相互SSH免密   compute1-7     他们相互SSH免密 k ...

  9. document对象相关的几个常用的方法

    方法  描述 var newP=createElement("p"); 创建了一个p标签,p也可替换为div,span等 var oldTxt=createTextNode(&qu ...

  10. 【Python】迭代器

    对迭代器和生成器的概念一直很混乱,总结一下: 迭代器: 1.所谓的迭代器,就是具有__next__()方法的对象: 2.__iter__()方法返回一个迭代器对象,这个对象必须具有__next__() ...