成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

基于HAProxy的高性能緩存服務(wù)器nuster

import. / 2035人閱讀

摘要:是一個(gè)基于的高性能緩存服務(wù)器介紹是一個(gè)基于的高性能緩存服務(wù)器。可以為多個(gè)代理添加,并多帶帶設(shè)置某個(gè)代理的緩存是否開啟。默認(rèn)秒如果不希望失效則設(shè)為默認(rèn)只緩存的響應(yīng),如果需要緩存其他的則可以添加,會(huì)緩存任何狀態(tài)碼。

Nuster是一個(gè)基于HAProxy的高性能緩存服務(wù)器

https://github.com/jiangwenyu...

介紹

Nuster是一個(gè)基于HAProxy的高性能緩存服務(wù)器。Nuster完全兼容HAProxy,并且利用
HAProxy的ACL功能來提供非常細(xì)致的緩存規(guī)則,比如

請(qǐng)求地址為某某時(shí)緩存

請(qǐng)求參數(shù)中的X為Y時(shí)緩存

響應(yīng)頭中的X為Y時(shí)緩存

請(qǐng)求速率超過多少時(shí)緩存

等等

性能

非??? 單進(jìn)程模式下是nginx的3倍,多進(jìn)程下nginx的2倍,varnish的3倍。

詳見benchmark

安裝
make TARGET=linux2628
make install

具體參照HAProxy README

使用方法

global中添加cache on, 然后在backendlisten中添加cache filter和cache rule

指令 cache

syntax: cache on|off [data-size size]

default: none

context: global

控制是否開啟緩存。
可以設(shè)置data-size來控制緩存數(shù)據(jù)的內(nèi)存使用量??梢允褂?b>m, M, gG.
默認(rèn)是1MB,同時(shí)也是最小使用量。只有http內(nèi)容計(jì)算在內(nèi),并不包括使用緩存帶來的內(nèi)存開銷。

filter cache

syntax: filter cache [on|off]

default: on

context: backend, listen

定義一個(gè)cache filter, 另外cache-rule也需要添加。
可以為多個(gè)代理添加,并多帶帶設(shè)置某個(gè)代理的緩存是否開啟。
如果定義了多個(gè)filter,需要把cache filter放在最后。

cache-rule

syntax: cache-rule name [key KEY] [ttl TTL] [code CODE] [if|unless condition]

default: none

context: backend, listen

定義緩存規(guī)則??梢酝瑫r(shí)定義多個(gè),但是需要注意順序,匹配則會(huì)停止測(cè)試。

acl pathA path /a.html
filter cache
cache-rule all ttl 3600
cache-rule path01 ttl 60 if pathA

path01這條規(guī)則永遠(yuǎn)不會(huì)執(zhí)行,因?yàn)閍ll會(huì)匹配所有的規(guī)則。

name

定義一個(gè)名字。

key KEY

定義key,由以下關(guān)鍵字組成:

method: http method, GET/POST...

scheme: http or https

host: the host in the request

path: the URL path of the request

query: the whole query string of the request

header_NAME: the value of header NAME

cookie_NAME: the value of cookie NAME

param_NAME: the value of query NAME

body: the body of the request

默認(rèn)key是method.scheme.host.path.query.body

Example

GET http://www.example.com/q?name=X&type=Y

http header:
GET /q?name=X&type=Y HTTP/1.1
Host: www.example.com
ASDF: Z
Cookie: logged_in=yes; user=nuster;

會(huì)得到:

method: GET

scheme: http

host: www.example.com

path: /q

query: name=X&type=Y

header_ASDF: Z

cookie_user: nuster

param_type: Y

body: (empty)

所以默認(rèn)的key就會(huì)得到GEThttpwww.example.com/qname=X&type=Y, 而
key method.scheme.host.path.header_ASDF.cookie_user.param_type則會(huì)生成
GEThttpwww.example.com/qZnusterY

一個(gè)請(qǐng)求的key能在緩存中找到則返回緩存內(nèi)容。

ttl TTL

定義key的失效時(shí)間,可以使用 d, h, m and s。默認(rèn)3600秒.
如果不希望失效則設(shè)為0

code CODE1,CODE2...

默認(rèn)只緩存200的響應(yīng),如果需要緩存其他的則可以添加,all會(huì)緩存任何狀態(tài)碼。

cache-rule only200
cache-rule 200and404 code 200,404
cache-rule all code all
if|unless condition

