job.h 5.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149
  1. /* vim:expandtab:shiftwidth=2:tabstop=2:smarttab:
  2. *
  3. * Gearmand client and server library.
  4. *
  5. * Copyright (C) 2011-2012 Data Differential, http://datadifferential.com/
  6. * Copyright (C) 2008 Brian Aker, Eric Day
  7. * All rights reserved.
  8. *
  9. * Redistribution and use in source and binary forms, with or without
  10. * modification, are permitted provided that the following conditions are
  11. * met:
  12. *
  13. * * Redistributions of source code must retain the above copyright
  14. * notice, this list of conditions and the following disclaimer.
  15. *
  16. * * Redistributions in binary form must reproduce the above
  17. * copyright notice, this list of conditions and the following disclaimer
  18. * in the documentation and/or other materials provided with the
  19. * distribution.
  20. *
  21. * * The names of its contributors may not be used to endorse or
  22. * promote products derived from this software without specific prior
  23. * written permission.
  24. *
  25. * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
  26. * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
  27. * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
  28. * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
  29. * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
  30. * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
  31. * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
  32. * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
  33. * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
  34. * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
  35. * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
  36. *
  37. */
  38. /**
  39. * @file
  40. * @brief Job Declarations
  41. */
  42. #pragma once
  43. #include <libgearman-server/struct/job.h>
  44. /** @addtogroup gearman_server_job Job Declarations @ingroup gearman_server
  45. *
  46. * This is a low level interface for gearman server jobs. This is used
  47. * internally by the server interface, so you probably want to look there first.
  48. *
  49. * @{
  50. */
  51. #ifdef __cplusplus
  52. extern "C" {
  53. #endif
  54. /**
  55. * Add a new job to a server instance.
  56. */
  57. GEARMAN_API
  58. gearman_server_job_st *
  59. gearman_server_job_add(gearman_server_st *server,
  60. const char *function_name, size_t function_name_size,
  61. const char *unique, size_t unique_size,
  62. const void *data, size_t data_size,
  63. gearman_job_priority_t priority,
  64. gearman_server_client_st *server_client,
  65. gearmand_error_t *ret_ptr,
  66. int64_t when);
  67. GEARMAN_API
  68. gearman_server_job_st *
  69. gearman_server_job_add_reducer(gearman_server_st *server,
  70. const char *function_name, size_t function_name_size,
  71. const char *unique, size_t unique_size,
  72. const char *reducer, size_t reducer_name_size,
  73. const void *data, size_t data_size,
  74. gearman_job_priority_t priority,
  75. gearman_server_client_st *server_client,
  76. gearmand_error_t *ret_ptr,
  77. int64_t when);
  78. /**
  79. * Initialize a server job structure.
  80. */
  81. GEARMAN_API
  82. gearman_server_job_st *
  83. gearman_server_job_create(gearman_server_st *server);
  84. /**
  85. * Free a server job structure.
  86. */
  87. GEARMAN_API
  88. void gearman_server_job_free(gearman_server_job_st *server_job);
  89. /**
  90. * Get a server job structure from the job handle.
  91. */
  92. GEARMAN_API
  93. gearman_server_job_st *gearman_server_job_get(gearman_server_st *server,
  94. const char *job_handle,
  95. const size_t job_handle_length,
  96. gearman_server_con_st *worker_con);
  97. /**
  98. * See if there are any jobs to be run for the server worker connection.
  99. */
  100. GEARMAN_API
  101. gearman_server_job_st *
  102. gearman_server_job_peek(gearman_server_con_st *server_con);
  103. /**
  104. * Start running a job for the server worker connection.
  105. */
  106. GEARMAN_API
  107. gearman_server_job_st *
  108. gearman_server_job_take(gearman_server_con_st *server_con);
  109. /**
  110. * Queue a job to be run.
  111. */
  112. GEARMAN_API
  113. gearmand_error_t gearman_server_job_queue(gearman_server_job_st *server_job);
  114. uint32_t _server_job_hash(const char *key, size_t key_size);
  115. void *_proc(void *data);
  116. void _server_con_worker_list_append(gearman_server_worker_st *list,
  117. gearman_server_worker_st *worker);
  118. gearman_server_job_st *gearman_server_job_get_by_unique(gearman_server_st *server,
  119. const char *unique,
  120. const size_t unique_length,
  121. gearman_server_con_st *worker_con);
  122. /** @} */
  123. void destroy_gearman_server_job_st(gearman_server_job_st *);
  124. #ifdef __cplusplus
  125. }
  126. #endif