日期:2013-07-06  浏览次数:20546 次

作为MySQL管理员,一个普通的目标就是确保服务器尽可能地处于运转形状,使得客户机能够随时访问它。但是,有时最好关闭服务器(例如,如果正在进行数据库的重定位,不希望服务器在该数据库中更新表)。保持服务器运转和偶尔关闭它的需求关系不是本书所解
决的。但是我们至少可以讨论如何使服务器启动和停止,以便您具备进行这两个操作的能力。
    本章的说明只用于UNIX 系统。如果正在运转Windows 系统,可以跳过本章,由于附录A“获得和安装软件”一节中包含了所有需求的启动和关闭命令。
    调用本章给出的命令
    为了简约,在大多数情况中,诸如mysqla d m i n、mysqldump 等程序在本章中没有给出任何- h、- u或- p选项。笔者假定您将会用连接服务器所需的任何选项调用这些程序。

用无特权的用户账号运转MySQL服务器

    在讨论如何启动服务器之前,考虑一下在服务器启动时应该运转哪个账号。服务器可以手工和自动启动。如果手工启动,则服务器以UNIX 用户身份运转(您恰好作为该用户进行了注册)。即,如果笔者以paul 进行注册并启动服务器,则它将以paul 身份运转。如果用s u命令将用户切换到root 然后启动服务器,则服务器以root 身份运转。
    但是,大多数时候可能都不会采用手工启动服务器。您很可能将安排服务器在系统引导时作为标准启动过程的一部分自动地运转。在UNIX中,该启动过程由系统以UNIX 的r o o t用户的身份执行,该过程中启动的任何进程都用root 的权限运转。
    应该紧记MySQL服务器启动过程的两个目标:
    要服务器以某些非root 的用户身份启动。通常,除非进程真的需求root 访问权而mysql办不到,否则应限制任何进程的能力。
    要服务器一直以同一个用户的身份运转。服务器有时作为一个用户运转而有时又作为另一个用户运转时会产生矛盾。这将导致文件和目录以不同的所有权在该数据下被创建,甚至惹起服务器不能访问数据库或表。以同一个用户的身份分歧地运转服务器可以避免该问题。
    为了以标准的、非特权的用户身份运转数据库,可按如下步骤执行该过程:
    1) 选择用于运转服务器的账号。mysqld 可以以任何用户身份运转,但是很明显,它只为MySQL活动创建了一个单独的账号。您也可以为MySQL专门指定一个组。笔者将调用的这些用户和组的名字命名为mysqladm 和mysqlg r p。如果您使用了其他的名字,则在本书中有mysqladm 和mysqlgrp 的地方替换它们
    如果您在本人的账号下安装了MySQL并且系统中没有特定的管理权限,则您可以在本人的ID 用户下运转服务器。在这种情况下,应使用您本人的注册名和组名替代mysqladm 和mysqlgrp 。
    如果您利用RPM 文件在RedHat Linux 下安装了MySQL,则该安装程序将在mysql名下自动创建了一个账号。应使用该名字替换mysqladm 。
    2) 如果必要的话,可用系统常用的账号创建过程( a c count - c r e a t i o n)来创建服务器账号。这需求以root 身份进行操作。
    3) 关闭服务器(如果它在运转)。
    4) 修正数据目录以及任何子目录和文件的所有权,使mysqladm 用户拥有它们。例如,如果数据目录是/ us r / l o c a l / v a r,则可按以下设置mysqladm 用户的所有权:
    # cd /usr/local/var 挪动到数据目录
    # chown -r mysqladmin.mysqlgrp 设置所有目录和文件的所有权
    5) 修正数据目录以及任何子目录和文件的答应权,使得只要mysqladm 用户能够访问它们。设置该方式以避免其他人员访问是一种好得安全预防措施。如果数据目录是/ us r / l o c a l / v a r,则可通过mysqladm 用户按下列操作设置应具有的一切(您需求以root 身份运转这些命令):
    # cd /usr/local/var 挪动到数据目录
    # chmod -R go -rwx 使所有一切只对mysqladm 可访问
    在设置数据目录及其内容的所有权和方式时,观察符号连接。您需求跟踪符号连接并修正所指向的文件或目录的所有权和方式。如果这些连接文件所定位的目录不属于您,则这样做可能会惹起麻烦,因此您必须是root 用户。
    在完成前述过程后,应确保无论是作为mysqladm 还是作为root 用户注册都一直启动服务器。在后者中,要确保指定了--user = mysqladm 的选项,使服务器可以将其用户ID 切换到mysqla d m(该选项在系统启动过程中也可使用)。
    --user 选项被添加到MySQL3.22 的mysql中。如果您的版本比MySQL3.22 旧,则在启动服务器并作为root 用户运转时,可以使用su命令指示系统在指定账号下运转服务器。您需求阅读有关su的人工页,由于作为一个指定用户运转命令的语法被改变了。

启动服务器的方法

    如果您曾经确定了用来运转服务器的账号,则可以选择安排怎样启动服务器。可以从命令行手工运转,或在系统启动过程中自动运转服务器。有三种启动服务器的次要方法:
    直接调用mysqld。这或许是最小的命令方法。除了说明mysqld --help 是一个有用的命令(用它可以查找您可利用其他启动方法使用的选项)外,笔者不打算进一步讨论它。
    调用safe_mysqld 脚本。safe_mysqld 试图确定服务器程序和数据目录的位置,然后利用反映这些位置的选项调用服务器。safe_mysqld 将服务器的标准错误输出重定向到数据目录的错误文件中,并以记录的方式出现。在启动服务器后, safe_mysqld 还监控
服务器,并在其死机时重新启动。safe_mysqld 通常用于UNIX 的BSD 风格的版本。
    如果您曾经作为root 或在系统启动程序中启动s a f e _ mysqld,则错误日志将由r o o t拥