#coding: utf-
'''
Author:
Time:
Target:
''' import logging
import logging.handlers
import os
import json
import tornado.httpserver
import tornado.ioloop
import tornado.web
from tornado.options import define, options
import time
import gc define("port", default=, help="Please send email to me", type=int) def init_log(log_filename, pattern='test'):
'''
记录log日志
:param log_filename:日志记录名
:param pattern: 类型
:return:
'''
formatter = logging.Formatter('%(asctime)s %(levelname)s %(message)s')
logger = logging.getLogger()
if pattern == 'production':
fh = logging.handlers.TimedRotatingFileHandler(
filename=log_filename, when='midnight')
fh.suffix = '%Y%m%d.log'
logger.setLevel(logging.INFO)
elif pattern == 'rotating_test':
fh = logging.handlers.TimedRotatingFileHandler(
filename=log_filename, when='M')
fh.suffix = '%Y%m%d-%H%M.log'
logger.setLevel(logging.DEBUG)
elif pattern == 'test':
fh = logging.FileHandler(filename=log_filename, mode='w')
logger.setLevel(logging.DEBUG)
else:
#print('No Legal Pattern')
raise TypeError
fh.setFormatter(formatter)
logger.addHandler(fh)
return logger if __name__ == "__main__":
tornado.options.parse_command_line()
app = tornado.web.Application(
handlers = [
(r"/update", update),
(r"/Cleantext",clean)
]
)
'''
# 第一种多进程启动模式
http_server = tornado.httpserver.HTTPServer(app)
http_server.listen(options.port)
http_server.start()
#http_server.start()
tornado.ioloop.IOLoop.instance().start() ''' # 第二种多进程启动模式
sockets = tornado.netutil.bind_sockets(options.port)
task_id = tornado.process.fork_processes()
#取到的task_id 是0~3。os.getpid()取子进程ID,os.getppid()取父进程ID
if task_id is None:
task_id = str(os.getpid()) + "_" + str(os.getppid()) http_server = tornado.httpserver.HTTPServer(app)
http_server.add_sockets(sockets) #global LOGGER
LOG_FOLDER = './server_%s_log'%(options.port)
if not os.path.exists(LOG_FOLDER):
os.makedirs(LOG_FOLDER)
LOG_PATH = os.path.join(LOG_FOLDER, 'ServerLog')
# print(LOG_PATH)
# 每个子进程自己创建一个日志文件
LOGGER = init_log(LOG_PATH + str(task_id) , pattern='production') tornado.ioloop.IOLoop.instance().start()
class update(tornado.web.RequestHandler):

    def post(self):

        result = {
'status': 'success'
} post_data = self.request.body
time1=time.time()
post_data=post_data.decode('utf-8')
try:
post_data=json.loads(post_data)
except Exception as e:
post_data=post_data.replace('\n','').replace('\r','')
post_data = json.loads(post_data) #print(post_data)
channel=post_data['channel']
#print(channel)
sentence=post_data['content'] self.write(json.dumps(post_data))
self.add_header('Content-Type', 'application/json') time2=time.time()
LOGGER.info('INFO 200 POST/clean %2.5f ms'%(*(time2-time1)))

