⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 manual_common_problems.html

📁 这是一部完整的MYSQL中文参考手册,里面详尽的介绍了MYSQL的使用方法.
💻 HTML
字号:
<html>

<head>
<title>MySQL中文参考手册- 19 用MySQL解决一些常见问题</title>
<style type="text/css">
<!--
.p14{font-size:14.8px;font-family:宋体;line-height:14pt;}
.p5{ border: 1px solid rgb(146,201,201) }
.a:hover{color:red;}
a.t1:visited{color:red;}
-->
</style>
</head>

<body bgColor="#ffffff" link="#101090" text="#000000" vLink="#7030b0" class="p4">

<h1><img src="Img/mysql-logo.gif" alt="mysql-logo.gif (3082 bytes)" WIDTH="127" HEIGHT="60"><font color="#FF0000">MySQL中文参考手册</font></h1>

<p>翻译:<a href="mailto:clyan@sohu.com">晏子</a>(yanzi) 
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 主页:<a href="http://linuxdn.yeah.net">http://linuxdb.yeah.net</a></p>

<hr>

<p><a href="manual_Introduction.html">第一章</a>, <a href="manual_Problems.html">前一章</a>, 
<a href="manual_Clients.html">下一章</a>, <a href="manual_Concept_Index.html">最后一章</a>,<a href="manual_toc.html">目录</a>. </p>

<hr>

<h1><a href="manual_toc.html#Common_problems" name="Common_problems">19 用MySQL解决一些常见问题</a></h1>

<p><a name="IDX705"></a> </p>

<h2><a href="manual_toc.html#Replication" name="Replication">19.1 数据库复制</a></h2>

<p>一方面复制可以用来增加健壮性和速度。对健壮性,你有2个系统,而如果你出了问题,切换到备份即可。额外的速度通过把非更新查询的一部分送到复制服务器来达到。当然,这只在非更新查询为主时有用,但是这正是一般的情形。</p>

<p>一方面复制计划在不久的未来实现。这将被实现,使得从服务器将以较低优先级的更新和延迟插入被同步到最新数据(这将给读者以比写者更高的优先级)。 
</p>

<p><strong>MySQL</strong>(至今)没有数据库复制,但是有一些如何实现的信息。</p>

<p>复制一个数据库最一般的方法是使用更新日志。见<a href="manual_Server.html#Update_log">9.2 更新日志</a>。这要求充当一个主数据库(进行数据改变的)并且另一个或多个充当从数据库。要更新一个从数据库,只要运行<code>mysql 
&lt; update_log</code>。提供对于从数据库适当的主机、用户和口令选项,并且将主数据库的更新日志作为输入。</p>

<p>如果你从未从一张表中删除任何东西,你可以使用一个<code>TIMESTAMP</code>列找出自上一次复制以来(通过比较作你上次做复制的时间)表中哪个行被插入和被改变,且仅拷贝这些行到镜像中。</p>

<p>有可能使用更新日志(对删除)和时间戳记(在两端)做成一个双向更新系统统,但是在这种情况下,当同一数据在两端被改变时,你必须能处理冲突。你可能想保持旧版本以帮助决定什么被更新了。</p>

<p>因为在这种情况中复制用SQL语句进行,你不应该在更新数据库的语句中使用下列函数;他们不能返回与原数据库相同的值: 

<ul>
  <li><code>DATABASE()</code> </li>
  <li><code>GET_LOCK()</code>和<code>RELEASE_LOCK()</code> </li>
  <li><code>RAND()</code> </li>
  <li><code>USER()</code>, <code>SYSTEM_USER()</code>或<code>SESSION_USER()</code> </li>
  <li><code>VERSION()</code> </li>
</ul>

<p>所有的时间函数可安全地使用,比如如果需要,时间戳记被送到镜像。<code>LAST_INSERT_ID()</code>也可安全地使用。</p>

<p><a name="IDX708"></a></p>

<h2><a href="manual_toc.html#Backup" name="Backup">19.2 数据库备份</a></h2>

<p>因为<strong>MySQL</strong>表作为文件存储,做一个备份是容易的。为了得到一个一致的备份,在相关的表上做一个<code>LOCK 
TABLES</code>。见<a href="manual_Reference.html#LOCK_TABLES">7.24<code> LOCK 
TABLES/UNLOCK TABLES</code>句法</a>。你只需一个读锁定;当你在数据库目录中做文件的一个拷贝时,这允许其他线程继续查询该表。如果你想要做一个SQL级的备份,你可以<code>SELECT 
INTO OUTFILE</code>。</p>

<p>备份一个数据库的另一个方法是使用<code>mysqldump</code>程序: 

<ol>
  <li>为你的数据库做一个完整的备份:<pre>shell&gt; mysqldump --tab=/path/to/some/dir --opt --full
</pre>
    <p>你也可以简单地拷贝所有的表文件(<tt>“*.frm”、“*.MYD”</tt>和<tt>“*.MYI”</tt>文件),只要服务器不在更新任何东西。</p>
  </li>
  <li><a name="IDX709"></a>停止<code>mysqld</code>如果它正在运行,然后以<code>--log-update</code>选项启动它。你将得到一个<tt>名为“<kbd>hostname</kbd>.n”</tt>形式的日志文件, 
    这里<code>n</code>是随着你每次执行<code>mysqladmin refresh</code>或<code>mysqladmin 
    flush-logs</code>、<code>FLUSH LOGS</code>语句、或重启服务器而递增的一个数字。这些日志文件向你提供了在你执行<code>mysqldump</code>处后面进行的复制数据库改变的所需信息。</li>