定義ACL條件
詳見HAProxy configuration的7. Using ACLs and fetching samples

FAQ 如何調(diào)試?

global添加debug, 或者帶-d啟動(dòng)haproxy

緩存相關(guān)的調(diào)試信息以[CACHE]開頭

如何緩存POST請(qǐng)求?

添加option http-buffer-request

如果自定義了key的話需要使用body關(guān)鍵字

請(qǐng)求body可能不完整,詳見HAProxy configuration 的
option http-buffer-request小節(jié)

另外可以為post請(qǐng)求多帶帶設(shè)置一個(gè)后端

Example
global
    cache on data-size 100m
    #daemon
    ## to debug cache
    #debug
defaults
    retries 3
    option redispatch
    timeout client  30s
    timeout connect 30s
    timeout server  30s
frontend web1
    bind *:8080
    mode http
    acl pathPost path /search
    use_backend app1a if pathPost
    default_backend app1b
backend app1a
    balance roundrobin
    # mode must be http
    mode http

    # http-buffer-request must be enabled to cache post request
    option http-buffer-request

    acl pathPost path /search

    # enable cache for this proxy
    filter cache

    # cache /search for 120 seconds. Only works when POST/PUT
    cache-rule rpost ttl 120 if pathPost

    server s1 10.0.0.10:8080
backend app1b
    balance     roundrobin
    mode http

    filter cache on

    # cache /a.jpg, not expire
    acl pathA path /a.jpg
    cache-rule r1 ttl 0 if pathA

    # cache /mypage, key contains cookie[userId], so it will be cached per user
    acl pathB path /mypage
    cache-rule r2 key method.scheme.host.path.query.cookie_userId ttl 60 if pathB

    # cache /a.html if response"s header[cache] is yes
    http-request set-var(txn.pathC) path
    acl pathC var(txn.pathC) -m str /a.html
    acl resHdrCache1 res.hdr(cache) yes
    cache-rule r3 if pathC resHdrCache1

    # cache /heavy for 100 seconds if be_conn greater than 10
    acl heavypage path /heavy
    acl tooFast be_conn ge 100
    cache-rule heavy ttl 100 if heavypage tooFast 

    # cache all if response"s header[asdf] is fdsa
    acl resHdrCache2 res.hdr(asdf)  fdsa
    cache-rule resCache ttl 0 if resHdrCache1

    server s1 10.0.0.10:8080

frontend web2
    bind *:8081
    mode http
    default_backend app2
backend app2
    balance     roundrobin
    mode http

    # disable cache on this proxy
    filter cache off
    cache-rule all

    server s2 10.0.0.11:8080

listen web3
    bind *:8082
    mode http

    filter cache
    cache-rule everything

    server s3 10.0.0.12:8080

文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/61919.html

相關(guān)文章

  • 基于HAProxy性能HTTP緩存務(wù)器和RESTful NoSQL緩存務(wù)器

    摘要:中文日本語基于的高性能緩存服務(wù)器和緩存服務(wù)器。定義條件詳見的也可以用作類似或者那樣的緩存服務(wù)器,來緩存動(dòng)態(tài)或者靜態(tài)的資源。 NuSTER Wiki | English | 中文 | 日本語 基于HAProxy的高性能HTTP緩存服務(wù)器和RESTful NoSQL緩存服務(wù)器。 中文版更新可能不及時(shí),最新版請(qǐng)參照英文版README.md 目錄 介紹 性能 入門指南 使用方法 指令 C...

    mmy123456 評(píng)論0 收藏0
  • 性能緩存務(wù)器 nuster v1.7.10.1 發(fā)布

    摘要:高性能緩存服務(wù)器已發(fā)布。本次更新主要升級(jí)到更改了配置文件關(guān)鍵字,刪除了關(guān)鍵字為升級(jí)到進(jìn)行了代碼重構(gòu)。項(xiàng)目主頁本次更新介紹是一個(gè)基于的高性能緩存服務(wù)器。完全兼容,并且利用的功能來提供非常細(xì)致的緩存規(guī)則。 高性能緩存服務(wù)器 nuster v1.7.10.1 已發(fā)布。本次更新主要升級(jí)到HAProxy v1.7.10, 更改了配置文件關(guān)鍵字,刪除了share關(guān)鍵字, 為升級(jí)到HAProxy v...

    binta 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

最新活動(dòng)
閱讀需要支付1元查看
<