Provided by: libapache2-mod-mono_3.8-3build1_amd64 bug

NAME

       mod_mono - apache module that enables ASP.NET pages. Works together with mod-mono-server.exe

DESCRIPTION

       mod_mono is a simple module that works with Apache 2.0 or newer.

       It  needs  mod-mono-server.exe  installed  on  the  system.  By  default, it will attemp to run mod-mono-
       server.exe if it doesn't find it's running.

CONFIGURATION DIRECTIVES

       All the directives but MonoSetServerAlias accept an optional first argument that is  the  mod-mono-server
       instance alias for which the directive applies.  If only one argument is provided for them, thr directive
       will  apply  to the 'default' mod-mono-server instance. Refer to the monodoc documentation on configuring
       mod_mono for more examples.

       MonoUnixUmask
              It accepts an octal number as a parameter. The number must be a  valid  unix  file  creation  mask
              value (see umask(2)). The mask will be applied whenever a directory or file is created from within
              an ASP.NET application.  Default value: "0077".

       MonoUnixSocket
              It  accepts  a  file  name  as  argument. That file will be a named pipe used to send/receive data
              from/to mod_mono to/from mod-mono-server.  You cannot use MonoListenPort and MonoUnixSocket at the
              same time.  Default value: "/tmp/mod_mono_server".

       MonoListenPort
              TCP port  on  which  mod-mono-server  should  listen/is  listening  on.  Mutually  exclusive  with
              MonoUnixSocket. When this options is specified, mod-mono-server and mod_mono will use a TCP socket
              for communication.  Default value: none

       MonoListenBacklog N
              The backlog of connections to set on the listener socket in mod-mono-server.  By default the value
              is set to 500.

       MonoMinThreads N
              The minimum number of threads the threadpool allocates in mod-mono-server.  Increase this value to
              better  handle  the  sudden  arrival  of connections.  The default value is determined by the mono
              runtime.

       MonoListenAddress
              IP  address  where  mod-mono-server  should  listen/is  listening  on.  Can  only  be  used   when
              MonoListenPort is specified.  Default value: "127.0.0.1"

       MonoRunXSP
              If  the value is True, it tells mod_mono to spawn mod-mono-server.exe if it's not already running.
              If set to False, most of these directives are useless.  Default value: True

       MonoXSPStartAttempts
              Number of times mod_mono will attempt to start a backend which died. Value cannot be lower than 0.
              Default value: 3

       MonoXSPStartWaitTime
              Number of seconds to wait after starting the backend.  This  is  to  let  the  backend  initialize
              properly before attempting to connect to it. Value cannot be lower than 2.  Default value: 2

       MonoAutoRestartMode
              Set  the  auto-restart  mode  for  the  backend(s). Three modes are available: None - do not auto-
              restart, Requests - restart after a configured number of requests served, Time - restart after the
              backend has been up for the specified period of time.  Note that if you  enable  auto-restart  you
              should consider using off-process state server, since on every restart your application state will
              be lost.  Default value: None

       MonoAutoRestartRequests
              Number  of  requests  for  a backend to serve before auto-restarting. The value here is taken into
              account only when MonoAutoRestartMode is set to Requests.  Default value: 10000

       MonoAutoRestartTime
              Time after which the backend should be auto-restarted.  The  time  format  is:  DD[:HH[:MM[:SS]]].
              Default value: 00:12:00:00

       MonoExecutablePath (Obsoleted, ignored)
              Don't  use  this. It is ignored and has been left here for compatibility purposes.  Default value:
              "/usr/bin/mono"

       MonoPath
              This value will be used to set the MONO_PATH environment variable.  Default value: ""

       MonoServerPath
              The full path to the mod-mono-server script.  Default value: "/usr/bin/mod-mono-server"

       MonoTargetFramework
              If MonoRunXSP is True, this option selects the .NET framework version to  use.  This  affects  the
              backend  that  is started to service the requests. The MonoServerPath option takes precedence over
              this setting. Available values are "2.0", "3.5" and "4.0".  Default value: "2.0"

       MonoWapiDir
              The directory where mono runtime will create the ".wapi" directory used to  emulate  windows  I/O.
              It's used to set MONO_SHARED_DIR.  Default value: "/tmp"

       MonoDocumentRootDir
              The directory passed in --root argument when launching mod-mono-server.

       MonoMaxCPUTime
              If  MonoRunXSP  is  True,  CPU  time limit in seconds allowed for the spawned mono process. Beyond
              that, it will be restarted. If this capability is not available on your system, the directive will
              be ignored.  Default value: system default

       MonoMaxMemory
              If MonoRunXSP is True, the maximum size of the process's data segment (data size) in bytes allowed
              for the spawned mono process.  It will be restarted when the limit is reached. If this  capability
              is not available on your system, the directive will be ignored.  Default value: system default

       MonoApplications

       AddMonoApplications
              This  value  will be passed to mod-mono-server.exe in the --applications option. See xsp(1) manual
              page for details.

       MonoApplicationsConfigFile
              The argument passed in --appconfigfile argument to mod-mono-server.  Default value: NULL.

       MonoApplicationsConfigDir
              The argument passed in --appconfigdir argument to  mod-mono-server.   Default  value:  config/mod-
              mono-applications

       Note   that   you   must  specify  at  least  one  of  MonoApplications,  MonoApplicationsConfigFile  and
       MonoApplicationsConfigDir.

       MonoAutoApplication
              Enables or disables automatic ASP.NET applications discovery. By default it is enabled if you have
              no application configured.  Otherwise,  it's  disabled.  The  possible  values  are  'enabled'  or
              'disabled'.

       MonoDebug
              Runs mono in debug mode, which produces stack traces with line numbers.  Default value: False.

       MonoSetServerAlias
              Takes  a  server  alias name. This is to be used inside <Directory> or <Location>.  Default value:
              'default' if the directive is not used.

       MonoSetEnv
              Takes a string of 'name=value' pairs separated by semicolons.  For  each  pair,  it  calls  setenv
              (name, value) before running mod-mono-server.

       MonoIOMAP
              Takes  alias  name  and  a  string  of  the  same format and meaning as the MONO_IOMAP environment
              variable (see the mono(1) manpage). The effect is that mod_mono performs the same actions as  mono
              runtime  with  MONO_IOMAP  in  effect,  as well as that the MONO_IOMAP variable with the specified
              value is exported in the  backend  environment.   This  option  is  necessary  when  you're  using
              MONO_IOMAP  in  your  application  and there might be static files with mixed case names - in such
              case mod_mono attempts to open the file directly and sends it using  apache  facilities.   Default
              value: none

       MonoMaxActiveRequests
              The  maximum  number  of concurrent requests mod_mono will pass off to the ASP.NET backend. Set to
              zero to turn off the limit. Default value: 0.

       MonoMaxWaitingRequests
              The maximum number of concurrent requests mod_mono will hold while the  ASP.NET  backend  is  busy
              with  the  maximum  number  of requests specified by MonoMaxActiveRequests. Requests that can't be
              processed or held are dropped with Service Unavailable. Default value: 150.

       MonoCheckHiddenFiles
              Do not protect hidden files/directories from being accessed by clients.  Hidden  files/directories
              are  those  with  Hidden  attribute  on  Windows  and  whose  name  starts with a dot on Unix. Any
              file/directory below a hidden directory is inacessible. This option turns the default behavior  of
              protecting  such locations off. If your application does not contain any hidden files/directories,
              you might want to use this option as the checking  process  has  a  per-request  cost.  Accepts  a
              boolean   value   -   'true'   or   'false'   Default   value:   true.    AppSettings   key  name:
              MonoServerCheckHiddenFiles.

