本次要分享的是利用windows+nginx+iis+redis+Task.MainForm組建分佈式架構,由標題就能看出此內容不是一篇分享文章能說完的,因此我打算分幾篇分享文章來說解,一步一步實現分佈式架構;下面將先給出整個架構的核心節點簡介,但願各位多多點贊:css
. 架構設計圖展現html
. nginx+iis構建服務集羣nginx
. redis存儲分佈式共享的session及共享session運做流程正則表達式
. redis主從配置及Sentinel管理多個Redis集羣redis
. 定時框架Task.MainForm提供數據給redis集羣儲存數據庫
以上是整個架構的我認爲核心的部分,其中沒有包含有數據庫方面的設計(請忽略),下面先發張架構設計圖:windows
以上是我的的見解,下面來正式分享今天的文章吧(nginx+iis構建服務集羣):後端
. nginx經常使用基礎配置總結瀏覽器
. 用nginx搭建靜態文件緩存服務緩存
. nginx+iis構建服務集羣
下面一步一個腳印的來分享:
. nginx經常使用基礎配置總結
首先,咱們須要從網上下載nginx服務文件,具體windows系統下用何版本請網上搜索,我這裏用的版本是nginx-1.10.1;下載下來後目錄結構是這樣的:
咱們須要瞭解而且操做的配置文件是conf文件夾下面的nginx.conf文件,該目錄下的其餘文件通常採用默認的就行;打開文件不看#號註釋的行;events節點:
events節點:
worker_connections:默認值1024,表明nginx服務地址的最大鏈接數1024;
http節點:
include:mime.types其實對應的是nginx.conf同級目錄下的mime.types文件,裏面是能訪問的mime類型
default_type:application/octet-stream默認類型
keepalive_timeout:鏈接超時時間,單位秒
server節點:
listen:nginx監聽的端口號
server_name:服務名稱
location:路由設置(支持正則表達式);其中經常使用到的節點有
proxy_connect_timeout:nginx跟後端服務器鏈接超時時間(代理鏈接超時)
proxy_pass:代理地址名稱
proxy_set_header:設置讓服務端獲取真實的Ip,端口等;對應的值有(Host,X-Real-IP,X-Forwarded-For)
upstream節點:
設定負載均衡的服務器列表
設置代理地址名稱(和上面的proxy_pass對應)
設置負載均衡分配規則,經常使用規則有:
輪詢:挨個輪詢訪問(默認)
ip_hash:訪問一次後固定訪問一個後端服務器,能夠解決session的問題
fair:後端服務器的響應時間來分配請求,響應時間短的優先分配
weight:權重,值越大訪問量越多
proxy_temp_path節點:代理臨時文件夾路徑
proxy_cache_path節點:代理緩存文件夾路徑(緩存文件都在這裏)
以上介紹的信息基本能完成一個負載均衡經常使用搭建了,其餘的更詳細的節點請參考官網
. 用nginx搭建靜態文件緩存服務
一般分佈式架構的一些css,js,圖片文件都是被緩存起來的,這樣提供高效的加載速度;由文章開頭時發佈的一張架構圖能夠看到,用戶A要真實訪問到服務集羣須要通過nginx這道服務器轉發,這樣須要跳轉一次才能獲取到css靜態文件明顯比直接在nginx服務器就返回這些文件的速度慢;因此這種狀況下就有了把靜態資源緩存到nginx服務上的需求了;下面先來看下nginx配置文件須要的配置信息:
#負載均衡的服務器列表 upstream shenniu.test.com{ server 127.0.0.1:4041; } ##cache## proxy_connect_timeout 5; proxy_read_timeout 60; proxy_send_timeout 5; proxy_buffer_size 16k; proxy_buffers 4 64k; proxy_busy_buffers_size 128k; proxy_temp_file_write_size 128k; proxy_temp_path D:/E/nginx-1.10.1/home/temp_dir; proxy_cache_path D:/E/nginx-1.10.1/home/cache levels=1:2 keys_zone=cache_one:200m inactive=1d max_size=30g; ##end##
注意這裏upstream節點後面的shenniu.test.com域名在後面會使用,節點裏面的server對應ip:端口如:server 127.0.0.1:4041(這個是真實的站點項目的ip+端口),而後須要設置保存緩存文件的路徑:proxy_cache_path和proxy_temp_path
而後server節點裏面listen監聽3031端口,server_name:shenniu.test.com,增長靜態資源路由配置
location ~ .*\.(gif|jpg|png|css|js|flv|ico|swf)(.*) { #proxy_pass http://shenniu.file.com; proxy_pass http://shenniu.test.com; proxy_redirect off; proxy_set_header Host $host; proxy_cache cache_one; proxy_cache_valid 200 302 1h; proxy_cache_valid 301 1d; proxy_cache_valid any 1m; expires 30d; #緩存時長,這裏是30天 }
注意裏面反向代理的proxy_pass 對應的值http://+上面upstream節點的shenniu.test.com,因此就是proxy_pass http://shenniu.test.com這個地址就是訪問代理的地址;直接shenniu.test.com域名,咱們須要在本機的這個目錄結構C:\Windows\System32\drivers\etc中找到host文件,而後裏面增長如:127.0.0.1 shenniu.test.com同樣代碼,這樣咱們的域名就能夠在本機的瀏覽器中訪問了;增長頁面的路由配置:
location ~ .*(\/|\.(html|htm))(.*) { proxy_connect_timeout 90; #nginx跟後端服務器鏈接超時時間(代理鏈接超時) proxy_pass http://shenniu.test.com; proxy_redirect default; #服務端獲取真實的Ip,端口等 proxy_set_header Host $host; proxy_set_header X-Real-IP $remote_addr; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; }
而後,咱們還須要用iis發佈一個項目,名稱爲ShenNiu.Stage01,對應的ip和端口是上面upstream節點裏面的數據:
而後,在瀏覽器訪問分別用ip和域名訪問效果:
好這個是本地host配置域名訪問,可是這尚未用到nginx,由於咋們配置的nginx反向代理的端口是server節點裏面listen監聽3031端口,因此應該訪問的是http://shenniu.test.com:3031/user/login地址,此時在瀏覽器是訪問不了該端口的,還須要咋們來啓動nginx服務:
好,如今使用nginx配置反向代理並第一次訪問代理對應的站點程序,因爲咋們配置的緩存文件地址在D:/E/nginx-1.10.1/home/cache目錄,因此查看文件夾:
這裏面的就是緩存文件所在的位置,此處問生成的緩存文件夾;再來咋們第二次在瀏覽器中訪問網站,並F12查看對應的js,css等文件:
此時文件的來源Server對應的是nginx服務,沒錯如今訪問的就是nginx緩存的文件了
. nginx+iis構建服務集羣
上面的搭建靜態緩存服務其實大體都涉及到了nginx用來作分發的功能,下面咱們來快速在剛纔的基礎增長一些節點信息,搭建站點服務集羣;首先,咱們修改upstream節點,內容信息增長如:
#負載均衡的服務器列表 upstream shenniu.test.com{ server 127.0.0.1:4041; server 127.0.0.1:4040; }
只須要增長這段代碼,由於上面靜態文件服務的時候已經增長了頁面的路由設置(能夠往上看);爲了演示分佈式架構,咱們還須要在iis中在配置個和ShenNiu.Stage01(對應的ip+端口:127.0.0.1:4041)站點同樣程序的站點ShenNiu.Stage02(對應的ip+端口:127.0.0.1:4040),可是把登錄頁的title分別標註爲"系統01","系統02"這樣來區分訪問到的是那個站點,配置好後下面咱們來再從新加載nginx配置:
而後,訪問反向代理地址http://shenniu.test.com:3031/user/login訪問下頁面看到的效果如:
此時訪問一樣的域名,得出的第一個頁面title是"系統01",第二個是"系統02",能夠看出訪問的站點分別對應的是127.0.0.1:4041和127.0.0.1:4040,也就是咋們配置的iis中的ShenNiu.Stage01和ShenNiu.Stage02,這樣nginx作分發站點就成功了,站點服務集羣就這樣建立成功了。
本篇分享的內容只是nginx+iis作一個簡單的集羣,後面一篇的分享文章將講解redis存儲分佈式共享的session及共享session運做流程,敬請期待也謝謝多多支持點贊。