mod_cband - A per-user, per-virtualhost and per-destination bandwidth
                             limiter for the Apache HTTP Server Version 2
					     
					     
					     Documentation
					     =============


1. Units accepted in various directives:

    * transfer speeds:
          o kbps, Mbps, Gbps - multiples of "bits per second", respectively: 1024, 1024*1024 and 1024*1024*1024 bps
          o kb/s, Mb/s, Gb/s - multiples of "bytes per second", respectively: 1024, 1024*1024 and 1024*1024*1024 b/s
          o defaults to kbps 

    * transfer quotas:
          o K, M, G - multiples of bytes, respectively: 1000, 1000*1000 and 1000*1000*1000 bytes
          o Ki, Mi, Gi - multiples of bytes, respectively: 1024, 1024*1024 and 1024*1024*1024 bytes
          o defaults to K 

    * time periods:
          o S, M, H, D, W - multiples of seconds: Seconds, Minutes, Hours, Days, Weeks; respectively: 1, 60, 3600, 86400, 604800 seconds
          o defaults to S 


2. Directives

Name		CBandDefaultExceededURL
Description 	Default URL where mod_cband should redirect all requests to the virtualhost or 
		user when the configured transfer limit is exceeded
NOTE:		If you don't specify the exceeded URL location then standard 503 Service Unavailable 
		will be sent
Context 	Server config
Syntax 		CBandDefaultExceededURL URL


Name 		CBandDefaultExceededCode
Description 	The http code sent to the user when the configured transfer is exceeded
Context 	Server config
Syntax 		CBandDefaultExceededCode HTTP_CODE
Example 	CBandDefaultExceededCode 509


Name 		CBandScoreFlushPeriod
Description 	Specifies a period after which the score for the virtualhost or user is written to the scoreboard file. Use this to improve mod_cband's performance
Default 	1
Context 	Server config
Syntax 		CBandScoreFlushPeriod number_of_requests
Example 	CBandScoreFlushPeriod 100
		Any virtualhost's or user's scoreboard will be saved after 100 requests


Name 		CBandSpeed
Description 	Specifies a maximal speed for a virtualhost
Context 	<Virtualhost>
Syntax 		CBandSpeed kbps rps max_conn
		kbps - maximal transfer speed in [kMG]bps or [kMG]B/s
		rps - maximal requests per second
		max_conn - maximal number of simultaneous connections
Example 	CBandSpeed 1024 10 30
		Specifies maximal speed 1024kbps (1024 * 1024 bits per second), 
		maximal 10 requests per second and with a maximum of 30 open connections
NOTE:		This feature is available from version 0.9.6.0


Name 		CBandRemoteSpeed
Description 	Specifies maximal speed for any remote client
Context 	<Virtualhost>
Syntax 		CBandRemoteSpeed kbps rps max_conn
		kbps - maximal transfer speed in [kMG]bps or [kMG]B/s
		rps - maximal requests per second
		max_conn - maximal number of simultaneous connections
Example 	CBandRemoteSpeed 20kb/s 3 3
		Specifies maximal speed 20kB/s (20 * 1024 bytes per second), 
		maximal 3 requests per second and 3 open connections for any remote client
NOTE:		This feature is available from version 0.9.6.1-rc2


Name 		CBandClassRemoteSpeed
Description 	Specifies maximal speed for any remote client from some destination class
Context 	<Virtualhost>
Syntax 		CBandClassRemoteSpeed class_name kbps rps
		class_name - name of defined destination class
		kbps - maximal transfer speed in kbps or kB/s
		rps - maximal requests per second
		max_conn - maximal number of simultaneous connections
Example 	<CBandClass googlebot_class>
		    CBandClassDst 66.249.64/24
		    CBandClassDst 66.249.65/24
		    CBandClassDst 66.249.79/24
		</CBandClass>
		CBandClassRemoteSpeed googlebot_class 20kb/s 2 3
		
		Specifies maximal speed 20kB/s (20 * 1024 bytes per second), 
		maximal 2 requests per second and 3 open connections for any remote client from 
		class googlebot_class
NOTE:		This feature is available from version 0.9.6.1-rc2


Name 		CBandRandomPulse
Description 	Turns On or Off the random pulse generator for data sending
		Random pulse generator is a part of the speed-limiting implementation of mod_cband. 
		This directive changes the way a connection's speed is determined and enforced. 
		The connections' speeds are measured within some time period and then provided for in 
		that period. When r.p.g. is enabled this period is chosen randomly, 
		providing for a statisticaly saner load distribution. Disabling this causes spikes both in 
		bandwidth and cpu usages
