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

資訊專欄INFORMATION COLUMN

初識Splash

Karrdy / 1621人閱讀

摘要:負(fù)載均衡設(shè)置負(fù)載均衡的目的就是為了多個(gè)服務(wù)器分擔(dān)壓力。修改的配置文件,添加如下內(nèi)容服務(wù)器集群名為代表最少鏈接負(fù)載均衡,去掉此行將使用默認(rèn)的輪詢策略實(shí)現(xiàn)負(fù)載均衡若使用,此方法確保同一服務(wù)器響應(yīng)請求,此方法適合有狀態(tài)的服務(wù)。

輸入下面命令運(yùn)行splash:

docker run -p 8050:8050 scrapinghub/splash

一個(gè)splash的基本實(shí)例:

function main(splash, args)
    splash:go("http://www.baidu.com")
    splash:wait(0.5)
    lcoal title = splash:evaljs("document.title")
    return {title=title}
end

將上面實(shí)例復(fù)制到 localhost:8050 的代碼編輯區(qū)域,并將網(wǎng)址設(shè)為 http://www.baidu.com

點(diǎn)擊Render me!返回 http://www.baidu.com 的title

我們在這里定義的方法名稱為main(),這個(gè)名稱是固定的,Splash會根據(jù)這個(gè)名字執(zhí)行。

入口及返回值

該方法的返回值既可以是字典形式,也可以是字符串形式,最后都會轉(zhuǎn)化為Splash HTTP Response。

異步處理

Splash支持異步處理,但是這里沒有顯式指明回調(diào)方法,其回調(diào)實(shí)在Splash內(nèi)部完成的。

示例如下:

function main(splash, args)
    local example_urls = {"www.baidu.com", "www.taobao.com", "www.zhihu.com"}
    local urls = args.urls or example_urls
    local results  = {}
    for index, url in ipairs(urls) do
        local ok, reason = splash:go("http://" .. url)
        if ok then
            splash:wait(2)
            results[url] = splash:png()
        end
    end
    return results
end

上面實(shí)例運(yùn)行結(jié)果為,三個(gè)網(wǎng)站的的截圖。
在腳本內(nèi)調(diào)用的wait()方法類似與sleep()。其參數(shù)為等待的秒數(shù)。

“..”為拼接字符串。

Splash對象屬性

args

該屬性可以獲取加載時(shí)配置的參數(shù),比如URL,

如果為GET請求,它還可以獲取GET請求參數(shù);

如果為POST請求,它可以獲取表單提交的數(shù)據(jù)。

Splash也支持使用第二個(gè)參數(shù)直接作為args,例如:

function main(spalsh, args)
    local url = args.url
end

這里第二個(gè)參數(shù)args就相當(dāng)于splash.args屬性,以上代碼等價(jià)于:

function main(spalsh)
    local url = splash.args.url
end

js_enable

這個(gè)屬性是Splash的JavaScript執(zhí)行開關(guān),可以將其配置為true或false來控制是否執(zhí)行JavaScript代碼,默認(rèn)為true.

一般不用設(shè)置此屬性,默認(rèn)開啟。

resource_timeout

顧名思義,此屬性設(shè)置加載的超時(shí)時(shí)間,單位為秒。如果設(shè)置為0或者nil(類似python中的None),代表不檢測超時(shí)。

此屬性用于加載速度較慢的情況,避免給一直等待,超過時(shí)間無響應(yīng),直接拋出異常忽略即可。

image_enable

顧名思義,設(shè)置圖片是否加載,默認(rèn)情況加載。禁用之后可以節(jié)省網(wǎng)絡(luò)流量并提高加載速度。

注意,禁用圖片加載可能會影響JavaScript渲染。因?yàn)榻脠D片加載后,它的外層DOM節(jié)點(diǎn)的高度會發(fā)生變化,進(jìn)而影響

DOM節(jié)點(diǎn)的位置。若JavaScript對圖片節(jié)點(diǎn)有操作的話,其執(zhí)行就會有影響。

初次之外Splash使用了緩存,一開始緩存了圖片,然后禁用了圖片加載。再進(jìn)行加載圖片還會出現(xiàn),此時(shí)重啟Splash即可

。

plugins_enable

此屬性控制瀏覽器插件(如Flash插件)是否開啟。默認(rèn)false,不開啟。

scroll_position

通過設(shè)置此屬性來控制頁面上下或左右滾動。
示例如下:

