您最多选择25个主题 主题必须以字母或数字开头,可以包含连字符 (-),并且长度不得超过35个字符
 
 
 

84 行
2.0 KiB

  1. package gearman
  2. import (
  3. "net"
  4. "os"
  5. // "log"
  6. )
  7. type jobClient struct {
  8. conn net.Conn
  9. worker *Worker
  10. running bool
  11. }
  12. func newJobClient(addr string, worker *Worker) (jobclient *jobClient, err os.Error) {
  13. conn, err := net.Dial(TCP, addr)
  14. if err != nil {
  15. return nil, err
  16. }
  17. jobclient = &jobClient{conn:conn, worker:worker, running:true}
  18. return jobclient, err
  19. }
  20. func (client *jobClient) Work() {
  21. noop := true
  22. OUT: for client.running {
  23. // grab job
  24. if noop {
  25. client.WriteJob(NewWorkerJob(REQ, GRAB_JOB, nil))
  26. }
  27. var rel []byte
  28. for {
  29. buf := make([]byte, 2048)
  30. n, err := client.conn.Read(buf)
  31. if err != nil {
  32. if err == os.EOF && n == 0 {
  33. break
  34. }
  35. client.worker.ErrQueue <- err
  36. continue OUT
  37. }
  38. rel = append(rel, buf[0: n] ...)
  39. }
  40. job, err := DecodeWorkerJob(rel)
  41. if err != nil {
  42. client.worker.ErrQueue <- err
  43. continue
  44. } else {
  45. switch(job.dataType) {
  46. case NOOP:
  47. noop = true
  48. case NO_JOB:
  49. noop = false
  50. client.WriteJob(NewWorkerJob(REQ, PRE_SLEEP, nil))
  51. case ECHO_RES, JOB_ASSIGN_UNIQ, JOB_ASSIGN:
  52. job.client = client
  53. client.worker.incoming <- job
  54. }
  55. }
  56. }
  57. return
  58. }
  59. func (client *jobClient) WriteJob(job *WorkerJob) (err os.Error) {
  60. return client.Write(job.Encode())
  61. }
  62. func (client *jobClient) Write(buf []byte) (err os.Error) {
  63. var n int
  64. for i := 0; i < len(buf); i += n {
  65. n, err = client.conn.Write(buf[i:])
  66. if err != nil {
  67. return err
  68. }
  69. }
  70. return
  71. }
  72. func (client *jobClient) Close() (err os.Error) {
  73. client.running = false
  74. err = client.conn.Close()
  75. return
  76. }