Crontab实例

cron是一个linux下的定时执行工具,可以在无需人工干预的情况下运行作业。由于Cron 是Linux的内置服务,但它不自动起来,可以用以下的方法启动、关闭这个服务:

/sbin/service crond start //启动服务
/sbin/service crond stop //关闭服务
/sbin/service crond restart //重启服务
/sbin/service crond reload //重新载入配置

你也可以将这个服务在系统启动的时候自动启动:
在/etc/rc.d/rc.local这个脚本的末尾加上:
/sbin/service crond start

现在Cron这个服务已经在进程里面了,我们就可以用这个服务了,Cron服务提供以下几种接口供大家使用:

1、直接用crontab命令编辑

cron服务提供crontab命令来设定cron服务的,以下是这个命令的一些参数与说明:

crontab -u //设定某个用户的cron服务,一般root用户在执行这个命令的时候需要此参数
crontab -l //列出某个用户cron服务的详细内容
crontab -r //删除某个用户的cron服务
crontab -e //编辑某个用户的cron服务

比如说root查看自己的cron设置:crontab -u root -l
再例如,root想删除fred的cron设置:crontab -u fred -r
在编辑cron服务时,编辑的内容有一些格式和约定,输入:crontab -u root -e
进入vi编辑模式,编辑的内容一定要符合下面的格式:*/1 * * * * ls >> /tmp/ls.txt

这个格式的前一部分是对时间的设定,后面一部分是要执行的命令,如果要执行的命令太多,可以把这些命令写到一个脚本里面,然后在这里直接调用这个脚本就可以了,调用的时候记得写出命令的完整路径。时间的设定我们有一定的约定,前面五个*号代表五个数字,数字的取值范围和含义如下:

分钟 (0-59)
小時 (0-23)
日期 (1-31)
月份 (1-12)
星期 (0-6)//0代表星期天

除了数字还有几个个特殊的符号就是”*”、”/”和”-“、”,”,*代表所有的取值范围内的数字,”/”代表每的意思,”*/5″表示每5个单位,”-“代表从某个数字到某个数字,”,”分开几个离散的数字。以下举几个例子说明问题:

每天早上6点

0 6 * * * echo “Good morning.” >> /tmp/test.txt //注意单纯echo,从屏幕上看不到任何输出,因为cron把任何输出都email到root的信箱了。

每两个小时

0 */2 * * * echo “Have a break now.” >> /tmp/test.txt

晚上11点到早上8点之间每两个小时,早上八点

0 23-7/2,8 * * * echo “Have a good dream:)” >> /tmp/test.txt

每个月的4号和每个礼拜的礼拜一到礼拜三的早上11点

0 11 4 * 1-3 command line

1月1日早上4点

0 4 1 1 * command line

每次编辑完某个用户的cron设置后,cron自动在/var/spool/cron下生成一个与此用户同名的文件,此用户的cron信息都记录在这个文件中,这个文件是不可以直接编辑的,只可以用crontab -e 来编辑。cron启动后每过一份钟读一次这个文件,检查是否要执行里面的命令。因此此文件修改后不需要重新启动cron服务。

2、编辑/etc/crontab 文件配置cron

cron服务每分钟不仅要读一次/var/spool/cron内的所有文件,还需要读一次/etc/crontab,因此我们配置这个文件也能运用 cron服务做一些事情。用crontab配置是针对某个用户的,而编辑/etc/crontab是针对系统的任务。此文件的文件格式是:

SHELL=/bin/bash

PATH=/sbin:/bin:/usr/sbin:/usr/bin

MAILTO=root //如果出现错误,或者有数据输出,数据作为邮件发给这个帐号

HOME=/ //使用者运行的路径,这里是根目录

# run-parts

01 * * * * root run-parts /etc/cron.hourly //每小时执行/etc/cron.hourly内的脚本
02 4 * * * root run-parts /etc/cron.daily //每天执行/etc/cron.daily内的脚本
22 4 * * 0 root run-parts /etc/cron.weekly //每星期执行/etc/cron.weekly内的脚本
42 4 1 * * root run-parts /etc/cron.monthly //每月去执行/etc/cron.monthly内的脚本

