빠른 시작: SQL Server 설치 및 SUSE Linux Enterprise Server에 데이터베이스 만들기

적용 대상:SQL Server - Linux

이 빠른 시작에서는 SLES(SUSE Linux Enterprise Server) v12에 SQL Server 2017(14.x)을 설치합니다. 그런 다음 sqlcmd를 연결하여 첫 번째 데이터베이스를 만들고 쿼리를 실행합니다.

지원되는 플랫폼에 대한 자세한 내용은 SQL Server 2017 on Linux 릴리스 정보를 참조하세요.

이 빠른 시작에서는 SLES(SUSE Linux Enterprise Server) v15(SP3)에 SQL Server 2019(15.x)를 설치합니다. 그런 다음 sqlcmd를 연결하여 첫 번째 데이터베이스를 만들고 쿼리를 실행합니다.

지원되는 플랫폼에 대한 자세한 내용은 SQL Server 2019 on Linux 릴리스 정보를 참조하세요.

이 빠른 시작에서는 SLES(SUSE Linux Enterprise Server) v15(SP3)에 SQL Server 2022(16.x)를 설치합니다. 그런 다음 sqlcmd를 연결하여 첫 번째 데이터베이스를 만들고 쿼리를 실행합니다.

지원되는 플랫폼에 대한 자세한 내용은 SQL Server 2022 on Linux 릴리스 정보를 참조하세요.

이 자습서를 사용하려면 사용자 입력과 인터넷 연결이 필요합니다. 무인 또는 오프라인 설치 절차에 관심이 있는 경우 SQL Server on Linux에 대한 설치 지침을 참조하세요.

필수 구성 요소

최소 2GB의 메모리를 포함하는 SLES v12 SP5 머신이 있어야 합니다. 파일 시스템은 XFS 또는 EXT4여야 합니다. BTRFS 등의 다른 파일 시스템은 지원되지 않습니다.

메모리가 2GB 이상인 SLES v15(SP1 - SP4) 컴퓨터가 있어야 합니다. 파일 시스템은 XFS 또는 EXT4여야 합니다. BTRFS 등의 다른 파일 시스템은 지원되지 않습니다.

메모리가 2GB 이상인 SLES v15(SP1 - SP4) 컴퓨터가 있어야 합니다. 파일 시스템은 XFS 또는 EXT4여야 합니다. BTRFS 등의 다른 파일 시스템은 지원되지 않습니다.

사용자의 머신에 SUSE Linux Enterprise Server를 설치하려면 https://www.suse.com/products/server으로 이동합니다. Azure에서 SLES 가상 머신을 만들 수도 있습니다. Azure CLI를 사용하여 Linux VM 만들기 및 관리를 참조하고 az vm create에 대한 호출에 --image SLES을 사용하세요.

이전에 SQL Server의 CTP(커뮤니티 기술 미리 보기) 또는 RC(릴리스 후보)를 설치한 경우 다음 단계를 수행하기 전에 이전 리포지토리를 제거해야 합니다. 자세한 내용은 SQL Server on Linux 설치 및 업그레이드를 위한 리포지토리 구성을 참조하세요.

참고 항목

현재 Windows 10 또는 Windows 11용 Linux용 Windows 하위 시스템 설치 대상으로 지원되지 않습니다.

기타 시스템 요구 사항은 SQL Server on Linux에 대한 시스템 요구 사항을 참조하세요.

SQL Server 설치

