Docker ERROR: Container command not found or does not exist when running from Win10

Docker ERROR: Container command not found or does not exist when running from Win10

这让我发疯...

我有 Win10,我安装了 Docker 工具箱

Docker=1.10.2 
Compose=1.6.0 
VirtualBox=5.0.14

我已经在 Linux [亚马逊 linux] 中成功启动了 LAMP 但是当我尝试做同样的事情时,终端响应 "ERROR: Container command not found or does not exist" 据我了解,Windows 解释 CMD 语法的方式有问题。

我试过了

 - CMD ["/run.sh"]
 - ENTRYPOINT ["/run.sh"]     
 - CMD /run.sh
 - CMD '/run.sh'
 - CMD run.sh
 - CMD "/run.sh"

但似乎没有任何效果。

注意:当我运行CMD /run.sh错误没有出现但容器立即退出。

注意 2:在 AWS

上尝试使用 Docker-Machine 设置 LAMP 时,我遇到了完全相同的问题

我有这个 DockerfileLamp :

FROM ubuntu

# -- Install needed packages --
ENV DEBIAN_FRONTEND noninteractive

# -- Install additional utilities --
RUN apt-get update && \
  apt-get install -y supervisor git curl apache2 mcrypt cron wget nano unzip

# -- Install PHP 5.5 --
RUN apt-get -y update && \
    apt-get -y install php5 libapache2-mod-php5 mysql-server-5.5 php5-mysql pwgen php-apc php5-mcrypt php5-xdebug php5-gd php5-curl php-pear openssh-server php5-cli php5-apcu php5-intl php5-imagick php5-json

# -- Set localhost to apache conf file --
RUN echo "ServerName localhost" >> /etc/apache2/apache2.conf

# -- Add image configuration and scripts --
ADD ./lamp/start-apache2.sh /start-apache2.sh
ADD ./lamp/start-mysqld.sh /start-mysqld.sh
ADD ./lamp/run.sh /run.sh
RUN chmod 755 /*.sh
ADD ./lamp/my.cnf /etc/mysql/conf.d/my.cnf
ADD ./lamp/supervisord-apache2.conf 
    /etc/supervisor/conf.d/supervisord-apache2.conf
ADD ./lamp/supervisord-mysqld.conf 
    /etc/supervisor/conf.d/supervisord-mysqld.conf

# -- Remove pre-installed database --
RUN rm -rf /var/lib/mysql/*
# -- Add MySQL utils --
ADD ./lamp/setup_MySQL.sh /setup_MySQL.sh
RUN chmod 755 /*.sh

# -- config to enable .htaccess --
##ADD apache_default /etc/apache2/sites-available/000-default.conf
RUN a2enmod rewrite

# -- Environmental variables to configure php --
ENV PHP_UPLOAD_MAX_FILESIZE 10M
ENV PHP_POST_MAX_SIZE 10M

# -- Add volumes for MySQL --
##VOLUME  ["/etc/mysql", "/var/lib/mysql" ]

# -- Set up SSH server --
RUN mkdir /var/run/sshd
RUN echo 'root:root' |chpasswd
RUN sed -ri 's/^PermitRootLogin\s+.*/PermitRootLogin yes/'
    /etc/ssh/sshd_config
RUN sed -ri 's/UsePAM yes/#UsePAM yes/g' /etc/ssh/sshd_config
ADD ./lamp/supervisord-openssh-server.conf
    /etc/supervisor/conf.d/supervisord-openssh-server.conf

# -- Install Python & pip --
RUN apt-get update && \
    apt-get upgrade -y && \
    apt-get install -y python python-pip python-dev && \
    pip install --upgrade pip
# -- Install xvfb --
RUN apt-get install -y xvfb   

EXPOSE 80 3306 22

CMD /run.sh

run.sh :

#!/bin/bash

VOLUME_HOME="/var/lib/mysql"

