想法
- 最原始的辦法是經過ftp或者winscp這樣的工具能實現內容上傳,可是不夠簡化,首先你要登陸服務器,而後找到相應文件夾進行更新。
- 第二種方法是先更新gitee倉庫,而後經過ssh登陸服務器,而後從倉庫pull下全部代碼
- 第三種方法是不須要gitee倉庫,直接在服務器建一個空倉庫,而後把本地發佈文件push到服務器倉庫上
上面3種方法,第1種最原始,第2種比較繁瑣,第3種簡單可操做,可是第3種有一個問題,就是代碼管理所有在服務器上,可視性比較差,能不能經過gitee管理代碼,包括原始文件,而後一旦用戶push,經過鉤子函數,觸發服務器主動拉取,這樣,全部操做都簡化爲了本地的一個git push指令。說幹就幹,問了一圈度娘,果真高手在民間,幾個關鍵步驟都有相應的帖子介紹。php
第一步 創建hexo空倉庫
本地把項目文件通通push上去,除了node_module文件夾。這樣,項目文件也不會丟失,便於之後複用。html
第二步 創建服務器到hexo倉庫私鑰通訊
1. 建立ssh鏈接密鑰
參看 https://gitee.com/help/articles/4181#article-header0node
ssh-keygen -t rsa -C "xxxxx@xxxxx.com" # Generating public/private rsa key pair...
產生兩個文件:id_rsa id_rsa.pub
切換到 ~/.ssh目錄,cat id_rsa.pub 文件,複製,這個就是gitee須要的公鑰,注意最後的用戶信息不要複製
gitee倉庫上操做後,服務器就能免登陸操做倉庫了nginx



2. 建立webhooks鉤子函數並在服務器上處理
分兩步,一是gitee上進行添加webhooks鉤子,不懂得能夠參照官方文檔 https://gitee.com/help/categories/40
第二步,在服務器上添加地址監聽,對上一步填寫的post地址進行維護,大意就是一旦收到post請求,就執行一個sh命令,這個命令能夠pull下倉庫代碼。git

我這裏用的是nodejs的express模塊監聽某個端口,文件名爲wenhooks.js,具體代碼以下
var http = require('http') var createHandler = require('gitee-webhook-handler') var handler = createHandler({ path: '/webhooks_push', secret: 'cqmygysdssjtwmydtsgx'}); function run_cmd(cmd, args, callback) { var spawn = require('child_process').spawn; var child = spawn(cmd, args); var resp = ""; child.stdout.on('data', function(buffer) { resp += buffer.toString(); }); child.stdout.on('end', function() { callback (resp) }); } handler.on('error', function (err) { console.error('Error:', err.message) }) handler.on('Push Hook', function (event) { // # 這個地方就是GitHub 和 Gitee 不同的地方,須要注意 console.log('Received a push event for %s to %s', event.payload.repository.name, event.payload.ref); run_cmd('sh', ['/*/*/deploy.sh'], function(text){ console.log("sh deploy success");console.log(text) });//# 須要執行的腳本位置,須要自行修改爲本身的,這行代碼比較重要,是要讓系統去執行一個腳本命令 }) try { http.createServer(function (req, res) { handler(req, res, function (err) { res.statusCode = 404 res.end('no such location') }) }).listen(1999) // # 服務監聽的端口,自行修改 }catch(err){ console.error('Error:', err.message) }
而後編輯一下腳本文件deploy.sh,大概內容以下:web
cd /hexo項目路徑 #須要改爲本身的項目地址,這行比較重要,當時由於這個問題折騰了很久,全部的都對,就是pull失敗 git pull git@gitee.com:zdong22/hexo.git
node下的pm2工具啓動進程,很是方便
pm2 start webhooks.js --name wenhook
算法

3.起一個Nginx服務
須要使用ssl,這樣傳輸更安全
首先監聽80端口和443端口,而後80端口重定向到443端口
修改nginx.conf文件內容以下:express
//80端口配置 server { listen 80; server_name zhangdong.site; index index.html index.htm index.php; root /hexo項目路徑; error_page 404 /404.html; include enable-php.conf; #將 http 重定向 https return 301 https://$server_name$request_uri; } //443端口配置 #https zhagndong.site server { listen 443 ssl; server_name zhangdong.site; root /項目路徑; index index.php index.html index.htm; location / { # First attempt to serve request as file, then # as directory, then fall back to displaying a 404. try_files $uri $uri/ /index.php?$query_string; } location ~ \.php$ { try_files $uri /index.php =404; fastcgi_split_path_info ^(.+\.php)(/.+)$; fastcgi_pass unix:/var/run/php/php7.0-fpm.sock; fastcgi_index index.php; fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name; include fastcgi_params; } # ssl證書地址 ssl_certificate /網站證書.pem; # pem文件的路徑 ssl_certificate_key /網站證書.key; # key文件的路徑 # ssl驗證相關配置 ssl_session_timeout 5m; #緩存有效期 ssl_ciphers ECDHE-RSA-AES128-GCM-SHA256:ECDHE:ECDH:AES:HIGH:!NULL:!aNULL:!MD5:!ADH:!RC4; #加密算法 ssl_protocols TLSv1 TLSv1.1 TLSv1.2; #安全連接可選的加密協議 ssl_prefer_server_ciphers on; #使用服務器端的首選算法 }
4. 服務器設置一下git參數
pull只拉取public文件夾就好了,其它的不須要
具體方法是:
打開.git文件夾緩存
[root@iZbp13m488196desr77aezZ .git]# ls branches config description FETCH_HEAD HEAD hooks index info logs objects ORIG_HEAD refs
修改config文件,sparesecheckout 從false改成true安全
[root@iZbp13m488196desr77aezZ .git]# cat config [core] repositoryformatversion = 0 filemode = true bare = false logallrefupdates = true sparsecheckout = true [remote "origin"] url = git@gitee.com:zdong22/hexo.git fetch = +refs/heads/*:refs/remotes/origin/*

修改
.git/info
下的
sparse-checkout
文件,添加一行,
public/
[root@iZbp13m488196desr77aezZ info]# ls exclude sparse-checkout [root@iZbp13m488196desr77aezZ info]# cat sparse-checkout public/ [root@iZbp13m488196desr77aezZ info]#

大功告成!
如今發文邏輯就是
hexo new ->編輯 ->hexo clean -> hexo g -> git push ,幾個指令,而後網站就更好了。
ps:還有幾個重要的點
一是端口要確保能訪問,系統防火牆打開端口以後,雲服務器控制檯還有一道防火牆
二是文件權限必定要肯定,拿一個普通用戶去執行root操做確定失敗
三是發佈以後檢查一下,是否是內容存在問題,訪問是否正常
來源: 淺淺的無名小卒
文章做者: Zhang
文章連接: https://zhangdong.site/2021/02/02/tong-guo-gitee-guan-li-hexo-fa-bu-nei-rong/
本文章著做權歸做者全部,任何形式的轉載都請註明出處。