 
Kea Administrator Reference Manual
Kea is an open source implementation of the Dynamic Host Configuration Protocol (DHCP) servers, developed and maintained by Internet Systems Consortium (ISC).
This is the reference guide for Kea version 2.7.6. Links to the most up-to-date version of this document (in PDF, HTML, and plain text formats) can be found on Read the Docs. Other useful Kea information can be found in our Knowledgebase.
- 1. Introduction
- 2. Quick Start
- 3. Installation
- 4. Kea Database Administration- 4.1. Databases and Schema Versions
- 4.2. The kea-adminTool
- 4.3. Supported Backends- 4.3.1. Memfile
- 4.3.2. MySQL
- 4.3.3. PostgreSQL- 4.3.3.1. First-Time Creation of the PostgreSQL Database
- 4.3.3.2. Initialize the PostgreSQL Database Using kea-admin
- 4.3.3.3. Upgrading a PostgreSQL Engine From an Earlier Version
- 4.3.3.4. Upgrading a PostgreSQL Database From an Earlier Version of Kea
- 4.3.3.5. PostgreSQL without OpenSSL support
- 4.3.3.6. Improved Performance With PostgreSQL
 
- 4.3.4. Using Read-Only Databases With Host Reservations
- 4.3.5. Limitations Related to the Use of SQL Databases
 
 
- 5. Kea Configuration
- 6. Managing Kea with keactrl
- 7. The Kea Control Agent
- 8. The DHCPv4 Server- 8.1. Starting and Stopping the DHCPv4 Server
- 8.2. DHCPv4 Server Configuration- 8.2.1. Introduction
- 8.2.2. Lease Storage
- 8.2.3. Hosts Storage
- 8.2.4. Interface Configuration
- 8.2.5. Issues With Unicast Responses to DHCPINFORM
- 8.2.6. IPv4 Subnet Identifier
- 8.2.7. IPv4 Subnet Prefix
- 8.2.8. Configuration of IPv4 Address Pools
- 8.2.9. Sending T1 (Option 58) and T2 (Option 59)
- 8.2.10. Standard DHCPv4 Options
- 8.2.11. CableLabs Client Conf Suboptions
- 8.2.12. Custom DHCPv4 Options
- 8.2.13. DHCPv4 Private Options
- 8.2.14. DHCPv4 Vendor-Specific Options
- 8.2.15. Nested DHCPv4 Options (Custom Option Spaces)
- 8.2.16. Unspecified Parameters for DHCPv4 Option Configuration
- 8.2.17. Support for Long Options
- 8.2.18. Support for IPv6-Only Preferred Option
- 8.2.19. Stateless Configuration of DHCPv4 Clients
- 8.2.20. Client Classification in DHCPv4
- 8.2.21. DDNS for DHCPv4
- 8.2.22. Next Server (siaddr)
- 8.2.23. Echoing Client-ID (RFC 6842)
- 8.2.24. Using Client Identifier and Hardware Address
- 8.2.25. Authoritative DHCPv4 Server Behavior
- 8.2.26. DHCPv4-over-DHCPv6: DHCPv4 Side
- 8.2.27. Sanity Checks in DHCPv4
- 8.2.28. Storing Extended Lease Information
- 8.2.29. Stash Agent Options
- 8.2.30. Multi-Threading Settings
- 8.2.31. Multi-Threading Settings With Different Database Backends
- 8.2.32. IPv6-Only Preferred Networks
- 8.2.33. Lease Caching
- 8.2.34. Temporary Allocation on DHCPDISCOVER
- 8.2.35. DNR (Discovery of Network-designated Resolvers) Options for DHCPv4
 
