name mode size
doc 040000
Makefile 100644 497B
README 100644 7.46kB
bdb.c 100644 2.79kB
bdb.h 100644 2.2kB
bdb_api.c 100644 20.38kB
bdb_api.h 100644 2.03kB
bdb_base.c 100644 7.19kB
bdb_res.h 100644 2.68kB
bdb_rval.c 100644 2.38kB
bdb_sval.c 100644 6.47kB
bdb_uval.c 100644 4.94kB
bdb_val.c 100644 9.15kB
bdb_vals.h 100644 2.6kB
version.dump 100644 359B
1. BDB Module Sippy Software, Inc. Copyright © 2006 Sippy Software, Inc. __________________________________________________________________ 1.1. Overview 1.1.1. Design of DBD Engine 1.2. Dependencies 1.2.1. External libraries or applications 1.3. Exported parameters 1.3.1. describe_table (string) 1.4. Constrains and limitations 1.5. Installation and running 1.5.1. Using BDB With Basic SER Configuration 1.1. Overview The SER (SIP Express Router) supports several different persistent storage backends (flatfile, dbtext and several SQL servers). However, in certain cases those existing backends don't satisfy conditions. Particularly, SQL server-based backends typically provide good performance and scalability, but at the same time require considerable efforts to configure and manage and also have significant memory and on-disk footprint, while simpler storage backends (flatfile, dbtext) are lighter and simpler to setup and manage, but scale poorly and don't provide sufficient performance. For certain types of applications (i.e. embedded SIP applications, SIP load balancing farms etc), different solution that would combine some of the non-overlapping properties of those two existing classes of backends is necessary. Berkeley DB is widely regarded as industry-leading open source, embeddable database engine that provides developers with fast, reliable, local persistence with almost zero administration. 1.1.1. Design of DBD Engine The dbtext database system architecture: * A database is represented by a directory in the local file system where BDB environment is located. Note When using BDB driver in SER, the database URL for modules must be the path to the directory where the BDB environment is located, prefixed by "bdb://", e.g., "bdb:///var/db/ser". If there is no "/" after "bdb://" then "CFG_DIR/" (the OS-specific path defined at SER's compile time) is inserted at the beginning of the database path automatically. So that, either an absolute path to database directory, or one relative to "CFG_DIR" directory should be provided in the URL. * The individual tables internaly are represented by binary files inside environment directory. Note The BDB driver uses BTree access method. On-disk storage format has been developed to be as simple as possible, while meeting performance requirements set forth above. It is not compatible with on-disk format of any other BDB-based DB engine (e.g. MySQL's BDB table handler). 1.2. Dependencies 1.2.1. External libraries or applications The next libraries or applications must be installed before running SER with this module: * Berkeley DB 4.X 1.3. Exported parameters 1.3.1. describe_table (string) Define the table and its structure. Each table that will be used by other modules has to be defined. The format of the parameter is: table_name:column_name_1(column_type_1)[column_name_2(column_type_2)[.. . column_name_N(column_type_N)]] The names of table and columns must not include white spaces. The first column in definition is used as index. Between name of table and name of first column must be ":". Between two columns definitions must be exactly one white space. Type of column has to be enclosed into parentheses. Supported column types are: * int * float * double * string * str * datetime * blob * bitmap 1.4. Constrains and limitations Use of indexes: * Effective SELECT, UPDATE and DELETE operations on a structured storage that contains any more or less decent number of records are impossible without using some kind of indexing scheme. Since Berkley DB is relatively simple storage engine it provides only basic support for indexing, nearly not as rich as usually expected by an average SQL user. Therefore, it has been decided to limit number of indexes supported to one per table. This is sufficient for most of the uses in the SER (for example: usrloc, auth_db etc). * SELECT/UPDATE/DELETE records matching criteria. Due to its simplicity, Berkley DB only supports exact match on indexed field. In order to support <, >, <= and >= operations mandated by the SIP DB API it is necessary to fall back to sequental scan of the index values, which obviously has significant negative impact on performance. Fortunately those advanced records matching criterias are not required neither by the usrloc module nor by auth_db module. * BDB driver uses index only if key column appears in search clause at least once and records matching operator associated with it is '='. * It is not allowed to set index value to NULL or an empty string. * It is not allowed to update index value. The DELETE followed by INSERT should be used instead. BDB driver does not support db_raw_query() method. BDB driver does not support ORDER BY clause of db_query() method. 1.5. Installation and running Compile the module and load it instead of mysql or other DB modules. Example 1. Load the bdb module ... loadmodule "/path/to/ser/modules/" ... modparam("module_name", "db_url", "bdb:///path/to/bdb/database") ... Example 2. definition of the standard version table ... modparam("bdb", "describe_table", "version:table_name(str) table_version(int)") ... 1.5.1. Using BDB With Basic SER Configuration Here are the definitions for tables used by usrloc module as well as a part of basic configuration file to use BDB driver with SER. The table structures may change in future releases, so that some adjustment to example below may be necessary. That example corresponds to SER v0.9.4 According to the configuration file below, the table files will be placed in the //var/db/ser/ directory. The table version should be populated manually before the SER is started. To do this version.dump file located in the directotry of BDB driver sources and db_load utility from Berkeley BD distribution should be used as follows: Example 3. Population of version table $ db_load -h /var/db/ser -f version.dump version Example 4. Configuration file # ---------- global configuration parameters ------------------------ # [skip] # ---------- module loading ----------------------------------------- loadmodule "/usr/local/lib/ser/modules/" loadmodule "/usr/local/lib/ser/modules/" # ---------- module-specific configuration parameteres -------------- modparam("usrloc", "db_mode", 2) modparam("usrloc", "timer_interval", 3) modparam("usrloc", "db_url", "bdb:///var/db/ser") modparam("bdb", "describe_table", "version:table_name(str) table_version(int)") modparam("bdb", "describe_table", "location:username(str) domain(str) contact(st r) i_env(int) expires(datetime) q(double) callid(str) cseq(int) method(str) flag s(int) user_agent(str) received(str)") modparam("bdb", "describe_table", "aliases:username(str) domain(str) contact(str ) i_env(int) expires(datetime) q(double) callid(str) cseq(int) method(str) flags (int) user_agent(str) received(str)") # ---------- request routing logic ---------------------------------- # [skip]