Context 	Global
Syntax 		CBandRandomPulse On/Off


Name 		CBandLimit
Description 	Specifies bandwidth limit for virtualhost
Context 	<Virtualhost>
Syntax 		CBandLimit limit
		limit - bandwidth quota size, available units: K (kilo), M (mega), G (giga), Ki (kibi), 
		Mi (mebi), Gi (gibi)
Example 	CBandLimit 10M
		Specifies 10 * 1000 * 1000 bytes bandwidth quota

		CBandLimit 10Mi
		Specifies 10 * 1024 * 1024 bytes bandwidth quota


Name 		CBandClassLimit
Description 	Specifies bandwidth limit for virtualhost's destination class
Context 	<Virtualhost>
Syntax 		CBandClassLimit class_name limit
		class_name - the name of defined class
		limit - bandwidth quota size, available units: K (kilo), M (mega), G (giga), Ki (kibi), 
		Mi (mebi), Gi (gibi)


Name 		CBandExceededURL
Description 	Specifies a URL where mod_cband should redirect all requests to a virtualhost when the configured transfer limit is exceeded NOTE: If you don't specify the exceeded URL location then standard 503 Service Unavailable will be sent
Context 	<Virtualhost>
Syntax 		CBandExceededURL URL


Name 		CBandExceededSpeed
Description 	Specifies maximal speed to which mod_cband slows down a virtualhost when the configured transfer limit is exceeded
Context 	<Virtualhost>
Syntax 		CBandExceededSpeed kbps rps max_conn
		kbps - maximal transfer speed in kbps or kB/s
		rps - maximal requests per second
		max_conn - maximal number of simultaneous connections
NOTE:		This feature is available from version 0.9.6.0


Name 		CBandScoreboard
Description 	Specifies virtualhost's scoreboard file
Context 	<Virtualhost>
Syntax 		CBandScoreboard path
NOTE: 		The path must be writeable for the apache-user


Name 		CBandPeriod
Description 	Specifies a period after which a virtualhost's usages are cleared
Context 	<Virtualhost>
Syntax 		CBandPeriod period
		period - available units: S (seconds), M (minutes), H (hours), D (days), W (weeks)
Example 	CBandPeriod 1W
		CBandPeriod 14D
		CBandPeriod 60M
		
		
Name 		CBandPeriodSlice
Description 	Specifies the period slice length
Default 	slice_len = limit
Context 	<Virtualhost>
Syntax 		CBandPeriodSlice slice_length
Example 	CBandLimit 100G
		CBandPeriod 4W
		CBandPeriodSlice 1W
		A period will be divided into 4 small slices (4W/1W = 4). Each slice has 100G/4=25G 
		bandwidth limit. After 1W slice limit will be 50G, after 2W will be 75G ...


Name 		<CBandUser>
Description 	Define a new cband user
Context 	Server config
Syntax 		<CBandUser user_name>


Name 		CBandUserSpeed
Description 	Specifies maximal speed for a cband user
Context 	<CBandUser>
Syntax 		CBandUserSpeed kbps rps max_conn
		kbps - maximal transfer speed in kbps or kB/s
		rps - maximal requests per second
		max_conn - maximal number of simultaneous connections
Example 	CBandUserSpeed 100kb/s 10 5
		Specifies maximal speed 100 kB/s (100 * 1024 bytes per second), 
		maximal 10 requests per second and 5 open connections
NOTE:		This feature is available from version 0.9.6.0


Name 		CBandUserLimit
Description 	Specifies bandwidth limit for a cband user
Context 	<CBandUser>
Syntax 		CBandUserLimit limit
		limit - bandwidth quota size, available units: K (kilo), M (mega), G (giga), Ki (kibi), 
		Mi (mebi), Gi (gibi)
Example 	CBandUserLimit 10M
		Specifies 10 * 1000 * 1000 bytes bandwidth quota

		CBandUserLimit 10Mi
		Specifies 10 * 1024 * 1024 bytes bandwidth quota


Name 		CBandUserClassLimit
Description 	Specifies bandwidth limit for a cband user's destination class
Context 	<CBandUser>
Syntax 		CBandUserClassLimit class_name limit
		class_name - the name of defined class
		limit - bandwidth quota size, available units: K (kilo), M (mega), G (giga), Ki (kibi), 
		Mi (mebi), Gi (gibi)