- 8.3. Host Reservations in DHCPv4- 8.3.1. Address Reservation Types
- 8.3.2. Conflicts in DHCPv4 Reservations
- 8.3.3. Reserving a Hostname
- 8.3.4. Including Specific DHCPv4 Options in Reservations
- 8.3.5. Reserving Next Server, Server Hostname, and Boot File Name
- 8.3.6. Reserving Client Classes in DHCPv4
- 8.3.7. Storing Host Reservations in MySQL or PostgreSQL
- 8.3.8. Fine-Tuning DHCPv4 Host Reservation
- 8.3.9. Global Reservations in DHCPv4
- 8.3.10. Pool Selection with Client Class Reservations
- 8.3.11. Subnet Selection with Client Class Reservations
- 8.3.12. Multiple Reservations for the Same IP
- 8.3.13. Host Reservations as Basic Access Control
 
- 8.4. Shared Networks in DHCPv4
- 8.5. Server Identifier in DHCPv4
- 8.6. How the DHCPv4 Server Selects a Subnet for the Client
- 8.7. Duplicate Addresses (DHCPDECLINE Support)
- 8.8. Statistics in the DHCPv4 Server
- 8.9. Management API for the DHCPv4 Server
- 8.10. User Contexts in IPv4
- 8.11. Supported DHCP Standards
- 8.12. DHCPv4 Server Limitations
- 8.13. Kea DHCPv4 Server Examples
- 8.14. Configuration Backend in DHCPv4
- 8.15. Kea DHCPv4 Compatibility Configuration Parameters
- 8.16. Address Allocation Strategies in DHCPv4
 
- 9. The DHCPv6 Server- 9.1. Starting and Stopping the DHCPv6 Server
- 9.2. DHCPv6 Server Configuration- 9.2.1. Introduction
- 9.2.2. Lease Storage
- 9.2.3. Hosts Storage
- 9.2.4. Interface Configuration
- 9.2.5. IPv6 Subnet Identifier
- 9.2.6. IPv6 Subnet Prefix
- 9.2.7. Unicast Traffic Support
- 9.2.8. Configuration of IPv6 Address Pools
- 9.2.9. Subnet and Prefix Delegation Pools
- 9.2.10. Prefix Exclude Option
- 9.2.11. Standard DHCPv6 Options
- 9.2.12. Common Softwire46 Options
- 9.2.13. DNR (Discovery of Network-designated Resolvers) Options for DHCPv6
- 9.2.14. NTP Server Suboptions
- 9.2.15. Custom DHCPv6 Options
- 9.2.16. DHCPv6 Vendor-Specific Options
- 9.2.17. Nested DHCPv6 Options (Custom Option Spaces)
- 9.2.18. Unspecified Parameters for DHCPv6 Option Configuration
- 9.2.19. Controlling the Values Sent for T1 and T2 Times
- 9.2.20. IPv6 Subnet Selection
- 9.2.21. Rapid Commit
- 9.2.22. DHCPv6 Relays
- 9.2.23. Relay-Supplied Options
- 9.2.24. Client Classification in DHCPv6
- 9.2.25. DDNS for DHCPv6
- 9.2.26. DHCPv4-over-DHCPv6: DHCPv6 Side
- 9.2.27. Sanity Checks in DHCPv6
- 9.2.28. Storing Extended Lease Information
- 9.2.29. Multi-Threading Settings
- 9.2.30. Multi-Threading Settings With Different Database Backends
- 9.2.31. Lease Caching
 
- 9.3. Host Reservations in DHCPv6- 9.3.1. Address/Prefix Reservation Types
- 9.3.2. Conflicts in DHCPv6 Reservations
- 9.3.3. Reserving a Hostname
- 9.3.4. Including Specific DHCPv6 Options in Reservations
- 9.3.5. Reserving Client Classes in DHCPv6
- 9.3.6. Storing Host Reservations in MySQL or PostgreSQL
- 9.3.7. Fine-Tuning DHCPv6 Host Reservation
- 9.3.8. Global Reservations in DHCPv6
- 9.3.9. Pool Selection with Client Class Reservations
- 9.3.10. Subnet Selection with Client Class Reservations
- 9.3.11. Multiple Reservations for the Same IP
- 9.3.12. Host Reservations as Basic Access Control
 
