本主题是关于 Docker 网络的,我无法允许 dockerised Jenkins 使用 dockerised SMTP 服务器。
以下是我运行容器并将它们连接到用户定义的网络的方式,以便容器的名称可以用作目标主机:
# Run Jenkins image, with port binding, Docker sock sharing, and configuration sharing
docker run -d -p 8080:8080 -v /var/run/docker.sock:/var/run/docker.sock -v /root/jenkins_conf/:/var/jenkins_home/ --name jenkins jenkins/jenkins:lts
# Run SMTP image
docker run -d --name smtp namshi/smtp
# Create user-defined network
docker network create jenkins-net
# Connect both containers
docker network connect jenkins-net jenkins
docker network connect jenkins-net smtp
在我的 jenkins 容器中,我可以通过默认的“桥”网络访问 smtp 服务:
$ (echo >/dev/tcp/172.17.0.5/25) &>/dev/null && echo "open" || echo "close"
open
我也可以通过我的用户定义的网络访问它,包括 IP 和主机名:
$ (echo >/dev/tcp/172.18.0.3/25) &>/dev/null && echo "open" || echo "close"
open
$ (echo >/dev/tcp/smtp/25) &>/dev/null && echo "open" || echo "close"
open
到现在为止还挺好。
但是,在 Jenkins > 管理 Jenkins > 配置系统 > 电子邮件通知中,尝试使用测试电子邮件发送工具给我以下结果:
SMTP server: 172.17.0.5 (SMTP container IP on the default 'bridge' network)
SMTP port: 25
=> 电子邮件已发送并已正式收到!
SMTP server: 172.18.0.3 (SMTP container IP on my user-defined 'jenkins-net' network)
SMTP port: 25
=> 发送电子邮件失败 com.sun.mail.smtp.SMTPAddressFailedException: 550 relay not allowed
SMTP server: smtp (SMTP container name on my user-defined 'jenkins-net' network)
SMTP port: 25
=>同样的错误
为什么使用 2 个网络时 SMTP 服务器的行为不同?
我对 Docker 网络缺少什么?
编辑:所以快速的解决方案是使用 --network 选项运行 smtp 容器,而不是运行它然后将其连接到网络。有关更多详细信息和充分性,请参阅下面的 Stefano 的答案。