Table of Contents
List of Tables
List of Examples
This module is an implementation of a cache system designed for DNS records. For successful DNS queries of all types, the module will store in a cache/db backend the mappings, for TTL number of seconds received in the DNS answer. Failed DNS queries will also be stored in the back-end, with a TTL that can be specified by the user. The module uses the Key-Value interface exported from the core.
The url of the key-value back-end that will be used for storing the DNS records.
Example 1.1. Set cachedb_url parameter
...
#use internal cachedb_local module
modparam("dns_cache", "cachedb_url","local://")
#use cachedb_memcached module with memcached server at 192.168.2.130
modparam("dns_cache", "cachedb_url","memcached://192.168.2.130:8888/")
...
		The number of seconds that a failed DNS query will be kept in cache. Default is 3600.
Example 1.2. Set blacklist_timeout parameter
...
modparam("dns_cache", "blacklist_timeout",7200) # 2 hours
...
		The minimum number of seconds that a DNS record will be kept in cache. If the TTL received in the DNS answer is lower than this value, the record will be cached for min_ttl seconds.
Default value is 0 seconds (no minimum TTL is enforced).
Table 2.1. Top contributors by DevScore(1), authored commits(2) and lines added/removed(3)
| Name | DevScore | Commits | Lines ++ | Lines -- | |
|---|---|---|---|---|---|
| 1. | Vlad Paiu (@vladpaiu) | 15 | 5 | 1006 | 3 | 
| 2. | Liviu Chircu (@liviuchircu) | 13 | 11 | 50 | 48 | 
| 3. | Razvan Crainea (@razvancrainea) | 11 | 9 | 12 | 14 | 
| 4. | Bogdan-Andrei Iancu (@bogdan-iancu) | 9 | 7 | 22 | 13 | 
| 5. | Leo Smith | 8 | 6 | 32 | 2 | 
| 6. | James Stanley | 3 | 1 | 2 | 2 | 
| 7. | Maksym Sobolyev (@sobomax) | 3 | 1 | 2 | 2 | 
| 8. | Peter Lemenkov (@lemenkov) | 3 | 1 | 1 | 1 | 
| 9. | Alexandra Titoc | 2 | 1 | 2 | 0 | 
| 10. | Vlad Patrascu (@rvlad-patrascu) | 2 | 1 | 1 | 0 | 
(1) DevScore = author_commits + author_lines_added / (project_lines_added / project_commits) + author_lines_deleted / (project_lines_deleted / project_commits)
(2) including any documentation-related commits, excluding merge commits. Regarding imported patches/code, we do our best to count the work on behalf of the proper owner, as per the "fix_authors" and "mod_renames" arrays in opensips/doc/build-contrib.sh. If you identify any patches/commits which do not get properly attributed to you, please submit a pull request which extends "fix_authors" and/or "mod_renames".
(3) ignoring whitespace edits, renamed files and auto-generated files
Table 2.2. Most recently active contributors(1) to this module
| Name | Commit Activity | |
|---|---|---|
| 1. | James Stanley | Jun 2025 - Jun 2025 | 
| 2. | Leo Smith | Mar 2025 - Mar 2025 | 
| 3. | Bogdan-Andrei Iancu (@bogdan-iancu) | Jun 2012 - Dec 2024 | 
| 4. | Alexandra Titoc | Sep 2024 - Sep 2024 | 
| 5. | Maksym Sobolyev (@sobomax) | Feb 2023 - Feb 2023 | 
| 6. | Liviu Chircu (@liviuchircu) | Mar 2014 - Apr 2021 | 
| 7. | Razvan Crainea (@razvancrainea) | Feb 2012 - Sep 2019 | 
| 8. | Peter Lemenkov (@lemenkov) | Jun 2018 - Jun 2018 | 
| 9. | Vlad Patrascu (@rvlad-patrascu) | May 2017 - May 2017 | 
| 10. | Vlad Paiu (@vladpaiu) | Feb 2012 - Oct 2012 | 
(1) including any documentation-related commits, excluding merge commits
Last edited by: Leo Smith, Razvan Crainea (@razvancrainea), Peter Lemenkov (@lemenkov), Liviu Chircu (@liviuchircu), Bogdan-Andrei Iancu (@bogdan-iancu), Vlad Paiu (@vladpaiu).
Documentation Copyrights:
Copyright © 2012 www.opensips-solutions.com