连接Mysql提示Can’t connect to local MySQL server through socket的解决方法

Mysqlliuliangsong 发表了文章 • 0 个评论 • 642 次浏览 • 2016-10-19 11:35 • 来自相关话题

mysql、mysqldump、mysqladmin、php连接mysql服务常会提示下面错误:ERROR 2002 (HY000): Can't connect to local MySQL server through socket '/var/lib/mysql/mysql.sock' (2)   这是由于当使用host参数为“localhost”连接Mysql服务时,会优先使用“sock文件”进行连接,而不是使用“IP:端口”进行连接,而mysql尝试使用“sock文件”进行连接时,却无法获取“sock文件”的位置。
 
要解决此错误,有两种解决方法:将连接参数“host”的值由“localhost”改成“127.0.0.1”;按下面方法,在“/etc/mysql.cnf”中指定“sock文件”位置。 一、查看mysql服务的socket文件位置:  mysql socket文件的位置是在/etc/my.cnf中设置的,cat /etc/my.cnf内容如下:[mysqld]
datadir=/storage/aiezu.com/mysql
socket=/storage/aiezu.com/mysql/mysql.sock
user=mysql  其中socket等于的路径就是socket文件的位置,我们只要修改my.cnf文件,告诉mysql,mysqldump,mysqladmin等mysql服务的socket位置在哪里就可以了,文件中可以看出,我的socket文件位置为:"/storage/aiezu.com/mysql/mysql.sock"。
 二、修改my.cnf文件解决问题:  在/etc/my.cnf文件中添加如下内容,并重启mysqld服务,即可解决mysql、mysqldump、mysqladmin的“Can't connect to local MySQL server through socket '/var/lib/mysql/mysql.sock'”问题:[mysqld]
datadir=/storage/aiezu.com/mysql
socket=/storage/aiezu.com/mysql/mysql.sock

[mysql]
socket=/storage/aiezu.com/mysql/mysql.sock

[client]
socket=/storage/aiezu.com/mysql/mysql.sock

[mysqldump]
socket=/storage/aiezu.com/mysql/mysql.sock

[mysqladmin]
socket=/storage/aiezu.com/mysql/mysql.sock 三、php连接mysql服务提示"Can't connect to local MySQL server through socket..."的解决方法:  有时候mysql服务正常运行,用户名密码也完全正确,使用php的mysql_connect函数却连接不了mysql,调用php的mysql_error()函数提示“Can't connect to local MySQL server through socket '/var/lib/mysql/mysql.sock'”,这是我们需要修改/etc/php.ini文件。
  在/etc/php.ini文件中"[MySQL]"项下找到"mysql.default_socket",并设置其值指向正确的mysql服务socket文件即可,如:[MySQL]
...省略n行...
mysql.default_socket = "/storage/aiezu.com/mysql/mysql.sock" 四、python连接mysql提示"Can't connect to local MySQL server through socket..."的解决方法:  在连接mysql数据库函数中指定socket文件,如下:#!/usr/bin/python
from MySQLdb import connect
conn = connect(db="pzy", user="root", host="localhost", unix_socket="/storage/aiezu.com/mysql/mysql.sock")
cur = conn.cursor()
count=cur.execute("show databases")
print 'there has %s dbs' % count
conn.commit()
conn.close() 五、 php pdo连接mysql提示"Can't connect to local MySQL server through socket..."的解决方法:  同样在连接字符串添加mysql socket文件的位置即可,如下:<?php
$dsn = "mysql:host=localhost;dbname=pzy;unix_socket=/storage/aiezu.com/mysql/mysql.sock";
$db = new PDO($dsn, 'root', '');
$rs = $db->query("SELECT * FROM qrtest");
while($row = $rs->fetch()){
print_r($row);
}
?> 
六、相关页面:ERROR 2002 (HY000): Can't connect to local MySQL server through socket '***' (2) 查看全部
mysql、mysqldump、mysqladmin、php连接mysql服务常会提示下面错误:
ERROR 2002 (HY000): Can't connect to local MySQL server through socket '/var/lib/mysql/mysql.sock' (2)
   这是由于当使用host参数为“localhost”连接Mysql服务时,会优先使用“sock文件”进行连接,而不是使用“IP:端口”进行连接,而mysql尝试使用“sock文件”进行连接时,却无法获取“sock文件”的位置。
 
