CentOS, Fedora, RHEL에서 SQL Azure 접속하기

안녕하세요. Windows Azure MVP 남정현입니다.

SQL Azure를 사용한다면 아마 거의 예외없이 접속하는 클라이언트 측의 운영 체제는 Windows 운영 체제일 것입니다. 그러나 만약 리눅스를 클라이언트 측의 운영 체제로 직접 사용하기 원한다면 어떻게 해야 할까요? 기존에 여러분이 사용하고 있을 가능성이 높은 드라이버로 FreeTDS가 있겠습니다만 버전이 낮은 드라이버는 SQL Azure가 철칙으로 사용하는 SSL 연결을 지원하지 못합니다. 최근에 출시된 FreeTDS의 경우 SSL을 지원하기는 하지만, SQL Azure로 연결을 시도할 경우 연결 과정에서 응답 없음 상태로 빠지거나 여러가지 다른 오류가 발생할 수 있습니다. 아마도 향후에 개선될 것으로 기대합니다. 이 블로그에서 설명하려는 내용에 대해 최상의 결과를 얻기 위하여 현재는 Microsoft SQL Server ODBC Driver 1.0 for Linux가 필요합니다.

시스템 요구 사항

Microsoft SQL Server ODBC Driver for Linux를 설치하기 위해서는 다음의 조건을 만족해야 합니다.

  • 64비트 지원 프로세서가 필요합니다. (x64 또는 AMD64)
  • CentOS, Fedora, RHEL 등의 Redhat 계통의 최신 리눅스 운영 체제가 필요합니다.
  • 실행 중인 운영 체제의 커널이 x86_64 환경에서 실행 중이어야 합니다.

그리고 당연한 이야기이지만 시스템 관리자 권한을 얻은 상태에서 실행해야 합니다.

설치 전에 필요한 모든 패키지 설치하기

운영 체제의 버전마다 필요로 하는 패키지의 최소 버전에 차이가 존재하기는 하나, 아래의 명령어들을 사용하여 일반적인 종속성 상의 요구 사항을 모두 정리할 수 있습니다. 아래 명령어들은 설치 전후반에 걸쳐 필요한 패키지들을 모두 설치해 줄 것입니다.

  • yum install glibc
  • yum install e2fsprogs
  • yum install krb5-libs
  • yum install openssl
  • yum install libgcc
  • yum install libstdc++
  • yum install make
  • yum install gcc
  • yum install bison
  • yum install byacc
  • yum install libuuid
  • yum install wget
  • yum install tar

드라이버 파일 내려 받기

드라이버 파일을 내려받기 위하여 http://www.microsoft.com/en-us/download/details.aspx?id=28160 페이지에서 적절한 버전의 tar 패키지 파일을 내려 받아야 합니다. 만약 서버 환경에서 직접 설치해야 하는 상황인 경우, 다운로드 URL을 확인하여 bit.ly 등의 단축 주소로 주소를 줄이고 그 주소를 wget 명령에 대입하면 수고스러움을 덜 수 있습니다.

파일을 다운로드하고나서 tar 유틸리티로 압축을 해제합니다.

tar xvzf sqlncli-11.0.1790.0.tar.gz

그 이후에는 해당 디렉터리로 이동한 다음 필요한 작업을 진행합니다.

unixODBC Driver Manager 설치하기

SQL Server Driver for Linux는 unixODBC 환경 아래에서 작동하도록 만들어진 드라이버이므로 반드시 unixODBC Driver Manager를 시스템에 설치해야 합니다. 만약 기존에 이미 설치가 되어있는 상태이면 다음 섹션으로 넘어가서 곧바로 드라이버를 설치해도 됩니다.

아래 명령어를 sqlncli 디렉터리에서 실행합니다.

./build_dm.sh

상세한 안내 메시지가 나타나게 되는데, YES를 입력하여 내용에 동의함을 표시합니다. 그 다음에는 unixODBC를 대신 다운로드하고 컴파일하고 설치하는 작업이 자동으로 진행될 것입니다. 그리고 최종적으로 사용자가 직접 설치를 진행해야 하는데, 스크립트 실행이 완료되면 아래와 같은 메시지를 볼 수 있을 것입니다. 메시지에 실제로 출력된 임시 경로로 이동하도록 정확히 이름을 지정하는 것에 유의하여 아래와 유사한 명령어를 실행합니다.

cd /tmp/unixODBC.x.x.x/unixODBC-2.3.0; make install

Linux나 Unix 명령어에 익숙하지 않은 분들을 위하여 부연 설명을 드리면, 세미콜론은 순차적인 실행을 위하여 사용되는 연산자입니다. 즉, 디렉터리를 이동하고난 다음에 make install 명령어를 실행하라는 의미입니다. 설치가 끝나고 나면 다시 sqlncli 디렉터리로 이동합니다.

ODBCINST.INI 파일 백업하기

실제 드라이버를 설치하기 전에 만약 odbcinst.ini 파일을 백업해야 할 필요가 있다면 아래 명령어를 사용하여 정확한 경로를 확인하고 해당 파일을 복사하여 백업하기 바랍니다.

odbc_config odbcinstini

실제 드라이버 설치하기

이제 실제 드라이버를 설치할 차례입니다. sqlncli 디렉터리로 이동한 다음, 아래와 같이 명령어를 입력합니다.

./install.sh install

사용자 계약서를 표시하는데, 모두 읽어보기 귀찮으시다면 키보드의 q키를 누릅니다. 그러면 동의 여부를 곧바로 묻는 프롬프트가 나오는데 여기서 YES를 입력하고 기다립니다. 특별한 오류 없이 설치가 끝났다면 마지막으로 아래 명령어를 입력하여 정상적으로 설치가 되었는지 확인해봅니다.

./install.sh verify

특별한 오류 메시지가 없다면 정상적으로 설치가 완료된 것입니다.

SQL Azure 연결 테스트해보기

이제 리눅스 환경에서도 SQL Azure에 연결이 잘 되는지 확인해볼 차례입니다. ODBC를 사용한다고 하였지만 별도로 인스턴스를 등록하거나 복잡한 절차를 거치지 않고 곧바로 테스트해볼 방법이 있는데, FreeTDS와 마찬가지로, 그리고 FreeTDS가 그러했듯이 Microsoft가 제공하는 sqlcmd 유틸리티가 여기에서도 그대로 제공됩니다.

sqlcmd -U <SQL Azure 계정 ID> -P <SQL Azure 비밀 번호> -S <서버 ID>.database.windows.net -d <데이터베이스 이름>

Windows에서 사용하던 것과 다르지 않음을 알 수 있습니다. 정상적으로 접속이 되면 1> 프롬프트가 나타날 것이고, 여기에 아래와 같이 쿼리를 수행해 봅니다.

select @@version
go

그러면 아래 그림과 같이 결과가 나타나는 것을 볼 수 있습니다. 보시는 것과 같이 SQL Azure를 Linux에서도 Native Driver를 사용하여 접속할 수 있습니다. 🙂

결론

다소 복잡한 내용들이었지만, 리눅스에서도 SQL Server와 SQL Azure를 얼마든지 접근하고 다룰 수 있는 방법이 있기 때문에 데이터베이스 때문에 Windows를 써야 하는 불편함을 감수해야 할 필요가 전혀 없다는 것을 확인하였습니다. 향후에는 더 나은 방법으로 더 리눅스 환경에서 최적화된 형태로 SQL Azure나 SQL Server에 접속할 수 있을 것으로 기대합니다. 아티클에 대해서 개선할 점이나 의견을 주실 부분이 있으시면 언제든 의견을 주십시오.

댓글 남기기