Скриптовый конвейер Jenkins с контейнером sidecar MYSQL для тестирования - PullRequest
1 голос
/ 15 января 2020

У меня есть конвейер ниже, который будет запускать фактический контейнер вместе с контейнером MYSQL для запуска теста.

stage('Test - To check MYSQL connect') { 
        def dockerfile = 'Dockerfile.test'
        def mysql = docker.image('mysql:5.6').run('-e MYSQL_ALLOW_EMPTY_PASSWORD=yes')
        docker.build("rds-test", "-f ${dockerfile} .")
        def rds_test_image = docker.image('rds-test')
        rds_test_image.inside("--link ${mysql.id}:mysql "){
            sh 'echo "Inside Container"'
        }
    }

И я застрял с ошибкой ниже

Successfully tagged rds-test:latest
[Pipeline] isUnix
[Pipeline] sh
+ docker inspect -f . rds-test
.
[Pipeline] withDockerContainer
Jenkins seems to be running inside container d4e0934157d5eb6a9edadef31413d0da44e0e3eaacbb1719fc8d47fbf0a60a2b
$ docker run -t -d -u 1000:1000 --link d14340adbef9c95483d0369857dd000edf1b986e9df452b8faaf907fe9e89bf2:mysql -w /var/jenkins_home/workspace/test-jenkinsfile-s3-rds-backup --volumes-from d4e0934157d5eb6a9edadef31413d0da44e0e3eaacbb1719fc8d47fbf0a60a2b -e ******** -e ******** -e ******** -e ******** -e ******** -e ******** -e ******** -e ******** -e ******** -e ******** -e ******** -e ******** -e ******** -e ******** -e ******** -e ******** -e ******** -e ******** -e ******** -e ******** -e ******** -e ******** -e ******** -e ******** rds-test cat
[Pipeline] // withDockerContainer
[Pipeline] }
[Pipeline] // stage
[Pipeline] }
[Pipeline] // node
[Pipeline] End of Pipeline
java.io.IOException: Failed to run image 'rds-test'. Error: docker: Error response from daemon: Cannot link to a non running container: /sharp_sanderson AS /fervent_lewin/mysql.

На всякий случай, если вы хотите взглянуть на dockerfile rds-test https://github.com/epynic/rds-mysql-s3-backup/tree/feature

Ответы [ 2 ]

1 голос
/ 15 января 2020

Идентификатор работающего контейнера не будет получен при возврате метода run, а скорее будет сохранен во временной лямбда-переменной блока withRun. Чтобы использовать эту возможность, мы изменили бы ваш код соответствующим образом:

stage('Test - To check MYSQL connect') { 
  def dockerfile = 'Dockerfile.test'
  docker.build("rds-test", "-f ${dockerfile} .")
  def rds_test_image = docker.image('rds-test')

  docker.image('mysql:5.6').withRun('-e MYSQL_ALLOW_EMPTY_PASSWORD=yes') { container ->
    rds_test_image.inside("--link ${container.id}:mysql") {
      sh 'echo "Inside Container"'
    }
  }
}

Как вы можете видеть выше, запуск вашего второго контейнера в блоке кода другого контейнера withRun делает идентификатор контейнера доступным внутри id переменная-член временной лямбда-переменной, инициализированной в блоке (здесь для удобства названа container).

Обратите внимание, что здесь можно также выполнить небольшую очистку кода, присвоив значение rds_test_image возврат docker.build("rds-test", "-f ${dockerfile} .") вместо добавления еще одной строки кода, присваивающей его возвращению docker.image('rds-test'). Новый код также будет более стабильным.

0 голосов
/ 16 января 2020

В приведенном выше случае контейнер mysql был недоступен до --link с предложением Мэтта Шучара обновить ответ

stage('Test - To check MYSQL connect') { 
    def dockerfile = 'Dockerfile.test'
    docker.build("rds-latest", "-f ${dockerfile} .")
    def rds_test_image = docker.image('rds-test:latest')
    docker.image('mysql:5.6').withRun('-e MYSQL_ROOT_PASSWORD=admin --name=mysql_server -p 3306:3306') { container ->
        docker.image('mysql:5.6').inside("--link ${container.id}:mysql") {
            /* Wait until mysql service is up */
            sh 'while ! mysqladmin ping -hmysql --silent; do sleep 1; done'
        }

        rds_test_image.inside("--link ${container.id}:mysql -e MYSQL_HOST=mysql -e MYSQL_PWD=admin -e USER=root "){
            sh 'bash scripts/test_script.sh'
        }
    }
}
...