X 我知道了TIPS:左右滑动导航栏可以查看更多栏目

2014
06-21

2014
06-16

今天备份vps的时候出现mysqldump: command not found错误,百度了一下解决方法:

先用一条find命令查找mysqldump的所载路径

find / -name mysqldump -print

然后再用ln命令链接到/usr/bin下面

ln -fs /usr/local/mysql/bin/mysqldump /usr/bin

注意 /usr/local/mysql/bin/mysqldump要为刚才输出的路径。

mysqldump

原理:直接输入命令mysqldump会发现提示命令不存在,是由于系统默认会查找/usr/bin下的命令,如果这个命令不在这个目录下,自然会找不到命令,并报错。

2014
06-11

vi 中的正则表达式 (Regular Expression)
===================================
.1. 定义和例子
============
正则表达式只是一个字符模板,用来在搜索中匹配相同的字符.
在大多数的程序中,正则表达式是括在正斜杠中间的.
例如, /love/就是一个以正斜杠为分隔符的正则表达式,其中的
模板love 将用在搜索所有行中与它匹配的字符. 更为有趣的是
正则表达式可以被特殊的元字符控制.让我们通过下面的例子来进
一步了解这个概念.
有文本如下:
Hi tom,
I think I failed my anatomy test yesterday. I
had a terrible stomach ache. I ate too many
fried green tomatoes.
Anyway, Tom, Ineed your help. I’d like to make
the test up tomorrow, but don’t know where to
begin studying. Do you think you could help me?
After work, about 7 PM, come to my place and I’ll
treat you to pizza in return for your help.
Thanks.
Your pal,
guy@phantom

假设你发觉Tom 并没有参加考试,而是David 参加的考试.同时还
发现, 在贺信中Tom的T用的是小写.于是你决定做一个全文替换,把tom
替换为Tom.

在vi命令行模式下输入:
:1, $s/tom/David/g
^ ^ ^ ^ ^
| | | | |—- global 对全文有效
| | | |
| | |——— 将tom 替换为 David , 使用正则表达式.
| |——- 替换单词
|—— 从文件的第一行到文件的最后一行.

替换后的文本如下:
Hi David,
I think I failed my anaDavidy test yesterday, I
had terible sDavidach ache. I ate too many
fried green Davidatoes.
Anyway, David, I need your help. I’d like to make
the test up Davidorrow, but don’t know where to
begin studying. Do you think you could help me?
After work, about ? PM, come to my place and
I’ll treat you to pizza in return for your help.
Thanks.
Your pal,
guy@phanDavid

我们发现有些单词中含有tom的的也被替换了.
这是因为我们没有使用正则表达式的元字符来界定一个模板从而控制
字符的替换动作.
使用:
:1, $s/\<[Tt]om\>/David/g
就可以得到我们想要的结果了,即只替换单词tom而不是含有tom字符的
单词.

.2. 正则表达式的元字符
==================
正则表达式的元字符是一些特殊的字符,它们允许你以某种方式界定一个
模板来控制什么样的替换将发生.有的元字符锚定一个单词在行首或者行尾.
有的元字符允许你指定一个字符范围或者一些字符, 来找到大写字母, 小写字母
数字或者非数字等.

有两套正则表达式字符集, 一套是基本元字符集, 另一套是扩展元字符集.
另外, POSIX (Portable Operating System Interface for Computer Eaviron ment)
标准还提供了一套元字符集.下表提供了可以在所有版本的vi, grep, egrep, sed and gawk
中使用的基本元字符集.
表:
———————————————————————————————-
元字符 | 功能 | 例子 | 匹配什么
———————————————————————————————-
^ | 锚定行的开始 | /^love/ | 匹配所有以love开头的行.
———————————————————————————————-
$ | 锚定行的结束 | /love$/ | 匹配所有以love结束的行.
———————————————————————————————-
. | 匹配一个字符 | /l..e/ | 匹配这样的行, 这些行包含这样的字符,
| | |第一个字符是 l,紧跟着两个字符,然后是e.
———————————————————————————————–
* | 代表0个或多个先前字符 | /*love/ | 匹配这样的行, 有0个或者多个空格,空格
| | |候跟着love
———————————————————————————————–
[] | 匹配字符组中的一个字符 | /[lL]ove/ | 匹配所有包含love or Love 的行
———————————————————————————————–
[x-y] | 匹配以字符范围组成的组中的一个字符 | /[A-Z]ove | 匹配所有这样的行, 这些行包含如下字符
| | |第一个字符是从A到Z 中间的一个, 后面跟
| | |着ove
———————————————————————————————–
[^] | 匹配一个不在范围内的字符 | /[^A-Z]ove/ | 匹配所有这样的行, 这些行包含如下字符
| | |第一个字符不是从A到Z 中间的一个, 后面
| | |跟着ove
———————————————————————————————–
\ | 用来转义一个字符 | /love\./ | 匹配所有这样的行, 这些行包含如下字符
| | |love 后面跟着一个点, 通常点是表示任何
| | |字符的通配符.
———————————————————————————————–
\< | 锚定单词的开始 | /\ | | |开头的单词 (vi & grep 都支持这个功能)
-----------------------------------------------------------------------------------------------
\> | 锚定单词的结束 | / | … ^ … 以love结束的单词 … ^
———————————————————————————————–
\(..\) | 标记后面用到的匹配字符 | /\(love\)a\1b | 最多可以使用9个标签. 第一个标签是模板
| | |最左边的部分. 在这例子中, 模板love
| | |保存为标签1, 后面的\1指的就是love;
| | |本例子搜索的是这样的行, 这些行包含这样
| | |的字符,在lovea 后面跟着loveb.
————————————————————————————————
[NOTE: 各种版本的Unix 以及模板匹配 (pattern-matching) 实用程序并不都是可信赖的, 通常我们使用 vi & grep]

假设你熟悉 vi 是怎样工作的, 每一个元字符都在 vi 搜索字符串的术语中有详细描述.
下面的例子中, 被加重的字符就是 vi 将找到的匹配字符.

文本如下:
I had a lovely time on our little picnic.
Lovers were all around us. It is springtime. Oh
Love, how much I adore you. Do you know
the extent of my love? Oh, by the way, I think
I lost my gloves somewhere out in that field of
clover. Did you see them? I can only hope love
is forever. I live for you. It’s hard to get back
in the groove.
~
~
~
/love/

结果如下:
I had a lovely time on our little picnic.
^
Lovers were all around us. It is springtime. Oh
^
Love, how much I adore you. Do you know
^
the extent of my love? Oh, by the way, I think
^
I lost my gloves somewhere out in that field of
^
clover. Did you see them? I can only hope love
^ ^
is forever. I live for you. It’s hard to get back
in the groove.

//
还有一些测试命令如下:
/^love/
/love$/
/l.ve/
/[lL]ove/
/ove[a-z]/
/ove[^a-zA-Z0-9]/

//
//:~ Tue 22 Apr 2003 11:42:51 PM CST
//:~ End Of PAGE 1

自己实现的例子

替换代码

结果是

替换代码是

2014
05-30

用rpm包安装的MySQL是不会安装/etc/my.cnf文件的,

至于为什么没有这个文件而MySQL却也能正常启动和作用,在点有两个说法,

第一种说法,my.cnf只是MySQL启动时的一个参数文件,可以没有它,这时MySQL会用内置的默认参数启动,

第二种说法,MySQL在启动时自动使用/usr/share/mysql目录下的my-medium.cnf文件,这种说法仅限于rpm包安装的MySQL,

解决方法,只需要复制一个/usr/share/mysql目录下的.cnf文件到/etc目录,并改名为my.cnf即可。

2014
05-30

1.首先确认服务器出于安全的状态,也就是没有人能够任意地连接MySQL数据库。
因为在重新设置MySQL的root密码的期间,MySQL数据库完全出于没有密码保护的
状态下,其他的用户也可以任意地登录和修改MySQL的信息。可以采用将MySQL对
外的端口封闭,并且停止Apache以及所有的用户进程的方法实现服务器的准安全
状态。最安全的状态是到服务器的Console上面操作,并且拔掉网线。
2.修改MySQL的登录设置:
# vi /etc/my.cnf
在[mysqld]的段中加上一句:skip-grant-tables
例如:

保存并且退出vi。
3.重新启动mysqld

4.登录并修改MySQL的root密码

5.将MySQL的登录设置修改回来
# vi /etc/my.cnf
将刚才在[mysqld]的段中加上的skip-grant-tables删除
保存并且退出vi。
6.重新启动mysqld
# /etc/init.d/mysqld restart
Stopping MySQL: [ OK ]
Starting MySQL: [ OK ]
Work for fun,Live for love!

2014
05-27

2014
05-26

Open the file “catalog/view/theme/lexus_mobile/template/product/product.tpl” then find the code:

Replace to:

2013
08-03

今天发现/usr/local/mysql/var下很多mysql-bin.000001、mysql-bin.000002文件,GOOGLE之。。

这是数据库的操作日志,例如UPDATE一个表,或者DELETE一些数据,即使该语句没有匹配的数据,这个命令也会存储到日志文件中,还包括每个语句执行的时间,也会记录进去的。

这样做主要有以下两个目的:
1:数据恢复
如果你的数据库出问题了,而你之前有过备份,那么可以看日志文件,找出是哪个命令导致你的数据库出问题了,想办法挽回损失。
2:主从服务器之间同步数据
主服务器上所有的操作都在记录日志中,从服务器可以根据该日志来进行,以确保两个同步。

处理方法分两种情况:
1:只有一个mysql服务器,那么可以简单的注释掉这个选项就行了。
vi /etc/my.cnf把里面的log-bin这一行注释掉,重启mysql服务即可。
2:如果你的环境是主从服务器,那么就需要做以下操作了。
A:在每个从属服务器上,使用SHOW SLAVE STATUS来检查它正在读取哪个日志。
B:使用SHOW MASTER LOGS获得主服务器上的一系列日志。
C:在所有的从属服务器中判定最早的日志,这个是目标日志,如果所有的从属服务器是更新的,就是清单上的最后一个日志。
D:清理所有的日志,但是不包括目标日志,因为从服务器还要跟它同步。
清理日志方法为:
PURGE MASTER LOGS TO ‘mysql-bin.010′;
PURGE MASTER LOGS BEFORE ’2008-12-19 21:00:00′;

如果你确定从服务器已经同步过了,跟主服务器一样了,那么可以直接RESET MASTER将这些文件删除。

======================================

如何删除mysql-bin.0000X 日志文件呢?

mysql> reset master; (清除日志文件)
Query OK, 0 rows affected (8.51 sec)

mysql>

好了,我们再来查看下mysql文件夹占用多少空间?

[root@jiucool var]# du -h –max-depth=1 /usr/local/mysql/
37M /usr/local/mysql/var
70M /usr/local/mysql/mysql-test
15M /usr/local/mysql/lib
448K /usr/local/mysql/include
2.9M /usr/local/mysql/share
7.6M /usr/local/mysql/libexec
17M /usr/local/mysql/bin
11M /usr/local/mysql/docs
2.9M /usr/local/mysql/sql-bench
163M /usr/local/mysql/

好了,看一下,整个mysql 目录才占用163M大小!OK,没问题,既然mysql-bin.0000X日志文件占用这么大空间,存在的意义又不是特别大,那么我们就不让它生成吧.

[root@jiucool var]# find / -name my.cnf

找到了my.cnf 即mysql配置文件,我们将log-bin=mysql-bin 这条注释掉即可.

# Replication Master Server (default)
# binary logging is required for replication
#log-bin=mysql-bin

重启下mysql吧.

OK,至此,操作完成. 以后再不会因为就几十M的数据库大小生成N个G的日志文件啦.

2013
07-30

1.数组转换成字符串:把数组存成字符串,用逗号隔开.2.字符串转换成数组:用逗号把字符串分隔成数组。

2013
07-18

不知道有没有用收集
Website URL PR Description
https://adwords.google.com/select/KeywordToolExternal Google关键词建议与搜索量
http://freekeywords.wordtracker.com/ 关键词建议与搜索量
http://www.keyworddiscovery.com/search.html 关键词建议与搜索量

http://tools.seobook.com/keyword-tools/seobook/

http://www.google.com/trends/hottrends Google美国地区热门关键词
http://www.google.com/webhp?complete=1 Google关键词结果提示
https://account.uk.miva.com/advertiser/Account/Popups/KeywordGenBox.asp 查询相关关键词搜索情况以及建议
http://www.selfseo.com/keyword_suggestion_tool.php 3 关键词建议与分地区流行度
http://www.seochat.com/seo-tools/keyword-suggestions-google/ 3 Keyword Suggestions for Google
http://www.webmaster-toolkit.com/keyword-research-tool.shtml 3 Keyword Research Tool
http://www.keyworddiscovery.com/keywords.html 2 Keyword Discovery and Analyze

http://www.webconfs.com/website-keyword-suggestions.php

http://www.seochat.com/seo-tools/keyword-density/ Keyword Density
http://tool.motoricerca.info/keyword-density.phtml Keyword Density
http://www.ranks.nl/tools/spider.html 5 Keyword Density
http://www.keyworddensity.com/search_engine_optimization/keyword_density.cgi 2 Keyword Density
http://googlerankings.com/ultimate_seo_tool.php 5 Keyword Density
http://www.webconfs.com/keyword-density-checker.php 3 Keyword Density
http://tools.seobook.com/general/keyword-density/ 4 Keyword Density
http://www.webuildpages.com/seo-tools/keyword-density/index.php 4 Keyword Density
http://www.semrush.com/ 4 竞争分析
http://www.seochat.com/seo-tools/search-engine-keyword-position/ 搜索关键词位置
http://www.google.cn/trends 谷歌趋势
http://index.baidu.com/ 百度工具