ฉันกำลังพยายามแทรกไฟล์กำหนดค่าที่รวบรวมความลับลงในคอนเทนเนอร์ Docker โดยเป็นส่วนหนึ่งของ Jenkinsfile ที่กำลังใช้ไวยากรณ์การประกาศ
เจนกินส์ไฟล์:
pipeline {
agent {
dockerfile true
}
environment {
CONFIG = credentials('name-of-Jenkins-secret-file')
}
stages {
stage('Build') {
steps {
sh "echo ${CONFIG} > /usr/src/scripts/config/default.json"
}
}
}
}
นักเทียบท่าไฟล์:
FROM node:carbon
WORKDIR /usr/src/scripts
COPY package*.json ./
RUN npm install
COPY . .
ENTRYPOINT node ./run.js
ขั้นตอนที่เสร็จสิ้นเมื่อสร้าง:
Record trace of a Docker image used in FROM <1s
docker build -t 47a61bffd47bc4f049a967a05f05889983734f32 -f "Dockerfile" "."— Shell Script 1s
Dockerfile— Read file from workspace <1s
Checks if running on a Unix-like node <1s
General SCM <1s
Shell Script
[repo_branch-4ZXYH5FGLRRVXQLNJJ2SCGKMMGIMGWH5VUJEHPFZ6CDVODQSHRHQ] Running shell script
Error response from daemon: Container 0daa4e0d56818544fd228607d7c6318963f80ad99c0f8781a425163c4fb4fc2f is not running
script returned exit code -2
STATUS: FAILED
ฉันไม่แน่ใจว่าฉันพยายามบรรลุเป้าหมายนี้ด้วยวิธีที่แปลกหรือผิดปกติหรือไม่ เนื้อหาส่วนใหญ่ที่ฉันพบในการพูดคุยถึงการสร้างอิมเมจนักเทียบท่าโดยใช้ไปป์ไลน์นั้นมีจุดประสงค์ที่จะบันทึกรูปภาพเหล่านั้นไว้ในที่เก็บส่วนตัว ซึ่งบ่งบอกว่าฉันอาจกำลังทำอะไรแปลก ๆ ข้อผิดพลาดบ่งชี้ว่าไม่สามารถดำเนินการบนคอนเทนเนอร์ที่ไม่ได้ทำงานอยู่ได้