Copyright 2006-2009 Lennart Poettering <mzzbqqaffq (at) 0pointer (dot) net>
Copyright 2006-2009 Lennart Poettering
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.
Version 0.6 released, changes include: add a new directive DNSSDServiceTxtRecord
Version 0.5 released, changes include: updated for Apache 2.2; for compatibility with older Apache versions please use mod_dnssd 0.4.
Version 0.4 released, changes include: deal properly with vhosts listening on ports != 80; add new DNSSDUserDir directive.
Version 0.3 released, changes include: fix compilation on FreeBSD and Mandriva; compatibility with Apache 2.2; fix a memory corruption bug
Version 0.2 released, changes include: handle graceful restarts properly, other smaller cleanups
Version 0.1 released, initial realease
mod_dnssd is an Apache HTTPD module which adds Zeroconf support via DNS-SD using Avahi.
Version 0.6 is more or less stable and fulfills its purpose.
For activating mod_dnssd just load it into the server and use the global directive DNSSDEnable to enable it:
DNSSDEnable on
That's it, nothing more is required! The module publishes all configured virtual hosts and the mod_userdir directories of all local users. For mod_userdir to work you need to load that module and configure it for the path ~/public_html/.
Please note that all ServerNames used in the Apache configuration files for services that shall be published with Avahi/DNS-SD need to be valid and in FQDN format, i.e. resolvable via mDNS or traditional DNS, and consist of at least two labels. (foobar does not qualify as such, but foobar.local does.)
Five other directives are available: the global directive DNSSDAutoRegisterUserDir can be used to disable automatic registration of mod_userdir directories. The global directive DNSSDAutoRegisterVHosts can be used to disable automatic registration of all local virtual hosts.
The two directives DNSSDServiceName and DNSSDServiceTypes which can be placed inside a <VirtualHost> or <Location> section can be used to define additional services for publishing or to finetune the service name or types of virtual hosts. If placed inside a <VirtualHost> you can change the service types and name of the attached service (if used with DNSSDAutoRegisterVHosts set to on) or to register a service for the virtual host (if used with DNSSDAutoRegisterVHosts disabled). DNSSDServiceTypes takes a list of at least one DNS-SD service type (defaults to _http._tcp). A good example when to pass more than one service type is a WebDAV server:
DNSSDServiceTypes _http._tcp _webdav._tcp
This will register the server both as HTTP and as WebDAV service. Please note that both services do have different types but share the same name! Other areas where this might become handy is when registering RSS formatted blogs or XMLRPC services.
DNSSDServiceName and DNSSDServiceTypes are especially useful inside a <Location> block. Using this notation you can register additional services in subdirectories of the server. A quick and incomplete example:
... DNSSDEnable On DNSSDAutoRegisterVHosts On DNSSDAutoRegisterUserDir On <VirtualHost *> DocumentRoot /var/www DNSSDServiceName "Our Little Home Web Server" <Location /doc> DNSSDServiceName "Documentation" ... </Location> <Location /squirrelmail> DNSSDServiceName "Webmail" ... </Location> <Location /webdav> DAV On DNSSDServiceName "Our WebDAV folder" DNSSDServiceTypes _webdav._tcp _http._tcp ... </Location> <Location /blog.rss> DNSSDServiceName "The Blog" DNSSDServiceTypes _rss._tcp ... </Location> ... </VirtualHost> ...
This will register six services: Our Little Home Web Server, Documentation, Webmail and Our WebDAV folder as type _http._tcp, Our WebDAV folder a second time under the type _webdav._tcp and finally The Blog as type _rss._tcp.
The directive DNSSDServicePort can be used to tell mod_dnssd the right port number in complicated setups, where it fails to detect the correct one to use. It is seldomly used and you probably shouldn't bother.
The global directive DNSSDUserDir may be used to change the directory inside the user's home directory that is published by DNSSDAutoRegisterUserDir. This defaults to public_html. If you used the UserDir directive in your Apache configuration file you probably want to use this directive, too. Please note, however, that DNSSDUserDir doesn't accept the full syntax that UserDir accepts. In fact only the simplest form - a simple string without any * and without the / prefix - is accepted.
You might find this blog article I wrote enlightening which contains more examples how to make use of mod_dnssd.
mod_dnssd requires a current release of Apache 2.2 with apxs and a development installation of Avahi 0.6 or newer. mod_dnssd has been tested exclusively with mpm_prefork, your mileage with other MPMs may vary. (Please report successes or failures!)
mod_dnssd has been developed and tested on Debian GNU/Linux "testing" from January 2006, it should work on most other Linux distributions and probably POSIX implementations since it uses GNU autoconf and Apache apxs for source code configuration.
As this package is made with the GNU autotools you should run ./configure inside the distribution directory for configuring the source tree. After that you should run make for compilation and make install (as root) for installation of mod_dnssd.
This work was inspired by Sander Temme's and Sebastien Estienne's mod_zeroconf module.
Sebastien Estienne for packaging mod_dnssd for Debian.
Bastien Nocera for adding the DNSSDServiceTxtRecord directive.
The newest release is always available from http://0pointer.de/lennart/projects/mod_dnssd/
The current release is 0.6
Get mod_dnssd's development sources from the GIT repository (gitweb):
git clone git://git.0pointer.de/mod_dnssd
You may find an up to date Debian package of mod_dnssd in the Debian package repository.