前提
今天中午的时候发现自已网站突然不能访问了,我猜肯定是后台的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:
' + data);
});
free.stderr.on('data', function (data) {
console.log('standard error output:
' + 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
会生成整个站点静态文件,默认存放在blog
的public
目录。
采用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