sed -ri -e "s/^upload_max_filesize.*/upload_max_filesize = ${PHP_UPLOAD_MAX_FILESIZE}/" \
    -e "s/^post_max_size.*/post_max_size = ${PHP_POST_MAX_SIZE}/" /etc/php5/apache2/php.ini
if [[ ! -d $VOLUME_HOME/mysql ]]; then
    echo "=> An empty or uninitialized MySQL volume is detected in $VOLUME_HOME"
    echo "=> Installing MySQL ..."
    mysql_install_db > /dev/null 2>&1
    echo "=> Done!"  
    /setup_MySQL.sh
else
    echo "=> Using an existing volume of MySQL"
fi

exec supervisord -n

docker-compose.yml

lamp: # apache + mysql/php
  build: .
  dockerfile: DockerfileLamp
  ports:
    - "8181:80"   # open apache to public
    - "3333:3306" # open mysql to public 
    - "2222:22"   # open SSH to public

Docker 以流程为中心,换句话说,当您的 CMD 脚本终止时,您的容器也会终止。在脚本的末尾 运行 ...

tail -f logfile (where logfile is some logfile you are interested in)

这将

1 - 停止你的容器退出 2 - 允许你做

docker logs -f containerName

帮你调试

3 - 允许您进入带有

的容器
docker exec -it bash containerName 

然后你可以运行你认为在容器内失败的命令并尝试解决这个问题

虽然这不能直接回答你的问题,但它应该给你足够的武器来解决这个问题

我通过简化文件解决了它。我注释掉了所有控件,因为无论我尝试什么,它都会继续抛出 Syntax Errors

#!/bin/bash

VOLUME_HOME="/var/lib/mysql"

sed -ri -e "s/^upload_max_filesize.*/upload_max_filesize = ${PHP_UPLOAD_MAX_FILESIZE}/" \
    -e "s/^post_max_size.*/post_max_size = ${PHP_POST_MAX_SIZE}/" /etc/php5/apache2/php.ini

#if [[ ! -d $VOLUME_HOME/mysql ]]; then
    echo "=> An empty or uninitialized MySQL volume is detected in $VOLUME_HOME"
    echo "=> Installing MySQL ..."
    mysql_install_db > /dev/null 2>&1
    echo "=> Done!"
    /setup_MySQL.sh
#else
#    echo "=> Using an existing volume of MySQL"
#fi

exec supervisord -n

它适用于我的情况,所以我不打算进一步调查。干杯!

已编辑

上面的解决方案不是很完整。 它起作用了,因为我是从容器内部进行更改的。

永久解决方案如下: 我将 run.sh 文件迁移到私有 Gist 。 [它不需要是私有的但可以] 我认为问题在于,当我尝试从 Windows 机器 [本地或云提供商] 构建 Dockerfile 时,它​​弄乱了语法、EOF、换行符等等。 所以我通过添加要点 url

打破了它

ADD http://gist_url/run.sh /run.sh

注意 1:您必须使用原始文件 URL,否则您将获得完整的 HTML。

注意 2:私有 gist 不是 protected.You 不需要身份验证来获取 URL。

对于另一个 project,我试图开始使用 Docker 机器 运行 在 Windows 上工作,进入 docker- 的相同模棱两可的错误消息撰写 Container command not found or does not exist

你关于行尾的评论促使我在 git-bash 中尝试 dos2unix ./*/*.sh(多个脚本,在子文件夹中),这为我解决了这个问题。

我怀疑 git clone 保存带有 DOS 行结尾的文件,这导致第一行 !#/bin/bash 的语法不正确。

$ docker-compose -v
docker-compose version 1.6.2, build e80fc83

$ docker version
Client:
 Version:      1.10.3
 API version:  1.22
 Go version:   go1.5.3
 Git commit:   20f81dd
 Built:        Thu Mar 10 21:49:11 2016
 OS/Arch:      windows/amd64

Server:
 Version:      1.10.3
 API version:  1.22
 Go version:   go1.5.3
 Git commit:   20f81dd
 Built:        Thu Mar 10 21:49:11 2016
 OS/Arch:      linux/amd64