140 lines
5.5 KiB
Markdown
140 lines
5.5 KiB
Markdown
|
# [dhcpd](#dhcpd)
|
||
|
|
||
|
Install and configure dhcpd on your system.
|
||
|
|
||
|
|GitHub|GitLab|Quality|Downloads|Version|
|
||
|
|------|------|-------|---------|-------|
|
||
|
|[data:image/s3,"s3://crabby-images/c0875/c0875133910224aec64482238f93dca6d21c8bf8" alt="github"](https://github.com/robertdebock/ansible-role-dhcpd/actions)|[data:image/s3,"s3://crabby-images/0e544/0e544d40c9d5f032a0ec6c5f50b06c930efbc141" alt="gitlab"](https://gitlab.com/robertdebock/ansible-role-dhcpd)|[data:image/s3,"s3://crabby-images/9da5b/9da5bfb91f49ba0e48e3277c45934f7d20572449" alt="quality"](https://galaxy.ansible.com/robertdebock/dhcpd)|[data:image/s3,"s3://crabby-images/79c0d/79c0d0f539d283700e6d82beea1acdee4dec961e" alt="downloads"](https://galaxy.ansible.com/robertdebock/dhcpd)|[data:image/s3,"s3://crabby-images/c6583/c65839b612f69826c62c0f7ee76f65baee629d65" alt="Version"](https://github.com/robertdebock/ansible-role-dhcpd/releases/)|
|
||
|
|
||
|
## [Example Playbook](#example-playbook)
|
||
|
|
||
|
This example is taken from `molecule/default/converge.yml` and is tested on each push, pull request and release.
|
||
|
```yaml
|
||
|
---
|
||
|
- name: Converge
|
||
|
hosts: all
|
||
|
become: yes
|
||
|
gather_facts: yes
|
||
|
|
||
|
vars:
|
||
|
dhcpd_subnets:
|
||
|
- network: "{{ ansible_default_ipv4.network }}"
|
||
|
netmask: "255.255.255.0"
|
||
|
|
||
|
roles:
|
||
|
- role: robertdebock.dhcpd
|
||
|
```
|
||
|
|
||
|
The machine needs to be prepared. In CI this is done using `molecule/default/prepare.yml`:
|
||
|
```yaml
|
||
|
---
|
||
|
- name: Prepare
|
||
|
hosts: all
|
||
|
gather_facts: no
|
||
|
become: yes
|
||
|
|
||
|
roles:
|
||
|
- role: robertdebock.bootstrap
|
||
|
- role: robertdebock.apt_autostart
|
||
|
- role: robertdebock.core_dependencies
|
||
|
```
|
||
|
|
||
|
Also see a [full explanation and example](https://robertdebock.nl/how-to-use-these-roles.html) on how to use these roles.
|
||
|
|
||
|
## [Role Variables](#role-variables)
|
||
|
|
||
|
The default values for the variables are set in `defaults/main.yml`:
|
||
|
```yaml
|
||
|
---
|
||
|
# defaults file for dhcpd
|
||
|
|
||
|
# Configuration settings for the daemon.
|
||
|
dhcpd_ipv4_interface: "{{ ansible_default_ipv4.interface | default('eth0') }}"
|
||
|
|
||
|
# Setting applicable for the global scope.
|
||
|
dhcpd_default_lease_time: 600
|
||
|
dhcpd_max_lease_time: 7200
|
||
|
dhcpd_subnet_mask: "255.255.255.0"
|
||
|
dhcpd_broadcast_address: "10.0.2.255"
|
||
|
dhcpd_routers: "10.0.2.254"
|
||
|
dhcpd_domain_name_servers:
|
||
|
- "192.168.1.1"
|
||
|
- "192.168.1.2"
|
||
|
dhcpd_domain_search: example.com
|
||
|
|
||
|
# The image to serve for PXE booting.
|
||
|
dhcpd_filename: "pxelinux.0"
|
||
|
# Where the image can be downloaded from.
|
||
|
dhcpd_next_server: "10.0.2.254"
|
||
|
|
||
|
# DHCP works with subnets, a list containing properties per subnet.
|
||
|
dhcpd_subnets:
|
||
|
- network: "10.0.2.0"
|
||
|
netmask: "255.255.255.0"
|
||
|
range_start: "10.0.2.200"
|
||
|
range_end: "10.0.2.210"
|
||
|
```
|
||
|
|
||
|
## [Requirements](#requirements)
|
||
|
|
||
|
- pip packages listed in [requirements.txt](https://github.com/robertdebock/ansible-role-dhcpd/blob/master/requirements.txt).
|
||
|
|
||
|
## [Status of used roles](#status-of-requirements)
|
||
|
|
||
|
The following roles are used to prepare a system. You can prepare your system in another way.
|
||
|
|
||
|
| Requirement | GitHub | GitLab |
|
||
|
|-------------|--------|--------|
|
||
|
|[robertdebock.apt_autostart](https://galaxy.ansible.com/robertdebock/apt_autostart)|[data:image/s3,"s3://crabby-images/b4095/b40955220a8b43bb31fed545194f4e2e1340ca5a" alt="Build Status GitHub"](https://github.com/robertdebock/ansible-role-apt_autostart/actions)|[data:image/s3,"s3://crabby-images/ac433/ac4338ab608796a6bc221835806e2e2b6d449b85" alt="Build Status GitLab "](https://gitlab.com/robertdebock/ansible-role-apt_autostart)|
|
||
|
|[robertdebock.bootstrap](https://galaxy.ansible.com/robertdebock/bootstrap)|[data:image/s3,"s3://crabby-images/1924d/1924d23393422e14c8d821767dbd7b5407434858" alt="Build Status GitHub"](https://github.com/robertdebock/ansible-role-bootstrap/actions)|[data:image/s3,"s3://crabby-images/56088/560882c33407dfd85eb3909d80dac36f1a03d1b7" alt="Build Status GitLab "](https://gitlab.com/robertdebock/ansible-role-bootstrap)|
|
||
|
|[robertdebock.core_dependencies](https://galaxy.ansible.com/robertdebock/core_dependencies)|[data:image/s3,"s3://crabby-images/b9c35/b9c355186033cbc5c3b5c3cdcbf1b8283e150aa9" alt="Build Status GitHub"](https://github.com/robertdebock/ansible-role-core_dependencies/actions)|[data:image/s3,"s3://crabby-images/4c1b6/4c1b6bbc2c6ae9f5a8479c55d4e3fd83ae9925ea" alt="Build Status GitLab "](https://gitlab.com/robertdebock/ansible-role-core_dependencies)|
|
||
|
|
||
|
## [Context](#context)
|
||
|
|
||
|
This role is a part of many compatible roles. Have a look at [the documentation of these roles](https://robertdebock.nl/) for further information.
|
||
|
|
||
|
Here is an overview of related roles:
|
||
|
data:image/s3,"s3://crabby-images/e9ea5/e9ea51a3c05ae69fb5db18ccb1c1c6530052470c" alt="dependencies"
|
||
|
|
||
|
## [Compatibility](#compatibility)
|
||
|
|
||
|
This role has been tested on these [container images](https://hub.docker.com/u/robertdebock):
|
||
|
|
||
|
|container|tags|
|
||
|
|---------|----|
|
||
|
|alpine|all|
|
||
|
|amazon|Candidate|
|
||
|
|el|8|
|
||
|
|debian|all|
|
||
|
|fedora|all|
|
||
|
|ubuntu|all|
|
||
|
|
||
|
The minimum version of Ansible required is 2.10, tests have been done to:
|
||
|
|
||
|
- The previous version.
|
||
|
- The current version.
|
||
|
- The development version.
|
||
|
|
||
|
## [Exceptions](#exceptions)
|
||
|
|
||
|
Some roles can't run on a specific distribution or version. Here are some exceptions.
|
||
|
|
||
|
| variation | reason |
|
||
|
|---------------------------|------------------------|
|
||
|
| Suse | Starting ISC DHCPv4 Server chown: invalid user: 'dhcpd:root
|
||
|
shadow
|
||
|
... |
|
||
|
|
||
|
|
||
|
If you find issues, please register them in [GitHub](https://github.com/robertdebock/ansible-role-dhcpd/issues)
|
||
|
|
||
|
## [License](#license)
|
||
|
|
||
|
Apache-2.0
|
||
|
|
||
|
## [Author Information](#author-information)
|
||
|
|
||
|
[Robert de Bock](https://robertdebock.nl/)
|
||
|
|
||
|
Please consider [sponsoring me](https://github.com/sponsors/robertdebock).
|