主頁 > 軟體設計 > 前端專案環境搭建并部署專案(推薦)

前端專案環境搭建并部署專案(推薦)

2021-08-17 07:31:55 軟體設計

本次主要講解的是服務器上node環境的搭建,以及vue/react/等的專案的部署,作為一名前端,一定要學會哦,

購買云服務器/主機

云服務器:阿里云、百度云、新浪云、騰訊云

主機:不建議購買,共享的不穩定

我下面的案例用10幾塊的渣渣云服務器進行演示,因為便宜,但我不推薦你們用


購買域名,進行備案

這個步驟可以不需要先進行,有了服務器有公網ip也可以訪問,域名后面講


遠程連接

1. 阿里云等服務器網頁自帶的 , 輸入遠程連接密碼

2.通過ssh客戶端連接(推薦)

由于我用的Mac,所以我就用Termius演示吧,windows的話推薦putty等ssh工具,搜索關鍵詞windows常用ssh

如圖上只需要address(公網ip)和port(ssh埠號),這里有必要宣告一下:

  1. 云服務器回默認22為ssh埠號
  2. 共享云主機分配給你ip一般就是ssh埠號

連接成功后如下:

安裝node

如何從EPEL庫安裝Node.js

另一個有效且簡單的方法來安裝Node.js就是從官方庫,這同樣確保您可以訪問到EPEL庫,

你可以通過運行以下命令,

sudo yum install epel-release

現在可以使用yum命令安裝Node.js了,

sudo yum install nodejs

因為在開發程序中我需要管理節點包,我還要安裝新公共管理的軟體包管理器,

使用以下命令,

sudo yum install npm

whereis node 

三條安裝命令, 中間有提示yes/no的一律按y,帶寬小的耐心等待安裝
安裝成功后執行where is node 如下,表明已經安裝成功


配置安全組

云服務器的話可以配置,云主機的話一般不給配置,這個根據需求來配置,一般我都是配置

1. 埠范圍   1/60000
2. 授權物件: 0.0.0.0/0

我不建議大家這樣配置 ,安全組顧名思義為了安全,所以埠應該開放的越少越好,例如你要用8080埠那么給個8080就好了

當然也有的是給你配置防火墻的,如果你的埠不能用,請查看安全組或者防火墻有沒有打開你要用的埠

這里的演示暫且跳過,上圖大家想必能看懂,就是配置了幾個埠,


測驗是否可用

我們測驗上傳一個server.js看看,先做如下準備作業:

檔案上傳的話我們推薦xftp或者xshell等ftp工具

我用FileZilla演示,界面都差不多的,首先我們連接到服務器:

這個就是協議不對了,我們修改下連接協議

修改成sftp協議后點擊連接

如上連接成功!

既然連接成功那我們寫個簡單的介面:

// 匯入http模塊:
var http = require('http');
// 創建http server,并傳入回呼函式:
var server = http.createServer(function (request, response) {
    // 回呼函式接收request和response物件,
    // 獲得HTTP請求的method和url:
    console.log(request.method + ': ' + request.url);
    // 將HTTP回應200寫入response, 同時設定Content-Type: text/html:
    response.writeHead(200, {'Content-Type': 'text/html'});
    // 將HTTP回應的HTML內容寫入response:
    response.end('Hello world!');
});

// 讓服務器監聽8080埠:
server.listen(8089);

console.log('Server is running at http://127.0.0.1:8089/');

這條介面本地可以運行,那么我們再用ftp工具上傳到服務器

再用ssh工具運行

運行后我們打開站點,ip:埠,發現無法訪問

這時我們去檢測下埠號(http://coolaf.com/tool/port)的開放情況,發現如下圖,22是開放的,8089是關閉的,這也就是為什么我們ssh和ftp能通過22埠連接,8089不能訪問站點的原因了,那么我們就得打開埠了,方式前面提到過,就是安全組和防火墻,開啟就行當然也可以通過命令打開,下面我用命令打開埠


命令列控制防火墻

//打開8000-9000埠,成功回傳success
firewall-cmd --zone=public --add-port=8000-9000/udp --permanen

//打開8089埠,成功回傳success
firewall-cmd --zone=public --add-port=8089/tcp --permanent

//重啟防火墻,成功回傳success
firewall-cmd --reload

//檢測是否打開埠,成功打開回傳yes
firewall-cmd --zone=public --query-port=8089/tcp

執行了上述操作后,可以看到已經可以訪問了


添加負載均衡(pm2)

你看我們是啟動了這個測驗案例,可是如果服務器重啟,那么案例就直接結束了,這是相當不對的,所以我們需要負載均衡,即用就掛起服務,

npm i pm2 -g 全域安裝pm2

pm2 start app.js  后臺掛起服務

pm2 list  查看后臺掛起所有服務

pm2 stop id  根據服務id 停止當前服務 

pm2 delete id 根據服務 id 洗掉當前服務 

pm2 restart id 重啟服務 

安裝后報錯,是node和npm的版本問題

執行下面的 命令

sudo npm install -g n

# 最新版本
n lastest
# 穩定版本
n stable
# 安裝指定版本
n 10.12.0

執行pm2 list,如下說明成功

pm2安裝好了,我們再來通過pm2啟動測驗案例:

pm2 start后再執行兩條命令

使用pm2 start (啟動服務) --- 上面我們執行了
執行pm2 save (保存當前已經啟動了的服務)
執行pm2 startup (設定開機自啟的配置)

設定開機自啟成功!重啟服務器看下,loading....啟動成功!

pm2開機自啟到此已經成功了!


安裝MongoDB

MongoDB 是一個介于關系資料庫和非關系資料庫之間的產品,是非關系資料庫當中功能最豐富,最像關系資料庫的,他支持的資料結構非常松散,是類似json的bson格式,因此可以存盤比較復雜的資料型別,Mongo最大的特點是他支持的查詢語言非常強大,其語法有點類似于面向物件的查詢語言,幾乎可以實作類似關系資料庫單表查詢的絕大部分功能,而且還支持對資料建立索引,
Packages包說明
MongoDB官方源中包含以下幾個依賴包:
mongodb-org: MongoDB元資料包,安裝時自動安裝下面四個組件包:
1.mongodb-org-server: 包含MongoDB守護行程和相關的配置和初始化腳本,
2.mongodb-org-mongos: 包含mongos的守護行程,
3.mongodb-org-shell: 包含mongo shell,
4.mongodb-org-tools: 包含MongoDB的工具: mongoimport, bsondump, mongodump, mongoexport, mongofiles, mongooplog, mongoperf, mongorestore, mongostat, and mongotop,

安裝mongodb程序中注意以下幾個知識點

1. vim命令基本使用
       1. vim a.txt
       2. 先按鍵盤的 i
       3. 寫入內容 (shift + ins)
       4. 退出 先按 ESC 鍵
       5. 再打 **: wq** 會出即可保存并退出
 2. 注意點: 防火墻忽略

1.配置MongoDB的yum源

創建yum源檔案:

vi /etc/yum.repos.d/mongodb-org-3.4.repo

添加以下內容:

[mongodb-org-3.4]  
name=MongoDB Repository  
baseurl=https://repo.mongodb.org/yum/redhat/$releasever/mongodb-org/3.4/x86_64/  
gpgcheck=1  
enabled=1  
gpgkey=https://www.mongodb.org/static/pgp/server-3.4.asc

這里可以修改 gpgcheck=0, 省去gpg驗證

安裝之前先更新所有包 :yum update (可選操作)

2.安裝mongodb

安裝命令

yum -y install mongodb-org

安裝完成后
查看mongo安裝位置 whereis mongod
查看修改組態檔 : vim /etc/mongod.conf


3.啟動MongoDB
啟動mongodb :systemctl start mongod.service
停止mongodb :systemctl stop mongod.service
查到mongodb的狀態:systemctl status mongod.service

4.設定開機啟動

設定開機啟動 :systemctl enable mongod.service

5.啟動mongodb

啟動:mongo shell

6.設定mongodb遠程訪問

注意先打開27017埠,前面有講怎么打開

重啟mongodb:systemctl restart mongod.service


nginx安裝 /配置

Nginx 是 C語言 開發,建議在 Linux 上運行,當然,也可以安裝 Windows 版本,本篇則使用 [CentOS](https://www.linuxidc.com/topicnews.aspx?tid=14) 7 作為安裝環境,

1.gcc 安裝

安裝 nginx 需要先將官網下載的原始碼進行編譯,編譯依賴 gcc 環境,如果沒有 gcc 環境,則需要安裝:

yum install gcc-c++

2.PCRE pcre-devel 安裝

PCRE(Perl Compatible Regular Expressions) 是一個Perl庫,包括 perl 兼容的正則運算式庫,nginx 的 http 模塊使用 pcre 來決議正則運算式,所以需要在 linux 上安裝 pcre 庫,pcre-devel 是使用 pcre 開發的一個二次開發庫,nginx也需要此庫,命令:

yum install -y pcre pcre-devel

3.zlib 安裝

zlib 庫提供了很多種壓縮和解壓縮的方式, nginx 使用 zlib 對 http 包的內容進行 gzip ,所以需要在 Centos 上安裝 zlib 庫,

yum install -y zlib zlib-devel

4.OpenSSL 安裝

OpenSSL 是一個強大的安全套接字層密碼庫,囊括主要的密碼演算法、常用的密鑰和證書封裝管理功能及 SSL 協議,并提供豐富的應用程式供測驗或其它目的使用,
nginx 不僅支持 http 協議,還支持 https(即在ssl協議上傳輸http),所以需要在 Centos 安裝 OpenSSL 庫

yum install -y openssl openssl-devel

5.下載nginx

官網下載https://nginx.org/en/download.html

使用`wget`命令下載:

wget -c https://nginx.org/download/nginx-1.10.1.tar.gz

兩種方式下哪個版本看自己需求,盡量用穩定版,

6.解壓:

tar -zxvf nginx-1.10.1.tar.gz
cd nginx-1.10.1

7.配置:

其實在 nginx-1.10.1 版本中你就不需要去配置相關東西,默認就可以了,當然,如果你要自己配置目錄也是可以的,

1.使用默認配置

./configure 

2.自定義配置(不推薦)

+
    ./configure \
    --prefix=/usr/local/nginx \
    --conf-path=/usr/local/nginx/conf/nginx.conf \
    --pid-path=/usr/local/nginx/conf/nginx.pid \
    --lock-path=/var/lock/nginx.lock \
    --error-log-path=/var/log/nginx/error.log \
    --http-log-path=/var/log/nginx/access.log \
    --with-http_gzip_static_module \
    --http-client-body-temp-path=/var/temp/nginx/client \
    --http-proxy-temp-path=/var/temp/nginx/proxy \
    --http-fastcgi-temp-path=/var/temp/nginx/fastcgi \
    --http-uwsgi-temp-path=/var/temp/nginx/uwsgi \
    --http-scgi-temp-path=/var/temp/nginx/scgi

注:將臨時檔案目錄指定為/var/temp/nginx,需要在/var下創建temp及nginx目錄

3.配置https支持的ssl模塊

./configure --prefix=/usr/local/nginx --with-http_ssl_module

8.編譯安裝

make
make install

9.查找安裝路徑

whereis nginx

10.啟動、停止nginx

cd /usr/local/nginx/sbin/
./nginx 
./nginx -s stop
./nginx -s quit
./nginx -s reload

`./nginx -s quit`:此方式停止步驟是待nginx行程處理任務完畢進行停止,
`./nginx -s stop`:此方式相當于先查出nginx行程id再使用kill命令強制殺掉行程

查詢nginx行程:

ps aux|grep nginx

11.重啟 nginx

1.先停止再啟動(推薦):
對 nginx 進行重啟相當于先停止再啟動,即先執行停止命令再執行啟動命令,如下:

./nginx -s quit
./nginx

2.重新加載組態檔:
當 ngin x的組態檔 nginx.conf 修改后,要想讓配置生效需要重啟 nginx,使用`-s reload`不用先 停止 ngin x再啟動 nginx 即可將配置資訊在 nginx 中生效,如下:

./nginx -s reload

以上的步驟執行完后,瀏覽器輸入公網ip

看到這個,就代表著nginx配置上去了!

12.開機自啟動

vi /etc/rc.local

增加一行:/usr/local/nginx/sbin/nginx

設定執行權限:

chmod 755 /etc/rc.local

到這里,nginx就安裝完畢了,啟動、停止、重啟操作也都完成了,當然,你也可以添加為系統服務,我這里就不在演示了,

就重啟看下!

ok了,如果出不來記得開放80埠!


nginx靜態服務器 \ 反向代理

我們先上傳一個專案,將專案build后的檔案

在 /usr/local/nginx/conf/nginx.conf 中修改如下配置:

server {
          listen 80;
          server_name localhost;
          location / {
            root   html/amap-use;
			try_files $uri /index.html; #解決路由重定向跳轉 404 頁面配置
            index  index.html index.htm;
          }
        }

指向到我們剛剛上傳的檔案!

再打開瀏覽器輸入 公網ip

成功了!

再來看反向代理

例如我們的vue專案,在vue.config.js里配置了反向代理,本地可用發布后獲取不到資料,這個時候我們要配置nignx反向代理

server {
          listen 80;
          server_name localhost;
          location / {
            root   html/amap-use;
			try_files $uri /index.html; #解決路由重定向跳轉 404 頁面配置
            index  index.html index.htm;
          }
          location /marketing { # 解決反向代理資料獲取不到
                proxy_pass https://resource.smartisan.com/marketing;
          }
          location /product {
                proxy_pass https://www.smartisan.com/product;
          }
        }

多專案配置多個埠

解決: 在nginx組態檔中添加多個 server配置, 但是要注意 專案檔案夾要和 nginx /html目錄同級

目錄應該如下:

nginx
       
     html
       
     vue-project
       
     react-project

在 /usr/local/nginx/conf/nginx.conf 中修改如下配置:

server {  #此2為默認埠設定
               listen       80;
               server_name  localhost;
       
               #charset koi8-r;
       
               #access_log  logs/host.access.log  main;
       
               location / {
                   root   project_list;
                   index  index.html index.htm;
               }
       
               #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;
               }
       
               # proxy the PHP scripts to Apache listening on 127.0.0.1:80
               #
               #location ~ \.php$ {
               #    proxy_pass   http://127.0.0.1;
               #}
       
               # pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000
               #
               #location ~ \.php$ {
               #    root           html;
               #    fastcgi_pass   127.0.0.1:9000;
               #    fastcgi_index  index.php;
               #    fastcgi_param  SCRIPT_FILENAME  /scripts$fastcgi_script_name;
               #    include        fastcgi_params;
               #}
       
               # deny access to .htaccess files, if Apache's document root
               # concurs with nginx's one
               #
               #location ~ /\.ht {
               #    deny  all;
               #}
           }
       
       server {
             listen 10002;
             server_name localhost;
             location / {
                 root zmh_react_project;
                  try_files $uri /index.html; #解決路由重定向跳轉 404 頁面配置
                  index index.html;
             }
             location /marketing { # 解決反向代理資料獲取不到
                   proxy_pass https://resource.smartisan.com/marketing;
             }
             location /product {
                   proxy_pass https://www.smartisan.com/product;
             }
           }
           
        server {
             listen 10001;
             server_name localhost;
             location / {
                 root zmh_react_project;
                  try_files $uri /index.html; #解決路由重定向跳轉 404 頁面配置
                  index index.html;
             }
             location /marketing { # 解決反向代理資料獲取不到
                   proxy_pass https://resource.smartisan.com/marketing;
             }
             location /product {
                   proxy_pass https://www.smartisan.com/product;
             }
           }

各位在配置程序中可能會遇到的問題

1.瀏覽器ip打不開

原因可能如下
埠未開放,靜態資源指向錯誤等

卡住可以私信我,看到幫你處理,謝謝大家,

2.如果你是測驗的話建議可以把防火墻關了,或者打開所有埠,因為你會經常忘了自己沒開放打開埠

轉載請註明出處,本文鏈接:https://www.uj5u.com/ruanti/294181.html

標籤:其他

上一篇:harbor高可用部署

下一篇:計算機專業找實習攻略大全,先別急著進大廠搞定實習再說

標籤雲
其他(157675) Python(38076) JavaScript(25376) Java(17977) C(15215) 區塊鏈(8255) C#(7972) AI(7469) 爪哇(7425) MySQL(7132) html(6777) 基礎類(6313) sql(6102) 熊猫(6058) PHP(5869) 数组(5741) R(5409) Linux(5327) 反应(5209) 腳本語言(PerlPython)(5129) 非技術區(4971) Android(4554) 数据框(4311) css(4259) 节点.js(4032) C語言(3288) json(3245) 列表(3129) 扑(3119) C++語言(3117) 安卓(2998) 打字稿(2995) VBA(2789) Java相關(2746) 疑難問題(2699) 细绳(2522) 單片機工控(2479) iOS(2429) ASP.NET(2402) MongoDB(2323) 麻木的(2285) 正则表达式(2254) 字典(2211) 循环(2198) 迅速(2185) 擅长(2169) 镖(2155) 功能(1967) .NET技术(1958) Web開發(1951) python-3.x(1918) HtmlCss(1915) 弹簧靴(1913) C++(1909) xml(1889) PostgreSQL(1872) .NETCore(1853) 谷歌表格(1846) Unity3D(1843) for循环(1842)

熱門瀏覽
  • 面試突擊第一季,第二季,第三季

    第一季必考 https://www.bilibili.com/video/BV1FE411y79Y?from=search&seid=15921726601957489746 第二季分布式 https://www.bilibili.com/video/BV13f4y127ee/?spm_id_fro ......

    uj5u.com 2020-09-10 05:35:24 more
  • 第三單元作業總結

    1.前言 這應該是本學期最后一次寫作業總結了吧。總體來說,對作業的節奏也差不多掌握了,作業做起來的效率也更高了。雖然和之前的作業一樣,作業中都要用到新的知識,但是相比之前,更加懂得了如何利用工具以及資料。雖然之間卡過殼,但總體而言,這幾次作業還算完成的比較好。 2.作業程序總結 相比前兩個單元,此單 ......

    uj5u.com 2020-09-10 05:35:41 more
  • 北航OO(2020)第四單元博客作業暨課程總結博客

    北航OO(2020)第四單元博客作業暨課程總結博客 本單元作業的架構設計 在本單元中,由于UML圖具有比較清晰的樹形結構,因此我對其中需要進行查詢操作的元素進行了包裝,在樹的父節點中存盤所有孩子的參考。考慮到性能問題,我采用了快取機制,一次查詢后盡可能快取已經遍歷過的資訊,以減少遍歷次數。 本單元我 ......

    uj5u.com 2020-09-10 05:35:48 more
  • BUAA_OO_第四單元

    一、UML決議器設計 ? 先看下題目:第四單元實作一個基于JDK 8帶有效性檢查的UML(Unified Modeling Language)類圖,順序圖,狀態圖分析器 MyUmlInteraction,實際上我們要建立一個有向圖模型,UML中的物件(元素)可能與同級元素連接,也可與低級元素相連形成 ......

    uj5u.com 2020-09-10 05:35:54 more
  • 6.1邏輯運算子

    邏輯運算子 1. && 短路與 運算式1 && 運算式2 01.運算式1為true并且運算式2也為true 整體回傳為true 02.運算式1為false,將不會執行運算式2 整體回傳為false 03.只要有一個運算式為false 整體回傳為false 2. || 短路或 運算式1 || 運算式2 ......

    uj5u.com 2020-09-10 05:35:56 more
  • BUAAOO 第四單元 & 課程總結

    1. 第四單元:StarUml檔案決議 本單元采用了圖模型決議UML。 UML檔案可以抽象為圖、子圖、邊的邏輯結構。 在實作中,圖的節點包括類、介面、屬性,子圖包括狀態圖、順序圖等。 采用了三次遍歷UML元素的方法建圖,第一遍遍歷建點,第二、三次遍歷設定屬性、連邊,實作圖物件的初始化。這里借鑒了一些 ......

    uj5u.com 2020-09-10 05:36:06 more
  • 談談我對C# 多型的理解

    面向物件三要素:封裝、繼承、多型。 封裝和繼承,這兩個比較好理解,但要理解多型的話,可就稍微有點難度了。今天,我們就來講講多型的理解。 我們應該經常會看到面試題目:請談談對多型的理解。 其實呢,多型非常簡單,就一句話:呼叫同一種方法產生了不同的結果。 具體實作方式有三種。 一、多載 多載很簡單。 p ......

    uj5u.com 2020-09-10 05:36:09 more
  • Python 資料驅動工具:DDT

    背景 python 的unittest 沒有自帶資料驅動功能。 所以如果使用unittest,同時又想使用資料驅動,那么就可以使用DDT來完成。 DDT是 “Data-Driven Tests”的縮寫。 資料:http://ddt.readthedocs.io/en/latest/ 使用方法 dd. ......

    uj5u.com 2020-09-10 05:36:13 more
  • Python里面的xlrd模塊詳解

    那我就一下面積個問題對xlrd模塊進行學習一下: 1.什么是xlrd模塊? 2.為什么使用xlrd模塊? 3.怎樣使用xlrd模塊? 1.什么是xlrd模塊? ?python操作excel主要用到xlrd和xlwt這兩個庫,即xlrd是讀excel,xlwt是寫excel的庫。 今天就先來說一下xl ......

    uj5u.com 2020-09-10 05:36:28 more
  • 當我們創建HashMap時,底層到底做了什么?

    jdk1.7中的底層實作程序(底層基于陣列+鏈表) 在我們new HashMap()時,底層創建了默認長度為16的一維陣列Entry[ ] table。當我們呼叫map.put(key1,value1)方法向HashMap里添加資料的時候: 首先,呼叫key1所在類的hashCode()計算key1 ......

    uj5u.com 2020-09-10 05:36:38 more
最新发布
  • 【中介者設計模式詳解】C/Java/JS/Go/Python/TS不同語言實作

    * 中介者模式是一種行為型設計模式,它可以用來減少類之間的直接依賴關系,
    * 將物件之間的通信封裝到一個中介者物件中,從而使得各個物件之間的關系更加松散。
    * 在中介者模式中,物件之間不再直接相互互動,而是通過中介者來中轉訊息。 ......

    uj5u.com 2023-04-20 08:20:47 more
  • 露天煤礦現場調研和交流案例分享

    他們集團的資訊化公司及研究院在一個礦區正在做智能礦山的統一平臺的 試點,專案投資大概1億,包括了礦山的各方面的內容,顯示得我們這次交流有點多余。他們2年前開始做智能礦山的規劃,有很多煤礦行業專家的加持,他們的描述是非常完美,但是去年底應該上線的平臺,現在還沒有看到影子。他們確實有很多場景需求,但是被... ......

    uj5u.com 2023-04-20 08:20:25 more
  • 《社區人員管理》實戰案例設計&個人案例分享

    設計是一個讓人夢想成真程序,開始編碼、測驗、除錯之前進行需求分析和架構設計,才能保證關鍵方面都做正確 ......

    uj5u.com 2023-04-20 08:20:17 more
  • 軟體架構生態化-多角色交付的探索實踐

    作為一個技術架構師,不僅僅要緊跟行業技術趨勢,還要結合研發團隊現狀及痛點,探索新的交付方案。在日常中,你是否遇到如下問題 “ 業務需求排期長研發是瓶頸;非研發角色感受不到研發技改提效的變化;引入ISV 團隊又擔心質量和安全,培訓周期長“等等,基于此我們探索了一種新的技術體系及交付方案來解決如上問題。 ......

    uj5u.com 2023-04-20 08:20:10 more
  • 【中介者設計模式詳解】C/Java/JS/Go/Python/TS不同語言實作

    * 中介者模式是一種行為型設計模式,它可以用來減少類之間的直接依賴關系,
    * 將物件之間的通信封裝到一個中介者物件中,從而使得各個物件之間的關系更加松散。
    * 在中介者模式中,物件之間不再直接相互互動,而是通過中介者來中轉訊息。 ......

    uj5u.com 2023-04-20 08:19:44 more
  • 露天煤礦現場調研和交流案例分享

    他們集團的資訊化公司及研究院在一個礦區正在做智能礦山的統一平臺的 試點,專案投資大概1億,包括了礦山的各方面的內容,顯示得我們這次交流有點多余。他們2年前開始做智能礦山的規劃,有很多煤礦行業專家的加持,他們的描述是非常完美,但是去年底應該上線的平臺,現在還沒有看到影子。他們確實有很多場景需求,但是被... ......

    uj5u.com 2023-04-20 08:19:07 more
  • 《社區人員管理》實戰案例設計&個人案例分享

    設計是一個讓人夢想成真程序,開始編碼、測驗、除錯之前進行需求分析和架構設計,才能保證關鍵方面都做正確 ......

    uj5u.com 2023-04-20 08:18:57 more
  • 軟體架構生態化-多角色交付的探索實踐

    作為一個技術架構師,不僅僅要緊跟行業技術趨勢,還要結合研發團隊現狀及痛點,探索新的交付方案。在日常中,你是否遇到如下問題 “ 業務需求排期長研發是瓶頸;非研發角色感受不到研發技改提效的變化;引入ISV 團隊又擔心質量和安全,培訓周期長“等等,基于此我們探索了一種新的技術體系及交付方案來解決如上問題。 ......

    uj5u.com 2023-04-20 08:18:49 more
  • 05單件模式

    #經典的單件模式 public class Singleton { private static Singleton uniqueInstance; //一個靜態變數持有Singleton類的唯一實體。 // 其他有用的實體變數寫在這里 //構造器宣告為私有,只有Singleton可以實體化這個類! ......

    uj5u.com 2023-04-19 08:42:51 more
  • 【架構與設計】常見微服務分層架構的區別和落地實踐

    軟體工程的方方面面都遵循一個最基本的道理:沒有銀彈,架構分層模型更是如此,每一種都有各自優缺點,所以請根據不同的業務場景,并遵循簡單、可演進這兩個重要的架構原則選擇合適的架構分層模型即可。 ......

    uj5u.com 2023-04-19 08:42:41 more