SLES에서 SQL Server을 구성하려면 터미널에서 다음 명령을 실행하여 mssql-server 패키지를 설치합니다.

  1. SQL Server 2017(14.x) SLES 리포지토리 구성 파일을 다운로드합니다.

    sudo zypper addrepo -fc https://packages.microsoft.com/config/sles/12/mssql-server-2017.repo
    

    다른 버전의 SQL Server를 설치하려면 이 문서의 SQL Server 2019(15.x) 또는 SQL Server 2022(16.x) 버전을 참조하세요.

  2. 리포지토리를 새로 고칩니다.

    sudo zypper --gpg-auto-import-keys refresh
    

    Microsoft 패키지 서명 키가 시스템에 설치되어 있는지 확인하려면 아래 명령을 사용하여 키를 가져올 수 있습니다.

    sudo rpm --import https://packages.microsoft.com/keys/microsoft.asc
    
  3. SQL Server를 설치하기 전에 SUSE 고객 센터에서 SUSE Linux Enterprise Server를 등록하고 활성화한 후에는 데스크톱 애플리케이션 모듈과 개발 도구 모듈을 모두 활성화해야 합니다. 이러한 모듈은 일부 SQL Server 패키지 종속성에 필요합니다.

  4. 이제 SQL Server를 설치할 준비가 되었습니다. 다음 명령을 실행하여 SQL Server를 설치합니다.

    sudo zypper install -y mssql-server
    
  5. 패키지 설치가 완료되면 mssql-conf setup을 실행하고, 프롬프트에 따라 SA 암호를 설정하고, 버전을 선택합니다. 다시 말씀드리지만, 다음 SQL Server 버전은 체험용 라이선스인 Evaluation, Developer 및 Express로 제공됩니다.

    sudo /opt/mssql/bin/mssql-conf setup
    

    SA 계정에 대한 강력한 암호를 지정해야 합니다. 대문자와 소문자, 0~9의 숫자 및/또는 영숫자가 아닌 기호를 포함하여 최소 길이 8자가 필요합니다.

  6. 구성이 완료되면 서비스가 실행 중인지 확인합니다.

    systemctl status mssql-server
    
  7. 원격으로 연결하려면 방화벽에서 SQL Server TCP 포트(기본값 1433)를 열어야 할 수도 있습니다. SUSE 방화벽을 사용하는 경우 구성 파일을 편집 /etc/sysconfig/SuSEfirewall2 해야 합니다. SQL Server 포트 번호를 포함하도록 FW_SERVICES_EXT_TCP 항목을 수정합니다.

    FW_SERVICES_EXT_TCP="1433"
    

이제 SQL Server는 SLES 머신에서 실행 중이며 사용할 준비가 되었습니다.

  1. SQL Server 2019(15.x) SLES 리포지토리 구성 파일을 다운로드합니다.

    sudo zypper addrepo -fc https://packages.microsoft.com/config/sles/15/mssql-server-2019.repo
    

    다른 버전의 SQL Server를 설치하려면 이 문서의 SQL Server 2017(14.x) 또는 SQL Server 2022(16.x) 버전을 참조하세요.

  2. 리포지토리를 새로 고칩니다.

    sudo zypper --gpg-auto-import-keys refresh
    

    Microsoft 패키지 서명 키가 시스템에 설치되어 있는지 확인하려면 아래 명령을 사용하여 키를 가져올 수 있습니다.

    sudo rpm --import https://packages.microsoft.com/keys/microsoft.asc
    
  3. SQL Server를 설치하기 전에 SUSE 고객 센터에서 SUSE Linux Enterprise Server를 등록하고 활성화한 후에는 데스크톱 애플리케이션 모듈과 개발 도구 모듈을 모두 활성화해야 합니다. 이러한 모듈은 일부 SQL Server 패키지 종속성에 필요합니다.

  4. 이제 SQL Server를 설치할 준비가 되었습니다. 다음 명령을 실행하여 SQL Server를 설치합니다.

    sudo zypper install -y mssql-server
    
  5. 패키지 설치가 완료되면 mssql-conf setup을 실행하고, 프롬프트에 따라 SA 암호를 설정하고, 버전을 선택합니다. 다시 말씀드리지만, 다음 SQL Server 버전은 체험용 라이선스인 Evaluation, Developer 및 Express로 제공됩니다.

    sudo /opt/mssql/bin/mssql-conf setup
    

    SA 계정에 대한 강력한 암호를 지정해야 합니다. 대문자와 소문자, 0~9의 숫자 및/또는 영숫자가 아닌 기호를 포함하여 최소 길이 8자가 필요합니다.

  6. 구성이 완료되면 서비스가 실행 중인지 확인합니다.

    systemctl status mssql-server
    
  7. 원격으로 연결하려면 방화벽에서 SQL Server TCP 포트(기본값 1433)를 열어야 할 수 있습니다.

    참고

    SLES에서는 예를 들어 firewalld를 사용하여 방화벽을 관리할 수 있습니다. sudo zypper install firewalld를 사용하여 설치한 다음, sudo systemctl start firewalld로 시작합니다. sudo firewall-cmd --zone=public --add-port=1433/tcp --permanent를 사용하여 방화벽 규칙을 추가한 다음, 설정을 적용하기 위해 sudo firewall-cmd --reload를 사용하여 방화벽을 다시 로드합니다.