- 9.4. Shared Networks in DHCPv6
- 9.5. Server Identifier in DHCPv6
- 9.6. DHCPv6 Data Directory
- 9.7. Stateless DHCPv6 (INFORMATION-REQUEST Message)
- 9.8. Support for RFC 7550 (now part of RFC 8415)
- 9.9. Using a Specific Relay Agent for a Subnet
- 9.10. Segregating IPv6 Clients in a Cable Network
- 9.11. MAC/Hardware Addresses in DHCPv6
- 9.12. Duplicate Addresses (DHCPDECLINE Support)
- 9.13. Statistics in the DHCPv6 Server
- 9.14. Management API for the DHCPv6 Server
- 9.15. User Contexts in IPv6
- 9.16. Supported DHCPv6 Standards
- 9.17. DHCPv6 Server Limitations
- 9.18. Kea DHCPv6 Server Examples
- 9.19. Configuration Backend in DHCPv6
- 9.20. Kea DHCPv6 Compatibility Configuration Parameters
- 9.21. Allocation Strategies in DHCPv6
 
- 10. Database Connectivity
- 11. Lease Expiration
- 12. Congestion Handling
- 13. The DHCP-DDNS Server- 13.1. Overview
- 13.2. Starting and Stopping the DHCP-DDNS Server
- 13.3. Configuring the DHCP-DDNS Server
- 13.4. DHCP-DDNS Server Statistics
- 13.5. DHCP-DDNS Server Limitations
- 13.6. Supported Standards
 
- 14. The LFC Process
- 15. Client Classification- 15.1. Client Classification Overview
- 15.2. Built-in Client Classes
- 15.3. Using Expressions in Classification
- 15.4. Configuring Classes
- 15.5. Using Static Host Reservations in Classification
- 15.6. Configuring Subnets With Class Information
- 15.7. Configuring Pools With Class Information
- 15.8. Class Priority
- 15.9. Option Class-Tagging
- 15.10. Classes and Hooks
- 15.11. Debugging Expressions
 
- 16. Hook Libraries- 16.1. Introduction
- 16.2. Installing Hook Packages
- 16.3. Configuring Hook Libraries
- 16.4. Available Hook Libraries
- 16.5. libdhcp_bootp.so: Support for BOOTP Clients
- 16.6. libdhcp_cb_cmds.so: Configuration Backend Commands- 16.6.1. Command Structure
- 16.6.2. Control Commands for DHCP Servers
- 16.6.3. Metadata
- 16.6.4. The remote-server4-del,remote-server6-delCommands
- 16.6.5. The remote-server4-get,remote-server6-getCommands
- 16.6.6. The remote-server4-get-all,remote-server6-get-allCommands
- 16.6.7. The remote-server4-set,remote-server6-setCommands
- 16.6.8. The remote-global-parameter4-del,remote-global-parameter6-delCommands
- 16.6.9. The remote-global-parameter4-get,remote-global-parameter6-getCommands
- 16.6.10. The remote-global-parameter4-get-all,remote-global-parameter6-get-allCommands
- 16.6.11. The remote-global-parameter4-set,remote-global-parameter6-setCommands
- 16.6.12. The remote-network4-del,remote-network6-delCommands
- 16.6.13. The remote-network4-get,remote-network6-getCommands
- 16.6.14. The remote-network4-list,remote-network6-listCommands
- 16.6.15. The remote-network4-set,remote-network6-setCommands
- 16.6.16. The remote-option-def4-del,remote-option-def6-delCommands
- 16.6.17. The remote-option-def4-get,remote-option-def6-getCommands
- 16.6.18. The remote-option-def4-get-all,remote-option-def6-get-allCommands
- 16.6.19. The remote-option-def4-set,remote-option-def6-setCommands
- 16.6.20. The remote-option4-global-del,remote-option6-global-delCommands
- 16.6.21. The remote-option4-global-get,remote-option6-global-getCommands
- 16.6.22. The remote-option4-global-get-all,remote-option6-global-get-allCommands
- 16.6.23. The remote-option4-global-set,remote-option6-global-setCommands
- 16.6.24. The remote-option4-network-del,remote-option6-network-delCommands
- 16.6.25. The remote-option4-network-set,remote-option6-network-setCommands
- 16.6.26. The remote-option6-pd-pool-delCommand
- 16.6.27. The remote-option6-pd-pool-setCommand
- 16.6.28. The remote-option4-pool-del,remote-option6-pool-delCommands
- 16.6.29. The remote-option4-pool-set,remote-option6-pool-setCommands
- 16.6.30. The remote-option4-subnet-del,remote-option6-subnet-delCommands
- 16.6.31. The remote-option4-subnet-set,remote-option6-subnet-setCommands
- 16.6.32. The remote-subnet4-del-by-id,remote-subnet6-del-by-idCommands
- 16.6.33. The remote-subnet4-del-by-prefix,remote-subnet6-del-by-prefixCommands
- 16.6.34. The remote-subnet4-get-by-id,remote-subnet6-get-by-idCommands
- 16.6.35. The remote-subnet4-get-by-prefix,remote-subnet6-get-by-prefixCommands
- 16.6.36. The remote-subnet4-list,remote-subnet6-listCommands
- 16.6.37. The remote-subnet4-set,remote-subnet6-setCommands
- 16.6.38. The remote-class4-del,remote-class6-delCommands
- 16.6.39. The remote-class4-get,remote-class6-getCommands
- 16.6.40. The remote-class4-get-all,remote-class6-get-allCommands
- 16.6.41. The remote-class4-set,remote-class6-setCommands
 
- 16.7. libdhcp_class_cmds.so: Class Commands
- 16.8. libdhcp_ddns_tuning.so: DDNS Tuning
- 16.9. libdhcp_flex_id.so: Flexible Identifier for Host Reservations
- 16.10. libdhcp_flex_option.so: Flexible Option Actions for Option Value Settings
- 16.11. libddns_gss_tsig.so: Sign DNS Updates With GSS-TSIG
- 16.12. libdhcp_ha.so: High Availability Outage Resilience for Kea Servers- 16.12.1. Supported Configurations
- 16.12.2. Clocks on Active Servers
- 16.12.3. HTTPS Support
- 16.12.4. Server States
- 16.12.5. Scope Transition in a Partner-Down Case
- 16.12.6. Load-Balancing Configuration
- 16.12.7. Load Balancing With Advanced Classification
- 16.12.8. Hot-Standby Configuration
- 16.12.9. Passive-Backup Configuration
- 16.12.10. Lease Information Sharing
- 16.12.11. Controlling Lease-Page Size Limit
- 16.12.12. Timeouts
- 16.12.13. Pausing the HA State Machine
- 16.12.14. Control Agent Configuration
- 16.12.15. Multi-Threaded Configuration (HA+MT)
- 16.12.16. Parked-Packet Limit
- 16.12.17. Controlled Shutdown and Maintenance of DHCP Servers
- 16.12.18. Control Commands for High Availability- 16.12.18.1. The ha-syncCommand
- 16.12.18.2. The ha-scopesCommand
- 16.12.18.3. The ha-continueCommand
- 16.12.18.4. The ha-heartbeatCommand
- 16.12.18.5. The status-getCommand
- 16.12.18.6. The ha-maintenance-startCommand
- 16.12.18.7. The ha-maintenance-cancelCommand
- 16.12.18.8. The ha-maintenance-notifyCommand
- 16.12.18.9. The ha-resetCommand
- 16.12.18.10. The ha-sync-complete-notifyCommand
 
- 16.12.18.1. The 
- 16.12.19. Hub and Spoke Configuration
 
- 16.13. libdhcp_host_cache.so: Host Cache Reservations for Improved Performance
- 16.14. libdhcp_host_cmds.so: Host Commands- 16.14.1. The subnet-idParameter
- 16.14.2. The operation-targetParameter
- 16.14.3. The reservation-addCommand
- 16.14.4. The reservation-getCommand
- 16.14.5. The reservation-get-allCommand
- 16.14.6. The reservation-get-pageCommand
- 16.14.7. The reservation-get-by-addressCommand
- 16.14.8. The reservation-get-by-hostnameCommand
- 16.14.9. The reservation-get-by-idCommand
- 16.14.10. The reservation-delCommand
- 16.14.11. The reservation-updateCommand
- 16.14.12. General Mentions
 
