摘要:前言本文講解的是做為前端開發人員,對服務器的了解還是小白的我,是如何一步步將項目部署在阿里云的服務器上,并進行性能優化,達到頁面秒內看到,秒內看到首屏內容的。搭建的項目是采用了主流的前后端分離思想的,這里只講服務器環境搭建與性能優化。
前言
本文講解的是:做為前端開發人員,對服務器的了解還是小白的我,是如何一步步將 node+mongodb 項目部署在阿里云 centos 7.3 的服務器上,并進行性能優化,達到頁面 1 秒內看到 loading ,3 秒內看到首屏內容的。
搭建的項目是采用了主流的前后端分離思想的,這里只講 服務器環境搭建與性能優化。
效果請看 http://biaochenxuying.cn/main.html
1. 流程開發好前端與后端程序。
購買服務器與域名
服務器上安裝所需環境(本項目是 node 和 mongodb )
服務器上開放端口與設置規則
用 nginx、apache 或者tomcat 來提供HTTP服務或者設置代理
上傳項目代碼 或者 用碼云或者 gihub 來拉取你的代碼到服務器上
啟動 express 服務器
優化頁面加載
2. 內容細節 2.1 開發好前端與后端程序開發好前端與后端程序,這個沒什么好說的,就是開發!開發!開發!再開發!
2.2 購買服務器與域名本人一直覺得程序員應該有一個自己的個人網站,擁有自己的域名與服務器。學知識或者測試項目的時候可以用來測試。
阿里云有個專供學生的云翼計劃 阿里云學生套餐,入門級的云服務器原價1400多,學生認證后只要114一年,非常劃算。
還是學生的,直接購買;不是學生了,有弟弟、妹妹的,可以用他們的大學生身份,購買,非常便宜實用(我購買的就是學生優惠套餐)。當然阿里云服務器在每年雙 11 時都有很大優惠,也很便宜,選什么配置與價格得看自己的用處。
服務器預裝環境可以選擇 CentOS 或者 windows server,,為了體驗和學習 linux 系統,我選擇了CentOS。
再次是購買域名 阿里域名購買,本人也是在阿里云購買的。域名是分 國際域名與國內域名的,國際域名是不用備案的,但是國內的域名是必須 ICP備案的 阿里云ICP代備案管理系統,不然不能用,如果是國內域名,如何備案域名,請自己上網查找教程。
當然如果你的網站只用來自己用的話,可以不用買域名,因為可以通過服務器的公網 ip 來訪問網站內容的。
如果購買了域名了,還要設置域名映射到相應的公網 ip ,不然也不能用。
3. 服務器上安裝所需環境(本項目是 node 和 mongodb ) 3.1 登錄服務器因本人用的是 MacBook Pro ,所以直接打開 mac 終端,通過下面的命令行連接到服務器。root 是阿里云服務器默認的賬號名,連接時候會叫你輸入密碼,輸入你購買時設置的或者后來設置的密碼。
ssh root@47.106.20.666 //你的服務器公網 ip,比如 47.106.20.666
如圖:
window 系統的,請用 Putty 或 Xshell 來登錄,可以參考一下這篇文章 把 Node.js 項目部署到阿里云服務器(CentOs)
一般在新服務器創建后,建議先升級一下 CentOS:
yum -y update
常用的 Linux 命令
cd 進入目錄 cd .. 返回上一個目錄 ls -a 查看當前目錄 mkdir abc 創建abc文件夾 mv 移動或重命名 rm 刪除一個文件或者目錄3.2 安裝 node
升級常用庫文件, 安裝 node.js 需要通過 g++ 進行編譯。
yum -y install gcc gcc-c++ autoconf
跳轉到目錄:/usr/local/src,這個文件夾通常用來存放軟件源代碼:
cd /usr/local/src
下載 node.js 源碼,也可以使用 scp 命令直接上傳,因為下載實在太慢了:
下載地址:Downloads,請下載最新的相應版本的源碼進行下載,本人下載了 v10.13.0 版本的。
https://nodejs.org/dist/v10.13.0/node-v10.13.0.tar.gz
下載完成后解壓:
tar -xzvf node-v10.13.0.tar.gz
進入解壓后的文件夾:
cd node-v10.13.0
執行配置腳本來進行預編譯處理:
./configure
編譯源代碼,這個步驟花的時間會很長,大概需要 5 到 10 分鐘:
make
編譯完成后,執行安裝命令,使之在系統范圍內可用:
make install
安裝 express 推薦 global 安裝
npm -g install express
建立超級鏈接, 不然 sudo node 時會報 "command not found"
sudo ln -s /usr/local/bin/node /usr/bin/node sudo ln -s /usr/local/lib/node /usr/lib/node sudo ln -s /usr/local/bin/npm /usr/bin/npm sudo ln -s /usr/local/bin/node-waf /usr/bin/node-waf
通過指令查看 node 及 npm 版本:
node -v
npm -v
node.js 到這里就基本安裝完成了。
3.2 安裝 mongodb下載地址:mongodb
下載時,請選對相應的環境與版本,因為本人的服務器是 CentOS ,其實本質就是 linux 系統,所以選擇了如下圖環境與目前最新的版本。
mongodb :
軟件安裝位置:/usr/local/mongodb 數據存放位置:/home/mongodb/data 數據備份位置:/home/mongodb/bak 日志存放位置:/home/mongodb/logs
下載安裝包
> cd /usr/local > wget https://fastdl.mongodb.org/linux/mongodb-linux-x86_64-4.0.4.tgz
解壓安裝包,重命名文件夾為 mongodb
tar zxvf mongodb-linux-x86_64-4.0.4.tgz mv mongodb-linux-x86_64-4.0.4 mongodb
在 var 文件夾里建立 mongodb 文件夾,并分別建立文件夾 data 用于存放數據,logs 用于存放日志
mkdir /var/mongodb mkdir /var/mongodb/data mkdir /var/mongodb/logs
打開 rc.local 文件,添加 CentOS 開機啟動項:
vim /etc/rc.d/rc.local // 不懂 vim 操作的請自行查看相應的文檔教程,比如: vim 模式下,要 按了 i 才能插入內容,輸入完之后,要按 shift 加 :wq 才能保存退出。
將 mongodb 啟動命令追加到本文件中,讓 mongodb 開機自啟動:
/usr/local/mongodb/bin/mongod --dbpath=/var/mongodb/data --logpath /var/mongodb/logs/log.log -fork
啟動 mongodb
/usr/local/mongodb/bin/mongod --dbpath=/var/mongodb/data --logpath /var/mongodb/logs/log.log -fork
看到如下信息說明已經安裝完成并成功啟動:
forked process: 18394 all output going to: /var/mongodb/logs/log.log
mongodb 默認的端口號是 27017。
如果你數據庫的連接要賬號和密碼的,要創建數據庫管理員,不然直接連接即可。
在 mongo shell 中創建管理員及數據庫。
切換到 admin 數據庫,創建超級管理員帳號
use admin db.createUser({ user: "用戶名", pwd:"登陸密碼", roles:[{ role: "userAdminAnyDatabase", db: "admin" }] })
切換到要使用的數據庫,如 taodb 數據庫,創建這個數據庫的管理員帳號
use taodb
db.createUser({ user: "用戶名", pwd:"登陸密碼", roles:[ { role: "readWrite", db: "taodb" }] //讀寫權限 })
重復按兩下 control+c ,退出 mongo shell。
到這里 mongodb 基本已經安裝設置完成了。
備份與恢復 請看這篇文章:MongoDB 備份(mongodump)與恢復(mongorestore)
安裝 node 與 mongodb 也可以參考這篇文章:CentOs搭建NodeJs服務器—Mongodb安裝
如果你只放靜態的網頁,可以參考這個篇文章 通過云虛擬主機控制臺設置默認首頁
但是我們是要部署后臺程序的,所以要看以下的內容:
安全組規則是什么鬼
授權安全組規則可以允許或者禁止與安全組相關聯的 ECS 實例的公網和內網的入方向和出方向的訪問。?
阿里云安全組應用案例文檔80 端口是為 HTTP(HyperText Transport Protocol) 即超文本傳輸協議開放的,瀏覽器 HTTP 訪問 IP 或域名的 80 端口時,可以省略 80 端口號
如果我們沒有開放相應的端口,
比如我們的服務要用到 3000 ,就要開放 3000 的端口,不然是訪問不了的;其他端口同理。
端口都配置對了,以為能用公網 IP 進行訪問了么 ? 小兄弟你太天真了 ...
還有 防火墻 這一關呢,如果防火墻沒有關閉或者相關的端口沒有開放,也是不能用公網 IP 進行訪問網站內容的。
和安全組端口同理,比如我們的服務要用到的是 3000 端口,就要開放 3000 的端口,不然是訪問不了的;其他端口同理。
出于安全考慮還是把防火墻開上,只開放相應的端口最好。
怎么開放相應的端口 ? 看下面兩篇文章足矣,這里就不展開了。
1. 將nodejs項目部署到阿里云ESC服務器,linux系統配置80端口,實現公網IP訪問3.4 用 nginx、apache 或者 tomcat 來提供 HTTP 服務或者設置代理2. centos出現“FirewallD is not running”怎么辦
我是用了 nginx 的,所以這里只介紹 nginx 。
安裝 nginx 請看這兩篇文章:
1. Centos7安裝Nginx實戰2. 阿里云Centos7安裝Nginx服務器實現反向代理
開啟 ngnx 代理
進入到目錄位置
cd /usr/local/nginx
在 nginx 目錄下有一個 sbin 目錄,sbin 目錄下有一個 nginx 可執行程序。
./nginx
關閉 nginx
./nginx -s stop
重啟
./nginx -s reload
基本的使用就是這樣子了。
如下給出我的 nginx 代理的設置:
我的兩個項目是放在 /home/blog/blog-react/build/; 和 /home/blog/blog-react-admin/dist/; 下的,如果你們的路徑不是這個,請修改成你們的路徑。
#user nobody; worker_processes 1; #error_log logs/error.log; #error_log logs/error.log notice; #error_log logs/error.log info; #pid logs/nginx.pid; events { worker_connections 1024; } http { include mime.types; default_type application/octet-stream; #log_format main "$remote_addr - $remote_user [$time_local] "$request" " # "$status $body_bytes_sent "$http_referer" " # ""$http_user_agent" "$http_x_forwarded_for""; #access_log logs/access.log main; sendfile on; #tcp_nopush on; #keepalive_timeout 0; keepalive_timeout 65; #gzip on; # 如果port_in_redirect為off時,那么始終按照默認的80端口;如果該指令打開,那么將會返回當前正在監聽的端口。 port_in_redirect off; # 前臺展示打開的服務代理 server { listen 80; server_name localhost; #charset koi8-r; #access_log logs/host.access.log main; #root /home/blog; location / { root /home/blog/blog-react/build/; index index.html; try_files $uri $uri/ @router; autoindex on; } location @router{ rewrite ^.*$ /index.html last; } location /api/ { proxy_set_header X-Real-IP $remote_addr; proxy_pass http://47.106.136.114:3000/ ; } gzip on; gzip_buffers 32 4k; gzip_comp_level 6; gzip_min_length 200; gzip_types text/css text/xml application/javascript; gzip_vary on; #error_page 404 /404.html; # redirect server error pages to the static page /50x.html # error_page 500 502 503 504 /50x.html; location = /50x.html { root html; } } # HTTPS server # 管理后臺打開的服務代理 server { listen 4444; server_name localhost; # charset koi8-r; # ssl_certificate cert.pem; # ssl_certificate_key cert.key; # ssl_session_cache shared:SSL:1m; # ssl_session_timeout 5m; # ssl_ciphers HIGH:!aNULL:!MD5; # ssl_prefer_server_ciphers on; location / { root /home/blog/blog-react-admin/dist/; index index.html index.htm; try_files $uri $uri/ @router; autoindex on; } location @router{ rewrite ^.*$ /index.html last; } location /api/ { proxy_set_header X-Real-IP $remote_addr; proxy_pass http://47.106.136.114:3000/ ; } gzip on; gzip_buffers 32 4k; gzip_comp_level 6; gzip_min_length 200; gzip_types text/css text/xml application/javascript; gzip_vary on; error_page 500 502 503 504 /50x.html; } }
我是開了兩個代理的:前臺展示打開的服務代理和管理后臺打開的服務代理,這個項目是分開端口訪問的。
比如:我的公網 ip 是 47.106.20.666,那么可以通過 http://47.106.20.666 即可訪問前臺展示,http://47.106.20.666:4444 即可訪問管理后臺的登錄界面。
至于為什么要寫這樣的配置:
try_files $uri $uri/ @router; location @router{ rewrite ^.*$ /index.html last; }
因為進入到文章詳情時或者前端路由變化了,再刷新瀏覽器,發現瀏覽器出現 404 。刷新頁面時訪問的資源在服務端找不到,因為 react-router 設置的路徑不是真實存在的路徑。
所以那樣設置是為了可以刷新還可以打到對應的路徑的。
刷新出現 404 問題,可以看下這篇文章 react,vue等部署單頁面項目時,訪問刷新出現404問題3.5 上傳項目代碼,或者用碼云、 gihub 來拉取你的代碼到服務器上
我是創建了碼云的賬號來管理項目代碼的,因為碼云上可以創建免費的私有倉庫,我在本地把碼上傳到 Gitee.com 上,再進入服務器用 git 把代碼拉取下來就可以了,非常方便。
具體請看:碼云(Gitee.com)幫助文檔 V1.2
git 的安裝請看: CentOS 7.4 系統安裝 git
如果不想用 git 進行代碼管理,請用其他可以連接服務器上傳文件的軟件,比如 FileZilla。
3.6 啟動 express 服務啟動 express 服務,我用了 pm2, 可以永久運行在服務器上,且不會一報錯 express 服務就掛了,而且運行中還可以進行其他操作。
安裝:
npm install -g pm2
切換當前工作目錄到 express 應用文件夾下,執行 pm2 命令啟動 express 服務:
pm2 start ./bin/www
比如我操作項目時的基本操作:
cd /home/blog/blog-node pm2 start ./bin/www // 開啟 pm2 stop ./bin/www // 關閉 pm2 list //查看所用已啟動項目:3.7 頁面加載優化
再看剛剛的 nginx 的一些配置:
server { gzip on; gzip_buffers 32 4k; gzip_comp_level 6; gzip_min_length 200; gzip_types text/css text/xml application/javascript; gzip_vary on; }
這個就是利用 ngonx 開啟 gzip,親測開啟之后,壓縮了接近 2/3 的文件大小,本來要 1M 多的文件,開啟壓縮之后,變成了 300k 左右。
還有其他的優化請看這篇文章 React 16 加載性能優化指南,寫的很不錯,我的一些優化都是參考了這個篇文章的。
做完一系列的優化處理之后,在網絡正常的情況下,頁面首屏渲染由本來是接近 5 秒,變成了 3 秒內,首屏渲染之前的 loading 在 1 秒內可見了。
4. 項目地址本人的個人博客項目地址:
前臺展示: https://github.com/biaochenxuying/blog-react管理后臺:https://github.com/biaochenxuying/blog-react-admin
后端:https://github.com/biaochenxuying/blog-node
blog:https://github.com/biaochenxuying/blog
本博客系統的系列文章:
react + node + express + ant + mongodb 的簡潔兼時尚的博客網站
react + Ant Design + 支持 markdown 的 blog-react 項目文檔說明
基于 node + express + mongodb 的 blog-node 項目文檔說明
服務器小白的我,是如何將node+mongodb項目部署在服務器上并進行性能優化的
5. 最后對 全棧修煉 有興趣的朋友可以掃下方二維碼關注我的公眾號
我會不定期更新有價值的內容,長期運營。
關注公眾號并回復 福利 可領取免費學習資料,福利詳情請猛戳: Python、Java、Linux、Go、node、vue、react、javaScript
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/19432.html
摘要:前言此項目是用于構建博客網站的,由三部分組成,包含前臺展示管理后臺和后端。體驗地址網站主頁網站首頁管理后臺計劃這次是一個完整的全棧式開發,只要部署了這三個項目的代碼,是完全可以搭建好博客網站的。 showImg(https://segmentfault.com/img/remote/1460000017095592); 前言 此項目是用于構建博客網站的,由三部分組成,包含前臺展示、管理...
摘要:前言此項目是基于螞蟻金服開源的之上,用全家桶的進行再次開發的,項目已經開源,項目地址在上。項目地址開源不易,如果覺得該項目不錯或者對你有所幫助,歡迎到上給個,謝謝。 showImg(https://segmentfault.com/img/remote/1460000017116745); 前言 此 blog-react-admin 項目是基于 螞蟻金服開源的 ant design p...
摘要:前言是采用了主流的前后端分離思想的,主里只講后端。項目是的進行開發的,項目已經開源,項目地址在上。路由接口主文件所有的路由接口文章各模塊的列表都是用了分頁的形式的。 showImg(https://segmentfault.com/img/remote/1460000017136149); 前言 blog-node 是采用了主流的前后端分離思想的,主里只講 后端。 blog-node ...
摘要:本地和服務器環境本地位服務器阿里云輕量應用服務器使用的連接工具當然還有這幾個中任選一個就好啦。連接工具使用方法創建填入服務器地址和用戶名,點擊確認然后輸入密碼即可。執行測試項目新建項目文件。使用編輯器打開項目文件。 本地和服務器環境 本地:Windows10 64位 服務器:阿里云輕量應用服務器CentOS 7.3 使用的連接工具:puttymobaxterm當然還有Xshell這幾個...
閱讀 1895·2021-11-15 11:46
閱讀 1091·2021-10-26 09:49
閱讀 1825·2021-10-14 09:42
閱讀 3384·2021-09-26 09:55
閱讀 838·2019-08-30 13:58
閱讀 1039·2019-08-29 16:40
閱讀 3474·2019-08-26 10:27
閱讀 611·2019-08-23 18:18