NAME
disbatch - CLI to the Disbatch Command Interface (DCI).
VERSION
version 4.102
SYNOPSIS
disbatch [<arguments>] <command> [<command arguments>]
ARGUMENTS
- --url <URL>
-
URL for the DCI you wish to connect to. Default is
http://localhost:8080
. - --username <username>
-
DCI username
- --password <password>
-
DCI password
- --help
-
Display this message
- --ssl_ca_file <ssl_ca_file>
-
Path to the SSL CA file. Needed if using SSL with a private CA.
- --disable_ssl_verification
-
Disables hostname verification if SSL is used.
Only used if
--ssl_ca_file
is not used. - --config <config_file>
-
Path to Disbatch config file. Default is
/etc/disbatch/config.json
.Only used if neither
--ssl_ca_file
nor--disable_ssl_verification
is used.Note: the SSL settings in the Disbatch config file are for MongoDB, but ideally if using SSL with MongoDB, then it is also being used with the DCI.
COMMANDS
- plugins
-
List all allowed plugin names.
$ disbatch plugins Disbatch::Plugin::Demo
- queues
-
List all queues this disbatch server processes.
$ disbatch queues ID | Plugin | Name | Threads | Queued | Running | Completed | -------------------------+------------------------+------+---------+--------+---------+-----------+- 56eade3aeb6af81e0123ed21 | Disbatch::Plugin::Demo | demo | 0 | 0 | 0 | 0 | 1 total queues.
Note:
status
is an alias forqueues
. - create-queue <name> <plugin>
-
Create a new queue.
$ disbatch create-queue fizz Disbatch::Plugin::Demo Created queue fizz: 579a6735eb6af83e5a5297d5
Error examples:
$ disbatch create-queue Error posting http://localhost:8080/queues (400 Bad Request): {"plugin":"","error":"Unknown plugin"} $ disbatch create-queue test Error posting http://localhost:8080/queues (400 Bad Request): {"plugin":"","error":"Unknown plugin"} $ disbatch create-queue test Disbatch::Plugin::Fake Error posting http://localhost:8080/queues (400 Bad Request): {"plugin":"Disbatch::Plugin::Fake","error":"Unknown plugin"}
- update-queue <queue> <field> <value> [<field> <value> ...]
-
Change a field's value in a queue. Valid fields are
name
,plugin
, andthreads
.$ disbatch update-queue 579a6735eb6af83e5a5297d5 name buzz Updated queue 579a6735eb6af83e5a5297d5: {"name":"buzz"}
Error examples:
$ disbatch update-queue 579a6eaeeb6af87dc52d17e1 Error posting http://localhost:8080/queues/579a6eaeeb6af87dc52d17e1 (400 Bad Request): {"error":"no params"} $ disbatch update-queue 579a6eaeeb6af87dc52d17e1 bad field Error posting http://localhost:8080/queues/579a6eaeeb6af87dc52d17e1 (400 Bad Request): {"error":"unknown param","param":"bad"} $ disbatch update-queue 579a6eaeeb6af87dc52d17e1 threads Must pass an even number of arguments as key/value pairs $ disbatch update-queue 579a6eaeeb6af87dc52d17e1 threads zero Error posting http://localhost:8080/queues/579a6eaeeb6af87dc52d17e1 (400 Bad Request): {"error":"threads must be a non-negative integer"} $ disbatch update-queue 579a6eaeeb6af87dc52d17e1 plugin Disbatch::Plugin::Fake Error posting http://localhost:8080/queues/579a6eaeeb6af87dc52d17e1 (400 Bad Request): {"plugin":"Disbatch::Plugin::Fake","error":"unknown plugin"} $ disbatch update-queue 579a7059eb6af87dcc6ef4e3 threads 0 Error posting http://localhost:8080/queues/579a7059eb6af87dcc6ef4e3 (400 Bad Request): {"MongoDB::UpdateResult":{"matched_count":0,"upserted_id":null,"write_concern_errors":[],"write_errors":[],"modified_count":0},"error":"MongoDB::UpdateResult=HASH(0x401de18)"} $ disbatch update-queue 579a7059eb6af87dcc6ef4e3 name demo Error posting http://localhost:8080/queues/579a7059eb6af87dcc6ef4e3 (400 Bad Request): {"MongoDB::UpdateResult":{"matched_count":0,"upserted_id":null,"write_concern_errors":[],"write_errors":[],"modified_count":0},"error":"MongoDB::UpdateResult=HASH(0x401de18)"}
- delete-queue <queue>
-
Delete a queue.
$ disbatch delete-queue 579a6735eb6af83e5a5297d5 Deleted queue 579a6735eb6af83e5a5297d5 $ disbatch delete-queue fizz Deleted queue fizz
Error examples:
$ disbatch delete-queue 579a6eaeeb6af87dc52d17e1 Error deleting http://localhost:8080/queues/579a6eaeeb6af87dc52d17e1 (400 Bad Request): {"error":"MongoDB::DeleteResult=HASH(0x35344b8)","MongoDB::DeleteResult":{"deleted_count":0,"write_concern_errors":[],"write_errors":[]}} $ disbatch delete-queue fizz Error deleting http://localhost:8080/queues/fizz (400 Bad Request): {"error":"MongoDB::DeleteResult=HASH(0x3106520)","MongoDB::DeleteResult":{"deleted_count":0,"write_concern_errors":[],"write_errors":[]}}
- create-task <queue> [<key> <value> ...]
-
Creates a task in the specified queue with the given params.
$ disbatch create-task 579a49d6eb6af83e5b4ceec1 user1 ashley user2 ashley Created 1 tasks in queue 579a49d6eb6af83e5b4ceec1 579a67b3eb6af83e612d8c58
Error examples:
$ disbatch create-task Queue name not given
- create-tasks <queue> <array_of_params>
-
Creates multiple tasks in the specified queue with the given params.
$ disbatch create-tasks 579a49d6eb6af83e5b4ceec1 '[{"fizz":1}]' Created 1 tasks in queue 579a49d6eb6af83e5b4ceec1 579a67dbeb6af83e5930fc72
Error examples:
$ disbatch create-tasks 579a7059eb6af87dcc6ef4e2 Error posting http://localhost:8080/tasks/579a7059eb6af87dcc6ef4e2 (400 Bad Request): {"error":"params must be a JSON array of task params"} $ disbatch create-tasks 579a7059eb6af87dcc6ef4e2 '{}' Error posting http://localhost:8080/tasks/579a7059eb6af87dcc6ef4e2 (400 Bad Request): {"error":"params must be a JSON array of task params"} $ disbatch create-tasks 579a7059eb6af87dcc6ef4e2 '[]' Error posting http://localhost:8080/tasks/579a7059eb6af87dcc6ef4e2 (400 Bad Request): {"MongoDB::InsertManyResult":{"acknowledged":1,"inserted":[],"write_concern_errors":[],"write_errors":[]},"error":"Unknown error"} $ disbatch create-tasks 579ba809eb6af868d538f631 '[{"fizz":1},{"buzz":2}]' Error posting http://localhost:8080/tasks/579ba809eb6af868d538f631 (400 Bad Request): {"error":"queue not found"} $ disbatch create-tasks DNE '[{"fizz":1},{"buzz":2}]' Error posting http://localhost:8080/tasks/fizzzzzzz (400 Bad Request): {"error":"queue not found"}
- create-tasks <queue> --collection <collection> <json_object>
-
Creates multiple tasks in the specified queue with the given params, based off a filter from another collection.
The
json_object
must have fieldsfilter
andparams
whose values are Objects.In the below example, the
users
collection is queried for all documents matching{migration: "foo"}
. These documents are then used to set task params, and the values from the query collection are accessed by prependingdocument.
.$ disbatch create-tasks 56eade3aeb6af81e0123ed21 --collection users '{"filter":{"migration":"foo"},"params":{"user":"document.username","migration":"document.migration"}}' Created 2 tasks in queue 56eade3aeb6af81e0123ed21 579b72a5eb6af86a8f5220f1 579b72a5eb6af86a8f5220f2
Error examples:
$ disbatch --collection DNE create-tasks 579a7059eb6af87dcc6ef4e2 '{"filter":{"migration":"foo"},"params":{"user":"document.username"}}' Error posting http://localhost:8080/tasks/test/DNE (400 Bad Request): {"MongoDB::InsertManyResult":{"acknowledged":1,"inserted":[],"write_concern_errors":[],"write_errors":[]},"error":"Unknown error"}
- tasks [<json_filter>] [[--limit <limit>] [--skip <skip>] [--fields] [--noterse] [--epoch] [--pretty] | [--count]]
-
Returns a JSON array of task documents matching the JSON query given. Note that blessed values may be munged to be proper JSON. Limit of
20
documents returned by default.$ disbatch tasks '{"queue":"56eade3aeb6af81e0123ed21"}' [{"ctime":1469805221.996,"stderr":null,"status":-2,"mtime":1469805221.996,"_id":{"$oid":"579b72a5eb6af86a8f5220f1"},"node":null,"params":{"migration":"foo","user":"ashley"},"queue":{"$oid":"56eade3aeb6af81e0123ed21"},"stdout":null},{"ctime":1469805221.996,"stderr":null,"status":-2,"mtime":1469805221.996,"_id":{"$oid":"579b72a5eb6af86a8f5220f2"},"node":null,"params":{"migration":"foo","user":"matt"},"queue":{"$oid":"56eade3aeb6af81e0123ed21"},"stdout":null}]
The option
--limit
can be used to change the maxinum number of documents returned. The option--skip
can be used to skip that number of documents in returned results. The option--fields
can be used to only return the specified fields of tasks.The option
--noterse
can be used to disable terse mode (on by default). If enabled, the GridFS id or"[terse mode]"
will be returned forstdout
andstderr
of each document. If disabled, the actual values ofstdout
andstderr
will be returned, which may be a MongoDB::OID object. The option--full
will replace any MongoDB::OID values ofstdout
andstderr
with their full content.The option
--epoch
will returnctime
andmtime
as FIXME instead of FIXME.The option
--pretty
can be used to have the response pretty-printed.If the option
--count
is used, returns a count of the matching task documents instead.$ disbatch tasks '{"queue":"56eade3aeb6af81e0123ed21"}' --count 2 tasks
Error examples:
$ disbatch tasks '[]' Invalid filter is not a JSON object: '[]' $ disbatch tasks '{"status":-2}' Error getting http://localhost:3002/tasks (400 Bad Request): {"error":"non-indexed params given","indexes":[["id"],["node","status","queue","id"],["queue","status"]],"invalid_params":["status"],"path":"/tasks","title":"Disbatch Tasks Query"}
- search [<json_filter>] [--options <options>] [--count | --terse]
-
DEPRECATED: requires Disbatch::Web::Tasks. use the new tasks command above.
Returns a JSON array of task documents matching the JSON query given. Note that blessed values may be munged to be proper JSON. Limit of
100
documents returned.$ disbatch search '{"params.migration":"foo"}' [{"ctime":1469805221.996,"stderr":null,"status":-2,"mtime":1469805221.996,"_id":{"$oid":"579b72a5eb6af86a8f5220f1"},"node":null,"params":{"migration":"foo","user":"ashley"},"queue":{"$oid":"56eade3aeb6af81e0123ed21"},"stdout":null},{"ctime":1469805221.996,"stderr":null,"status":-2,"mtime":1469805221.996,"_id":{"$oid":"579b72a5eb6af86a8f5220f2"},"node":null,"params":{"migration":"foo","user":"matt"},"queue":{"$oid":"56eade3aeb6af81e0123ed21"},"stdout":null}]
The option
--pretty
can be used to have the response pretty-printed.If the option
--count
is used, returns a count of the matching task documents instead.$ disbatch search '{"params.migration":"foo"}' --count 2 tasks
The option
--options
can be used to pass additional options to MongoDB::Collection#find. It's value is a JSON Object. Use--options '{"limit":20}'
to return only the first 20 documents (default is 100). This will fail if you try to set it above 100.The option
--noterse
can be used to disable terse mode (on by default). If enabled, the GridFS id or"[terse mode]"
will be returned forstdout
andstderr
of each document. If disabled, the full content ofstdout
andstderr
will be returned.Error examples:
$ disbatch search '[]' Error posting http://localhost:8080/tasks/search (400 Bad Request): {"error":"filter and options must be name/value objects"} $ disbatch search '"foo"' Invalid filter is not JSON: '"foo"'
SEE ALSO
AUTHORS
Ashley Willis <awillis@synacor.com>
Matt Busigin
COPYRIGHT AND LICENSE
This software is Copyright (c) 2016, 2019 by Ashley Willis.
This is free software, licensed under:
The Apache License, Version 2.0, January 2004