1DBD::mysql::INSTALL(3)User Contributed Perl DocumentationDBD::mysql::INSTALL(3)
2
3
4

NAME

6       INSTALL - How to install and configure DBD::mysql
7

SYNOPSIS

9         perl Makefile.PL [options]
10         make
11         make test
12         make install
13

DESCRIPTION

15       This document describes the installation and configuration of
16       DBD::mysql, the Perl DBI driver for the MySQL database. Before reading
17       on, make sure that you have the prerequisites available: Perl, MySQL
18       and DBI. For details see the separate section.  "PREREQUISITES".
19
20       Depending on your version of Perl, it might be possible to use a binary
21       distribution of DBD::mysql. If possible, this is recommended. Otherwise
22       you need to install from the sources.  If so, you will definitely need
23       a C compiler. Installation from binaries and sources are both described
24       in separate sections. "BINARY INSTALLATION". "SOURCE INSTALLATION".
25
26       Finally, if you encounter any problems, do not forget to read the
27       section on known problems. "KNOWN PROBLEMS". If that doesn't help, you
28       should look into the archive of the mailing list perl@lists.mysql.com.
29       See http://www.mysql.com for archive locations. And if that still
30       doesn't help, please post a question on this mailing list.
31

PREREQUISITES

33       Perl
34           Preferrably a version of Perl, that comes preconfigured with your
35           system. For example, all Linux and FreeBSD distributions come with
36           Perl. For Windows, ActivePerl is recommended, see
37           http://www.activestate.com for details.
38
39       MySQL
40           You need not install the actual MySQL database server, the client
41           files and the devlopment files are sufficient. For example, Fedora
42           Core 4 Linux distribution comes with RPM files (using YUM)
43           mysql.i386 and mysql-server.i386 (use "yum search" to find exact
44           package names). These are sufficient, if the MySQL server is
45           located on a foreign machine.  You may also create client files by
46           compiling from the MySQL source distribution and using
47
48             configure --without-server
49
50           If you are using Windows and need to compile from sources (which is
51           only the case if you are not using ActivePerl), then you must
52           ensure that the header and library files are installed. This may
53           require choosing a "Custom installation" and selecting the
54           appropriate option when running the MySQL setup program.
55
56       DBI DBD::mysql is a DBI driver, hence you need DBI. It is available
57           from the same source where you got the DBD::mysql distribution
58           from.
59
60       C compiler
61           A C compiler is only required, if you install from source. In most
62           cases there are binary distributions of DBD::mysql available.
63           However, if you need a C compiler, make sure, that it is the same C
64           compiler that was used for compiling Perl and MySQL! Otherwise you
65           will almost definitely encounter problems because of differences in
66           the underlying C runtime libraries.
67
68           In the worst case, this might mean to compile Perl and MySQL
69           yourself. But believe me, experience shows that a lot of problems
70           are fixed this way.
71
72       Gzip libraries
73           Late versions of MySQL come with support for compression. Thus it
74           may be required that you have install an RPM package like libz-
75           devel, libgz-devel or something similar.
76

BINARY INSTALLATION

