如何解决Jenkins slave 的 Swarm 撰写文件
我正在尝试为 jenkins/slave
创建一个撰写文件,以便在我的单节点群中运行。
我使用的图像是 jenkins/slave
用于图像的 docker
run
命令是 docker run -i --rm --name agent1 --init -v agent1-workdir:/home/jenkins/agent jenkins/agent java -jar /usr/share/jenkins/agent.jar -workdir /home/jenkins/agent
我的撰写文件如下所示:
('local_registry:5000/jenkins_ansible_slave' 是构建的映像,我已将其推送到本地注册表)
slave1:
image: 'local_registry:5000/jenkins_ansible_slave'
ports:
- "22:22"
init: true
volumes:
- "/home/user/agent:/home/jenkins/agent"
command: "java -jar /usr/share/jenkins/agent.jar -workdir /home/jenkins/agent"
networks:
- net
slave1
服务未启动,我在检查服务日志时收到此错误
DEVOPS-STACK_slave1.1.vcm7tc3i0ral@local_registry | INFO: Using /home/jenkins/agent/remoting as a remoting work directory
DEVOPS-STACK_slave1.1.vcm7tc3i0ral@local_registry | May 03,2021 3:27:01 PM org.jenkinsci.remoting.engine.workdirManager setupLogging
DEVOPS-STACK_slave1.1.vcm7tc3i0ral@local_registry | INFO: Both error and output logs will be printed to /home/jenkins/agent/remoting
DEVOPS-STACK_slave1.1.vcm7tc3i0ral@local_registry | Exception in thread "main" java.io.EOFException: unexpected stream termination
DEVOPS-STACK_slave1.1.vcm7tc3i0ral@local_registry | at hudson.remoting.ChannelBuilder.negotiate(ChannelBuilder.java:415)
DEVOPS-STACK_slave1.1.vcm7tc3i0ral@local_registry | at hudson.remoting.ChannelBuilder.build(ChannelBuilder.java:360)
DEVOPS-STACK_slave1.1.vcm7tc3i0ral@local_registry | at hudson.remoting.Launcher.main(Launcher.java:762)
DEVOPS-STACK_slave1.1.vcm7tc3i0ral@local_registry | at hudson.remoting.Launcher.runWithStdinStdout(Launcher.java:710)
DEVOPS-STACK_slave1.1.vcm7tc3i0ral@local_registry | at hudson.remoting.Launcher.run(Launcher.java:396)
DEVOPS-STACK_slave1.1.vcm7tc3i0ral@local_registry | at hudson.remoting.Launcher.main(Launcher.java:296)
DEVOPS-STACK_slave1.1.vcm7tc3i0ral@local_registry | <===[JENKINS REMOTING CAPACITY]===>rO0ABXNyABpodWRzb24ucmVtb3RpbmcuQ2FwYWJpbGl0eQAAAAAAAAABAgABSgAEbWFza3hwAAAAAAAAAf4=
知道这里出了什么问题吗?
谢谢,
解决方法
添加
stdin_open: true # docker run -i
tty: true # docker run -t
我认为这会解决您的问题。 你的 docker-compose 配置应该是这样的。
slave1:
image: 'local_registry:5000/jenkins_ansible_slave'
ports:
- "22:22"
init: true
volumes:
- "/home/user/agent:/home/jenkins/agent"
command: "java -jar /usr/share/jenkins/agent.jar -workDir /home/jenkins/agent"
networks:
- net
stdin_open: true # docker run -i
tty: true # docker run -t
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。