add changelog for 1.13
[beanstalkd.git] / doc / protocol.zh-CN.md
bloba72a816f535b669b363d7669a8b41100ecb8c6b1
1 # Beanstalkd中文协议
3 ### 总括
5 `beanstalkd` 协议基于 ASCII 编码运行在 tcp 上. 客户端连接服务器并发送指令和数据,然后等待响应并关闭连接. 对于每个连接,服务器按照接收命令的序列依次处理并响应. 所有整型值都非负的十进制数,除非有特别声明.
7 ### 名称约定
9 所有名称必须是 ASCII 码字符串,即包括:
11 * **字母** (A-Z and a-z)
12 * **数字** (0-9)
13 * **连字符** ("-")
14 * **加号** ("+")
15 * **斜线** ("/")
16 * **分号** (";")
17 * **点** (".")
18 * **美元符** ("$")
19 * **下划线** ("_")
20 * **括号** ("*(*" and "*)*")
22 **注意**:名称不能以连字符开始,并且是以空白字符结束,每个名称至少包含一个字符.
24 ### 错误说明
26 | 返回的错误                               | 描述       |
27 | --------------------------------------- | -------- |
28 | `OUT_OF_MEMORY\r\n`                     | 服务器没有足够的内存分配给特定的 job,客户端应该稍后重试 |
29 | `INTERNAL_ERROR\r\n`                    | 服务器内部错误,该错误不应该发生,如果发生了,请报告: [http://groups.google.com/group/beanstalk-talk](http://groups.google.com/group/beanstalk-talk).|
30 | `BAD_FORMAT\r\n`                         | 格式不正确,客户端发送的指令格式出错,有可能不是以 `\r\n` 结尾,或者要求整型值等等 |
31 | `UNKNOWN_COMMAND\r\n`                   | 未知的命令,客户端发送的指令服务器不理解 |
33 ### job 的生命周期
35 Client 使用 put 命令创建一个工作任务 job. 在整个生命周期中 job 可能有四个工作状态:ready、reserved、delayed、buried. 在 put 操作之后,一个 job 的典型状态是 ready,在 ready 队列中,它将等待一个 worker 取出此 job 并设置为其为 reserved 状态. worker占有此 job 并执行,当 job 执行完毕,worker 可以发送一个 delete 指令删除此 job.
37 | Status              | Description   |
38 | --------------------| ------------- |
39 | `ready`             | 等待被取出并处理 |
40 | `reserved`          | 如果 job 被 worker 取出,将被此 worker 预订,worker 将执行此 job |
41 | `delayed`           | 等待特定时间之后,状态再迁移为 `ready` 状态 |
42 | `buried`            | 等待唤醒,通常在 job 处理失败时进入该状态
44 #### job 典型的生命周期
46 ```text
47    put            reserve               delete
48   -----> [READY] ---------> [RESERVED] --------> *poof*
49 ```
51 #### job 可能的状态迁移
53 ```text
54    put with delay               release with delay
55   ----------------> [DELAYED] <------------.
56                         |                   |
57                  kick   | (time passes)     |
58                         |                   |
59    put                  v     reserve       |       delete
60   -----------------> [READY] ---------> [RESERVED] --------> *poof*
61                        ^  ^                |  |
62                        |   \  release      |  |
63                        |    `-------------'   |
64                        |                      |
65                        | kick                 |
66                        |                      |
67                        |       bury           |
68                     [BURIED] <---------------'
69                        |
70                        |  delete
71                         `--------> *poof*
72 ```
74 ## Tubes
76 一个 beanstalkd 实例服务可能有一个或者多个 tube,用来储存统一类型的 job.每个 tube 由一个就绪 (`ready`) 队列与延迟 (`delayed`) 队列组成.每个 job 所有的状态迁移在一个 tube 中完成.通过发送 `watch` 指令, 消费者 consumers 可以监控感兴趣的 tube.通过发送 `ignore` 指令, 消费者 consumers 可以取消监控 tube.通过 `list-tubes-watched`命令返回所有监控的 tubes,当客户端预订 (`reserved`) 一个 job,此 job 可能来自任何一个它监控的 tube.
78 当一个客户端连接上服务器时,客户端监控的 tube 默认为 `defaut`,如果客户端提交 job 时,没有使用 `use` 命令,那么这些 job 就存于名为`default`的 tube 中.
80 tube 按需求创建,无论他们在什么时候被引用到.如果一个 tube 变为空(即 no ready jobs,no delayed jobs,no buried jobs)和没有任何客户端引用(being watched),它将会被**自动删除**.
82 ### 指令说明(Commands)
84 #### 生产者指令说明(Producer Commands)
86 #### `put`
88 插入一个 job 到队列
90 **指令格式**
92 ```text
93 put <pri> <delay> <ttr> <bytes>\r\n
94 <data>\r\n
95 ```
97 * `<pri>` 整型值, 为优先级, 可以为0-2^32 (4,294,967,295) 值越小优先级越高, 默认为1024.
98 * `<delay>` 整型值,延迟`ready`的秒数,在这段时间 job 为 `delayed` 状态. 最大 delay 值为 2^32-1.
99 * `<ttr>` -- time to run --整型值,允许 worker 执行的最大秒数,如果 worker 在这段时间不能 delete,release,bury job,那么当 job 超时,服务器将**自动** release 此job,此 job 的状态迁移为`ready`. 最小为 1 秒,如果客户端指定为 0 将会被重置为 1. 最大 ttr 值为 2^32-1.
100 * `<bytes>` 整型值,job body的长度,不包含`\r\n`,这个值必须小于 `max-job-size`,默认为 2^16.
101 * `<data>`   job body
103 **响应**
105 ```text
106 INSERTED <id>\r\n
109 表示插入 job 成功,id 为新 job 的任务标识,整型值 (uint64)
111 ```text
112 BURIED <id>\r\n
115 如服务器为了增加队列的优先级而,内存不足时返回,id 为新 job 的任务标识,整型值 (uint64)
117 ```text
118 EXPECTED_CRLF\r\n
121 job body 必须以 `\r\n` 结尾
123 ```text
124 JOB_TOO_BIG\r\n
127 job body 的长度超过 `max-job-size`
129 ```text
130 DRAINING\r\n
133 表示服务器资源耗尽,表示服务器已经进入了`drain mode`,服务器再也不能接受连接,客户端应该使用其他服务器或者断开稍后重试
135 #### `use`
137 producer 生产者使用,之后使用的 put 指令,都将会把 job 放置于 use 的 tube 中,如果没有指定 use 的 tube, 任务 job 将会进入默认名称为 `default` 的 tube 
139 **指令格式**
141 ```text
142 use <tube>\r\n
143 tube tube 的名称,最大为 200 字节,不存在时将自动创建
146 **响应**
148 ```text
149 USING <tube>\r\n tube 为正在使用的tube名称
152 #### 消费者指令说明(Worker Commands)
154 #### `reserve`
156 预订(reserved) job 等待处理. beanstalkd 将返回一个新预订的 job,如果没有 job,beanstalkd 将一直等待到有 job 时才发送响应. 一旦 job 状态迁移为 `reserved`, 取出 job 的 client 被限制在指定的时间(如果设置了ttr)完成,否则将超时,job 状态重装迁移为ready.
158 **指令格式**
160 ```text
161 reserve\r\n
164 可选的一个相似的命令
165 `reserve-with-timeout \r\n` 设置取 job 的超时时间,timeout 设置为 0 时,服务器立即响应或者 TIMED_OUT,积极的设置超时,将会限制客户端阻塞在取 job 的请求的时间.
167 ##### 失败响应
169 ```text
170 DEADLINE_SOON\r\n
173 * 在一个预定的任务 job 的运行时间内, **最后一秒**会被服务器保持为一个**安全边际**,在这个**时间间隔** (1s) 中,client 将无法获取其他任务. 如果客户端在安全隔离期间发出一个预留 (reserve) 指令,或者客户端在等候一个预定 (reserve) 指令返回结果时,client 安全隔离期到达时,将会收到 `DEADLINE_SOON` 回复
174 * `DEADLINE_SOON` 的返回结果提示 client 这是一个 delete 或者 touch 它所预订(reserved) 的任务 job 的时机,之后 beanstalkd 服务端将会自动释放 `ttr` 到期的 job
176 ```text
177 TIMED_OUT\r\n 超时
180 ##### 成功响应
182 ```text
183 RESERVED <id> <bytes>\r\n
184 <data>\r\n
187 成功取出 job:
189 * `<id>` 为 job id,整型值
190 * `<bytes>` 为 job body 的长度,不包含`\r\n`,
191 * `<data>` 为job body
193 #### `delete`
195 从队列中删除一个job
197 **指令格式**
199 ```text
200 delete <id>\r\n
203 * `<id>` 为 job id
205 **响应**
207 ```text
208 DELETED\r\n
211 * 删除成功
213 ```text
214 NOT_FOUND\r\n
217 * job 不存在时,或者 job 并不为当前的 client 所 reserved;
218 * job 的状态不为 `ready`和 `buried`(这种情况是在 job 被其他 client 所预订(reserved) 且还未执行超时,此时当前 client 发送了 delete 指令就会收到 `NOT_FOUND` 回复)
220 #### `release`
222 release 指令将一个`reserved`的 job 恢复为`ready`. 它通常在 job 执行失败时使用.
224 **指令格式**
226 ```text
227 release <id> <pri> <delay>\r\n
230 * `<id>` 为job id
231 * `<pri>` 为 job 的优先级
232 * `<delay>` 为延迟`ready`的秒数
235 **响应**
237 ```text
238 RELEASED\r\n 表明成功
239 BURIED\r\n 如服务器为了增加队列的优先级而,内存不足时返回
240 bury <id> <pri>\r\n
243 * `<id>` 为 job id
244 * `<pri>` 为优先级
246 **响应**
248 ```text
249 BURIED\r\n 表明成功
250 NOT_FOUND\r\n 如果 job 不存在或者 client 没有预订此 job
253 #### `touch`
255 允许 worker 请求更多的时间执行 job;当 job 需要更长的时间来执行,这个指令就将会起作用,worker 可用周期性的告诉服务器它仍然在执行job(可以被 `DEADLINE_SOON` 触发)
257 **指令格式**
259 ```text
260 touch <id>\r\n
263 * `<id>` 为 job id
265 **响应**
267 ```text
268 TOUCHED\r\n 表明成功
269 NOT_FOUND\r\n 如果 job 不存在或者 client 没有预订此 job
272 #### `watch`
274 添加监控的 tube 到 watch list 列表,reserve 指令将会从监控的 tube 列表获取 job,对于每个连接,监控的列表默认为 `default`
276 **指令格式**
278 ```text
279 watch <tube>\r\n
282 * `<tube>` 为监控的 tube 名称,名称最大为 200 字节,如果 tube 不存在会**自动创建**
284 **响应**
286 ```text
287 WATCHING <count>\r\n 表明成功
290 * `<count>` 整型值,已监控的 tube 数量
292 #### `ignore`
294 从已监控的 watch list 列表中移出特定的 tube 
296 **指令格式**
298 ```text
299 ignore <tube>\r\n
302 * `<tube>` 为移出的 tube 名称,名称最多为 200 字节,如果 tube 不存在会自动创建
304 **响应**
306 ```text
307 WATCHING <count>\r\n 表明成功
310 * `<count>` 整型值,已监控的tube数量
312 ```text
313 NOT_IGNORED\r\n
316 * 如果 client 尝试忽略其仅有的tube时的响应
318 #### 其他指令说明(Other Command)
320 #### `peek`
322 让 client 在系统中检查 job,有四种形式的命令,其中第一种形式的指令是针对当前使用 (use) 的 tube
324 **指令格式**
326 ```text
327 peek <id>\r\n  返回 id 对应的 job
328 peek-ready\r\n 返回下一个 ready job
329 peek-delayed\r\n 返回下一个延迟剩余时间最短的 job
330 peek-buried\r\n 返回下一个在 buried 列表中的 job
333 **响应**
335 ```text
336 NOT_FOUND\r\n
337 ``` 
339 * 如果 job 不存在,或者没有对应状态的 job
341 ```text
342 FOUND <id> <bytes>\r\n <data>\r\n
345 * `<id>` 为对应的 job id
346 * `<bytes>` job body 的字节数
347 * `<data>` 为 job body
349 #### `kick`
351 此指令应用在当前使用 (use) 的 tube 中,它将 job 的状态迁移为`ready`或者`delayed`
352 **指令格式**
354 ```text
355 kick <bound>\r\n
358 * `<bound>` 整型值,唤醒的 job 上限
360 **响应**
363 KICKED <count>\r\n
365 * `<count>` 为真实唤醒的job数量
367 #### kick-job
369 kick 指令的一个变体,可以使单个 job 被唤醒,使一个状态为`buried`或者`delayed`的 job迁移为`ready`,所有的状态迁移都在相同的 tube 中完成
371 **指令格式**
373 ```text
374 kick-job <id>\r\n
376 * `<id>` 为job id
378 **响应**
379 `NOT_FOUND\r\n` 如果 job 不存在,或者 job 是不可唤醒的状态
380 `KICKED\r\n` 表明成功
382 #### `stats-job`
384 统计 job 的相关信息
386 **指令格式**
388 ```text
389 stats-job <id>\r\n
392 * `<id>` 为 job id
394 **响应**
396 ```text
397 NOT_FOUND\r\n 如果job不存在
399 OK <bytes>\r\n<data>\r\n
402 * `<bytes>` 为接下来的 data 区块的长度
403 * `<data>` 为 YAML file 的统计信息
405 其中 YAML file 包括的 key 有:
407 * `id` 表示 job id
408 * `tube` 表示 tube 的名称
409 * `state` 表示 job 的当前状态
410 * `pri` 表示 job 的优先级
411 * `age` 表示 job 创建的时间单位秒
412 * `time-left` 表示 job 的状态迁移为 ready 的时间,仅在 job 状态为`reserved`或者`delayed`时有意义,当 job 状态为`reserved`时表示剩余的超时时间.
413 * `file` 表示包含此 job 的`binlog`序号,如果没有开启它将为 0
414 * `reserves` 表示 job 被`reserved`的次数
415 * `timeouts` 表示 job 处理的超时时间
416 * `releases` 表示 job 被`released`的次数
417 * `buries` 表示 job 被`buried`的次数
418 * `kicks` 表示 job 被`kiced`的次数
420 #### `stats-tube`
422 统计 tube 的相关信息
424 **指令格式**
426 ```text
427 stats-tube <tube>\r\n
430 * `<tube>` 为对应的 tube 的名称,最多为 200 字节
432 **响应**
434 ```text
435 NOT_FOUND\r\n
437 * 如果tube不存在
439 ```text
440 OK <bytes>\r\n
441 <data>\r\n
444 * `<bytes>` 为接下来的 data 区块的长度
445 * `<data>` 为 YAML file的统计信息
447 其中 YAML file 包括的 key 有:
449 * `name` 表示tube的名称
450 * `current-jobs-urgent` 此 tube 中优先级小于 1024 状态为`ready`的 job 数量
451 * `current-jobs-ready` 此 tube 中状态为`ready`的 job 数量
452 * `current-jobs-reserved` 此 tube 中状态为`reserved`的 job 数量
453 * `current-jobs-delayed` 此 tube 中状态为`delayed`的 job 数量
454 * `current-jobs-bureid` 此 tube 中状态为`buried`的job数量
455 * `total-jobs` 此 tube 中创建的所有job数量
456 * `current-using` 使用此 tube 打开的连接数
457 * `current-wating` 使用此 tube 打开连接并且等待响应的连接数
458 * `current-watching` 打开的连接监控此 tube 的数量
459 * `pause` 此 tube 暂停的秒数
460 * `cmd-delete` 此 tube 中总共执行的`delete`指令的次数
461 * `cmd-pause-tube` 此 tube 中总共执行`pause-tube`指令的次数
462 * `pause-time-left` 此 tube 暂停剩余的秒数
464 #### `stats`
466 返回整个消息队列系统的整体信息
468 **指令格式**
470 ```text
471 stats\r\n
474 **响应**
476 ```text
477 OK <bytes>\r\n
478 <data>\r\n
480 * `<bytes>` 为接下来的 data 区块的长度
481 * `<data>` 为 YAML file 的统计信息
483 从 beanstalkd 进程启动以来,所有的信息都累积的,这些信息不储存在 binlog 中
484 其中 YAML file 包括的key有:
486 * `current-jobs-urgent` 优先级小于 1024 状态为`ready`的 job 数量
487 * `current-jobs-ready` 状态为`ready`的 job 数量
488 * `current-jobs-reserved` 状态为`reserved`的 job 数量
489 * `current-jobs-delayed` 状态为`delayed`的 job 数量
490 * `current-jobs-bureid` 状态为`buried`的 job 数量
491 * `cmd-put` 总共执行`put`指令的次数
492 * `cmd-peek` 总共执行`peek`指令的次数
493 * `cmd-peek-ready` 总共执行`peek-ready`指令的次数
494 * `cmd-peek-delayed` 总共执行`peek-delayed`指令的次数
495 * `cmd-peek-buried` 总共执行`peek-buried`指令的次数
496 * `cmd-reserve` 总共执行`reserve`指令的次数
497 * `cmd-use` 总共执行`use`指令的次数
498 * `cmd-watch` 总共执行`watch`指令的次数
499 * `cmd-ignore` 总共执行`ignore`指令的次数
500 * `cmd-release` 总共执行`release`指令的次数
501 * `cmd-bury` 总共执行`bury`指令的次数
502 * `cmd-kick` 总共执行`kick`指令的次数
503 * `cmd-stats` 总共执行`stats`指令的次数
504 * `cmd-stats-job` 总共执行`stats-job`指令的次数
505 * `cmd-stats-tube` 总共执行`stats-tube`指令的次数
506 * `cmd-list-tubes` 总共执行`list-tubes`指令的次数
507 * `cmd-list-tube-used` 总共执行`list-tube-used`指令的次数
508 * `cmd-list-tubes-watched` 总共执行`list-tubes-watched`指令的次数
509 * `cmd-pause-tube` 总共执行`pause-tube`指令的次数
510 * `job-timeouts` 所有超时的 job 的总共数量
511 * `total-jobs` 创建的所有 job 数量
512 * `max-job-size` job 的数据部分最大长度
513 * `current-tubes` 当前存在的 tube 数量
514 * `current-connections` 当前打开的连接数
515 * `current-producers` 当前所有的打开的连接中至少执行一次 put 指令的连接数量
516 * `current-workers` 当前所有的打开的连接中至少执行一次 reserve 指令的连接数量
517 * `current-waiting` 当前所有的打开的连接中执行 reserve 指令但是未响应的连接数量
518 * `total-connections` 总共处理的连接数
519 * `pid` 服务器进程的 id
520 * `version` 服务器版本号
521 * `rusage-utime` 进程总共占用的用户 CPU 时间
522 * `rusage-stime` 进程总共占用的系统 CPU 时间
523 * `uptime` 服务器进程运行的秒数
524 * `binlog-oldest-index` 开始储存 jobs 的 binlog 索引号
525 * `binlog-current-index` 当前储存 jobs 的 binlog 索引号
526 * `binlog-max-size` binlog 的最大容量
527 * `binlog-records-written` binlog 累积写入的记录数
528 * `binlog-records-migrated` is the cumulative number of records written as part of compaction.
529 * `id` 一个随机字符串,在 beanstalkd 进程启动时产生
530 * `hostname` 主机名
532 #### `list-tubes`
534 列出当前 beanstalkd 所有存在的 tubes
536 **指令格式**
538 ```text
539 list-tubes\r\n
542 **响应**
544 ```text
545 OK <bytes>\r\n
546 <data>\r\n
549 * `<bytes>` 为接下来的 data 区块的长度
550 * `<data>` 为 YAML file,包含所有的 tube 名称
552 #### `list-tube-used`
554 列出当前 client 正在 use 的 tube
556 **指令格式**
558 ```text
559 list-tube-used\r\n
562 **响应**
564 ```text
565 USING <tube>\r\n
568 * `<tube>` 为 tube 名称
570 #### `list-tubes-watched`
572 列出当前 client 所 watch 的 tubes
574 **指令格式**
576 ```text
577 list-tubes-watched\r\n
580 **响应**
582 ```text
583 OK <bytes>\r\n
584 <data>\r\n
587 * `<bytes>` 为接下来的 data 区块的长度
588 * `<data>` 为 YAML file,包含所有的 tube 名称
590 #### `quit`
592 client 向 beanstalkd 发送 `quit` 报文,并关闭连接,beanstalkd 收到该报文后主动关闭连接
594 **指令格式**
596 ```text
597 quit\r\n
600 无响应
602 #### `pause-tube`
604 此指令针对特定的 tube 内所有新的 job 延迟指定的秒数
606 **指令格式**
608 ```text
609 pause-tube <tube-name> <delay>\r\n
612 * `<delay>` 延迟的时间
614 **响应**
616 ```text
617 PAUSED\r\n 表示成功
618 NOT_FOUND\r\n tube 不存在
622 > Translated by PHPBoy :http://www.phpboy.net/ and fzb.me
623 Revised by Pseudocodes: https://github.com/pseudocodes