dotask 0.2.3__tar.gz → 0.2.4__tar.gz

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.4
2
2
  Name: dotask
3
- Version: 0.2.3
3
+ Version: 0.2.4
4
4
  Summary: 发布订阅注解方式
5
5
  Home-page: https://gitee.com/d-yz/task-manager
6
6
  Author: dyz
@@ -17,7 +17,8 @@ Description-Content-Type: text/markdown
17
17
  License-File: LICENSE
18
18
  Dynamic: license-file
19
19
 
20
- ## 0.1.0
20
+ ## 版本说明
21
+ ### 0.1.0
21
22
  - 在方法上添加@task就可以直接开启一个线程执行任务
22
23
  - 常用参数:
23
24
  - 生产者: role="producer",topic="自定义"
@@ -28,9 +29,50 @@ Dynamic: license-file
28
29
  - subscribe: 对哪些主题感兴趣
29
30
  - publish_after: 消费完后继续发布新主题
30
31
  - 特别的:方法的返回值可以进行传递,若没有返回值则不会发布新主题(只针对消费者和消费者之间)
31
- ## 0.2.0
32
+ ### 0.2.x
32
33
  1. dotask暴露topic_manager=>可以更好的管理生产消费者
33
34
  2. 迁移logger至util包下
34
35
  3. 添加本地调用shell工具函数->可以很好的适配@task消费者
35
36
  1. max_concurrent:控制并发执行的shell数量
36
37
  2. 引入dotask.Shell 调用Shell(max_concurrent=?).local_shell_execute(cmd,callback)来使用
38
+ ## 快速开始
39
+ ### 安装
40
+ `pip install dotask`
41
+ ### 示例
42
+ 1. 简单的生产发布模式
43
+
44
+ ```
45
+ from dotask import task
46
+ from dotask.util import logger
47
+ import random
48
+
49
+ if __name__ == '__main__':
50
+
51
+ @task(role="producer",topic="scan")
52
+ def a():
53
+ return random.randint(1,10)
54
+
55
+
56
+ @task(role="consumer",subscribe="scan",publish_after="sayHi")
57
+ def b(data):
58
+ if data >5:
59
+ return data
60
+ logger.warning(f"本次生成数字:{data},不会继续发布sayHi主题")
61
+
62
+ @task(role="consumer",subscribe="sayHi")
63
+ def c(data):
64
+ logger.debug(f"c触发")
65
+ logger.info(f"消费:{data}")
66
+ //=====================================================================
67
+ 2026-02-08 17:30:37 - INFO - 发布主题-[scan]:5
68
+ 2026-02-08 17:30:37 - WARNING - 本次生成数字:5,不会继续发布sayHi主题
69
+ 2026-02-08 17:30:38 - INFO - 发布主题-[scan]:8
70
+ 2026-02-08 17:30:38 - INFO - 发布主题-[sayHi]:8
71
+ 2026-02-08 17:30:38 - DEBUG - c触发
72
+ 2026-02-08 17:30:38 - INFO - 消费:8
73
+ 2026-02-08 17:30:38 - INFO - 发布主题-[scan]:6
74
+ 2026-02-08 17:30:38 - INFO - 发布主题-[sayHi]:6
75
+ 2026-02-08 17:30:38 - DEBUG - c触发
76
+ 2026-02-08 17:30:38 - INFO - 消费:6
77
+ //======================================================================
78
+ ```
dotask-0.2.4/README.md ADDED
@@ -0,0 +1,59 @@
1
+ ## 版本说明
2
+ ### 0.1.0
3
+ - 在方法上添加@task就可以直接开启一个线程执行任务
4
+ - 常用参数:
5
+ - 生产者: role="producer",topic="自定义"
6
+ - 消费者: role="consumer",subscribe="自定义",publish_after="自定义"
7
+ - 说明:
8
+ - role: 用于区分上下游 producer/consumer
9
+ - topic: 发布的主题
10
+ - subscribe: 对哪些主题感兴趣
11
+ - publish_after: 消费完后继续发布新主题
12
+ - 特别的:方法的返回值可以进行传递,若没有返回值则不会发布新主题(只针对消费者和消费者之间)
13
+ ### 0.2.x
14
+ 1. dotask暴露topic_manager=>可以更好的管理生产消费者
15
+ 2. 迁移logger至util包下
16
+ 3. 添加本地调用shell工具函数->可以很好的适配@task消费者
17
+ 1. max_concurrent:控制并发执行的shell数量
18
+ 2. 引入dotask.Shell 调用Shell(max_concurrent=?).local_shell_execute(cmd,callback)来使用
19
+ ## 快速开始
20
+ ### 安装
21
+ `pip install dotask`
22
+ ### 示例
23
+ 1. 简单的生产发布模式
24
+
25
+ ```
26
+ from dotask import task
27
+ from dotask.util import logger
28
+ import random
29
+
30
+ if __name__ == '__main__':
31
+
32
+ @task(role="producer",topic="scan")
33
+ def a():
34
+ return random.randint(1,10)
35
+
36
+
37
+ @task(role="consumer",subscribe="scan",publish_after="sayHi")
38
+ def b(data):
39
+ if data >5:
40
+ return data
41
+ logger.warning(f"本次生成数字:{data},不会继续发布sayHi主题")
42
+
43
+ @task(role="consumer",subscribe="sayHi")
44
+ def c(data):
45
+ logger.debug(f"c触发")
46
+ logger.info(f"消费:{data}")
47
+ //=====================================================================
48
+ 2026-02-08 17:30:37 - INFO - 发布主题-[scan]:5
49
+ 2026-02-08 17:30:37 - WARNING - 本次生成数字:5,不会继续发布sayHi主题
50
+ 2026-02-08 17:30:38 - INFO - 发布主题-[scan]:8
51
+ 2026-02-08 17:30:38 - INFO - 发布主题-[sayHi]:8
52
+ 2026-02-08 17:30:38 - DEBUG - c触发
53
+ 2026-02-08 17:30:38 - INFO - 消费:8
54
+ 2026-02-08 17:30:38 - INFO - 发布主题-[scan]:6
55
+ 2026-02-08 17:30:38 - INFO - 发布主题-[sayHi]:6
56
+ 2026-02-08 17:30:38 - DEBUG - c触发
57
+ 2026-02-08 17:30:38 - INFO - 消费:6
58
+ //======================================================================
59
+ ```
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.4
2
2
  Name: dotask