SAMPLE VIRTUAL HOST CONFIGURATION

       Note that the configuration below requires the mod_mono module to be loaded by Apache. How it is done  is
       distribution-specific - please check your distribution documentation for details.

       This one using <Directory>:
             Alias /mono "/usr/lib/xsp/test"
             AddMonoApplications default "/mono:/usr/lib/xsp/test"
             <Directory /usr/lib/xsp/test>
                     SetHandler mono
                     <IfModule mod_dir.c>
                           DirectoryIndex index.aspx
                     </IfModule>
             </Directory>

       This one using <Location>:
             Alias /demo "/usr/lib/xsp/test"
             AddMonoApplications default "/demo:/usr/lib/xsp/test"
             <Location /demo>
                     SetHandler mono
             </Location>

       If  you prefer to .webapp configuration file(s) (see manual page of xsp), you can change MonoApplications
       in the above samples by:

             MonoApplicationsConfigFile default "/var/www/applications.webapp"

       replacing the path to the file with yours.

       If you want to use several .webapp files, use this instead:

             MonoApplicationsConfigDir default "/var/www/webapp"

       and all the .webapp files found in the directory /var/www/webapp will be loaded.

       Refer to monodoc documentation on configuring mod_mono for more examples.

THE MOD_MONO CONTROL PANEL

       mod_mono provides a simple web-based control panel for restarting the mod-mono-server,  which  is  useful
       when  assemblies  need  to  be  reloaded from disk after they have been changed.  To activate the control
       panel, place the following in your httpd.conf:

                   <Location /mono>
                     SetHandler mono-ctrl
                     Order deny,allow
                     Deny from all
                     Allow from 127.0.0.1
                   </Location>

       The control panel is then accessible at http://yourdomain.com/mono.  Clicking the link  to  restart  mod-
       mono-server will immediately restart it.

       The  Order/Deny/Allow  access controls above restrict access to the control panel to the computer with IP
       address 127.0.0.1. Replace this (or add more Allow lines) with the IP address of  your  own  computer  so
       that  you  can access the control panel.  You can also use Apache's htaccess features to password protect
       it, too.

