Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
M
mariadb
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Kirill Smelkov
mariadb
Commits
166c15a9
Commit
166c15a9
authored
Sep 05, 2000
by
jcole@tetra.bedford.progress.com
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
manual.texi:
Latest grammatical and spelling corrections. Amended/corrected install instructions.
parent
6355860b
Changes
2
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
116 additions
and
43 deletions
+116
-43
BitKeeper/etc/logging_ok
BitKeeper/etc/logging_ok
+1
-0
Docs/manual.texi
Docs/manual.texi
+115
-43
No files found.
BitKeeper/etc/logging_ok
View file @
166c15a9
...
...
@@ -16,3 +16,4 @@ tonu@work.mysql.com
monty@donna.mysql.com
jcole@tetra.spaceapes.com
jcole@ham.spaceapes.com
jcole@tetra.bedford.progress.com
Docs/manual.texi
View file @
166c15a9
...
...
@@ -1116,16 +1116,11 @@ Work against software patents
@end menu
This manual is currently available in Texinfo, plain text, Info, HTML,
PostScript and PDF versions. Because of their size, PostScript and PDF
versions are not included with the main @strong{MySQL} distribution, but
are available for separate download at
@uref{http://www.mysql.com/}.
The primary document is the Texinfo file. The HTML version is produced
automatically using a modified version of @code{texi2html}. The plain
text and Info versions are produced with @code{makeinfo}. The Postscript
version is produced using @code{texi2dvi} and @code{dvips}. The PDF
version is produced with @code{pdftex}.
PostScript and PDF versions. The primary document is the Texinfo file.
The HTML version is produced automatically using a modified version of
@code{texi2html}. The plain text and Info versions are produced with
@code{makeinfo}. The Postscript version is produced using @code{texi2dvi}
and @code{dvips}. The PDF version is produced with @code{pdftex}.
This manual is written and maintained by David Axmark, Michael (Monty)
Widenius, Jeremy Cole, and Paul DuBois. For other contributors,
...
...
@@ -1566,8 +1561,8 @@ can be used to determine how the optimizer resolves a query.
@node Stability, Year 2000 compliance, Features, Introduction
@section How stable is MySQL?
This section addresses the questions
,
``How stable is
@strong{MySQL}?''
and,
``Can I depend on @strong{MySQL} in this project?''
This section addresses the questions ``How stable is
@strong{MySQL}?''
, and
``Can I depend on @strong{MySQL} in this project?''
We will try to clarify some issues and to answer some of the more
important questions that seem to concern many people. This section has been
put together from information gathered from the mailing list (which is very
...
...
@@ -2485,7 +2480,7 @@ version of @strong{MySQL} before posting! Anyone should be able to repeat the
bug by just using 'mysql test < script' on the included test case or run
the shell / perl script that is included in the bug report. All bugs
posted on this list will be corrected or documented in the next @strong{MySQL}
release! If there are only small code changes involved
,
to correct this
release! If there are only small code changes involved to correct this
problem, we will also post a patch that fixes the problem.
Remember that it is possible to respond to a message containing too much
...
...
@@ -2628,7 +2623,7 @@ sorry. After all, it should be easier for you to provide an example that
uses your actual situation and it is by all means better for us. In case you
have data you don't want to show to others, you can use @code{ftp} to
transfer it to @uref{ftp://support.mysql.com/pub/mysql/secret/}. If the data
are
really top secret and you don't want to show them even to us, then go ahead
is
really top secret and you don't want to show them even to us, then go ahead
and provide an example using other names, but please regard this as the last
choice.
...
...
@@ -2883,7 +2878,7 @@ programs in the @file{client} directory is GPL. Each file has a header
that shows which copyright is used for that file.
@item The client library and the (GNU @code{getopt}) library are covered
by the ``GNU LIBRARY GENERAL PUBLIC LICENSE''.
by the ``GNU LIBRARY GENERAL PUBLIC LICENSE''.
@xref{LGPL license}.
@item Some parts of the source (the @code{regexp} library) are covered
by a Berkeley-style copyright.
...
...
@@ -2926,7 +2921,7 @@ license. See the documentation for that version for more information.
This section describes some situations illustrating whether or not you
must license the @strong{MySQL} server. Generally these examples
involve providing @strong{MySQL} as an integra
ted
part of a product.
involve providing @strong{MySQL} as an integra
l
part of a product.
Note that a single @strong{MySQL} license covers any number of CPUs and
@code{mysqld} servers on a machine! There is no artificial limit on the number
...
...
@@ -2945,23 +2940,27 @@ are several cases to consider:
@item
Does your application require @strong{MySQL} to function properly?
@item
If your product requires @strong{MySQL}, you need a license for any
machine that runs the @code{mysqld} server. For example, if you've
designed your application around @strong{MySQL}, then you've really made
a commercial product that requires the engine, so you need a license.
@item
If your application does not require @strong{MySQL}, you need not obtain
a license. For example, if using @strong{MySQL} just adds some new optional
features to your product (such as adding logging to a database if
@strong{MySQL} is used rather than logging to a text file), it should
fall within normal use, and a license would not be required.
@item
In other words, you need a license if you sell a product designed
specifically for use with @strong{MySQL} or that requires the
@strong{MySQL} server to function at all. This is true whether or not
you provide @strong{MySQL} for your client as part of your product
distribution.
@item
It also depends on what you're doing for the client. Do you plan to
provide your client with detailed instructions on installing
@strong{MySQL} with your software? Then your product may be contingent
...
...
@@ -2984,7 +2983,7 @@ they have some problem with their @strong{MySQL} installation, their ISP
will be able to solve the problem for them (in some cases with the help
from the @strong{MySQL} development team).
All ISPs that want
s to keep themself up to
date should subscribe
All ISPs that want
to keep themselves up-to-
date should subscribe
to our announce mailing list so that they can be aware of fatal issues
that may be relevant for their @code{MySQL} installations.
...
...
@@ -3249,7 +3248,7 @@ extended email support you have already helped the further development
of @strong{MySQL}.
@item
Typical
ques
tions that are covered by extended email support are:
Typical
situa
tions that are covered by extended email support are:
@itemize @minus
@item
...
...
@@ -3271,8 +3270,8 @@ We will provide hints on optimizing @code{mysqld} for your situation.
@item
You are allowed to influence the priority of items on the @strong{MySQL}
TODO
. This will ensure that the features you really need will be implement
ed
sooner than they might be otherwise.
TODO
List. @xref{TODO}. This will ensure that the features you really ne
ed
will be implemented
sooner than they might be otherwise.
@end itemize
@node Login support, Extended login support, Extended email support, Support
...
...
@@ -3342,7 +3341,7 @@ to be able to create a binary distribution.
If you can provide accommodations and pay for traveler fares, you can even
get a @strong{MySQL} developer to visit you and offer you help with your
troubles. Extended login support entitles you to one personal
encounter per year, but we are a
s a
lways very flexible towards our customers!
encounter per year, but we are always very flexible towards our customers!
@end itemize
@node Installing, Compatibility, Licensing and Support, Top
...
...
@@ -4304,11 +4303,16 @@ The basic commands you must execute to install and use a @strong{MySQL}
binary distribution are:
@example
shell> gunzip < mysql-VERSION-OS.tar.gz | tar xvf -
shell> groupadd mysql
shell> useradd -g mysql mysql
shell> cd /usr/local
shell> gunzip < /path/to/mysql-VERSION-OS.tar.gz | tar xvf -
shell> ln -s mysql-VERSION-OS mysql
shell> cd mysql
shell> scripts/mysql_install_db
shell> bin/safe_mysqld &
shell> chown -R mysql /usr/local/mysql
shell> chgrp -R mysql /usr/local/mysql
shell> bin/safe_mysqld --user=mysql &
@end example
You can add new users using the @code{bin/mysql_setpermission} script if
...
...
@@ -4338,11 +4342,31 @@ archives and have names like @file{mysql-VERSION-OS.tar.gz}, where
the type of operating system for which the distribution is intended (e.g.,
@code{pc-linux-gnu-i586}).
@item
Add a user and group for @code{mysqld} to run as:
@example
shell> groupadd mysql
shell> useradd -g mysql mysql
@end example
These commands add the @code{mysql} group, and the @code{mysql} user. The
syntax for @code{useradd} and @code{groupadd} may differ slightly on different
Unixes. They may also be called @code{adduser} and @code{addgroup}. You may
wish to call the user and group something else instead of @code{mysql}.
@item
Change into the intended installation directory:
@example
shell> cd /usr/local
@end example
@item
Unpack the distribution and create the installation directory:
@example
shell> gunzip < mysql-VERSION-OS.tar.gz | tar xvf -
shell> gunzip <
/path/to/
mysql-VERSION-OS.tar.gz | tar xvf -
shell> ln -s mysql-VERSION-OS mysql
@end example
...
...
@@ -4387,7 +4411,7 @@ $MYSQL = '/usr/local/bin/mysql'; # path to mysql executable
@end example
Change the path to reflect the location where @code{mysql} actually is
stored on your system. If you do not do this, you will get a @code{
b
roken
stored on your system. If you do not do this, you will get a @code{
B
roken
pipe} error when you run @code{mysqlaccess}.
@item
...
...
@@ -4401,6 +4425,19 @@ Note that @strong{MySQL} versions older than 3.22.10 started the
@strong{MySQL} server when you run @code{mysql_install_db}. This is no
longer true!
@item
Change ownership of the installation directory to the user which you will
run @code{mysqld} as:
@example
shell> chown -R mysql /usr/local/mysql
shell> chgrp -R mysql /usr/local/mysql
@end example
The first command changes the @code{owner} attribute of the files to the
@code{mysql} user, and the second changes the @code{group} attribute to
the @code{mysql} group.
@item
If you want to install support for the Perl @code{DBI}/@code{DBD} interface,
see @ref{Perl support}.
...
...
@@ -4420,7 +4457,7 @@ and test your distribution.
You can start the @strong{MySQL} server with the following command:
@example
shell> bin/safe_mysqld &
shell> bin/safe_mysqld
--user=mysql
&
@end example
@xref{Post-installation}.
...
...
@@ -4436,8 +4473,9 @@ file. The @strong{MySQL} RPMs are currently being built on a RedHat 5.2
system but should work on other versions of Linux that support @code{rpm} and
use @code{glibc}.
If you have problems with an RPM file, for example @code{Sorry, the host
'xxxx' could not be looked up}, see @ref{Binary notes-Linux}.
If you have problems with an RPM file, for example, if you receive the error
``@code{Sorry, the host 'xxxx' could not be looked up}'', see
@ref{Binary notes-Linux}.
The RPM files you may want to use are:
...
...
@@ -4445,7 +4483,7 @@ The RPM files you may want to use are:
@item @code{MySQL-VERSION.i386.rpm}
The @strong{MySQL} server. You will need this unless you only want to
connect to a
nother
@strong{MySQL} server running on another machine.
connect to a @strong{MySQL} server running on another machine.
@item @code{MySQL-client-VERSION.i386.rpm}
...
...
@@ -4726,14 +4764,20 @@ reports}.
@subsection Quick installation overview
The basic commands you must execute to install a @strong{MySQL} source
distribution are
(from an unpacked @code{tar} file)
:
distribution are:
@example
shell> configure
shell> groupadd mysql
shell> useradd -g mysql mysql
shell> gunzip < mysql-VERSION.tar.gz | tar -xvf -
shell> cd mysql-VERSION
shell> ./configure --prefix=/usr/local/mysql
shell> make
shell> make install
shell> scripts/mysql_install_db
shell> /usr/local/mysql/bin/safe_mysqld &
shell> chown -R mysql /usr/local/mysql
shell> chgrp -R mysql /usr/local/mysql
shell> /usr/local/mysql/bin/safe_mysqld --user=mysql &
@end example
If you start from a source RPM, then do the following.
...
...
@@ -4765,25 +4809,42 @@ Obtain a distribution file from one of the sites listed in
archives and have names like @file{mysql-VERSION.tar.gz}, where
@code{VERSION} is a number like @value{mysql_version}.
@item
Add a user and group for @code{mysqld} to run as:
@example
shell> groupadd mysql
shell> useradd -g mysql mysql
@end example
These commands add the @code{mysql} group, and the @code{mysql} user. The
syntax for @code{useradd} and @code{groupadd} may differ slightly on different
Unixes. They may also be called @code{adduser} and @code{addgroup}. You may
wish to call the user and group something else instead of @code{mysql}.
@item
Unpack the distribution into the current directory:
@example
shell> gunzip < mysql-VERSION.tar.gz | tar xvf -
shell> gunzip <
/path/to/
mysql-VERSION.tar.gz | tar xvf -
@end example
This command creates a directory named @file{mysql-VERSION}.
@item
Change into the top-level directory of the unpacked distribution:
@example
shell> cd mysql-VERSION
@end example
@item
Configure the release and compile everything:
@example
shell> ./configure --prefix=/usr/local/mysql
shell> make
@end example
When you run @code{configure}, you might want to specify some options.
Run @code{./configure --help} for a list of options.
@ref{configure options, , @code{configure} options}, discusses some of the
...
...
@@ -4801,14 +4862,17 @@ a number of common problems.
@item
Install everything:
@example
shell> make install
@end example
You might need to run this command as @code{root}.
@item
Create the @strong{MySQL} grant tables (necessary only if you haven't
installed @strong{MySQL} before):
@example
shell> scripts/mysql_install_db
@end example
...
...
@@ -4817,6 +4881,19 @@ Note that @strong{MySQL} versions older than 3.22.10 started the
@strong{MySQL} server when you run @code{mysql_install_db}. This is no
longer true!
@item
Change ownership of the installation to the user which you will run
@code{mysqld} as:
@example
shell> chown -R mysql /usr/local/mysql
shell> chgrp -R mysql /usr/local/mysql
@end example
The first command changes the @code{owner} attribute of the files to the
@code{mysql} user, and the second changes the @code{group} attribute to
the @code{mysql} group.
@item
If you want to install support for the Perl @code{DBI}/@code{DBD} interface,
see @ref{Perl support}.
...
...
@@ -4832,12 +4909,8 @@ start}.
After everything has been installed, you should initialize and test your
distribution.
You can start the @strong{MySQL} server with the following command,
where @code{BINDIR} is the directory in which @code{safe_mysqld} is
installed (@file{/usr/local/bin} by default):
@example
shell>
BINDIR/safe_mysqld
&
shell>
/usr/local/mysql/bin/safe_mysqld --user=mysql
&
@end example
If that command fails immediately with @code{mysqld daemon ended} then you can
...
...
@@ -7725,7 +7798,6 @@ for installation from a source distribution:
@example
shell> ./scripts/mysql_install_db
shell> cd mysql_installation_directory
* Command-line options:: Command-line options
shell> ./bin/safe_mysqld &
@end example
...
...
@@ -8116,7 +8188,7 @@ shell> tail host_name.err
shell> tail host_name.log
@end example
If you find
in the log file something like: the following
:
If you find
something like the following in the log file
:
@example
000729 14:50:10 bdb: Recovery function for LSN 1 27595 failed
000729 14:50:10 bdb: warning: ./test/t1.db: No such file or directory
...
...
@@ -9616,7 +9688,7 @@ shell> replace " #" " --" -- text-file-with-funny-comments.sql
@node Standards, Commit-rollback, Missing functions, Compatibility
@section What standards does MySQL follow?
Entry level SQL92. ODBC level 0-2.
Entry level SQL92. ODBC level
s
0-2.
@node Commit-rollback, , Standards, Compatibility
@section How to cope without @code{COMMIT}/@code{ROLLBACK}
...
...
@@ -9777,7 +9849,7 @@ system. This section describes how it works.
Anyone using @strong{MySQL} on a computer connected to the Internet
should read this section to avoid the most common security mistakes.
In discussing ``security'' we emphasize the necessity of fully protecting the
In discussing ``security''
,
we emphasize the necessity of fully protecting the
entire server host (not simply the @strong{MySQL} server) against all types
of applicable attacks: eavesdropping, altering, playback and Denial of
Service. We do not cover all aspects of availability and fault tolerance
...
...
@@ -9795,7 +9867,7 @@ When running @strong{MySQL}, follow these guidelines whenever possible:
@itemize @bullet
@item
DON'T EVER GIVE ANYONE (EXCEPT THE @strong{MySQL} ROOT USER) ACCESS TO THE
mysql.user
DATABAS
E! The encrypted password is the real password in
mysql.user
TABL
E! The encrypted password is the real password in
@strong{MySQL}; If you know this for one user you can easily login as
him if you have access to his 'host'.
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment