Twikoo私有化部署教程--遷移騰訊雲

来源:https://www.cnblogs.com/xiaoniuhululu/archive/2022/09/22/16719508.html
-Advertisement-
Play Games

作者:小牛呼嚕嚕 | https://xiaoniuhululu.com 電腦內功、JAVA底層、面試相關資料等更多精彩文章在公眾號「小牛呼嚕嚕 」 給我的小破站,換了許多獨立的評論系統,twikoo還是用的最舒服的。 可是該評論系統 一直用的是騰訊的雲開發CloudBase免費版的,2022-0 ...


目錄

作者:小牛呼嚕嚕 | https://xiaoniuhululu.com
電腦內功、JAVA底層、面試相關資料等更多精彩文章在公眾號「小牛呼嚕嚕 」

給我的小破站,換了許多獨立的評論系統,twikoo還是用的最舒服的。

可是該評論系統 一直用的是騰訊的雲開發CloudBase免費版的,2022-08-08 騰訊收費模式正式,變成了收費,再也白嫖不了,看了下價格 每月39.9每月19.9,提價太高,有點吃不消,後面可能還會繼續提價,像微信讀書一樣。

正好twikoo作者也放出了私有化部署的版本,那就連夜進行遷移, 結果坑不少呢,筆者花了3天才搞好,故簡單記錄一下

備份數據

決定遷移前,得先把騰訊雲開發CloudBase的聊天數據備份下來

  1. 登錄 騰訊雲
  2. 打開雲開發 CloudBase;
  3. 選擇要導出的環境;
  4. 點擊左側的資料庫,點擊 comment 集合,點擊導出按鈕;
  5. 導出格式選擇 JSON(推薦,如果想用 Excel 等軟體查看,可以選擇 CSV),欄位不填;

私有化部署

創建容器

由於之前的博客已遷移到騰訊雲伺服器上,順便把評論系統也遷過來

可以參考: 博客遷移騰訊雲 https://mp.weixin.qq.com/s/O_-dAgKxk64hiClul0vDQw

由於已安裝docker ,那我就選中twikoo docker版 安裝

  1. 拉取鏡像
docker pull imaegoo/twikoo
  1. 創建並啟動容器
docker run -p 8099:8080 -v /root/twikoo/data:/app/data -d imaegoo/twikoo
  1. 別忘了,把伺服器的防火牆8099埠放開

  2. 測試容器是否正常工作

我博客使用Hexo+Next來生成的,直接修改主題配置文件

twikoo:
  enable: true
  visitor: true
  envId: xxxxxxxxxxxxxxx #將 envId 從之前的騰訊雲開發 ID 換成 http://ip地址:port 

然後hexo clean;hexo g;hexo s啟動本地hexo測試環境,就可以連上了

導入數據

第一次打開twikoo面板,需要設置密碼

然後選擇導入按鈕

將剛剛從騰訊雲開發上下載的文件導入進去即可

重新配置twikoo面板設置

導入的數據只是評論內容,需要照著線上騰訊雲開發的管理面板,把設置重新配一下

其中比較煩的就是郵件通知,需要從郵箱商重新獲取SMTP_PASS

引入前端CDN

<script src="https://cdn.staticfile.org/twikoo/1.6.4/twikoo.all.min.js"></script>

這樣基本上twikoo評論系統就遷移過來了,下麵講講最重要的nginx https反代http

Nginx https反代http

由於twikoo本身不支持https, 而如今http 傳輸數據還是不夠安全的,需要我們通過nginx來實現 https反向代理http

由於我博客本身,已經用了ssl正式了,我需要再加一個埠8099

  1. 方案一:通過一個功能變數名稱、一個ssl證書、來用https再代理一個埠

這個方案 目前網上沒有特別好的方法,筆者查遍了中文、英文相關的博客,沒有特別好的辦法,最後想出了個折中的辦法

nginx.conf:

upstream twi { #需要配置upstream
        server xxxx.com:8099; #你的功能變數名稱+加埠
    }  


server {
    listen       443 ssl;
    server_name  xxx.com;#你的功能變數名稱

    ssl_certificate      /etc/nginx/ssl/com_bundle.crt;#證書
    ssl_certificate_key  /etc/nginx/ssl/com.key;#證書.key

    # ssl_session_cache    shared:SSL:1m;
    ssl_session_timeout  5m;
    
    ssl_protocols SSLv3 TLSv1 TLSv1.1 TLSv1.2;
    ssl_ciphers  HIGH:!ADH:!EXPORT56:RC4+RSA:+MEDIUM;
    ssl_prefer_server_ciphers  on;

    location / {
        root /usr/share/nginx/html/hexo;
        index  index.html index.htm;
    }

    location /twi/ {
        proxy_http_version 1.1;
        proxy_set_header Upgrade $http_upgrade;
        proxy_set_header Connection "upgrade"; 
        proxy_pass_header Set-Cookie;

        proxy_set_header Host $host:$server_port; 
        proxy_set_header X-Real-IP $remote_addr;
        proxy_set_header X-Forwarded-For $remote_addr;
        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
        proxy_redirect off;

        add_header Access-Control-Allow-Origin *;
        add_header Access-Control-Allow-Methods "POST, GET,PUT,DELETE, OPTIONS";
        add_header Access-Control-Allow-Headers "Origin, Authorization, Accept";
        add_header Access-Control-Allow-Credentials true;

        proxy_headers_hash_max_size 512;
        proxy_headers_hash_bucket_size 128; 
        

        #proxy_pass http://localhost:8099/;
        proxy_pass http://twi; # 這邊只能這樣寫,不然服務轉發不過去
    }


}

