|
NAMEDBD::MariaDB::INSTALL - How to install and configure DBD::MariaDBSYNOPSISperl Makefile.PL [options] make make test make install DESCRIPTIONThis document describes the installation and configuration of DBD::MariaDB, the Perl DBI driver for the MariaDB and MySQL database. Before reading on, make sure that you have the prerequisites available: Perl, MariaDB/MySQL and DBI. For details see the separate section "PREREQUISITES".Finally, if you encounter any problems, do not forget to read the section on known problems "KNOWN PROBLEMS". If that doesn't help, you should check the section on "SUPPORT". PREREQUISITES
SOURCE INSTALLATIONSo you need to install from sources? If you are lucky, the Perl module "CPAN" will do all for you, thanks to the excellent work of Andreas König. Otherwise you will need to do a manual installation. All of these installation types have their own section: "CPAN installation", "Manual installation" and "Configuration".The DBD::MariaDB "Makefile.PL" needs to know where to find your MySQL installation. This may be achieved using command line switches (see "Configuration") or automatically using the "mariadb_config" or "mysql_config" binary which comes with most MariaDB and MySQL distributions. If your MariaDB or MySQL distribution contains "mariadb_config" or "mysql_config" the easiest method is to ensure this binary is on your path. Typically, this is the case if you've installed the mysql library from your systems' package manager. e.g. PATH=$PATH:/usr/local/mysql/bin export PATH As stated, to compile DBD::MariaDB you'll need a C compiler. This should be the same compiler as the one used to build perl AND the MariaDB or MySQL client libraries. If you're on linux, this is most typically the case and you need not worry. If you're on UNIX systems, you might want to pay attention. Also you'll need to get the MariaDB or MySQL client and development headers on your system. The easiest is to get these from your package manager. To run the tests that ship with the module, you'll need access to a running MariaDB or MySQL server. This can be running on localhost, but it can also be on a remote machine. You can use any server version which is greater or equal to 4.1.0. It does not have to be same as version of client library. Also you can use MariaDB client library and MySQL server or vice-versa. On Fedora the process is as follows. In this example we install and start a local server for running the tests against. yum -y install make gcc mariadb-devel mariadb-libs mariadb-server yum -y install "perl(Test::Deep)" "perl(Test::More)" systemctl start mariadb.service Environment VariablesFor ease of use, you can set environment variables for DBD::MariaDB installation. You can set any or all of the options, and export them by putting them in your .bashrc or the like:export DBD_MARIADB_CFLAGS=-I/usr/local/mysql/include/mysql export DBD_MARIADB_LIBS="-L/usr/local/mysql/lib/mysql -lmysqlclient" export DBD_MARIADB_CONFIG=mysql_config export DBD_MARIADB_TESTDB=test export DBD_MARIADB_TESTHOST=127.0.0.1 export DBD_MARIADB_TESTPORT=3306 export DBD_MARIADB_TESTSOCKET=/var/run/mysqld/mysqld.sock export DBD_MARIADB_TESTUSER=me export DBD_MARIADB_TESTPASSWORD=s3kr1+ The most useful may be the host, database, port, socket, user, and password. Installation will first look to your "mariadb_config", your "mysql_config", and then your environment variables, and then it will guess with intelligent defaults. CPAN installationInstallation of DBD::MariaDB can be incredibly easy:cpan DBD::MariaDB Please note that this will only work if the prerequisites are fulfilled, which means you have a C-compiler installed, and you have the development headers and mariadb or mysql client libraries available on your system. If you are using the CPAN module for the first time, just answer the questions by accepting the defaults which are fine in most cases. If you cannot get the CPAN module working, you might try manual installation. If installation with CPAN fails because your local settings have been guessed wrong, you need to ensure MariaDB's "mariadb_config" or MySQL's "mysql_config" is on your path (see "SOURCE INSTALLATION") or alternatively create a script called "mysql_config". This is described in more details later. "Configuration". Manual installationFor a manual installation you need to fetch the DBD::MariaDB source distribution. The latest version is always available from <https://metacpan.org/release/DBD-MariaDB>.The name is typically something like DBD-MariaDB-<version>.tar.gz The archive needs to be extracted. On Windows you may use a tool like 7-zip, on *nix you type tar xf DBD-MariaDB-<version>.tar.gz This will create a subdirectory DBD-MariaDB-<version>. Enter this subdirectory and type perl Makefile.PL make make test On Windows you may need to replace "make" with "dmake", "gmake" or "nmake". If the tests seem to look fine, you may continue with make install If the compilation (make) or tests fail, you might need to configure some settings. For example you might choose a different database, the C compiler or the linker might need some flags. "Configuration". "Compiler flags". "Linker flags". For Cygwin there is a special section below. "Cygwin". ConfigurationThe install script "Makefile.PL" can be configured via a lot of switches. All switches can be used on the command line. For example, the test database:perl Makefile.PL --testdb=<db> If you do not like configuring these switches on the command line, you may alternatively create a script called "mariadb_config" or "mysql_config". This is described later on. Available switches are:
If a switch is not present on the command line, then the script "mariadb_config" or "mysql_config" will be executed. This script comes as part of the MariaDB or MySQL distribution. For example, to determine the C compiler flags, we are executing mysql_config --cflags mysql_config --libs If you want to configure your own settings for cflags or libs, then you have to create a script with same name that provides needed details. Compiler flagsNote: the following info about compiler and linker flags, you shouldn't have to use these options because "Makefile.PL" is pretty good at utilizing "mariadb_config" and "mysql_config" to get the flags that you need for a successful compile.It is typically not so difficult to determine the appropriate flags for the C compiler. The linker flags, which you find in the next section, are another story. The determination of the C compiler flags is usually left to a configuration script called "mysql_config", which can be invoked with mysql_config --cflags When doing so, it will emit a line with suggested C compiler flags, for example like this: -L/usr/include/mysql The C compiler must find some header files. Header files have the extension .h. MySQL header files are, for example, mysql.h and mysql_version.h. In most cases the header files are not installed by default. For example, on Windows it is an installation option of the MySQL setup program (Custom installation), whether the header files are installed or not. On Red Hat Linux, you need to install an RPM archive "mariadb-devel", "mariadb-embedded-devel", "mysql-devel" or "mysql-embedded-devel". If you know the location of the header files, then you will need to add an option -L<header directory> to the C compiler flags, for example "-L/usr/include/mysql". Linker flagsAppropriate linker flags are the most common source of problems while installing DBD::MariaDB. I will only give a rough overview, you'll find more details in the troubleshooting section. "KNOWN PROBLEMS"The determination of the C compiler flags is usually left to a configuration script called "mysql_config", which can be invoked with mysql_config --libs When doing so, it will emit a line with suggested C compiler flags, for example like this: -L'/usr/lib/mysql' -lmysqlclient -lnsl -lm -lz -lcrypt The following items typically need to be configured for the linker:
MARIADB NATIVE CLIENT INSTALLATIONThe MariaDB native client is another option for connecting to a MySQL database licensed LGPL 2.1. To build DBD::MariaDB against this client, you will first need to build the client. Generally, this is done with the following:cd path/to/src/mariadb-native-client cmake -G "Unix Makefiles' make sudo make install Once the client is built and installed, you can build DBD::MariaDB against it: perl Makefile.PL --testuser=xxx --testpassword=xxx \ --testsocket=/path/to/mysqld.sock \ --mariadb_config=/usr/local/bin/mariadb_config make make test make install SPECIAL SYSTEMSBelow you find information on particular systems:macOSFor installing DBD::MariaDB you need to have the libssl header files and the mysql client libs. The easiest way to install these is using Homebrew (<https://brew.sh/>).Once you have Homebrew set up, you can simply install the dependencies using brew install openssl mysql-connector-c Then you can install DBD::MariaDB using your cpan client. CygwinIf you are a user of Cygwin you already know, it contains a nicely running perl 5.6.1, installation of additional modules usually works like a charm via the standard procedure ofperl makefile.PL make make test make install The Windows binary distribution of MySQL runs smoothly under Cygwin. You can start/stop the server and use all Windows clients without problem. But to install DBD::MariaDB you have to take a little special action. Don't attempt to build DBD::MariaDB against either the MySQL Windows or Linux/Unix distributions: neither will work! You MUST compile the MySQL clients yourself under Cygwin, to get a libmysqlclient.a compiled under Cygwin. Really! You'll only need that library and the header files, you don't need any other client parts. Continue to use the Windows binaries. And don't attempt (currently) to build the MySQL Server part, it is unnecessary, as MySQL AB does an excellent job to deliver optimized binaries for the mainstream operating systems, and it is told, that the server compiled under Cygwin is unstable. Install a MySQL server for testing against. You can install the regular Windows MySQL server package on your Windows machine, or you can also test against a MySQL server on a remote host. Build MySQL clients under Cygwin: Download the MySQL LINUX source from <https://www.mysql.com/downloads>, unpack mysql-<version>.tar.gz into some tmp location and from this directory run configure: ./configure --prefix=/usr/local/mysql --without-server This prepares the Makefile with the installed Cygwin features. It takes some time, but should finish without error. The "--prefix", as given, installs the whole Cygwin/MySQL thingy into a location not normally in your PATH, so that you continue to use already installed Windows binaries. The "--without-server" parameter tells configure to only build the clients. make This builds all MySQL client parts ... be patient. It should finish finally without any error. make install This installs the compiled client files under /usr/local/mysql/. Remember, you don't need anything except the library under /usr/local/mysql/lib and the headers under /usr/local/mysql/include! Essentially you are now done with this part. If you want, you may try your compiled binaries shortly; for that, do: cd /usr/local/mysql/bin ./mysql -h 127.0.0.1 The host ("-h") parameter 127.0.0.1 targets the local host, but forces the mysql client to use a TCP/IP connection. The default would be a pipe/socket connection (even if you say "-h localhost") and this doesn't work between Cygwin and Windows (as far as I know). If you have your MySQL server running on some other box, then please substitute 127.0.0.1 with the name or IP-number of that box. Please note, in my environment the "mysql" client did not accept a simple RETURN, I had to use CTRL-RETURN to send commands ... strange, but I didn't attempt to fix that, as we are only interested in the built lib and headers. At the "mysql>" prompt do a quick check: mysql> use mysql mysql> show tables; mysql> select * from db; mysql> exit You are now ready to build DBD::MariaDB! compile DBD::MariaDB Download and extract DBD-MariaDB-<version>.tar.gz from CPAN, "cd" into unpacked dir DBD-MariaDB-<version> you probably did that already, if you are reading this! cp /usr/local/mysql/bin/mysql_config . This copies the executable script mentioned in the DBD::MariaDB docs from your just built Cywin/MySQL client directory; it knows about your Cygwin installation, especially about the right libraries to link with. perl Makefile.PL --testhost=127.0.0.1 The "--testhost=127.0.0.1" parameter again forces a TCP/IP connection to the MySQL server on the local host instead of a pipe/socket connection for the "make test" phase. make This should run without error make test make install This installs DBD::MariaDB into the Perl hierarchy. KNOWN PROBLEMSno gzip on your systemSome Linux distributions don't come with a gzip library by default. Running "make" terminates with an error message likeLD_RUN_PATH="/usr/lib/mysql:/lib:/usr/lib" gcc -o blib/arch/auto/DBD/mysql/mysql.so -shared -L/usr/local/lib dbdimp.o mysql.o -L/usr/lib/mysql -lmysqlclient -lm -L/usr/lib/gcc-lib/i386-redhat-linux/2.96 -lgcc -lz /usr/bin/ld: cannot find -lz collect2: ld returned 1 exit status make: *** [blib/arch/auto/DBD/mysql/mysql.so] Error 1 If this is the case for you, install an RPM archive like "libz-devel", "libgz-devel", "zlib-devel" or "gzlib-devel" or something similar. different compiler for mysql and perlIf Perl was compiled with gcc or egcs, but MySQL was compiled with another compiler or on another system, an error message like this is very likely when running "make test":t/00base............install_driver(mysql) failed: Can't load '../blib/arch/auto/DBD/mysql/mysql.so' for module DBD::MariaDB: ../blib/arch/auto/DBD/mysql/mysql.so: undefined symbol: _umoddi3 at /usr/local/perl-5.005/lib/5.005/i586-linux-thread/DynaLoader.pm line 168. This means, that your linker doesn't include libgcc.a. You have the following options: The solution is telling the linker to use "libgcc". Run gcc --print-libgcc-file to determine the exact location of libgcc.a or for older versions of gcc gcc -v to determine the directory. If you know the directory, add a -L<directory> -lgcc to the list of C compiler flags. "Configuration". "Linker flags". SUPPORTFinally, if everything else fails, you are not alone. First of all, for an immediate answer, you should look into the archives of the dbi-users mailing list, which is available at Perl DBI Users' Forum <https://groups.google.com/forum/#!forum/perl.dbi.users>.To subscribe to this list, send and email to "dbi-users-subscribe@perl.org" <mailto:dbi-users-subscribe@perl.org>. If you don't find an appropriate posting and reply in the mailing list, please post a question. Typically a reply will be seen within one or two days.
Visit the GSP FreeBSD Man Page Interface. |