如何運行最新的 docker 和 docker-compose 開發版本?

如何運行最新的 docker 和 docker-compose 開發版本?

我正在嘗試弄清楚如何在 Ubuntu 14.10 上一起運行 docker 和 docker-compose 的開發版本,以期解決一個錯誤:https://github.com/docker/compose/pull/1349

最新的 Docker 開發版本

docker -v
# Docker version 1.7.0-dev, build 6a7a757

# docker-compose -v
docker-compose version: 1.3.0rc3
CPython version: 2.7.8
OpenSSL version: OpenSSL 1.0.1f 6 Jan 2014

但docker不喜歡伺服器版本

# which docker 
/usr/bin/docker
# sudo /usr/bin/docker -d & 
WARN[0000] Your kernel does not support swap memory limit. 
INFO[0000] Loading containers: start.                   
.......................................................................INFO[0000] No non-localhost DNS nameservers are left in resolv.conf. Using default external servers : [nameserver 8.8.8.8 nameserver 8.8.4.4] 
INFO[0000] No non-localhost DNS nameservers are left in resolv.conf. Using default external servers : [nameserver 8.8.8.8 nameserver 8.8.4.4] 
WARN[0000] Failed to allocate and map port 8080: Error starting userland proxy: listen tcp 0.0.0.0:8080: bind: address already in use 

INFO[0000] Loading containers: done.                    
INFO[0000] Daemon has completed initialization          
INFO[0000] Docker daemon                                 commit=6a7a757 execdriver=native-0.2 graphdriver=aufs version=1.7.0-dev

# ps auxf | grep docker
root     24854  0.0  0.0  73360  3800 pts/14   S    09:59   0:00          |       \_ sudo /usr/bin/docker -d
root     24866  0.0  0.1 439152 19556 pts/14   Sl   09:59   0:00          |       |   \_ /usr/bin/docker -d
root     24982  0.0  0.0 109264 14584 pts/14   Sl   09:59   0:00          |       |       \_ docker-proxy -proto tcp -host-ip 0.0.0.0 -host-port 32768 -container-ip 172.17.0.2 -container-port 29015
root     25102  0.0  0.1 109264 16552 pts/14   Sl   09:59   0:00          |       |       \_ docker-proxy -proto tcp -host-ip 0.0.0.0 -host-port 32769 -container-ip 172.17.0.2 -container-port 28015
root     25131  0.0  0.0 109264 14516 pts/14   Sl   09:59   0:00          |       |       \_ docker-proxy -proto tcp -host-ip 0.0.0.0 -host-port 32770 -container-ip 172.17.0.2 -container-port 8080

# docker ps
Error response from daemon: client and server don't have same version (client : 1.20, server: 1.15)

目前候選開發版本 docker-compose 預計伺服器版本為 1.18

# which docker-compose 
/usr/local/bin/docker-compose
# docker-compose ps
client and server don't have same version (client : 1.18, server: 1.15)

即使停止守護程序後,我仍然收到相同的錯誤訊息

# sudo killall docker
INFO[0288] Processing signal 'terminated' 
# docker ps
Error response from daemon: client and server don't have same version (client : 1.20, server: 1.15)

我知道我可以將 docker 客戶端降級以匹配 docker-compose 所需的版本 1.18,但我仍然不明白為什麼伺服器版本報告為 1.15,而相同的二進位客戶端似乎是 1.20。

補充問題:當docker守護程序停止時,docker客戶端仍然收到不正確的伺服器版本訊息,這是怎麼回事?

答案1

升級 Docker 後嘗試重新啟動 docker 服務 ( sudo service docker restart)。這可能是以下原因:

您仍在運行舊版本的 Docker。

我遇到了一個非常類似的問題,升級了 Docker,並不斷遇到相同的錯誤訊息,直到我重新啟動服務。

答案2

此實例中的問題是環境變數$DOCKER_HOST指向另一個使用不同版本的系統,因此沒有進程出現在ps不相容的 API 中。

刪除變數unset DOCKER_HOST解決了問題。

相關內容