Skip to content

Asynchronous beanstalkd driver for Common Lisp. Runs off of cl-async.

License

Notifications You must be signed in to change notification settings

orthecreedence/beanstalk-async

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

36 Commits
 
 
 
 
 
 
 
 
 
 

Repository files navigation

beanstalk-async

This library requires cl-async.

beanstalk-async is a driver to communicate asynchronously with a beastalkd server in Common Lisp. It's currently in alpha, so please don't use it for production until all the bugs/issues are ironed out.

Important note

This library was recently converted to use cl-async's futures and the command documenation below is WRONG. Don't use this library yet.

Commands

All commands take the following keyword arguments, and so are not documented individually for each command (they will be represented as "..." in the function definitions).

  • :finish-cb - The callback that is run when the command completes successfully. finish-cb takes different arguments depending on what command is run, which will be documented for each command. However, every finish-cb does take a socket parameter as the first argument, which can be used to send more commands over the same socket.
  • :event-cb - Callback that's invoked when errors or events occurs while processing a command. This can be a connection being closed, beanstalkd returning an error, etc.
  • :write-cb - This callback is called when the data being sent to beanstalkd has finished sending (ie the command data was flushed out to the socket). It can be useful to close the socket directly after sending data.
  • :socket - When given the socket passed into finish-cb, the next command will be written onto that socket instead of opening a new one.
  • :read-timeout - How many seconds to wait for data on a socket before timing out. This defaults to 5 for all commands except the reserve commands, which default to nil (no timeout).
  • :host - The host to send the command to. Ignored if :socket is given.
  • :port - The port to send the command to. Ignored if :socket is given.

Command/function reference

beanstalk-command

The low-level command that all other commands are built on top of. Supports opening a new connection, or writing data onto an existing connect (socket) if it's passed in via the :socket keyword. The socket is passed in to all finish-cb arguments, allowing more commands to be run on the same socket once a command finishes.

;; definition
(beanstalk-command command &key args data ...)

;; examples
(beanstalk-command "delete"
                   :args '(13)
                   :finish-cb (lambda (socket response)
                                ...)
                   :event-cb (lambda (err)
                               (format t "event: ~a~%" err)))

beanstalk-command isn't really meant for direct usage, although it's exposed in case you need it.

put

Add a job to the queue.

;; definition
(put priority delay ttr data &key ...)

;; example
(put 1024 0 30 "get a job"
  :finish-cb (lambda (sock status id) ...)
  :event-cb (lambda (ev) (format t "event while putting: ~a~%" ev)))

;; finish-cb definition
(lambda (socket status id) ...)

use

Use a tube.

;; definition
(use tube &key ...)

;; example
(use "instant-messages"
  :finish-cb (lambda (sock status)
               (put 1024 0 30 "LOLOL!!!!!"
                 :finish-cb (lambda (sock status id)
                              ...)
                 :socket sock)))

;; finish-cb definition
(lambda (socket status) ...)

reserve

Reserve an item from the queue. Doesn't run its finish-cb until a job is available on the watched tubes.

;; definition
(reserve &key ...)

;; example
(reserve
  :finish-cb (lambda (sock status id data)
               ...))

;; finish-cb definition
(lambda (socket status job-id job-data) ...)

data in the format-cb is a byte-array, and can be converted to a string via babel:octets-to-string.

reserve-with-timeout

Reserve an item from the queue, but if a job doesn't become available on the watched tubes before timeout seconds passes, this will call finish-cb with :timed-out in the status.

;; definition
(reserve-with-timeout timeout &key ...)

;; example
(reserve-with-timeout 5
  :finish-cb (lambda (sock status id data)
               ...))

;; finish-cb definition
(lambda (socket status job-id job-data) ...)

data in the format-cb is a byte-array, and can be converted to a string via babel:octets-to-string.

del

Delete a job in the used tube.

;; definition
(del id &key ...)

;; example
(watch "jobs"
  :finish-cb (lambda (sock status count)
               (reserve
                 :finish-cb (lambda (sock status id data)
                              (process-job id data)
                              (del id
                                :finish-cb (lambda (sock status)
                                             (quit :socket sock))
                                :socket sock))
                 :socket sock)))

;; finish-cb definition
(lambda (socket status) ...)

release

Release a job back into the queue.