78       Binary installation is possible in the most cases, depending on your
79       system. I give some examples:
80
81   Windows
82       ActivePerl offers a PPM archive of DBD::mysql. All you need to do is
83       typing
84
85         ppm
86         install DBI
87         install DBD-mysql
88
89       This will fetch the modules via HTTP and install them. If you need to
90       use a WWW proxy server, the environment variable HTTP_proxy must be
91       set:
92
93         set HTTP_proxy=http://my.proxy.server:8000/
94         ppm
95         install DBI
96         install DBD-mysql
97
98       Of course you need to replace the host name "my.proxy.server" and the
99       port number 8000 with your local values.
100
101       If the above procedure doesn't work, please upgrade to the latest
102       version of ActivePerl. Versions before build 623 are known to have
103       problems.
104
105       PPM 3 is said to miss DBD::mysql in the repository. Thus use of PPM 3
106       is discouraged, in favour of PPM 2. If you need to use PPM 3, try
107
108         ppm
109         rep add PPM2 http://ppm.activestate.com/PPMPackages/5.6plus/
110         rep 2
111         install DBI
112         install DBD-mysql
113
114   Red Hat Linux
115       As of version 7.1, Red Hat Linux comes with MySQL and DBD::mysql.  You
116       need to ensure that the following RPM's are installed:
117
118         mysql
119         perl-DBI
120         perl-DBD-MySQL
121
122       For installation from source the following RPM's are required
123
124         mysql-devel
125         libz-devel
126
127       Optional are
128
129         mysql-server
130
131   Fedora Core Linux
132       As of version 3, Fedora Linux comes with MySQL and DBD::mysql.  You
133       need to ensure that the following RPM's are installed:
134
135         mysql or mysql-server
136         perl-DBD-MySQL
137
138       For installation from source the following RPM's are required
139
140         mysql-devel
141         libz-devel
142
143       Please try
144
145         yum search mysql
146
147       To see the exact names
148
149       Note: (important) FC 3 comes with MySQL 3.x, and some people have
150       upgraded using MySQL RPMs for newer versions. If you do this, you must
151       re-compile you DBD::mysql because your existing DBD::mysql will be
152       linked against the old version of MySQL's client libs. CPAN has no way
153       to know or detect that you have upgraded MySQL.
154
155   Other systems
156       In the case of Linux or FreeBSD distributions it is very likely that
157       all you need comes with your distribution, as in the case of Red Hat
158       Linux. I just cannot give you names, as I am not using these systems.
159
160       Please let me know if you find the files in your SuSE Linux, Debian
161       Linux or FreeBSD distribution so that I can extend the above list.
162

SOURCE INSTALLATION

