Jenkins脚本化管道与Sidecar MYSQL容器进行测试

时间:2020-01-15 14:09:23

标签: docker jenkins jenkins-pipeline jenkins-docker

我有下面的管道,它将与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.

以防万一,您需要查看rds-test dockerfile https://github.com/epynic/rds-mysql-s3-backup/tree/feature

2 个答案:

答案 0 :(得分:1)

正在运行的容器的ID不会在run方法的返回中被捕获,而是存储在withRun块的临时lambda变量中。要利用此功能,我们将相应地修改您的代码:

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可在该块中初始化的临时lambda变量的id成员变量中访问(为方便起见,此处命名为container

请注意,您还可以在此处进行少量代码清理,方法是将rds_test_image的值分配给docker.build("rds-test", "-f ${dockerfile} .")的返回值,而不是添加另一行代码将其分配给{{1}的返回值}。新代码也将更加稳定。

答案 1 :(得分:0)

上述情况是因为在--linkMatt Schuchard建议更新答案之前,mysql容器不可用

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'
        }
    }
}