Microsoft SQL Server 데이터베이스에 연결하는 Elastic Beanstalk PHP 플랫폼에서 애플리케이션을 배포하려고 할 때 발생하는 오류를 해결하려면 어떻게 해야 하나요?

최종 업데이트 날짜: 2021년 8월 2일

Microsoft SQL Server 데이터베이스에 연결되는 AWS Elastic Beanstalk PHP 플랫폼에서 애플리케이션을 배포하려고 합니다. 그랬더니 다음과 같은 오류가 발생했습니다. "PHP Fatal error: Uncaught Error: Call to undefined function sqlsrv_connect() in /var/app/current/DB/."

간략한 설명

PHP를 Microsoft SQL Server 데이터베이스에 연결하려면, 먼저 SQLSRV 라이브러리와 PDO 확장을 설치하고 구성해야 합니다. 라이브러리 및 확장은 기본적으로 설치 및 구성되지 않습니다.

이 오류를 해결하려면 Amazon Elastic Compute Cloud(Amazon EC2) 인스턴스에서 스크립트를 실행하는 .ebextensions 구성 파일을 사용할 수 있습니다. 스크립트는 다음을 수행합니다.

  • Microsoft SQL Server에 올바른 드라이버 및 도구 설치
  • 필요한 PHP 라이브러리와 확장 활성화

중요: 다음 해결 방법에서 사용되는 .ebextensions 파일은 Amazon Linux 1과 Amazon Linux 2 Amazon Machine Image(AMI) 인스턴스에만 해당됩니다. .ebextensions 파일은 Elastic Beanstalk의 Windows 또는 사용자 지정 Ubuntu AMI 인스턴스에는 적용되지 않습니다.

해결 방법

참고: 다음 해결 방법은 PHP 플랫폼 버전에 관계없이 Elastic Beanstalk 환경에 해당됩니다.

1.    애플리케이션 번들의 루트에서 .ebextensions라는 디렉터리를 생성합니다.

2.    .ebextensions 구성 파일(예: .ebextensions/pdo_sqlsrv.config)을 만듭니다. 예를 들면 다음과 같습니다.

###################################################################################################
#### Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.
#### 
#### Permission is hereby granted, free of charge, to any person obtaining a copy of this
#### software and associated documentation files (the "Software"), to deal in the Software
#### without restriction, including without limitation the rights to use, copy, modify,
#### merge, publish, distribute, sublicense, and/or sell copies of the Software, and to
#### permit persons to whom the Software is furnished to do so.
###################################################################################################

###################################################################################################
#### THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED,
#### INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A
#### PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT
#### HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
#### OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
#### SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
###################################################################################################

commands:
  install_mssql:
    command: |
      #!/bin/bash

      # 0. EXIT if pdo_sqlsrv is already installed
      if php -m | grep -q 'pdo_sqlsrv'
      then
        echo 'pdo_sqlsrv is already installed'
      else
        # 1. Register the Microsoft Linux repository
        wget https://packages.microsoft.com/config/rhel/8/prod.repo -O /etc/yum.repos.d/msprod.repo

        # 2. Install MSSQL and tools
        ACCEPT_EULA=N yum install mssql-tools msodbcsql17 unixODBC-devel -y --disablerepo=amzn*
        # The license terms for this product can be downloaded from http://go.microsoft.com/fwlink/?LinkId=746949 and found in /usr/share/doc/mssql-tools/LICENSE.txt . By changing "ACCEPT_EULA=N" to "ACCEPT_EULA=Y", you indicate that you accept the license terms.
        echo 'export PATH="$PATH:/opt/mssql-tools/bin"' >> ~/.bash_profile
        echo 'export PATH="$PATH:/opt/mssql-tools/bin"' >> ~/.bashrc
        source ~/.bashrc

        # 3. Install SQLSRV and its PDO extension, and stop pecl/pecl7 from overwriting php.ini
        cp -f "/etc/php.ini" "/tmp/php.ini.bk"
        pecl7 install sqlsrv pdo_sqlsrv || pecl install sqlsrv pdo_sqlsrv
        cp -f "/tmp/php.ini.bk" "/etc/php.ini"

        # 4. Manually add the extensions to the proper php.ini.d file and fix parameters
        sqlvar=$(php -r "echo ini_get('extension_dir');") && chmod 0755 $sqlvar/sqlsrv.so && chmod 0755 $sqlvar/pdo_sqlsrv.so
        echo extension=pdo_sqlsrv.so >> `php --ini | grep "Scan for additional .ini files" | sed -e "s|.*:\s*||"`/30-pdo_sqlsrv.ini
        echo extension=sqlsrv.so >> `php --ini | grep "Scan for additional .ini files" | sed -e "s|.*:\s*||"`/20-sqlsrv.ini
      fi

이 문서가 도움이 되었나요?


결제 또는 기술 지원이 필요하세요?