celery中task和share_task的区别

task:

装饰函数,将函数当成celery的任务函数

import time
from celery import Celery
app=Celery('tasks',broker='redis://192.168.10.48:6379',backend='redis://192.168.10.48:6379)

@app.task
def xxxxxx(x, y):
 time.sleep(10)
 return x + y

share_task:

1. 装饰函数,将函数当成celery的任务函数,

2. 不依赖某个celery对象,而是加载到内存之后自动添加到celery对象中

3. 与多个celery对象进行关联

import time
from celery import Celery
from celery import shared_task
share_task֢
app=Celery('tasks',broker='redis://192.168.10.48:6379',backend='redis://192.168.10.8:63')

@shared_task
def xxxxxx(x, y):
 time.sleep(10)
 return x + y
 

s1.py
 import time
 from celery import Celery
 app = Celery('tasks',broker='r...')
 
s2.py
 from celery import shared_task
 @shared_task
 def x1(x, y):
 time.sleep(10)
 return x + y

s3.py
import s1
import s2
import time
from celery import Celery
from celery import shared_task
app1 = Celery('t1',broker='redis://192.168.10.48:6379')
app2 = Celery('t2',broker='redis://192.168.10.49:6379')

@app1.task
def x1(x, y):
 time.sleep(10)
 return x + y

@app2.task
def x2():
 return 666

@shared_task
def x3():
 pass

​

### .gitignore 文件示例与模板 #### 基础规则说明 `.gitignore` 文件用于定义不应被 Git 跟踪的文件模式。这有助于防止不必要的或敏感的数据进入版本控制系统[^4]。 #### 示例 `.gitignore` 文件内容 对于不同类型的项目,`.gitignore` 的设置也会有所不同。以下是几个常见的例子: ##### Python 项目 适用于Python项目的典型 `.gitignore` 配置如下所示: ```plaintext # Byte-compiled / optimized / DLL files __pycache__/ *.py[cod] *$py.class # C extensions *.so # Distribution / packaging .Python build/ develop-eggs/ dist/ downloads/ eggs/ .eggs/ lib/ lib64/ parts/ sdist/ var/ wheels/ pip-wheel-metadata/ share/python-wheels/ *.egg-info/ .installed.cfg setup.cfg # PyInstaller # Usually these files are written by a python script from a template # before PyInstaller builds the exe, so as to inject date/other infos into it. *.manifest *.spec # Installer logs pip-log.txt pip-delete-this-directory.txt # Unit test / coverage reports htmlcov/ .tox/ .nox/ .coverage .coverage.* .cache nosetests.xml coverage.xml *,cover .hypothesis/ # Translations *.mo *.pot # Django stuff: .db.sqlite3* # Flask project related instance/ .webassets-cache # Scrapy stuff: .scrapy # Sphinx documentation docs/_build/ # PyBuilder target/ # Jupyter Notebook .ipynb_checkpoints # IPython profile_default/ ipython_config.py # pyenv .python-version # pipenv # According to pypa/pipenv#598, it is recommended to include Pipfile.lock in version control. # However, in case of collaboration, if having platform-specific dependencies or dependencies # having no cross-platform support, pipenv may install dependencies that don’t work, or not # install all needed dependencies. Pipfile.lock # celery beat schedule file celerybeat-schedule # SageMath parsed files .sage.py # Environments .env .venv env/ venv/ ENV/ env.bak/ venv.bak/ # Spyder project settings .spyderproject .spyproject # Rope project settings .ropeproject # mkdocs documentation /site # mypy .mypy_cache/ .dmypy.json dmypy.json # VS Code workspace metadata and cache directories .vscode/* !.vscode/settings.json !.vscode/tasks.json !.vscode/launch.json !.vscode/extensions.json .history ``` ##### Node.js 项目 针对Node.js环境下的 `.gitignore` 可能会像这样设计: ```plaintext # Logs logs *.log npm-debug.log* yarn-debug.log* yarn-error.log* # Runtime data pids *.pid *.seed *.pid.lock # Directory for instrumented libs generated by jscoverage/JSCover lib-cov # Coverage directory used by tools like istanbul coverage # nyc test coverage .nyc_output # Grunt intermediate storage (https://gruntjs.com/creating-plugins#storing-task-files) .grunt # Bower dependency directory (https://bower.io/) bower_components # node_modules node_modules # Compiled binary addons (https://nodejs.org/api/addons.html) build/Release # Dependency directories for tooling like nodemon .dylans # Optional npm cache directory .npm # Optional eslint cache .eslintcache # Optional REPL history default $HOME/.node_repl_history .node_repl_history # Output of 'npm pack' *.tgz # Yarn Integrity file .yarn-integrity # dotenv environment variables file .env .env.test # parcel-bundler cache (https://parceljs.org/) .cache # next.js build output .next # Nuxt.js build/output directory .nuxt # vuepress build output .vuepress/dist # Serverless directories .serverless/ # FuseBox cache .fusebox/ # DynamoDB Local files .dynamodb/ ``` ##### Java/Maven 项目 Java开发尤其是采用Maven构建工具时,可能会有类似的忽略列表: ```plaintext /target/ !/.mvn/wrapper/maven-wrapper.jar ###### IDE Specific ###### .idea/ .project .settings/ .recommenders/ ###### OS Generated Files ###### .DS_Store .DS_Store? ._* .Spotlight-V100 .Trashes ehthumbs.db Thumbs.db ###### Mobile Projects ###### android/build/ ios/build/ platforms/ plugins/ hooks/ www/cordova_plugins.js www/cordova.js.map ``` #### 创建自定义 `.gitignore` 模板的方法 为了简化新项目的初始化过程,可以利用现成的资源来快速生成适合特定编程语言技术栈的 `.gitignore` 文件。GitHub提供了官方支持的一系列预设模版,访问 [GitHub/gitignore](https://github.com/github/gitignore) 即可获取更多种类的选择并下载对应的模板文件。 另外,在本地环境中也可以通过命令行方式创建全局范围内的默认排除项清单,只需执行 `git config --global core.excludesfile ~/.gitignore_global` 并编辑该路径指向的实际文件即可实现跨多个仓库应用相同的忽略策略[^3]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

骑台风走

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值