前提

  今天中午的时候发现自已网站突然不能访问了,我猜肯定是后台的hexo服务异常自动kill掉了。果然登录服务器ps -ef | grep hexo查看进程,果然发现hexo的进程不在了。由于我将输出的日志指向了/dev/null(Linux下的垃圾回收箱)。排查不了错误信息,只能思考有什么方法保证网站一直正常访问。 
   
  Hexo后台启动命令:hexo server & 
   
大致思路
  - 通过守护脚本的方式,检测进程是否存在,如果不存在则启动 
  - forever让nodejs应用后台执行 
  - 通过nginx反向代理静态文件的方式 
  

守护脚本

    #! /bin/sh
#进程名字可修改
PRO_NAME=hexo while true ; do # 用ps获取$PRO_NAME进程数量
NUM=`ps aux | grep ${PRO_NAME} | grep -v grep |wc -l`
# echo $NUM
# 少于1,重启进程
if [ "${NUM}" -lt "1" ];then
echo "${PRO_NAME} was killed"
hexo server &
# 大于1,杀掉所有进程,重启
elif [ "${NUM}" -gt "1" ];then
echo "more than 1 ${PRO_NAME},killall ${PRO_NAME}"
killall -9 $PRO_NAME
hexo server &
fi
# kill僵尸进程
NUM_STAT=`ps aux | grep ${PRO_NAME} | grep T | grep -v grep | wc -l` if [ "${NUM_STAT}" -gt "0" ];then
killall -9 ${PRO_NAME}
hexo server &
fi
done exit 0

npm forever

  项目地址:foreverjs/forever 
  资料: 
    Hexo快速搭建 
    Hexo博客后台运行技巧 
  - 安装步骤


[sudo] npm install forever -g cd /path/to/your/project #hexo根目录
[sudo] npm install forever-monitor #检查forever是否安装完成
forever #返回帮助文档

  - forever基础命令

    $ sudo npm install forever -g   #安装
$ forever start app.js #启动
$ forever stop app.js #关闭
$ forever start -l forever.log -o out.log -e err.log app.js #输出日志和错误

  - 守护Hexo: 
  在Hexo的根目录/opt/blog下创建app.js文件。 
  添加如下内容:

    var spawn = require('child_process').spawn;
free = spawn('hexo', ['server', '-p 4000']);/* 其实就是等于执行hexo server -p 4000*/ free.stdout.on('data', function (data) {
console.log('standard output:\n' + data);
}); free.stderr.on('data', function (data) {
console.log('standard error output:\n' + data);
}); free.on('exit', function (code, signal) {
console.log('child process eixt ,exit:' + code);
});

  - 启动forever

    forever --minUptime 10000 --spinSleepTime 26000 start app.js

    ## minUptime、spinSleepTime可填可不填,不填默认也会有,参数的意思可以直接去forever上查询。

  - 验证: 
   - 检查forever是否监控进程( forever list ) 
   - 查看hexo进程号 
   - kill 掉Hexo进程( kill -9 pid ) 
   - 重新查看hexo进程号 
  如果两次的pid不一样,表示hexo进程不存在时,会自动重启、 
  

Nginx静态化

  Hexo静态化Host尝试 
   
  通过hexo g会生成整个站点静态文件,默认存放在blogpublic目录。 
  采用Nginx指向本地静态资源目录的方式暴露服务。Nginx默认启动会创建两个线程,一个Master process(对请求分配),一个work process(处理每个请求)。对请求的透传处理,不作任何处理。所以相对于其他容器而言更加稳定,并且访问静态资源的效率上会比部署在一般容器中更快。

  Nginx部署

  linux环境下安装nginx教程 
  linux下安装nginx 
  Installing nginx on CentOS 6.4

    yum install pcre* -y
yum install openssl* -y
yum install zlib -y
yum install zlib-devel -y
yum install wget -y cd /opt
wget http://nginx.org/download/nginx-1.13.0.tar.gz
cp nginx-1.13.0.tar.gz /usr/local
cd /usr/local
tar -zxvf nginx-1.13.0.tar.gz
mv nginx-1.13.0 nginx ./configure --prefix=/usr/local/nginx
make && make install
ln -s /usr/local/nginx/sbin/nginx /usr/local/bin/nginx #启动
nginx #浏览器直接访问http://localhost/即可访问到Nginx的静态页面
#因为Nginx默认占用80端口,所以必须以root用户启动

  编辑Nginx配置文件 
   - 静态文件的方式

    server {
listen 80;
server_name rtime.xin www.rtime.xin notes.rtime.xin;
if ($host != 'www.rtime.xin' ) {
rewrite ^/(.*)$ http://www.rtime.xin/$1 permanent;
}
location / {
root /opt/blog/public;
index index.html index.htm;
}
}

   - 端口的方式

    server {
listen 80;
server_name rtime.xin www.rtime.xin notes.rtime.xin;
#access_log /var/log/nginx/log/host.access.log main;
location / {
proxy_pass http://127.0.0.1:4000/;
proxy_redirect off;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
}
}

  建议还是采用反向代理  静态资源 的方式。效率上可以直接秒杀通过hexo服务的方式。但是存在缺陷是public目录必须是最新的、所以每次编写完文章之后,必须执行hexo g,生成最新的静态资源。

遇到的问题

  Q : nginx 1.9.5 ./configure: error: invalid option “–with-http_spdy_module”?? 
  A:nginx 1.9.5 已经没有了 –with-http_spdy_module ,取代的是 –with-http_v2_module

 

Hexo Daemon的更多相关文章

  1. Hexo构建Blog系列

    Hexo是一个开源构建blog框架,基于nodejs研发.可以自由切换主题,插件等功能,实现自已酷炫博客需求. 下面是基于hexo实践所产出的一些心得,供大家参考. 基础 Hexo 搭建 Hexo 与 ...

  2. 【原】Github+Hexo+NextT搭建个人博客

    摘要 GitHub 是一个开源项目的托管网站,相信很多人都听过.在上面有很多高质量的项目代码,我们也可以把自己的项目代码托管到GitHub,与朋友们共享交流.GitHub Pages 是Github为 ...

  3. 使用HEXO快速建站

    先安好npm,请参照:http://max.cszi.com/archives/482 打开网站:https://hexo.io/   npm install hexo-cli -g hexo ini ...

  4. hexo+github搭建个人博客

    最近用hexo+github搭建了自己的个人博客-https://liuyfl.github.io,其中碰到了一些问题,记录下来,以便查阅. hexo+github在win7环境下搭建个人博客:hex ...

  5. 基于Hexo和Github搭建博客

    搭建自己的个人博客. 准备工作 确保电脑需要已下载安装node和npm.查看安装是否成功,windows只需在命令行输入以下两条命令即可. 1 2 $ node -v $ npm -v 安装hexo ...

  6. Hexo的coney主题的一些补充说明

    title: Hexo的coney主题的一些补充说明 date: 2014-12-14 14:10:44 categories: Hexo tags: [hexo,技巧] --- Coney是一个非常 ...

  7. 基于hexo+github搭建一个独立博客

    一直听说用hexo搭建一个拥有自己域名的博客是很酷炫的事情~,在这十一花上半个小时整个hexo博客岂不美哉. 使用Hexo吸引我的是,其简单优雅, 而且风格多变, 适合程序员搭建个人博客,而且支持多平 ...

  8. 手把手教从零开始在GitHub上使用Hexo搭建博客教程(四)-使用Travis自动部署Hexo(2)

    前言 前面一篇文章介绍了Travis自动部署Hexo的常规使用教程,也是个人比较推荐的方法. 前文最后也提到了在Windows系统中可能会有一些小问题,为了在Windows系统中也可以实现使用Trav ...

  9. 手把手教从零开始在GitHub上使用Hexo搭建博客教程(三)-使用Travis自动部署Hexo(1)

    前言 前面两篇文章介绍了在github上使用hexo搭建博客的基本环境和hexo相关参数设置等. 基于目前,博客基本上是可以完美运行了. 但是,有一点是不太好,就是源码同步问题,如果在不同的电脑上写文 ...

随机推荐

  1. POJ 2442 Sequence(堆的使用练习)

    题目地址:id=2442">POJ 2442 真心没想到这题的思路. .原来是从第一行逐步向下加,每次都仅仅保存前n小的数.顺便练习了下堆.. 只是感觉堆的这样的使用方法用的不太多啊. ...

  2. ubuntu 各种窗体操作

    通用 ctrl+alt+0~9 改变窗体大小和是否显示 alt+F4 关闭窗体菜单键+相应启动器位置的编号打开程序 ctrl+pageup/pagedown 在tab间移动 ctrle+shift+p ...

  3. HDU 5310 Souvenir

    Souvenir  Accepts: 901  Submissions: 2743  Time Limit: 2000/1000 MS (Java/Others)  Memory Limit: 262 ...

  4. MPI搭建简要教程

    具体安装部署,能够參考 http://www.ibm.com/developerworks/cn/linux/l-cn-mpich2/,该教程将的比較具体. 注:不同版本号的 MPICH2对编译器以及 ...

  5. m_Orchestrate learning system---二十六、动态给封装好的控件添加属性

    m_Orchestrate learning system---二十六.动态给封装好的控件添加属性 一.总结 一句话总结:比如我现在封装好了ueditor控件,我外部调用这个控件,因为要写数据到数据库 ...

  6. BZOJ 2049 LCT

    思路:LCT的基本操作 //By SiriusRen #include <cstdio> #include <cstring> #include <algorithm&g ...

  7. AngularJs轻松入门(三)MVC架构

    MVC应用程序架构最早于1970年起源于Smalltalk语言,后来在桌面应用程序开发中使用较为广泛,如今在WEB开发中也非常流行.MVC的核心思想是將数据的管理(Model).业务逻辑控制(Cont ...

  8. 使用NiftyModeEffects对话框

    最近看到一篇有关个性对话框的文章,里面介绍了非常酷的动画效果,开源的项目下载来试试,用法很简单. NoftyDialogEffects效果参考:       http://tympanus.net/D ...

  9. 使用物化视图解决GoldenGate不能使用中文表名问题

    源端: conn sh/sh create table "学生" ("学号" number primary key,"姓名" varchar ...

  10. js文字的无缝滚动(上下)

    使用scrolltop值的递增配合setInterval与setTimeout实现相关效果,左右无缝滚动使用scrollLeft即可 Dom内容 <div id="container& ...