;; definition
(release id priority delay &key ...)

;; example
(reserve
  :finish-cb (lambda (sock status id data)
               ;; OH NO error processing job, release it
               (release id 1024 10
                 :finish-cb (lambda (sock status)
                              ...)
                 :socket sock)))

;; finish-cb definition
(lambda (socket status) ...)

bury

Bury a job.

;; definition
(bury id priority &key ...)

;; example
(reserve
  :finish-cb (lambda (sock status id data)
               (bury id 1024
                 :finish-cb (lambda (sock status)
                              (quit :socket sock))
                 :socket sock)))

;; finish-cb definition
(lambda (socket status) ...)

touch

Refresh the ttr value on a job.

;; definition
(touch id &key ...)

;; finish-cb definition
(lambda (socket status) ...)

watch

Watch a tube.

;; definition
(watch tube &key ...)

;; finish-cb definition
(lambda (socket status number-of-watched-tubes) ...)

ignore

Ignore a tube, opposite of watch.

;; definition
(ignore tube &key ...)

;; finish-cb defintiion
(lambda (socket status number-of-watched-tubes) ...)

peek

Get a job by id (without reserving).

;; definition
(peek id &key ...)

;; example
(peek 140
  :finish-cb (lambda (sock status id data)
               (format t "found job: ~s~%" (babel:octets-to-string data))))

;; finish-cb definition
(lambda (socket status job-id job-data) ...)

peek-ready

Get the next ready job (without reserving).

;; definition
(peek-ready &key ...)

;; finish-cb definition
(lambda (socket status job-id job-data) ...)

peek-delayed

Get the next delayed job (without reserving).

;; definition
(peek-delayed &key ...)

;; finish-cb definition
(lambda (socket status job-id job-data) ...)

peek-buried

Get the next buried job (without reserving).

;; definition
(peek-buried &key ...)

;; finish-cb definition
(lambda (socket status job-id job-data) ...)

kick

Kick a number of buried jobs.

;; definition
(kick bound &key ...)

;; finish-cb definition
(lambda (socket status number-kicked-jobs) ...)

kick-job

Kick a specific job by id.

;; definition
(kick-job id &key ...)

;; finish-cb definition
(lambda (socket status) ...)

stats-job

Get extra information about a job.

;; definition
(stats-job id &key ...)

;; finish-cb defintion
(lambda (socket status stats-plist) ...)

stats-tube

Get information about a tube.

;; definition
(stats-tube tube &key ...)

;; finish-cb definition
(lambda (socket status stats-plist) ...)

stats

Get server stats.

;; definition
(stats &key ...)

;; finish-cb definition
(lambda (socket status stats-plist) ...)

list-tubes

List all tubes.

;; definition
(list-tubes &key ...)

;; finish-cb definition
(lambda (socket status list-of-tube-names) ...)

list-tubes-used

List used tubes.

;; definition
(list-tubes-used &key ...)

;; finish-cb definition
(lambda (socket status list-of-tube-names) ...)

list-tubes-watched

List watched tubes.

;; definition
(list-tubes-watched &key ...)

;; finish-cb definition
(lambda (socket status list-of-tube-names) ...)

quit

End the current connection/session. This closes the given socket (on the beanstalkd end), so any given finish-cb will generally not be called.

;; definition
(quit &key ...)

;; example
(reserve
  :finish-cb (lambda (sock status id data)
               (process-job id data)
               (quit :socket sock)))

pause-tube

Pause a tube for the specified number of seconds.

;; definition
(pause-tube tube delay &key ...)

;; finish-cb definition
(lambda (socket status) ...)

parse-beanstalk-yaml

Not a beanstalkd command, but if running raw commands via beanstalk-command, this will let you parse the YAML returned by some commands. Takes a string, so convert the data byte-array to a string before giving it to parse-beanstalk-yaml.

It is horribly simple, and only geared for parsing one-level YAML structures. It cannot deal with more complicated structures. It returns either a plist for key/value data, or a list for array data.

;; definition
(parse-beanstalk-yaml str)

Notes

This library was built as part of an effort to make asynchronous programming in Common Lisp a viable option. It is built on top of cl-async.

It is licensed MIT.

About

Asynchronous beanstalkd driver for Common Lisp. Runs off of cl-async.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published