* 질문 등록 시 다음의 내용을 꼭 기입하여 주세요.
Ubuntu 16.04 64bit | |
10.1.0.7663 |
|
[도움말]-[버전정보] 확인 | |
PHP 7.0.22-0ubuntu0.16.04.1 |
* CUBRID 응용 오류, SQL 오류 또는 SQL 튜닝 관련된 문의는 반드시 다음의 내용을 추가해 주세요. 비밀글이나 비밀 댓글도 가능합니다.
* 저희가 상황을 이해하고, 재현이 가능해야 알 수 있는 문제들이 많습니다. 가능한 정보/정황들을 부탁합니다.
에러 내용 및 재현 방법 | 재현 가능한 Source와 SQL |
관련 테이블(인덱스, 키정보 포함) 정보 | CUBRID 홈 디렉토리 아래 log 디렉토리 압축 |
-------------- 아래에 질문 사항을 기입해 주세요. ------------------------------------------------------------------------
현재 서버에는 apt-get으로 설치한 nginx, php7.0-fpm, php7.0-dev이 있으며, cubrid 10.1 버전을 설치하여 운영중입니다.
(CUBRID의 경우 다른 사용자 계정에서 설치되어 운영중에 있음)
다음과 같은 순서로 php7용 드라이버를 설치하였습니다.
1. 큐브리드 홈페이지 downloads 내 PHP 7 / Linux (SRC) 다운로드
2. 압축 해제 후 해당 폴더(cubrid-php-7)로 이동
3. $ phpize
4. $ ./configure --with-cubrid --with-php-config=/usr/bin/php-config
5. $ make
6. $ sudo make install
7. /etc/php/7.0/fpm/php.ini 파일 하단에 [cubrid]\nextension = cubrid.so 추가
8. $ sudo service php7.0-fpm restart
이후 아래와 같은 test.php파일 생성하여 접근하였습니다.
<?php
$con = cubrid_connect("host", port, "db", "user", "pw");
if($con) {
echo cubrid_get_server_info($con)."\n";
echo cubrid_get_client_info($con)."\n";
echo cubrid_get_charset($con)."\n";
cubrid_disconnect($con);
}
?>
이 경우 nginx(fastcgi_pass unix:/run/php/php7.0-fpm.sock으로 연결)에서 502 Bad Gateway 에러가 표시되며, php 로그에는 아래와 같이 출력됩니다.
WARNING: [pool www] child 113826 exited on signal 11 (SIGSEGV - core dumped) after 1.086763 seconds from start
cli php쪽의 php.ini에도 extension 추가하여 아래와 같이 gdb로 테스트한 경우 다음과 같은 결과가 확인됩니다.
1. $ gdb php
2. (gdb) run test.php
Starting program: /usr/bin/php test.php
[Thread debu.gging using libthread_db enabled]
Using host libthread_db library "/lib/x86_64-linux-gnu/libthread_db.so.1".
[New Thread 0x7fffec4f6700 (LWP 118243)]
10.1.0.7663
10.0.0
utf-8
Thread 1 "php" received signal SIGSEGV, Segmentation fault.
0x00007ffff79ae208 in inflateEnd () from /lib/x86_64-linux-gnu/libz.so.1
php 코드 중간에 SELECT문을 execute하여 fetch하면 결과가 표시되는 것을 보아 동작은 되는 것 같으나 위와 같이 Segmentation fault 문제와 함께 signal 11에러와 함께 종료됩니다.
드라이버상의 문제인지, 제 서버 구성 환경에서의 문제인지 확실히 알 수가 없어 문의드려봅니다.
(Node.js나 Ruby 드라이버의 경우 정상적으로 동작하고 있습니다. php7 드라이버에서만 문제가 발생합니다)
현재, PHP7 zend platform의 memory 관련 문제로 예측되며, 오류 분석 작업을 진행하고 있습니다.
조치되는대로 댓글을 올리겠습니다.