Name 		CBandUserExceededURL
Description 	Specifies a URL where mod_cband should redirect all requests to user's virtualhost when the configured transfer limit is exceeded
NOTE: If you don't specify the exceeded URL location then standard 503 Service Unavailable will be sent
Context 	<CBandUser>
Syntax 		CBandUserExceededURL URL


Name 		CBandUserExceededSpeed
Description 	Specifies maximal speed to which mod_cband slows down user when the configured transfer limit is exceeded
NOTE: 		CBandUserExceededURL must not be used if you want to only slow down user's pages with 
		CBandUserExceededSpeed directive
Context 	<CBandUser>
Syntax 		CBandUserExceededSpeed kbps rps max_conn
		kbps - maximal transfer speed in kbps or kB/s
		rps - maximal requests per second
		max_conn - maximal number of simultaneous connections
NOTE:		This feature is available from version 0.9.6.0


Name 		CBandUserScoreboard
Description 	Specifies a user's scoreboard file
Context 	<CBandUser>
Syntax 		CBandUserScoreboard path
NOTE: 		The path must be writeable for the apache-user


Name 		CBandUserPeriod
Description 	Specifies a period after which a user's usages are cleared
Context 	<CBandUser>
Syntax 		CBandUserPeriod period
		period - available units: S (seconds), M (minutes), H (hours), D (days), W (weeks)
Example 	CBandUserPeriod 1W
		CBandUserPeriod 14D
		CBandUserPeriod 60M
		
		
Name 		CBandUserPeriodSlice
Description 	Specifies a period slice length
Default 	slice_len = limit
Context 	<CBandUser>
Syntax 		CBandUserPeriodSlice slice_length
Example 	CBandUserLimit 100G
		CBandUserPeriod 4W
		CBandUserPeriodSlice 1W
		A period will be divided into 4 small slices (4W/1W = 4). Each slice has 100G/4=25G 
		bandwidth limit. After 1W slice limit will be 50G, after 2W will be 75G ...


3. Status Handler Configuration Example
To view actual bandwidth limits, usages, users, scoreboards, add the following lines into the config file:

<Location /cband-status> 
SetHandler cband-status
</Location> 

<Location /cband-status-me> 
SetHandler cband-status-me
</Location> 

Then you can access the status page with a URL like:
http://server_name/cband-status
http://server_name/cband-status-me

An example of the cband-status is available here
An example of the cband-status-me is available here

In versions >=0.9.5-rc1 you can also view /cband-status handler in the XML format:

http://server_name/cband-status?xml
http://server_name/cband-status-me?xml

An example of the cband-status in the XML format is available here
An example of the cband-status-me in the XML format is available here


4. Bandwidth Speed Configuration Example

<VirtualHost *:80>
    DocumentRoot /var/www/xyz.org/
    ServerName xyz.org
    CustomLog /var/log/apache2/xyz.org.access combined
    ErrorLog /var/log/apache2/xyz.org.access.error
    RewriteEngine On
    RewriteOptions inherit

    # Maximal 1024kbps speed for this virtualhost
    # Maximal 10 requests per second for this virtualhost
    # Maximal 30 open connections for this virtualhost
    CBandSpeed 1024 10 30
    
    # Maximal 10kB/s speed, 3 requests/s and 2 open connections for any remote client
    CBandRemoteSpeed 10kb/s 3 2
    
    # Maximal 20kB/s speed, 2 requests/s and 3 open connections for remote
    # clients from class googlebot_class :P
    CBandClassRemoteSpeed googlebot_class 20kb/s 2 3
</VirtualHost>

5. Bandwidth Quota Configuration Example
per-virtualhost bandwidth limiting configuration
Next, you may define virtualhost's bandwidth limits, URL location and the path to scoreboard files for individual virtualhosts:

# specify default 'bandwidth exceeded' location
CBandDefaultExceededURL	http://haha.org/bandwidth_exceeded.html

<VirtualHost *:80>
    DocumentRoot /var/www/xyz.org/
    ServerName xyz.org
    CustomLog /var/log/apache2/xyz.org.access combined
    ErrorLog /var/log/apache2/xyz.org.access.error
    RewriteEngine On
    RewriteOptions inherit

    # 100MB virtualhost bandwidth limit
    CBandLimit 100000

    # redirect to http://abc.org/bandwidth_exceeded.html
    # when the limit has been reached
    CBandExceededURL http://abc.org/bandwidth_exceeded.html

    # virtualhost's scoreboard file
    CBandScoreboard /var/run/apache2/xyz.org.scoreboard
    
    # a period of time after which the scoreboard will be cleared (30 minutes) 
    # (only in >=0.9.5-rc2)
    CBandPeriod 30M