이제 SQL Server는 SLES 머신에서 실행 중이며 사용할 준비가 되었습니다.

  1. SQL Server 2022(16.x) SLES 리포지토리 구성 파일을 다운로드합니다.

    sudo zypper addrepo -fc https://packages.microsoft.com/config/sles/15/mssql-server-2022.repo
    

    다른 버전의 SQL Server를 설치하려면 이 문서의 SQL Server 2017(14.x) 또는 SQL Server 2019(15.x) 버전을 참조하세요.

  2. 리포지토리를 새로 고칩니다.

    sudo zypper --gpg-auto-import-keys refresh
    

    Microsoft 패키지 서명 키가 시스템에 설치되어 있는지 확인하려면 아래 명령을 사용하여 키를 가져올 수 있습니다.

    sudo rpm --import https://packages.microsoft.com/keys/microsoft.asc
    
  3. SQL Server를 설치하기 전에 SUSE 고객 센터에서 SUSE Linux Enterprise Server를 등록하고 활성화한 후에는 데스크톱 애플리케이션 모듈과 개발 도구 모듈을 모두 활성화해야 합니다. 이러한 모듈은 일부 SQL Server 패키지 종속성에 필요합니다.

  4. 이제 SQL Server를 설치할 준비가 되었습니다. 다음 명령을 실행하여 SQL Server를 설치합니다.

    sudo zypper install -y mssql-server
    
  5. 패키지 설치가 완료되면 mssql-conf setup을 실행하고, 프롬프트에 따라 SA 암호를 설정하고, 버전을 선택합니다. 다시 말씀드리지만, 다음 SQL Server 버전은 체험용 라이선스인 Evaluation, Developer 및 Express로 제공됩니다.

    sudo /opt/mssql/bin/mssql-conf setup
    

    SA 계정에 대한 강력한 암호를 지정해야 합니다. 대문자와 소문자, 0~9의 숫자 및/또는 영숫자가 아닌 기호를 포함하여 최소 길이 8자가 필요합니다.

  6. 구성이 완료되면 서비스가 실행 중인지 확인합니다.

    systemctl status mssql-server
    
  7. 원격으로 연결하려면 방화벽에서 SQL Server TCP 포트(기본값 1433)를 열어야 할 수 있습니다.

    참고

    SLES에서는 예를 들어 firewalld를 사용하여 방화벽을 관리할 수 있습니다. sudo zypper install firewalld를 사용하여 설치한 다음, sudo systemctl start firewalld로 시작합니다. sudo firewall-cmd --zone=public --add-port=1433/tcp --permanent를 사용하여 방화벽 규칙을 추가한 다음, 설정을 적용하기 위해 sudo firewall-cmd --reload를 사용하여 방화벽을 다시 로드합니다.

이제 SQL Server는 SLES 머신에서 실행 중이며 사용할 준비가 되었습니다.

sa 모범 사례로 계정 사용 안 함

설치 후 처음으로 계정을 사용하여 sa SQL Server 인스턴스에 연결하는 경우 이러한 단계를 수행한 다음 즉시 로그인을 보안 모범 사례로 사용하지 않도록 설정하는 sa 것이 중요합니다.

  1. 새 로그인을 만들고 sysadmin 서버 역할의 멤버로 만듭니다.

  2. 만든 새 로그인을 사용하여 SQL Server 인스턴스에 커넥트.

  3. 보안 모범 사례에 sa 권장되는 대로 계정을 사용하지 않도록 설정합니다.

SQL Server 명령줄 도구 설치

데이터베이스를 만들려면 SQL Server에서 Transact-SQL 문을 실행할 수 있는 도구와 연결해야 합니다. SQL Server 명령줄 도구인 sqlcmd 유틸리티 및 bcp 유틸리티를 설치하는 단계는 다음과 같습니다.

