Can't connect to MySQL server on 'localhost' (10061) 解决

Can't connect to MySQL server on 'localhost' (10061) 解决

Can't connect to MySQL server on'localhost'(10061)解决

2009-12-0209:45

SupeSite info:Can not connect to MySQL server

User:guest

Time:2009-11-122:16pm

Script:/xs/index.php

Error:Can't connect to MySQL server on'localhost'(10061)

Errno.:2003

■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■

服务器提示:Can not connect to MySQL server即无法连接到MySQL服务器

错误信息:Can't connect to MySQL server on'localhost'(10061)

即不能连接到MySQL服务器'本机'(10061)

errno。:2003

搜索了一下资料,别的网友说因为数据库连接超过最大连接数,MySQL数据库服务停止了。

根据提示信息判断这台机器上没提供MySQL服务,需要从新启动这台机器上的MySQL服务即可。

重启之前在My.ini中查找max_connections修改连接数为1000保存后在重启。

有时遇到MySQL无法启动,很可能是My.ini出错,若没有My.ini文件,可以自己创建一个,一般都创建在在winnt目录下(不同系统,目录不同,但都在windows安装目录)。

My.ini文件完整内容:

#This File was made using the WinMySQLAdmin1.4Tool

#2002-8-423:10:46

#Uncomment or Add only the keys that you know how works.

#Read the MySQL Manual for instructions

[mysqld]

basedir=D:/mysql/

#bind-address=192.168.0.1

datadir=D:/mysql/data

#default-character-set=gbk

#character_set=gbk

#language=D:/mysql/share/

#slow query log#=

#tmpdir#=

#port=3306

#set-variable=key_buffer=16M

set-variable=default-character-set=gbk

max_connections=256

max_user_connections=256

[WinMySQLadmin]

Server=D:/mysql/bin/mysqld-max-nt.exe

user=root

password=

my.cnf文件内容

#Example mysql config file.

#Copy this file to c:\my.cnf to set global options

#

#One can use all long options that the program supports.

#Run the program with--help to get a list of available options

#This will be passed to all mysql clients

[client]

#password=my_password

port=3306

#socket=MySQL

#Here is entries for some specific programs

#The following values assume you have at least32M ram

#The MySQL server

[mysqld]

port=3306

#socket=MySQL

skip-locking

default-character-set=gbk

set-variable=key_buffer=16M

set-variable=max_allowed_packet=1M

set-variable=thread_stack=128K

set-variable=flush_time=1800

#Uncomment the following row if you move the MySQL distribution to another

#location

#basedir=d:/mysql/

[mysqldump]

quick

set-variable=max_allowed_packet=16M

[mysql]

no-auto-rehash

[isamchk]

set-variable=key=16M

[client_fltk]

help_file=d:\mysql\sql_client\MySQL.help

client_file=d:\mysql\MySQL.options

history_length=20

database=test

queries_root=d:\mysql\queries

last_database_file=d:\mysql\lastdb

顺便转来My.ini文件的解析

引用

(1)、back_log:

要求MySQL能有的连接数量。当主要MySQL线程在一个很短时间内得到非常多的连接请求,这就起作用,然后主线程花些时间(尽管很短)检查连接并且启动一个新线程。

back_log值指出在MySQL暂时停止回答新请求之前的短时间内多少个请求可以被存在堆栈中。只有如果期望在一个短时间内有很多连接,你需要增加它,换句话说,这值对到来的TCP/IP连接的侦听队列的大小。你的操作系统在这个队列大小上有它自己的限制。试图设定back_log高于你的操作系统的限制将是无效的。

当你观察你的主机进程列表,发现大量264084|unauthenticated user|xxx.xxx.xxx.xxx|NULL|Connect|NULL|login|NULL的待连接进程时,就要加大back_log的值了。默认数值是50,我把它改为500。

(2)、interactive_timeout:

服务器在关闭它前在一个交互连接上等待行动的秒数。一个交互的客户被定义为对mysql_real_connect()使用CLIENT_INTERACTIVE选项的客户。默认数值是28800,我把它改为7200。

(3)、key_buffer_size:

索引块是缓冲的并且被所有的线程共享。key_buffer_size是用于索引块的缓冲区大小,增加它可得到更好处理的索引(对所有读和多重写),到你能负担得起那样多。如果你使它太大,系统将开始换页并且真的变慢了。默认数值是8388600(8M),我的MySQL主机有2GB内存,所以我把它改为402649088(400MB)。

(4)、max_connections:

允许的同时客户的数量。增加该值增加mysqld要求的文件描述符的数量。这个数字应该增加,否则,你将经常看到Too many connections错误。默认数值是100,我把它改为1024。

(5)、record_buffer:

每个进行一个顺序扫描的线程为其扫描的每张表分配这个大小的一个缓冲区。如果你做很多顺序扫描,你可能想要增加该值。默认数值是131072(128K),我把它改为16773120(16M)

(6)、sort_buffer:

每个需要进行排序的线程分配该大小的一个缓冲区。增加这值加速ORDER BY或GROUP BY操作。默认数值是2097144(2M),我把它改为16777208(16M)。

(7)、table_cache:

为所有线程打开表的数量。增加该值能增加mysqld要求的文件描述符的数量。MySQL对每个唯一打开的表需要2个文件描述符。默认数值是64,我把它改为512。

(、thread_cache_size:

可以复用的保存在中的线程的数量。如果有,新的线程从缓存中取得,当断开连接的时候如果有空间,客户的线置在缓存中。如果有很多新的线程,为了提高性能可以这个变量值。通过比较Connections和Threads_created状态的变量,可以看到这个变量的作用。我把它设置为80。

(10)、wait_timeout:

服务器在关闭它之前在一个连接上等待行动的秒数。默认数值是28800,我把它改为7200。

注:参数的调整可以通过修改/etc/my.cnf文件并重启MySQL实现。这是一个比较谨慎的工作,上面的结果也仅仅是我的一些看法,你可以根据你自己主机的硬件情况(特别是内存大小)进一步修改。