主頁 > 軟體設計 > Nginx 反向代理、負載均衡、虛擬主機

Nginx 反向代理、負載均衡、虛擬主機

2021-08-14 07:25:20 軟體設計

文章目錄

    • 一、反向代理
      • 1、代理原理
      • 2、正/反向代理的區別
        • (1)正向代理
        • (2)反向代理
      • 3、配置Nginx-Proxy
        • (1)代理模塊
        • (2)代理配置
        • (3) proxy 代理實體
    • 二、負載均衡
      • 1、負載均衡的作用
      • 2、upstream配置
      • 3、負載均衡演算法
      • 4、配置實體
      • 5、負載均衡配置狀態引數
    • 三、動靜分離
      • 1、動靜分離的作用
      • 2、動靜分離實體
        • (1)準備環境
        • (2)代理服務器
        • (3)配置靜態網頁
        • (4)配置動態網頁
        • (5)訪問頁面
    • 四、虛擬主機
      • 1、什么是虛擬主機
      • 2、配置型別
      • 3、基于域名的虛擬主機
      • 4、 基于ip的虛擬主機
      • 5、 基于埠的虛擬主機

一、反向代理

1、代理原理

  • 反向代理產生的背景:

在計算機世界里,由于單個服務器的處理客戶端(用戶)請求能力有一個極限,當用戶的接入請求蜂擁而入時,會造成服務器忙不過來的局面,可以使用多個服務器來共同分擔成千上萬的用戶請求,這些服務器提供相同的服務,對于用戶來說,根本感覺不到任何差別,

  • 反向代理服務的實作:

需要有一個負載均衡設備(即反向代理服務器)來分發用戶請求,將用戶請求分發到空閑的服務器上,服務器回傳自己的服務到負載均衡設備,負載均衡設備將服務器的服務回傳用戶,

2、正/反向代理的區別

什么是反向代理?為什么叫反向代理?什么是正向代理?我們來舉例說明

(1)正向代理

正向代理的程序隱藏了真實的請求客戶端,服務器不知道真實的客戶端是誰,客戶端請求的服務都被代理服務器代替請求,我們常說的代理也就是正向代理,

正向代理中代理的物件是客戶端,proxy和client同屬一個LAN,對server透明;
在這里插入圖片描述

(2)反向代理

反向代理的程序隱藏了真實的服務器,客戶不知道真正提供服務的人是誰,客戶端請求的服務都被代理服務器處理,

反向代理中代理的物件是服務端,proxy和server同屬一個LAN,對client透明,

在這里插入圖片描述

3、配置Nginx-Proxy

(1)代理模塊

ngx_http_proxy_module

(2)代理配置

nginx proxy 具體配置詳解

專案Value
proxy_pass真實服務器的地址,可以是ip也可以是域名和url地址
proxy_set_header重新定義或者添加發往后端服務器的請求頭
proxy_set_header X-Real-IP啟用客戶端真實地址(否則日志中顯示的是代理在訪問網站)
proxy_set_header X-Forwarded-For記錄代理地址
proxy_connect_timeout后端服務器連接的超時時間發起三次握手等候回應超時時間
proxy_send_timeout后端服務器資料回傳時間,就是在規定時間之內后端服務器必須傳完所有的資料
proxy_read_timeoutnginx接收upstream(上游/真實) server資料超時, 默認60s, 如果連續的60s內沒有收到1個位元組, 連接關閉,像長連接
代理
Syntax: 	proxy_pass URL;				   #代理的后端服務器URL
Default: 	—
Context: 	location, if in location, limit_except

                  
頭資訊
Syntax: 	proxy_set_header field value;
Default: 	proxy_set_header Host $proxy_host;		#設定真實客戶端地址
            proxy_set_header Connection close;
Context: 	http, server, location

超時
Syntax: 	proxy_connect_timeout time;
Default: 	proxy_connect_timeout 60s;				#鏈接超時
Context: 	http, server, location