function main(splash, args)
    assert(splash:go("https://www.taobao.com"))
    splash.scroll_position = {y=400}
    return {png = splash:png()}
end

這樣我們可以控制頁面向下滾動400像素。

Splash對象方法

go()

該方法用來請求某個(gè)鏈接,也可以模擬GET和POST請求,同時(shí)支持傳入請求頭、表單等數(shù)據(jù),其用法如下:

ok, reason = splash:go{url, baseurl=nil, http_method="GET", body=nil, formdata=nil}

其參數(shù)說明如下:

url:請求的URL。

baseurl:可選參數(shù),默認(rèn)為空,表示資源加載相對路徑。

headers:可選參數(shù),默認(rèn)為空,表示請求頭。

http_method:可選參數(shù),默認(rèn)為GET,同時(shí)支持POST。

body:可選參數(shù),默認(rèn)為空,發(fā)POST請求時(shí)的表單數(shù)據(jù),使用的Content-type為application/json。

formdata:可選參數(shù),默認(rèn)為空,POST請求時(shí)的表單數(shù)據(jù),使用的Content-type為application/x-www-form-urlencoded

該方法的返回結(jié)果是結(jié)果ok和原因reason的組合,如果ok為空,代表網(wǎng)頁加載出現(xiàn)了錯(cuò)誤,此時(shí)reason變量包含了錯(cuò)誤的原因,否則證明頁面加載成功。

示例如下:

function main(splash, args)
    local ok, reason = splash:go{"http://httpbin.org/post", http_method="POST", body="name=Germy"}
    if ok then
        return splash:html()
    end
end

wait()

此方法可以控制頁面等待時(shí)間使用方法如下:
ok, reason = splash:wait(time, cancel_on_redirect=false, cancel_on_error=true)

參數(shù)說明如下:

time:等待的秒數(shù)。

cancel_on_redirect:可選參數(shù)默認(rèn)為false,表示如果發(fā)生重定向就停止等待,并返回重定向的結(jié)果。

cancel_on_error:可選參數(shù),默認(rèn)為false,表示如果發(fā)生了加載錯(cuò)誤,就停止等待。

返回結(jié)果也是ok和reason的組合。

jsfunc()

此方法可以直接調(diào)用JavaScript定義的方法,但是所調(diào)用的方法需要用雙中括號包圍,這相當(dāng)于實(shí)現(xiàn)了JavaScript方法到Lua腳本的轉(zhuǎn)換。

evaljs()

此方法可以執(zhí)行JavaScript代碼并返回最后一條JavaScript語句的返回結(jié)果,使用方法如下:

result = splash:evaljs(js)

runjs()

此方法可以執(zhí)行JavaScript代碼,它與evaljs()的功能類似,但是更偏向于執(zhí)行某些動作或聲明某些方法。

autoload()

此方法可以設(shè)置每個(gè)頁面訪問時(shí)自動加載的對象,使用發(fā)放如下:

ok, reason = splash:autoload{source_or_url, source=nil, url=nil}

參數(shù)說明如下:

source_or_url:JavaScript代碼或者JavaScript庫鏈接。

source:JavaScript代碼

url:JavaScript庫鏈接

此方法只負(fù)責(zé)加載JavaScript代碼或庫,不執(zhí)行任何操作。執(zhí)行操作的話,需要調(diào)用evaljs()或runjs()方法。

call_later()

此方法可以通過設(shè)置定時(shí)任務(wù)和延遲時(shí)間來實(shí)現(xiàn)任務(wù)延時(shí)執(zhí)行,并且可以在執(zhí)行前通過cancel()方法重新執(zhí)行定時(shí)任務(wù)。

示例如下:

function main(splash, args)
    local snapshots = {}
    local timer = splash:call_later(function()
        snapshots["a"] = splash:png()
        splash:wait(1.0)
        snapshots["b"] = splash:png()
    end, 0.2)
    splash:go("https://www.taobao.com")
    splash:wait(3.0)
    return snapshots
end

http_get()

此方法可以模擬發(fā)送HTTP的GET請求,使用方法如下:

response = splash:http_get{url, headers=nil, follow_redirects=true}

參數(shù)說明如下:

url:請求URL

headers:可選參數(shù),默認(rèn)為空,請求頭。

follow_redirects:可選參數(shù),表示是啟動自動重定向,默認(rèn)為true。

http_post()

此方法用來模擬發(fā)送POST請求,使用方法如下:

 response = splash:http_post{url, headers=nil, follow_redirects=true, body=nil}

參數(shù)說明如下:

