Кукольный пакет "обеспечить => последний" не всегда работает
У меня уникальная ситуация, когда пакет Puppet ensure => latest
Директива работала только на некоторых моих системах. Из 30 серверов пакеты обновлены должным образом на всех, кроме 4. Я пытаюсь получить основные версии пакета программного обеспечения с < 9.40 до 9.50. Я мог бы указать жесткий уровень, но я столкнулся с проблемой многократного подстановочного знака архитектуры.
Фрагмент кода манифеста:
# Install packages
$spppackages = [ "hp-snmp-agents", "hpssa", "hp-health", "hp-smh-templates", "hpsmh", "hpssacli", "hponcfg", ]
package { $spppackages:
ensure => latest,
require => Yumrepo['HP-spp'],
}
M колективный статус:
mco package hp-snmp-agents status
Summary of Ensure:
9.50-2564.40.rhel6 = 14
9.50-2564.34.rhel5 = 9
9.40-2506.37.rhel6 = 4 <== This is what I'm trying to fix!
9.50-2564.35.rhel5 = 1
Я попытался отладить это на уязвимых системах с помощью:
puppet apply --verbose --debug --execute 'package { hp-snmp-agents: ensure => latest }'
В результате чего:
Info: Applying configuration version '1393411670'
Debug: Prefetching yum resources for package
Debug: Executing '/bin/rpm --version'
Debug: Executing '/bin/rpm -qa --nosignature --nodigest --qf '%{NAME} %|EPOCH?{%{EPOCH}}:{0}| %{VERSION} %{RELEASE} %{ARCH} :DESC: %{SUMMARY}\n''
Error: Could not prefetch package provider 'yum': invalid byte sequence in US-ASCII
Debug: Executing '/bin/rpm -q hp-snmp-agents --nosignature --nodigest --qf '%{NAME} %|EPOCH?{%{EPOCH}}:{0}| %{VERSION} %{RELEASE} %{ARCH} :DESC: %{SUMMARY}\n''
Debug: Finishing transaction 11762680
Debug: Storing state
Debug: Stored state in 0.09 seconds
Бег yum list updates hp-snmp-agents
показывает, что пакет может быть обновлен yum и доступна более новая версия:
Installed Packages
hp-snmp-agents.x86_64 9.40-2506.37.rhel6 @HP-spp
Available Packages
hp-snmp-agents.x86_64 9.50-2564.40.rhel6 HP-spp
Похоже, что проблема может быть в формате запроса версии rpm. Выполнение этого вручную дает:
# /bin/rpm -q hp-snmp-agents --nosignature --nodigest --qf '%{NAME} %|EPOCH?{%{EPOCH}}:{0}| %{VERSION} %{RELEASE} %{ARCH} :DESC: %{SUMMARY}\n'
hp-snmp-agents 0 9.40 2506.37.rhel6 x86_64 :DESC: Insight Management Agents(SNMP) for HP ProLiant Systems
Если я ensure => 9.50-xxx
на hp-snmp-agents
пакет, я могу заставить это работать на упрямых системах. Кажется, что даже ввод поддельного номера версии запускает сборку каталога, и последующие запуски агента Puppet работают и обновляются должным образом. Мне просто любопытно, почему это сработало без проблем на 26 из 30 серверов и требовало массирования на остальных.
Обратите внимание, я сделал yum clean all
через Mcollective в качестве начального шага устранения неполадок
1 ответ
Я считаю, что проблема заключается в следующем:
Debug: Executing '/bin/rpm -qa --nosignature --nodigest --qf '%{NAME} %|EPOCH?{%{EPOCH}}:{0}| %{VERSION} %{RELEASE} %{ARCH} :DESC: %{SUMMARY}\n''
Error: Could not prefetch package provider 'yum': invalid byte sequence in US-ASCII
О чем говорится в этой ошибке: https://tickets.puppetlabs.com/browse/PUP-736
В основном где-то в этом rpm -qa ...
вывод, вы получаете UTF-8 (или другой не-ASCII) символ, и это заставляет кукольника думать, что провайдер "yum" не годится. Поскольку у провайдера "rpm" нет ensure => latest
поддержка, он игнорирует это, и вы получаете старую версию.
Вы можете либо обновить программу до версии 3.4.3, которая включает исправление, либо сравнить /bin/rpm -qa ... | sort
вывод между коробками, которые работали правильно и не работали правильно, чтобы найти пакет преступника. Переход с LANG=C на LANG=en_US.UTF-8 (или любой другой действующий UTF-8 LANG) также должен временно решить проблему.