glfs/server/databases/mysql.xml
Krejzi 9697f0f25b Remove unused python modules, clean up python modules page, tag remaining modules as 72checked and tag remaining kde4 packages as 72checked.
git-svn-id: svn://svn.linuxfromscratch.org/BLFS/trunk/BOOK@10798 af4574ff-66df-0310-9fd7-8a98e5e911e0
2012-10-26 10:46:42 +00:00

371 lines
15 KiB
XML

<?xml version="1.0" encoding="ISO-8859-1"?>
<!DOCTYPE sect1 PUBLIC "-//OASIS//DTD DocBook XML V4.5//EN"
"http://www.oasis-open.org/docbook/xml/4.5/docbookx.dtd" [
<!ENTITY % general-entities SYSTEM "../../general.ent">
%general-entities;
<!ENTITY mysql-download-http "http://cdn.mysql.com/Downloads/MySQL-5.5/mysql-&mysql-version;.tar.gz">
<!ENTITY mysql-download-ftp " ">
<!ENTITY mysql-md5sum "da8ddb3d00e6e159153d2444360f52a8">
<!ENTITY mysql-size "24 MB">
<!ENTITY mysql-buildsize "932 MB (additional 170 MB to run the test suite)">
<!ENTITY mysql-time "4.0 SBU (Test suite is an additional 45 minutes, only partially CPU dependent)">
]>
<sect1 id="mysql" xreflabel="MySQL-&mysql-version;">
<?dbhtml filename="mysql.html"?>
<sect1info>
<othername>$LastChangedBy$</othername>
<date>$Date$</date>
</sect1info>
<title>MySQL-&mysql-version;</title>
<indexterm zone="mysql">
<primary sortas="a-MySQL">MySQL</primary>
</indexterm>
<sect2 role="package">
<title>Introduction to MySQL</title>
<para><application>MySQL</application> is a widely used and fast SQL
database server. It is a client/server implementation that consists of a
server daemon and many different client programs and libraries.</para>
&lfs72_checked;
<bridgehead renderas="sect3">Package Information</bridgehead>
<itemizedlist spacing="compact">
<listitem>
<para>Download (HTTP): <ulink url="&mysql-download-http;"/></para>
</listitem>
<listitem>
<para>Download (FTP): <ulink url="&mysql-download-ftp;"/></para>
</listitem>
<listitem>
<para>Download MD5 sum: &mysql-md5sum;</para>
</listitem>
<listitem>
<para>Download size: &mysql-size;</para>
</listitem>
<listitem>
<para>Estimated disk space required: &mysql-buildsize;</para>
</listitem>
<listitem>
<para>Estimated build time: &mysql-time;</para>
</listitem>
</itemizedlist>
<bridgehead renderas="sect3">Additional Downloads</bridgehead>
<itemizedlist spacing="compact">
<listitem>
<para>Optional patch (required if building for Amarok): <ulink
url="&patch-root;/mysql-&mysql-version;-embedded_library_shared-1.patch"/></para>
</listitem>
<listitem>
<para>Optional patch (required if building only the client): <ulink
url="&patch-root;/mysql-&mysql-version;-fix_client_only-1.patch"/></para>
</listitem>
<listitem>
<para>Optional Documentation (see tip below):
<ulink url="http://dev.mysql.com/doc/"/>
</para>
</listitem>
</itemizedlist>
<bridgehead renderas="sect3">MySQL Dependencies</bridgehead>
<bridgehead renderas="sect4">Required</bridgehead>
<para role="optional"><xref linkend="cmake"/></para>
<bridgehead renderas="sect4">Recommended</bridgehead>
<para role="optional"><xref linkend="openssl"/></para>
<bridgehead renderas="sect4">Optional</bridgehead>
<para role="optional">
<ulink url="http://packages.debian.org/source/sid/libaio">libaio</ulink>
</para>
<para condition="html" role="usernotes">User Notes:
<ulink url="&blfs-wiki;/mysql"/></para>
</sect2>
<sect2 role="installation">
<title>Installation of MySQL</title>
<sect3>
<title>Building</title>
<para>For security reasons, running the server as an unprivileged user
and group is strongly encouraged. Issue the following (as
<systemitem class="username">root</systemitem>) to create the user and
group:</para>
<screen role="root"><userinput>groupadd -g 40 mysql &amp;&amp;
useradd -c "MySQL Server" -d /dev/null -g mysql -s /bin/false -u 40 mysql</userinput></screen>
<para>If the MySQL server is not needed, it is possible to build only the
client libraries of MySQL. To do this you need to apply the optional patch,
use the cmake option <parameter>-DWITHOUT_SERVER=ON</parameter> and the
client-only installation instructions below.</para>
<para>MySQL contains an embedded server library which can be enabled with
the cmake option <parameter>-DWITH_EMBEDDED_SERVER=ON</parameter>. By default
this server is built as a statically linked library,
<filename>libmysqld.a</filename>, but by applying the optional patch, a
shared version of this library can be built. The shared library is needed
by certain applications, such as <application>Amarok</application>.</para>
<para>There are numerous options available to
<userinput>cmake</userinput>. Check the output of the `<userinput>cmake .
-LH</userinput>` for additional customization options. See the <ulink
url="http://dev.mysql.com/doc/refman/5.5/en/source-configuration-options.html">MySQL
Documentation</ulink> for a full listing of all options.</para>
<para>If you want the shared version of the embedded server library, apply
the patch:</para>
<screen><userinput>patch -Np1 -i ../mysql-&mysql-version;-embedded_library_shared-1.patch</userinput></screen>
<para>If building the client-only, apply the patch:</para>
<screen><userinput>patch -Np1 -i ../mysql-&mysql-version;-fix_client_only-1.patch</userinput></screen>
<para>Configure and build <application>MySQL</application> by
running the following commands:</para>
<screen><userinput>mkdir build &amp;&amp;
cd build &amp;&amp;
cmake -DCMAKE_INSTALL_PREFIX=/usr \
-DINSTALL_DOCDIR=share/doc/mysql \
-DINSTALL_DOCREADMEDIR=share/doc/mysql \
-DINSTALL_INCLUDEDIR=include/mysql \
-DINSTALL_INFODIR=share/info \
-DINSTALL_MANDIR=share/man \
-DINSTALL_MYSQLDATADIR=/srv/mysql \
-DINSTALL_MYSQLSHAREDIR=share/mysql \
-DINSTALL_MYSQLTESTDIR=share/mysql/test \
-DINSTALL_PLUGINDIR=lib/mysql \
-DINSTALL_SBINDIR=sbin \
-DINSTALL_SCRIPTDIR=bin \
-DINSTALL_SQLBENCHDIR=share/mysql/bench \
-DINSTALL_SUPPORTFILESDIR=share/mysql/support \
-DMYSQL_DATADIR=/srv/mysql \
-DMYSQL_UNIX_ADDR=/var/run/mysql/mysql.sock \
-DSYSCONFDIR=/etc \
-DWITH_PARTITION_STORAGE_ENGINE=OFF \
-DWITH_PERFSCHEMA_STORAGE_ENGINE=OFF \
-DWITH_READLINE=system \
-DWITH_SSL=system \
.. &amp;&amp;
make</userinput></screen>
<para>To test the results, issue: <command>make test-force 2>&amp;1 | tee
test.log</command>. This forces the test to run to completion and logs all
the test output. There will be many tests that are not run due to
configuration options and developer considerations. Note that if you use
TCP Wrappers and have a restrictive <filename>/etc/hosts.deny</filename>
file, you will need to add an appropriate entry to the
<filename>/etc/hosts.allow</filename> file for the
<command>mysqld</command> daemon. Otherwise many of the tests will
fail. Also, two tests will fail if ipv6 is not available in the kernel
either as a module or built in.</para>
<note><para>The SSL tests may fail due to expired certificates.</para></note>
</sect3>
<sect3>
<title>Installation (server and client)</title>
<para>To install the server and client, issue the following command (as
the <systemitem class="username">root</systemitem> user):</para>
<screen role="root"><userinput>SEGMENTS="Client Server IniFiles ManPages SharedLibraries"
SEGMENTS="$SEGMENTS Development Documentation Info Readme"
for segment in $SEGMENTS; do
cmake -DCMAKE_INSTALL_COMPONENT=$segment -P cmake_install.cmake
done
unset SEGMENTS</userinput></screen>
<note><para>If you built the embedded server library add
<userinput>Embedded</userinput> to the <userinput>SEGMENTS</userinput>
variable above.</para></note>
<tip><para>The only documentation shipped in the source tarball are
<filename>mysql.info</filename> and man pages. You can download various
formats of the <application>MySQL</application> Reference Manual
from <ulink url="http://dev.mysql.com/doc/"/>.</para></tip>
</sect3>
<sect3>
<title>Installation (client only)</title>
<para>If you would like to install the client software only, issue the
following (as <systemitem class="username">root</systemitem>):</para>
<screen role="root"><userinput>SEGMENTS="Client ManPages SharedLibraries"
SEGMENTS="$SEGMENTS Development Documentation Info Readme"
for segment in $SEGMENTS; do
cmake -DCMAKE_INSTALL_COMPONENT=$segment -P cmake_install.cmake
done
unset SEGMENTS</userinput></screen>
</sect3>
</sect2>
<sect2 role="commands">
<title>Command Explanations</title>
<para><parameter>-DWITH_&lt;engine&gt;_STORAGE_ENGINE=ON</parameter>: The default
instructions only build the innobase (InnoDB) storage engine. If other
storage engines are desired use this switch to enable them. Valid choices
are ARCHIVE, BLACKHOLE, EXAMPLE, FEDERATED, INNOBASE, NDBCLUSTER,
PARTITION and PERFSCHEMA.</para>
<para><parameter>-DWITHOUT_SERVER=ON</parameter>: Use this switch if you don't
want the server and would like to build the client only.</para>
<para><parameter>-DWITH_EMBEDDED_SERVER=ON</parameter>: Use this switch to build
the embedded server library.</para>
<para><parameter>-DWITH_SSL=system</parameter>: Use this switch to build
against a system version of SSL.</para>
<para><command>cmake -DCMAKE_INSTALL_COMPONENT=$segment ...</command>: This
command installs the appropriate portion of the package. Different
segments may be added or deleted as desired. Valid segments are listed
with `<command>make list_install_components</command>`.
Note that the 'DataFiles' install segment does not honor the
-DMYSQL_DATADIR or -DINSTALL_MYSQLDATADIR statements and installs datafiles
in <filename class="directory">/usr/data</filename>.</para>
</sect2>
<sect2 role="configuration">
<title>Configuring MySQL</title>
<sect3 id="mysql-config">
<title>Config Files</title>
<para><filename>/etc/my.cnf</filename> and
<filename>~/.my.cnf</filename></para>
<indexterm zone="mysql mysql-config">
<primary sortas="e-AA.my.cnf">~/.my.cnf</primary>
</indexterm>
<indexterm zone="mysql mysql-config">
<primary sortas="e-etc-my.cnf">/etc/my.cnf</primary>
</indexterm>
</sect3>
<sect3>
<title>Configuration Information</title>
<para>There are several default configuration files available in
<filename class="directory">/usr/share/mysql</filename> which you can
use. When creating the file, ensure binary logs are disabled unless you
are doing database replication. Create <filename>/etc/my.cnf</filename>
using the following commands as the <systemitem
class="username">root</systemitem> user:</para>
<screen role="root"><userinput>install -v -m644 /usr/share/mysql/support/my-medium.cnf /etc/my.cnf
sed -i 's/^log-bin/#log-bin/' /etc/my.cnf</userinput></screen>
<para>You can now install a database and change the ownership to the
unprivileged user and group (perform as the <systemitem
class="username">root</systemitem> user):</para>
<screen role="root"><userinput>mysql_install_db --basedir=/usr --datadir=/srv/mysql --user=mysql &amp;&amp;
chgrp -v mysql /srv/mysql{,/test,/mysql}</userinput></screen>
<para>Further configuration requires that the
<application>MySQL</application> server is running. Start
the server using the following commands as the <systemitem
class="username">root</systemitem> user:</para>
<screen role="root"><userinput>install -v -m755 -o mysql -g mysql -d /var/run/mysql &amp;&amp;
mysqld_safe --user=mysql 2&gt;&amp;1 &gt;/dev/null &amp;</userinput></screen>
<para>A default installation does not set up a password for the
administrator, so use the following command as the <systemitem
class="username">root</systemitem> user to set one. Replace
<replaceable>&lt;new-password&gt;</replaceable> with your own.</para>
<screen role="root"><userinput>mysqladmin -u root password <replaceable>&lt;new-password&gt;</replaceable></userinput></screen>
<para>Configuration of the server is now finished. Shut the server
down using the following command as the <systemitem
class="username">root</systemitem> user:</para>
<screen role="root"><userinput>mysqladmin -p shutdown</userinput></screen>
</sect3>
<sect3 id="mysql-init">
<title>Boot Script</title>
<para>Install the <filename>/etc/rc.d/init.d/mysql</filename> init script
included in the <xref linkend="bootscripts"/> package as
the <systemitem class="username">root</systemitem> user to start the
<application>MySQL</application> server during system boot-up.</para>
<indexterm zone="mysql mysql-init">
<primary sortas="f-mysql">mysql</primary>
</indexterm>
<screen role="root"><userinput>make install-mysql</userinput></screen>
</sect3>
</sect2>
<sect2 role="content">
<title>Contents</title>
<segmentedlist>
<segtitle>Installed Programs</segtitle>
<segtitle>Installed Libraries</segtitle>
<segtitle>Installed Directories</segtitle>
<seglistitem>
<seg>innochecksum, msql2mysql, my_print_defaults, myisam_ftdump,
myisamchk, myisamlog, myisampack, mysql, mysql_client_test,
mysql_config, mysql_convert_table_format, mysql_find_rows,
mysql_fix_extensions, mysql_install_db, mysql_plugin,
mysql_secure_installation, mysql_setpermission, mysql_tzinfo_to_sql,
mysql_upgrade, mysql_waitpid, mysql_zap, mysqlaccess, mysqladmin,
mysqlbinlog, mysqlbug, mysqlcheck, mysqld, mysqld_multi, mysqld_safe,
mysqldump, mysqldumpslow, mysqlhotcopy, mysqlimport, mysqlshow,
mysqlslap, mysqltest, perror, replace, resolve_stack_dump and
resolveip</seg>
<seg>libmysqlclient.{so,a}, libmysqlclient_r.{so,a}, libmysqlservices.a
and several in /usr/lib/mysql</seg>
<seg>/srv/mysql, /usr/include/mysql, /usr/lib/mysql, /usr/share/mysql and
/var/run/mysql</seg>
</seglistitem>
</segmentedlist>
<bridgehead renderas="sect3">Short Descriptions</bridgehead>
<para>Descriptions of all the programs and libraries would be several
pages long. Instead, consult the <filename>mysql.info</filename>
documentation or the on-line reference manual at <ulink
url="http://dev.mysql.com/doc/refman/5.5/en/index.html"/>.</para>
<para>The <application>Perl</application> DBI modules must be installed
for some of the <application>MySQL</application> support programs to
function properly.</para>
</sect2>
</sect1>