大家注意”run-parts”这个参数了,如果去掉这个参数的话,后面就可以写要运行的某个脚本名,而不是文件夹名了。
————————————–

基本格式 :
*  *  *  *  *  command
分 时 日 月 周 命令

第1列表示分钟1~59 每分钟用*或者 */1表示
第2列表示小时1~23(0表示0点)
第3列表示日期1~31
第4列表示月份1~12
第5列标识号星期0~6(0表示星期天)
第6列要运行的命令

crontab文件的一些例子:

30 21 * * * /usr/local/etc/rc.d/lighttpd restart
上面的例子表示每晚的21:30重启lighttpd 。

45 4 1,10,22 * * /usr/local/etc/rc.d/lighttpd restart
上面的例子表示每月1、10、22日的4 : 45重启lighttpd 。

10 1 * * 6,0 /usr/local/etc/rc.d/lighttpd restart
上面的例子表示每周六、周日的1 : 10重启lighttpd 。

0,30 18-23 * * * /usr/local/etc/rc.d/lighttpd restart
上面的例子表示在每天18 : 00至23 : 00之间每隔30分钟重启lighttpd 。

0 23 * * 6 /usr/local/etc/rc.d/lighttpd restart
上面的例子表示每星期六的11 : 00 pm重启lighttpd 。

* */1 * * * /usr/local/etc/rc.d/lighttpd restart
每一小时重启lighttpd

* 23-7/1 * * * /usr/local/etc/rc.d/lighttpd restart
晚上11点到早上7点之间,每隔一小时重启lighttpd

0 11 4 * mon-wed /usr/local/etc/rc.d/lighttpd restart
每月的4号与每周一到周三的11点重启lighttpd

0 4 1 jan * /usr/local/etc/rc.d/lighttpd restart
一月一号的4点重启lighttpd

原文:http://www.cublog.cn/u/31547/showart_438018.html

QuickWeb VPS设置及数据备份

解决apache乱码问题
环境安装好后,运行GBK编码的网站,你会发现网页显示的是乱码,因为apache的默认配置是utf-8
修改apache的配置文件/etc/httpd/conf/httpd.conf

1
AddDefaultCharset UTF-8

改为

1
AddDefaultCharset off

或者修改.htaccess文件,加如下代码(也可以直接用你的网站编码,如:GBK)

1
AddDefaultCharset off

让apache支持.htaccess
修改apache的配置文件/etc/httpd/conf/httpd.conf

1
2
3
4
<Directory />
  Options FollowSymLinks
  AllowOverride None
</Directory>

改为

1
2
3
4
<Directory />
  Options FollowSymLinks
  AllowOverride All
</Directory>

注意修改httpd.conf要重启apache

1
/etc/init.d/httpd reload

备份数据库及网站文件脚本

1
vi /home/backup.sh
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
#! /bin/php

# MYSQL Setup
DUMP=mysqldump
DBUSER=USER
DBPASS=PASS

# Backup Path
DATADIR=/home/wwwroot
BAKDIR=/home/backup
DATETIME=$(date -d now +%Y%m%d)

# FTP Setup
FTPHOST=HOST
FTPUSER=USER
FTPPASS=PASS

# MKDIR
if [ ! -d $BAKDIR ]; then
 mkdir -p $BAKDIR
fi

# DEL Backup
rm -fr $BAKDIR/data_*.gz

# Backup MYSQL
$DUMP -u$DBUSER -p$DBPASS --all-databases --lock-all-tables | gzip > $BAKDIR/data_mysql_$DATETIME.sql.gz

# Backup Files
tar czPf $BAKDIR/data_files_$DATETIME.tar.gz $DATADIR

# Put data
ftp -n $FTPHOST << EOF
user $FTPUSER $FTPPASS
type binary
put data_mysql_*.gz
put data_files_*.gz
close
quit
EOF

其中的用户名和密码以及备份的路径都改成你网站的。
在SSH中执行

1
2
cd /home
./backup.sh

