Comments (7)
搞定了,吧消费线程的上下文传递到超时装饰器启动的线程里面来,因为设置超时杀死后,用户的函数实际是超时装饰器里面另外起了个线程里面运行的.
from funboost.
这个是我意料之中的, 超时杀死和支持远程杀死 这两个功能都是吧函数包装在另外一个单独的线程里面去运行的,和funboost设置到上下文时候不是在同一个线程里面,所以获取不到的, 要兼容这两个功能代码还需要改造的,要去注超时装饰器和支持远程杀死装饰器里面去改代码了,需要把一个线程的上下文赋值到这个新的独立包装线程里面去,需要等待一段时间我再实现.
超时杀死和远程杀死这两个功能,已经提示了不要轻易使用的, 因为要支持杀死,就要把它放到一个单独的线程里面运行,杀死函数其实就是使用c语言的ctypes 杀死这个函数运行所在的线程,如果杀死函数时候,用户函数获取了线程锁,但是还没释放,程序会永远死锁,
而且设置超时杀死,代码性能明显又会下降一截,因为每次运行消息都要新创建一个线程,非必要别使用.
你现在是必须要用超时杀死吗?
from funboost.
这个问题和上个回答你添加taskid一样, 所谓的上下文 必须是同一个线程/协程下才行,
from funboost.
funboost_current_task 是刚加的,现在不兼容设置函数超时杀死和远程杀死
from funboost.
明白了,但是感觉可以在文档说明一下。因为直观的感受就是莫名的时好时坏(有的队列没加超时杀死,有的加了,或者开始没加好使,后来加了又报错了)
from funboost.
这个是我意料之中的, 超时杀死和支持远程杀死 这两个功能都是吧函数包装在另外一个单独的线程里面去运行的,和funboost设置到上下文时候不是在同一个线程里面,所以获取不到的, 要兼容这两个功能代码还需要改造的,要去注超时装饰器和支持远程杀死装饰器里面去改代码了,需要把一个线程的上下文赋值到这个新的独立包装线程里面去,需要等待一段时间我再实现.
超时杀死和远程杀死这两个功能,已经提示了不要轻易使用的, 因为要支持杀死,就要把它放到一个单独的线程里面运行,杀死函数其实就是使用c语言的ctypes 杀死这个函数运行所在的线程,如果杀死函数时候,用户函数获取了线程锁,但是还没释放,程序会永远死锁,
而且设置超时杀死,代码性能明显又会下降一截,因为每次运行消息都要新创建一个线程,非必要别使用. 你现在是必须要用超时杀死吗?
倒也不是非得用,就是做个兜底,防止某些个别消息处理太慢,一直挂着
from funboost.
更新新版试了下,已经可以了 。
from funboost.
Related Issues (20)
- sqlite作为中间件例子在mac/linux运行,报错 read-only [用户文件夹权限问题,自己修改个文件夹] HOT 4
- 如何快捷的停止multi_process_consume 这个消费函数的所有进程 HOT 3
- base_publisher的publish函数好像有点问题[用户没了解python字典是可变对象] HOT 8
- 发现一个有趣的问题 HOT 3
- 如果两个booster嵌套使用的话,多进程好像运行会阻塞? HOT 21
- delay
- delay 任务支持retry的时候设置countdown吗? HOT 3
- django的模块引入和启动 HOT 16
- pip包太厚重了, 能不能搞精简一点的, 比如我就只需要redis跟异步就可以了, 其他的完全不需要 HOT 10
- 接受非booster传过来的消息,没有extra, 导致consume 失败 HOT 1
- result_web. index.html 中 其中的一个css文件无法下载了 “bootstrap.min.css” HOT 1
- 姑且提醒下这个repo错别字连篇
- [BUG]ModuleNotFoundError: No module named 'db_libs' [contrib里面是作者额外贡献的功能,需要用户自己安装相关三方包] HOT 3
- 请教: 如何使用 nb_log 打印task_id HOT 19
- 【bug】可能存在的bug- 在线急等修复(我就不用再加猴子补丁了~~)[用户自己写法错误问题] HOT 8
- windows上的脚本到linux上远程执行时的路径不正确 HOT 9
- 你好,我想请教一下使用Rocketmq作为中间件时自定义消费者类的问题 HOT 9
- 关于定时任务持久化方面的一些疑惑 HOT 5
- 更新44.9报错
Recommend Projects
-
React
A declarative, efficient, and flexible JavaScript library for building user interfaces.
-
Vue.js
🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.
-
Typescript
TypeScript is a superset of JavaScript that compiles to clean JavaScript output.
-
TensorFlow
An Open Source Machine Learning Framework for Everyone
-
Django
The Web framework for perfectionists with deadlines.
-
Laravel
A PHP framework for web artisans
-
D3
Bring data to life with SVG, Canvas and HTML. 📊📈🎉
-
Recommend Topics
-
javascript
JavaScript (JS) is a lightweight interpreted programming language with first-class functions.
-
web
Some thing interesting about web. New door for the world.
-
server
A server is a program made to process requests and deliver data to clients.
-
Machine learning
Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.
-
Visualization
Some thing interesting about visualization, use data art
-
Game
Some thing interesting about game, make everyone happy.
Recommend Org
-
Facebook
We are working to build community through open source technology. NB: members must have two-factor auth.
-
Microsoft
Open source projects and samples from Microsoft.
-
Google
Google ❤️ Open Source for everyone.
-
Alibaba
Alibaba Open Source for everyone
-
D3
Data-Driven Documents codes.
-
Tencent
China tencent open source team.
from funboost.