blob: 14355e170fa4c6c3d0804eccb5a0c8a8e4119a59 [file] [log] [blame]
/*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright ownership.
* The ASF licenses this file to You 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"
#include "jk_status.h"
struct worker_factory_record
{
const char *name;
int type;
worker_factory fac;
};
typedef struct worker_factory_record worker_factory_record_t;
static worker_factory_record_t worker_factories[] = {
/*
* AJPv12 worker, this is the stable worker.
*/
{JK_AJP12_WORKER_NAME, JK_AJP12_WORKER_TYPE, ajp12_worker_factory},
/*
* AJPv13 worker, fast bi-directional worker.
*/
{JK_AJP13_WORKER_NAME, JK_AJP13_WORKER_TYPE, ajp13_worker_factory},
/*
* AJPv14 worker, next generation fast bi-directional worker.
*/
{JK_AJP14_WORKER_NAME, JK_AJP14_WORKER_TYPE, 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, JK_JNI_WORKER_TYPE, jni_worker_factory},
#endif
/*
* Load balancing worker. Performs round robin with sticky
* session load balancing.
*/
{JK_LB_WORKER_NAME, JK_LB_WORKER_TYPE, lb_worker_factory},
/*
* Status worker. Performs display display and
* worker management.
*/
{JK_STATUS_WORKER_NAME, JK_STATUS_WORKER_TYPE, status_worker_factory},
/*
* Marks the end of the worker factory list.
*/
{NULL, 0, NULL}
};
#endif /* _JK_WORKER_LIST_H */
#endif /* _PLACE_WORKER_LIST_HERE */