這樣達到的效果是 訪問https://xxx.com/twi nginx 會將轉發到http://xxx.com:8099,訪問一下,twikoo提示一切正常

但坑爹的是,把將 envId 從之前的騰訊雲開發 ID 換成 https://xxx.com/twi後,發現twikoo 不支持 這樣的寫法,這樣其會無法獲取 accessToken, 就是這個值強行塞進去,還是繞不開內部的校驗,所以花了許多時間,但只能放棄

  1. 方案二 :通過多個功能變數名稱、多個ssl證書、來用https再代理一個埠

突然小牛靈感一閃,可以申請子功能變數名稱啊(這個去功能變數名稱提供商再添一條解析規則即可,筆者這裡是阿裡雲),這樣也不用再額外花錢啦,又去阿裡雲又申請了一個免費ssl證書(騰訊只能免費申請一個ssl證書,阿裡可以免費申請20個呢!!!)

nginx.conf: 添加下麵配置

upstream twi {#需要配置upstream
        server xxxx.com:8099; #你的功能變數名稱+加埠
    }  

server {
    listen  443 ssl;
    server_name  twikoo.xxx.com; #子功能變數名稱

    ssl_certificate      /etc/nginx/ssl/twikoo.xxx.com/twikoo.xxx.com.pem;
    ssl_certificate_key  /etc/nginx/ssl/twikoo.xxx.com/twikoo.xxx.com.key;

    # ssl_session_cache    shared:SSL:1m;
    ssl_session_timeout  5m;
    
    ssl_protocols SSLv3 TLSv1 TLSv1.1 TLSv1.2;
    ssl_ciphers  HIGH:!ADH:!EXPORT56:RC4+RSA:+MEDIUM;
    ssl_prefer_server_ciphers  on;

    location / {
        #proxy_pass http://localhost:8099;
        #proxy_pass http://twi; #這種方法,會導致twikoo郵件通知出現bug:getaddrinfo ENOTFOUND!!!
        proxy_pass http://xxx.com:8099;#建議這種寫法,和主功能變數名稱保持一致

        # add_header Access-Control-Allow-Origin "*" always; #這個不要加
        # add_header Access-Control-Allow-Methods "POST, GET,PUT,DELETE, OPTIONS";
        # add_header Access-Control-Allow-Headers "Origin, Authorization, Accept";
    }
        
}
             

發現這樣是最快最穩的寫法!

註意的是add_header Access-Control-Allow-Origin "*" always;這個跨越設置不要加,好像nginx會預設將一個子功能變數名稱對頂級功能變數名稱放開跨域限制,加了的話,會提示only allow one異常

這樣就實現了:訪問https://twikoo.xxx.com nginx 會將轉發到http://xxx.com:8099

把將 envId 從之前的騰訊雲開發 ID 換成 https://twikoo.xxx.com後,發現twikoo一切正常

終於把twikoo成功私有化部署了!完結撒花~~


參考資料:
https://www.imaegoo.com/2022/twikoo-data-export/


