hashicorp Vault与Jenkins Pipeline集成

时间:2020-04-23 13:49:19

标签: jenkins-pipeline hashicorp-vault

我已经在k8s集群中安装了hashicorp保险库,并且 我已经从UI中存储了kv机密,正在寻找文档或链接来从jenkins管道中检索这些机密。

1 个答案:

答案 0 :(得分:1)

有一个插件可以执行以下操作:https://github.com/jenkinsci/hashicorp-vault-plugin#usage-via-jenkinsfile

node {
    // define the secrets and the env variables
    // engine version can be defined on secret, job, folder or global.
    // the default is engine version 2 unless otherwise specified globally.
    def secrets = [
        [path: 'secret/testing', engineVersion: 1, secretValues: [
            [envVar: 'testing', vaultKey: 'value_one'],
            [envVar: 'testing_again', vaultKey: 'value_two']]],
        [path: 'secret/another_test', engineVersion: 2, secretValues: [
            [vaultKey: 'another_test']]]
    ]

    // optional configuration, if you do not provide this the next higher configuration
    // (e.g. folder or global) will be used
    def configuration = [vaultUrl: 'http://my-very-other-vault-url.com',
                         vaultCredentialId: 'my-vault-cred-id',
                         engineVersion: 1]
    // inside this block your credentials will be available as env variables
    withVault([configuration: configuration, vaultSecrets: secrets]) {
        sh 'echo $testing'
        sh 'echo $testing_again'
        sh 'echo $another_test'
    }
}