- 20
- 十一月
两台服务器间数据移植
因为小说站24note(http://www.24note.cn) 所在的服务器的压力大,再加上软件的问题,导致服务器不稳定,虽然现在的方法是每隔1小时重启下apache,但是也不是长久之计,所以,今天晚上就加班把24note 上面的数据都移植到另外一台服务器上面。
其实数据移植并不困难,但是数据量真的太大了,小说站上面有大量的静态页、txt文件、手机小说书的jrd 文件等等,还有一个几百兆的数据库,所以就不能用传统的ftp来操作了。
linux 有很多很好的工具,来实现不同服务器间的数据移植。我用的是scp命令:
#scp -r 用户名@原数据所在服务器IP : 原数据的局对路径 当前服务器的数据存放位置
查看全文>>
- 14
- 十一月
APACHE 日志管理,以及apache2.2 的配置问题
最近服务器apache经常当机,一时也查不出原因,也只有想着如何去优化一下了。首先想到的是apache 的日志。
其实如果没有必要存储日志,可以禁用日志,这是对于不需要日志分析的情况,如果需要保存日志,又不想日志文件太大,则可以用下面的方法:
就是把日志按照日期分割,每天在服务器上面生成一个单独文件,这样,访问量再大,日志文件的大小也就有了限制。
打开apache 的配置文件
#vi /usr/local/apache2/conf/httpd.conf
查看全文>>
- 05
- 六月
Apache 限制并发连接数和下载速度 的配置
昨天我们的一台服务器apache出现了问题,页面无法访问,过段时间要重启apache才能访问页面。查看了系统日志,没有发现被攻击的迹象,然后查看了所有网站的日志,发现一个论坛的LOG 显示了大量了mp3下载,而且是同一IP不断刷新,我想这就是我们Apache当机的原因,随后关闭了此网站,apache 再也没有出现问题,所以问题应该就在这。
下面就是如何解决这个问题了。因为这个论坛是提供音乐在线收听的,里面有大量的mp3文件,也就避免不了大量的下载链接,而我们之前也没有做任何限制(因为这不是下载站,而且没有经验)。为此,我上网找了些资料,发现了两个很好的apache模块: mod_bw 和 mod_limitipconn ;分别是限速和限制IP连接数的模块。
安装mod_bw 和 mod_limitipconn 都非常简单。
查看全文>>
- 13
- 十月
[转载]centos 5.0 编译安装apache 2.2.6+php5.2.5+mysql5.0.46+Z
V2.0 2007年2月12日 操作系统更新为centos 5.0 apache 更新为2.2.6版本, php更新为5.2.5,增加集成Suhosin补丁,mysql 更新为5.0.46, Zend Optimizer 更新为3.3.0。解决新平台下的一些问题。修正文字错误。
v1.2 2007年2月12日 apache 更新为2.2.4版本,增加mod_ssl和openssl支持,增加apr和apr-util的编译, php更新为5.2.1,增加集成Suhosin补丁,mysql 更新为5.0.33, Zend Optimizer 更新为3.2.2,增加phpmyadmin。修改一些文字错误。
v1.0 2007年1月11日
先声明,我绝对是个Linux的菜鸟,以下的这些文字个人的安装笔记,是参考了网上许多高手的成功经验组合而成的,说实话我自己的东西不多 :)我想把这些经验写下来,既可以对其他跟我一样摸索的兄弟一个经验,也可以防止以后自己都忘记了,嘿嘿。
所以如果某个大虾看到我借用了你的资源,请你不要生气。也欢迎大家进行指点。
1、下载centos 5
我是下载的DVD版本,大家也可以下载服务器CD安装版本,其实都差不多。大家可以到这儿下载,速度很快的。
http://ftp.iasi.roedu.net/mirrors/ce…86-bin-DVD.iso
当然也可以在windows下用BT或迅雷下载,速度也很不错的。
下载后当然就刻录成光盘。我建议你刻录DVD啦,如果是菜鸟,也可以在图形界面进行学习,不会这么抓不住头脑。
查看全文>>
- 11
- 九月
Linux下,PHP5 的编译安装傻瓜步骤
很多人在安装php的时候都会遇到很多的问题,但是我想只要按照步骤一步一步的进行,仔细的查看输出结果,应该可以顺利的安装好PHP,也能体会到linux命令行带来的乐趣,下面我们一起开始安装PHP5吧,后面我还会写一些linux简单的配置和apache的相关文章。
cd /usr/local/src
wget http://jp.php.net/get/php-5.2.5.tar.gz/from/this/mirror
rpm -qa | grep php
rpm -e php-ldap-4.3.9-3.22.9 php-pear-4.3.9-3.22.9 php-4.3.9-3.22.9
#libcurl
rpm -qa | grep curl
rpm -e curl curl-devel
rpm -e curl-7.12.1-11.el4
查看全文>>
- 03
- 九月
MYSQL命令行模式管理MySql的一点心得
MySql数据库是中小型网站后台数据库的首选,因为它对非商业应用是免费的.网站开发者可以搭建一个”Linux+Apache+PHP+MySql”平台,这是一个最省钱的高效平台.在使用MySql进行开发时,MySql自带的文档对于新手来说是份很好的参考资料.本文是我在使用MySql中的小小心得。
当前一般用户的开发环境多是Windows或Linux,用户可以到http://www.codepub.com/software/index.html下载相关版本进行安装,在windows中MySql以服务形式存在,在使用前应确保此服务已经启动,未启动可用netstartmysql命令启动。而Linux中启动时可用“/etc/rc.d/init.d/mysqldstart”命令,注意启动者应具有管理员权限。
刚安装好的MySql包含一个含空密码的root帐户和一个匿名帐户,这是很大的安全隐患,对于一些重要的应用我们应将安全性尽可能提高,在这里应把匿名帐户删除、root帐户设置密码,可用如下命令进行:
| usemysql;deletefromUserwhereUser=”";updateUsersetPassword=PASSWORD(’newpassword’)whereUser=’root’; |
如果要对用户所用的登录终端进行限制,可以更新User表中相应用户的Host字段,在进行了以上更改后应重新启动数据库服务,此时登录时可用如下类似命令:
| mysql-uroot-p;mysql-uroot-pnewpassword;mysqlmydb-uroot-p;
mysqlmydb-uroot-pnewpassword; |
上面命令参数是常用参数的一部分,详细情况可参考文档。此处的mydb是要登录的数据库的名称。
在进行开发和实际应用中,用户不应该只用root用户进行连接数据库,虽然使用root用户进行测试时很方便,但会给系统带来重大安全隐患,也不利于管理技术的提高。我们给一个应用中使用的用户赋予最恰当的数据库权限。如一个只进行数据插入的用户不应赋予其删除数据的权限。MySql的用户管理是通过User表来实现的,添加新用户常用的方法有两个,一是在User表插入相应的数据行,同时设置相应的权限;二是通过GRANT命令创建具有某种权限的用户。其中GRANT的常用用法如下:
| grantallonmydb.*toNewUserName@HostNameidentifiedby”password”;grantusageon*.*toNewUserName@HostNameidentifiedby”password”;grantselect,insert,updateonmydb.*toNewUserName@HostNameidentifiedby”password”;
grantupdate,deleteonmydb.TestTabletoNewUserName@HostNameidentifiedby”password”; |
若要给此用户赋予他在相应对象上的权限的管理能力,可在GRANT后面添加WITHGRANTOPTION选项。而对于用插入User表添加的用户,Password字段应用PASSWORD函数进行更新加密,以防不轨之人窃看密码。对于那些已经不用的用户应给予清除,权限过界的用户应及时回收权限,回收权限可以通过更新User表相应字段,也可以使用REVOKE操作。
下面给出本人从其它资料获得的对常用权限的解释:
全局管理权限:
FILE:在MySQL服务器上读写文件。
PROCESS:显示或杀死属于其它用户的服务线程。
RELOAD:重载访问控制表,刷新日志等。
SHUTDOWN:关闭MySQL服务。
数据库/数据表/数据列权限:
Alter:修改已存在的数据表(例如增加/删除列)和索引。
Create:建立新的数据库或数据表。
Delete:删除表的记录。
Drop:删除数据表或数据库。
INDEX:建立或删除索引。
Insert:增加表的记录。
Select:显示/搜索表的记录。
Update:修改表中已存在的记录。
特别的权限:
ALL:允许做任何事(和root一样)。
USAGE:只允许登录–其它什么也不允许做。
最后给出本人在RedHat9.0下的MySql操作演示:
选用数据库的root用户登录
| [weiwen@weiwenlinux]$mysql-uroot-pEnterpassword:MyPasswordmysql>createdatabasemydb;
QueryOK,1rowaffected(0.02sec) mysql>usemydb; Databasechanged mysql>createtableTestTable(Idintaut_incrementprimarykey, UserNamevarchar(16)notnull, Addressvarchar(255)); QueryOK,0rowsaffected(0.02sec) mysql>grantallonmydb.*totest@localhostidentifiedby”test”; QueryOK,0rowsaffected(0.01sec) mysql>quit Bye [weiwen@weiwenlinux]$mysqlmydb-utest-ptest |
其中test.sql是用vi编辑好的SQL脚本,其内容为:
| InsertintoTestTable(UserName,Address)values(’Tom’,’shanghai’);InsertintoTestTable(UserName,Address)values(’John’,'beijing’);select*fromTestTable; |
运行已经编辑好的SQL脚本可以用sourcefilename或.filename。
以上只是对新手的简单练习,要成为一个数据库好手,当以孜孜不倦地追求知识,不断地思考、尝试、再思考。
。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。
MySql常用命令总结
这两天搞个网站,又用到MySql,可是命令却一个都想不起来,所以,趁这次机会,把这些整理一下,权当作笔记吧,以便自己以后查阅!
1:使用SHOW语句找出在服务器上当前存在什么数据库:
| mysql>SHOWDATABASES; |
2:2、创建一个数据库MYSQLDATA
| mysql>CreateDATABASEMYSQLDATA; |
3:选择你所创建的数据库
| mysql>USEMYSQLDATA;(按回车键出现Databasechanged时说明操作成功!) |
4:查看现在的数据库中存在什么表
| mysql>SHOWTABLES; |
5:创建一个数据库表
| mysql>CreateTABLEMYTABLE(nameVARCHAR(20),sexCHAR(1)); |
6:显示表的结构:
| mysql>DESCRIBEMYTABLE; |
7:往表中加入记录
| mysql>insertintoMYTABLEvalues(”hyq”,”M”); |
8:用文本方式将数据装入数据库表中(例如D:/mysql.txt)
| mysql>LOADDATALOCALINFILE”D:/mysql.txt”INTOTABLEMYTABLE; |
9:导入.sql文件命令(例如D:/mysql.sql)
| mysql>usedatabase; mysql>sourced:/mysql.sql; |
10:删除表
| mysql>dropTABLEMYTABLE; |
11:清空表
| mysql>deletefromMYTABLE; |
12:更新表中数据
| mysql>updateMYTABLEsetsex=”f”wherename=’hyq’; |
- 03
- 九月
Linux服务器 Grep命令详解
Linux服务器 Grep命令详解
1. grep简介
grep (global search regular expression(RE) and print out the line,全面搜索正则表达式并把行打印出来)是一种强大的文本搜索工具,它能使用正则表达式搜索文本,并把匹配的行打印出来。Unix的grep家族包括grep、 egrep和fgrep。egrep和fgrep的命令只跟grep有很小不同。egrep是grep的扩展,支持更多的re元字符, fgrep就是 fixed grep或fast grep,它们把所有的字母都看作单词,也就是说,正则表达式中的元字符表示回其自身的字面意义,不再特殊。linux 使用GNU版本的grep。它功能更强,可以通过-G、-E、-F命令行选项来使用egrep和fgrep的功能。
grep的工作方式是这样的,它在一个或多个文件中搜索字符串模板。如果模板包括空格,则必须被引用,模板后的所有字符串被看作文件名。搜索的结果被送到屏幕,不影响原文件内容。
grep可用于shell脚本,因为grep通过返回一个状态值来说明搜索的状态,如果模板搜索成功,则返回0,如果搜索不成功,则返回1,如果搜索的文件不存在,则返回2。我们利用这些返回值就可进行一些自动化的文本处理工作。
2. grep正则表达式元字符集(基本集)
^
锚定行的开始 如:’^grep’匹配所有以grep开头的行。
$
锚定行的结束 如:’grep$’匹配所有以grep结尾的行。
匹配一个非换行符的字符 如:’gr.p’匹配gr后接一个任意字符,然后是p。
*
匹配零个或多个先前字符 如:’*grep’匹配所有一个或多个空格后紧跟grep的行。 .*一起用代表任意字符。
[]
匹配一个指定范围内的字符,如’[Gg]rep’匹配Grep和grep。
[^]
匹配一个不在指定范围内的字符,如:’[^A-FH-Z]rep’匹配不包含A-R和T-Z的一个字母开头,紧跟rep的行。
\(..\)
标记匹配字符,如’\(love\)’,love被标记为1。
\<
锚定单词的开始,如:’\\>
锚定单词的结束,如’grep\>’匹配包含以grep结尾的单词的行。
x\{m\}
重复字符x,m次,如:’0\{5\}’匹配包含5个o的行。
x\{m,\}
重复字符x,至少m次,如:’o\{5,\}’匹配至少有5个o的行。
x\{m,n\}
重复字符x,至少m次,不多于n次,如:’o\{5,10\}’匹配5–10个o的行。
\w
匹配文字和数字字符,也就是[A-Za-z0-9],如:’G\w*p’匹配以G后跟零个或多个文字或数字字符,然后是p。
\W
\w的反置形式,匹配一个或多个非单词字符,如点号句号等。
\b
单词锁定符,如: ‘\bgrepb\’只匹配grep。
3. 用于egrep和 grep -E的元字符扩展集
+
匹配一个或多个先前的字符。如:’[a-z]+able’,匹配一个或多个小写字母后跟able的串,如loveable,enable,disable等。
?
匹配零个或多个先前的字符。如:’gr?p’匹配gr后跟一个或没有字符,然后是p的行。
a|b|c
匹配a或b或c。如:grep|sed匹配grep或sed
()
分组符号,如:love(able|rs)ov+匹配loveable或lovers,匹配一个或多个ov。
x{m},x{m,},x{m,n}
作用同x\{m\},x\{m,\},x\{m,n\}
4. POSIX字符类
为了在不同国家的字符编码中保持一至,POSIX(The Portable Operating System Interface)增加了特殊的字符类,如[:alnum:]是A-Za-z0-9的另一个写法。要把它们放到[]号内才能成为正则表达式,如[A- Za-z0-9]或[[: alnum:]]。在linux下的grep除fgrep外,都支持POSIX的字符类。
[:alnum:]
文字数字字符
[:alpha:]
文字字符
[:digit:]
数字字符
[:graph:]
非空字符(非空格、控制字符)
[:lower:]
小写字符
[:cntrl:]
控制字符
[:print:]
非空字符(包括空格)
[:punct:]
标点符号
[:space:]
所有空白字符(新行,空格,制表符)
[:upper:]
大写字符
[:xdigit:]
十六进制数字(0-9,a-f,A-F)
5. Grep命令选项
-?
同时显示匹配行上下的?行,如:grep -2 pattern filename同时显示匹配行的上下2行。
-b,–byte-offset
打印匹配行前面打印该行所在的块号码。
-c,–count
只打印匹配的行数,不显示匹配的内容。
-f File,–file=File
从文件中提取模板。空文件中包含0个模板,所以什么都不匹配。
-h,–no-filename
当搜索多个文件时,不显示匹配文件名前缀。
-i,–ignore-case
忽略大小写差别。
-q,–quiet
取消显示,只返回退出状态。0则表示找到了匹配的行。
-l,–files-with-matches
打印匹配模板的文件清单。
-L,–files-without-match
打印不匹配模板的文件清单。
-n,–line-number
在匹配的行前面打印行号。
-s,–silent
不显示关于不存在或者无法读取文件的错误信息。
-v,–revert-match
反检索,只显示不匹配的行。
-w,–word-regexp
如果被\<和\>引用,就把表达式做为一个单词搜索。
-V,–version
显示软件版本信息。
6. 实例
要用好grep这个工具,其实就是要写好正则表达式,所以这里不对grep的所有功能进行实例讲解,只列几个例子,讲解一个正则表达式的写法。
$ ls -l | grep ‘^a’
通过管道过滤ls -l输出的内容,只显示以a开头的行。
$ grep ‘test’ d*
显示所有以d开头的文件中包含test的行。
$ grep ‘test’ aa bb cc
显示在aa,bb,cc文件中匹配test的行。
$ grep ‘[a-z]\{5\}’ aa
显示所有包含每个字符串至少有5个连续小写字符的字符串的行。
$ grep ‘w\(es\)t.*\1′ aa
如果west被匹配,则es就被存储到内存中,并标记为1,然后搜索任意个字符(.*),这些字符后面紧跟着另外一个es(\1),找到就显示该行。如果用egrep或grep -E,就不用”\”号进行转义,直接写成’w(es)t.*\1′就可以了。
