HEXO 部署到雲服務器詳細指南

一、環境安裝

1.1 node js 安裝

yum install gcc-c++ make
yum -y install nodejs
驗證:

node -v 
npm -v
1.2 安裝git、nginx

Git 用於版本管理和部署,Nginx 用於靜態博客託管。

yum install git nginx -y
1.3 安裝hexo

我們使用 Node.js 的包管理器 npm 安裝 hexo-cli 和 hexo-server
npm install hexo-cli hexo-server -g
hexo-cli 是 Hexo 的命令行工具,可用於快速新建、發佈、部署博客;hexo-server 是 Hexo 的內建服務器,可用於部署前的預覽和測試。-g 選項,表示全局安裝。

驗證
hexo
二、創建git環境

參考地址

2.1 在雲服務器上創建一個 GIT 用戶,用來運行 GIT 服務

創建用戶:adduser git
設置密碼:passwd git
2.2 創建證書

切換到git用戶:su git
創建.ssh目錄:mkdir .ssh && chmod 700 .ssh
然後在雲服務創建authorized_keys公鑰保存文件:touch .ssh/authorized_keys && chmod 600 .ssh/authorized_keys
__ tip: __ 公鑰保存文件authorized_keys是一行添加一個
2.3 創建git倉庫目錄

創建一個名爲blog的git倉庫

mkdir /var/repo
cd /var/repo
git init --bare blog.git
2.4 配置 GIT HOOKS

vim /var/repo/blog.git/hooks/post-receive
添加

#!/bin/sh
git --work-tree=/var/www/hexo --git-dir=/var/repo/blog.git checkout -f
然後保存退出,並設置權限

chmod +x /var/repo/blog.git/hooks/post-receive
2.5 改變 BLOG.GIT 目錄的擁有者爲 GIT 用戶

chown -R git:git blog.git
2.6 創建靜態文件目錄並將2.3步驟生成的git倉庫鏈接到靜態文件目錄下

創建靜態文件目錄(文章網頁):mkdir /var/www/hexo
鏈接git倉庫:chown -R git:git /var/www/hexo
配置權限:chmod -R 755 /var/www/hexo
這樣git倉庫更新便會自動同步到hexo目錄下
2.7、爲了安全考慮,禁用GIT用戶的SHELL 登錄權限配置(下面兩個步驟非常重要,否則客戶端總是提示密碼錯誤!!!)

首先你必須確保 git-shell 已存在於 /etc/shells 文件中

使用命令which git-shell判斷系統是否安裝了git-shell。如果已經安裝,則返回git-shell的安裝目錄,如:/usr/bin/git-shell;如果未安裝則需要安裝git-shell命令,安裝命令:yum install git
判斷shells文件是否存在,判斷命令:cat /etc/shells
如果文件不存在或沒有/usr/bin/git-shell,則需要使用vim增加這個路徑:
sudo vim /etc/shells,在最後一行添加git-shell路徑
# /etc/shells: valid login shells 
/bin/sh
/bin/dash
/bin/bash
/bin/rbash
/usr/bin/tmux
/usr/bin/screen
/usr/bin/git-shell # 添加你的git-shell
```

現在你可以使用 chsh 命令修改任一系統用戶的shell權限了
現在我們修改第一步中創建的git用戶的登錄權限,禁止git用戶使用shell權限:
終端中輸入sudo chsh git
[圖片上傳失敗...(image-86e8df-1521642804894)]

然後在Login Shell [/bin/bash]: 後輸入git-shell路徑/usr/bin/git-shell

修改完成後驗證: vim /etc/passwd找到類似git:x:1000:1000:,,,:/home/git:/usr/bin/git-shell,看看git用戶是否是以git-shell結尾

這樣,git用戶就只能使用SSH連接對Git倉庫進行推送和拉取操作,而不能登錄機器並取得普通shell命令
2.8 測試

當上述步驟都完成後,我們就可以測試下git服務器是否部署成功,最簡單的方法便是使用clone來校驗
用戶電腦(window or mac)git客戶端執行clone操作git clone git@服務器ip:/var/repo/blog.git
當出現下面這種框,然後輸入我們在第一步時創建git這個用戶的密碼就能成功clone了。


git_server


git_server
如果clone成功,表示git服務器搭建成功

三、hexo配置

打開hexo博客目錄,編輯_config.yml文件
修改repository爲:

deploy:
  type: git
  repository: git@ip或域名:/var/repo/blog.git
  branch: master
然後執行hexo g -d將文件上傳到你部署的服務器上,如果上傳成功,將如下圖所示:
article_upload_finish.png

四、nginx配置

最後,爲了能讓瀏覽器能直接訪問靜態頁面,需要使用nginx將端口或域名指向hexo靜態文件目錄

4.1 修改 NGINX 的 DEFAULT 設置

ubuntu
vim /etc/nginx/sites-available/default
centos
vim /etc/nginx/conf.d/blog.conf
注意:不同版本的nginx或系統,nginx的配置文件不一定相同,根據具體情況來修改配置

4.2 將其中的 ROOT 指令指向 /var/www/hexo 目錄(也就是GIT鉤子目錄)

server {
    listen 80;
    listen [::]:80;
    root /var/www/hexo; # 修改的地方
    server_name laoyuyu.me www.laoyuyu.me; # 如果需要改域名訪問,修改server_name 爲域名便可
    location / {
            # First attempt to serve request as file, then
            # as directory, then fall back to displaying a 404.
            try_files $uri $uri/ =404;
    }
}
4.3 最後重啓服務,讓NGINX生效

service nginx restart 
4.4 nginx 常見錯誤

我在配置完Nginx後,啓動的時候總是無法正常訪問到我的web應用,查看日誌文件(/var/log/nginx/error.log)後發現:

connect() to 127.0.0.1:8080 failed (13: Permission denied)
從這個錯誤信息中可以看出是訪問權限的問題,解決辦法如下:

vi /etc/nginx/nginx.conf
#user nginx;
user root;
其實就是將nginx的用戶修改爲root用戶即可,當然也可以爲nginx用戶增加相應的權限。
--------------------- 
作者:weixin_34405925 
原文:https://blog.csdn.net/weixin_34405925/article/details/86783406 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章