다음 단계를 사용하여 SUSE Linux Enterprise Server에 mssql-tools18 을 설치합니다.

  1. Microsoft 패키지 서명 키를 가져옵니다.

    curl -O https://packages.microsoft.com/keys/microsoft.asc
    sudo rpm --import microsoft.asc
    
  2. Zypper에 SQL Server 리포지토리를 추가합니다.

    • SLES 15의 경우 다음 명령을 사용합니다.

      sudo zypper ar https://packages.microsoft.com/config/sles/15/prod.repo
      
    • SLES 12의 경우 다음 명령을 사용합니다.

      sudo zypper ar https://packages.microsoft.com/config/sles/12/prod.repo
      
  3. unixODBC 개발자 패키지를 사용하여 mssql-tools18을 설치합니다.

    • SLES 15의 경우 다음 명령을 사용합니다.
    sudo zypper install -y mssql-tools18 unixODBC-devel glibc-locale-base
    
    • SLES 12의 경우 다음 명령을 사용합니다.
    sudo zypper install -y mssql-tools18 unixODBC-devel
    

    참고 항목

    최신 버전의 mssql-tools18로 업데이트하려면 다음 명령을 실행합니다.

    sudo zypper refresh
    sudo zypper update mssql-tools18
    
  4. 선택 사항: bash 셸에서 환경 변수에 추가 /opt/mssql-tools18/bin/ 합니다 PATH .

    로그인 세션에 대한 bash 셸에서 sqlcmd 및 bcp에 액세스할 수 있도록 하려면 다음 명령을 사용하여 파일에서 ~/.bash_profile 수정합니다PATH.

    echo 'export PATH="$PATH:/opt/mssql-tools18/bin"' >> ~/.bash_profile
    

    대화형/비 로그인 세션을 위해 bash 셸에서 sqlcmd 또는 bcp에 액세스할 수 있도록 하려면 다음 명령을 사용하여 파일에서 ~/.bashrc 수정 PATH 합니다.

    echo 'export PATH="$PATH:/opt/mssql-tools18/bin"' >> ~/.bashrc
    source ~/.bashrc
    

로컬로 연결

다음 단계에서는 sqlcmd를 사용하여 새 SQL Server 인스턴스에 로컬로 연결합니다.

  1. sqlcmd를 SQL Server 이름(-S), 사용자 이름(-U) 및 암호(-P)의 매개 변수를 사용하여 실행합니다. 이 자습서에서는 로컬로 연결하므로 서버 이름은 localhost입니다. 사용자 이름은 sa이고 암호는 설치할 때 SA 계정에 지정한 암호입니다.

    sqlcmd -S localhost -U sa -P '<YourPassword>'
    

    참고 항목

    최신 버전의 sqlcmd 는 기본적으로 안전합니다. 연결 암호화에 대한 자세한 내용은 Windows용 sqlcmd 유틸리티를 참조하고 Linux 및 macOS용 sqlcmd를 사용하여 커넥트. 연결이 성공하지 못하면 sqlcmd옵션을 추가하여 -No 암호화가 필수가 아니라 선택 사항임을 지정할 수 있습니다.

    명령줄에서 암호를 생략하여 입력하라는 메시지가 표시되도록 할 수 있습니다.

    나중에 원격으로 연결하려는 경우 -S 매개 변수에 컴퓨터 이름 또는 IP 주소를 지정하고 방화벽에서 포트 1433이 열려 있는지 확인합니다.

  2. 성공하면 sqlcmd 명령 프롬프트 1>이 표시됩니다.

  3. 연결 오류가 발생하는 경우 먼저 오류 메시지에서 문제를 진단합니다. 그런 다음 connection troubleshooting recommendations(연결 문제 해결 권장 사항)를 검토합니다.

데이터 만들기 및 쿼리

다음 섹션에서는 sqlcmd를 사용하여 새 데이터베이스를 만들고, 데이터를 추가하고, 간단한 쿼리를 실행하는 단계를 안내합니다.

Transact-SQL 문 및 쿼리를 작성하는 방법에 대한 자세한 내용은 자습서: TRANSACT-SQL 문 작성을 참조하세요.

새 데이터베이스 만들기

다음 단계에서는 TestDB라는 새 데이터베이스를 만듭니다.

  1. sqlcmd 명령 프롬프트에서 다음 Transact-SQL 명령을 붙여넣어 테스트 데이터베이스를 만듭니다.

    CREATE DATABASE TestDB;
    
  2. 다음 줄에 서버에 있는 모든 데이터베이스의 이름을 반환하는 쿼리를 작성합니다.

    SELECT Name from sys.databases;
    
  3. 앞의 두 명령은 즉시 실행되지 않았습니다. 앞의 명령을 실행하려면 새 줄에 GO를 입력해야 합니다.

    GO
    