tornado多进程模式不同进程写不同日志的更多相关文章

  1. tornado 多进程模式

    https://www.douban.com/note/217901726/ 官方文档的helloworld实例中的启动方法: if __name__ == "__main__": ...

  2. 不得不注意tornado多进程部署的副作用

    tornado多进程启动时,采用的是fork的方式. 一个现有进程可以调用fork函数创建一个新进程.由fork创建的新进程被称为子进程(child process).fork函数被调用一次但返回两次 ...

  3. 0704 Process继承实现多进程、Pool进程池,进程间通过队列通信,Pool实现多进程实现复制文件

    通过继承的方式,实现Process多进程 from multiprocessing import Process import time class MyNewProcess(Process): de ...

  4. 多进程 multiprocessing 模块进程并发Process;Pool ;Queue队列 、threading模块;

    multiprocessing 模块中的 Process类提供了跨平台的多进程功能,在windows和linux系统都可以使用. 1.首先要实例化一个类,传入要执行的函数. 实例名 = Process ...

  5. SQLite 预写式日志

    SQLite在3.7.0版本引入了WAL (Write-Ahead-Logging),WAL的全称是Write Ahead Logging,它是很多数据库中用于实现原子事务的一种机制,引入WAL机制之 ...

  6. C#写文本日志帮助类(支持多线程)

    代码: using System; using System.Configuration; using System.IO; using System.Threading.Tasks; namespa ...

  7. 结合FireBreath在Chrome/FireFox的多进程模式下崩溃一例

    FireBreath是跨浏览器跨操作系统的插件方案,它封装了ActiveX和NPAPI的插件接口,使用统一的API来暴露JSAPI.Chrome和FireFox使用NPAPI,IE使用ActiveX. ...

  8. Node.js - 阿里Egg的多进程模型和进程间通讯

    前言 最近用Egg作为底层框架开发项目,好奇其多进程模型的管理实现,于是学习了解了一些东西,顺便记录下来.文章如有错误, 请轻喷 为什么需要多进程 伴随科技的发展, 现在的服务器基本上都是多核cpu的 ...

  9. php实现多进程和关闭进程

    一.php实现多进程 PHP有个pcntl_fork的函数可以实现多进程,但要加载pcntl拓展,而且只有在linux下才能编译这个拓展. 先代码: <?php$arr = ['30000000 ...

随机推荐

  1. Docker 0x06: Docker Volume卷

    目录 Docker Volume卷 一句话什么是docker volume? docker volume特性 docker 挂载卷 docker 多容器间共享数据券 删除,查看数据卷 备份还原数据卷 ...

  2. Detectron2源码阅读笔记-(二)Registry&build_*方法

    ​ Trainer解析 我们继续Detectron2代码阅读笔记-(一)中的内容. 上图画出了detectron2文件夹中的三个子文件夹(tools,config,engine)之间的关系.那么剩下的 ...

  3. Java精通并发-Lock与synchronized关键字在底层的区别及实例分析

    在上两次中已经将Lock这个接口的整个官方说明进行了阅读,这次来了解一下它的一个非常重要的实现类: 啥叫“可重入”呢?其实是指一个线程已经拿到了锁,然后该线程还能再次获取这把锁,接下来在了解它之前先用 ...

  4. urdf 学习记录

    1.URDF(Unified Robot Description Format),统一的机器人描述文件格式.主要用来描述机器人的几何形状,在可视化时(如RViz中)显示出机器人的几何形状.与画图软件( ...

  5. Caused by: com.mysql.jdbc.exceptions.jdbc4.MySQLIntegrityConstraintViolationException: Column 'org_mer_id' in where clause is ambiguous

    ### Error querying database. Cause: com.mysql.jdbc.exceptions.jdbc4.MySQLIntegrityConstraintViolatio ...

  6. Gym100739H Hard Molecules

    Hard Molecules 给定一个连通图中每个点的度数,求一个满足条件的图,图可以有重边,不能有自环. n<=5000, di<=109 题解 如果不要求图连通,那么只需要判断 \[ ...

  7. 【Hadoop】新建hadoop用户以及用户组,给予sudo权限(转)

    1.首先新建用户,adduser命令 sudo adduser hadoop passwd hadoop 输入密码之后,一路 y 确定. 2.添加用户组 在创建hadoop用户的同时也创建了hadoo ...

  8. node 进程管理 child_process [spawn,exec] | 珠峰培训node正式课 网络爬虫

    run.js ; function set(){ i++ setTimeout(function(){ console.log(i) ){ set(); } },) }set(); child_pro ...

  9. 数据分析 - Matplotlib

    简介 Matplotlib是一个强大的Python绘图和数据可视化的工具包.数据可视化也是我们数据分析的最重要的工作之一,可以帮助我们完成很多操作,例如:找出异常值.必要的一些数据转换等.完成数据分析 ...

  10. du -h

    du命令用来查看目录或文件所占用磁盘空间的大小.常用选项组合为:du -sh   一.du的功能:`du` reports the amount of disk space used by the s ...