[APACHE DOCUMENTATION]

Apache HTTP Server Version 1.3

Manual Page: apxs

NAME
     apxs - APache eXtenSion tool

SYNOPSIS
     apxs -g [ -S variable=value ] -n name

     apxs -q [ -S variable=value ] query ...

     apxs -c [ -S variable=value ] [ -o dsofile ] [ -I incdir ] [
     -D  variable[=value]  ]  [  -L  libdir  ]  [  -l libname ] [
     -Wc,compiler-flags ] [ -Wl,linker-flags ] files ...

     apxs -i [ -S variable=value ] [ -n name ] [ -a ] [ -A ] dso-
     file ...

     apxs -e [ -S variable=value ] [ -n name ] [ -a ] [ -A ] dso-
     file ...

DESCRIPTION
     apxs is a tool for building and installing extension modules
     for  the  Apache  HyperText Transfer Protocol (HTTP) server.
     This is achieved by building a Dynamic Shared  Object  (DSO)
     from  one  or  more source or object files which then can be
     loaded into the Apache server under runtime via the  LoadMo-
     dule directive from mod_so.

     So to use this extension mechanism,  your  platform  has  to
     support  the DSO feature and your Apache httpd binary has to
     be built with the mod_so module.  The  apxs  tool  automati-
     cally complains if this is not the case.  You can check this
     yourself by manually running the command

       $ httpd -l

     The module mod_so should be part of the displayed list.   If
     these requirements are fulfilled, you can easily extend your
     Apache server's functionality by installing your own modules
     with the DSO mechanism by the help of this apxs tool:

       $ apxs -i -a -c mod_foo.c
       gcc -fpic -DSHARED_MODULE -I/path/to/apache/include -c mod_foo.c
       ld -Bshareable -o mod_foo.so mod_foo.o
       cp mod_foo.so /path/to/apache/libexec/mod_foo.so
       chmod 755 /path/to/apache/libexec/mod_foo.so
       [activating module `foo' in /path/to/apache/etc/httpd.conf]
       $ apachectl restart
       /path/to/apache/sbin/apachectl restart: httpd not running, trying to start
       [Tue Mar 31 11:27:55 1998] [debug] mod_so.c(303): loaded module foo_module
       /path/to/apache/sbin/apachectl restart: httpd started
       $ _

     The arguments files can be any C source file (.c), a  object
     file  (.o)  or  even  a  library archive (.a). The apxs tool
     automatically recognizes these extensions and  automatically
     uses  the  C source files for compilation while it just uses
     the object and archive files for the linking phase. But when
     using such pre-compiled objects, make sure they are compiled
     for Position Independent Code (PIC) to be able to  use  them
     for a DSO. For instance with GCC you always just have to use
     -fpic.  For other C compilers please consult its manual page
     or  watch  for  the  flags  apxs  uses to compile the object
     files.

     For more details about DSO support in Apache, first read the
     background  information about DSO in htdocs/manual/dso.html,
     then read the documentation of mod_so.

OPTIONS
     Common options:

     -n name     This explicitly sets the module name for the  -i
                 (install)  and  -g (template generation) option.
                 Use this to explicitly specify the module  name.
                 For  option  -g  this is required, for option -i
                 the apxs tool tries to determine the  name  from
                 the source or (as a fallback) at least by guess-
                 ing it from the filename.

     Query options:

     -q          Performs a query for apxs's knowledge about cer-
                 tain  settings.  The query parameters can be one
                 or more of the following variable names:
                   CC              TARGET
                   CFLAGS          SBINDIR
                   CFLAGS_SHLIB    INCLUDEDIR
                   LD_SHLIB        LIBEXECDIR
                   LDFLAGS_SHLIB   SYSCONFDIR
                   LIBS_SHLIB      PREFIX
                 Use this for manually determining settings.  For
                 instance use
                   INC=-I`apxs -q INCLUDEDIR`
                 inside your own Makefiles  if  you  need  manual
                 access to Apache's C header files.

     Configuration options:

     -S variable=value
                 This option changes the apxs settings  described
                 above.

     Template Generation options:
     -g          This generates a subdirectory name  (see  option
                 -n)  and there two files: A sample module source
                 file named mod_name.c which can  be  used  as  a
                 template  for  creating your own modules or as a
                 quick start for playing with the apxs mechanism.
                 And  a  corresponding  Makefile  for even easier
                 building and installing of this module.

     DSO compilation options:

     -c          This indicates  the  compilation  operation.  It
                 first  compiles the C source files (.c) of files
                 into corresponding object files  (.o)  and  then
                 builds  a DSO in dsofile by linking these object
                 files plus the remaining object  files  (.o  and
                 .a)  of  files  If no -o option is specified the
                 output file is guessed from the  first  filename
                 in   files   and   thus   usually   defaults  to
                 mod_name.so

     -o dsofile  Explicitly specifies the filename of the created
                 DSO  file.  If not specified and the name cannot
                 be guessed from the  files  list,  the  fallback
                 name mod_unknown.so is used.

     -D variable[=value]
                 This option is directly passed  through  to  the
                 compilation  command(s).   Use  this to add your
                 own defines to the build process.

     -I incdir   This option is directly passed  through  to  the
                 compilation  command(s).   Use  this to add your
                 own include directories to search to  the  build
                 process.

     -L libdir   This option is directly passed  through  to  the
                 linker  command.   Use  this  to  add  your  own
                 library directories to search to the build  pro-
                 cess.

     -l libname  This option is directly passed  through  to  the
                 linker  command.   Use  this  to  add  your  own
                 libraries to search to the build process.

     -Wc,compiler-flags
                 This option passes compiler-flags as  additional
                 flags  to the compiler command.  Use this to add
                 local compiler-specific options.

     -Wl,linker-flags
                 This option passes  linker-flags  as  additional
                 flags  to  the  linker command.  Use this to add
                 local linker-specific options.

     DSO installation and configuration options:

     -i          This indicates the  installation  operation  and
                 installs  one  or  more  DSOs  into the server's
                 libexec directory.

     -a          This  activates  the  module  by   automatically
                 adding   a   corresponding  LoadModule  line  to
                 Apache's httpd.conf configuration  file,  or  by
                 enabling it if it already exists.

     -A          Same as option -a  but  the  created  LoadModule
                 directive is prefixed with a hash sign (#), i.e.
                 the module is just prepared for later activation
                 but initially disabled.

     -e          This indicates the editing operation, which  can
                 be  used with the -a and -A options similarly to
                 the -i operation  to  edit  Apache's  httpd.conf
                 configuration file without attempting to install
                 the module.

EXAMPLES
     Assume you have an Apache module named  mod_foo.c  available
     which should extend Apache's server functionality. To accom-
     plish this you first have to compile the C source into a DSO
     suitable  for  loading  into the Apache server under runtime
     via the following command:

       $ apxs -c mod_foo.c
       gcc -fpic -DSHARED_MODULE -I/path/to/apache/include -c mod_foo.c
       ld -Bshareable -o mod_foo.so mod_foo.o
       $ _

     Then you have to update the Apache configuration  by  making
     sure  a LoadModule directive is present to load this DSO. To
     simplify this step apxs provides an automatic way to install
     the   DSO  in  the  "libexec"  directory  and  updating  the
     httpd.conf file accordingly. This can be  achieved  by  run-
     ning:

       $ apxs -i -a mod_foo.c
       cp mod_foo.so /path/to/apache/libexec/mod_foo.so
       chmod 755 /path/to/apache/libexec/mod_foo.so
       [activating module `foo' in /path/to/apache/etc/httpd.conf]
       $ _

     This way a line named

       LoadModule foo_module libexec/mod_foo.so

     is added to the configuration file if still not present.  If
     you  want  to have this operation to be disabled, use the -A
     option, i.e.

       $ apxs -i -A mod_foo.c

     For a quick test of the apxs mechanism you can create a sam-
     ple  Apache  module  template  plus a corresponding Makefile
     via:

       $ apxs -g -n foo
       Creating [DIR]  foo
       Creating [FILE] foo/Makefile
       Creating [FILE] foo/mod_foo.c
       $ _

     Then you can immediately compile this sample module  into  a
     DSO and load it into the Apache server:

       $ cd foo
       $ make all reload
       apxs -c mod_foo.c
       gcc -fpic -DSHARED_MODULE -I/path/to/apache/include -c mod_foo.c
       ld -Bshareable -o mod_foo.so mod_foo.o
       apxs -i -a -n "foo" mod_foo.so
       cp mod_foo.so /path/to/apache/libexec/mod_foo.so
       chmod 755 /path/to/apache/libexec/mod_foo.so
       [activating module `foo' in /path/to/apache/etc/httpd.conf]
       apachectl restart
       /path/to/apache/sbin/apachectl restart: httpd not running, trying to start
       [Tue Mar 31 11:27:55 1998] [debug] mod_so.c(303): loaded module foo_module
       /path/to/apache/sbin/apachectl restart: httpd started
       $ _

     You can even use apxs to compile complex modules outside the
     Apache  source  tree,  like PHP3, because apxs automatically
     recognized C source files and object files.

       $ cd php3
       $ ./configure --with-shared-apache=../apache-1.3
       $ apxs -c -o libphp3.so mod_php3.c libmodphp3-so.a
       gcc -fpic -DSHARED_MODULE -I/tmp/apache/include  -c mod_php3.c
       ld -Bshareable -o libphp3.so mod_php3.o libmodphp3-so.a
       $ _

     Only C source files  are  compiled  while  remaining  object
     files are used for the linking phase.

SEE ALSO
     apachectl(1), httpd(8).


Apache HTTP Server Version 1.3

Index Home