164       So you need to install from sources. If you are lucky, the Perl module
165       "CPAN" will do all for you, thanks to the excellent work of Andreas
166       Koenig. Otherwise you will need to do a manual installation. Some of
167       you, in particular system administrators of multiple sites, will choose
168       automatic installation. All of these installation types have an own
169       section. "CPAN installation".  "Manual installation". "Configuration".
170
171       The DBD::mysql Makefile.PL needs to know where to find your MySQL
172       installation. This may be achieved using command line switches (see
173       "Configuration") or automatically using the mysql_config binary which
174       comes with most MySQL distributions. If your MySQL distribution
175       contains mysql_config the easiest method is to ensure this binary is on
176       your path.
177
178       e.g.
179
180         PATH=$PATH:/usr/local/mysql/bin
181         export PATH
182
183   CPAN installation
184       Installation of DBD::mysql can be incredibly easy:
185
186         cpan
187         install DBD::mysql
188
189       If you are using the CPAN module for the first time, just answer the
190       questions by accepting the defaults which are fine in most cases. If
191       you are using an older version of Perl, you might instead need a
192
193         perl -MCPAN -e shell
194         install DBD::mysql
195
196       If you cannot get the CPAN module working, you might try manual
197       installation. If installation with CPAN fails because the your local
198       settings have been guessed wrong, you need to ensure MySQL's
199       mysql_config is on your path (see "SOURCE INSTALLATION") or
200       alternatively create a script called "mysql_config". This is described
201       in more details later. "Configuration".
202
203   Manual installation
204       For a manual installation you need to fetch the DBD::mysql source
205       distribution. The latest version is always available from
206
207         http://www.cpan.org/modules/by-module/DBD/
208
209       The name is typically something like
210
211         DBD-mysql-1.2216.tar.gz
212
213       The archive needs to be extracted. On Windows you may use a tool like
214       WinZip, on Unix you type
215
216         gzip -cd DBD-mysql-1.2216.tar.gz | tar xf -
217
218       This will create a subdirectory DBD-mysql-1.2216. Enter this
219       subdirectory and type
220
221         perl Makefile.PL
222         make
223         make test
224
225       (On Windows you may need to replace "make" with "nmake" or "dmake".) If
226       the tests seem to look fine, you may continue with
227
228         make install
229
230       If the compilation (make) or tests fail, you might need to configure
231       some settings.
232
233       For example you might choose a different database, the C compiler or
234       the linker might need some flags. "Configuration".  "Compiler flags".
235       "Linker flags".
236
237       For Windows/CygWin there is a special section below.  "CygWin" in
238       Windows.
239
240   Configuration
241       The install script "Makefile.PL" can be configured via a lot of
242       switches. All switches can be used on the command line. For example,
243       the test database:
244
245         perl Makefile.PL --testdb=<db>
246
247       If you do not like configuring these switches on the command line, you
248       may alternatively create a script called "mysql_config".  This is
249       described later on.
250
251       Available switches are:
252
253       testdb
254           Name of the test database, defaults to test.
255
256       testuser
257           Name of the test user, defaults to empty. If the name is empty,
258           then the currently logged in users name will be used.
259
260       testpassword
261           Password of the test user, defaults to empty.
262
263       testhost
264           Host name or IP number of the test database; defaults to localhost.
265
266       testport
267           Port number of the test database
268
269       ps-protcol=1 or 0
270           Whether to run the test suite using server prepared statements or
271           driver emulated prepared statemetns. ps-protocol=1 means use server
272           prepare, ps-protocol=0 means driver emulated.
273
274       cflags
275           This is a list of flags that you want to give to the C compiler.
276           The most important flag is the location of the MySQL header files.
277           For example, on Red Hat Linux the header files are in
278           /usr/include/mysql and you might try
279
280             -I/usr/include/mysql
281
282           On Windows the header files may be in C:\mysql\include and you
283           might try
284
285             -IC:\mysql\include
286
287           The default flags are determined by running
288
289             mysql_config --cflags
290
291           More details on the C compiler flags can be found in the following
292           section. "Compiler flags".
293
294       libs
295           This is a list of flags that you want to give to the linker or
296           loader. The most important flags are the locations and names of
297           additional libraries. For example, on Red Hat Linux your MySQL
298           client libraries are in /usr/lib/mysql and you might try
299
300             -L/usr/lib/mysql -lmysqlclient -lz
301
302           On Windows the libraries may be in C:\mysql\lib and
303
304             -LC:\mysql\lib -lmysqlclient
305
306           might be a good choice. The default flags are determined by running
307
308             mysql_config --libs
309
310           More details on the linker flags can be found in a separate
311           section.  "Linker flags".
312
313       If a switch is not present on the command line, then the script
314       "mysql_config" will be executed. This script comes as part of the MySQL
315       distribution. For example, to determine the C compiler flags, we are
316       executing
317
318         mysql_config --cflags
319         mysql_config --libs
320
321       If you want to configure your own settings for database name, database
322       user and so on, then you have to create a script with the same name,
323       that replies
324
325   Compiler flags
326       Note: the folling info about compiler and linker flags, you shouldn't
327       have to use these options because Makefile.PL is pretty good at
328       utilising mysql_config to get the flags that you need for a successful
329       compile.
330
331       It is typically not so difficult to determine the appropriate flags for
332       the C compiler. The linker flags, which you find in the next section,
333       are another story.
334
335       The determination of the C compiler flags is usually left to a
336       configuration script called mysql_config, which can be invoked with
337
338         mysql_config --cflags
339
340       When doing so, it will emit a line with suggested C compiler flags, for
341       example like this:
342
343         -L/usr/include/mysql
344
345       The C compiler must find some header files. Header files have the
346       extension ".h". MySQL header files are, for example, mysql.h and
347       mysql_version.h. In most cases the header files are not installed by
348       default. For example, on Windows it is an installation option of the
349       MySQL setup program (Custom installation), whether the header files are
350       installed or not. On Red Hat Linux, you need to install an RPM archive
351       mysql-devel or MySQL-devel.
352
353       If you know the location of the header files, then you will need to add
354       an option
355
356         -L<header directory>
357
358       to the C compiler flags, for example "-L/usr/include/mysql".
359
360   Linker flags
361       Appropriate linker flags are the most common source of problems while
362       installing DBD::mysql. I will only give a rough overview, you'll find
363       more details in the troubleshooting section.  "KNOWN PROBLEMS"
364
365       The determination of the C compiler flags is usually left to a
366       configuration script called mysql_config, which can be invoked with
367
368         mysql_config --libs
369
370       When doing so, it will emit a line with suggested C compiler flags, for
371       example like this:
372
373          -L'/usr/lib/mysql' -lmysqlclient -lnsl -lm   -lz -lcrypt
374
375       The following items typically need to be configured for the linker:
376
377       The mysqlclient library
378           The MySQL client library comes as part of the MySQL distribution.
379           Depending on your system it may be a file called
380
381             F<libmysqlclient.a>   statically linked library, Unix
382             F<libmysqlclient.so>  dynamically linked library, Unix
383             F<mysqlclient.lib>    statically linked library, Windows
384             F<mysqlclient.dll>    dynamically linked library, Windows
385
386           or something similar.
387
388           As in the case of the header files, the client library is typically
389           not installed by default. On Windows you will need to select them
390           while running the MySQL setup program (Custom installation). On Red
391           Hat Linux an RPM archive mysql-devel or MySQL-devel must be
392           installed.
393
394           The linker needs to know the location and name of the mysqlclient
395           library. This can be done by adding the flags
396
397             -L<lib directory> -lmysqlclient
398
399           or by adding the complete path name. Examples:
400
401             -L/usr/lib/mysql -lmysqlclient
402             -LC:\mysql\lib -lmysqlclient
403
404           If you would like to use the static libraries (and there are
405           excellent reasons to do so), you need to create a separate
406           directory, copy the static libraries to that place and use the -L
407           switch above to point to your new directory. For example:
408
409             mkdir /tmp/mysql-static
410             cp /usr/lib/mysql/*.a /tmp/mysql-static
411             perl Makefile.PL --libs="-L/tmp/mysql-static -lmysqlclient"
412             make
413             make test
414             make install
415             rm -rf /tmp/mysql-static
416
417       The gzip library
418           The MySQL client can use compression when talking to the MySQL
419           server, a nice feature when sending or receiving large texts over a
420           slow network.
421
422           On Unix you typically find the appropriate file name by running
423
424             ldconfig -p | grep libz
425             ldconfig -p | grep libgz
426
427           Once you know the name (libz.a or libgz.a is best), just add it to
428           the list of linker flags. If this seems to be causing problem you
429           may also try to link without gzip libraries.
430

SPECIAL SYSTEMS

432       Below you find information on particular systems:
433
434   Windows/CygWin
435       If you are a user of Cygwin (the Redhat distribution) you already know,
436       it contains a nicely running perl 5.6.1, installation of additional
437       modules usually works as a charme via the standard procedure of
438
439           perl makefile.PL
440           make
441           make test
442           make install
443
444       The Windows binary distribution of MySQL runs smoothly under Cygwin.
445       You can start/stop the server and use all Windows clients without
446       problem.  But to install DBD::mysql you have to take a little special
447       action.
448
449       Don't attempt to build DBD::mysql against either the MySQL Windows or
450       Linux/Unix BINARY distributions: neither will work!
451
452       You MUST compile the MySQL clients yourself under Cygwin, to get a
453       'libmysqlclient.a' compiled under Cygwin. Really! You'll only need that
454       library and the header files, you don't need any other client parts.
455       Continue to use the Windows binaries. And don't attempt (currently) to
456       build the MySQL Server part, it is unneccessary, as MySQL AB does an
457       excellent job to deliver optimized binaries for the mainstream
458       operating systems, and it is told, that the server compiled under
459       Cygwin is unstable.
460
461       Install MySQL (if you havn't already)
462
463       -   download the MySQL Windows Binaries from
464           http://www.mysql.com/downloads/index.html
465
466       -   unzip mysql-<version>-win.zip into some temporary location
467
468       -   start the setup.exe there and follow the instructions
469
470       -   start the server
471
472       -   alternatively download, install and start the server on a remote
473           server, on what supported OS ever
474
475       Build MySQL clients under Cygwin:
476
477       -   download the MySQL LINUX source from
478           http://www.mysql.com/downloads/index.html
479
480       -   unpack mysql-<version>.tar.gz into some tmp location
481
482       -   cd into the unpacked dir mysql-<version>
483
484             ./configure --prefix=/usr/local/mysql --without-server
485
486           This prepares the Makefile with the installed Cygwin features. It
487           takes some time, but should finish without error. The 'prefix', as
488           given, installs the whole Cygwin/MySQL thingy into a location not
489           normally in your PATH, so that you continue to use already
490           installed Windows binaries. The --without-server parameter tells
491           configure to only build the clients.
492
493       -
494             make
495
496           This builds all MySQL client parts ... be patient. It should finish
497           finally without any error.
498
499       -
500             make install
501
502           This installs the compiled client files under /usr/local/mysql/.
503           Remember, you don't need anything except the library under
504           /usr/local/mysql/lib and the headers under
505           /usr/local/mysql/include!
506
507           Essentially you are now done with this part. If you want, you may
508           try your compiled binaries shortly; for that, do:
509
510       -
511             cd /usr/local/mysql/bin
512             ./mysql -h 127.0.0.1
513
514           The host (-h) parameter 127.0.0.1 targets the local host, but
515           forces the mysql client to use a TCP/IP connection. The default
516           would be a pipe/socket connection (even if you say '-h localhost')
517           and this doesn't work between Cygwin and Windows (as far as I
518           know).
519
520           If you have your MySQL server running on some other box, then
521           please substitute '127.0.0.1' with the name or IP-number of that
522           box.
523
524       Please note, in my environment the 'mysql' client did not accept a
525       simple RETURN, I had to use CTRL-RETURN to send commands ... strange,
526       but I didn't attempt to fix that, as we are only interested in the
527       built lib and headers.
528
529       At the 'mysql>' prompt do a quick check:
530
531         mysql> use mysql
532         mysql> show tables;
533         mysql> select * from db;
534         mysql> exit
535
536       You are now ready to build DBD::mysql!
537
538       Build DBD::mysql:
539
540       -   download DBD-mysql-<version>.tar.gz from CPAN
541
542       -   unpack DBD-mysql-<version>.tar.gz
543
544       -   cd into unpacked dir DBD-mysql-<version> you probably did that
545           already, if you are reading this!
546
547       -
548             cp /usr/local/mysql/bin/mysql_config .
549
550           This copies the executable script mentioned in the DBD::mysql docs
551           from your just built Cywin/MySQL client directory; it knows about
552           your Cygwin installation, especially about the right libraries to
553           link with.
554
555       -
556             perl Makefile.PL --testhost=127.0.0.1
557
558           The --testhost=127.0.0.1 parameter again forces a TCP/IP connection
559           to the MySQL server on the local host instead of a pipe/socket
560           connection for the 'make test' phase.
561
562       -
563             make
564
565           This should run without error
566
567       -
568             make test
569
570           with DBD-mysql-2.1022 or earlier you will see several errors in
571           dbdadmin.t, mysql.t and mysql2.t; with later versions you should
572           not get errors (except possibly one, indicating, that some tables
573           could not be dropped. I'm hunting for a solution to that problem,
574           but have none yet).
575
576       -
577             make install
578
579           This installs DBD::mysql into the Perl hierarchy.
580
581       Notes:
582
583       This was tested with MySQL version 3.23.54a and DBD::mysql version
584       2.1022. I patched the above mentioned test scripts and sent the patches
585       to the author of DBD::mysql Jochen Wiedman.
586
587       Georg Rehfeld          15. Jan. 2003
588

KNOWN PROBLEMS

590       1.) Some Linux distributions don't come with a gzip library by default.
591           Running "make" terminates with an error message like
592
593             LD_RUN_PATH="/usr/lib/mysql:/lib:/usr/lib" gcc
594               -o blib/arch/auto/DBD/mysql/mysql.so  -shared
595               -L/usr/local/lib dbdimp.o mysql.o -L/usr/lib/mysql
596               -lmysqlclient -lm -L/usr/lib/gcc-lib/i386-redhat-linux/2.96
597               -lgcc -lz
598             /usr/bin/ld: cannot find -lz
599             collect2: ld returned 1 exit status
600             make: *** [blib/arch/auto/DBD/mysql/mysql.so] Error 1
601
602           If this is the case for you, install an RPM archive like libz-
603           devel, libgz-devel, zlib-devel or gzlib-devel or something similar.
604
605       2.) If Perl was compiled with gcc or egcs, but MySQL was compiled with
606           another compiler or on another system, an error message like this
607           is very likely when running "Make test":
608
609             t/00base............install_driver(mysql) failed: Can't load
610             '../blib/arch/auto/DBD/mysql/mysql.so' for module DBD::mysql:
611             ../blib/arch/auto/DBD/mysql/mysql.so: undefined symbol: _umoddi3
612             at /usr/local/perl-5.005/lib/5.005/i586-linux-thread/DynaLoader.pm
613             line 168.
614
615           This means, that your linker doesn't include libgcc.a. You have the
616           following options:
617
618           The solution is telling the linker to use libgcc. Run
619
620             gcc --print-libgcc-file
621
622           to determine the exact location of libgcc.a or for older versions
623           of gcc
624
625             gcc -v
626
627           to determine the directory. If you know the directory, add a
628
629             -L<directory> -lgcc
630
631           to the list of C compiler flags. "Configuration". "Linker flags".
632
633       3.) There are known problems with shared versions of libmysqlclient, at
634           least on some Linux boxes. If you receive an error message similar
635           to
636
637             install_driver(mysql) failed: Can't load
638             '/usr/lib/perl5/site_perl/i586-linux/auto/DBD/mysql/mysql.so'
639             for module DBD::mysql: File not found at
640             /usr/lib/perl5/i586-linux/5.00404/DynaLoader.pm line 166
641
642           then this error message can be misleading: It's not mysql.so that
643           fails being loaded, but libmysqlclient.so! The usual problem is
644           that this file is located in a directory like
645
646             /usr/lib/mysql
647
648           where the linker doesn't look for it.
649
650           The best workaround is using a statically linked mysqlclient
651           library, for example
652
653             /usr/lib/mysql/libmysqlclient.a
654
655           The use of a statically linked library is described in the previous
656           section on linker flags. "Configuration".  "Linker flags".
657
658       4.) Red Hat 8 & 9 set the Default locale to UTF which causes problems
659           with MakeMaker.  To build DBD::mysql on these systems, do a 'unset
660           LANG' before runing 'perl Makefile.PL'
661

SUPPORT

663       Finally, if everything else fails, you are not alone. First of all, for
664       an immediate answer, you should look into the archives of the mailing
665       list perl@lists.mysql.com. See http://www.mysql.com for archive
666       locations.
667
668       If you don't find an appropriate posting and reply in the mailing list,
669       please post a question. Typically a reply will be seen within one or
670       two days.
671
672
673
674perl v5.12.1                      2010-04-12            DBD::mysql::INSTALL(3)
Impressum