</ol>

<p>如果你必须恢复一些东西,尝试首先用<code>myisamchk -r</code>恢复你的表。这应该处理所有情况的99.9%。如果<code>myisamchk</code>失败,尝试下列过程: 

<ol>
  <li>恢复原来的<code>mysqldump</code>备份。</li>
  <li>执行下列命令以再次运行更新日志中的更改: <pre>shell&gt; ls -1 -t -r hostname.[0-9]* | xargs cat | mysql
</pre>
  </li>
</ol>

<p><code>ls</code>被用来以正确的顺序得到所有的日志文件。 </p>

<p>你也可以与<code>SELECT * INTO OUTFILE 'file_name' FROM tbl_name</code>做有选择的备份并且用<code>LOAD 
DATA INFILE 'file_name' REPLACE ...</code>恢复。为了避免重复记录,在表中你需要一个<code>PRIMARY 
KEY</code>或<code>UNIQUE</code>键。当在唯一键值上一个新记录与一个老记录重复时,<code>REPLACE</code>关键词使得老记录用一个新记录替代。</p>

<p><a name="IDX710"></a></p>

<h2><a href="manual_toc.html#Multiple_servers" name="Multiple_servers">19.3 
在同一台机器上运行多个MySQL服务器</a></h2>

<p>有些情况下你可能想要在同一台机器上运行多个服务器。例如,你可能想要测试一个新的<strong>MySQL</strong>版本而让你现有生产系统的设置不受到干扰,或你可能是想要为不同的客户提供独立的<strong>MySQL</strong>安装一个因特网服务供应商。</p>

<p>如果你想要运行多个服务器,最容易的方法是用不同的TCP/IP端口和套接字文件重新编译服务器,因此他们不是侦听同一个TCP/IP端口或套接字。 
</p>

<p>假设一个现存服务器配置为缺省端口号和套接字文件,那么用一个这样的<code>configure</code>命令行设置新的服务器:</p>

<pre>shell&gt; ./configure  --with-tcp-port=port_number \
             --with-unix-socket=file_name \
             --prefix=/usr/local/mysql-3.22.9
</pre>

<p>这里<code>port_number</code>和<code>file_name</code>应该不同于缺省端口号和套接字文件路径名,而且<code>--prefix</code>值应该指定一个不同于现存的<strong>MySQL</strong>安装所在的安装目录。 
</p>

<p>你可以用这个命令检查由任何当前执行的<strong>MySQL</strong>所使用的套接字和端口:</p>

<pre>shell&gt; mysqladmin -h hostname --port=port_number variables
</pre>

<p>如果你有一个<strong>MySQL</strong>服务器正运行在你使用了的端口上,你将得到<strong>MySQL</strong>的一些最重要的可配置变量的一张表,包括套接字名等。</p>

<p>你也应该编辑你机器的初始化脚本(可能<tt>是“mysql.server”</tt>)来启动并杀死多个<code>mysqld</code>服务器。</p>

<p>你不必重新编译一个新<strong>MySQL</strong>服务器,只要以一个不同的端口和套接字启动即可。你可以通过指定在运行时<code>safe_mysqld</code>使用的选项来改变端口和套接字:</p>

<pre>shell&gt; /path/to/safe_mysqld --socket=file_name --port=port_number
</pre>

<p>如果你在与开启日志的另一个服务器相同的一个数据库目录下运行新服务器,你也应该用<code>safe_mysqld</code>的<code>--log</code>和<code>--log-update</code>选项来指定日志文件的名字,否则,两个服务器可能正在试图写入同一个日志文件。</p>

<p><strong>警告</strong>:通常你决不应该有在同一个数据库中更新数据的2个服务器!如果你的OS不支持无故障(fault-free)的系统锁定,这可能导致令人惊讶的事情发生!</p>

<p>如果你想要为第二个服务器使用另一个数据库目录,你可以使用<code>safe_mysqld</code>的<code>--datadir=path</code>选项。</p>

<p>当你想要连接一个正在运行的使用一个不同于编译进你的客户程序中端口的<strong>MySQL</strong>服务器时,你可以使用下列方法之一: 

<ul>
  <li>以<code>--host 'hostname' --port=port_numer</code>或<code>[--host localhost] 
    --socket=file_name</code>启动客户。</li>
  <li>在你的C或Perl程序中,当连接<strong>MySQL</strong>服务器时,你可以给出端口和套接字参数。</li>
  <li>在你启动客户程序之前,<a name="IDX711"></a><a name="IDX712"></a><a name="IDX713"></a><a name="IDX714"></a>设置<code>MYSQL_UNIX_PORT</code>和<code>MYSQL_TCP_PORT</code>环境变量,指向Unix套接字和TCP/IP的端口。如果你通常使用一个特定的套接字或端口,你应该将设置这些环境变量的命令放进你的<tt>“.login”</tt>文件中。见<a href="manual_Tools.html#Programs">12.1 不同的 MySQL程序概述</a>。</li>
  <li><a name="IDX715"></a>在你的主目录<tt>下的“.my.cnf”</tt>文件中指定缺省套接字和TCP/IP端口。见<a href="manual_Installing.html#Option_files">4.15.4 选项文件</a>。</li>
</ul>

<hr>

<p><a href="manual_Introduction.html">第一章</a>, <a href="manual_Problems.html">前一章</a>, 
<a href="manual_Clients.html">下一章</a>, <a href="manual_Concept_Index.html">最后一章</a>,<a href="manual_toc.html">目录</a>. </p>
</body>
</html>

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -