摘要:現在,我們已經有了云服務器了,接下來就是如何把我們能在本地跑起來的代碼部署在服務器上。云服務器設置,是運維同學經常打交道的。討論地址歡迎一起討論,地址從零開始學習部署參考資料誰說前端不需要懂反向代理與負載均衡從入門到實踐
前段時間看到了張云龍的文章 一個程序員的成長之路 - 剖析別人,總結自己,里面有這么一段話
棧外技術,是指棧內技術的上下游,領域外的相關專業知識,包括但不限于服務端技術、運維、CDN、測試,甚至 UI 設計、產品設計等等,擴展你棧內技術的周圍領域,充分理解你的工作在整個技術研發體系中處于怎樣的環節。工作之余多投入一份精力,把其他棧外技術不斷納入到你的知識體系中來,建立棧外能力。前端想要做的深入,往往會涉及到緩存、模板渲染、用戶體驗等知識,沒有相當的棧外技術積累,你很難為自己的團隊爭取到足夠的話語權。
想想自己在公司的時候,基本都是寫業務,做前端相關的工作,但對于其他方面是涉獵比較少,或者基本沒有的。又再想想之前面試的時候,面試官也會問一些棧外問題,比如說你們公司的代碼是如何發布部署的,這時候的我是一臉懵逼的。這就使得我想要懂得如何部署代碼,以下是折騰的過程,記錄一下。
云服務器云服務器的購買,可以選擇阿里云和騰訊云,我之前并沒有仔細地去比價兩者的價格如何,想著就是用來玩玩如何部署的,也就沒有多在意這些,畢竟也不是長期購買,花不了幾個錢,就選了騰訊云。至于選購什么配置的服務器,就看個人了。買完之后,還要做一些認證等,需要等待一兩天的時間。對了,我還買了一個域名,但是后來發現備案的手續挺麻煩的,想著之后用 ip 地址也可以訪問,就沒有去管了。
ssh 登錄有了服務器后,你需要登錄。那要怎么登錄呢,這里介紹一個簡單的方法。
本地生成 ssh 公鑰首先,你需要確認自己是否已經擁有秘鑰。默認情況下,用戶的 SSH 秘鑰存儲在~/.ssh 目錄下。進入該目錄并列出其中內容,便可以快速確認自己是否已擁有秘鑰:
# 本地 $ cd ~/.ssh $ ls config id_rsa id_rsa.pub known_hosts
我們需要尋找一對以 id_dsa 或 id_rsa 命名的文件,其中一個帶有 .pub 擴展名。.pub 文件是你的公鑰,另 一個則是私鑰。如果找不到這樣的文件或者根本沒有 .ssh 目錄, 你可以通過運行 ssh-keygen 程序來創建它們。
# 本地 $ ssh-keygen Generating public/private rsa key pair. # 輸入 enter 鍵 Enter file in which to save the key (/Users/laohan/.ssh/id_rsa): Created directory "/Users/laohan/.ssh". # 兩次輸入密碼 Enter passphrase (empty for no passphrase): Enter same passphrase again: Your identification has been saved in /Users/laohan/.ssh/id_rsa. Your public key has been saved in /Users/laohan/.ssh/id_rsa.pub. The key fingerprint is: SHA256:XhI9aeGsVJklGyUTvNu+6ABzOZdZL2+y5aMOVQa+ZvI laohan@bogon The key"s randomart image is: +---[RSA 2048]----+ | .O*+ | | =+X . | | o O.o o | | . =.= = | | o S *o* . | | = =.*.o | | o ..E + | | . o.*. | | .o.=o.. | +----[SHA256]-----+
首先 ssh-keygen 會確認密鑰的存儲位置(默認是 .ssh/id_rsa),然后它會讓你重復一個密碼兩次,如果不想在使用公鑰的時候輸入密碼,可以留空。
公鑰看起來是這樣的:
$ cat ~/.ssh/id_rsa.pub ssh-rsa AAAAB3NzaC1yc2EAAAADAQABAAABAQDc4xbJxlMTgiE13I1RL6IsG44+3CQc8Ft03eZnYfNrPVeQIf9r9kTuArSiUnY+BHXn3mrQ5i+5AGi+alys94Pum2dZ68QtlY1QdEl4iN3LFXUkbJc+M0rllaDGH5JNtfk5imVqDo8Tn7aJsFd4IXbwrl3Euf+ccOb+s92RHwzbSRx37tP9pLF9ujfL0UXfg3+DmRJMJT7iN3OiJxfuF5k8KSySEz+YbhQoNeySuvVPeRHG/U6xOGcpzNjQIPApGsuFdLT5R/5x15W7SrC//XWuIQMmlVTW2X0YH+5NjT0nlLVWxS4drtRCS66JXtRceVqs5H5InbsLfALfTPyIkZ4t laohan@bogon
具體可以參考這里 Generating a new SSH key and adding it to the ssh-agent
云服務器配置$ cd $ mkdir .ssh && chmod 700 .ssh $ touch .ssh/authorized_keys && chmod 600 .ssh/authorized_keys
接下來,把開發者的 SSH 公鑰添加到這個用戶的 authorized_keys 文件中。
$ vim .ssh/authorized_keys # 把之前生成是 SSH 公鑰添加到文件尾部本地 config 配置
現在已經可以通過 ssh 無密碼的方式登錄云服務器了
ssh root@IP # IP 為 云服務器的 IP 地址
如上,是不是感覺很方便。可是這種方式,你還是需要知道云服務器的 ip 地址,那有沒有更省腦的方式呢?
有的,在~/.ssh 下的 config 文件中添加以下代碼即可
Host hostname # hostname 為你想要設置的別名 HostName IP # IP 為云服務器的 IP 地址 User root IdentitiesOnly yes
之后,就可以通過如下的方式登錄到云服務器了
ssh hostname # hostname 為你剛才設置的名稱代碼
個人理解,云服務器也就是一臺機器,你的代碼在自己的電腦怎么跑,到了云服務器還是怎么跑,只是運行的環境不一樣了,需要做一些配置。
現在,我們已經有了云服務器了,接下來就是如何把我們能在本地跑起來的代碼部署在服務器上。
我采用的方式比較簡單,就是直接在把我本地的代碼 push 到 github 上面,然后在服務器那里用 git clone,把代碼下載到本地。github 地址 koa-demo。又或者你可以把代碼在本地打包后,利用 scp 遠程復制。
云服務器設置 nginxnginx,是運維同學經常打交道的。你可能聽過反向代理、負載均衡等名詞,這都是跟 nginx 有關的。
安裝 nginx我的服務器是 centos 系統的,所以安裝的方式如下
yum install -y nginx
至于其他系統的安裝方式,自行查找了。
conf 配置對于 nginx 來說,主要就是 nginx.cof 這份配置文件,位于/etc/nginx 路徑下,下面就進行修改
cd /etc/nginx vi nginx.conf
修改后的內容如下
注意:確保紅色圈中的 1 部分沒有被注釋,圈中的 2 部分注釋。
這樣做的目的是為了如果之后需要添加多個 server 的話,都在 nginx.conf 文件改,就不容易維護了。
接下來,添加我們這次需要的跟 nginx 相關的文件
cd /etc/nginx/conf.d touch koa-demo.conf vi koa-demo.conf
然后,把以下內容 copy 到 koa-demo.con 中并保存
upstream koa-demo { server 127.0.0.1:3000; } server { listen 80; location / { proxy_pass http://koa-demo; } }
之后,使用下面的命令
nginx -t # 用來測試你的配置文件是否 ok nginx -s reload # 重新加載配置文件
沒意外的話,這個時候在瀏覽器中輸入你的云服務器 ip 地址,就可以看到效果了。
等等,你說你的瀏覽器沒反應。不要慌,這是因為你的代碼還沒運行呢
# 我的代碼克隆在這里,你的路徑可能跟我的不同 cd /opt/koa-demo npm start
這時候再刷新頁面,ok 了,大功告成。
接著,你可能就想給自己加個雞腿慶祝一下,然后就退出了云服務器,跑去吃飯了。吃完飯回來,再次刷新瀏覽器,我了個去,怎么又沒內容了。 為什么會這樣呢?
這是因為你打開的方式不對,也就是啟動代碼的方式不對,你可以看看 packagek.json 的內容,npm start 其實就是執行 node index.js 。當你這邊退出了,這個進程也就結束了,想想在你的本地是不是也這樣,你在你的終端運行,打開瀏覽器是沒有問題的,退出終端,再刷新頁面,就出問題了。
那這個問題要如何解決呢?呃,如果你之前有接觸過 node,那應該就聽過 pm2 這個詞了。是的,沒錯,接下來我們就用這個 pm2 解決我們的問題。
pm2 運行程序如何學習 pm2 呢,最快的方式就去看它的 官網 咯,里面的文檔還是寫的很不錯的,一個 Quick Start 直接入門。
這里就不多介紹了,看文檔會更快了解。 那接下來怎么跑呢,你可以看到 package.json 里面的 script 還有個命令,就是 pm2,這個就是我之前已經添加好了,用 pm2 來啟動程序的命令。具體如下:
# 先登錄到云服務器 ssh hostname # 進入代碼目錄 cd /opt/koa-demo # run npm run pm2
這個時候,即使你退出了,再次刷新頁面,也不會有問題了。
Docker 部署docker,你應該聽過這個名詞吧,沒聽過說明你有點跟不上時代阿。 如果沒有了解過 docker,可以參考阮一峰老師的 Docker 入門教程。
接下來,就試一試如何利用 docker 部署我們的 nodejs 應用。
首先,我們需要在我們的 koa-demo 中添加 Dockerfile 和.dockerignore。我已經在代碼中添加好了,你可以直接簡單地復制到你的項目中。至于其中的那些命令代表什么意思,就不多解釋了。你看完阮老師的那篇文章,多少有點了解了。或者你可以 docker COMMAND -h 獲取各個命令的使用。
云主機安裝 docker首先,我們需要在云主機上安裝 docker,可以參考 docker 官網 About Docker CE, 里面有關于各個系統的安裝說明,很詳細了。
編譯鏡像進入到我們的代碼目錄,利用 docker build 命令,編譯出我們需要的鏡像文件,然后用 docker run,運行容器
cd /opt/koa-demo docker build -t koa-demo . docker run -d -p 7000:3000 koa-demo
這里,我用本地的 7000 端口映射容器的 3000 端口。
這個時候,你可以使用一下命令,看是否正確運行
curl -i localhost:7000 # 應該會返回如下結果 HTTP/1.1 200 OK Content-Type: text/plain; charset=utf-8 Content-Length: 30 Date: Mon, 02 Jul 2018 12:12:26 GMT Connection: keep-alive It"s success, congratulation!
現在,我們的容器已經跑起來了,你可以想試試直接在瀏覽器輸入 ip:port 這樣的形式是否可以訪問,等你輸入之后,你會發現是沒有反應的。
為什么呢,不要急,我們還沒有添加 nginx 配置呢。
cd /etc/nginx/conf.d vi docker-demo.conf # 寫入以下內容 upstream docker-demo { server 127.0.0.1:7000; } server { listen 7000; location / { proxy_pass http://docker-demo; } }
記得用 nginx -t 來測試你的 conf 是否 ok, 然后 nginx -s reload 重新加載一下。
這個時候,你就可以用 IP:Port(這里的 Port 是上面的 listen 的端口) 的形式訪問了。
假如,你這個時候還是沒法訪問的話,有可能是你的安全組設置的問題,設置一下即可。
總結以上就是一個小白的辛酸部署路,路程艱辛,但學到了不少東西,收獲很多。
討論地址歡迎一起討論,github地址 從零開始學習部署
參考資料誰說前端不需要懂-Nginx 反向代理與負載均衡
Dockerizing a Node.js web app
Get Docker CE for CentOS
Docker — 從入門到實踐
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://specialneedsforspecialkids.com/yun/27357.html
摘要:后來網上看到了很多和搭建的靜態博客,由于編輯器的實用性,及,等代碼托管平臺的免費特點,讓很多人都轉向了和。于是我也花了兩三天的時間來研究搭建了自己的博客。 以前的博客(blog.duweibin.cn)是在學習thinkphp的時候自己做的一個小項目,模板也是網上找的,后臺是自己用thinkphp框架寫的,上一個博客搭建過程中讓自己學會了thinkphp對MVC操作,(M層還沒具體用過...
摘要:盡量按照前端后端部署運維來講,當然中途涉及到跨域這種前后協調的還是無法避免捎帶一筆。關于我目前在寫從零構建前后分離項目系列,修正和補充以此為準不斷更新的項目實踐地址彩蛋提前預覽下一章傳送門 序: 開源的意義 本系列提前首發地址 背景 從事了近4年的互聯網行業,逐漸擔當過團隊的前端到后端的負責人,和大家一樣從小白逐漸的成長起來,回首望去幾年前的博客還是那么稚嫩。 回首這幾年: 從一個ja...
摘要:列表是中數據類型其中的一種關鍵字是。列表是一種可變序列類型我們可以追加插入刪除和替換列表中的元素。 列表是python中數據類型其中的一種,關鍵字是list。列表(list)是一種可變序列類型,我們可以追加、插入、刪除和 替換列表中的元...
摘要:從前端到后端到運維,經歷了幾次前后端架構的演變,踩了無數的坑,度過無數難免的夜。為了工作或學習,確實造過一些輪子,前端的后端的,也開源出來過覺得能提高生產力的。 showImg(https://segmentfault.com/img/bVbgeXP?w=713&h=275); 序: 開源的意義 本系列提前首發地址 背景 從事了近4年的互聯網行業,逐漸擔當過團隊的前端到后端的負責人,和...
閱讀 3794·2023-04-25 16:32
閱讀 2194·2021-09-28 09:36
閱讀 2034·2021-09-06 15:02
閱讀 673·2021-09-02 15:21
閱讀 918·2019-08-30 15:56
閱讀 3513·2019-08-30 15:45
閱讀 1708·2019-08-30 13:09
閱讀 379·2019-08-29 16:05