Syntax: 	proxy_read_timeout time;
Default: 	proxy_read_timeout 60s;
Context: 	http, server, location

Syntax: 	proxy_send_timeout time; #nginx行程向fastcgi行程發送request的整個程序的超時時間
Default: 	proxy_send_timeout 60s;
Context: 	http, server, location

(3) proxy 代理實體

前提:環境兩臺nginx真實服務器

1、nginx-1 啟動網站(內容)(作為網站服務器)·

nginx-1的ip:192.168.62.157
已經編譯安裝好,檢查nginx是否啟動是否可以訪問
[root@nginx-server ~]# cat /home/www/html/index.html 
1000phone

[root@nginx-server ~]# cat /etc/nginx/conf.d/aa.conf
server {
        listen 80;
        server_name localhost;
        location / {
               root /home/www/html;
               index index.html index.hml;
        }
}

2、nginx-2 啟動代理程式

nginx-2的ip:192.168.62.159
配置nginx的yum源直接yum安裝
啟動
編輯nginx的組態檔(編輯之前,洗掉/注釋掉之前的配置):
[root@nginx-server ~]# vim /etc/nginx/conf.d/default.conf
server {
   listen       80;
   server_name  localhost;

   location / {
   proxy_pass http://192.168.62.157:80;
   proxy_set_header Host $http_host;#填寫nginx-1服務器的地址,
   proxy_set_header X-Real-IP $remote_addr;
   proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;

   proxy_connect_timeout 30;
   proxy_send_timeout 60;
   proxy_read_timeout 60;
    }
}
重新加載nginx組態檔
[root@nginx-server ~]# nginx -s reload

3、 使用PC客戶端訪問nginx-2服務器地址

瀏覽器中輸入http://192.168.62.159/ (也可以是nginx-2服務器的域名),成功訪問nginx-1服務器頁面

4、 觀察nginx-1(192.168.62.157)服務器的日志

在這里插入圖片描述

  • 192.168.62.159 代理服務器地址

  • 192.168.62.1 客戶機地址

  • 訪問成功, 記錄了客戶機的IP和代理服務器的IP

二、負載均衡

1、負載均衡的作用

當一臺服務器的單位時間內的訪問量越大時,服務器壓力就越大,大到超過自身承受能力時,服務器就會崩潰,為了避免服務器崩潰,讓用戶有更好的體驗,我們通過負載均衡的方式來分擔服務器壓力,

我們可以建立很多很多服務器,組成一個服務器集群,當用戶訪問網站時,先訪問一個中間服務器,在讓這個中間服務器在服務器集群中選擇一個壓力較小的服務器,然后將該訪問請求引入該服務器,如此以來,用戶的每次訪問,都會保證服務器集群中的每個服務器壓力趨于平衡,分擔了服務器壓力,避免了服務器崩潰的情況,

負載均衡是用反向代理的原理實作的,

[外鏈圖片轉存失敗,源站可能有防盜鏈機制,建議將圖片保存下來直接上傳(img-kYQzZ6N4-1628758910409)(assets/1561622346506.png)]

2、upstream配置

首先給大家說下 upstream 這個配置的,這個配置是寫一組被代理的服務器地址,然后配置負載均衡的演算法,這里的被代理服務器地址有2種寫法,

upstream youngfitapp { 
      server 192.168.62.157:8080;
      server 192.168.62.158:8080;
}
server {
        listen 80;
        server_name localhost;
        location / {         
           proxy_pass  http://youngfitapp;
        }
}

3、負載均衡演算法