</VirtualHost>


per-user bandwidth limiting configuration (only in versions >=0.9.1)
In versions >=0.9.1 you can define limits for users and assign virtualhosts to them

# define user 'dembol'
<CBandUser dembol>
    # 200MB bandwidth limit for user 'dembol'
    CBandUserLimit 200000

    # redirect to http://abc.org/bandwidth_exceeded.html
    # when the limit has been reached
    CBandUserExceededURL http://abc.org/bandwidth_exceeded.html

    # user's scoreboard file
    CBandUserScoreboard /var/run/apache2/dembol.scoreboard
    
    # a period of time after which the scoreboard will be cleared (5 weeks) 
    # (only in >=0.9.5-rc2)
    CBandUserPeriod 5W
</CBandUser>

# assign virtualhost 'xyz.org' to user 'dembol'
<VirtualHost *:80>
    ServerName xyz.org
    # Specify virtualhost's owner
    CBandUser dembol
</VirtualHost>

# assign virtualhost 'aga.org' to user 'dembol'
<VirtualHost *:80>
    ServerName aga.org
    # Specify virtualhost's owner
    CBandUser dembol
</VirtualHost>


per-user and per-virtualhost bandwidth limiting configuration (only in versions >=0.9.1)
In versions >=0.9.1 you can also mix per-user and per-virtualhost bandwidth limiting techniques

# define user 'dembol'
<CBandUser dembol>
    # 200MB bandwidth limit for user 'dembol'
    CBandUserLimit 200000

    # redirect to http://abc.org/bandwidth_exceeded.html
    # when the limit has been reached
    CBandUserExceededURL http://abc.org/bandwidth_exceeded.html

    # user's scoreboard file
    CBandUserScoreboard /var/run/apache2/dembol.scoreboard
    
    # a period of time after which the scoreboard will be cleared (4 days) 
    # (only in >=0.9.5-rc2)
    CBandUserPeriod 4D
</CBandUser>

# assign virtualhost 'xyz.org' to user 'dembol'
<VirtualHost *:80>
    ServerName xyz.org
    # Specify virtualhost's owner
    CBandUser dembol
    
    # 100MB virtualhost bandwidth limit
    CBandLimit 100000

    # redirect to http://abc.org/bandwidth_exceeded.html
    # when the limit has been reached
    CBandExceededURL http://abc.org/bandwidth_exceeded.html

    # virtualhost's scoreboard file
    CBandScoreboard /var/run/apache2/xyz.org.scoreboard
    
    # a period of time after which the scoreboard will be cleared (50 minutes) 
    # (only in >=0.9.5-rc2)
    CBandPeriod 50M
</VirtualHost>

# assign virtualhost 'aga.org' to user 'dembol'
<VirtualHost *:80>
    ServerName aga.org
    # Specify virtualhost's owner
    CBandUser dembol
</VirtualHost>


per-destination bandwidth limiting configuration (only in >=0.9.5-rc1 versions)
In >= 0.9.5-rc1 you can limit traffic to some destination classes. The destination classes are defined by <CBandClass class_name> section. The limits for the classes are specified by CBandClassLimit and CBandUserClassLimit commands

# define 'class_1'
<CBandClass class_1>
    CBandClassDst 217.172.231.67
    CBandClassDst 127/8
    CBandClassDst 192.168.0.0/24
    CBandClassDst 10.0.0.20
</CBandClass>

# define 'class_2'
<CBandClass class_2>
    CBandClassDst 192.168.100.100
    CBandClassDst 153.19/16
</CBandClass>

<CBandUser dembol>
    CBandUserLimit 1000000
    CBandUserExceededURL http://edns.pl/bandwidth_exceeded.html
    CBandUserScoreboard /home/dembol/write/user.dembol.scoreboard
    
    # 500MB limit for 'class_2'
    CBandUserClassLimit class_2 500000
</CBandUser>

<VirtualHost *:80>
    ...
    CBandUser dembol
    
    # 1GB limit for 'class_1'
    CBandClassLimit class_1 1000000
    
    # a period of time after which the scoreboard will be cleared (120 seconds) 
    # (only in >=0.9.5-rc2)
    CBandPeriod 120S
</VirtualHost>



Server is hosted by Alanstudio
Linux Operating System

Recommend screen resolution 1024 x 768 / IE / FireFox
Alan Studio © 2007 by Alan Cheung Hin Lun. All rights reserved.