要解决此错误,有两种解决方法:
  • 将连接参数“host”的值由“localhost”改成“127.0.0.1”;
  • 按下面方法,在“/etc/mysql.cnf”中指定“sock文件”位置。
 

一、查看mysql服务的socket文件位置:

  mysql socket文件的位置是在/etc/my.cnf中设置的,cat /etc/my.cnf内容如下:
[mysqld]
datadir=/storage/aiezu.com/mysql
socket=/storage/aiezu.com/mysql/mysql.sock
user=mysql
  其中socket等于的路径就是socket文件的位置,我们只要修改my.cnf文件,告诉mysql,mysqldump,mysqladmin等mysql服务的socket位置在哪里就可以了,文件中可以看出,我的socket文件位置为:"/storage/aiezu.com/mysql/mysql.sock"。
 

二、修改my.cnf文件解决问题:

  在/etc/my.cnf文件中添加如下内容,并重启mysqld服务,即可解决mysql、mysqldump、mysqladmin的“Can't connect to local MySQL server through socket '/var/lib/mysql/mysql.sock'”问题:
[mysqld]
datadir=/storage/aiezu.com/mysql
socket=/storage/aiezu.com/mysql/mysql.sock

[mysql]
socket=/storage/aiezu.com/mysql/mysql.sock

[client]
socket=/storage/aiezu.com/mysql/mysql.sock

[mysqldump]
socket=/storage/aiezu.com/mysql/mysql.sock

[mysqladmin]
socket=/storage/aiezu.com/mysql/mysql.sock

 

三、php连接mysql服务提示"Can't connect to local MySQL server through socket..."的解决方法:

  有时候mysql服务正常运行,用户名密码也完全正确,使用php的mysql_connect函数却连接不了mysql,调用php的mysql_error()函数提示“Can't connect to local MySQL server through socket '/var/lib/mysql/mysql.sock'”,这是我们需要修改/etc/php.ini文件。
  在/etc/php.ini文件中"[MySQL]"项下找到"mysql.default_socket",并设置其值指向正确的mysql服务socket文件即可,如:
[MySQL]
...省略n行...
mysql.default_socket = "/storage/aiezu.com/mysql/mysql.sock"
 

四、python连接mysql提示"Can't connect to local MySQL server through socket..."的解决方法:

  在连接mysql数据库函数中指定socket文件,如下:
#!/usr/bin/python
from MySQLdb import connect
conn = connect(db="pzy", user="root", host="localhost", unix_socket="/storage/aiezu.com/mysql/mysql.sock")
cur = conn.cursor()
count=cur.execute("show databases")
print 'there has %s dbs' % count
conn.commit()
conn.close()
 

五、 php pdo连接mysql提示"Can't connect to local MySQL server through socket..."的解决方法:

  同样在连接字符串添加mysql socket文件的位置即可,如下:
<?php
$dsn = "mysql:host=localhost;dbname=pzy;unix_socket=/storage/aiezu.com/mysql/mysql.sock";
$db = new PDO($dsn, 'root', '');
$rs = $db->query("SELECT * FROM qrtest");
while($row = $rs->fetch()){
print_r($row);
}
?>
 
六、相关页面:

PHP正则表达式匹配所有ASCII字符

PHPliuliangsong 发表了文章 • 0 个评论 • 545 次浏览 • 2016-10-18 22:15 • 来自相关话题

PHP可以使用"#[[:ascii:]]#"或者"#[\x{00}-\x{ff}]#u"来匹配ASCII字符。<?php
//删除所有ascii字符
echo preg_replace("#[\x{00}-\x{ff}]#u", "", "abc!@爱E族#{}x aiezu.com");
//输出: 爱族

//删除所有非ascii字符
echo preg_replace("#[^[:ascii:]]#u", "", "abc!@爱E族#{}x aiezu.com");
//输出: abc!@E#{}x aiezu.com 查看全部
PHP可以使用"#[[:ascii:]]#"或者"#[\x{00}-\x{ff}]#u"来匹配ASCII字符。
<?php
//删除所有ascii字符
echo preg_replace("#[\x{00}-\x{ff}]#u", "", "abc!@爱E族#{}x aiezu.com");
//输出: 爱族

