Сбой Ansible AWX при использовании DSL для задания Jenkins

Я использую сервер Jenkins 2.140 в Ubuntu 16.04, а также сервер Ansible AWX 1.0.7.2, использующий Ansible 2.6.2.

Я создаю работу в Jenkins, которая запускает шаблон на моем сервере Ansible AWX. У меня есть несколько других заданий Jenkins, которые запускают шаблоны, которые все работают, поэтому я знаю, что общая конфигурация, которую я использую для этого, в порядке.

Однако, когда я создаю задание Jenkins, используя начальное задание, которое использует JobDSL, задание завершается ошибкой на шаге Ansible AWX с такими выходными данными:

11:50:42 [EnvInject] - Loading node environment variables.
11:50:42 Building remotely on windows-slave (excel Windows orqaheadless windows) in workspace C:\JenkinsSlave\workspace\create-ec2-instance-2
11:50:42 ERROR: Build step failed with exception
11:50:42 java.lang.NullPointerException
11:50:42    at org.jenkinsci.plugins.ansible_tower.AnsibleTower.perform(AnsibleTower.java:129)
11:50:42    at hudson.tasks.BuildStepMonitor$1.perform(BuildStepMonitor.java:20)
11:50:42    at hudson.model.AbstractBuild$AbstractBuildExecution.perform(AbstractBuild.java:744)
11:50:42    at hudson.model.Build$BuildExecution.build(Build.java:206)
11:50:42    at hudson.model.Build$BuildExecution.doRun(Build.java:163)
11:50:42    at hudson.model.AbstractBuild$AbstractBuildExecution.run(AbstractBuild.java:504)
11:50:42    at hudson.model.Run.execute(Run.java:1815)
11:50:42    at hudson.model.FreeStyleBuild.run(FreeStyleBuild.java:43)
11:50:42    at hudson.model.ResourceController.execute(ResourceController.java:97)
11:50:42    at hudson.model.Executor.run(Executor.java:429)
11:50:42 Build step 'Ansible Tower' marked build as failure
11:50:42 [BFA] Scanning build for known causes...
11:50:42 [BFA] No failure causes found
11:50:42 [BFA] Done. 0s
11:50:42 Started calculate disk usage of build
11:50:42 Finished Calculation of disk usage of build in 0 seconds
11:50:42 Started calculate disk usage of workspace
11:50:42 Finished Calculation of disk usage of workspace in 0 seconds
11:50:42 Finished: FAILURE

Этот вывод на самом деле ничего не дает мне работать, тем более что я не эксперт по Java.

Я настраиваю работу Дженкинса вручную, и все хорошо. Это config.xml для рабочей работы (только часть AWX). Обратите внимание, что все эти дополнительные переменные передаются ранее в работе в качестве параметров:

<builders>
<org.jenkinsci.plugins.ansible__tower.AnsibleTower plugin="ansible-tower@0.9.0">
<towerServer>AWX Server</towerServer>
<jobTemplate>create-ec2-instance</jobTemplate>
<extraVars>
key_name: ${key_name} ec2_termination_protection: ${ec2_termination_protection} vpc_subnet_id: ${vpc_subnet_id} security_groups: ${security_groups} instance_type: ${instance_type} instance_profile_name: ${instance_profile_name} assign_public_ip: ${assign_public_ip} region: ${region} image: ${image} instance_tags: ${instance_tags} ec2_wait_for_create: ${ec2_wait_for_create} ec2_wait_for_create_timeout: ${ec2_wait_for_create_timeout} exact_count: ${exact_count} delete_volume_on_termination: ${delete_volume_on_termination} data_disk_size: ${data_disk_size} private_domain: ${private_domain} route53_private_record_ttl: ${route53_private_record_ttl} dns_record: ${dns_record} elastic_ip: ${elastic_ip}
</extraVars>
<jobTags/>
<skipJobTags/>
<jobType>run</jobType>
<limit/>
<inventory/>
<credential/>
<verbose>true</verbose>
<importTowerLogs>true</importTowerLogs>
<removeColor>false</removeColor>
<templateType>job</templateType>
<importWorkflowChildLogs>false</importWorkflowChildLogs>
</org.jenkinsci.plugins.ansible__tower.AnsibleTower>
</builders>

И config.xml из-за неудачной работы JobDSL, которая выглядит для меня так же:

<builders>
<org.jenkinsci.plugins.ansible__tower.AnsibleTower>
<towerServer>AWX Server</towerServer>
<jobTemplate>create-ec2-instance</jobTemplate>
<jobType>run</jobType>
<templateType>job</templateType>
<extraVars>
key_name: ${key_name} ec2_termination_protection: ${ec2_termination_protection} vpc_subnet_id: ${vpc_subnet_id} security_groups: ${security_groups} instance_type: ${instance_type} instance_profile_name: ${instance_profile_name} assign_public_ip: ${assign_public_ip} region: ${region} image: ${image} instance_tags: ${instance_tags} ec2_wait_for_create: ${ec2_wait_for_create} ec2_wait_for_create_timeout: ${ec2_wait_for_create_timeout} exact_count: ${exact_count} delete_volume_on_termination: ${delete_volume_on_termination} data_disk_size: ${data_disk_size} private_domain: ${private_domain} route53_private_record_ttl: ${route53_private_record_ttl} dns_record: ${dns_record} elastic_ip: ${elastic_ip}
</extraVars>
<verbose>true</verbose>
<importTowerLogs>true</importTowerLogs>
</org.jenkinsci.plugins.ansible__tower.AnsibleTower>
</builders>

Таким образом, есть некоторые ожидаемые различия, которые вы всегда получаете с заданиями, сгенерированными JobDSL, например, отсутствуют пустые поля, но это относится ко всем нашим (успешным) другим заданиям, которые следуют этому процессу.

Сценарий JobDSL находится здесь:

    configure { project ->
        project / 'builders ' << 'org.jenkinsci.plugins.ansible__tower.AnsibleTower' {
            towerServer 'AWX Server'
            jobTemplate ('create-ec2-instance')
            templateType 'job'
            jobType 'run'
            extraVars('''key_name: ${key_name} 
ec2_termination_protection: ${ec2_termination_protection} 
vpc_subnet_id: ${vpc_subnet_id} 
security_groups: ${security_groups} 
instance_type: ${instance_type} 
instance_profile_name: ${instance_profile_name} 
assign_public_ip: ${assign_public_ip} 
region: ${region} image: ${image} 
instance_tags: ${instance_tags} 
ec2_wait_for_create: ${ec2_wait_for_create} 
ec2_wait_for_create_timeout: ${ec2_wait_for_create_timeout} 
exact_count: ${exact_count} 
delete_volume_on_termination: ${delete_volume_on_termination} 
data_disk_size: ${data_disk_size} 
private_domain: ${private_domain} 
route53_private_record_ttl: ${route53_private_record_ttl} 
dns_record: ${dns_record} 
elastic_ip: ${elastic_ip}''')
            verbose 'true'
            importTowerLogs 'true'
        }
    }

На мой взгляд, сгенерированная работа выглядит идентично в пользовательском интерфейсе (как и в XML), и все же я продолжаю получать этот сбой при запуске. Я явно что-то упускаю, но я не могу на всю жизнь, если я увижу что.

1 ответ

Решение

Несмотря на то, что другие задания AWX создаются без этого, я добавил недостающие (пустые) поля, и задание начало выполняться успешно.

Итак, измените мой скрипт JobDSL на это:

    configure { project ->
        project / 'builders ' << 'org.jenkinsci.plugins.ansible__tower.AnsibleTower' {
            towerServer 'AWX Server'
            jobTemplate ('create-ec2-instance')
            extraVars('''key_name: ${key_name} 
ec2_termination_protection: ${ec2_termination_protection} 
vpc_subnet_id: ${vpc_subnet_id} 
security_groups: ${security_groups} 
instance_type: ${instance_type} 
instance_profile_name: ${instance_profile_name} 
assign_public_ip: ${assign_public_ip} 
region: ${region} 
image: ${image} 
instance_tags: ${instance_tags} 
ec2_wait_for_create: ${ec2_wait_for_create} 
ec2_wait_for_create_timeout: ${ec2_wait_for_create_timeout} 
exact_count: ${exact_count} 
delete_volume_on_termination: ${delete_volume_on_termination} 
data_disk_size: ${data_disk_size} 
private_domain: ${private_domain} 
route53_private_record_ttl: ${route53_private_record_ttl} 
dns_record: ${dns_record} 
elastic_ip: ${elastic_ip}''')
            jobTags ''
            skipJobTags ''
            jobType 'run'
            limit ''
            inventory ''
            credential ''
            verbose 'true'
            importTowerLogs 'true'
            removeColor ''
            templateType 'job'
            importWorkflowChildLogs ''

И сейчас работает как положено.

Другие вопросы по тегам