就会自动备份数据库及网站文件到你设定的另一个FTP上去

我们还可以设置自动运行这段脚本,让它在每个星期的3和7自动备份

1
2
crontab –e
0 0 * * 3,7 /bin/php /home/backup.sh

数据库恢复

1
mysqldump -u用户名 -p密码 -h主机 数据库 < 路径

例如:

1
mysql -uUSER -pPASS DBNAME < /home/backup/bak.sql

VPS LAMP环境安装可参考QuickWeb VPS之LAMP环境安装
VPS FTP及PHPMyAdmin安装可参考QuickWeb VPS之vsftpd,phpmyadmin安装
crontab的用法可以看Crontab实例

替换coolcode代码高亮插件为wp-syntax

终于把coolcode代码高亮插件替换为wp-syntax,wp-syntax 使用简单,显示方式简洁,视觉感官利落,对W3C也友好。

首先下载安装好wp-syntax,激活插件。
进入PHPMYADMIN替换原来coolcode的插件代码

1
2
UPDATE `wp_posts` SET `post_content` = replace (`post_content`,'<coolcode','<pre');
UPDATE `wp_posts` SET `post_content` = replace (`post_content`,'</coolcode','</pre');

wp-syntax是用以下代码,设置对应参数来完成 wp-syntax 高亮代码显示的,编辑文章时,选择HTML模式下
<pre lang=”LANGUAGE” line=”1″>要显示的代码</pre>
相关参数说明:
lang=”LANGUAGE”,在language处填写你要运行的代码语言,如css、php、html、javascript等;
line=”1″,1表示代码从第一行开始显示,可以不写,不写为全部显示。

wp-syntax 还支持下面代码:
abap, actionscript, actionscript3, ada, apache, applescript, aptsources, asm, asp, autoit, avisynth, bash, bf, blitzbasic, bnf, boo, c, cmac, caddcl, cadlisp, cil, cfdg, cfm, cobol, cpp-qt, cpp, csharp, css, d, dcs, delphi, diff, div, dos, dot, eiffel, email, fortran, freebasic, genero, gettext, glsl, gml, bnuplot, groovy, haskell, hq9plus, html4strict, idl, ini, inno, intercal, io, java, java5, javascript, kixtart, klonec, klonecpp, latex, lisp, locobasic, lolcode lotusformulas, lotusscript, lscript, lsl2, lua, m68k, make, matlab, mirc, modula3, mpasm, mxml, mysql, nsis, oberon2, objc, ocaml-brief, ocaml, oobas, oracle11, oracle8, pascal, per, pic16, pixelbender, perl, php-brief, php, plsql, povray, powershell, progress, prolog, providex, python, qbasic, rails, rebol, reg, robots, ruby, sas, scala, scheme, scilab, sdlbasic, smalltalk, smarty, sql, tcl, teraterm, text, thinbasic, tsql, typoscript, vb, vbnet, verilog, vhdl, vim, visualfoxpro, visualprolog, whitespace, winbatch, xml, xorg_conf, xpp, z80

如果你嫌每次都要切换到HTML模式,手工添加麻烦的话,你还可以利用WP-Syntax Button插件添加按钮到编辑框中。

eho.st免费空间PHP+MYSQL

2G/5G/PHP/MYSQL/LP/FTP/绑米/无广告/eho.st

FreeWebhosting Features:

* * FREE 2GB Disk Space
* * FREE 5GB Bandwidth
* * FREE Php5 support
* * FREE 10 mySQL DB’s
* * Pre-installed scripts
* * Incredible support
* * Powerful server network (100mbps port speed!)

* * No forced ads
* * Free web statistics (awstats)
* * Full FTP Access
* * Instant activation
* * Domain Name Support
* * yourname.eho.st
* * and so much more…
* server monitor
继续阅读

dreamhost空间MYSQL数据库备份方法

如何利用SSH(Shell)来备份和恢复MySQL数据库的方法
例如:
数据库参数为::
MySQL地址:mysql.dh.net
MySQL名称:mysql_dbname
MySQL用户:mysql_dbuser
MySQL密码:mysql_dbpass

