jumpserver/apps/common
Bai 7707101379 perf: 优化飞书信息通知文案 2023-08-15 08:17:24 +05:00
..
api perf: 修改支持 Django4 2023-07-24 11:52:25 +08:00
auth fix some typos 2023-06-19 15:19:41 +08:00
const perf: 修改支持 Django4 2023-07-24 11:52:25 +08:00
db fix: 启动500 (#11133) 2023-07-31 18:31:11 +08:00
drf perf: 修改支持 Django4 2023-07-24 11:52:25 +08:00
hashers pref: 修改添加 gather facts 2022-10-14 19:40:51 +08:00
management perf: 连接方式新增 guide 模式 (#11237) 2023-08-09 19:59:53 +05:00
migrations
plugins Update es.py 2023-07-31 17:53:08 +08:00
sdk perf: 优化飞书信息通知文案 2023-08-15 08:17:24 +05:00
serializers Merge pull request #11048 from huiserwang/dev_huiserwang 2023-07-24 10:15:28 +08:00
storage feat: 支持文件上传下载备份 (#10438) 2023-06-08 18:04:07 +08:00
templatetags
urls fix: 修复 su-from-accounts API; 前端 Select2 组件初始化时 API 报错的问题; 2022-12-07 19:26:28 +08:00
utils feat: 系统工具改为异步,增加tcpdump工具 2023-08-07 10:18:51 +08:00
views Update mixins.py 2023-06-14 17:10:38 +08:00
README.md
__init__.py fix: ignore 2023-03-09 18:12:56 +08:00
apps.py perf: 修改 gettext 2023-07-24 14:09:22 +08:00
cache.py perf: 优化部分云厂商的redis连接的问题 2022-04-15 10:00:49 +08:00
decorators.py feat: 账号密钥用vault储存 (#10830) 2023-07-31 17:39:30 +08:00
exceptions.py perf: 优化confirm接口 (#8451) 2022-07-04 11:29:39 +08:00
local.py fix: 有可能保存明文密码 2023-03-09 13:02:34 +08:00
permissions.py perf: dashboard user amount (#9582) 2023-02-16 14:27:54 +08:00
signal_handlers.py perf: 修改 logging 避免冲突 2023-06-21 17:49:16 +08:00
signals.py
struct.py
tasks.py perf: 修改支持 Django4 2023-07-24 11:52:25 +08:00
tests.py
thread_pools.py
tree.py
validators.py perf: 修改支持 Django4 2023-07-24 11:52:25 +08:00

README.md

Common app

Common app provide common view, function or others.

Common app shouldn't rely on other apps, because It may lead to cycle import.

If your want to implement some function or class, you should think whether other app use or not. If yes, You should make in common.

If the ability more relate to your app tightness, It's mean your app provide this ability, not common, You should write it on your app utils.

Celery usage

JumpServer use celery to run task async. Using redis as the broker, so you should run a redis instance

Run redis

$ yum -y install redis 

or

$ docker run -name jumpserver-redis -d -p 6379:6379 redis redis-server

Write tasks in app_name/tasks.py

ops/tasks.py

from __future__ import absolute_import

import time
from celery import shared_task
from common import celery_app


@shared_task
def longtime_add(x, y):
    print 'long time task begins'
    # sleep 5 seconds
    time.sleep(5)
    print 'long time task finished'
    return x + y
    

@celery_app.task(name='hello-world')
def hello():
    print 'hello world!'
  

Run celery in development

$ cd apps
$ celery -A common worker -l info 

Test using task

$ ./manage.py shell
>>> from ops.tasks import longtime_add
>>> res = longtime_add.delay(1, 2)
>>> res.get()