СРЕДА: aws opsworks chef 11.10 и ubuntu 14.04.
Я использую рецепт от шеф-повара, чтобы обновить /etc/dhcp/dhclient.conf
файл на узле aws opsworks ec2, чтобы добавить мой настраиваемый суффикс поиска DNS в строку поиска в /etc/resolv.conf
файл.
Как получить мой рецепт перезагрузки узла ТОЛЬКО если file.insert_line_if_no_match
обновляет файл? Очевидно, я не хочу, чтобы узел перезагружался каждый раз при запуске рецепта.
В моем фрагменте кода под значением node['opsworks']['stack']['name']
что-то вроде a.dev.mydomain.com
.
ruby_block "add custom dns domain search suffix" do
block do
file = Chef::Util::FileEdit.new("/etc/dhcp/dhclient.conf")
file.insert_line_if_no_match("/append domain-search/", "append domain-search \"#{node['opsworks']['stack']['name']}\";")
file.write_file
end
end
Приведенный выше фрагмент кода добавляет последнюю строку в /etc/dhcp/dhclient.conf
:
# Configuration file for /sbin/dhclient, which is included in Debian's
# dhcp3-client package.
#
option rfc3442-classless-static-routes code 121 = array of unsigned integer 8;
send host-name = gethostname();
request subnet-mask, broadcast-address, time-offset, routers,
domain-name, domain-name-servers, domain-search, host-name,
dhcp6.name-servers, dhcp6.domain-search,
netbios-name-servers, netbios-scope, interface-mtu,
rfc3442-classless-static-routes, ntp-servers,
dhcp6.fqdn, dhcp6.sntp-servers;
append domain-search "a.dev.mydomain.com";
После перезагрузки /etc/dhcp/dhclient.conf
изменяется следующим образом:
# Dynamic resolv.conf(5) file for glibc resolver(3) generated by resolvconf(8)
# DO NOT EDIT THIS FILE BY HAND -- YOUR CHANGES WILL BE OVERWRITTEN
nameserver 172.16.0.23
search ec2.internal a.dev.mydomain.com
ПРИМЕЧАНИЕ. Я думаю, что это слишком рискованно пытаться реализовать настройку с помощью чего-то вроде sudo dhclient -r; sudo dhclient
после обновления файла, но я бы хотел услышать, удалось ли кому-нибудь получить этот тип обновления для работы без перезагрузки.
Я настоятельно рекомендую вам найти способ сделать это без перезагрузки компьютера. Я сделал что-то подобное, например, на Centos, что было достигнуто с помощью sudo service network restart
. Тем не менее, независимо от того, перезагружаете ли вы компьютер или только одну службу, вы будете использовать один и тот же шаблон.
Правильный способ сделать это - использовать собственный ресурс / поставщика. В этом случае (а он вполне может уже быть в сообществе) вы должны написать LWRP, который читает dhclient.conf
файл и изменяет его только при необходимости изменения. Затем он установит updated_by_last_action
если файл обновлен. На этом этапе вы могли бы использовать service
или execute
ресурс для перезапуска службы / машины. Ресурс перезапуска подписывается на изменения ресурса LWRP.
Или вы делаете что-то вроде этого:
execute "add custom dns domain search suffix" do
command "echo 'append domain-search \"#{node['opsworks']['stack']['name']}\";' >> /etc/dhcp/dhclient.conf"
not_if { ::File.open('/etc/dhcp/dhclient.conf').read() =~ /append domain-search/ }
end
execute 'restart machine' do
command 'shutdown immediate -r'
action :nothing
subscribes :run, 'execute[add custom dns domain search suffix]'
end
Большое спасибо Tejay Cardon, ваш код работает как шарм (я обещаю, что когда-нибудь займусь написанием LWRP)!
FTR следующий код работает для меня на сборке aws ec2 ubuntu 14.04 без перезагрузки. Я даже смог сделать sudo ifdown eth0 && sudo ifup eth0
из сеанса ssh и не отключился.
execute "add custom dns domain search suffix" do
command "echo 'append domain-search \"#{node['opsworks']['stack']['name']}\";' >> /etc/dhcp/dhclient.conf"
not_if { ::File.open('/etc/dhcp/dhclient.conf').read() =~ /append domain-search/ }
end
execute 'bounce eth0' do
command 'sudo ifdown eth0 && sudo ifup eth0'
action :nothing
subscribes :run, 'execute[add custom dns domain search suffix]'
end
По какой-то причине sudo service networking restart
и sudo /etc/init.d/networking restart
больше не работает post ubuntu 13.04, и я не делаю этого на рабочем столе или sudo service network-manager restart
возможно, сработало.