
因此,我設定了兩個 Ubuntu AWS 實例(一個小的 t2.medium 和一個大的 r3.large)。 t2.medium 上安裝了 Jenkins CI,r3.large 上安裝了 docker 引擎。這裡的目的是擁有一個主伺服器(t2.medium)和一個從伺服器(r3.large);主伺服器可以委託 docker 容器執行作業(根據需要啟動 jenkins docker 容器)。
我的問題是我對這個問題有點不知所措。我一直在研究,但我所做的幾乎所有事情都失敗了。
我目前的情況是:就像我上面提到的,我在一個實例上成功運行了 jenkins,在另一個實例上成功運行了 docker 引擎。我也有docker插件,找到了這裡,安裝在詹金斯上,我已經按照該頁面上的說明進行操作。但是,當我添加雲端並添加憑證時,唯一顯示的內容是“-none-”;然而,相同的憑證顯示在底部。
問題是每次測試連線時都會出現以下錯誤:
shaded.org.apache.http.conn.HttpHostConnectException: Connect to 10.96.24.240:4243 [/10.96.24.240] failed: Connection refused
。
任何幫助將非常感激!我已經這樣做了一個多星期了!我就是無法理解這個問題。
編輯:如果我以錯誤的方式進行操作,請指導我如何實現預期的設定。
EDIT2:這兩個實例之間的所有連接埠都已開啟。
EDIT3:這是我的泊塢窗圖:
ubuntu@ip-10-96-24-240:~$ docker ps
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
ubuntu@ip-10-96-24-240:~$ docker images
REPOSITORY TAG IMAGE ID CREATED VIRTUAL SIZE
jenkins-1 latest 9de6ee8eeebc 3 days ago 816.3 MB
ubuntu latest 8251da35e7a7 2 weeks ago 188.4 MB
jenkins latest 0c79d0a394dc 3 weeks ago 888 MB
evarga/jenkins-slave latest 8880612971b0 8 months ago 610.8 MB
答案1
好吧,這並不能完全滿足我的問題,但它是問題的可行答案shaded.org.apache.http.conn.HttpHostConnectException: Connect to 10.96.24.240:4243 [/10.96.24.240] failed: Connection refused
。我的問題是我沒有添加以下程式碼/etc/init/docker.conf
:
description "Docker daemon"
start on filesystem and started lxc-net
stop on runlevel [!2345]
respawn
script
/usr/bin/docker -H tcp://127.0.0.1:4243 -d
end script
我還設定1.8.1
了Docker Version
客戶端版本。相反,它應該是當前的 API 版本1.20
。
我希望這對像我這樣的初學者有所幫助。 :)
編輯:自從我發布這篇文章以來,Docker conf 檔案已經發生了一些變化,這是我的 docker.conf 現在的樣子:
pre-start script
# see also https://github.com/tianon/cgroupfs-mount/blob/master/cgroupfs-mount
if grep -v '^#' /etc/fstab | grep -q cgroup \
|| [ ! -e /proc/cgroups ] \
|| [ ! -d /sys/fs/cgroup ]; then
exit 0
fi
if ! mountpoint -q /sys/fs/cgroup; then
mount -t tmpfs -o uid=0,gid=0,mode=0755 cgroup /sys/fs/cgroup
fi
(
cd /sys/fs/cgroup
for sys in $(awk '!/^#/ { if ($4 == 1) print $1 }' /proc/cgroups); do
mkdir -p $sys
if ! mountpoint -q $sys; then
if ! mount -n -t cgroup -o $sys cgroup $sys; then
rmdir $sys || true
fi
fi
done
)
end script
script
# modify these in /etc/default/$UPSTART_JOB (/etc/default/docker)
DOCKER=/usr/bin/$UPSTART_JOB
DOCKER_OPTS='-H tcp://0.0.0.0:4243 -H unix:///var/run/docker.sock'
if [ -f /etc/default/$UPSTART_JOB ]; then
. /etc/default/$UPSTART_JOB
fi
exec "$DOCKER" daemon $DOCKER_OPTS
end script
# Don't emit "started" event until docker.sock is ready.
# See https://github.com/docker/docker/issues/6647
post-start script
DOCKER_OPTS='-H tcp://0.0.0.0:4243 -H unix:///var/run/docker.sock'
if [ -f /etc/default/$UPSTART_JOB ]; then
. /etc/default/$UPSTART_JOB
fi
if ! printf "%s" "$DOCKER_OPTS" | grep -qE -e '-H|--host'; then
while ! [ -e /var/run/docker.sock ]; do
initctl status $UPSTART_JOB | grep -qE "(stop|respawn)/" && exit 1
echo "Waiting for /var/run/docker.sock"
sleep 0.1
done
echo "/var/run/docker.sock is up"
fi
end script
所以現在唯一需要做的就是-H tcp://0.0.0.0:4243 -H unix:///var/run/docker.sock
添加DOCKER_OPTS