ENVIRONMENT VARIABLES

       It may modify MONO_PATH, PATH and MONO_SHARED_DIR when starting mod-mono-server.

       The MOD_MONO_CCV variable may be used to select which component will do client certificate validity (CCV)
       checks. By default both Apache and Mono will verify the client  certificates.  This  can  be  changed  to
       either  "apache"  or  "mono" to limit the validity check to either environment.  This variable can be set
       using MonoSetEnv to allow different vhost to use separate validation techniques.

       The MOD_MONO_LOCKING_MECHANISM variable may  be  used  to  choose  the  APR  locking  mechanism  for  the
       dashboard.  The  currently  defined  mechanism  names  are:  DEFAULT, FCNT, FLOCK, SYSVSEM, PROC_PTHREAD,
       POSIXSEM. Note that not every mechanism may be available for your platform. In such case,  mod_mono  will
       fallback  to using the DEFAULT value which lets the APR decide which locking mechanism to use. DEFAULT is
       also the default value for the option if the environment variable is not set or  its  value  is  unknown.
       This  value  MUST  NOT  be set using MonoSetEnv - it MUST be present in the Apache environment before the
       module is initialized and its configuration parsed.

FILES

       httpd.conf

AUTHORS

       mod_mono  was  started  by  Daniel  Ridruejo   (daniel   rawbyte   com).   Currently,   Marek   Habersack
       (mhabersack@novell.com) is the maintainer.

MAILING LISTS

       See http://mail.ximian.com/mailman/mono-list for details.

WEB SITE

       Visit http://mono-project.com/Mod_mono for details.

SEE ALSO

       xsp(1),mod-mono-server(1),mono(1),mcs(1)

mod_mono 3.8                                       28 Jan 2009                                       mod_mono(8)