我要把数据库备份为bak.sql

步骤:
同样,使用windows系统自己带的telnet或者去下载一个putty来,登陆以后,一路cd到自己觉得合适的目录下(确认当前目录可写).
输入下面的命令:
mysqldump -h mysql.dh.net -p mysql_dbname -u mysql_dbuser >bak.sql
然后回车,提示你输入数据库登陆密码,输入完密码后回车,OK! 就把数据库备份到当前目录下了

如何恢复bak.sql数据库:::
输入下面命令后回车
mysql -h mysql.dh.net -p mysql_dbname -u mysql_dbuser
提示你输入密码,输入密码后然后回车
会出现MySQL操作提示符号
然后输入下面的命令
source bak.sql
请先确认bak.sql这个文件再当前目录下
回车.OK,恢复ing…..

几个免费PHP+MySQL空间

9999mb.com
优点:
存储空间:10GB
空间流量:100GB/mo
顶级域名绑定:1个
MySQL数量:5个
数据库用户: 5个
管理: Panel管理,支持Web上传,Phpmyadmin管理数据库。
技术支持:7×24
缺点:
文件类型限制,常见的mp3/rar/zip文件无法上传。文件大小限定在750kb。有广告。
申请地址: www.9999mb.com

speqo.com
配置:
5 GB Disk Space
50 GB Bandwidth
50 MySQL Databases
50 Email Accounts
50 Subdomains
cPanel后台,一个顶级域名和50个2级域名绑定。
最重要的是,几乎没有FTP上传限制,并且不用放任何广告。
探针探出的服务器配置如下:
CPU个数: 4
类型:Dual Core AMD Opteron(tm) Processor 265 缓存:1024 KB
类型:Dual Core AMD Opteron(tm) Processor 265 缓存:1024 KB
类型:Dual Core AMD Opteron(tm) Processor 265 缓存:1024 KB
类型:Dual Core AMD Opteron(tm) Processor 265 缓存:1024 KB
物理内存:共 3964.17 M, 已使用 3674.98 M, 空闲 289.19 M, 使用率 92.7 %
申请地址: www.speqo.com

继续阅读

免费MySQL数据库

Db4free:专业提供免费数据库服务,支持 MySQL 5.0,5.1,支持使用Phpmyadmin进行管理,以后还将扩展支持PostgreSQL, Firebird 等数据库

如果你只有php空间没有mysql数据库支持,可以尝试db4free提供的服务,比较稳定,不过相对国内来讲速度不算快,可以拿来做测试用

Mysql+Apche+PHP+Phpmyadmin+Zend安装教程

一、安装Apache_2.0.53

1. 运行apache_2.0.53-win32-x86-no_ssl.msi
(1) Network domain和Server Name:网站的domain name,例www.aaa.com.cn,推荐填localhost,server name也为 localhost,类推。
(2) Administrator’s Email Address:管理者电子邮件。
(3) 选for All Users, on port 80, as a Service。(对本机所有用户有效)
(4) The installation type:选typical。
(5) Where to install:最好选默认安装,以后会省很多麻烦:
c:\Program Files\Apache Group\,然后开始安装。(如果你装了如瑞星等防火墙软件,最好这时待在电脑旁,否则防火墙会弹出是否允许Apache访问网络的选项,不点则自动读秒后默认为阻止,记得点是。)
安装完成,桌面右下角系统栏会出现Apache图标,开启状态应有绿色小箭头)。在浏览器输入http://localhost/http://127.0.0.1/,会出现带Apcache羽毛标志的欢迎信息,说明安装成功。

下面开始进行设置:
进入C:\Program Files\Apache Group\Apache2\conf\目录,用记事本打开httpd.conf文件:(别象我一样被N多设置吓住,如果你想速成,那么带#的句子其实你可以直接跳过不看,直接用记事本搜索相关内容更改。用#标注的都是对该项设置的注释说明文件,要修改的正文通常在注释的下面点,如果你E文凑合或者有合适电子字典,你会发现大部分句子也能读懂,)

继续阅读