Как получить доступ к SQL серверу из docker ASP. net основного API-образа - PullRequest
0 голосов
/ 28 апреля 2020

Я сгенерировал файл docker для asp. net основного API с помощью одностраничного приложения благодаря Visual Studio. После некоторых исследований в Интернете я исправляю различные проблемы со СПА в этом docker файле. В конце концов, моя проблема в соединении с нашим сервером базы данных.

Когда я пытался подключиться, у меня появляется

Microsoft.Data.SqlClient.SqlException: связанный с сетью или instance-speci c Ошибка при установлении соединения с SQL Сервером.

Похоже, что это связано с тем, что мой контейнер не может получить доступ к серверу, после часа и часа поиска в Google, Я нашел решение только с SQL, размещенным в docker образе.

Как ко всему моему docker образу wab-приложения, имеющего доступ ко всей сети компании для доступа к другому серверу? Я использую имя компьютера ant, а не IP, чтобы соответствовать требованиям компании.

Спасибо за все

Версии:

  • . net core api: 3.1
  • Я использую docker для Windows
  • docker Использование linux Контейнер

Вот мой docker файл

   #See https://aka.ms/containerfastmode to understand how Visual Studio uses this Dockerfile to build your images for faster debugging.

FROM mcr.microsoft.com/dotnet/core/aspnet:3.1-buster-slim AS base
WORKDIR /app
EXPOSE 80
EXPOSE 443

FROM mcr.microsoft.com/dotnet/core/sdk:3.1-buster AS build
RUN apt-get update -yq \
    && apt-get install curl gnupg -yq \
    && curl -sL https://deb.nodesource.com/setup_10.x | bash \
    && apt-get install nodejs -yq
WORKDIR /src
COPY ["Company.Dtm.WebApi.AppWebApi/Company.Dtm.WebApi.AppWebApi.csproj", "Company.Dtm.WebApi.AppWebApi/"]
COPY ["CompanyFramework/Company.Framework.WebApi/Company.Framework.WebApi.csproj", "CompanyFramework/Company.Framework.WebApi/"]
COPY ["CompanyFramework/Company.Framework.Model/Company.Framework.Model.csproj", "CompanyFramework/Company.Framework.Model/"]
COPY ["CompanyFramework/Company.Framework.Tools/Company.Framework.Tools.csproj", "CompanyFramework/Company.Framework.Tools/"]
COPY ["AppLib/Company.Dtm.Lib.AppLib/Company.Dtm.Lib.AppLib.csproj", "AppLib/Company.Dtm.Lib.AppLib/"]
RUN dotnet restore "Company.Dtm.WebApi.AppWebApi/Company.Dtm.WebApi.AppWebApi.csproj"
COPY . .
WORKDIR "/src/Company.Dtm.WebApi.AppWebApi"
RUN dotnet build "Company.Dtm.WebApi.AppWebApi.csproj" -c Debug -o /app/build

FROM build AS publish
RUN dotnet publish "Company.Dtm.WebApi.AppWebApi.csproj" -c Debug -o /app/publish

FROM base AS final
WORKDIR /app

COPY --from=publish /app/publish .
ENTRYPOINT ["dotnet", "Company.Dtm.WebApi.AppWebApi.dll"]

Вот мой docker -композит

version: '3'
services:
  webapp:
    build: .
    network_mode: "bridge"
    ports:
     - "8880:80"

1 Ответ

0 голосов
/ 28 апреля 2020

Вам нужно добавить другой сервис для вашей базы данных в вашем файле compose. Примерно так:

version: "3"
  services:
    web:
        build: .
        ports:
            - "8000:80"
        depends_on:
            - db
    db:
        image: "mcr.microsoft.com/mssql/server"
        environment:
            SA_PASSWORD: "Your_password123"
            ACCEPT_EULA: "Y"

обязательно замените пароль в переменной окружения SA_PASSWORD в db.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...