데이터 삽입

다음으로 새 테이블 dbo.Inventory를 만들고 두 개의 새 행을 삽입합니다.

  1. sqlcmd 명령 프롬프트에서 컨텍스트를 새 TestDB 데이터베이스로 전환합니다.

    USE TestDB;
    
  2. dbo.Inventory라는 새 테이블을 만듭니다.

    CREATE TABLE dbo.Inventory (
        id INT,
        name NVARCHAR(50),
        quantity INT,
        PRIMARY KEY (id)
    );
    
  3. 새 테이블에 데이터를 삽입합니다.

    INSERT INTO dbo.Inventory VALUES (1, 'banana', 150);
    INSERT INTO dbo.Inventory VALUES (2, 'orange', 154);
    
  4. GO를 입력하여 앞의 명령을 실행합니다.

    GO
    

데이터 선택

이제 쿼리를 실행하여 dbo.Inventory 테이블에서 데이터를 반환합니다.

  1. sqlcmd 명령 프롬프트에서 dbo.Inventory 테이블에서 수량이 152보다 큰 행을 반환하는 쿼리를 입력합니다.

    SELECT * FROM dbo.Inventory
    WHERE quantity > 152;
    
  2. 다음 명령을 실행합니다.

    GO
    

sqlcmd 명령 프롬프트 종료

sqlcmd 세션을 종료하려면 QUIT를 입력합니다.

QUIT

성능 모범 사례

Linux에 SQL Server를 설치한 후에는 프로덕션 시나리오에 대한 성능을 향상시키도록 Linux 및 SQL Server를 구성하기 위한 모범 사례를 검토하세요. 자세한 내용은 SQL Server on Linux의 성능 모범 사례 및 구성 지침을 참조하세요.

플랫폼 간 데이터 도구

sqlcmd 외에도 다음과 같은 플랫폼 간 도구를 사용하여 SQL Server를 관리할 수 있습니다.

도구 설명
Azure Data Studio 플랫폼 간 GUI 데이터베이스 관리 유틸리티입니다.
Visual Studio Code mssql 확장을 사용하여 Transact-SQL 문을 실행하는 플랫폼 간 GUI 코드 편집기입니다.
PowerShell Core cmdlet을 기준으로 하는 플랫폼 간 자동화 및 구성 도구입니다.
mssql-cli Transact-SQL 명령을 실행하기 위한 플랫폼 간 명령줄 인터페이스입니다.

Windows에서 커넥트

Windows의 SQL Server 도구는 원격 SQL Server 인스턴스에 연결할 때와 동일하게 Linux의 SQL Server 인스턴스에 연결합니다.

Linux 컴퓨터에 연결할 수 있는 Windows 컴퓨터가 있는 경우 이 항목의 단계와 동일하게 Windows 명령 프롬프트에서 sqlcmd를 실행해 보세요. localhost대신 대상 Linux 컴퓨터 이름이나 IP 주소를 사용하고 SQL Server 컴퓨터에 TCP 포트 1433이 열려 있는지 확인해야 합니다. Windows에서 연결하는 데 문제가 있는 경우 connection troubleshooting recommendations(연결 문제 해결 권장 사항)를 참조하세요.

Windows에서 실행하지만 Linux의 SQL Server에 연결하는 다른 도구는 다음을 참조하세요.

기타 배포 시나리오

다른 설치 시나리오의 경우 다음 리소스를 참조하세요.

  • 업그레이드: Linux에서 SQL Server의 기존 설치를 업그레이드하는 방법 알아보기
  • 제거: Linux에서 SQL Server 제거
  • 무인 설치: 확인 메시지를 표시하지 않고 설치를 스크립팅하는 방법을 알아봅니다.
  • 오프라인 설치: 오프라인 설치에 대한 패키지를 수동으로 다운로드하는 방법을 알아봅니다.

질문과 대답은 SQL Server on Linux FAQ를 참조하세요.

SQL 설명서에 참여하세요

SQL 콘텐츠를 직접 편집할 수 있다는 것을 알고 계셨나요? 직접 편집하면 설명서가 개선될 뿐만 아니라 페이지에 참여자로 기입됩니다.

자세한 내용은 SQL Server 설명서에 기여하는 방법을 참조하세요.