本篇文章到這裡就結束啦,很感謝你能看到最後,如果覺得文章對你有幫助,別忘記關註我!更多精彩的文章


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 多用戶即時通訊系統03 4.編碼實現02 4.4功能實現-私聊功能實現 4.4.1思路分析 客戶端 - 發送者: 用戶在控制台輸入信息,客戶端接收內容 將消息構建成Messgae對象,通過對應的socket發送給伺服器 伺服器: 可以讀取到客戶端(發送者)發送給某個用戶(接收者)的消息 從管理線程的 ...
  • Java基礎鞏固(二)——多線程 1.基本概念 程式是指令和數據的有序集合,其本身沒有任何運行的含義,是一個靜態的概念。 進程是執行程式的一次執行過程,它是一個動態的概念。是系統資源分配的單位。 一個進程可以包含若幹個線程,線程是cpu調度和執行的單位。 ==進程是資源分配的最小單位,線程是程式執行 ...
  • Java後端開發——美團(牛客) Java的基本數據類型,各自的位元組數 ​ 老生常談,不多說了. | 類型 | 位元組數 | | | | | byte | 1位元組 | | short | 2位元組 | | int | 4位元組 | | long | 8位元組 | | float | 4位元組 | | doub ...
  • 多用戶即時通訊系統03 4.編碼實現02 4.3功能實現-無異常退出系統 4.3.1思路分析 上述代碼運行時,在客戶端選擇退出系統的時候,可以發現程式並沒有停止運行,原因是: 退出時,程式將迴圈標誌loop設為false,退出了內層迴圈,而外層迴圈因為也用了loop來作為迴圈條件,外層迴圈也同樣退出 ...
  • 多用戶即時通訊系統03 4.編碼實現02 4.2功能實現-拉取線上用戶 4.2.1思路分析 客戶端想要知道線上用戶列表,就要向伺服器發送請求(Message),因為只有伺服器端保持著所有與客戶端相連接的socket和uid信息。 整個流程大致為:對Message的種類進行擴展,然後客戶端向伺服器發送 ...
  • 一、事務操作 模塊 from django.db import transaction 1 開啟事務:with transaction.atomic() from django.db import transaction class MyView(View): def post(self, requ ...
  • 1. 啟動分析 源碼版本是 7.1.0.M6 首先從 ProcessEngineAutoConfiguration 開始 ProcessEngineAutoConfiguration 是activiti-spring-boot-starter 7.1.0.M6自動配置的入口類,在這裡主要看 Spri ...
  • Python可以做的事情真的太多了,常見的網站開發,軟體開發,爬蟲,數據分析,人工智慧,機器學習,量化投資,自動化辦公,自動化運維,游戲開發,腳本製作,樹莓派等等等等~ 今天咱們就來試試用Python做一個簡單的程式,只需要十幾行代碼即可,灰常簡單~ 知識點 PyQt6 sys 代碼展示 #引入類 ...
一周排行
    -Advertisement-
    Play Games
  • 一:背景 1.講故事 在分析的眾多dump中,經常會遇到各種奇葩的問題,僅通過dump這種快照形式還是有很多問題搞不定,而通過 perfview 這種粒度又太粗,很難找到問題之所在,真的很頭疼,比如本篇的 短命線程 問題,參考圖如下: 我們在 t2 時刻抓取的dump對查看 短命線程 毫無幫助,我根 ...
  • 在日常後端Api開發中,我們跟前端的溝通中,通常需要協商好入參的數據類型,和參數是通過什麼方式存在於請求中的,是表單(form)、請求體(body)、地址欄參數(query)、還是說通過請求頭(header)。 當協商好後,我們的介面又需要怎麼去接收這些數據呢?很多小伙伴可能上手就是直接寫一個實體, ...
  • 許多情況下我們需要用到攝像頭獲取圖像,進而處理圖像,這篇博文介紹利用pyqt5、OpenCV實現用電腦上連接的攝像頭拍照並保存照片。為了使用和後續開發方便,這裡利用pyqt5設計了個相機界面,後面將介紹如何實現,要點包括界面設計、邏輯實現及完整代碼。 ...
  • 思路分析 註冊頁面需要對用戶提交的數據進行校驗,並且需要對用戶輸入錯誤的地方進行提示! 所有我們需要使用forms組件搭建註冊頁面! 平時我們書寫form是組件的時候是在views.py裡面書寫的, 但是為了接耦合,我們需要將forms組件都單獨寫在一個地方,需要用的時候導入就行! 例如,在項目文件 ...
  • 思路分析 登錄頁面,我們還是採用ajax的方式提交用戶數據 唯一需要學習的是如何製作圖片驗證碼! 具體的登錄頁面效果圖如下: 如何製作圖片驗證碼 推導步驟1:在img標簽的src屬性里放上驗證碼的請求路徑 補充1.img的src屬性: 1.圖片路徑 2.url 3.圖片的二進位數據 補充2:字體樣式 ...
  • 哈嘍,兄弟們! 最近有許多小伙伴都在吐槽打工好難。 每天都是執行許多重覆的任務 例如閱讀新聞、發郵件、查看天氣、打開書簽、清理文件夾等等, 使用自動化腳本,就無需手動一次又一次地完成這些任務, 非常方便啊有木有?! 而在某種程度上,Python 就是自動化的代名詞。 今天就來和大家一起學習一下, 用 ...
  • 作者:IT王小二 博客:https://itwxe.com 前面小二介紹過使用Typora+PicGo+LskyPro打造舒適寫作環境,那時候需要使用水印功能,但是小二在升級LskyPro2.x版本發現有很多不如人意的東西,遂棄用LskyPro使用MinIO結合代碼實現自己需要的圖床功能,也適合以後 ...
  • OpenAI Gym是一款用於研發和比較強化學習演算法的工具包,本文主要介紹Gym模擬環境的功能和工具包的使用方法,並詳細介紹其中的經典控制問題中的倒立擺(CartPole-v0/1)問題。最後針對倒立擺問題如何建立控制模型並採用爬山演算法優化進行了介紹,並給出了相應的完整python代碼示例和解釋。要... ...
  • python爬蟲瀏覽器偽裝 #導入urllib.request模塊 import urllib.request #設置請求頭 headers=("User-Agent","Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/537.36 (KHTML, l ...
  • 前端代碼搭建 主要利用的是bootstrap3中js插件里的模態框版塊 <li><a href="" data-toggle="modal" data-target=".bs-example-modal-lg">修改密碼</a></li> <div class="modal fade bs-exam ...