LAMP服务器的简单备份方法

我用CentOS作为网站服务器的OS,我是这样备份我的网站的。

以下简称网站服务器为C,我的电脑是A。首先,在C上用一段shell script备份网站:

backup.sh

#! /bin/bash
# This script is to backup the website files and db

mysqldump mydb -pmypass >/var/www/mysite/mydump.sql

datestamp=`date +%Y%m%d`
filewww=”/home/myuser/backup/mysite_””$datestamp””.zip”

zip -r $filewww /var/www/mysite

然后可以先运行一下这个script,看看结果是否符合预期。如果没问题,就可以将其加入到crontab了,每天自动运行。

59 3 * * * /bin/bash /home/myuser/backup.sh

这样C这边每天凌晨会备份一次并生成一个zip压缩包。但是把C的备份留在C就没意义了,我还要定期的把zip从C传到A。由于A不像C那样不间断运行的,所以如果从C向A传输就需要测试A是否在线,麻烦。不如让A取C上的zip。这就涉及到另一个问题,身份验证。

为一段自动运行的script提供password,我觉得不如使用public key验证来得专业,而且简单,两步就搞定:

ssh-keygen -t rsa

ssh-copy-id -i .ssh/id_rsa.pub [email protected]

这期间问到private key password时直接回车就行了;[email protected]的password还是需要输入的(否则……)。

下一步就是在A上写script,获取C上的备份,成功获取后删除C上的备份,并将A本机上超过一个月的备份删除。

backup-mysite.sh

#!/bin/bash
#by Raymond, Jun, 2009
#1, get backup files from …
#2, delete after a successful copy
scp [email protected]:/home/myuser/backup/*.zip /home/myuser/backup
if [ $? -eq 0 ]
then
ssh [email protected] rm /home/myuser/backup/*.zip
fi

#3, delete old backup files here
find /home/myuser/backup/*.zip -mtime +30 -exec rm {} \;

最后在把此script添加到A的crontab基本就没事了。过程类似上面的crontab,就偷懒不写了。注:懒是SA的美德。

Update: mysqldump –opt 对于恢复数据是个很好的开关.

Python+Django笔记之二

一个简单的select * 操作的Django方式:

首先配置urls.py

from django.conf.urls.defaults import *
from misc import views

urlpatterns = patterns(‘ ‘,
(r’^notes/$’, views.list_notes),
)

其中r’^notes/$’是regex,用于匹配url;views.list_notes是views.py中的list_notes 方法。

然后写list_notes:

def list_notes(request):
notes = Note.objects.order_by(‘-created_date’)
conduit = {
‘notes’: notes
}
return render_to_response(
‘misc/list.html’,
conduit,
context_instance = RequestContext(request),
)

其中conduit这个词来自Mass Effect 🙂

最后就是把上面的misc/list.html写出来:

{% extends “base.html” %}

{% block title %}List Notes – {{ block.super }}{% endblock %}

{% block body %}
{% if notes %}
<ul>
{% for note in notes %}
<li>{{ note.created_date }} : {{ note.message }}</li>
{% endfor %}
</ul>
{% else %}
<p>No notes yet.</p>
{% endif %}
{% endblock %}

这样用浏览器访问类似http://localhost:8000/app/notes的url时,全部notes应该就列出来了,并按时间倒序排列。

OpenOffice 3.0

昨天我突然想看看MS Office的Volume License是怎么个规则,于是我去下载常见问题的文档。结果很滑稽:此FAQ文档是MS Office 2007的DOCX格式!看来微软认为我应该先买Office,然后再问问题。

好在OpenOffice.org 3.0(简称OOo)刚刚发布,支持MS Office 07格式。于是我用OOo看了MS的FAQ:

补充:OOo3安装包只有140MB,功能一点不差!包括以下模块:

  • OOo Base,对应MS Access数据库
  • OOo Calc,对应MS Excel电子表格
  • OOo Draw,对应MS Visio流程图
  • OOo Impress,对应MS PowerPoint幻灯片
  • OOo Math,好像MS Office没有,是写数学公式的工具
  • OOo Writer,对应MS Word字处理

希望能在公司推广开来