搭建个人wiki站点
来源:互联网 发布:2015年度十大网络用语 编辑:程序博客网 时间:2024/05/16 04:55
原文请猛戳:http://galoisplusplus.gitcafe.com/blog/2013/09/19/have-fun-with-vim-wiki/
写blog确实是一种消化和深入理解知识的方式,但往往要整理一个完整的主题相当的耗时间。
平时我也想记一记一些有用然而散乱的tips,慢慢积累起来。
作为一位Vim忠实粉,我理所当然找到了大名鼎鼎的Vim插件[Vimwiki](http://www.vim.org/scripts/script.php?script_id=2226),
并开始借此搭建我的个人wiki。
用[pathogen](https://github.com/tpope/vim-pathogen)这个管理Vim插件的插件把Vimwiki安装上后,需要在.vimrc中加入一些设置,其中最重要的是指定你所写的wiki源文件的路径和要发布的html文件的路径:
```
let g:vimwiki_list = [{'path': '~/my_site/', 'path_html': '~/public_html/'}]
```
接下来就可以在你所指定的'path'下创建.wiki文件,编辑完后是用以下Vim命令
```
:Vimwiki2HTML
```
Vimwiki插件就会自动将该.wiki文件转化为同名的html页面(例如topic.wiki生成的是topic.html)并把html放到你所指定的'path_html'下。
如果要转化所有条目可以用以下的Vim命令:
```
:VimwikiAll2HTML
```
<!-- more -->
有了html页面,自然想发布到某网站上。我选择了提供pages服务的业界良心Github,创建一个名为wiki的新repo(https://github.com/yszheda/wiki),把'path_html'上的html文件托管到上面,并通过gh-pages分支发布我的Project pages(http://yszheda.github.io/wiki/)。
页面的样式我偷懒直接使用了Github官方提供的Architect主题,为了让该主题应用到所有Vimwiki生成的html页面上,需要修改Vimwiki插件目录下的```autoload/vimwiki/default.tpl```模板文件:
```
<!DOCTYPE html>
<html>
<head>
<meta charset='utf-8'>
<!--
<link rel="Stylesheet" type="text/css" href="%root_path%%css%">
-->
<link href='https://fonts.googleapis.com/css?family=Architects+Daughter' rel='stylesheet' type='text/css'>
<link rel="stylesheet" type="text/css" href="stylesheets/stylesheet.css" media="screen" />
<link rel="stylesheet" type="text/css" href="stylesheets/pygment_trac.css" media="screen" />
<link rel="stylesheet" type="text/css" href="stylesheets/print.css" media="print" />
<!--[if lt IE 9]>
<script src="//html5shiv.googlecode.com/svn/trunk/html5.js"></script>
<![endif]-->
<title>%title%</title>
<meta http-equiv="Content-Type" content="text/html; charset=%encoding%">
</head>
<body>
<header>
<div class="inner">
<h1>Wiki</h1>
<h2>by yszheda</h2>
<a href="https://github.com/yszheda/wiki" class="button"><small>View project on</small>GitHub</a>
</div>
</header>
<div id="content-wrapper">
<div class="inner clearfix">
<section id="main-content">
%content%
</section>
<aside id="sidebar">
<p>Wiki maintained by <a href="https://github.com/yszheda">yszheda</a></p>
<p>This page was generated by <a href="pages.github.com">GitHub Pages</a> using the Architect theme by <a href="https://twitter.com/jasonlong">Jason Long</a>.</p>
</aside>
</div>
</div>
</body>
</html>
```
接下来要折腾的就是自动发布Vimwiki生成的html页面了。
我写了一个简单的auto-deploy.sh脚本:
```
#!/bin/bash
path_html= # set your vimwiki html path
cd $path_html
git checkout gh-pages
git add *.html
git commit -m"syn at `date`"
git push origin gh-pages
```
再把它设置为定时作业,可以用经典的```crontab```,例如```crontab -e```后加入:
```
* 20 * * * /<path>/auto-deploy.sh
```
设置每日晚上八点自动发布。
不过作为一名Arch user,很早之间就<del>当小白鼠</del>从sysvinit迁移到了systemd,自然要试试这个高大上的```systemd```。
systemd也支持定时作业,以我的例子来讲,我希望每日定时发布,可以从创建一般的daily event开始。
编辑```/etc/systemd/system/timer-daily.timer```文件:
```
[Unit]
Description=Daily Timer
[Timer]
OnBootSec=10min
OnUnitActiveSec=1d
Unit=timer-daily.target
[Install]
WantedBy=basic.target
```
编辑```/etc/systemd/system/timer-daily.target```文件:
```
[Unit]
Description=Daily Timer Target
StopWhenUnneeded=yes
```
创建以下目录,作为接下来要被执行的具体的定时作业的服务设置文件的路径:
```
mkdir /etc/systemd/system/timer-daily.target.wants
```
在该目录下添加具体要被执行的定时作业的服务设置文件```/etc/systemd/system/timer-daily.target.wants/syn-vimwiki.service```:
```
[Unit]
Description=syn vimwiki
[Service]
Nice=19
IOSchedulingClass=2
IOSchedulingPriority=7
ExecStart= /<path>/auto-deploy.sh
```
最后执行
```
systemctl enable timer-daily.timer && systemctl start timer-daily.timer
```
即可。
设置按小时或按星期定时发布也是可以的,
万能的[Arch wiki](https://wiki.archlinux.org/index.php/Systemd/cron_functionality)上都有详细的说明。
===我是分隔线===
后来我又改主意了,想频繁更新,同时也不想像wiki那样搞得那么麻烦。于是我把syn-wiki单独出来,syn-vimwiki.service文件移到它的父目录(/etc/systemd/system/),同时给它设个独立的timer。以下是/etc/systemd/system/syn-vimwiki.timer文件的内容:
```
[Timer]
OnUnitActiveSec=10s
OnBootSec=10s
[Install]
WantedBy=basic.target
```
最后执行
```
systemctl enable syn-vimwiki.timer && systemctl start syn-vimwiki.timer
systemctl restart syn-vimwiki.service
```
===我是分隔线===
关于systemd再多啰嗦几句,迁移到systemd后自然还是可以用原来的```cron```服务的,如果某一天你打了鸡血,突然变激进了,想把cron撤掉换成纯systemd(Arch发行版就经常干这种事XD),在执行
```
systemctl stop cronie && systemctl disable cronie
```
之前,别忘了加入```logrotate```、```man-db-update```、```mlocate-update```、```verify-shadow```这些服务的配置文件。
至于具体的内容,万能的[Arch wiki](https://wiki.archlinux.org/index.php/Systemd/cron_functionality)也早为不折腾不死的你准备好了XD
- 搭建个人wiki站点
- 个人wiki网站的搭建
- nginx结合moinmoin搭建wiki站点
- 个人wiki网站:dokuwiki的搭建
- Mac下使用simiki搭建个人wiki
- 如何搭建Jekyll个人站点
- 个人wiki
- Mac下WordPress个人站点环境搭建
- 使用Hugo搭建个人博客站点
- Hexo+GitHub搭建个人站点(新!)
- 我的个人站点搭建 框架选择
- github pages + hexo 搭建个人博客站点
- Github Pages搭建个人站点和项目站点
- 如何使用Mediawiki搭建个人wiki系统、以及wiki的部分基本操作和设置
- 著名Wiki站点一览
- 个人站点.
- 个人站点
- MoinMoin桌面版 个人wiki
- 是时候说再见了
- oracle添加主键
- 在发布站点前,Web开发者需要关注哪些技术细节?
- spring源码分析 源于百度
- 关于opencv图像类型的转换
- 搭建个人wiki站点
- Conscription 最小生成树
- HDU解题报告——1016
- POJ-3349 Snowflake Snow Snowflakes
- uva10887
- java中基本数据类型与对象引用类型的默认初始化值学习
- 会话管理
- using System.Drawing;是否缺少程序集引用?的解决办法
- 虚拟机Hyper-V, VMware, VPC使用及比较