3
- Version: 0.2.3
3
+ Version: 0.2.4
4
4
  Summary: 发布订阅注解方式
5
5
  Home-page: https://gitee.com/d-yz/task-manager
6
6
  Author: dyz
@@ -17,7 +17,8 @@ Description-Content-Type: text/markdown
17
17
  License-File: LICENSE
18
18
  Dynamic: license-file
19
19
 
20
- ## 0.1.0
20
+ ## 版本说明
21
+ ### 0.1.0
21
22
  - 在方法上添加@task就可以直接开启一个线程执行任务
22
23
  - 常用参数:
23
24
  - 生产者: role="producer",topic="自定义"
@@ -28,9 +29,50 @@ Dynamic: license-file
28
29
  - subscribe: 对哪些主题感兴趣
29
30
  - publish_after: 消费完后继续发布新主题
30
31
  - 特别的:方法的返回值可以进行传递,若没有返回值则不会发布新主题(只针对消费者和消费者之间)
31
- ## 0.2.0
32
+ ### 0.2.x
32
33
  1. dotask暴露topic_manager=>可以更好的管理生产消费者
33
34
  2. 迁移logger至util包下
34
35
  3. 添加本地调用shell工具函数->可以很好的适配@task消费者
35
36
  1. max_concurrent:控制并发执行的shell数量
36
37
  2. 引入dotask.Shell 调用Shell(max_concurrent=?).local_shell_execute(cmd,callback)来使用
38
+ ## 快速开始
39
+ ### 安装
40
+ `pip install dotask`
41
+ ### 示例
42
+ 1. 简单的生产发布模式
43
+
44
+ ```
45
+ from dotask import task
46
+ from dotask.util import logger
47
+ import random
48
+
49
+ if __name__ == '__main__':
50
+
51
+ @task(role="producer",topic="scan")
52
+ def a():
53
+ return random.randint(1,10)
54
+
55
+
56
+ @task(role="consumer",subscribe="scan",publish_after="sayHi")
57
+ def b(data):
58
+ if data >5:
59
+ return data
60
+ logger.warning(f"本次生成数字:{data},不会继续发布sayHi主题")
61
+
62
+ @task(role="consumer",subscribe="sayHi")
63
+ def c(data):
64
+ logger.debug(f"c触发")
65
+ logger.info(f"消费:{data}")
66
+ //=====================================================================
67
+ 2026-02-08 17:30:37 - INFO - 发布主题-[scan]:5
68
+ 2026-02-08 17:30:37 - WARNING - 本次生成数字:5,不会继续发布sayHi主题
69
+ 2026-02-08 17:30:38 - INFO - 发布主题-[scan]:8
70
+ 2026-02-08 17:30:38 - INFO - 发布主题-[sayHi]:8
71
+ 2026-02-08 17:30:38 - DEBUG - c触发
72
+ 2026-02-08 17:30:38 - INFO - 消费:8
73
+ 2026-02-08 17:30:38 - INFO - 发布主题-[scan]:6
74
+ 2026-02-08 17:30:38 - INFO - 发布主题-[sayHi]:6
75
+ 2026-02-08 17:30:38 - DEBUG - c触发
76
+ 2026-02-08 17:30:38 - INFO - 消费:6
77
+ //======================================================================
78
+ ```
@@ -1,6 +1,6 @@
1
1
  [metadata]
2
2
  name = dotask
3
- version = 0.2.3
3
+ version = 0.2.4
4
4
  author = dyz
5
5
  author_email = 837701454@qq.com
6
6
  description = 发布订阅注解方式
dotask-0.2.3/README.md DELETED
@@ -1,17 +0,0 @@
1
- ## 0.1.0
2
- - 在方法上添加@task就可以直接开启一个线程执行任务
3
- - 常用参数:
4
- - 生产者: role="producer",topic="自定义"
5
- - 消费者: role="consumer",subscribe="自定义",publish_after="自定义"
6
- - 说明:
7
- - role: 用于区分上下游 producer/consumer
8
- - topic: 发布的主题
9
- - subscribe: 对哪些主题感兴趣
10
- - publish_after: 消费完后继续发布新主题
11
- - 特别的:方法的返回值可以进行传递,若没有返回值则不会发布新主题(只针对消费者和消费者之间)
12
- ## 0.2.0
13
- 1. dotask暴露topic_manager=>可以更好的管理生产消费者
14
- 2. 迁移logger至util包下
15
- 3. 添加本地调用shell工具函数->可以很好的适配@task消费者
16
- 1. max_concurrent:控制并发执行的shell数量
17
- 2. 引入dotask.Shell 调用Shell(max_concurrent=?).local_shell_execute(cmd,callback)来使用
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes