guides:reference:infoblox:ipam_tree
Differences
This shows you the differences between two versions of the page.
Both sides previous revisionPrevious revisionNext revision | Previous revision | ||
guides:reference:infoblox:ipam_tree [2019/12/23 16:48] – ↷ Page moved from guides:reference:infoblox:dns:ipam_tree to guides:reference:infoblox:ipam_tree yspeerte | guides:reference:infoblox:ipam_tree [2024/07/03 12:31] (current) – external edit 127.0.0.1 | ||
---|---|---|---|
Line 1: | Line 1: | ||
+ | {{indexmenu_n> | ||
+ | |||
+ | ===== IPAM Tree ===== | ||
+ | |||
+ | To define the IPAM / DHCP tree for an ip-plan, the table '' | ||
+ | |||
+ | The credentials to access the netYCE databases with read-write permissions: | ||
+ | username: '' | ||
+ | password: '' | ||
+ | |||
+ | The credentials to access the netYCE databases with read-only permissions: | ||
+ | username: '' | ||
+ | password: '' | ||
+ | |||
+ | The ' | ||
+ | |||
+ | |||
+ | ==== Custom DHCP Tables ==== | ||
+ | |||
+ | Three tables are required for the Infoblox DHCP / IPAM functionality that all reside in the '' | ||
+ | |||
+ | The '' | ||
+ | |||
+ | The '' | ||
+ | |||
+ | The '' | ||
+ | |||
+ | |||
+ | BASE TABLE: NMS.Dhcp_tree | ||
+ | |||
+ | <code sql> | ||
+ | CREATE TABLE `NMS`.`Dhcp_tree` ( | ||
+ | `Dhcp_id` int(11) NOT NULL AUTO_INCREMENT, | ||
+ | `Plan_id` int(11) NOT NULL DEFAULT ' | ||
+ | `Net_name` varchar(20) DEFAULT '', | ||
+ | `Net_offset` varchar(20) DEFAULT '', | ||
+ | `Net_mask` varchar(20) DEFAULT '', | ||
+ | `Net_size` int(11) DEFAULT ' | ||
+ | `Net_tier` int(11) NOT NULL DEFAULT ' | ||
+ | `Net_type` varchar(20) DEFAULT '', | ||
+ | `Net_index` int(11) DEFAULT ' | ||
+ | `Scope_start` varchar(20) DEFAULT '', | ||
+ | `Scope_end` varchar(20) DEFAULT '', | ||
+ | `Dhcp_options` varchar(50) DEFAULT '', | ||
+ | `Features` varchar(200) DEFAULT '', | ||
+ | `Net_remark` varchar(100) DEFAULT '', | ||
+ | `Timestamp` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP, | ||
+ | PRIMARY KEY (`Dhcp_id`), | ||
+ | KEY `Net_index` (`Plan_id`, | ||
+ | KEY `Net_name` (`Plan_id`, | ||
+ | ) ENGINE=MyISAM AUTO_INCREMENT=1000 DEFAULT CHARSET=utf8 | ||
+ | </ | ||
+ | |||
+ | BASE TABLE: NMS.Dhcp_history | ||
+ | |||
+ | <code sql> | ||
+ | CREATE TABLE `NMS`.`Dhcp_history` ( | ||
+ | `Supernet` varchar(20) NOT NULL DEFAULT '', | ||
+ | `Xml_data` longtext, | ||
+ | `Timestamp` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP, | ||
+ | PRIMARY KEY (`Supernet`) | ||
+ | ) ENGINE=MyISAM DEFAULT CHARSET=utf8 | ||
+ | </ | ||
+ | |||
+ | BASE TABLE: NMS.Dhcp_clients | ||
+ | |||
+ | <code sql> | ||
+ | CREATE TABLE `NMS`.`Dhcp_clients` ( | ||
+ | `ClientCode` varchar(30) NOT NULL DEFAULT '', | ||
+ | `Lease_time` int(11) NOT NULL DEFAULT ' | ||
+ | `Ddns_enable` int(11) NOT NULL DEFAULT ' | ||
+ | `Dhcpsrv1_feature` varchar(20) DEFAULT '', | ||
+ | `Dhcpsrv2_feature` varchar(20) DEFAULT '', | ||
+ | `Domain1_feature` varchar(50) DEFAULT '', | ||
+ | `Domain2_feature` varchar(50) DEFAULT '', | ||
+ | `Domain3_feature` varchar(50) DEFAULT '', | ||
+ | `Lease1_feature` int(11) NOT NULL DEFAULT ' | ||
+ | `Lease2_feature` int(11) NOT NULL DEFAULT ' | ||
+ | `Dns_pri` varchar(20) DEFAULT '', | ||
+ | `Dns_sec` varchar(20) DEFAULT '', | ||
+ | `Dns_tert` varchar(20) DEFAULT '', | ||
+ | `Wins_pri` varchar(20) DEFAULT '', | ||
+ | `Wins_sec` varchar(20) DEFAULT '', | ||
+ | `Timestamp` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP, | ||
+ | PRIMARY KEY (`ClientCode`) | ||
+ | ) ENGINE=MyISAM DEFAULT CHARSET=utf8 | ||
+ | </ | ||
+ | |||
+ | |||
+ | ==== Tree Objects ==== | ||
+ | |||
+ | In an IPAM/DHCP tree three types of objects are used to build a structured, hierarchical representation of an ip-space called supernet. The tree consists of " | ||
+ | |||
+ | The " | ||
+ | |||
+ | The " | ||
+ | |||
+ | The " | ||
+ | |||
+ | The definition of a IPAM/DHCP tree is closely related to the definition of an IP-plan. The tree is structured around the subnets defined in the supernet' | ||
+ | |||
+ | Along with structuring the ip-plan' | ||
+ | |||
+ | ==== Tree Tiers ==== | ||
+ | |||
+ | To represent the hierarchy of each object in the tree, a " | ||
+ | |||
+ | To allow supernets to be grouped the tier can also be made negative - but only for " | ||
+ | |||
+ | The example below shows how a simple tree is created using two groups of subnets, ' | ||
+ | |||
+ | ^ Net_tier | ||
+ | | -3 | | container | Customer networks | 0.0.0.0 | 8 | | ||
+ | | -2 | | container | Aggregation | 0.0.0.0 | 12 | | ||
+ | | -1 | | container | Aggregation | 0.0.0.0 | 16 | | ||
+ | | 0 | | container | Supernet | 0.0.0.0 | 18 | | ||
+ | | 1 | | container | Users | 0.0.0.0 | 21 | | ||
+ | | 2 | 0 | net | Users | | | | ||
+ | | 3 | 0 | scope | Users | | | | ||
+ | | 2 | 1 | net | Users | | | | ||
+ | | 3 | 1 | scope | Users | | | | ||
+ | | 2 | 2 | net | Users | | | | ||
+ | | 3 | 2 | scope | Users | | | | ||
+ | | 2 | 3 | net | Users | | | | ||
+ | | 3 | 3 | scope | Users | | | | ||
+ | | 1 | | container | IPT | 0.0.8.0 | 21 | | ||
+ | | 2 | 0 | net | IPT | | | | ||
+ | | 3 | 0 | scope | IPT | | | | ||
+ | | 2 | 1 | net | IPT | | | | ||
+ | | 3 | 1 | scope | IPT | | | | ||
+ | | 2 | 2 | net | IPT | | | | ||
+ | | 3 | 2 | scope | IPT | | | | ||
+ | | 2 | 3 | net | IPT | | | | ||
+ | | 3 | 3 | scope | IPT | | | | ||
+ | |||
+ | |||
+ | ==== Network Index ==== | ||
+ | |||
+ | In the example above, the '' | ||
+ | |||
+ | This " | ||
+ | |||
+ | The example tree above was built around this (partial) ip-plan. | ||
+ | |||
+ | ^ Net_name ^ Net_index ^ Net_size ^ Net_offset ^ Net_range ^ | ||
+ | | Users | 0 | 25 | 0.0.0.0 | 0.0.0.127 | | ||
+ | | Users | 1 | 25 | 0.0.0.128 | 0.0.0.255 | | ||
+ | | Users | 2 | 25 | 0.0.1.0 | 0.0.1.127 | | ||
+ | | Users | 3 | 25 | 0.0.1.128 | 0.0.1.255 | | ||
+ | | IPT | 0 | 25 | 0.0.8.0 | 0.0.8.127 | | ||
+ | | IPT | 1 | 25 | 0.0.8.128 | 0.0.8.255 | | ||
+ | | IPT | 2 | 25 | 0.0.9.0 | 0.0.9.127 | | ||
+ | | IPT | 3 | 25 | 0.0.9.128 | 0.0.9.255 | | ||
+ | |||
+ | The tree can have subnets and scopes defined that are not part of the ip-plan. But then these details need to be added to the tree. Likewise, the tree does not need to have to include all subnets in the ip-plan. As in the case of a large range of Loopback /32 " | ||
+ | |||
+ | ==== Scope ranges ==== | ||
+ | |||
+ | The definition of the DHCP scopes is not complete until the dhcp range is added. The offsets for the first and the last ip-address of each scope must be added. Their values must reside within the subnet itself. If more than one scope is added to a subnet, their ranges may not overlap. | ||
+ | |||
+ | If the Scope_start or Scope_end is missing default values will be calculated. The default Scope_start is '' | ||
+ | |||
+ | ^ Net_tier | ||
+ | | 1 | | container | IPT | 0.0.8.0 | 21 | | | | ||
+ | | 2 | 0 | net | IPT | | | | | | ||
+ | | 3 | 0 | scope | IPT | | | 0.0.0.6 | 0.0.0.126 | | ||
+ | | 2 | 1 | net | IPT | | | | | | ||
+ | | 3 | 1 | scope | IPT | | | 0.0.0.6 | 0.0.0.126 | | ||
+ | | 2 | 2 | net | IPT | | | | | | ||
+ | | 3 | 2 | scope | IPT | | | 0.0.0.6 | 0.0.0.126 | | ||
+ | | 2 | 3 | net | IPT | | | | | | ||
+ | | 3 | 3 | scope | IPT | | | 0.0.0.6 | 0.0.0.126 | | ||
+ | |||
+ | |||
+ | ==== DHCP Options ==== | ||
+ | |||
+ | The final part of the tree definition is the assignment of the required DHCP options and their values. This is a complex topic in itself, requiring a separate article. | ||
+ | |||
+ | > <color blue> See the detailed article on [[guides: | ||
+ | |||
+ | // | ||