source: archive/mysql.xml@ 66966b2

10.0 10.1 11.0 11.1 11.2 11.3 12.0 12.1 8.3 8.4 9.0 9.1 basic bdubbs/svn elogind kea ken/TL2024 ken/inkscape-core-mods ken/tuningfonts lazarus lxqt perl-modules plabs/newcss plabs/python-mods python3.11 qt5new rahul/power-profiles-daemon renodr/vulkan-addition trunk upgradedb xry111/intltool xry111/llvm18 xry111/soup3 xry111/test-20220226 xry111/xf86-video-removal
Last change on this file since 66966b2 was 5e0662d, checked in by Bruce Dubbs <bdubbs@…>, 10 years ago

Updated to mariadb-10.0.10.
Archived mysql.

git-svn-id: svn://svn.linuxfromscratch.org/BLFS/trunk/BOOK@12960 af4574ff-66df-0310-9fd7-8a98e5e911e0

  • Property mode set to 100644
File size: 15.4 KB
Line 
1<?xml version="1.0" encoding="ISO-8859-1"?>
2<!DOCTYPE sect1 PUBLIC "-//OASIS//DTD DocBook XML V4.5//EN"
3 "http://www.oasis-open.org/docbook/xml/4.5/docbookx.dtd" [
4 <!ENTITY % general-entities SYSTEM "../../general.ent">
5 %general-entities;
6
7 <!ENTITY mysql-download-http "http://cdn.mysql.com/Downloads/MySQL-5.6/mysql-&mysql-version;.tar.gz">
8 <!ENTITY mysql-download-ftp " ">
9 <!ENTITY mysql-md5sum "1d3d91e8459c719bbef7c97bb499634d">
10 <!ENTITY mysql-size "32 MB">
11 <!ENTITY mysql-buildsize "572 MB (additional 359 MB installed)">
12 <!ENTITY mysql-time "6.3 SBU">
13]>
14
15<sect1 id="mysql" xreflabel="MySQL-&mysql-version;">
16 <?dbhtml filename="mysql.html"?>
17
18 <sect1info>
19 <othername>$LastChangedBy$</othername>
20 <date>$Date$</date>
21 </sect1info>
22
23 <title>MySQL-&mysql-version;</title>
24
25 <indexterm zone="mysql">
26 <primary sortas="a-MySQL">MySQL</primary>
27 </indexterm>
28
29 <sect2 role="package">
30 <title>Introduction to MySQL</title>
31
32 <para>
33 <application>MySQL</application> is a widely used and fast SQL database
34 server. It is a client/server implementation that consists of a
35 server daemon and many different client programs and libraries.
36 </para>
37
38 &lfs75_checked;
39
40 <bridgehead renderas="sect3">Package Information</bridgehead>
41 <itemizedlist spacing="compact">
42 <listitem>
43 <para>
44 Download (HTTP): <ulink url="&mysql-download-http;"/>
45 </para>
46 </listitem>
47 <listitem>
48 <para>
49 Download (FTP): <ulink url="&mysql-download-ftp;"/>
50 </para>
51 </listitem>
52 <listitem>
53 <para>
54 Download MD5 sum: &mysql-md5sum;
55 </para>
56 </listitem>
57 <listitem>
58 <para>
59 Download size: &mysql-size;
60 </para>
61 </listitem>
62 <listitem>
63 <para>
64 Estimated disk space required: &mysql-buildsize;
65 </para>
66 </listitem>
67 <listitem>
68 <para>
69 Estimated build time: &mysql-time;
70 </para>
71 </listitem>
72 </itemizedlist>
73
74 <bridgehead renderas="sect3">Additional Downloads</bridgehead>
75 <itemizedlist spacing="compact">
76 <listitem>
77 <para>
78 Optional patch (recommended if building for Amarok):
79 <ulink url="&patch-root;/mysql-&mysql-version;-embedded_library_shared-1.patch"/>
80 </para>
81 </listitem>
82 <listitem>
83 <para>
84 Optional Documentation (see tip below):
85 <ulink url="http://dev.mysql.com/doc/"/>
86 </para>
87 </listitem>
88 </itemizedlist>
89
90 <bridgehead renderas="sect3">MySQL Dependencies</bridgehead>
91
92 <bridgehead renderas="sect4">Required</bridgehead>
93 <para role="required">
94 <xref linkend="cmake"/>
95 </para>
96
97 <bridgehead renderas="sect4">Recommended</bridgehead>
98 <para role="recommended">
99 <xref linkend="libevent"/> and
100 <xref linkend="openssl"/>
101 </para>
102
103 <bridgehead renderas="sect4">Optional</bridgehead>
104 <para role="optional">
105 <ulink url="http://packages.debian.org/source/sid/libaio">libaio</ulink> and
106 <ulink url="http://www.thrysoee.dk/editline/">libedit</ulink>
107 </para>
108
109 <para condition="html" role="usernotes">User Notes:
110 <ulink url="&blfs-wiki;/mysql"/>
111 </para>
112 </sect2>
113
114 <sect2 role="installation">
115 <title>Installation of MySQL</title>
116
117 <para>
118 For security reasons, running the server as an unprivileged user
119 and group is strongly encouraged. Issue the following (as
120 <systemitem class="username">root</systemitem>) to create the
121 user and group:
122 </para>
123
124<screen role="root"><userinput>groupadd -g 40 mysql &amp;&amp;
125useradd -c "MySQL Server" -d /srv/mysql -g mysql -s /bin/false -u 40 mysql</userinput></screen>
126
127 <para>
128 If the MySQL server is not needed, it is possible to build only the
129 client libraries of MySQL. To do this you need to add
130 <parameter>-DWITHOUT_SERVER=ON</parameter> to the <command>cmake</command>
131 command below.
132 </para>
133
134 <para>
135 MySQL contains an embedded server library. By default, it is built as a
136 statically linked library, <filename>libmysqld.a</filename>, but by
137 applying the optional patch, a shared version of this library can be built.
138 The library is needed by certain applications, such as
139 <application>Amarok</application> and it is recommend to use the shared
140 libraries whenever it is possible.
141 </para>
142
143 <para>
144 There are numerous options available to
145 <command>cmake</command>. Check the output of the `<command>cmake .
146 -LH</command>` for additional customization options. See the <ulink
147 url="http://dev.mysql.com/doc/refman/5.6/en/source-configuration-options.html">
148 MySQL Documentation</ulink> for a full listing of all options.
149 </para>
150
151 <para>
152 If you want to build shared version of the embedded server library, apply
153 the following patch:
154 </para>
155
156<screen><userinput>patch -Np1 -i ../mysql-&mysql-version;-embedded_library_shared-1.patch</userinput></screen>
157
158 <para>
159 Install <application>MySQL</application> by running the
160 following commands:
161 </para>
162
163<screen><userinput>sed -i "/ADD_SUBDIRECTORY(sql\/share)/d" CMakeLists.txt &amp;&amp;
164sed -i "s/ADD_SUBDIRECTORY(libmysql)/&amp;\\nADD_SUBDIRECTORY(sql\/share)/" CMakeLists.txt &amp;&amp;
165sed -i "s@data/test@\${INSTALL_MYSQLSHAREDIR}@g" sql/CMakeLists.txt &amp;&amp;
166sed -i "s@data/mysql@\${INSTALL_MYSQLTESTDIR}@g" sql/CMakeLists.txt &amp;&amp;
167
168sed -i "s/srv_buf_size/srv_sort_buf_size/" storage/innobase/row/row0log.cc &amp;&amp;
169
170mkdir build &amp;&amp;
171cd build &amp;&amp;
172
173cmake -DCMAKE_BUILD_TYPE=Release \
174 -DCMAKE_INSTALL_PREFIX=/usr \
175 -DINSTALL_DOCDIR=share/doc/mysql \
176 -DINSTALL_DOCREADMEDIR=share/doc/mysql \
177 -DINSTALL_INCLUDEDIR=include/mysql \
178 -DINSTALL_INFODIR=share/info \
179 -DINSTALL_MANDIR=share/man \
180 -DINSTALL_MYSQLDATADIR=/srv/mysql \
181 -DINSTALL_MYSQLSHAREDIR=share/mysql \
182 -DINSTALL_MYSQLTESTDIR=share/mysql/test \
183 -DINSTALL_PLUGINDIR=lib/mysql/plugin \
184 -DINSTALL_SBINDIR=sbin \
185 -DINSTALL_SCRIPTDIR=bin \
186 -DINSTALL_SQLBENCHDIR=share/mysql/bench \
187 -DINSTALL_SUPPORTFILESDIR=share/mysql \
188 -DMYSQL_DATADIR=/srv/mysql \
189 -DMYSQL_UNIX_ADDR=/run/mysqld/mysqld.sock \
190 -DSYSCONFDIR=/etc/mysql \
191 -DWITH_PERFSCHEMA_STORAGE_ENGINE=OFF \
192 -DWITH_EXTRA_CHARSETS=complex \
193 -DWITH_LIBEVENT=system \
194 -DWITH_SSL=system \
195 .. &amp;&amp;
196make</userinput></screen>
197
198 <para>
199 To test the results, issue: <command>make test</command>.
200 </para>
201
202 <para>
203 Now, as the <systemitem class="username">root</systemitem> user:
204 </para>
205
206<screen role="root"><userinput>make install</userinput></screen>
207
208 <tip>
209 <para>
210 The only documentation shipped in the source tarball are
211 <filename>mysql.info</filename> and man pages. You can download
212 various formats of the <application>MySQL</application>
213 Reference Manual from <ulink url="http://dev.mysql.com/doc/"/>.
214 </para>
215 </tip>
216
217 </sect2>
218
219 <sect2 role="commands">
220 <title>Command Explanations</title>
221
222 <para>
223 <command>sed -i ...</command>: First two seds fix client-only builds.
224 Following two seds set correct installation directories for some
225 components. Last one fixes a bug in the code.
226 </para>
227
228 <para>
229 <parameter>-DWITHOUT_SERVER=ON</parameter>: Use this switch if you don't
230 want the server and would like to build the client only.
231 </para>
232
233 <para>
234 <parameter>-DWITH_EXTRA_CHARSETS=complex</parameter>: This switch enables
235 support for the complex character sets.
236 </para>
237
238 <para>
239 <parameter>-DWITH_LIBEVENT=system</parameter>: This switch is used to
240 tell the build system to use installed <application>libevent</application>.
241 Remove it if you didn't install <application>libevent</application>.
242 </para>
243
244 <para>
245 <parameter>-DWITH_SSL=system</parameter>: This switch is used to tell the
246 build system to use installed <application>OpenSSL</application>. Remove
247 it if you didn't install <application>OpenSSL</application>.
248 </para>
249
250 </sect2>
251
252 <sect2 role="configuration">
253 <title>Configuring MySQL</title>
254
255 <sect3 id="mysql-config">
256 <title>Config Files</title>
257
258 <para>
259 <filename>/etc/mysql/my.cnf</filename> and
260 <filename>~/.my.cnf</filename>
261 </para>
262
263 <indexterm zone="mysql mysql-config">
264 <primary sortas="e-AA.my.cnf">~/.my.cnf</primary>
265 </indexterm>
266
267 <indexterm zone="mysql mysql-config">
268 <primary sortas="e-etc-mysql-my.cnf">/etc/mysql/my.cnf</primary>
269 </indexterm>
270
271 </sect3>
272
273 <sect3>
274 <title>Configuration Information</title>
275
276 <note>
277 <para>
278 If you are upgrading from previous major version of
279 <application>MySQL</application>, be sure to consult
280 the <ulink
281 url="https://dev.mysql.com/doc/refman/5.6/en/upgrading-from-previous-series.html">
282 MySQL Reference Manual</ulink> for notes on
283 upgrading the software.
284 </para>
285 </note>
286
287 <para>
288 Create basic <filename>/etc/mysql/my.cnf</filename>
289 using the following command as the <systemitem
290 class="username">root</systemitem> user:
291 </para>
292
293<screen role="root"><userinput>install -v -dm 755 /etc/mysql &amp;&amp;
294cat &gt; /etc/mysql/my.cnf &lt;&lt; "EOF"
295<literal># Begin /etc/mysql/my.cnf
296
297# The following options will be passed to all MySQL clients
298[client]
299#password = your_password
300port = 3306
301socket = /run/mysqld/mysqld.sock
302
303# The MySQL server
304[mysqld]
305port = 3306
306socket = /run/mysqld/mysqld.sock
307datadir = /srv/mysql
308skip-external-locking
309key_buffer_size = 16M
310max_allowed_packet = 1M
311sort_buffer_size = 512K
312net_buffer_length = 16K
313myisam_sort_buffer_size = 8M
314
315# Don't listen on a TCP/IP port at all.
316skip-networking
317
318# required unique id between 1 and 2^32 - 1
319server-id = 1
320
321# Uncomment the following if you are using BDB tables
322#bdb_cache_size = 4M
323#bdb_max_lock = 10000
324
325# Uncomment the following if you are using InnoDB tables
326#innodb_data_home_dir = /srv/mysql
327#innodb_data_file_path = ibdata1:10M:autoextend
328#innodb_log_group_home_dir = /srv/mysql
329# You can set .._buffer_pool_size up to 50 - 80 %
330# of RAM but beware of setting memory usage too high
331#innodb_buffer_pool_size = 16M
332#innodb_additional_mem_pool_size = 2M
333# Set .._log_file_size to 25 % of buffer pool size
334#innodb_log_file_size = 5M
335#innodb_log_buffer_size = 8M
336#innodb_flush_log_at_trx_commit = 1
337#innodb_lock_wait_timeout = 50
338
339[mysqldump]
340quick
341max_allowed_packet = 16M
342
343[mysql]
344no-auto-rehash
345# Remove the next comment character if you are not familiar with SQL
346#safe-updates
347
348[isamchk]
349key_buffer = 20M
350sort_buffer_size = 20M
351read_buffer = 2M
352write_buffer = 2M
353
354[myisamchk]
355key_buffer_size = 20M
356sort_buffer_size = 20M
357read_buffer = 2M
358write_buffer = 2M
359
360[mysqlhotcopy]
361interactive-timeout
362
363# End /etc/mysql/my.cnf</literal>
364EOF</userinput></screen>
365
366 <para>
367 You can now install a database and change the ownership to the
368 unprivileged user and group (perform as the <systemitem
369 class="username">root</systemitem> user):
370 </para>
371
372<screen role="root"><userinput>mysql_install_db --basedir=/usr --datadir=/srv/mysql --user=mysql &amp;&amp;
373chown -R mysql:mysql /srv/mysql</userinput></screen>
374
375 <para>
376 Further configuration requires that the
377 <application>MySQL</application> server is running. Start
378 the server using the following commands as the <systemitem
379 class="username">root</systemitem> user:
380 </para>
381
382<screen role="root"><userinput>install -v -m755 -o mysql -g mysql -d /run/mysqld &amp;&amp;
383mysqld_safe --user=mysql 2&gt;&amp;1 &gt;/dev/null &amp;</userinput></screen>
384
385 <para>
386 A default installation does not set up a password for the
387 administrator, so use the following command as the <systemitem
388 class="username">root</systemitem> user to set one. Replace
389 <replaceable>&lt;new-password&gt;</replaceable> with your own.
390 </para>
391
392<screen role="root"><userinput>mysqladmin -u root password <replaceable>&lt;new-password&gt;</replaceable></userinput></screen>
393
394 <para>
395 Configuration of the server is now finished. Shut the server
396 down using the following command as the <systemitem
397 class="username">root</systemitem> user:
398 </para>
399
400<screen role="root"><userinput>mysqladmin -p shutdown</userinput></screen>
401
402 </sect3>
403
404 <sect3 id="mysql-init">
405 <title>Boot Script</title>
406
407 <para>
408 Install the <filename>/etc/rc.d/init.d/mysql</filename> init script
409 included in the <xref linkend="bootscripts"/> package as
410 the <systemitem class="username">root</systemitem> user to start the
411 <application>MySQL</application> server during system boot-up.
412 </para>
413
414 <indexterm zone="mysql mysql-init">
415 <primary sortas="f-mysql">mysql</primary>
416 </indexterm>
417
418<screen role="root"><userinput>make install-mysql</userinput></screen>
419
420 </sect3>
421
422 </sect2>
423
424 <sect2 role="content">
425 <title>Contents</title>
426
427 <segmentedlist>
428 <segtitle>Installed Programs</segtitle>
429 <segtitle>Installed Libraries</segtitle>
430 <segtitle>Installed Directories</segtitle>
431
432 <seglistitem>
433 <seg>
434 innochecksum, msql2mysql, myisamchk, myisam_ftdump, myisamlog,
435 myisampack, my_print_defaults, mysql, mysqlaccess, mysqlaccess.conf,
436 mysqladmin, mysqlbinlog, mysqlbug, mysqlcheck, mysql_client_test,
437 mysql_client_test_embedded, mysql_config, mysql_config_editor,
438 mysql_convert_table_format, mysqld, mysqld_multi, mysqld_safe, mysqldump,
439 mysqldumpslow, mysql_embedded, mysql_find_rows, mysql_fix_extensions,
440 mysqlhotcopy, mysqlimport, mysql_install_db, mysql_plugin,
441 mysql_secure_installation, mysql_setpermission, mysqlshow, mysqlslap,
442 mysqltest, mysqltest_embedded, mysql_tzinfo_to_sql, mysql_upgrade,
443 mysql_waitpid, mysql_zap, perror, replace, resolveip and
444 resolve_stack_dump
445 </seg>
446 <seg>
447 libmysqlclient.{so,a}, libmysqlclient_r.{so,a}, libmysqld.{so,a},
448 libmysqlservices.a and several under /usr/lib/mysql/plugin/
449 </seg>
450 <seg>
451 /etc/mysql,
452 /srv/mysql,
453 /usr/include/mysql,
454 /usr/lib/mysql,
455 /usr/share/doc/mysql and
456 /usr/share/mysql
457 </seg>
458 </seglistitem>
459 </segmentedlist>
460
461 <bridgehead renderas="sect3">Short Descriptions</bridgehead>
462
463 <para>
464 Descriptions of all the programs and libraries would be several
465 pages long. Instead, consult the <filename>mysql.info</filename>
466 documentation or the on-line reference manual at <ulink
467 url="http://dev.mysql.com/doc/refman/5.6/en/index.html"/>.
468 </para>
469
470 <para>
471 The <application>Perl</application> DBI modules must be installed
472 for some of the <application>MySQL</application> support programs to
473 function properly.
474 </para>
475
476 </sect2>
477
478</sect1>
Note: See TracBrowser for help on using the repository browser.