/resolver

Development repository for Chef Cookbook resolver

Primary LanguageRubyApache License 2.0Apache-2.0

resolver Cookbook

Build Status Cookbook Version

Configures /etc/resolv.conf, unless the nameservers attribute is empty. Search will be excluded if empty.

Requirements

Platforms

  • AIX
  • Debian/Ubuntu
  • RHEL/CentOS/Scientific/Amazon/Oracle
  • Fedora
  • FreeBSD/OpenBSD
  • Mac OS X
  • Solaris
  • openSUSE / SUSE Enterprise

Chef

  • Chef 12.1+

Cookbooks

  • none

Attributes

See attributes/default.rb for default values.

  • node['resolver']['search'] - an array of search domains for host-name lookup; a string may also be provided for backwards compatibility. Limited to 6 elements and 256 characters.
  • node['resolver']['nameservers'] - Required, an array of nameserver IP address strings; the default is an empty array, and the default recipe will not change resolv.conf if this is not set. See Usage.
  • node['resolver']['options'] - a hash of resolv.conf options. See Usage for examples.
  • node['resolver']['domain'] - Local domain name. if nil, the domain is determined from the local hostname returned by gethostname(2).

Recipes

default

Configure /etc/resolv.conf based on attributes.

Usage

Using the default recipe, set the resolver attributes in a role, for example from my base.rb:

"resolver" => {
  "nameservers" => ["10.13.37.120", "10.13.37.40"],
  "search" => [ "int.example.org", "ext.example.org" ],
  "options" => {
    "timeout" => 2, "rotate" => nil
  }
}

The resulting /etc/resolv.conf will look like:

search int.example.org ext.example.org
nameserver 10.13.37.120
nameserver 10.13.37.40
options timeout:2 rotate

License & Authors

Copyright 2009-2016, Chef Software, Inc.

Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at

    http://www.apache.org/licenses/LICENSE-2.0

Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.