blob: 6a497f8cdb22ebe4197437d6077b2a11be6d7c3b [file] [log] [blame]
/*
* Copyright 1999-2004 The Apache Software Foundation
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
/***************************************************************************
* Description: Worker list *
* Author: Gal Shachor <shachor@il.ibm.com> *
* Author: Henri Gomez <hgomez@apache.org> *
* Version: $Revision$ *
***************************************************************************/
/*
* This file includes a list of all the possible workers in the jk library
* plus their factories.
*
* If you want to add a worker just place it in the worker_factories array
* with its unique name and factory.
*
* If you want to remove a worker, hjust comment out its line in the
* worker_factories array as well as its header file. For example, look
* at what we have done to the ajp23 worker.
*
* Note: This file should be included only in the jk_worker controller.
* Currently the jk_worker controller is located in jk_worker.c
*/
#ifdef _PLACE_WORKER_LIST_HERE
#ifndef _JK_WORKER_LIST_H
#define _JK_WORKER_LIST_H
#include "jk_ajp12_worker.h"
#include "jk_ajp13_worker.h"
#include "jk_ajp14_worker.h"
#ifdef HAVE_JNI
#include "jk_jni_worker.h"
#endif
#include "jk_lb_worker.h"
struct worker_factory_record {
const char *name;
worker_factory fac;
};
typedef struct worker_factory_record worker_factory_record_t;
static jk_map_t *worker_map;
static worker_factory_record_t worker_factories[] = {
/*
* AJPv12 worker, this is the stable worker.
*/
{ JK_AJP12_WORKER_NAME, ajp12_worker_factory},
/*
* AJPv13 worker, fast bi-directional worker.
*/
{ JK_AJP13_WORKER_NAME, ajp13_worker_factory},
/*
* AJPv14 worker, next generation fast bi-directional worker.
*/
{ JK_AJP14_WORKER_NAME, ajp14_worker_factory},
/*
* In process JNI based worker. Requires the server to be
* multithreaded and to use native threads.
*/
#ifdef HAVE_JNI
{ JK_JNI_WORKER_NAME, jni_worker_factory},
#endif
/*
* Load balancing worker. Performs round robin with sticky
* session load balancing.
*/
{ JK_LB_WORKER_NAME, lb_worker_factory},
/*
* Marks the end of the worker factory list.
*/
{ NULL, NULL}
};
#endif /* _JK_WORKER_LIST_H */
#endif /* _PLACE_WORKER_LIST_HERE */