无法从容器

时间:2018-05-14 06:02:55

标签: sql-server docker networking

我试图从我计算机上托管的docker容器连接到我的远程SQL服务器。

但是只是发现了以下错误:

  

建立与SQL Server的连接时发生了与网络相关或特定于站点的错误。找不到服务器或无法访问服务器。检查实例名称是否正确,并且我将SQL Server配置为允许远程连接。有关详细信息,请参阅SQL Server联机丛书.. Sqlcmd:错误:Microsoft SQL Server Native Client 10.0:登录超时已过期。

但是,如果我尝试从主机上的SQL Server Management Studio连接到我的SQL服务器,一切正常。 另请注意,2周前,一切也在docker容器内工作。

这是我的docker compose文件和安装了SQL驱动程序的docker文件:

撰写:



version: '3'
services:
    nginx:
        image: nginx:1.10
        volumes:
            - ./:/var/www
            - .docker/nginx/vhost.conf:/etc/nginx/conf.d/default.conf
        ports:
            - ${DOCKER_IP}80:80
        links: 
            - php
        networks:
            - app-net

    php:
        build:
            context: ./
            dockerfile: .docker/php/DockerFile
        volumes:
            - ./:/var/www
        networks:
            -  app-net

networks:
     app-net:
        driver: bridge




Docker文件



FROM phpdockerio/php71-fpm:latest

# Install selected extensions and other stuff
RUN export DEBIAN_FRONTEND=noninteractive && \
    apt-get update && apt-get -y --no-install-recommends install \
    php7.1-mysql \
    php7.1-mbstring \
    php7.1-gd \
    php7.1-soap \
    php7.1-dev \ 
    apt-transport-https \ 
    git \
    ssh \
    curl \
    php-pear \
    && apt-get clean; rm -rf /var/lib/apt/lists/* /tmp/* /var/tmp/* /usr/share/doc/*

# Install Composer
RUN cd /usr/src
RUN curl -sS https://getcomposer.org/installer | php -- --install-dir=/usr/local/bin --filename=composer


# Install MSSQL extention
RUN curl https://packages.microsoft.com/keys/microsoft.asc | apt-key add -
RUN curl https://packages.microsoft.com/config/ubuntu/16.04/prod.list > /etc/apt/sources.list.d/mssql-release.list
RUN apt-get update
RUN ACCEPT_EULA=Y apt-get -y install msodbcsql mssql-tools g++ unixodbc-dev make
RUN pear config-set php_ini `php --ini | grep "Loaded Configuration" | sed -e "s|.*:\s*||"` system
RUN pecl install sqlsrv
RUN pecl install pdo_sqlsrv

RUN echo "extension=sqlsrv.so" >> /etc/php/7.1/fpm/php.ini
RUN echo "extension=pdo_sqlsrv.so" >> /etc/php/7.1/fpm/php.ini

# Fixed locals for MSSQL extention
RUN apt-get install -y locales
RUN echo "en_US.UTF-8 UTF-8" > /etc/locale.gen
RUN locale-gen

WORKDIR /var/www




在docker容器中,我无法ping SQL服务器。所以对我来说,我听起来像是一个网络问题,但我找不到解决方案。

请注意,SQL服务器本地托管在办公室的服务器上。

现在更新/解决 将Windows的dokcer降级到18.03.0-CE之后,一切都按预期工作。

2 个答案:

答案 0 :(得分:1)

默认情况下,Docker Bridge网络根本不会连接到Docker之外的世界;他们只允许容器互相交谈。 Docker Bridge Networks的文档确实提供了一些建议,允许Bridge网络流量通过在Docker主机上进行更改来与外界通信:

首先在内核中启用IP转发:

$ sysctl net.ipv4.conf.all.forwarding=1

然后更改主机防火墙以允许转发

$ sudo iptables -P FORWARD ACCEPT

这是一个相当宽松的防火墙配置,因此您可能希望保持更多的锁定。

另一种方法是将容器连接到两个不同的网络:当前用于容器之间通信的桥接网络,以及用于与MySQL通信的第二个主机网络。由于这会绕过Docker的所有NAT配置,因此您的服务的可扩展性可能会受到影响,但我认为传出连接可能没问题。

答案 1 :(得分:0)

对于我来说: 我在下面运行了这些

要查看所有容器:

  

docker ps -a

然后重新启动容器:

  

docker容器重启yourIdContainer

如果有错误:来自守护程序的错误响应:无法重新启动容器...

请重新启动Docker,然后再次重新启动容器。

通过MSSM连接到Sql Server,服务器名称:localhost,1433或IP

希望这会有所帮助。