No Description

tomoya e52eecfb00 modify README 1 year ago
media 8461235bfc add two images on README 1 year ago
README.md e52eecfb00 modify README 1 year ago
docker-compose.yml 497a811dee first commit 1 year ago
tasks.py 497a811dee first commit 1 year ago

README.md

Redis-Celery (Distributed Architecture)

This includes

  • Redis
  • Flower

sample case sample case

Usage (docker-compose)

  • start the system

    add ``` -d ``` run in background  
    * down the system   
    ctrl-c or  
    

    docker-compose down ```

Celery

Celery Documentation
Flower Documentation

install Celery

pip install -U "celery[redis]" 

Starting the worker

celery -A proj worker 

Options

Worker Options:
  -n, --hostname HOSTNAME         Set custom hostname (e.g., 'w1@%%h').  
                                  Expands: %%h (hostname), %%n (name) and %%d, (domain).  
  -D, --detach                    Start worker as a background process.  
  -S, --statedb PATH              Path to the state database. The extension  
                                  '.db' may be appended to the filename.  
  -l, --loglevel [DEBUG|INFO|WARNING|ERROR|CRITICAL|FATAL]  
                                  Logging level.  
  -O, --optimization [default|fair]  
                                  Apply optimization profile.  
  --prefetch-multiplier <prefetch multiplier>  
                                  Set custom prefetch multiplier value for  
                                  this worker instance.  
Pool Options:  
  * -c, --concurrency <concurrency>  
                                Number of child processes processing the  
                                queue.  The default is the number of CPUs  
                                available on your system.  

### woker in Windows
add ``` --pool=solo ``` option   

### Calling the task

shell

from tasks import hello hello.delay()

If your celery app set rsult backend

from tasks import hello
result = hello.delay()

The ready() method returns whether the task has finished processing or not:

result.ready() False

You can wait for the result to complete, but this is rarely used since it turns the asynchronous call into a synchronous one:

result.get(timeout=1) 'hello world' ```