Differences between revisions 2 and 3
Revision 2 as of 2009-01-04 09:01:37
Size: 5200
Editor: ZoomQuiet
Comment:
Revision 3 as of 2009-01-04 09:03:05
Size: 5200
Editor: ZoomQuiet
Comment:
Deletions are marked like this. Additions are marked like this.
Line 13: Line 13:
= KSPEG版~GgoogleGroup2mailam = = KSPEG版:GgoogleGroup2mailam =

TableOfContents

Include(ZPyUGnav)

http://foto.zoomquiet.org/logo/kspeg-logo-v0.6-72.png

KSPEG版:GgoogleGroup2mailam

  • 文档属主: jessinio
  • 版本历史:
    • v0.5~090104 创立;ZoomQuiet 迁移到啄木鸟维基

gg迁移需求

内部啓用了maillist服务, 需要把过去的在googlegroups中的邮件迁移回公司内部.

分析

数据的回源

迁移指定的googlegroups本应该对指定的服务索取数据的, 但现在googlegroups不提供API级的解决方案.

对于此问题, 可见如下讨论URL:

就目前的情况分析, 相应的有其它三种解决:

  1. 对web页面抓取, 取出相应的数据
  2. 对RSS的定阅, xml的数据抓取
  3. gmail的Email邮件download.

前两条总体是: xml格式 -> email格式, 非常麻烦, 或者工作量较大.

走gmail路线可以直接取得email格式数据. 但存在缺点:

  • 邮件的不完整性

决定迁移采取gmail的路线

数据的组织

将googlegroups数据迁移到公司的maillist(具体为mailman软件), 可以走如下路线:

  1. email格式文件 -> MDA

  2. email格式文件 -> mailman的归递程序

这里都需要对从googlegroups得到的email格式文件(具体说是从gmail从得到)需要做如下工作:

  1. 对email文件的排序
  2. 对eamil文件的重新整理
    • 如果使用email格式文件 -> MDA的方法,那就需要先在maillist中增加邮件中From的地址, 否则maillist不接收的

    • 请把mailman的require_explicit_destination设置为False
  3. 对于email格式文件 -> mailman的归递程序, 需要为每份email文件伪造类似如下的一文件头字符串:

实际迁移方法

如下两部分使用到自个写的python脚本:

  • attachment:migrate_gg_v0.1.py

使用gmail的Email

如下是脚本的交互过程:

what can I do for you?
d/D: download email to localhost mbox format
s/S: send localhost mbox file to MDA
m/M: make mbox file which can be use be maillist software
  • 首先要下载gmail的email文件, 选项d

which are your choice?d

User Name: richard.liao.i
  • 请使用拥用完整goolgegroups邮件的gmail帐号

input user Password: 
  • 输入密码
  • 如下是选项存放地和gmail中的label

which label do you want download?[return to Inbox]Cpc
which do you want to save email file?[return to /tmp/Cpc.box
  • 如下为email的下载提示

writing.... 1 (RFC822 {4734}
writing.... 2 (RFC822 {5364}
writing.... 3 (RFC822 {7133}
writing.... 4 (RFC822 {4559}
writing.... 5 (RFC822 {4708}
writing.... 6 (RFC822 {4821}
writing.... 7 (RFC822 {7581}
writing.... 8 (RFC822 {5168}
writing.... 9 (RFC822 {4825}
...
...

使用脚本放置Email到新的maillist中

下载完gmail的email后, 脚本会再说询问要进行的动作, 如下:

what can I do for you?
d/D: download email to localhost mbox format
s/S: send localhost mbox file to MDA
m/M: make mbox file which can be use be maillist software

which are your choice?m
  • 选择m, make一份新的email文件, 这里不使用S(通过MDA的方式,因为这会重发所有的email到MDA,比较浪费时间

where is the mbox file ?/tmp/Cpc.box
which mbox will be save to/tmp/kcpycamp.mbox
  • 填写刚才下载的email文件和新的email文件的存放地点

复制新的email文件到mailman的数据目录下:

[root@ml /usr/home/jessinio]# cp /tmp/kcpycamp.mbox /usr/local/mailman/archives/private/kcpycamp.mbox/
[root@ml /usr/home/jessinio]# chown mailman:mailman /usr/local/mailman/archives/private/kcpycamp.mbox/kcpycamp.mbox 

重新归档:

[root@ml /usr/home/jessinio]# /usr/local/mailman/bin/arch --wipe kcpycamp /usr/local/mailman/archives/private/kcpycamp.mbox/kcpycamp.mbox

迁移结果

最后的情况请见如下URL:

  • attachment:cpc-mailman.png
  • 声明
    1. 新的maillist中没有google公司华丽的web界面
    2. 新的maillist不会像(至少现在不会像)google公司对Email的强大thread功能
      • 我们在gmail里看到的邮件的thread来源可能很多, 如多个googlegroups, 我们现在只能针对一个googlegroups
    3. 新的maillist的邮件可能有不完整性. 因为googlegroups不提供API, 我们只能使用(至少现在是这样)上面提到的使用gmail的Email

TODO

  1. 工具通用化,使用 cmd 模块友好化交互
  2. 对大型历史列表的下载提供按照月度,进行分文件下载的支持
  3. 对 .eml 的输出支持
  4. 对 .txt 的输出支持

::-- jessinio [2009-01-04 06:07:29]


反馈

创建 by -- ZoomQuiet [DateTime(2009-01-04T08:58:18Z)]

PageComment2

[:/PageCommentData:PageCommentData]

MiscItems/2009-01-04 (last edited 2009-12-25 07:16:31 by localhost)