Aucune description

Jelte Jansen f9b5323ae8 [trac762] final comments il y a 14 ans
doc edea2125fa [master] document log4cplus requirement and some other minor doc changes. il y a 14 ans
ext d743478f2b [master] Added a reference to our local asio fix in ext/asio/README il y a 14 ans
src f9b5323ae8 [trac762] final comments il y a 14 ans
tests 489ef1ad97 [trac899] Merge branch 'master' into trac899 il y a 14 ans
tools c20ca24405 [trac609] il y a 14 ans
AUTHORS bfebabee9a Fix some misspellings. il y a 14 ans
COPYING ebf4a1bb2b added a minimal set to build the package. il y a 15 ans
ChangeLog 24a865aeec [trac1031] ChangeLog for trac 1031 il y a 14 ans
INSTALL d151653e75 [master] don't use autoreconf with the tarball il y a 14 ans
Makefile.am e2f1f9c450 [master] exclude botan, log4cplus and ext/coroutine from c++ coverage report il y a 14 ans
NEWS ebf4a1bb2b added a minimal set to build the package. il y a 15 ans
README bf4d941c69 [master] mention b10-stats-httpd and b10-host in README il y a 14 ans
configure.ac dae1d2e24f [trac710] Merge branch 'master' into trac710 il y a 14 ans
depcomp 6deb954c9e missing il y a 15 ans
install-sh ebf4a1bb2b added a minimal set to build the package. il y a 15 ans
missing ebf4a1bb2b added a minimal set to build the package. il y a 15 ans

README

This is the source for the development version of BIND 10.

BIND is the popular implementation of a DNS server, developer
interfaces, and DNS tools. BIND 10 is a rewrite of BIND 9. BIND 10
is written in C++ and Python and provides a modular environment
for serving, maintaining, and developing DNS.

BIND10-devel is new development leading up to the production
BIND 10 release. It contains prototype code and experimental
interfaces. Nevertheless it is ready to use now for testing the
new BIND 10 infrastructure ideas. The Year 2 milestones of the
five year plan are described here:

https://bind10.isc.org/wiki/Year2Milestones

This release includes the bind10 master process, b10-msgq message
bus, b10-auth authoritative DNS server (with SQLite3 and in-memory
backends), b10-resolver recursive or forwarding DNS server, b10-cmdctl
remote control daemon, b10-cfgmgr configuration manager, b10-xfrin
AXFR inbound service, b10-xfrout outgoing AXFR service, b10-zonemgr
secondary manager, b10-stats statistics collection and reporting
daemon, b10-stats-httpd for HTTP access to XML-formatted stats,
b10-host DNS lookup utility, and a new libdns++ library for C++
with a python wrapper.

Documentation is included and also available via the BIND 10
website at http://bind10.isc.org/

The latest released source may be downloaded from:

ftp://ftp.isc.org/isc/bind10/

Users and developers are encouraged to participate on the BIND 10
mailing lists:

https://lists.isc.org/mailman/listinfo/bind10-users
https://lists.isc.org/mailman/listinfo/bind10-dev

Bugs may be reported as tickets via the developers website:

http://bind10.isc.org/

BUILDING

See the Guide for detailed installation directions at
doc/guide/bind10-guide.html.

Simple build instructions:

./configure
make

If building from Git repository, run:

autoreconf --install

before running ./configure

Requires autoconf 2.59 or newer.

Use automake-1.11 or better for working Python 3.1 tests.
Alternatively, you could manually specify an absolute path to python
executable by the --with-pythonpath option of the configure script,
e.g.,
% ./configure --with-pythonpath=/usr/local/bin/python3.1

Operating-System specific tips:

- FreeBSD
You may need to install a python binding for sqlite3 by hand. A
sample procedure is as follows:
- add the following to /etc/make.conf
PYTHON_VERSION=3.1
- build and install the python binding from ports, assuming the top
directory of the ports system is /usr/ports
% cd /usr/ports/databases/py-sqlite3/
% make
% sudo make install

INSTALLATION

Install with:

make install

TESTS

