ID:               37630
 Updated by:       [EMAIL PROTECTED]
 Reported By:      openmacnews at gmail dot com
 Status:           Open
 Bug Type:         MySQL related
 Operating System: osx
 PHP Version:      5.1.4
 New Comment:

The switch to enable thread safety is --enable-maintainer-zts.  The
name suggests though, that you shoulnd't use it unless you've got a
really good reason to do so.


Now about the reentrancy issues of the mysql extensions:
None of ext/mysql, ext/mysqli, ext/pdo_mysql check for the reentrant
version of the client library if ZTS is enabled.

ext/mysql though, calls mysql_thread_init() and mysql_thread_end() and
thus cause sort of a deadlock if linked against libmysqlclient_r.

Just a recap, no fix yet.


Previous Comments:
------------------------------------------------------------------------

[2006-05-30 16:34:35] openmacnews at gmail dot com

mike,

great. rather than dribbles of info, can you, then, please specify what
configuration option does and how to end up linked agaist only the
right/single library?

bottom line is i'm looking for thread-safe php + mysql, linked against
libmysqlclient_r.

let's just say the documentation hasn't been, at least for me,
forthcoming on the matter ...

------------------------------------------------------------------------

[2006-05-30 16:22:54] [EMAIL PROTECTED]

This configure flag does not enable thread safety.

------------------------------------------------------------------------

[2006-05-30 15:44:09] openmacnews at gmail dot com

hi mike,

of course.

sorry, i should have specified rather than assumed it would be obvious
...

i have built php "--with-tsrm-pthreads".

same issue, one vs both libs linked.

------------------------------------------------------------------------

[2006-05-30 13:14:21] [EMAIL PROTECTED]

>i've built mysql 5.0.21 threadsafe -- hence, the link target >needs to
be the _reentrant_ libmysqlclient_r

No. If you don't build a threaded client, you don't need to link
against the reentrant client libraries.



------------------------------------------------------------------------

[2006-05-29 15:54:56] openmacnews at gmail dot com

Description:
------------
hi all,

i'm building php-5.1.4 from source on osx 10.4.6

i've built mysql 5.0.21 threadsafe -- hence, the link target needs to
be the _reentrant_ libmysqlclient_r.

if i configure php as:


setenv CPPFLAGS "-I/usr/local/mysql/include/mysql"
setenv LDFLAGS "-bind_at_load -L/usr/local/mysql/lib/mysql
-lmysqlclient_r" 

./configure \
  ...
  --enable-pdo \
  --with-mysql=/usr/local/mysql \
  --with-mysql-sock=/var/Process \
  --with-pdo-mysql=/usr/local/mysql \
  --with-apxs2=/usr/local/apache2/sbin/apxs \
  ...

the build completes w/o error, BUT, resultant libs & bins are built
linked against BOTH lmysqlclient_r AND lmysqlclient.

iiuc, this should NOT be the case.

to get around this, *prior* to config:

        perl -pi -e 's/mysqlclient\,/mysqlclient_r\,/g'
ext/pdo_mysql/config.m4
        perl -pi -e 's/mysqlclient\./mysqlclient_r\./g'
ext/pdo_mysql/config.m4

and after config, prior to *make*:

        perl -pi -e 's/mysqlclient /mysqlclient_r /g' Makefile
        perl -pi -e 's/mysqlclient\n/mysqlclient_r\n/g' Makefile

again, no errors, and the libs/bins are linked -- as expected --
against *only* the reentrant lib.


cheers,

richard



------------------------------------------------------------------------


-- 
Edit this bug report at http://bugs.php.net/?id=37630&edit=1

Reply via email to