다음을 통해 공유


빠른 시작: Red Hat에 SQL Server 설치 및 데이터베이스 만들기

적용 대상: SQL Server - Linux

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

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

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

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

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

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

이 자습서를 사용하려면 사용자 입력과 인터넷 연결이 필요합니다. 무인 또는 오프라인 설치 절차에 관심이 있는 경우 SQL Server on Linux 설치 지침을 참조하세요. RHEL에 미리 설치된 SQL Server VM을 프로덕션 기반 워크로드를 실행할 준비가 되도록 선택한 경우 SQL Server VM을 만들기 위한 모범 사례를 따르세요.

Azure Marketplace 이미지

다음 Azure Marketplace 이미지를 기반으로 VM을 만들 수 있습니다.

위의 마켓플레이스 이미지를 사용하는 경우 설치 단계를 거치지 않고 SQL Server를 시작하는 데 필요한 SKU와 sa 암호를 제공하여 인스턴스를 직접 구성할 수 있습니다. 위의 Marketplace 이미지를 사용하여 RHEL에 배포된 SQL Server Azure VM은 Microsoft와 Red Hat 모두에서 완전히 지원됩니다.

다음 명령을 사용하여 mssql-conf로 SQL Server on Linux를 구성할 수 있습니다.

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

필수 구성 요소

메모리가 2GB 이상인 RHEL 8.x 머신이 있어야 합니다.

사용자의 머신에 Red Hat Enterprise Linux를 설치하려면 https://access.redhat.com/products/red-hat-enterprise-linux/evaluation으로 이동합니다. Azure에서 RHEL 가상 머신을 만들 수도 있습니다. Azure CLI를 사용하여 Linux VM 만들기 및 관리를 참조하고 az vm create에 대한 호출에 --image RHEL을 사용하세요.

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

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

SQL Server 설치

SQL Server를 설치하기 위한 다음 명령은 RHEL 8 리포지토리를 가리킵니다. RHEL 8에는 SQL Server에 필요한 python2이(가) 사전 설치되어 있지 않습니다. SQL Server 설치 단계를 시작하기 전에 명령을 실행하고 python2이(가) 인터프리터로 선택되었는지 확인합니다.

sudo alternatives --config python
# If not configured, install python2 and openssl10 using the following commands:
sudo yum install python2
sudo yum install compat-openssl10
# Configure python2 as the default interpreter using this command:
sudo alternatives --config python

자세한 내용은 python2 설치 및 기본 인터프리터 https://www.redhat.com/en/blog/installing-microsoft-sql-server-red-hat-enterprise-linux-8-beta(으)로 구성하는 방법에 대한 블로그를 참조하세요.

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

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

    sudo curl -o /etc/yum.repos.d/mssql-server.repo https://packages.microsoft.com/config/rhel/8/mssql-server-2017.repo
    

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

  2. 다음 명령을 실행하여 SQL Server를 설치합니다.

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

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

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

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

    systemctl status mssql-server
    
  5. 원격 연결을 허용하려면 RHEL 방화벽에서 SQL Server 포트를 엽니다. 기본 SQL Server 포트는 TCP 1433입니다. 방화벽에 FirewallD를 사용 중인 경우 다음 명령을 사용할 수 있습니다.

    sudo firewall-cmd --zone=public --add-port=1433/tcp --permanent
    sudo firewall-cmd --reload
    

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

SQL Server를 설치하기 위한 다음 명령은 RHEL 8 리포지토리를 가리킵니다. RHEL 8에는 SQL Server에 필요한 python2이(가) 사전 설치되어 있지 않습니다. SQL Server 설치 단계를 시작하기 전에 명령을 실행하고 python2이(가) 인터프리터로 선택되었는지 확인합니다.

sudo alternatives --config python
# If not configured, install python2 and openssl10 using the following commands:
sudo yum install python2
sudo yum install compat-openssl10
# Configure python2 as the default interpreter using this command:
sudo alternatives --config python

자세한 내용은 python2 설치 및 기본 인터프리터 https://www.redhat.com/en/blog/installing-microsoft-sql-server-red-hat-enterprise-linux-8-beta(으)로 구성하는 방법에 대한 블로그를 참조하세요.

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

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

    sudo curl -o /etc/yum.repos.d/mssql-server.repo https://packages.microsoft.com/config/rhel/8/mssql-server-2019.repo
    

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

  2. 다음 명령을 실행하여 SQL Server를 설치합니다.

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

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

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

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

    systemctl status mssql-server
    
  5. 원격 연결을 허용하려면 RHEL 방화벽에서 SQL Server 포트를 엽니다. 기본 SQL Server 포트는 TCP 1433입니다. 방화벽에 FirewallD를 사용 중인 경우 다음 명령을 사용할 수 있습니다.

    sudo firewall-cmd --zone=public --add-port=1433/tcp --permanent
    sudo firewall-cmd --reload
    

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

SQL Server를 설치하기 위한 다음 명령은 RHEL 8 리포지토리를 가리킵니다.

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

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

    sudo curl -o /etc/yum.repos.d/mssql-server.repo https://packages.microsoft.com/config/rhel/8/mssql-server-2022.repo
    

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

  2. 다음 명령을 실행하여 SQL Server를 설치합니다.

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

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

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

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

    systemctl status mssql-server
    
  5. 원격 연결을 허용하려면 RHEL 방화벽에서 SQL Server 포트를 엽니다. 기본 SQL Server 포트는 TCP 1433입니다. 방화벽에 FirewallD를 사용 중인 경우 다음 명령을 사용할 수 있습니다.

    sudo firewall-cmd --zone=public --add-port=1433/tcp --permanent
    sudo firewall-cmd --reload
    

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

모범 사례로 sa 계정 사용 중지하기

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

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

  2. 만든 새 로그인을 사용하여 SQL Server 인스턴스에 연결합니다.

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

SQL Server 명령줄 도구 설치

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

다음 단계를 사용하여 Red Hat Enterprise Linux에서 mssql-tools18를 설치합니다.

  1. Microsoft Red Hat 리포지토리 구성 파일을 다운로드합니다.

    • Red Hat 9의 경우 다음 명령을 사용합니다.

      curl https://packages.microsoft.com/config/rhel/9/prod.repo | sudo tee /etc/yum.repos.d/mssql-release.repo
      
    • Red Hat 8의 경우 다음 명령을 사용합니다.

      curl https://packages.microsoft.com/config/rhel/8/prod.repo | sudo tee /etc/yum.repos.d/mssql-release.repo
      
    • Red Hat 7의 경우 다음 명령을 사용합니다.

      curl https://packages.microsoft.com/config/rhel/7/prod.repo | sudo tee /etc/yum.repos.d/mssql-release.repo
      
  2. 이전 버전의 mssql-tools가 설치되어 있는 경우 이전 unixODBC 패키지를 제거합니다.

    sudo yum remove mssql-tools unixODBC-utf16 unixODBC-utf16-devel
    
  3. 다음 명령을 실행하여 unixODBC 개발자 패키지와 함께 mssql-tools18를 설치합니다.

    sudo yum install -y mssql-tools18 unixODBC-devel
    

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

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

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

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

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

    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 설명서에 기여하는 방법을 참조하세요