upstream 支持4種負載均衡調度演算法:

  • 輪詢(默認):每個請求按時間順序逐一分配到不同的后端服務器;

  • weight(權重):這種方式比較靈活,當后端服務器性能存在差異的時候,通過配置權重,可以讓服務器的性能得到充分發揮,有效利用資源,weight和訪問比率成正比,用于后端服務器性能不均的情況,權重越高,在被訪問的概率越大,

  • ip_hash:每個請求按訪問ip的hash結果分配,同一個IP客戶端固定訪問一個后端服務器,可以保證來自同一ip的請求被打到固定的機器上,可以解決session問題;

  • url_hash:此種方式和ip_hash比較類似,根據url的hash 值進行分配,將url分配到同一個后端服務器,當服務器存在快取時比較有效

  • fair(第三方插件):這種方式根據后端服務器的回應時間進行分配,回應快的優先分配請求,必須先下載Nginx的 upstream_fair模塊;

4、配置實體

1、熱備:如果你有2臺服務器,當一臺服務器發生事故時,才啟用第二臺服務器給提供服務,服務器處理請求的順序:AAAAAA突然A掛啦,BBBBBBBBBBBBBB…

upstream myweb { 
      server 192.168.62.157:8080; 
      server 192.168.62.158:8080 backup;  #熱備     
}

2、輪詢:Nginx默認就是輪詢其權重都默認為1,服務器處理請求的順序:ABABABABAB…

upstream myweb {
      server 192.168.62.157:8080; 
      server 192.168.62.158:8080;      
}

3、加權輪詢:根據配置的權重的大小而分發給不同服務器不同數量的請求,如果不設定,則默認為1,下面服務器的請求順序為:ABBABBABBABBABB…

upstream myweb { 
      server 192.168.62.157:8080 weight=1;
      server 192.168.62.158:8080 weight=2;
}

4、ip_hash:Nginx會讓相同的客戶端ip請求相同的服務器,

upstream myweb {
	  ip_hash;
      server 192.168.62.157:8080; 
      server 192.168.62.158:8080;   
}

4、fair(第三方):按后端服務器的回應時間來分配請求,回應時間短的優先分配,

upstream backserver {
    server server1;
    server server2;
    fair;
}

5、url_hash(第三方):按訪問url的hash結果來分配請求,使每個url定向到同一個后端服務器,后端服務器為快取時比較有效,

upstream backserver {
    server squid1:3128;
    server squid2:3128;
    hash $request_uri;
    hash_method crc32;
}

5、負載均衡配置狀態引數

  • down,表示當前的server暫時不參與負載均衡,
  • backup,預留的備份機器,當其他所有的非backup機器出現故障或者忙的時候,才會請求backup機器,因此這臺機器的壓力最輕,
  • max_fails,允許請求失敗的次數,默認為1,當超過最大次數時,回傳錯誤,
  • fail_timeout,在經歷了max_fails次失敗后,暫停服務的時間單位秒,max_fails可以和fail_timeout一起使用,
 upstream myweb { 
      server 192.168.62.157:8080 weight=2 max_fails=2 fail_timeout=2;
      server 192.168.62.158:8080 weight=1 max_fails=2 fail_timeout=1;   
 }

三、動靜分離

1、動靜分離的作用

為了加快網站的決議速度,可以把動態頁面和靜態頁面由不同的服務器來決議,加快決議速度,降低原來單個服務器的壓力,

在動靜分離的tomcat的時候比較明顯,因為tomcat決議靜態很慢,其實這些原理的話都很好理解,簡單來說,就是使用正則運算式匹配過濾,然后交給不同的服務器,
在這里插入圖片描述

2、動靜分離實體

(1)準備環境

準備一個nginx代理 兩個http 分別處理動態和靜態,

192.168.62.159   代理服務器
192.168.62.157   動態資源
192.168.62.155   靜態資源

(2)代理服務器

192.168.62.159   代理服務器

1.配置nginx反向代理upstream;
[root@nginx-server conf.d]# cat upstream.conf 
upstream static {
        server 192.168.62.155:80 weight=1 max_fails=1 fail_timeout=60s;
}
upstream phpserver {
        server 192.168.62.157:80 weight=1 max_fails=1 fail_timeout=60s;
}
     server {
        listen      80;
        server_name     localhost;
        #動態資源加載
        location ~ \.(php|jsp)$ {
            proxy_pass http://phpserver;
            proxy_set_header Host $host:$server_port;
            proxy_set_header X-Real-IP $remote_addr;
            proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
                }
        #靜態資源加載
        location ~ .*\.(html|gif|jpg|png|bmp|swf|css|js)$ {
            proxy_pass http://static;
            proxy_set_header Host $host:$server_port;
            proxy_set_header X-Real-IP $remote_addr;
            proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
                }
        }

(3)配置靜態網頁

192.168.62.155   靜態資源

#靜態資源配置   主組態檔-include /etc/nginx/conf.d/*.conf
# vim /etc/nginx/conf.d/static.conf
server {
        listen 80;
        server_name     localhost;

        location ~ \.(html|jpg|png|js|css|gif|bmp|jpeg) {
        root /home/www/nginx;
        index index.html index.htm;
        }
}

[root@nginx-server2 nginx]# cat /home/www/nginx/index.html    //模擬靜態資源
hello 155

(4)配置動態網頁

192.168.62.157  動態資源

#動態資源配置:
yum 安裝php7.1
[root@nginx-server ~]# rpm -Uvh https://mirror.webtatic.com/yum/el7/epel-release.rpm
[root@nginx-server ~]# rpm -Uvh https://mirror.webtatic.com/yum/el7/webtatic-release.rpm
[root@nginx-server ~]# yum install php71w-xsl php71w php71w-ldap php71w-cli php71w-common php71w-devel php71w-gd php71w-pdo php71w-mysql php71w-mbstring php71w-bcmath php71w-mcrypt -y
[root@nginx-server ~]# yum install -y php71w-fpm
[root@nginx-server ~]# systemctl start php-fpm
[root@nginx-server ~]# systemctl enable php-fpm
編輯nginx的組態檔:
server {
        listen      80;
        server_name     localhost;
        location ~ \.php$ {
            root           /home/nginx/html;  #指定網站目錄
            fastcgi_pass   127.0.0.1:9000;    #指定訪問地址
            fastcgi_index  index.php;		#指定默認檔案
            fastcgi_param  SCRIPT_FILENAME  $document_root$fastcgi_script_name; #站點根目錄,取決于root配置項
            include        fastcgi_params;  #包含nginx常量定義
        		}
}
  
[root@nginx-server1 html]# cat /home/nginx/html/index.php   //模擬動態資源
dongtai

(5)訪問頁面

當訪問動態頁面時location匹配到 .\php 結尾的檔案轉發到后端php服務處理請求,

在這里插入圖片描述
當訪問靜態頁面的時候location 匹配到 (html|jpg|png|js|css|gif|bmp|jpeg) 通過轉發到靜態服務器,靜態服務通過location的正則匹配來處理請求,
在這里插入圖片描述

四、虛擬主機

1、什么是虛擬主機

虛擬主機是一種特殊的軟硬體技術,它可以將網路上的每一臺計算機分成多個虛擬主機,每個虛擬主機可以獨立對外提供web服務,這樣就可以實作一臺主機對外提供多個web服務,每個虛擬主機之間是獨立的,互不影響,

在這里插入圖片描述

2、配置型別

nginx可以實作虛擬主機的配置,nginx支持三種型別的虛擬主機配置,

  • 基于域名的虛擬主機 (server_name來區分虛擬主機——應用:web網站)

  • 基于ip的虛擬主機(一個主機系結多個ip地址)

  • 基于埠的虛擬主機 (埠來區分虛擬主機——應用:公司內部網站,外部網站的管理后臺)

3、基于域名的虛擬主機

1.配置通過域名區分的虛擬機
[root@localhost ~]# cat /etc/nginx/conf.d/aa.conf
server {
        listen       80;
        server_name  www.alan-1.com;
        charset utf-8;

        location / {
            root   /var/www/nginx;
            index  index.html index.htm;
        }

        error_page   500 502 503 504  /50x.html;
        location = /50x.html {
            root   html;
        }
}


server {
        listen       80;
        server_name  www.alan-2.com;
        charset utf-8;

        location / {
            root   /1000phone/html;
            index  index.html index.htm;
        }

        error_page   500 502 503 504  /50x.html;
        location = /50x.html {
            root   html;
        }
}


2.為域名為虛擬機,創建 index 檔案
[root@localhost ~]# mkdir -p /var/www/nginx
[root@localhost ~]# mkdir -p /1000phone/html
[root@localhost ~]# vim /1000phone/html/index.html
this is my 1000phone
[root@localhost ~]# vim /var/www/nginx/index.html
hello alan.


3.重新加載組態檔
[root@nginx]# nginx -s reload


4.客戶端配置決議
在 C:\Windows\System32\drivers\etc\hosts 檔案中添加兩行(linux:/etc/hosts)
10.0.105.199 web.testpm.com
10.0.105.199 web.1000phone.com

5. 測驗訪問
瀏覽器輸入:http://web.testpm.com/
瀏覽器輸入:http://web.1000phone.com/

4、 基于ip的虛擬主機

1.添加 ip
[root@localhost ~]# ip a 
1: lo: <LOOPBACK,UP,LOWER_UP> mtu 65536 qdisc noqueue state UNKNOWN qlen 1
    link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00
    inet 127.0.0.1/8 scope host lo
       valid_lft forever preferred_lft forever
    inet6 ::1/128 scope host 
       valid_lft forever preferred_lft forever
2: ens33: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc pfifo_fast state UP qlen 1000
    link/ether 00:0c:29:17:f1:af brd ff:ff:ff:ff:ff:ff
    inet 10.0.0.20/24 brd 10.0.105.255 scope global dynamic ens33
       valid_lft 81438sec preferred_lft 81438sec
    inet6 fe80::9d26:f3f0:db9c:c9be/64 scope link 
       valid_lft forever preferred_lft forever
             
[root@localhost ~]# ifconfig ens33:1 10.0.0.220/24


2、配置通過 ip 區分的虛擬機
[root@localhost ~]# cat /etc/nginx/nginx.conf
server {
        listen       80;
        server_name  10.0.0.20;
        charset utf-8;

        location / {
            root   /var/www/nginx;
            index  index.html index.htm;
        }

        error_page   500 502 503 504  /50x.html;
        location = /50x.html {
            root   html;
        }
}

server {
        listen       80;
        server_name  10.0.0.220;
        charset utf-8;

        location / {
            root   /1000phone/html;
            index  index.html index.htm;
        }

        error_page   500 502 503 504  /50x.html;
        location = /50x.html {
            root   html;
        }
}

3.重新加載組態檔
[root@localhost ~]#/usr/local/nginx/sbin/nginx -s reload


4、 測驗訪問
瀏覽器輸入:http://10.0.0.20
瀏覽器輸入:http://10.0.0.220

5、 基于埠的虛擬主機

1.配置
[root@localhost ~]# cat /etc/nginx/nginx.conf
server {
        listen       80;
        server_name  www.alan-1.com;
        charset utf-8;

        location / {
            root   /var/www/nginx;
            index  index.html index.htm;
        }

        error_page   500 502 503 504  /50x.html;
        location = /50x.html {
            root   html;
        }
}


server {
        listen       8080;
        server_name  www.alan-2.com;
        charset utf-8;

        location / {
            root   /1000phone/html;
            index  index.html index.htm;
        }

        error_page   500 502 503 504  /50x.html;
        location = /50x.html {
            root   html;
        }
    }

}

2.重新加載組態檔:
[root@localhost ~]# /usr/local/nginx/sbin/nginx -s reload

3.測驗訪問:
瀏覽器輸入:http://www.alan-1.com
瀏覽器輸入:http://www.alan-2.com:8080

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

標籤:其他

上一篇:Nginx常用模塊的使用(五):對IP地址和瀏覽器的限制

下一篇:nginx服務器配置prometheus監控,服務自啟動以及日志分割

標籤雲
其他(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