이 이미지는 Ubuntu기반 Linux에서 실행 중인 SQL Server로 구성됩니다. Linux에서는 Docker Engine 1.8 이상에서 사용할 수 있습니다.
SQL Server 2022(16.x) CU 14 버전 및 SQL Server 2019 (15.x) CU 28 버전으로 시작하면 컨테이너 이미지에 new mssql-tools18 패키지가 포함됩니다. 이전 디렉터리 /opt/mssql-tools/bin가 단계적으로 중단되고 있습니다. Microsoft ODBC 18 도구의 새 디렉터리가 /opt/mssql-tools18/bin 최신 도구 제품과 일치합니다. 변경 내용 및 보안 향상에 대한 자세한 내용은 SQL Server 릴리스용 ODBC Driver 18.0을 참조하세요.
이 문서의 예제에서는 docker 명령을 사용합니다. 그러나 이러한 명령은 대부분 Podman에서도 유효합니다. Podman은 Docker 엔진과 비슷한 명령줄 인터페이스를 제공합니다. Podman에 대해 자세히 알아보세요.
중요
sqlcmd는 현재 컨테이너를 만들 때 MSSQL_PID 매개 변수를 지원하지 않습니다. 이 빠른 시작에서 sqlcmd 지침을 사용하는 경우 SQL Server의 Developer 버전을 사용하여 컨테이너를 만듭니다. CLI(명령줄 인터페이스) 명령을 사용하여 선택한 라이선스를 사용하여 컨테이너를 만듭니다. 자세한 내용은 SQL Server Linux 컨테이너 배포 및 연결을 참조하세요.
사전 요구 사항
지원되는 모든 Linux 배포판에서 Docker Engine 1.8 이상 실행 자세한 내용은 사용자 Docker 설치를 참조하세요.
이전 명령은 최신 SQL Server 2017(14.x) linux 컨테이너 이미지를 끌어옵니다. 특정 이미지를 끌어오려면 콜론 및 mcr.microsoft.com/mssql/server:2017-GA-ubuntu 같은 태그 이름을 추가합니다. 사용 가능한 모든 이미지를 보려면 Microsoft 아티팩트 레지스트리를 참조하세요.
컨테이너 실행
Docker를 사용하여 linux 컨테이너 이미지를 실행하려면 bash 셸 또는 관리자 권한 PowerShell 명령 프롬프트에서 다음 명령을 사용할 수 있습니다.
중요
SA_PASSWORD 환경 변수는 사용되지 않습니다. 대신 MSSQL_SA_PASSWORD를 사용하세요.
암호는 SQL Server 기본 암호 정책이 따라야 합니다. 그렇지 않으면 컨테이너는 SQL 서버를 설정할 수 없어 작동이 중지됩니다. 기본적으로 암호는 8자 이상이어야 하며 대문자, 소문자, 0~9까지의 숫자 및 기호 네 가지 집합 중 세 집합의 문자를 포함해야 합니다. docker logs 명령을 사용하여 오류 로그를 검사할 수 있습니다.
기본적으로 이렇게 하면 개발자 버전의 SQL Server를 사용하여 컨테이너를 만듭니다. 컨테이너에서 프로덕션 버전을 실행하는 프로세스는 약간 다릅니다. 자세한 내용은 프로덕션 컨테이너 이미지 실행을 참조하세요.
다음 표에서는 이전 docker run 예제의 매개 변수에 대해 설명합니다.
매개 변수
설명
-e "ACCEPT_EULA=Y"
최종 사용자 사용권 계약 수락을 확인하기 위해 ACCEPT_EULA 변수를 어떤 값에 설정합니다. SQL Server 이미지에 대한 필수 설정입니다.
-e "MSSQL_SA_PASSWORD=<YourStrong@Passw0rd>"
8자 이상이고 암호 정책을 충족하는 자신만의 강력한 암호를 지정합니다. SQL Server 이미지에 대한 필수 설정입니다.
-e "MSSQL_COLLATION=<SQL_Server_collation>"
기본값 SQL_Latin1_General_CP1_CI_AS 대신 사용자 지정 SQL Server 데이터 정렬을 지정합니다.
-p 1433:1433
호스트 환경의 TCP 포트(첫 번째 값)를 컨테이너의 TCP 포트(두 번째 값)로 매핑합니다. 이 예제에서 SQL Server는 컨테이너의 TCP 1433에서 수신 대기하고 이 컨테이너는 호스트의 TCP 포트 1433에 공개됩니다.
--name sql1
컨테이너에 대해 임의로 생성된 이름보다는 사용자 지정 이름을 지정합니다. 둘 이상의 컨테이너를 실행하는 경우 이 동일한 이름을 다시 사용할 수 없습니다.
--hostname sql1
컨테이너 호스트 이름을 명시적으로 설정하는 데 사용됩니다. 지정하지 않으면 임의로 생성된 시스템 GUID인 컨테이너 ID가 기본값으로 사용됩니다.
-d
백그라운드(디먼)에서 컨테이너를 실행합니다.
mcr.microsoft.com/mssql/server:2017-latest
SQL Server Linux 컨테이너 이미지입니다.
컨테이너 끌어오기 및 실행
Microsoft Container Registry에서 SQL Server 2017(14.x) Linux 컨테이너 이미지를 끌어옵니다.
이전 명령은 최신 SQL Server 2017(14.x) linux 컨테이너 이미지를 시용합니다. 특정 이미지를 끌어오려면 2017-GA-ubuntu 같은 태그 이름으로 변경합니다. 사용 가능한 모든 이미지를 보려면 다음 명령을 실행합니다.
Bash
sudo sqlcmd create mssql get-tags
PowerShell
sqlcmd create mssql get-tags
Windows 명령 프롬프트
sqlcmd create mssql get-tags
다음 표에서는 이전 sqlcmd create mssql 예제의 매개 변수에 대해 설명합니다.
매개 변수
설명
--ACCEPT-EULA
최종 사용자 라이선스 계약에 대한 동의를 한다는 의미로 ACCEPT-EULA 플래그를 포함합니다. SQL Server 이미지에 대한 필수 설정입니다.
--port 1433
호스트 환경의 TCP 포트와 컨테이너의 TCP 포트를 매핑합니다. 이 예제에서 SQL Server는 컨테이너의 TCP 1433에서 수신 대기하고 이 컨테이너는 호스트의 TCP 포트 1433에 공개됩니다.
--name sql1
컨테이너에 대해 임의로 생성된 이름보다는 사용자 지정 이름을 지정합니다. 둘 이상의 컨테이너를 실행하는 경우 이 동일한 이름을 다시 사용할 수 없습니다.
--hostname sql1
컨테이너 호스트 이름을 명시적으로 설정하는 데 사용됩니다. 지정하지 않으면 임의로 생성된 시스템 GUID인 컨테이너 ID가 기본값으로 사용됩니다.
--tag 2017-latest
SQL Server Linux 컨테이너 이미지입니다.
컨테이너 목록 보기기
Docker 컨테이너를 보려면 docker ps 명령을 사용합니다.
Bash
sudo docker ps -a
PowerShell
docker ps -a
Windows 명령 프롬프트
docker ps -a
다음 예제와 비슷한 내용이 출력됩니다.
출력
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
d4a1999ef83e mcr.microsoft.com/mssql/server:2017-latest "/opt/mssql/bin/perm..." 2 minutes ago Up 2 minutes 0.0.0.0:1433->1433/tcp, :::1433->1433/tcp sql1
STATUS열에 Up 상태를 표시하는 경우, SQL Server는 컨테이너에서 실행되며 PORTS 열의 지정된 포트에서 수신 대기합니다. SQL Server 컨테이너에 대한 STATUS 열이 Exited로 표시 되면 SQL Server Docker 컨테이너 문제 해결을 참조 하세요. SQL Server 오류 로그에 SQL Server is now ready for client connections. This is an informational message; no user action is required 메시지가 표시되면 서버에서 연결할 준비가 된 것입니다. 다음 명령을 사용하여 컨테이너 내에서 SQL Server 오류 로그를 검토할 수 있습니다.
이전 명령은 최신 SQL Server 2019(15.x) linux 컨테이너 이미지를 끌어옵니다. 특정 이미지를 끌어오려면 콜론 및 mcr.microsoft.com/mssql/server:2019-GA-ubuntu 같은 태그 이름을 추가합니다. 사용 가능한 모든 이미지를 보려면 Microsoft 아티팩트 레지스트리를 참조하세요.
컨테이너 실행
Docker를 사용하여 linux 컨테이너 이미지를 실행하려면 bash 셸 또는 관리자 권한 PowerShell 명령 프롬프트에서 다음 명령을 사용할 수 있습니다.
중요
SA_PASSWORD 환경 변수는 사용되지 않습니다. 대신 MSSQL_SA_PASSWORD를 사용하세요.
암호는 SQL Server 기본 암호 정책이 따라야 합니다. 그렇지 않으면 컨테이너는 SQL 서버를 설정할 수 없어 작동이 중지됩니다. 기본적으로 암호는 8자 이상이어야 하며 대문자, 소문자, 0~9까지의 숫자 및 기호 네 가지 집합 중 세 집합의 문자를 포함해야 합니다. docker logs 명령을 사용하여 오류 로그를 검사할 수 있습니다.
기본적으로 이렇게 하면 개발자 버전의 SQL Server를 사용하여 컨테이너를 만듭니다. 컨테이너에서 프로덕션 버전을 실행하는 프로세스는 약간 다릅니다. 자세한 내용은 프로덕션 컨테이너 이미지 실행을 참조하세요.
다음 표에서는 이전 docker run 예제의 매개 변수에 대해 설명합니다.
매개 변수
설명
-e "ACCEPT_EULA=Y"
최종 사용자 사용권 계약 수락을 확인하기 위해 ACCEPT_EULA 변수를 어떤 값에 설정합니다. SQL Server 이미지에 대한 필수 설정입니다.
-e "MSSQL_SA_PASSWORD=<YourStrong@Passw0rd>"
8자 이상이고 암호 정책을 충족하는 자신만의 강력한 암호를 지정합니다. SQL Server 이미지에 대한 필수 설정입니다.
-e "MSSQL_COLLATION=<SQL_Server_collation>"
기본값 SQL_Latin1_General_CP1_CI_AS 대신 사용자 지정 SQL Server 데이터 정렬을 지정합니다.
-p 1433:1433
호스트 환경의 TCP 포트(첫 번째 값)를 컨테이너의 TCP 포트(두 번째 값)로 매핑합니다. 이 예제에서 SQL Server는 컨테이너의 TCP 1433에서 수신 대기하고 이 컨테이너는 호스트의 TCP 포트 1433에 공개됩니다.
--name sql1
컨테이너에 대해 임의로 생성된 이름보다는 사용자 지정 이름을 지정합니다. 둘 이상의 컨테이너를 실행하는 경우 이 동일한 이름을 다시 사용할 수 없습니다.
--hostname sql1
컨테이너 호스트 이름을 명시적으로 설정하는 데 사용됩니다. 지정하지 않으면 임의로 생성된 시스템 GUID인 컨테이너 ID가 기본값으로 사용됩니다.
-d
백그라운드(디먼)에서 컨테이너를 실행합니다.
mcr.microsoft.com/mssql/server:2019-latest
SQL Server Linux 컨테이너 이미지입니다.
컨테이너 끌어오기 및 실행
Microsoft Container Registry에서 SQL Server 2019(15.x) Linux 컨테이너 이미지를 끌어옵니다.
이전 명령은 최신 SQL Server 2019(15.x) linux 컨테이너 이미지를 끌어옵니다. 특정 이미지를 끌어오려면 2019-GA-ubuntu-16.04 같은 태그 이름으로 변경합니다. 사용 가능한 모든 이미지를 보려면 다음 명령을 실행합니다.
Bash
sudo sqlcmd create mssql get-tags
PowerShell
sqlcmd create mssql get-tags
Windows 명령 프롬프트
sqlcmd create mssql get-tags
기본적으로 이렇게 하면 개발자 버전의 SQL Server를 사용하여 컨테이너를 만듭니다. 컨테이너에서 프로덕션 버전을 실행하는 프로세스는 약간 다릅니다. 자세한 내용은 프로덕션 컨테이너 이미지 실행을 참조하세요.
다음 표에서는 이전 docker run 예제의 매개 변수에 대해 설명합니다.
매개 변수
설명
--ACCEPT_EULA
최종 사용자 라이선스 계약에 대한 동의를 한다는 의미로 ACCEPT_EULA 플래그를 포함합니다. SQL Server 이미지에 대한 필수 설정입니다.
--port 1433
호스트 환경의 TCP 포트와 컨테이너의 TCP 포트를 매핑합니다. 이 예제에서 SQL Server는 컨테이너의 TCP 1433에서 수신 대기하고 이 컨테이너는 호스트의 TCP 포트 1433에 공개됩니다.
--name sql1
컨테이너에 대해 임의로 생성된 이름보다는 사용자 지정 이름을 지정합니다. 둘 이상의 컨테이너를 실행하는 경우 이 동일한 이름을 다시 사용할 수 없습니다.
--hostname sql1
컨테이너 호스트 이름을 명시적으로 설정하는 데 사용됩니다. 지정하지 않으면 임의로 생성된 시스템 GUID인 컨테이너 ID가 기본값으로 사용됩니다.
--tag 2019-latest
SQL Server Linux 컨테이너 이미지입니다.
컨테이너 목록 보기기
Docker 컨테이너를 보려면 docker ps 명령을 사용합니다.
Bash
docker ps -a
PowerShell
docker ps -a
Windows 명령 프롬프트
docker ps -a
다음 예제와 비슷한 내용이 출력됩니다.
출력
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
d4a1999ef83e mcr.microsoft.com/mssql/server:2019-latest "/opt/mssql/bin/perm..." 2 minutes ago Up 2 minutes 0.0.0.0:1433->1433/tcp, :::1433->1433/tcp sql1
STATUS열에 Up 상태를 표시하는 경우, SQL Server는 컨테이너에서 실행되며 PORTS 열의 지정된 포트에서 수신 대기합니다. SQL Server 컨테이너에 대한 STATUS 열이 Exited로 표시 되면 SQL Server Docker 컨테이너 문제 해결을 참조 하세요. SQL Server 오류 로그에 SQL Server is now ready for client connections. This is an informational message; no user action is required 메시지가 표시되면 서버에서 연결할 준비가 된 것입니다. 다음 명령을 사용하여 컨테이너 내에서 SQL Server 오류 로그를 검토할 수 있습니다.
이전 명령은 최신 SQL Server 2022(16.x) Linux 컨테이너 이미지를 끌어옵니다. 특정 이미지를 끌어오려면 콜론 및 mcr.microsoft.com/mssql/server:2022-GA-ubuntu 같은 태그 이름을 추가합니다. 사용 가능한 모든 이미지를 보려면 Microsoft 아티팩트 레지스트리를 참조하세요.
컨테이너 실행
Docker를 사용하여 linux 컨테이너 이미지를 실행하려면 bash 셸 또는 관리자 권한 PowerShell 명령 프롬프트에서 다음 명령을 사용할 수 있습니다.
중요
SA_PASSWORD 환경 변수는 사용되지 않습니다. 대신 MSSQL_SA_PASSWORD를 사용하세요.
암호는 SQL Server 기본 암호 정책이 따라야 합니다. 그렇지 않으면 컨테이너는 SQL 서버를 설정할 수 없어 작동이 중지됩니다. 기본적으로 암호는 8자 이상이어야 하며 대문자, 소문자, 0~9까지의 숫자 및 기호 네 가지 집합 중 세 집합의 문자를 포함해야 합니다. docker logs 명령을 사용하여 오류 로그를 검사할 수 있습니다.
기본적으로 이렇게 하면 개발자 버전의 SQL Server를 사용하여 컨테이너를 만듭니다. 컨테이너에서 프로덕션 버전을 실행하는 프로세스는 약간 다릅니다. 자세한 내용은 프로덕션 컨테이너 이미지 실행을 참조하세요.
다음 표에서는 이전 docker run 예제의 매개 변수에 대해 설명합니다.
매개 변수
설명
-e "ACCEPT_EULA=Y"
최종 사용자 사용권 계약 수락을 확인하기 위해 ACCEPT_EULA 변수를 어떤 값에 설정합니다. SQL Server 이미지에 대한 필수 설정입니다.
-e "MSSQL_SA_PASSWORD=<YourStrong@Passw0rd>"
8자 이상이고 암호 정책을 충족하는 자신만의 강력한 암호를 지정합니다. SQL Server 이미지에 대한 필수 설정입니다.
-e "MSSQL_COLLATION=<SQL_Server_collation>"
기본값 SQL_Latin1_General_CP1_CI_AS 대신 사용자 지정 SQL Server 데이터 정렬을 지정합니다.
-p 1433:1433
호스트 환경의 TCP 포트(첫 번째 값)를 컨테이너의 TCP 포트(두 번째 값)로 매핑합니다. 이 예제에서 SQL Server는 컨테이너의 TCP 1433에서 수신 대기하고 이 컨테이너는 호스트의 TCP 포트 1433에 공개됩니다.
--name sql1
컨테이너에 대해 임의로 생성된 이름보다는 사용자 지정 이름을 지정합니다. 둘 이상의 컨테이너를 실행하는 경우 이 동일한 이름을 다시 사용할 수 없습니다.
--hostname sql1
컨테이너 호스트 이름을 명시적으로 설정하는 데 사용됩니다. 지정하지 않으면 임의로 생성된 시스템 GUID인 컨테이너 ID가 기본값으로 사용됩니다.
-d
백그라운드(디먼)에서 컨테이너를 실행합니다.
mcr.microsoft.com/mssql/server:2022-latest
SQL Server Linux 컨테이너 이미지입니다.
시스템 관리자 암호를 변경합니다.
SA 계정은 설치 중에 생성되는 SQL Server 인스턴스의 시스템 관리자입니다. SQL Server 컨테이너를 만든 후 컨테이너에서 echo $MSSQL_SA_PASSWORD를 실행하여 지정한 MSSQL_SA_PASSWORD 환경 변수를 검색할 수 있습니다. 보안을 위해 프로덕션 환경에서 SA 암호를 변경해야 합니다.
SA 사용자에게 사용할 강력한 암호를 선택합니다.
docker exec를 사용하여 sqlcmd를 실행하고 Transact-SQL을 사용하여 암호를 변경합니다. 다음 예제에서는 사용자 입력에서 이전 암호와 새 암호를 읽습니다.
Bash
docker exec -it sql1 /opt/mssql-tools18/bin/sqlcmd \
-S localhost -U SA \
-P "$(read -sp "Enter current SA password: "; echo "${REPLY}")" \
-Q "ALTER LOGIN SA WITH PASSWORD=\"$(read -sp "Enter new SA password: "; echo "${REPLY}")\""
PowerShell
docker exec -it sql1 /opt/mssql-tools18/bin/sqlcmd `
-S localhost -U SA -P"<YourStrong@Passw0rd>" `
-Q"ALTER LOGIN SA WITH PASSWORD='<YourNewStrong@Passw0rd>'"
Windows 명령 프롬프트
docker exec -it sql1 /opt/mssql-tools18/bin/sqlcmd `
-S localhost -U SA -P "<YourStrong@Passw0rd>" `
-Q "ALTER LOGIN SA WITH PASSWORD='<YourNewStrong@Passw0rd>'"
최신 버전의 sqlcmd는 기본적으로 안전합니다. 연결 암호화에 대한 자세한 내용은 Windows용 sqlcmd 유틸리티 및 Linux와 macOS용 sqlcmd를 사용하여 연결을 참조합니다. 연결이 성공하지 못하면 sqlcmd에 -No 옵션을 추가하여 암호화가 필수가 아니라 선택 사항임을 지정할 수 있습니다.
모범 사례로 sa 계정 사용 중지하기
중요
이후 단계에서는 이러한 자격 증명이 필요합니다. 여기에 입력한 사용자 ID와 암호를 적어 두세요.
설치 후 처음으로 sa 계정을 사용하여 SQL Server 인스턴스에 연결하는 경우 이러한 단계를 수행한 다음 즉시 sa 로그인을 보안 모범 사례로 사용하지 않도록 설정하는 것이 중요합니다.
새 로그인을 만들고 sysadmin 서버 역할의 멤버로 만듭니다.
컨테이너 또는 비 컨테이너 배포가 있는지 여부에 따라 Windows 인증 사용하도록 설정하고 새 Windows 기반 로그인을 만들고 sysadmin 서버 역할에 추가합니다.
이전 명령은 최신 SQL Server 2022(16.x) Linux 컨테이너 이미지를 끌어옵니다. 특정 이미지를 끌어오려면 2022-CU11-ubuntu-22.04 같은 태그 이름으로 변경합니다. 사용 가능한 모든 이미지를 보려면 다음 명령을 실행합니다.
Bash
sudo sqlcmd create mssql get-tags
PowerShell
sqlcmd create mssql get-tags
Windows 명령 프롬프트
sqlcmd create mssql get-tags
기본적으로 이렇게 하면 개발자 버전의 SQL Server를 사용하여 컨테이너를 만듭니다. 컨테이너에서 프로덕션 버전을 실행하는 프로세스는 약간 다릅니다. 자세한 내용은 프로덕션 컨테이너 이미지 실행을 참조하세요.
다음 표에서는 이전 docker run 예제의 매개 변수에 대해 설명합니다.
매개 변수
설명
--ACCEPT-EULA
최종 사용자 라이선스 계약에 대한 동의를 한다는 의미로 --ACCEPT-EULA 플래그를 포함합니다. SQL Server 이미지에 대한 필수 설정입니다.
--port 1433
호스트 환경의 TCP 포트와 컨테이너의 TCP 포트를 매핑합니다. 이 예제에서 SQL Server는 컨테이너의 TCP 1433에서 수신 대기하고 이 컨테이너는 호스트의 TCP 포트 1433에 공개됩니다.
--name sql1
컨테이너에 대해 임의로 생성된 이름보다는 사용자 지정 이름을 지정합니다. 둘 이상의 컨테이너를 실행하는 경우 이 동일한 이름을 다시 사용할 수 없습니다.
--hostname sql1
컨테이너 호스트 이름을 명시적으로 설정하는 데 사용됩니다. 지정하지 않으면 임의로 생성된 시스템 GUID인 컨테이너 ID가 기본값으로 사용됩니다.
--tag 2022-latest
SQL Server Linux 컨테이너 이미지입니다.
sqlcmd는 SA 암호를 사용하지 않도록 설정하고 컨테이너를 만들 때 현재 사용자를 기반으로 새 로그인을 만듭니다. 로그인 정보를 보려면 다음 명령을 사용합니다. 이후 단계에서 필요합니다.
Bash
sudo sqlcmd config view --raw
PowerShell
sqlcmd config view --raw
Windows 명령 프롬프트
sqlcmd config view --raw
컨테이너 목록 보기기
Docker 컨테이너를 보려면 docker ps 명령을 사용합니다.
Bash
docker ps -a
PowerShell
docker ps -a
Windows 명령 프롬프트
docker ps -a
다음 예제와 비슷한 내용이 출력됩니다.
출력
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
d4a1999ef83e mcr.microsoft.com/mssql/server:2022-latest "/opt/mssql/bin/perm..." 2 minutes ago Up 2 minutes 0.0.0.0:1433->1433/tcp, :::1433->1433/tcp sql1
STATUS열에 Up 상태를 표시하는 경우, SQL Server는 컨테이너에서 실행되며 PORTS 열의 지정된 포트에서 수신 대기합니다. SQL Server 컨테이너에 대한 STATUS 열이 Exited로 표시 되면 SQL Server Docker 컨테이너 문제 해결을 참조 하세요. SQL Server 오류 로그에 SQL Server is now ready for client connections. This is an informational message; no user action is required 메시지가 표시되면 서버에서 연결할 준비가 된 것입니다. 다음 명령을 사용하여 컨테이너 내에서 SQL Server 오류 로그를 검토할 수 있습니다.
최신 버전의 sqlcmd는 기본적으로 안전합니다. 연결 암호화에 대한 자세한 내용은 Windows용 sqlcmd 유틸리티 및 Linux와 macOS용 sqlcmd를 사용하여 연결을 참조합니다. 연결이 성공하지 못하면 sqlcmd에 -No 옵션을 추가하여 암호화가 필수가 아니라 선택 사항임을 지정할 수 있습니다.
최신 버전의 sqlcmd는 기본적으로 안전합니다. 연결 암호화에 대한 자세한 내용은 Windows용 sqlcmd 유틸리티 및 Linux와 macOS용 sqlcmd를 사용하여 연결을 참조합니다. 연결이 성공하지 못하면 sqlcmd에 -No 옵션을 추가하여 암호화가 필수가 아니라 선택 사항임을 지정할 수 있습니다.
최신 버전의 sqlcmd는 기본적으로 안전합니다. 연결 암호화에 대한 자세한 내용은 Windows용 sqlcmd 유틸리티 및 Linux와 macOS용 sqlcmd를 사용하여 연결을 참조합니다. 연결이 성공하지 못하면 sqlcmd에 -No 옵션을 추가하여 암호화가 필수가 아니라 선택 사항임을 지정할 수 있습니다.
SQL 연결을 지원하는 모든 외부 Linux, Windows 또는 macOS 도구에서 Docker 컴퓨터에 있는 SQL Server 인스턴스에 연결할 수 있습니다. 외부 도구는 호스트 컴퓨터에 대한 IP 주소를 사용합니다.
다음 단계에서는 컨테이너 외부의 sqlcmd를 사용하여 컨테이너에서 실행되는 SQL Server에 연결합니다. 이 단계에서는 컨테이너 외부에 SQL Server 명령줄 도구가 이미 설치되어 있다고 가정합니다. 다른 도구를 사용할 때도 동일한 원칙이 적용되지만 연결 프로세스는 각 도구에 고유합니다.
ifconfig 또는 ip addr을 사용하여 컨테이너의 호스트 머신에 대한 IP 주소를 찾습니다.
컨테이너의 포트 1433에 매핑된 IP 주소와 포트를 지정하는 sqlcmd를 실행합니다. 이 예제에서는 포트는 호스트 머신의 포트 1433과 동일합니다. 호스트 컴퓨터에서 다른 매핑된 포트를 지정한 경우 여기에서 사용합니다. 또한 연결을 허용하려면 방화벽에서 적절한 인바운드 포트를 열어야 합니다.
최신 버전의 sqlcmd는 기본적으로 안전합니다. 연결이 성공하지 못하고 버전 18 이상을 사용하는 경우 sqlcmd에 -No 옵션을 추가하여 암호화가 필수가 아니라 선택 사항임을 지정할 수 있습니다.