- 16.14.1. The 
- 16.15. libdhcp_lease_cmds.so: Lease Commands for Easier Lease Management- 16.15.1. The lease4-add,lease6-addCommands
- 16.15.2. The lease6-bulk-applyCommand
- 16.15.3. The lease4-get,lease6-getCommands
- 16.15.4. The lease4-get-all,lease6-get-allCommands
- 16.15.5. The lease4-get-page,lease6-get-pageCommands
- 16.15.6. The lease4-get-by-*,lease6-get-by-*Commands
- 16.15.7. The lease4-del,lease6-delCommands
- 16.15.8. The lease4-update,lease6-updateCommands
- 16.15.9. The lease4-wipe,lease6-wipeCommands
- 16.15.10. The lease4-resend-ddns,lease6-resend-ddnsCommands
- 16.15.11. The lease4-write,lease6-writeCommands
 
- 16.15.1. The 
- 16.16. libdhcp_lease_query.so: Leasequery Support
- 16.17. libdhcp_legal_log.so: Forensic Logging
- 16.18. libdhcp_limits.so: Limits to Manage Lease Allocation and Packet Processing
- 16.19. libdhcp_mysql.so: Database Backend for MySQL
- 16.20. libdhcp_perfmon.so: Performance Monitoring
- 16.21. libdhcp_ping_check.so: Ping Check
- 16.22. libdhcp_pgsql.so: Database Backend for PostgreSQL
- 16.23. libdhcp_radius.so: RADIUS Server Support
- 16.24. libdhcp_rbac.so: Role-Based Access Control
- 16.25. libdhcp_run_script.so: Run Script Support for External Hook Scripts
- 16.26. libdhcp_stat_cmds.so: Statistics Commands for Supplemental Lease Statistics
- 16.27. libdhcp_subnet_cmds.so: Subnet Commands to Manage Subnets and Shared Networks- 16.27.1. The subnet4-listCommand
- 16.27.2. The subnet6-listCommand
- 16.27.3. The subnet4-getCommand
- 16.27.4. The subnet6-getCommand
- 16.27.5. The subnet4-addCommand
- 16.27.6. The subnet6-addCommand
- 16.27.7. The subnet4-updateCommand
- 16.27.8. The subnet6-updateCommand
- 16.27.9. The subnet4-delCommand
- 16.27.10. The subnet6-delCommand
- 16.27.11. The subnet4-delta-addCommand
- 16.27.12. The subnet6-delta-addCommand
- 16.27.13. The subnet4-delta-delCommand
- 16.27.14. The subnet6-delta-delCommand
- 16.27.15. The network4-list,network6-listCommands
- 16.27.16. The network4-get,network6-getCommands
- 16.27.17. The network4-add,network6-addCommands
- 16.27.18. The network4-del,network6-delCommands
- 16.27.19. The network4-subnet-add,network6-subnet-addCommands
- 16.27.20. The network4-subnet-del,network6-subnet-delCommands
 
- 16.27.1. The 
- 16.28. libdhcp_user_chk.so: User Check
 
- 17. Statistics- 17.1. Statistics Overview
- 17.2. Statistics Lifecycle
- 17.3. Commands for Manipulating Statistics- 17.3.1. The statistic-getCommand
- 17.3.2. The statistic-resetCommand
- 17.3.3. The statistic-removeCommand
- 17.3.4. The statistic-get-allCommand
- 17.3.5. The statistic-reset-allCommand
- 17.3.6. The statistic-remove-allCommand
- 17.3.7. The statistic-sample-age-setCommand
- 17.3.8. The statistic-sample-age-set-allCommand
- 17.3.9. The statistic-sample-count-setCommand
- 17.3.10. The statistic-sample-count-set-allCommand
 
- 17.3.1. The 
- 17.4. Time Series
 