url:請求URL。

headers:可選參數(shù),默認(rèn)為空,請求頭。

follow_redrects:可選參數(shù),表示是否啟動自動重定向,默認(rèn)為true

body:可選參數(shù),即表單數(shù)據(jù),默認(rèn)為空

set_content()

此方法用來設(shè)置頁面的內(nèi)容,示例如下:

function main(splash, args)
    assert(splash:set_content("

hello

")) return splash:png() end

html()

此方法用來獲得網(wǎng)頁的源代碼

png()

此方法用來獲取PNG格式的網(wǎng)頁截圖。

jpeg()

此方法用來獲取JPEG格式的網(wǎng)頁截圖。

har()

此方法用來獲得頁面加載過程描述

url()

此方法可以獲取當(dāng)前正在訪問的URL

get_cookies()

此方法可以獲取當(dāng)前頁面的Cookies。

add_cookies()

此方法可以為當(dāng)前頁面添加Cookies。

clear_cookies()

此方法可以清除所有的Cookies。

get_viewport_size()

此方法可以獲取當(dāng)前瀏覽器頁面的大小。

set_viewport_size()

此方法可以設(shè)置當(dāng)前瀏覽器頁面的大小

set_viewport_full()

此方法可以設(shè)置瀏覽器全屏顯示

set_uer_agent()

此方法可以設(shè)置瀏覽器的User-Agent。

set_custom_headers()

此方法可以設(shè)置請求頭

select()

該方法可以選中符合條件的第一個(gè)節(jié)點(diǎn),如果有多個(gè)節(jié)點(diǎn)符合條件,則只會返回一個(gè),其參數(shù)時(shí)CSS選擇器。

select_all()

此方法可以選中所有符合條件的節(jié)點(diǎn),其參數(shù)是CSS選擇器。

mouse_click()

此方法可以模擬鼠標(biāo)點(diǎn)擊操作,傳入的參數(shù)為坐標(biāo)值的x 和y。此外,也可以直接選中某個(gè)節(jié)點(diǎn),然后調(diào)用此方法。

Splash API調(diào)用

與python結(jié)合調(diào)用。

render.html

此接口用于獲取JavaScript渲染的頁面的HTML代碼,接口地址就是Splash的運(yùn)行地址加此接口名稱,
例如 :

http://localhost:8050/render.html?url=https://www.baidu.com

我們給此接口傳遞了一個(gè)url參數(shù)來指定渲染的URL,返回結(jié)果即頁面渲染后的源代碼。

render.png

此接口可以獲取網(wǎng)頁截圖,通過width和heigh來控制寬高,返回PNG格式的圖片二進(jìn)制數(shù)據(jù)。示例如下:

curl http://localhost:8050/rnder.png?url=https://www.taobao.com&wait=5&width=1000&height=700

render.jpeg

此接口接口返回jpeg格式的網(wǎng)頁截圖。參數(shù)quality用來設(shè)置圖片質(zhì)量。

render.har

此接口用于獲取頁面加載的HAR數(shù)據(jù),示例如下:

curl http://localhost:8050/render.har?url=https://www.jd.com&wait=5

render.json

此接口包含了前面接口的所有功能,返回結(jié)果是JSON格式。

execute

此接口是最為強(qiáng)大的接口,實(shí)現(xiàn)了與Lua腳本的對接。

Splash負(fù)載均衡設(shè)置

負(fù)載均衡的目的就是為了多個(gè)服務(wù)器分擔(dān)壓力。
假設(shè)四臺服務(wù)器哦IP地址為:

127.0.0.1

127.0.0.2

127.0.0.3

127.0.0.4

四臺服務(wù)器的Splash均通過dockers的splash鏡像在端口:8050開啟服務(wù)。
選擇任意一臺帶有公網(wǎng)IP的主機(jī)來配置負(fù)載均衡。

首先在服務(wù)器安裝Nginx。

修改Nginx的配置文件nginx.conf,添加如下內(nèi)容:

http {
    upstream splash {  # 服務(wù)器集群名為splash
        least_conn;  
        # 代表最少鏈接負(fù)載均衡,去掉此行將使用默認(rèn)的輪詢策略實(shí)現(xiàn)負(fù)載均衡
        # 若使用ip_hash,此方法確保同一服務(wù)器響應(yīng)請求,此方法適合有狀態(tài)的服務(wù)。
        # Splash不需要應(yīng)用此設(shè)置。
        server 127.0.0.1:8050;
        # 還可以添加weight參數(shù)設(shè)置權(quán)值,權(quán)值越高分配到的請求越多。
        server 127.0.0.2:8050;
        server 127.0.0.3:8050;
        server 127.0.0.4:8050;
    }
    server {
        listen 8050;
        location / {
            proxy_pass http://splash;
            # 設(shè)置下面兩行來進(jìn)行用戶認(rèn)真。
            auth_basic "Restricted";
            auth_baseic_user_file /etc/nginx/conf.d/.htpasswd;
        }
    }
}

上面用戶認(rèn)證的用戶名和密碼配置放置在 /etc/nginx/conf.d 目錄下,我們需要使用htpasswd命令創(chuàng)建。

例如,創(chuàng)建一個(gè)用戶名為admin的文件,相關(guān)命令如下:

htpasswd -c .htpasswd admin

之后輸入兩次密碼即可。

配置完成后需要重啟Nginx服務(wù)。

測試文件在

./test_load_balance.py

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

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

相關(guān)文章

  • 初識Spalash

    摘要:負(fù)載均衡設(shè)置負(fù)載均衡的目的就是為了多個(gè)服務(wù)器分擔(dān)壓力。修改的配置文件,添加如下內(nèi)容服務(wù)器集群名為代表最少鏈接負(fù)載均衡,去掉此行將使用默認(rèn)的輪詢策略實(shí)現(xiàn)負(fù)載均衡若使用,此方法確保同一服務(wù)器響應(yīng)請求,此方法適合有狀態(tài)的服務(wù)。 輸入下面命令運(yùn)行splash: docker run -p 8050:8050 scrapinghub/splash 一個(gè)splash的基本實(shí)例: function ...

    xumenger 評論0 收藏0
  • 初識Spalash

    摘要:負(fù)載均衡設(shè)置負(fù)載均衡的目的就是為了多個(gè)服務(wù)器分擔(dān)壓力。修改的配置文件,添加如下內(nèi)容服務(wù)器集群名為代表最少鏈接負(fù)載均衡,去掉此行將使用默認(rèn)的輪詢策略實(shí)現(xiàn)負(fù)載均衡若使用,此方法確保同一服務(wù)器響應(yīng)請求,此方法適合有狀態(tài)的服務(wù)。 輸入下面命令運(yùn)行splash: docker run -p 8050:8050 scrapinghub/splash 一個(gè)splash的基本實(shí)例: function ...

    james 評論0 收藏0
  • Python3網(wǎng)絡(luò)爬蟲實(shí)戰(zhàn)---38、動態(tài)渲染頁面抓取:Splash的使用

    摘要:上一篇文章網(wǎng)絡(luò)爬蟲實(shí)戰(zhàn)動態(tài)渲染頁面抓取下一篇文章是一個(gè)渲染服務(wù),是一個(gè)帶有的輕量級瀏覽器,同時(shí)它對接了中的和庫,利用它我們同樣可以實(shí)現(xiàn)動態(tài)渲染頁面的抓取。 上一篇文章:Python3網(wǎng)絡(luò)爬蟲實(shí)戰(zhàn)---37、動態(tài)渲染頁面抓取:Selenium下一篇文章: Splash 是一個(gè) JavaScript 渲染服務(wù),是一個(gè)帶有 HTTP API 的輕量級瀏覽器,同時(shí)它對接了 Python 中的 ...

    姘擱『 評論0 收藏0
  • Python3網(wǎng)絡(luò)爬蟲實(shí)戰(zhàn)---11、爬蟲框架的安裝:ScrapySplash、ScrapyRedi

    摘要:上一篇文章網(wǎng)絡(luò)爬蟲實(shí)戰(zhàn)爬蟲框架的安裝下一篇文章網(wǎng)絡(luò)爬蟲實(shí)戰(zhàn)部署相關(guān)庫的安裝的安裝是一個(gè)中支持渲染的工具,本節(jié)來介紹一下它的安裝方式。另外一個(gè)是的庫的安裝,安裝之后即可在中使用服務(wù)。 上一篇文章:Python3網(wǎng)絡(luò)爬蟲實(shí)戰(zhàn)---10、爬蟲框架的安裝:PySpider、Scrapy下一篇文章:Python3網(wǎng)絡(luò)爬蟲實(shí)戰(zhàn)---12、部署相關(guān)庫的安裝:Docker、Scrapyd Scrap...

    harryhappy 評論0 收藏0

發(fā)表評論

0條評論

最新活動
閱讀需要支付1元查看
<