lru nuke causes varnish to stop respnding to client requests
Damon Snyder
damon at huddler-inc.com
Fri Sep 30 18:55:45 CEST 2011
Hi Matt,
Oh, sorry, I didn't notice the worker thread count at 3000. I would suggest
switching to -smalloc,38G (total mem * 0.8). If you have a lot of small
objects or objects of the same size, you could be encountering some
excessive nuking.
Also, what are your backends doing when this happens? Is the nuking a
coincidence or is there an issue further down the stack?
Damon
On Thu, Sep 29, 2011 at 5:42 PM, Matt Schurenko <MSchurenko at airg.com> wrote:
> Sorry. I forgot to mention that I already adjusted thread behaviour via
> varniahadm while varnish was running. I had it set to use min 50, max 3000
> and a thread timeout of 120s. I think the reason why n_wrk_overflow and
> n_wrk_drop are so high is due to this problem. Before the lru nuke happens
> the number of worker threads are ~ 100. As soon as it starts to nuke the
> number of threads jumps to the max. I am monitoring some stats with MRTG. I
> seem to remember that on the other varnish server it would being to lru nuke
> long before the cache got full. For this one there is no lru nuke activity
> until it reaches a certain point and then boom. 3000 threads are used up and
> no more new clients can connect. ****
>
> ** **
>
>
> Matt Schurenko
> Systems Administrator
> ****
>
> *air**G**®** **Share Your World*
> Suite 710, 1133 Melville Street****
>
> Vancouver, BC V6E 4E5****
>
> P: +1.604.408.2228 ****
>
> F: +1.866.874.8136****
>
> E: MSchurenko at airg.com****
>
> W: www.airg.com****
>
> *From:* Damon Snyder [mailto:damon at huddler-inc.com]
> *Sent:* September-29-11 5:30 PM
> *To:* Matt Schurenko
> *Cc:* varnish-misc at varnish-cache.org
> *Subject:* Re: lru nuke causes varnish to stop respnding to client
> requests****
>
> ** **
>
> Hi Matt,****
>
> It looks like you really need to bump up the number of worker threads. From
> your stats:****
>
> ** **
>
> n_wrk_queue 2861 0.02 N queued work requests****
>
> n_wrk_overflow 83534 0.52 N overflowed work requests****
>
> n_wrk_drop 10980 0.07 N dropped work requests****
>
> ** **
>
> You have a lot of requests that are on the queue waiting for a worker and
> you have a lot of requests where varnish has given up trying to fullfil with
> a worker. You can bump the number of works up using the -w command line
> option to varnishd. I would suggest something like -w 400,1000,120 to start
> with (the default is -w2,500,300). This says use 400 at a minimum, 1000 as
> the maximum, and set the timeout to 120s. According to the stats
> explanation doc <https://www.varnish-cache.org/trac/wiki/StatsExplained> your
> n_wrk_queue and n_wrk_drop should be 0. If you see these numbers going up
> again, use -w 500,2000,120 or something like that.****
>
> ** **
>
> Hope this helps,****
>
> Damon****
>
> ** **
>
> On Thu, Sep 29, 2011 at 4:34 PM, Matt Schurenko <MSchurenko at airg.com>
> wrote:****
>
> I’ve been having this problem for a couple weeks now on one of our varnish
> servers. I have posted a couple times already. What happens is that the
> server in questions runs fine until the cache gets full. When it starts to
> lru nuke the number of worker threads jumps up to thread_pool_max and
> varnish stops responding to any client requests. I have tried this with
> Centos5.4, 5.7 and now Slackware (all 64-bit ) and the behaviour is the
> same. ****
>
> ****
>
> I am using varnish version 2.1.5 on a Dell C6105 with 48GB of RAM.****
>
> ****
>
> Here is my varnishd command line:****
>
> ****
>
> /usr/local/sbin/varnishd -s file,/tmp/varnish-cache,48g -T 127.0.0.1:2000-a
> 0.0.0.0:80 -t 604800 -f /usr/local/etc/varnish/default.vcl -p http_headers
> 384 -p connect_timeout 4.0****
>
> ****
>
> Here is the output from varnishstat -1:****
>
> ****
>
> client_conn 38582763 240.38 Client connections accepted****
>
> client_drop 10950 0.07 Connection dropped, no sess/wrk
> ****
>
> client_req 38298994 238.61 Client requests received****
>
> cache_hit 32513762 202.57 Cache hits****
>
> cache_hitpass 0 0.00 Cache hits for pass****
>
> cache_miss 5784476 36.04 Cache misses****
>
> backend_conn 5725540 35.67 Backend conn. success****
>
> backend_unhealthy 0 0.00 Backend conn. not attempted***
> *
>
> backend_busy 0 0.00 Backend conn. too many****
>
> backend_fail 1383 0.01 Backend conn. failures****
>
> backend_reuse 60837 0.38 Backend conn. reuses****
>
> backend_toolate 33 0.00 Backend conn. was closed****
>
> backend_recycle 60870 0.38 Backend conn. recycles****
>
> backend_unused 0 0.00 Backend conn. unused****
>
> fetch_head 6 0.00 Fetch head****
>
> fetch_length 93631 0.58 Fetch with Length****
>
> fetch_chunked 5689433 35.45 Fetch chunked****
>
> fetch_eof 0 0.00 Fetch EOF****
>
> fetch_bad 0 0.00 Fetch had bad headers****
>
> fetch_close 107 0.00 Fetch wanted close****
>
> fetch_oldhttp 0 0.00 Fetch pre HTTP/1.1 closed****
>
> fetch_zero 0 0.00 Fetch zero len****
>
> fetch_failed 1 0.00 Fetch failed****
>
> n_sess_mem 7138 . N struct sess_mem****
>
> n_sess 6970 . N struct sess****
>
> n_object 5047123 . N struct object****
>
> n_vampireobject 0 . N unresurrected objects****
>
> n_objectcore 5048435 . N struct objectcore****
>
> n_objecthead 4955641 . N struct objecthead****
>
> n_smf 10139770 . N struct smf****
>
> n_smf_frag 295671 . N small free smf****
>
> n_smf_large 0 . N large free smf****
>
> n_vbe_conn 2997 . N struct vbe_conn****
>
> n_wrk 3000 . N worker threads****
>
> n_wrk_create 5739 0.04 N worker threads created****
>
> n_wrk_failed 0 0.00 N worker threads not created***
> *
>
> n_wrk_max 4063 0.03 N worker threads limited****
>
> n_wrk_queue 2861 0.02 N queued work requests****
>
> n_wrk_overflow 83534 0.52 N overflowed work requests****
>
> n_wrk_drop 10980 0.07 N dropped work requests****
>
> n_backend 2 . N backends****
>
> n_expired 2179 . N expired objects****
>
> n_lru_nuked 862615 . N LRU nuked objects****
>
> n_lru_saved 0 . N LRU saved objects****
>
> n_lru_moved 27156180 . N LRU moved objects****
>
> n_deathrow 0 . N objects on deathrow****
>
> losthdr 0 0.00 HTTP header overflows****
>
> n_objsendfile 0 0.00 Objects sent with sendfile****
>
> n_objwrite 37294888 232.35 Objects sent with write****
>
> n_objoverflow 0 0.00 Objects overflowing workspace**
> **
>
> s_sess 38566049 240.27 Total Sessions****
>
> s_req 38298994 238.61 Total Requests****
>
> s_pipe 0 0.00 Total pipe****
>
> s_pass 266 0.00 Total pass****
>
> s_fetch 5783176 36.03 Total fetch****
>
> s_hdrbytes 12570989864 78319.53 Total header bytes****
>
> s_bodybytes 151327304604 942796.38 Total body bytes****
>
> sess_closed 34673984 216.03 Session Closed****
>
> sess_pipeline 187 0.00 Session Pipeline****
>
> sess_readahead 321 0.00 Session Read Ahead****
>
> sess_linger 3929378 24.48 Session Linger****
>
> sess_herd 3929559 24.48 Session herd****
>
> shm_records 2025645664 12620.14 SHM records****
>
> shm_writes 169640580 1056.89 SHM writes****
>
> shm_flushes 41 0.00 SHM flushes due to overflow****
>
> shm_cont 580515 3.62 SHM MTX contention****
>
> shm_cycles 933 0.01 SHM cycles through buffer****
>
> sm_nreq 12431620 77.45 allocator requests****
>
> sm_nobj 9844099 . outstanding allocations****
>
> sm_balloc 43855261696 . bytes allocated****
>
> sm_bfree 7684345856 . bytes free****
>
> sma_nreq 0 0.00 SMA allocator requests****
>
> sma_nobj 0 . SMA outstanding allocations****
>
> sma_nbytes 0 . SMA outstanding bytes****
>
> sma_balloc 0 . SMA bytes allocated****
>
> sma_bfree 0 . SMA bytes free****
>
> sms_nreq 1566 0.01 SMS allocator requests****
>
> sms_nobj 0 . SMS outstanding allocations****
>
> sms_nbytes 0 . SMS outstanding bytes****
>
> sms_balloc 656154 . SMS bytes allocated****
>
> sms_bfree 656154 . SMS bytes freed****
>
> backend_req 5786381 36.05 Backend requests made****
>
> n_vcl 1 0.00 N vcl total****
>
> n_vcl_avail 1 0.00 N vcl available****
>
> n_vcl_discard 0 0.00 N vcl discarded****
>
> n_purge 218 . N total active purges****
>
> n_purge_add 218 0.00 N new purges added****
>
> n_purge_retire 0 0.00 N old purges deleted****
>
> n_purge_obj_test 588742 3.67 N objects tested****
>
> n_purge_re_test 120444323 750.39 N regexps tested against****
>
> n_purge_dups 0 0.00 N duplicate purges removed****
>
> hcb_nolock 38301670 238.63 HCB Lookups without lock****
>
> hcb_lock 5786309 36.05 HCB Lookups with lock****
>
> hcb_insert 5786305 36.05 HCB Inserts****
>
> esi_parse 0 0.00 Objects ESI parsed (unlock)****
>
> esi_errors 0 0.00 ESI parse errors (unlock)****
>
> accept_fail 0 0.00 Accept failures****
>
> client_drop_late 30 0.00 Connection dropped late****
>
> uptime 160509 1.00 Client uptime****
>
> backend_retry 25 0.00 Backend conn. retry****
>
> dir_dns_lookups 0 0.00 DNS director lookups****
>
> dir_dns_failed 0 0.00 DNS director failed lookups****
>
> dir_dns_hit 0 0.00 DNS director cached lookups hit
> ****
>
> dir_dns_cache_full 0 0.00 DNS director full dnscache***
> *
>
> fetch_1xx 0 0.00 Fetch no body (1xx)****
>
> fetch_204 0 0.00 Fetch no body (204)****
>
> fetch_304 0 0.00 Fetch no body (304)****
>
> ****
>
> Even though I have removed the server from our load balancer there are
> still a lot of requests going to the backend. Maybe these are all queued up
> requests that varnish is trying to fulfill? Here is some output from
> varnishlog –c when I try to connect with curl:****
>
> ****
>
> root at mvp14:~# varnishlog -c****
>
> 26 SessionOpen c 192.168.8.41 41942 0.0.0.0:80****
>
> 26 ReqStart c 192.168.8.41 41942 2108342803****
>
> 26 RxRequest c GET****
>
> 26 RxURL c /****
>
> 26 RxProtocol c HTTP/1.1****
>
> 26 RxHeader c User-Agent: curl/7.21.4 (x86_64-unknown-linux-gnu)
> libcurl/7.21.4 OpenSSL/0.9.8n zlib/1.2.5 libidn/1.19****
>
> 26 RxHeader c Host: mvp14.airg.com****
>
> 26 RxHeader c Accept: */*****
>
> 26 VCL_call c recv****
>
> 26 VCL_return c lookup****
>
> 26 VCL_call c hash****
>
> 26 VCL_return c hash****
>
> ****
>
> ****
>
> The connection just hangs here until it times out.****
>
> ****
>
> Any help would be appreciated. We are trying to replace our squid caching
> layer with varnish. However if I can’t resolve this issue we will have to go
> back to squid.****
>
> ****
>
> Thanks,****
>
> ****
>
> ****
>
> ****
>
> *Matt Schurenko*
> Systems Administrator ****
>
>
> _______________________________________________
> varnish-misc mailing list
> varnish-misc at varnish-cache.org
> https://www.varnish-cache.org/lists/mailman/listinfo/varnish-misc****
>
> ** **
>
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <https://www.varnish-cache.org/lists/pipermail/varnish-misc/attachments/20110930/41112534/attachment-0001.html>
More information about the varnish-misc
mailing list