//删除所有非ascii字符
echo preg_replace("#[^[:ascii:]]#u", "", "abc!@爱E族#{}x aiezu.com");
//输出: abc!@E#{}x aiezu.com

中文在UTF8和GBK编码中的范围

PHPliuliangsong 发表了文章 • 0 个评论 • 680 次浏览 • 2016-10-18 16:09 • 来自相关话题

编码范围
1. GBK (GB2312/GB18030)
x00-xff GBK双字节编码范围x20-x7f ASCII字符x80-xff 中文(GBK中文范围)
xa1-xff 中文(GB2312中文范围)

2. UTF-8 (Unicode)
u4e00-u9fa5 (中文)x3130-x318F (韩文)xAC00-xD7A3 (韩文)u0800-u4e00 (日文)


正则表达式例子:
1、使用PHP语言:<?php
preg_replace("#[\x80-\xff]#", "", '爱E族:aiezu.com'); //GBK中匹配
preg_replace("#[\x{4e00}-\x{9fa5}]#", "", '爱E族:aiezu.com'); //UTF8中匹配
2、使用javascript:var str = "爱E族:aiezu.com";
str.replace(/[\u4e00-\u9fa5]/g, "");
另外一些全角英文、特殊符号等UTF8字符的编码:
uff00 - uff0f:全角字符 ＀!"#$%&'()*+,./uff10 - uff19:全角字符 0123456789uff20 - uff20:全角字符 @uff21 - uff3a:全角大写 A-Zuff3b - uff40:全角字符[\]^_`uff41 - uff5a:全角大写 a-z 查看全部
编码范围
1. GBK (GB2312/GB18030)
  • x00-xff GBK双字节编码范围
  • x20-x7f ASCII字符
  • x80-xff 中文(GBK中文范围)

  • xa1-xff 中文(GB2312中文范围)


2. UTF-8 (Unicode)
  • u4e00-u9fa5 (中文)
  • x3130-x318F (韩文)
  • xAC00-xD7A3 (韩文)
  • u0800-u4e00 (日文)



正则表达式例子:
1、使用PHP语言:
<?php
preg_replace("#[\x80-\xff]#", "", '爱E族:aiezu.com'); //GBK中匹配
preg_replace("#[\x{4e00}-\x{9fa5}]#", "", '爱E族:aiezu.com'); //UTF8中匹配

2、使用javascript:
var str = "爱E族:aiezu.com";
str.replace(/[\u4e00-\u9fa5]/g, "");

另外一些全角英文、特殊符号等UTF8字符的编码:
  • uff00 - uff0f:全角字符 ＀!"#$%&'()*+,./
  • uff10 - uff19:全角字符 0123456789
  • uff20 - uff20:全角字符 @
  • uff21 - uff3a:全角大写 A-Z
  • uff3b - uff40:全角字符[\]^_`
  • uff41 - uff5a:全角大写 a-z

php正则表达匹配中文汉字

PHPliuliangsong 发表了文章 • 0 个评论 • 1113 次浏览 • 2016-10-18 15:36 • 来自相关话题

正则匹配中文汉字根据字符编码不同而略有区别:
GBK编码 - [\x80-\xff]+ GB2312编码 - [x\a1-\xff]+UTF-8编码 - [\x{4e00}-\x{9fa5}]+/u
 
示例:
1、匹配UTF8编码字符中的汉字:<?php
// 删除字符串中所有汉字
echo preg_replace("#[\x{4e00}-\x{9fa5}]#u", "", '爱E族: aiezu.com');
// E: aiezu.com

// 删除字符串中所有非汉字字符
echo preg_replace("/[^\x{4e00}-\x{9fa5}]/u", "", '爱E族(aiezu.com)');
// 输出: 爱族 
2、匹配GB2312编码字符中的汉字:<?php
//GB2312替换中文为空,输出:Eaiezu.com
echo preg_replace("#[\xa1-\xff]+#", "", '爱E族(aiezu.com)');

//GB2312替换非中文为空,输出:爱族()
echo preg_replace("#[^\xa1-\xff]+#", "", '爱E族(aiezu.com)');
 3、匹配GBK编码字符中的汉字:<?php
// GBK编码删除中文字符,输出:Eaiezu.com
echo preg_replace("#[\x80-\xff]+#", "", '爱E族:aiezu.com');

//GBK编码删除非中文字符,输出:爱族:
echo preg_replace("#[^\x80-\xff]+#", "", '爱E族:aiezu.com'); 查看全部
正则匹配中文汉字根据字符编码不同而略有区别:
  • GBK编码 - [\x80-\xff]+ 
  • GB2312编码 - [x\a1-\xff]+
  • UTF-8编码 - [\x{4e00}-\x{9fa5}]+/u

 
示例:
1、匹配UTF8编码字符中的汉字:
<?php
// 删除字符串中所有汉字
echo preg_replace("#[\x{4e00}-\x{9fa5}]#u", "", '爱E族: aiezu.com');
// E: aiezu.com

// 删除字符串中所有非汉字字符
echo preg_replace("/[^\x{4e00}-\x{9fa5}]/u", "", '爱E族(aiezu.com)');
// 输出: 爱族
 
2、匹配GB2312编码字符中的汉字:
<?php
//GB2312替换中文为空,输出:Eaiezu.com
echo preg_replace("#[\xa1-\xff]+#", "", '爱E族(aiezu.com)');

//GB2312替换非中文为空,输出:爱族()
echo preg_replace("#[^\xa1-\xff]+#", "", '爱E族(aiezu.com)');

 3、匹配GBK编码字符中的汉字:
<?php
// GBK编码删除中文字符,输出:Eaiezu.com
echo preg_replace("#[\x80-\xff]+#", "", '爱E族:aiezu.com');

//GBK编码删除非中文字符,输出:爱族:
echo preg_replace("#[^\x80-\xff]+#", "", '爱E族:aiezu.com');

Compilation failed: invalid UTF-8 string at offset 6 in /tmp/aiezu.com.php on line 2

PHPliuliangsong 发表了文章 • 0 个评论 • 153 次浏览 • 2016-10-18 15:12 • 来自相关话题

当我们通过下面代码、使用正则表达式期望将字符串中的非汉字替换为空,这时收到一条警告信息:<?php
echo preg_replace("#[^\x4e00-\x9fa5]#u", "", '爱E族:aiezu.com');警告信息:PHP Warning: preg_replace(): Compilation failed: invalid UTF-8 string at offset 6 in /tmp/aiezu.com.php on line 2这时如何解决呢?
 
原来正则表达式中的"\x"后的UTF8编码,必须使用大括号括起来才行,如下:<?php
echo preg_replace("#[^\x{4e00}-\x{9fa5}]#u", "", '爱E族:aiezu.com');
//输出: 爱族 查看全部
当我们通过下面代码、使用正则表达式期望将字符串中的非汉字替换为空,这时收到一条警告信息:
<?php
echo preg_replace("#[^\x4e00-\x9fa5]#u", "", '爱E族:aiezu.com');
警告信息:
PHP Warning:  preg_replace(): Compilation failed: invalid UTF-8 string at offset 6 in /tmp/aiezu.com.php on line 2
这时如何解决呢?
 
原来正则表达式中的"\x"后的UTF8编码,必须使用大括号括起来才行,如下:
<?php
echo preg_replace("#[^\x{4e00}-\x{9fa5}]#u", "", '爱E族:aiezu.com');
//输出: 爱族

Compilation failed: character value in \x{...} sequence is too large at offset xxx

PHPliuliangsong 发表了文章 • 0 个评论 • 283 次浏览 • 2016-10-18 14:48 • 来自相关话题

当我们使用正则表达式匹配汉字时,收到一条警告信息,如:<?php
echo preg_replace("#[^\x{4e00}-\x{9fa5}]#", "", '爱E族:aiezu.com');
//抛出警告:
// PHP Warning: preg_replace(): Compilation failed: character value in \x{...} sequence is too large at offset 9 in /tmp/aiezu.com.php on line 2  这是由于我们正则表达式没加"u"模式原因,如果没加"u"模式,"\x"后的大括号中最多只能包含两个字符,范围为:"\x{00}-\x{ff}",表示匹配ascii字符,所以上面错误的解决方法就是加上"u"模式,修改后代码如下:<?php
echo preg_replace("#[^\x{4e00}-\x{9fa5}]#u", "", '爱E族:aiezu.com');
//输出: 爱族 查看全部
当我们使用正则表达式匹配汉字时,收到一条警告信息,如:
<?php
echo preg_replace("#[^\x{4e00}-\x{9fa5}]#", "", '爱E族:aiezu.com');
//抛出警告:
// PHP Warning: preg_replace(): Compilation failed: character value in \x{...} sequence is too large at offset 9 in /tmp/aiezu.com.php on line 2
  这是由于我们正则表达式没加"u"模式原因,如果没加"u"模式,"\x"后的大括号中最多只能包含两个字符,范围为:"\x{00}-\x{ff}",表示匹配ascii字符,所以上面错误的解决方法就是加上"u"模式,修改后代码如下:
<?php
echo preg_replace("#[^\x{4e00}-\x{9fa5}]#u", "", '爱E族:aiezu.com');
//输出: 爱族

Compilation failed: PCRE does not support \L, \l, \N, \U, or \u at offset 3 in xxx

PHPliuliangsong 发表了文章 • 0 个评论 • 450 次浏览 • 2016-10-18 14:18 • 来自相关话题

当我们辛辛苦苦的在网上找到匹配汉字的正则表达式拿来用时,才发现不能用,如下面代码:<?php
echo preg_replace("#[^\u4e00-\u9fa5]#", "", '爱E族:aiezu.com');代码抛出如下警告信息:PHP Warning: preg_replace(): Compilation failed: PCRE does not support \L, \l, \N, \U, or \u at offset 3 in /tmp/aiezu.com.php on line 2 
解决办法:
  原来上面代码的"\u4e00-\u9fa5"是javascript中用来匹配汉字的,在PHP中应该改成"\x"开头,并使用大括号括起来:"\x{4e00}-\x{9fa5}",并在正则表达式上使用"u"模式(UTF8模式),详见下面代码:<?php
echo preg_replace("#[^\x{4e00}-\x{9fa5}]#u", "", '爱E族:aiezu.com');
//输出结果:爱族 查看全部
当我们辛辛苦苦的在网上找到匹配汉字的正则表达式拿来用时,才发现不能用,如下面代码:
<?php
echo preg_replace("#[^\u4e00-\u9fa5]#", "", '爱E族:aiezu.com');
代码抛出如下警告信息:
PHP Warning:  preg_replace(): Compilation failed: PCRE does not support \L, \l, \N, \U, or \u at offset 3 in /tmp/aiezu.com.php on line 2
 
解决办法:
  原来上面代码的"\u4e00-\u9fa5"是javascript中用来匹配汉字的,在PHP中应该改成"\x"开头,并使用大括号括起来:"\x{4e00}-\x{9fa5}",并在正则表达式上使用"u"模式(UTF8模式),详见下面代码:
<?php
echo preg_replace("#[^\x{4e00}-\x{9fa5}]#u", "", '爱E族:aiezu.com');
//输出结果:爱族

Javascript计算字符串长度,中文长度为2,英文为1

Javascriptliuliangsong 发表了文章 • 0 个评论 • 497 次浏览 • 2016-10-18 11:46 • 来自相关话题

  使用js计算字符串长度,ASCII字符(英文、数字、字母等)长度算1,非ASCII字符(汉字等多字节字符)长度算2:
 
方法:将非ascii字符替换成两个星号,再计算长度:function abslength( str ) {
return str.replace(/[^\x00-\xff]/ig, '**').length;
}
alert(abslength("爱E族: aiezu.com")); //弹出16
这是JS版本,要使用PHP按同样规则计算字符串长度,请参考:PHP计算字符串长度,中文长度为2,英文为1 查看全部
  使用js计算字符串长度,ASCII字符(英文、数字、字母等)长度算1,非ASCII字符(汉字等多字节字符)长度算2:
 
方法:将非ascii字符替换成两个星号,再计算长度:
function abslength( str ) {
return str.replace(/[^\x00-\xff]/ig, '**').length;
}
alert(abslength("爱E族: aiezu.com")); //弹出16

这是JS版本,要使用PHP按同样规则计算字符串长度,请参考:PHP计算字符串长度,中文长度为2,英文为1

PHP计算字符串长度,中文长度为2,英文为1

PHPliuliangsong 发表了文章 • 0 个评论 • 367 次浏览 • 2016-10-18 11:19 • 来自相关话题

  PHP计算字符串长度,ASCII字符(英文、数字、字母等)长度算1,非ASCII字符(汉字等多字节字符)长度算2:
方法一:
  将非ascii字符替换成两个星号,再使用strlen计算长度:<?php
function abslength( $str ) {
return strlen(preg_replace("#[^\x{00}-\x{ff}]#u", '**', $str));
}
echo abslength("爱E族: aiezu.com"); //输出16
方法二:
  循环判断每个字符是否为ASCII字符,是则加1,否则加2:<?php
function abslength($s){
$n = 0;
preg_match_all("/./us",$s,$matchs);
foreach($matchs[0] as $p){
$n += preg_match('#^['.chr(0x1).'-'.chr(0xff).']$#',$p) ? 1 : 2;
}
return $n;
}
echo abslength("爱E族: aiezu.com"); //16 
  这是PHP版本,要使用JS按同样规则计算字符串长度,请参考:Javascript计算字符串长度,中文长度为2,英文为1 查看全部
  PHP计算字符串长度,ASCII字符(英文、数字、字母等)长度算1,非ASCII字符(汉字等多字节字符)长度算2:
方法一:
  将非ascii字符替换成两个星号,再使用strlen计算长度:
<?php
function abslength( $str ) {
return strlen(preg_replace("#[^\x{00}-\x{ff}]#u", '**', $str));
}
echo abslength("爱E族: aiezu.com"); //输出16

方法二:
  循环判断每个字符是否为ASCII字符,是则加1,否则加2:
<?php
function abslength($s){
$n = 0;
preg_match_all("/./us",$s,$matchs);
foreach($matchs[0] as $p){
$n += preg_match('#^['.chr(0x1).'-'.chr(0xff).']$#',$p) ? 1 : 2;
}
return $n;
}
echo abslength("爱E族: aiezu.com"); //16
 
  这是PHP版本,要使用JS按同样规则计算字符串长度,请参考:Javascript计算字符串长度,中文长度为2,英文为1

PHP中eval函数导致HTTP 500错误的解决方法

PHPliuliangsong 发表了文章 • 0 个评论 • 245 次浏览 • 2016-10-18 11:10 • 来自相关话题

  使用php eval函数来执行PHP代码时,常常由于提交给eval函数执行的代码不是合法的PHP代码,而导致http服务返回"HTTP/1.0 500 Internal Server Error"错误。尝试使用下面方式进行异常处理:try {
eavl("code...");
} catch(Exception $e){}或者:@eavl("code...");后发现页面依然返回http 500错误,在网上google一下才发现这是一个bug,通过下面方式得以解决:ini_set('display_errors', 'on');
try {
eavl("code...");
} catch(Exception $e){}
ini_set('display_errors', 'on');或者:ini_set('display_errors', 'on');
@eavl("code...");
ini_set('display_errors', 'off'); 查看全部
  使用php eval函数来执行PHP代码时,常常由于提交给eval函数执行的代码不是合法的PHP代码,而导致http服务返回"HTTP/1.0 500 Internal Server Error"错误。尝试使用下面方式进行异常处理:
try {
eavl("code...");
} catch(Exception $e){}
或者:
@eavl("code...");
后发现页面依然返回http 500错误,在网上google一下才发现这是一个bug,通过下面方式得以解决:
ini_set('display_errors', 'on');
try {
eavl("code...");
} catch(Exception $e){}
ini_set('display_errors', 'on');
或者:
ini_set('display_errors', 'on');
@eavl("code...");
ini_set('display_errors', 'off');