|  | 
| 3. Crontab 定时执行任务
 
 在DreamHost系统下, 通过Shell可以建立自己的crontab. 具体使用如下:
 使用支持shell登录的终端(如fterm或putty), 地址栏输入 [email protected]:22即可以SSH方式登录至服务器.
 
 常用的crontab命令:
 crontab -l 显示所有现存cron job.
 
 crontab -r 删除当前cron jobs.
 
 crontab -e 编辑当前 “crontab file”. DH推荐使用nano
 
 注意你的crontab包含所有的cron jobs, 每个cron一行, 断行结尾. 一个正常的cron如下所示:
 
 45 2 * * * /home/user/script.pl
 第一个数字是每小时的第几分钟,
 第二个数字是每天的第几小时,
 第三个数字是每月的第几天,
 第四个数字是每年的第几月,
 第五个数字是每周的第几天.
 
 使用方式例如:
 32 * * * * : 表示每小时的第32分钟.
 12,42 * * * * : 表示每小时的第12及第42分钟两次
 */15 */2 * * *: 表示0:00, 0:15, 0:30, 0:45, 2:00, 2:15, 2:30, …
 43 18 * * 7: 表示每个周日的6:43pm运行命令行.
 
 在DreamHost下使用nano编辑完文件后,使用ctrl+o保存,ctrl+x退出编辑。
 
 4. tar命令
 tar命令的使用方法如下:
 
 tar [参数列表] [文件名]
 
 参数列表:
 -c 生成新的备份,并同时覆盖旧的备份文件
 -x 从备份文件中解压缩
 -t 列出备份文件内的文件目录
 -v 显示所有被操作文件列表
 -f 在指定位置生成备份
 -u 将不存在于备份中的文件,或将已经被更改的文件加入该备份中。
 
 举例说明:
 tar cvf filename.tar /*制作备份*/
 tar cvf tarfile.tar ./filename /*将filename的文件备份到tarfile.tar里面*/
 tar tvf filename.tar /*列出tar文档的内容*/
 tar xvf filename.tar /*从tar文档中导出文件*/
 tar zxpvf filename.tar.gz /*从tar.gz文档中导出文件*/
 tar zxvf filename.tar.gz /*同上*/
 tar xvf tarfile.tar ./filename /*导出tar文件中的单个文件*/
 
 5. vi编辑器
 Linux下很易用的一种编辑器,只需要稍微知道几个指令即可应用。
 
 打开vi:
 $vi [filename]:打开或新建文件,并将光标置于第一行首
 $vi +n [filename] :打开文件,并将光标置于第n行首
 $vi + [filename] :打开文件,并将光标置于最后一行首
 $vi +/pattern [filename]:打开文件,并将光标置于第一个与pattern匹配的串处
 $vi -r [filename] :在上次正用vi编辑时发生系统崩溃,恢复filename
 $vi [filename]….[filename] :打开多个文件,依次编辑
 
 如果filename不存在,则自动生成一个名字filename的新文件。
 
 vi共有两种状态:命令状态/编辑状态
 
 编辑状态下:
 第一次按下insert键为”insert”模式,再按一下为”replace”模式,使用ESC返回命令状态;
 在此状态下键盘的PgUp/PgDn/Insert/Delete/Home/End/方向键,均处于正常功能状态。
 
 命令状态下:
 输入的字符串作为命令处理,使用”insert”键切换到编辑状态;
 以下是命令状态下的命令清单:
 
 移动光标类命令
 h :光标左移一个字符
 l :光标右移一个字符
 space:光标右移一个字符
 Backspace:光标左移一个字符
 k或Ctrl+p:光标上移一行
 j或Ctrl+n :光标下移一行
 Enter :光标下移一行
 w或W :光标右移一个字至字首
 b或B :光标左移一个字至字首
 e或E :光标右移一个字j至字尾
 ) :光标移至句尾
 ( :光标移至句首
 }:光标移至段落开头
 {:光标移至段落结尾
 nG:光标移至第n行首
 n+:光标下移n行
 n-:光标上移n行
 n$:光标移至第n行尾
 H :光标移至屏幕顶行
 M :光标移至屏幕中间行
 L :光标移至屏幕最后行
 0:(注意是数字零)光标移至当前行首
 $:光标移至当前行尾
 
 屏幕翻滚类命令
 Ctrl+u:向文件首翻半屏
 Ctrl+d:向文件尾翻半屏
 Ctrl+f:向文件尾翻一屏
 Ctrl+b;向文件首翻一屏
 nz:将第n行滚至屏幕顶部,不指定n时将当前行滚至屏幕顶部。
 
 插入文本类命令
 i :在光标前
 I :在当前行首
 a:光标后
 A:在当前行尾
 o:在当前行之下新开一行
 O:在当前行之上新开一行
 r:替换当前字符
 R:替换当前字符及其后的字符,直至按ESC键
 s:从当前光标位置处开始,以输入的文本替代指定数目的字符
 S:删除指定数目的行,并以所输入文本代替之
 ncw或nCW:修改指定数目的字
 nCC:修改指定数目的行
 
 删除命令
 ndw或ndW:删除光标处开始及其后的n-1个字
 do:删至行首
 d$:删至行尾
 ndd:删除当前行及其后n-1行
 x或X:删除一个字符,x删除光标后的,而X删除光标前的
 Ctrl+u:删除输入方式下所输入的文本
 
 搜索及替换命令 :
 /pattern:从光标开始处向文件尾搜索pattern
 ?pattern:从光标开始处向文件首搜索pattern
 n:在同一方向重复上一次搜索命令
 N:在反方向上重复上一次搜索命令
 :s/p1/p2/g:将当前行中所有p1均用p2替代
 :n1,n2s/p1/p2/g:将第n1至n2行中所有p1均用p2替代
 :g/p1/s//p2/g:将文件中所有p1均用p2替换
 
 选项设置
 all:列出所有选项设置情况
 term:设置终端类型
 ignorance:在搜索中忽略大小写
 list:显示制表位(Ctrl+I)和行尾标志($)
 number:显示行号
 report:显示由面向行的命令修改过的数目
 terse:显示简短的警告信息
 warn:在转到别的文件时若没保存当前文件则显示NO write信息
 nomagic:允许在搜索模式中,使用前面不带“\”的特殊字符
 nowrapscan:禁止vi在搜索到达文件两端时,又从另一端开始
 mesg:允许vi显示其他用户用write写到自己终端上的信息
 
 最后行方式命令
 :n1,n2 co n3:将n1行到n2行之间的内容拷贝到第n3行下
 :n1,n2 m n3:将n1行到n2行之间的内容移至到第n3行下
 :n1,n2 d :将n1行到n2行之间的内容删除
 :w :保存当前文件
 :e filename:打开文件filename进行编辑
 :x:保存当前文件并退出
 :q:退出vi
 :q!:不保存文件并退出vi
 :!command:执行shell命令command
 :n1,n2 w!command:将文件中n1行至n2行的内容作为command的输入并执行之,若不指
 定n1,n2,则表示将整个文件内容作为command的输入
 :r!command:将命令command的输出结果放到当前行 。Adminis
 
 Post in LAMP | No Comments »
 
 mysql的一些乱七八糟的东西
 01月 27th, 2008
 mysql的一些乱七八糟的东西 使用MYSQL半年,自己经常用的东西- -
 
 Mysql –h192.168.0.110 –uks –p –P4444登录
 
 Mysqladmin –h192.168.0.110-uks –p reload重新加载用户表
 
 Mysqldump –R –h192.168.0.110 –uks –p test>c:/test.sql备份
 
 Mysql –h192.168.0.110 –uks –p test
 Windows下net stop mysql关闭服务
 
 Net start mysql 开启服务
 
 Linux下 service mysql stop关闭
 
 Service mysql start 开启
 
 Service mysql restart重启服务
 
 Linux下开机自动启动mysql
 
 #>chkconfig –add mysql 开机启动
 
 Chkconfig –del mysql 关闭自动启动
 
 Chkconfig – -list 查看服务启动情况
 
 Mysql命令行下
 
 Explain select……..查看该SELECT语句信息
 
 Show variables查看系统变量
 
 Show status 常看当前服务器状态
 
 Show databases;
 
 Show tables;
 
 Show processlist
 
 Show warnings;(查看最近一个警告或错误)
 
 Set global xxxx=xxxx;
 
 Flush ……清楚mysql使用的部分内部缓存
 
 Information_schema.tables表信息
 
 Mysql动态语句5.1
 
 只支持create table,delete,do ,insert,replace,select set ,update语句
 
 Describe tablename查看该表结构
 
 Optimize table XXX 清理该表中已删除的链接(可以释放一些资源)
 
 Source c:abc.sql 在MYSQL命令行中执行脚本
 
 Select
 
 Create
 
 Insert
 
 Update
 
 Alter
 
 Grant
 
 revoke
 
 就不说了= =
 
 Mysql 数据库名最长 64位字符串
 
 表名….. 64位字符串
 
 字段名……. 64位字符串
 
 用户名…….. 16位字符串
 
 密码……… 貌似没限制
 
 Handler(很牛X的东东)
 
 Handler testt open as abc;
 
 Handler abc read id=(123456);
 
 Handler abc close;
 
 Benchmark(n,expr)执行N次EXPR并测算时间
 
 Post in LAMP | No Comments »
 
 MYSQL在命令行创建存储过程
 01月 27th, 2008
 MYSQL在命令行创建存储过程 如何在MYSQL命令行创建存储过程
 
 今天早上在百度知道碰到这个问题,我开始没看明白…….后来才知道提问人的意思是要在命令行下创建存储过程。很感谢这个问题,因为我也不会呵呵,我一直都用EMS创建这些东西…….
 
 我也尝试了一些方法,但是第一个分号mysql就以为语句结束了,就拿那个例子来说:
 
 CREATE PROCEDURE p7 (IN b INTEGER(12))
 
 begin
 
 declare a INTEGER(12);
 
 set a=5;
 
 INSERT INTO t VALUES (a);
 
 SELECT s1*a FROM t WHERE b<=s1;
 
 End
 
 这个存储过程,在命令行直接创建的话,在第三排你输入分号后就报错了……因为MYSQL以为这个语句结束了,那对于MYSQL而言
 
 CREATE PROCEDURE p7 (IN b INTEGER(12))
 
 begin
 
 declare a INTEGER(12);
 
 肯定是个错误语句。
 
 然后看了些东西,原来要加分隔符- -……….
 
 DELIMITER //
 
 CREATE PROCEDURE p7 (IN b INTEGER(12))
 
 begin
 
 declare a INTEGER(12);
 
 set a=5;
 
 INSERT INTO t VALUES (a);
 
 SELECT s1*a FROM t WHERE b<=s1;
 
 End
 
 //
 
 就OK了…………意思就是说在//……//之间的当成一个语句执行所以MYSQL接到的才是这个存储过程完整的创建语句。
 
 Post in LAMP | No Comments »
 
 
 | 
 |