⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 jk_service.h

📁 jboss与apache集成的中间件,详情请参看文档说明.
💻 H
📖 第 1 页 / 共 2 页
字号:
     */    int (JK_METHOD * start_response) (jk_ws_service_t *s,                                      int status,                                      const char *reason,                                      const char *const *header_names,                                      const char *const *header_values,                                      unsigned num_of_headers);    /*     * Read a chunk of the request body into a buffer.  Attempt to read len     * bytes into the buffer.  Write the number of bytes actually read into     * actually_read.     */    int (JK_METHOD * read) (jk_ws_service_t *s,                            void *buffer,                            unsigned len, unsigned *actually_read);    /*     * Write a chunk of response data back to the browser.     */    int (JK_METHOD * write) (jk_ws_service_t *s,                             const void *buffer, unsigned len);    /*     * Flush a chunk of response data back to the browser.     */    void (JK_METHOD * flush) (jk_ws_service_t *s);};/* * The endpoint 'class', which represents one end of a connection to the * servlet engine.  Basically, supports nothing other than forwarding the * request to the servlet engine.  Endpoints can be persistent (as with * ajp13/ajp14, where a single connection is reused many times), or can last for a * single request (as with ajp12, where a new connection is created for * every request). * * An endpoint for a given protocol is obtained by the web server plugin * from a worker object for that protocol.  See below for details. * * As with all the core jk classes, this is essentially an abstract base * class which is implemented/extended by classes which are specific to a * particular protocol.  By using an abstract base class in this manner, * plugins can be written for different servers (e.g. IIS, Apache) without * the plugins having to worry about which protocol they are talking. * * This particular OO-in-C system uses a 'endpoint_private' pointer to * point to the protocol-specific data/functions.  So in the subclasses, the * methods do most of their work by getting their hands on the * endpoint_private pointer and then using that to get at the functions for * their protocol. * * Try imagining this as a 'public abstract class', and the * endpoint_private pointer as a sort of extra 'this' reference.  Or * imagine that you are seeing the internal vtables of your favorite OO * language.  Whatever works for you. * * See jk_ajp13_worker.c/jk_ajp14_worker.c and jk_ajp12_worker.c for examples. */struct jk_endpoint{    size_t rd;    size_t wr;    /*     * A 'this' pointer which is used by the subclasses of this class to     * point to data/functions which are specific to a given protocol     * (e.g. ajp12 or ajp13 or ajp14).     */    void *endpoint_private;    /*     * Forward a request to the servlet engine.  The request is described     * by the jk_ws_service_t object.     * is_error is either 0 meaning recoverable or set to     * the HTTP error code.     */    int (JK_METHOD * service) (jk_endpoint_t *e,                               jk_ws_service_t *s,                               jk_logger_t *l, int *is_error);    /*     * Called when this particular endpoint has finished processing a     * request.  For some protocols (e.g. ajp12), this frees the memory     * associated with the endpoint.  For others (e.g. ajp13/ajp14), this can     * return the endpoint to a cache of already opened endpoints.     *     * Note that the first argument is *not* a 'this' pointer, but is     * rather a pointer to a 'this' pointer.  This is necessary, because     * we may need to free this object.     */    int (JK_METHOD * done) (jk_endpoint_t **p, jk_logger_t *l);};/* * The worker 'class', which represents something to which the web server * can delegate requests. * * This can mean communicating with a particular servlet engine instance, * using a particular protocol.  A single web server instance may have * multiple workers communicating with a single servlet engine (it could be * using ajp12 for some requests and ajp13/ajp14 for others).  Or, a single web * server instance could have multiple workers communicating with different * servlet engines using the same protocol (it could be load balancing * among many engines, using ajp13/ajp14 for all communication). * * There is also a load balancing worker (jk_lb_worker.c), which itself * manages a group of workers. * * Web servers are configured to forward requests to a given worker.  To * handle those requests, the worker's get_endpoint method is called, and * then the service() method of that endpoint is called. * * As with all the core jk classes, this is essentially an abstract base * class which is implemented/extended by classes which are specific to a * particular protocol (or request-handling system).  By using an abstract * base class in this manner, plugins can be written for different servers * (e.g. IIS, Apache) without the plugins having to worry about which * protocol they are talking. * * This particular OO-in-C system uses a 'worker_private' pointer to * point to the protocol-specific data/functions.  So in the subclasses, the * methods do most of their work by getting their hands on the * worker_private pointer and then using that to get at the functions for * their protocol. * * Try imagining this as a 'public abstract class', and the * worker_private pointer as a sort of extra 'this' reference.  Or * imagine that you are seeing the internal vtables of your favorite OO * language.  Whatever works for you. * * See jk_ajp14_worker.c, jk_ajp13_worker.c and jk_ajp12_worker.c for examples. */struct jk_worker{    /*     * Public property to enable the number of retry attempts     * on this worker.     */    int retries;    /*     * A 'this' pointer which is used by the subclasses of this class to     * point to data/functions which are specific to a given protocol     * (e.g. ajp12 or ajp13 or ajp14).     */    void *worker_private;    int   type;    /*     * For all of the below (except destroy), the first argument is     * essentially a 'this' pointer.     */    /*     * Given a worker which is in the process of being created, and a list     * of configuration options (or 'properties'), check to see if it the     * options are.  This will always be called before the init() method.     * The init/validate distinction is a bit hazy to me.     * See jk_ajp13_worker.c/jk_ajp14_worker.c and jk_worker.c->wc_create_worker()     */    int (JK_METHOD * validate) (jk_worker_t *w,                                jk_map_t *props,                                jk_worker_env_t *we, jk_logger_t *l);    /*     * Update worker either from jk_status or reloading from workers.properties     */    int (JK_METHOD * update) (jk_worker_t *w,                              jk_map_t *props,                              jk_worker_env_t *we, jk_logger_t *l);    /*     * Do whatever initialization needs to be done to start this worker up.     * Configuration options are passed in via the props parameter.     */    int (JK_METHOD * init) (jk_worker_t *w,                            jk_map_t *props,                            jk_worker_env_t *we, jk_logger_t *l);    /*     * Obtain an endpoint to service a particular request.  A pointer to     * the endpoint is stored in pend.     */    int (JK_METHOD * get_endpoint) (jk_worker_t *w,                                    jk_endpoint_t **pend, jk_logger_t *l);    /*     * Shutdown this worker.  The first argument is not a 'this' pointer,     * but rather a pointer to 'this', so that the object can be free'd (I     * think -- though that doesn't seem to be happening.  Hmmm).     */    int (JK_METHOD * destroy) (jk_worker_t **w, jk_logger_t *l);    /*     * Maintain this worker.     */    int (JK_METHOD * maintain) (jk_worker_t *w, jk_logger_t *l);};/* * Essentially, an abstract base class (or factory class) with a single * method -- think of it as createWorker() or the Factory Method Design * Pattern.  There is a different worker_factory function for each of the * different types of workers.  The set of all these functions is created * at startup from the list in jk_worker_list.h, and then the correct one * is chosen in jk_worker.c->wc_create_worker().  See jk_worker.c and * jk_ajp13_worker.c/jk_ajp14_worker.c for examples. * * This allows new workers to be written without modifing the plugin code * for the various web servers (since the only link is through * jk_worker_list.h). */typedef int (JK_METHOD * worker_factory) (jk_worker_t **w,                                          const char *name,                                          jk_logger_t *l);void jk_init_ws_service(jk_ws_service_t *s);#ifdef __cplusplus}#endif                          /* __cplusplus */#endif                          /* JK_SERVICE_H */

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -