亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 學院 > 操作系統 > 正文

爛泥:haproxy學習之https配置

2024-06-28 14:32:45
字體:
來源:轉載
供稿:網友

本文由ilanniweb提供友情贊助,首發于爛泥行天下

想要獲得更多的文章,可以關注我的微信ilanniweb。

在前一段時間,我寫了幾篇有關學習haPRoxy的文章。今天我們再來介紹下haproxy的https配置,https協議的好處在此,我們就不就作介紹了。

我們只介紹如何配置https,以及https在實際生產環境中的應用。

PS:本實驗全部在haproxy1.5.4版本進行測試通過。haproxy1.3版本以下haproxy配置參數可能不能使用,需要注意版本號。

以下haproxy配置是線上生產環境直接使用的。

一、業務要求

現在根據業務的實際需要,有以下幾種不同的需求。如下:

1.1 http跳轉https

把所有請求http://http.ilanni.com的地址全部跳轉為https//:http.ilanni.com這個地址。

1.2 http與https并存

服務器同時開放http://http.ilanni.com和https://http.ilanni.com的訪問形式。

1.3 同臺服務器不同域名之間的https與http

同一臺服務器對http.ilanni.com域名訪問的全部跳轉為https://http.ilanni.com,而對haproxy.ilanni.com訪問走http協議,也就是跳轉到http://haproxy.ilanni.com這個地址。

1.4 同臺服務器多域名均使用https

同一臺服務器對http.ilanni.com和haproxy.ilanni.com訪問走http是協議。

二、配置haproxy并測試業務需求

現在我們根據業務的需求,我們來配置haproxy一一達到其需求。

2.1 http跳轉https配置

說實話haproxy的https配置要比nginx配置簡單的多了,我們只需要加入幾行代碼即可實現https的功能。

http跳轉https的haproxy配置文件內容,如下:

global

log 127.0.0.1 local0

log 127.0.0.1 local1 notice

maxconn 4096

uid 188

gid 188

daemon

tune.ssl.default-dh-param 2048

defaults

log global

mode http

option httplog

option dontlognull

option http-server-close

option forwardfor except 127.0.0.1

option redispatch

retries 3

option redispatch

maxconn 2000

timeout http-request 10s

timeout queue 1m

timeout connect 10s

timeout client 1m

timeout server 1m

timeout http-keep-alive 10s

timeout check 10s

maxconn 3000

listen admin_stats

bind 0.0.0.0:1080

mode http

option httplog

maxconn 10

stats refresh 30s

stats uri /stats

stats auth admin:admin

stats hide-version

frontend weblb

bind *:80

acl is_http hdr_beg(host) http.ilanni.com

redirect scheme https if !{ ssl_fc }

bind *:443 ssl crt /etc/haproxy/ilanni.com.pem

use_backend httpserver if is_http

backend httpserver

balance source

server web1 127.0.0.1:7070 maxconn 1024 weight 3 check inter 2000 rise 2 fall 3

clip_image001[4]

在以上配置文件中,需要注意的選項如下:

tune.ssl.default-dh-param 2048因為我們的SSL密鑰使用的是2048bit加密,所以在此進行聲明。

acl is_http hdr_beg(host) http.ilanni.com

redirect scheme https if !{ ssl_fc }

bind *:443 ssl crt /etc/haproxy/ilanni.com.pem

這三行表示把所有訪問http.ilanni.com這個域名的請求,全部轉發到https://http.ilanni.com這個連接。

2.2 測試http跳轉https

http跳轉https配置完畢后,我們選擇來測試其跳轉。如下:

clip_image002[10]

你會發現在瀏覽器中,無論你輸入的是http.ilanni.com,還是http://http.ilanni.com亦或是https://http.ilanni.com,都會自動跳轉到https://http.ilanni.com。

這樣就達到了,把所有的http請求跳轉到https的目的。

2.3 http與https并存配置

haproxy要實現http和https并存的話,配置也很簡單,只需要把haproxy分別監控不同的端口就行,配置文件如下:

global

log 127.0.0.1 local0

log 127.0.0.1 local1 notice

maxconn 4096

user haproxy

group haproxy

daemon

tune.ssl.default-dh-param 2048

defaults

log global

mode http

option httplog

option dontlognull

retries 3

option redispatch

maxconn 2000

timeout connect 5000ms

timeout client 50000ms

timeout server 50000ms

listen admin_stats

bind 0.0.0.0:1080

mode http

option httplog

maxconn 10

stats refresh 30s

stats uri /stats

stats auth admin:admin

stats hide-version

frontend weblb

bind *:80

acl is_http hdr_beg(host) http.ilanni.com

use_backend httpserver if is_http

backend httpserver

balance source

server web1 127.0.0.1:7070 maxconn 1024 weight 3 check inter 2000 rise 2 fall 3

frontend weblb443

bind *:443 ssl crt /etc/haproxy/ilanni.com.pem

acl is_443 hdr_beg(host) http.ilanni.com

use_backend httpserver443 if is_443

backend httpserver443

balance source

server web1 127.0.0.1:7070 maxconn 1024 weight 3 check inter 2000 rise 2 fall 3

在以上配置文件中,我們定義了兩個前端,一個前端用于監聽80端口,也就是http協議。另外一個前端監聽443端口,也就是https協議。

此時haproxy會根據客戶端請求的協議進行分發,如果發現客戶端請求的是http協議,則把該請求分發到監聽80端口的前端。如果發現客戶端請求的是https協議,則把該請求分發到監聽443端口的前端。如此就達到了haproxy讓http和https并存的要求。

2.4 測試http與https并存

http與https并存配置完畢后,我們選擇來測試其跳轉。如下:

clip_image003[4]

clip_image002[11]

通過測試你會發現,在瀏覽器中如果你輸入的是http://http.ilanni.com或者是http.ilanni.com都會直接跳轉到http://http.ilanni.com,而輸入的是https://http.ilanni.com,則只會跳轉到https://http.ilanni.com。

如此就到達了,我們業務的要求實現http和https并存。

2.5 同臺服務器不同域名之間的https與http配置

同臺服務器不同域名之間的http和https配置比較復雜,第一需要監聽兩個端口,第二還要根據不同的域名進行分發。

haproxy配置文件如下:

global

log 127.0.0.1 local0

log 127.0.0.1 local1 notice

maxconn 4096

uid 188

gid 188

daemon

tune.ssl.default-dh-param 2048

defaults

log global

mode http

option httplog

option dontlognull

option http-server-close

option forwardfor except 127.0.0.1

option redispatch

retries 3

option redispatch

maxconn 2000

timeout http-request 10s

timeout queue 1m

timeout connect 10s

timeout client 1m

timeout server 1m

timeout http-keep-alive 10s

timeout check 10s

maxconn 3000

listen admin_stats

bind 0.0.0.0:1080

mode http

option httplog

maxconn 10

stats refresh 30s

stats uri /stats

stats auth admin:admin

stats hide-version

frontend weblb

bind *:80

acl is_haproxy hdr_beg(host) haproxy.ilanni.com

acl is_http hdr_beg(host) http.ilanni.com

redirect prefix https://http.ilanni.com if is_http

use_backend haproxyserver if is_haproxy

backend haproxyserver

balance source

server web1 127.0.0.1:9090 maxconn 1024 weight 3 check inter 2000 rise 2 fall 3

frontend weblb443

bind *:443 ssl crt /etc/haproxy/ilanni.com.pem

acl is_443 hdr_beg(host) http.ilanni.com

use_backend httpserver443 if is_443

backend httpserver443

balance source

server web1 127.0.0.1:7070 maxconn 1024 weight 3 check inter 2000 rise 2 fall 3

clip_image004[4]

同臺服務器不同域名之間的https與http配置,我們配置了兩個前端一個用于監聽80端口,并且根據不同的域名進行跳轉。在80端口的規則中,如果客戶端請求的是http.ilanni.com,這個域名的話,則haproxy會把該請求直接跳轉到https://http.ilanni.com。如果是haproxy.ilanni.com,這個域名的話,則分發到后端的服務器。

另外一個前端用于監聽443端口,用于分發客戶端https://http.ilanni.com的請求。

2.6 測試同臺服務器不同域名之間的https與http配置

同臺服務器不同域名之間的https與http配置配置完畢后,我們現在來進行測試。如下:

clip_image005[4]

clip_image002[12]

通過上圖,我們可以發現在瀏覽器中輸入haproxy.ilanni.com會跳轉到http://haproxy.ilanni.com這個地址,而如果輸入的是http.ilanni.com或者是http://http.ilanni.com,亦或是https://http.ilanni.com的話,都會跳轉到https://http.ilanni.com。

如此就達到了我們的業務要求,同臺服務器上訪問haproxy.ilanni.com直接跳轉到80端口,如果訪問的是http.ilanni.com域名的話則跳轉到https://http.ilanni.com這個地址。

2.7 同臺服務器多域名均使用https配置

要使同臺服務器的兩個設置多個域名都使用https協議的話,配置很簡單。只需要在haproxy中啟用各自的https配置即可。

haproxy配置文件,如下:

global

log 127.0.0.1 local0

log 127.0.0.1 local1 notice

maxconn 4096

uid 108

gid 116

daemon

tune.ssl.default-dh-param 2048

defaults

log global

mode http

option httplog

option dontlognull

option http-server-close

option forwardfor except 127.0.0.1

option redispatch

retries 3

option redispatch

timeout http-request 10s

timeout queue 1m

timeout connect 10s

timeout client 1m

timeout server 1m

timeout http-keep-alive 10s

timeout check 10s

maxconn 3000

listen admin_stats

bind 0.0.0.0:1080

mode http

option httplog

maxconn 10

stats refresh 30s

stats uri /stats

stats auth admin:admin

stats hide-version

frontend web80

bind *:80

acl is_http hdr_beg(host) http.ilanni.com

redirect scheme https if !{ ssl_fc }

bind *:443 ssl crt /etc/haproxy/ilanni.com.pem

acl is_haproxy hdr_beg(host) haproxy.ilanni.com

redirect scheme https if !{ ssl_fc }

bind *:443 ssl crt /etc/haproxy/ilanni.com.pem

use_backend httpserver if is_http

use_backend haproxyserver if is_haproxy

backend httpserver

balance source

server web1 127.0.0.1:6060 maxconn 1024 weight 3 check inter 2000 rise 2 fall 3

backend haproxyserver

balance source

server web1 127.0.0.1:9090 maxconn 1024 weight 3 check inter 2000 rise 2 fall 3

clip_image006[4]

配置文件比較簡單,在此就不做進一步的講解了。

2.8 測試同臺服務器多域名均使用https

同臺服務器多域名均使用https,配置完畢后,現在我們來測試下。

clip_image002[13]

clip_image007[4]

通過上圖,我們可以看到在瀏覽中無論是輸入http.ilanni.com、http://http.ilanni.com,還是haproxy.ilanni.com、http://haproxy.ilanni.com,都會跳轉到相應的https地址。

這也達到了我們業務的要求。

 


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产精品爽爽ⅴa在线观看| 久久久久久久久久久人体| 一本一本久久a久久精品综合小说| 国产精品久久久久av| 欧美成在线视频| 亚洲色图13p| 成人免费视频a| 日韩影视在线观看| 奇米影视亚洲狠狠色| 日韩福利视频在线观看| 久久777国产线看观看精品| 日韩精品在线私人| 动漫精品一区二区| 97香蕉超级碰碰久久免费的优势| 亚洲欧洲第一视频| 欧美亚洲在线观看| 91久久久久久| 久久精品国产清自在天天线| 国产精品入口免费视| 91免费精品视频| 欧美日韩国产中文精品字幕自在自线| 久久九九全国免费精品观看| 久久久久久久久91| 欧美性猛交xxxx免费看| 久久精品国产成人精品| 国产精品久久久久不卡| 亚洲丁香婷深爱综合| 久久久黄色av| 久久久www成人免费精品| 亚洲综合大片69999| 国外成人免费在线播放| 欧美精品videosex极品1| 在线看日韩av| 欧美猛男性生活免费| 国产精品久久电影观看| 色综合久久悠悠| 人人做人人澡人人爽欧美| 神马国产精品影院av| 久久视频中文字幕| 亚洲欧美国内爽妇网| 国产精品电影久久久久电影网| 欧美日韩一区二区在线播放| 91久久久久久国产精品| 91丨九色丨国产在线| 国产精品免费网站| 欧美一区二区三区……| 欧美日韩免费一区| 亚洲女人天堂成人av在线| 91久久精品美女高潮| 亚洲在线观看视频网站| 欧美俄罗斯乱妇| 青草热久免费精品视频| 欧美精品免费在线观看| 欧美国产一区二区三区| 亚洲精品久久久久中文字幕欢迎你| 日韩精品在线影院| 亚洲国产又黄又爽女人高潮的| 国产经典一区二区| 欧美日韩午夜激情| 欧美一区二区视频97| 国产精品成人在线| 国产精品美女主播在线观看纯欲| 日本久久久久亚洲中字幕| 91精品综合视频| 亚洲乱码av中文一区二区| 国产精品视频不卡| 精品成人69xx.xyz| 97久久精品人人澡人人爽缅北| 国产成人在线亚洲欧美| 国产精品一久久香蕉国产线看观看| 日韩av日韩在线观看| 国产综合在线看| 操人视频在线观看欧美| 中文字幕在线观看日韩| 精品国内产的精品视频在线观看| 日韩欧美国产高清91| 97免费在线视频| 高清视频欧美一级| 日韩免费中文字幕| 国产精品美女久久久久久免费| 久久亚洲国产精品| 海角国产乱辈乱精品视频| 欧美日韩成人免费| 91精品国产高清| 精品调教chinesegay| 亚洲第一精品久久忘忧草社区| 亚洲欧美另类中文字幕| 欧美精品一本久久男人的天堂| 国产999精品视频| 久久久噜噜噜久久| 欧美激情精品久久久久久久变态| 日韩中文字幕欧美| 国产精品高潮粉嫩av| 欧美在线激情网| 美日韩丰满少妇在线观看| 川上优av一区二区线观看| 日韩在线视频免费观看| 国产自产女人91一区在线观看| 正在播放欧美视频| 国产精品日韩欧美| 日韩综合中文字幕| 国产精品91久久久| 国产精品美女久久久久av超清| 亚洲高清不卡av| www.久久撸.com| 亚洲视频第一页| 视频一区视频二区国产精品| 97精品视频在线播放| 国产日韩欧美中文| 国产精品揄拍500视频| 2019国产精品自在线拍国产不卡| 国产精品一区专区欧美日韩| 91探花福利精品国产自产在线| 国产精品入口夜色视频大尺度| 成人黄色免费在线观看| 国产精品第七影院| 中文字幕视频在线免费欧美日韩综合在线看| 久久中文字幕视频| 91九色视频导航| 久久久亚洲福利精品午夜| 国产裸体写真av一区二区| 亚洲男人天堂古典| 欧美性生交xxxxx久久久| 成人激情电影一区二区| 日韩电影中文字幕| 国产精品电影久久久久电影网| 成人h视频在线观看播放| 亚洲最大中文字幕| 色天天综合狠狠色| 欧美日本亚洲视频| 日韩av手机在线看| 日韩中文视频免费在线观看| 久久久久久久久久久久av| 亚洲男人av电影| 久久久精品在线| 5566成人精品视频免费| 国产精品69久久久久| 中文字幕久久亚洲| 美女啪啪无遮挡免费久久网站| 欧美精品少妇videofree| 日韩av资源在线播放| 国产精品亚洲美女av网站| 青青久久av北条麻妃海外网| 久久久久久久网站| 国产999在线观看| 丝袜一区二区三区| 欧美影院在线播放| 国产精品视频播放| 欧美激情喷水视频| 国产视频精品xxxx| 欧美成人小视频| 亚洲一区二区三区久久| 日韩人体视频一二区| 亚洲第一福利在线观看| 欧美理论电影网| 精品久久久久久国产| 色老头一区二区三区| 久久人人爽人人爽人人片av高清| 久久久久久噜噜噜久久久精品| 欧美午夜片欧美片在线观看| 97视频在线观看免费高清完整版在线观看| 亚洲欧美第一页| 国语自产精品视频在线看| 久久久久久欧美|