- 18. Management API- 18.1. Data Syntax
- 18.2. Control Agent Command Response Format
- 18.3. Using the Control Channel
- 18.4. Commands Supported by Both the DHCPv4 and DHCPv6 Servers- 18.4.1. The build-reportCommand
- 18.4.2. The config-getCommand
- 18.4.3. The config-hash-getCommand
- 18.4.4. The config-reloadCommand
- 18.4.5. The config-testCommand
- 18.4.6. The config-writeCommand
- 18.4.7. The leases-reclaimCommand
- 18.4.8. The list-commandsCommand
- 18.4.9. The config-setCommand
- 18.4.10. The shutdownCommand
- 18.4.11. The dhcp-disableCommand
- 18.4.12. The dhcp-enableCommand
- 18.4.13. The status-getCommand
- 18.4.14. The server-tag-getCommand:
- 18.4.15. The config-backend-pullCommand:
- 18.4.16. The version-getCommand
 
- 18.4.1. The 
- 18.5. Commands Supported by the DHCPv4 Server
- 18.6. Commands Supported by the DHCPv6 Server
- 18.7. Commands Supported by the D2 Server
- 18.8. Commands Supported by the Control Agent
- 18.9. Migration from the Control Agent
 
- 19. Logging
- 20. The Kea Shell
- 21. Integration With External Systems- 21.1. YANG/NETCONF- 21.1.1. Overview
- 21.1.2. Installing NETCONF
- 21.1.3. Compiling With NETCONF
- 21.1.4. Quick Sysrepo Overview
- 21.1.5. Supported YANG Models
- 21.1.6. Using the NETCONF Agent
- 21.1.7. Configuration
- 21.1.8. A kea-netconfConfiguration Example
- 21.1.9. Starting and Stopping the NETCONF Agent
- 21.1.10. A Step-by-Step NETCONF Agent Operation Example- 21.1.10.1. Setup of NETCONF Agent Operation Example
- 21.1.10.2. Example of Error Handling in NETCONF Operation
- 21.1.10.3. NETCONF Operation Example with Two Pools
- 21.1.10.4. NETCONF Operation Example with Two Subnets
- 21.1.10.5. NETCONF Operation Example With Logging
- 21.1.10.6. Migrating YANG Data From a Prior Sysrepo Version
 
 
- 21.2. GSS-TSIG- 21.2.1. GSS-TSIG Overview
- 21.2.2. GSS-TSIG Compilation
- 21.2.3. GSS-TSIG Deployment
- 21.2.4. Using GSS-TSIG
- 21.2.5. GSS-TSIG Statistics
- 21.2.6. GSS-TSIG Commands- 21.2.6.1. The gss-tsig-get-allCommand
- 21.2.6.2. The gss-tsig-getCommand
- 21.2.6.3. The gss-tsig-listCommand
- 21.2.6.4. The gss-tsig-key-getCommand
- 21.2.6.5. The gss-tsig-key-expireCommand
- 21.2.6.6. The gss-tsig-key-delCommand
- 21.2.6.7. The gss-tsig-purge-allCommand
- 21.2.6.8. The gss-tsig-purgeCommand
- 21.2.6.9. The gss-tsig-rekey-allCommand
- 21.2.6.10. The gss-tsig-rekeyCommand
 
- 21.2.6.1. The 
 
- 21.3. RADIUS
 
- 21.1. YANG/NETCONF
- 22. Monitoring Kea With Stork
- 23. Kea Security- 23.1. TLS/HTTPS Support
- 23.2. Securing a Kea Deployment- 23.2.1. Component-Based Design
- 23.2.2. Limiting Application Permissions
- 23.2.3. Securing Kea Administrative Access
- 23.2.4. Securing Database Connections
- 23.2.5. Information Leakage Through Logging
- 23.2.6. Cryptography Components
- 23.2.7. TSIG Signatures
- 23.2.8. Raw Socket Support
- 23.2.9. Remote Administrative Access
- 23.2.10. Authentication for Kea's RESTful API
 
- 23.3. Kea Security Processes