使用Jenkins将Postgresql映像部署到openshift后,如何执行数据库脚本?

时间:2019-01-15 17:28:01

标签: postgresql jenkins openshift jenkins-pipeline openshift-enterprise

我有一个Jenkins管道和postgresql官方模板的git repo:

kind: "BuildConfig"
apiVersion: "v1"
metadata:
  name: "postgresql-pipeline"
spec:
  strategy:
    jenkinsPipelineStrategy:
      jenkinsfile: |-
        pipeline {
          agent any
          environment {
            DATABASE_NAME = 'sampledb'
            DATABASE_USER = 'root'
            DATABASE_PASSWORD = 'root'
          }
          stages {
            stage('Clone git') {
              steps {
                git 'https://bitbucket.org/businnessdata_db/postgresql-test.git'
              }
            }
            stage('Deploy db') {
              steps {
                sh 'oc status'
                sh 'oc delete secret/postgresql'
                sh 'oc delete pvc/postgresql'
                sh 'oc delete all -l "app=postgresql-persistent"'
                sh 'oc new-app -f openshift/templates/postgresql-persistent.json'
              }
            }
            stage('Execute users script') {
              steps {
                sh 'oc status'

} } stage('Execute update script') { steps { sh 'oc status' } } } } type: JenkinsPipeline<code>

我必须在最后2个步骤中对新生成的数据库运行脚本吗?

1 个答案:

答案 0 :(得分:1)

您可以在Jenkins容器上安装psql,然后通过shell命令运行脚本。

sh """
export PGPASSWORD=<password>
psql -h <host> -d <database> -U <user_name> -p <port> -a -w -f <file>.sql
   """

或者,由于Jenkinsfiles是用Groovy编写的,因此请使用Groovy执行您的语句。这是用于处理数据库的Groovy documentation