The tests use the googletests framework for C++. It is available
from http://code.google.com/p/googletest/. To enable the tests,
configure BIND 10 with:

./configure --with-gtest

Then run "make check" to run these tests.

TEST COVERAGE

Code coverage reports may be generated using make. These are
based on running on the unit tests. The resulting reports are placed
in coverage-cpp-html and coverage-python-html directories for C++
and Python, respectively.

The code coverage report for the C++ tests uses LCOV. It is available
from http://ltp.sourceforge.net/. To generate the HTML report,
first configure BIND 10 with:

./configure --with-lcov

The code coverage report for the Python tests uses coverage.py (aka
pycoverage). It is available from http://nedbatchelder.com/code/coverage/.
To generate the HTML report, first configure BIND 10 with:

./configure --with-pycoverage

Doing code coverage tests:

make coverage
Does the clean, perform, and report targets for C++ and Python.

make clean-coverage
Zeroes the code coverage counters and removes the HTML reports
for C++ and Python.

make perform-coverage
Runs the C++ (using the googletests framework) and Python
tests.

make report-coverage
Generates the coverage reports in HTML for C++ and Python.

make clean-cpp-coverage
Zeroes the code coverage counters and removes the HTML report
for the C++ tests.

make clean-python-coverage
Zeroes the code coverage counters and removes the HTML report
for the Python tests.

make report-cpp-coverage
Generates the coverage report in HTML for C++, excluding
some unrelated headers. The HTML reports are placed in a
directory called coverage-cpp-html/.

make report-python-coverage
Generates the coverage report in HTML for Python. The HTML
reports are placed in a directory called coverage-python-html/.

DEVELOPERS

The generated run_*.sh scripts available in the src/bin directories
are for running the code using the source tree.

RUNNING

You can start the BIND 10 processes by running bind10 which is
installed to the sbin directory under the installation prefix.
The default location is:

/usr/local/sbin/bind10

For development work, you can also run the bind10 services from the
source tree:

./src/bin/bind10/run_bind10.sh

(Which will use the modules and configurations also from the source
tree.)

CONFIGURATION

Commands can be given through the bindctl tool.

The server must be running for bindctl to work.

The following configuration commands are available

help: show the different command modules
help: show the commands for module
help: show info for the command


config show [identifier]: Show the currently set values. If no identifier is
given, the current location is used. If a config
option is a list or a map, the value is not
shown directly, but must be requested separately.
config go [identifier]: Go to the given location within the configuration.
config set [identifier] : Set a configuration value.
config unset [identifier]: Remove a value (reverts to default if the option
is mandatory).
config add [identifier] : add a value to a list
config remove [identifier] : remove a value from a list
config revert: Revert all changes that have not been committed
config commit: Commit all changes
config diff: Show the changes that have not been committed yet


EXAMPLE SESSION

~> bindctl
["login success "] login as root
> help
BindCtl, verstion 0.1
usage: [param1 = value1 [, param2 = value2]]
Type Tab character to get the hint of module/command/paramters.
Type "help(? h)" for help on bindctl.
Type " help" for help on the specific module.
Type " help" for help on the specific command.

Available module names:
help Get help for bindctl
config Configuration commands
Xfrin same here
Auth same here
Boss same here
> config help
Module config Configuration commands
Available commands:
help (Get help for module)
show (Show configuration)
add (Add entry to configuration list)
remove (Remove entry from configuration list)
set (Set a configuration value)
unset (Unset a configuration value)
diff (Show all local changes)
revert (Revert all local changes)
commit (Commit all local changes)
go (Go to a specific configuration part)
> config show
Xfrin/ module
Auth/ module
Boss/ module
> config show Xfrin
transfers_in: 10 integer
> config go Auth
/Auth> config show
database_file: None string
/Auth> config set database_file /tmp/bind10_zones.db
/Auth> config commit
/Auth> config go /
> config show Auth/
database_file: /tmp/bind10_zones.db string
> config diff
{}
> config set Auth/foobar
Error: missing identifier or value
> config set Auth/database_file foobar
> config diff
{'Auth': {'database_file': 'foobar'}}
> config revert
> config diff
{}
> quit