tornado多进程模式不同进程写不同日志
#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多进程模式不同进程写不同日志的更多相关文章
- tornado 多进程模式
https://www.douban.com/note/217901726/ 官方文档的helloworld实例中的启动方法: if __name__ == "__main__": ...
- 不得不注意tornado多进程部署的副作用
tornado多进程启动时,采用的是fork的方式. 一个现有进程可以调用fork函数创建一个新进程.由fork创建的新进程被称为子进程(child process).fork函数被调用一次但返回两次 ...
- 0704 Process继承实现多进程、Pool进程池,进程间通过队列通信,Pool实现多进程实现复制文件
通过继承的方式,实现Process多进程 from multiprocessing import Process import time class MyNewProcess(Process): de ...
- 多进程 multiprocessing 模块进程并发Process;Pool ;Queue队列 、threading模块;
multiprocessing 模块中的 Process类提供了跨平台的多进程功能,在windows和linux系统都可以使用. 1.首先要实例化一个类,传入要执行的函数. 实例名 = Process ...
- SQLite 预写式日志
SQLite在3.7.0版本引入了WAL (Write-Ahead-Logging),WAL的全称是Write Ahead Logging,它是很多数据库中用于实现原子事务的一种机制,引入WAL机制之 ...
- C#写文本日志帮助类(支持多线程)
代码: using System; using System.Configuration; using System.IO; using System.Threading.Tasks; namespa ...
- 结合FireBreath在Chrome/FireFox的多进程模式下崩溃一例
FireBreath是跨浏览器跨操作系统的插件方案,它封装了ActiveX和NPAPI的插件接口,使用统一的API来暴露JSAPI.Chrome和FireFox使用NPAPI,IE使用ActiveX. ...
- Node.js - 阿里Egg的多进程模型和进程间通讯
前言 最近用Egg作为底层框架开发项目,好奇其多进程模型的管理实现,于是学习了解了一些东西,顺便记录下来.文章如有错误, 请轻喷 为什么需要多进程 伴随科技的发展, 现在的服务器基本上都是多核cpu的 ...
- php实现多进程和关闭进程
一.php实现多进程 PHP有个pcntl_fork的函数可以实现多进程,但要加载pcntl拓展,而且只有在linux下才能编译这个拓展. 先代码: <?php$arr = ['30000000 ...
随机推荐
- Python卸载不干净?苹果电脑卸载python教程
如今,Pyhon越来越火,屡次超越Java.C++成为编程语言排行榜第一的语言,国内的公司和程序员们也越来越喜欢使用Python.但是Python安装之后,散落在电脑各处,删除起来比较麻烦,很多小伙伴 ...
- elastic-job-lite-console后台以服务形式运行
原文:https://blog.csdn.net/u012637358/article/details/84846923 方式1:命令让程序一直在后台运行 nohup ./bin/start.sh & ...
- 词向量---LSA(Latent Semantic Analysis)
举例: 矩阵分解之后,取前两维,k=2, 单词距离: 文档距离: 通过LSA分析之后计算文档间的余弦相似度,属于同一个类型文本之间的相似度很接近:在原始文档间计算相似度,效果不如LSA 当出现新的 ...
- .gitignore 标准模板 -适用于SpringBoot+Vue项目 -Idea+VSCode开发
.gitignore 标准模板 -适用于SpringBoot+Vue项目 node_modules/ target/ !.mvn/wrapper/maven-wrapper.jar ### STS # ...
- 项目Beta冲刺(团队4/7)
项目Beta冲刺(团队) --4/7 作业要求: 项目Beta冲刺(团队) 1.团队信息 团队名 :男上加男 成员信息 : 队员学号 队员姓名 个人博客地址 备注 221600427 Alicesft ...
- node 进程管理 child_process [spawn,exec] | 珠峰培训node正式课 网络爬虫
run.js ; function set(){ i++ setTimeout(function(){ console.log(i) ){ set(); } },) }set(); child_pro ...
- placeholder 效果的实现,input提示字,获取焦点时消失
<!doctype html><html><head><meta charset="utf-8"><title>plac ...
- 函数式编程:面向可复用的map和pipeline机制的编程语言
函数式编程:面向可复用的map和pipeline机制的编程语言
- [Algorithm] 206. Reverse Linked List
Reverse a singly linked list. Example: Input: 1->2->3->4->5->NULL Output: 5->4-> ...
- Passwords Gym - 101174E (AC自动机上DP)
Problem E: Passwords \[ Time Limit: 1 s \quad Memory Limit: 256 MiB \] 题意 给出两个正整数\(A,B\),再给出\(n\)个字符 ...