From 2079fa56a40f42491e37702828a42e002a2b3db8546036c80266e6aae75cb151 Mon Sep 17 00:00:00 2001 From: Jan Engelhardt Date: Fri, 27 Mar 2015 10:35:30 +0000 Subject: [PATCH 1/4] varnish-4.0.3 OBS-URL: https://build.opensuse.org/package/show/server:http/varnish?expand=0&rev=67 --- ...h-on-malformed-Content-Length-header.patch | 290 ++++++++++++++++++ varnish-3.0.5.tar.gz | 3 - varnish-4.0.3.tar.gz | 3 + varnish.changes | 16 + varnish.spec | 53 ++-- 5 files changed, 340 insertions(+), 25 deletions(-) create mode 100644 0001-Fail-fetch-on-malformed-Content-Length-header.patch delete mode 100644 varnish-3.0.5.tar.gz create mode 100644 varnish-4.0.3.tar.gz diff --git a/0001-Fail-fetch-on-malformed-Content-Length-header.patch b/0001-Fail-fetch-on-malformed-Content-Length-header.patch new file mode 100644 index 0000000..23e4a9f --- /dev/null +++ b/0001-Fail-fetch-on-malformed-Content-Length-header.patch @@ -0,0 +1,290 @@ +From 9d61ea4d722549a984d912603902fccfac473824 Mon Sep 17 00:00:00 2001 +From: Martin Blix Grydeland +Date: Fri, 13 Mar 2015 15:23:15 +0100 +Subject: [PATCH] Fail fetch on malformed Content-Length header + +Add a common content length parser that is being used by both client +and backend side. + +Original patch by: fgs + +Fixes: #1691 +--- + bin/varnishd/cache/cache.h | 7 ++++--- + bin/varnishd/cache/cache_http.c | 29 +++++++++++++++++++++++++++++ + bin/varnishd/cache/cache_http1_fetch.c | 32 +++++--------------------------- + bin/varnishd/cache/cache_http1_fsm.c | 20 ++++++++++---------- + bin/varnishd/cache/cache_http1_proto.c | 5 +++-- + bin/varnishd/cache/cache_rfc2616.c | 18 +++++++++++++++--- + bin/varnishtest/tests/r01691.vtc | 21 +++++++++++++++++++++ + 7 files changed, 87 insertions(+), 45 deletions(-) + create mode 100644 bin/varnishtest/tests/r01691.vtc + +Index: varnish-4.0.3/bin/varnishd/cache/cache.h +=================================================================== +--- varnish-4.0.3.orig/bin/varnishd/cache/cache.h ++++ varnish-4.0.3/bin/varnishd/cache/cache.h +@@ -208,7 +208,7 @@ struct http { + * + */ + +-typedef ssize_t htc_read(struct http_conn *, void *, size_t); ++typedef ssize_t htc_read(struct http_conn *, void *, ssize_t); + + struct http_conn { + unsigned magic; +@@ -560,7 +560,7 @@ struct busyobj { + + struct pool_task fetch_task; + +- char *h_content_length; ++ ssize_t content_length; + + #define BO_FLAG(l, r, w, d) unsigned l:1; + #include "tbl/bo_flags.h" +@@ -1014,6 +1014,7 @@ int http_GetHdrData(const struct http *h + int http_GetHdrField(const struct http *hp, const char *hdr, + const char *field, char **ptr); + double http_GetHdrQ(const struct http *hp, const char *hdr, const char *field); ++ssize_t http_GetContentLength(const struct http *hp); + uint16_t http_GetStatus(const struct http *hp); + void http_SetStatus(struct http *to, uint16_t status); + const char *http_GetReq(const struct http *hp); +@@ -1040,7 +1041,7 @@ void HTTP1_Init(struct http_conn *htc, s + unsigned maxbytes, unsigned maxhdr); + enum htc_status_e HTTP1_Reinit(struct http_conn *htc); + enum htc_status_e HTTP1_Rx(struct http_conn *htc); +-ssize_t HTTP1_Read(struct http_conn *htc, void *d, size_t len); ++ssize_t HTTP1_Read(struct http_conn *htc, void *d, ssize_t len); + enum htc_status_e HTTP1_Complete(struct http_conn *htc); + uint16_t HTTP1_DissectRequest(struct req *); + uint16_t HTTP1_DissectResponse(struct http *sp, const struct http_conn *htc); +Index: varnish-4.0.3/bin/varnishd/cache/cache_http.c +=================================================================== +--- varnish-4.0.3.orig/bin/varnishd/cache/cache_http.c ++++ varnish-4.0.3/bin/varnishd/cache/cache_http.c +@@ -488,6 +488,35 @@ http_GetHdrField(const struct http *hp, + return (i); + } + ++/*--------------------------------------------------------------------*/ ++ ++ssize_t ++http_GetContentLength(const struct http *hp) ++{ ++ ssize_t cl, cll; ++ char *b; ++ ++ CHECK_OBJ_NOTNULL(hp, HTTP_MAGIC); ++ ++ if (!http_GetHdr(hp, H_Content_Length, &b)) ++ return (-1); ++ cl = 0; ++ if (!vct_isdigit(*b)) ++ return (-2); ++ for (;vct_isdigit(*b); b++) { ++ cll = cl; ++ cl *= 10; ++ cl += *b - '0'; ++ if (cll != cl / 10) ++ return (-2); ++ } ++ while (vct_islws(*b)) ++ b++; ++ if (*b != '\0') ++ return (-2); ++ return (cl); ++} ++ + /*-------------------------------------------------------------------- + * XXX: redo with http_GetHdrField() ? + */ +Index: varnish-4.0.3/bin/varnishd/cache/cache_http1_fetch.c +=================================================================== +--- varnish-4.0.3.orig/bin/varnishd/cache/cache_http1_fetch.c ++++ varnish-4.0.3/bin/varnishd/cache/cache_http1_fetch.c +@@ -43,29 +43,6 @@ + #include "vtcp.h" + #include "vtim.h" + +-/*-------------------------------------------------------------------- +- * Convert a string to a size_t safely +- */ +- +-static ssize_t +-vbf_fetch_number(const char *nbr, int radix) +-{ +- uintmax_t cll; +- ssize_t cl; +- char *q; +- +- if (*nbr == '\0') +- return (-1); +- cll = strtoumax(nbr, &q, radix); +- if (q == NULL || *q != '\0') +- return (-1); +- +- cl = (ssize_t)cll; +- if((uintmax_t)cl != cll) /* Protect against bogusly large values */ +- return (-1); +- return (cl); +-} +- + /*--------------------------------------------------------------------*/ + + static enum vfp_status __match_proto__(vfp_pull_f) +@@ -167,7 +144,6 @@ ssize_t + V1F_Setup_Fetch(struct busyobj *bo) + { + struct http_conn *htc; +- ssize_t cl; + + CHECK_OBJ_NOTNULL(bo, BUSYOBJ_MAGIC); + htc = &bo->htc; +@@ -176,13 +152,15 @@ V1F_Setup_Fetch(struct busyobj *bo) + + switch(htc->body_status) { + case BS_EOF: ++ assert(bo->content_length == -1); + VFP_Push(bo, v1f_pull_eof, 0); + return(-1); + case BS_LENGTH: +- cl = vbf_fetch_number(bo->h_content_length, 10); +- VFP_Push(bo, v1f_pull_straight, cl); +- return (cl); ++ assert(bo->content_length > 0); ++ VFP_Push(bo, v1f_pull_straight, bo->content_length); ++ return (bo->content_length); + case BS_CHUNKED: ++ assert(bo->content_length == -1); + VFP_Push(bo, v1f_pull_chunked, -1); + return (-1); + default: +Index: varnish-4.0.3/bin/varnishd/cache/cache_http1_fsm.c +=================================================================== +--- varnish-4.0.3.orig/bin/varnishd/cache/cache_http1_fsm.c ++++ varnish-4.0.3/bin/varnishd/cache/cache_http1_fsm.c +@@ -262,22 +262,22 @@ http1_cleanup(struct sess *sp, struct wo + static enum req_body_state_e + http1_req_body_status(struct req *req) + { +- char *ptr, *endp; ++ ssize_t cl; + + CHECK_OBJ_NOTNULL(req, REQ_MAGIC); + +- if (http_GetHdr(req->http, H_Content_Length, &ptr)) { +- AN(ptr); +- if (*ptr == '\0') +- return (REQ_BODY_FAIL); +- req->req_bodybytes = strtoul(ptr, &endp, 10); +- if (*endp != '\0' && !vct_islws(*endp)) +- return (REQ_BODY_FAIL); +- if (req->req_bodybytes == 0) +- return (REQ_BODY_NONE); ++ req->req_bodybytes = 0; ++ cl = http_GetContentLength(req->http); ++ if (cl == -2) ++ return (REQ_BODY_FAIL); ++ else if (cl == 0) ++ return (REQ_BODY_NONE); ++ else if (cl > 0) { ++ req->req_bodybytes = cl; + req->h1.bytes_yet = req->req_bodybytes - req->h1.bytes_done; + return (REQ_BODY_PRESENT); + } ++ assert(cl == -1); /* No Content-Length header */ + if (http_HdrIs(req->http, H_Transfer_Encoding, "chunked")) { + req->chunk_ctr = -1; + return (REQ_BODY_CHUNKED); +Index: varnish-4.0.3/bin/varnishd/cache/cache_http1_proto.c +=================================================================== +--- varnish-4.0.3.orig/bin/varnishd/cache/cache_http1_proto.c ++++ varnish-4.0.3/bin/varnishd/cache/cache_http1_proto.c +@@ -191,14 +191,15 @@ HTTP1_Rx(struct http_conn *htc) + * Read up to len bytes, returning pipelined data first. + */ + +-ssize_t +-HTTP1_Read(struct http_conn *htc, void *d, size_t len) ++ssize_t __match_proto__(htc_read) ++HTTP1_Read(struct http_conn *htc, void *d, ssize_t len) + { + size_t l; + unsigned char *p; + ssize_t i = 0; + + CHECK_OBJ_NOTNULL(htc, HTTP_CONN_MAGIC); ++ assert(len > 0); + l = 0; + p = d; + if (htc->pipeline.b) { +Index: varnish-4.0.3/bin/varnishd/cache/cache_rfc2616.c +=================================================================== +--- varnish-4.0.3.orig/bin/varnishd/cache/cache_rfc2616.c ++++ varnish-4.0.3/bin/varnishd/cache/cache_rfc2616.c +@@ -188,6 +188,7 @@ enum body_status + RFC2616_Body(struct busyobj *bo, struct dstat *stats) + { + struct http *hp; ++ ssize_t cl; + char *b; + + hp = bo->beresp; +@@ -199,6 +200,8 @@ RFC2616_Body(struct busyobj *bo, struct + else + bo->should_close = 0; + ++ bo->content_length = -1; ++ + if (!strcasecmp(http_GetReq(bo->bereq), "head")) { + /* + * A HEAD request can never have a body in the reply, +@@ -246,9 +249,18 @@ RFC2616_Body(struct busyobj *bo, struct + return (BS_ERROR); + } + +- if (http_GetHdr(hp, H_Content_Length, &bo->h_content_length)) { +- stats->fetch_length++; +- return (BS_LENGTH); ++ cl = http_GetContentLength(hp); ++ if (cl == -2) ++ return (BS_ERROR); ++ if (cl >= 0) { ++ bo->content_length = cl; ++ if (cl == 0) { ++ stats->fetch_zero++; ++ return (BS_NONE); ++ } else { ++ stats->fetch_length++; ++ return (BS_LENGTH); ++ } + } + + if (http_HdrIs(hp, H_Connection, "keep-alive")) { +Index: varnish-4.0.3/bin/varnishtest/tests/r01691.vtc +=================================================================== +--- /dev/null ++++ varnish-4.0.3/bin/varnishtest/tests/r01691.vtc +@@ -0,0 +1,21 @@ ++varnishtest "Test bogus Content-Length header" ++ ++server s1 { ++ rxreq ++ txresp -nolen -hdr "Content-Length: bogus" ++} -start ++ ++varnish v1 -vcl+backend { ++ ++} -start ++ ++logexpect l1 -v v1 { ++ expect * 1002 VCL_Error "Body cannot be fetched" ++} -start ++ ++client c1 { ++ txreq ++ rxresp ++} -run ++ ++logexpect l1 -wait diff --git a/varnish-3.0.5.tar.gz b/varnish-3.0.5.tar.gz deleted file mode 100644 index ecc8f2f..0000000 --- a/varnish-3.0.5.tar.gz +++ /dev/null @@ -1,3 +0,0 @@ -version https://git-lfs.github.com/spec/v1 -oid sha256:302fd6afc771524ca3912f5d945ab197a55762385c012b2054df7d86bf7ae2b7 -size 2116664 diff --git a/varnish-4.0.3.tar.gz b/varnish-4.0.3.tar.gz new file mode 100644 index 0000000..beee88e --- /dev/null +++ b/varnish-4.0.3.tar.gz @@ -0,0 +1,3 @@ +version https://git-lfs.github.com/spec/v1 +oid sha256:94b9a174097f47db2286acd2c35f235e49a2b7a9ddfdbd6eb7aa4da9ae8f8206 +size 1866760 diff --git a/varnish.changes b/varnish.changes index 88d0913..151c1ed 100644 --- a/varnish.changes +++ b/varnish.changes @@ -1,3 +1,19 @@ +------------------------------------------------------------------- +Fri Mar 27 10:34:15 UTC 2015 - jengelh@inai.de + +- Update to new upstream release 4.0.3 +* Full support for streaming objects through from the backend on a + cache miss. Bytes will be sent to 1..n requesting clients as they + come in from the backend server. +* Background (re)fetch of expired objects. On a cache miss where a + stale copy is available, serve the client the stale copy while + fetching an updated copy from the backend in the background. +* New varnishlog query language, allowing automatic grouping of + requests when debugging ESI or a failed backend request. +* Comprehensive request timestamp and byte counters. +- Add 0001-Fail-fetch-on-malformed-Content-Length-header.patch + [bnc#921316] + ------------------------------------------------------------------- Fri Jan 3 10:57:19 UTC 2014 - danimo@owncloud.com diff --git a/varnish.spec b/varnish.spec index 6dff52c..e6d7d34 100644 --- a/varnish.spec +++ b/varnish.spec @@ -1,7 +1,7 @@ # # spec file for package varnish # -# Copyright (c) 2009 SUSE LINUX Products GmbH, Nuernberg, Germany. +# Copyright (c) 2015 SUSE LINUX GmbH, Nuernberg, Germany. # # All modifications and additions to the file contributed by third parties # remain the property of their copyright owners, unless otherwise agreed @@ -15,37 +15,42 @@ # Please submit bugfixes or comments via http://bugs.opensuse.org/ # + Name: varnish %define library_name libvarnishapi1 -Version: 3.0.5 +Version: 4.0.3 Release: 0 Summary: Varnish is a high-performance HTTP accelerator License: BSD-2-Clause Group: Productivity/Networking/Web/Proxy -URL: http://varnish-cache.org/ +Url: http://varnish-cache.org/ #Git-Clone: git://git.varnish-cache.org/varnish-cache #Git-Web: https://varnish-cache.org/trac/browser -#DL-URL: http://downloads.sf.net/varnish/%name-%version.tar.bz2 -Source: %name-%version.tar.gz -Source2: varnish.init -Source3: varnish.sysconfig -Source4: vcl.conf -Source5: varnish.logrotate -Source6: varnishlog.init -Source7: varnish.service -Source8: varnishlog.service +Source: https://repo.varnish-cache.org/source/%name-%version.tar.gz +Source2: varnish.init +Source3: varnish.sysconfig +Source4: vcl.conf +Source5: varnish.logrotate +Source6: varnishlog.init +Source7: varnish.service +Source8: varnishlog.service +Patch1: 0001-Fail-fetch-on-malformed-Content-Length-header.patch -BuildRoot: %_tmppath/%name-%version-build -BuildRequires: libxslt, ncurses-devel, pcre-devel, readline-devel -BuildRequires: pkgconfig, xz +BuildRoot: %{_tmppath}/%{name}-%{version}-build +BuildRequires: libxslt +BuildRequires: ncurses-devel +BuildRequires: pcre-devel +BuildRequires: pkgconfig +BuildRequires: readline-devel +BuildRequires: python-docutils +BuildRequires: xz Prereq(post): %_sbindir/useradd %_sbindir/groupadd %if 0%{?suse_version} >= 1010 Recommends: logrotate %endif %if 0%{?suse_version} >= 1210 -BuildRequires: systemd -%{?systemd_requires} +BuildRequires: systemd-rpm-macros %endif %define pkg_home %_localstatedir/lib/%name %define pkg_logdir %_localstatedir/log/%name @@ -63,8 +68,8 @@ server. The purpose of this is to minimize the requests going to the backend server(s) by serving the same document to potentially many users. %package -n %library_name -Group: Productivity/Networking/Web/Proxy Summary: Shared libraries for Varnish +Group: Productivity/Networking/Web/Proxy %description -n %library_name Varnish is an HTTP accelerator. An HTTP accelerator (often called Reverse @@ -79,9 +84,9 @@ server(s) by serving the same document to potentially many users. This package holds the shared libraries for varnish. %package devel -Group: Development/Libraries/C and C++ Requires: %name = %version Summary: Development files for Varnish +Group: Development/Libraries/C and C++ %description devel Varnish is an HTTP accelerator. An HTTP accelerator (often called Reverse @@ -97,10 +102,11 @@ This package holds the development files for varnish. %prep %setup -q +%patch -P 1 -p1 %build export CFLAGS="%optflags -fstack-protector" -%configure --disable-static \ +%configure --disable-static --docdir="%_docdir/%name" \ --localstatedir=%_localstatedir/cache/ \ --enable-developer-warnings make %{?_smp_mflags} @@ -133,6 +139,8 @@ install -Dpm 0644 %{S:4} "$b/%_sysconfdir/%name/vcl.conf.example"; find "$b" -type f -name "*.la" -delete mkdir -p "$b/%pkg_logdir" +mkdir -p "$b/%_docdir/%name" +cp -a ChangeLog LICENSE README "$b/%_docdir/%name/" %pre %_bindir/getent group varnish >/dev/null || \ @@ -185,12 +193,12 @@ mkdir -p "$b/%pkg_logdir" %dir %attr(0750,root,varnish) %_sysconfdir/%name/ %config(noreplace) %attr(0640,root,varnish) %_sysconfdir/%name/vcl.conf %config %attr(0640,root,varnish) %_sysconfdir/%name/vcl.conf.example -%config(noreplace) %attr(0640,root,varnish) %_sysconfdir/%name/default.vcl %_libdir/varnish %_sbindir/varnish* %_sbindir/rcvarnish* %_mandir/man*/* -%doc ChangeLog LICENSE README +%_docdir/%name/ +%_datadir/%name/ %dir %attr(0750,varnish,varnish) %pkg_home %dir %attr(0750,varnish,varnish) %pkg_cachedir %dir %attr(0750,varnish,varnish) %pkg_logdir @@ -209,6 +217,7 @@ mkdir -p "$b/%pkg_logdir" %files devel %defattr(-,root,root,-) %_includedir/varnish +%_datadir/aclocal/ %_libdir/pkgconfig/* %_libdir/libvarnishapi.so From 4f0aaf30f83adda9efe55c0145b861c2ac367a15dd866eea7730bc11f31f68a9 Mon Sep 17 00:00:00 2001 From: Jan Engelhardt Date: Fri, 27 Mar 2015 18:14:08 +0000 Subject: [PATCH 2/4] Drop init scripts masked by service OBS-URL: https://build.opensuse.org/package/show/server:http/varnish?expand=0&rev=68 --- varnish.spec | 40 ++++------------------------------------ 1 file changed, 4 insertions(+), 36 deletions(-) diff --git a/varnish.spec b/varnish.spec index e6d7d34..19f886a 100644 --- a/varnish.spec +++ b/varnish.spec @@ -49,9 +49,7 @@ Prereq(post): %_sbindir/useradd %_sbindir/groupadd %if 0%{?suse_version} >= 1010 Recommends: logrotate %endif -%if 0%{?suse_version} >= 1210 BuildRequires: systemd-rpm-macros -%endif %define pkg_home %_localstatedir/lib/%name %define pkg_logdir %_localstatedir/log/%name %define pkg_cachedir %_localstatedir/cache/%name @@ -113,7 +111,7 @@ make %{?_smp_mflags} %install b="%buildroot"; -make install DESTDIR="%buildroot"; +%make_install # There is no use for them to normal users mv "$b/%_bindir"/* "$b/%_sbindir/"; # @@ -123,15 +121,11 @@ install -Dpm 0644 "%{S:5}" "$b/%_sysconfdir/logrotate.d/varnish"; # ##init scripts install -Dpm 0644 "%{S:3}" "$b/var/adm/fillup-templates/sysconfig.%name"; -install -Dpm 0755 "%{S:2}" "$b/%_initddir/varnish"; -install -Dpm 0755 "%{S:6}" "$b/%_initddir/varnishlog"; -%if 0%{?_unitdir:1} install -Dpm 0644 "%{S:7}" "$b/%_unitdir/varnish.service"; install -Dpm 0644 "%{S:8}" "$b/%_unitdir/varnishlog.service"; -%endif mkdir -p "$b/%_sbindir"; -ln -s "%_initddir/varnish" "$b/%_sbindir/rcvarnish"; -ln -s "%_initddir/varnishlog" "$b/%_sbindir/rcvarnishlog"; +ln -s service "$b/%_sbindir/rcvarnish"; +ln -s service "$b/%_sbindir/rcvarnishlog"; # ##config files install -Dpm 0644 %{S:4} "$b/%_sysconfdir/%name/vcl.conf"; @@ -148,47 +142,27 @@ cp -a ChangeLog LICENSE README "$b/%_docdir/%name/" %_bindir/getent passwd varnish >/dev/null || \ %_sbindir/useradd -g varnish -s /bin/false -r -c "user for Varnish" \ -d %pkg_home varnish || : -%if 0%{?_unitdir:1} %service_add_pre varnish.service %service_add_pre varnishlog.service -%endif %post -%fillup_and_insserv varnish -%fillup_and_insserv varnishlog -%if 0%{?_unitdir:1} %service_add_post varnish.service %service_add_post varnishlog.service -%endif %preun -%stop_on_removal varnish -%stop_on_removal varnishlog -%if 0%{?_unitdir:1} %service_del_preun varnish.service %service_del_preun varnishlog.service -%endif %postun -# Does sysv+systemd not very much conflict? But rpmlint wants to have it... -%restart_on_update varnish -%restart_on_update varnishlog -%if 0%{?_unitdir:1} %service_del_postun varnish.service %service_del_postun varnishlog.service -%endif -%insserv_cleanup %post -n %library_name -p /sbin/ldconfig %postun -n %library_name -p /sbin/ldconfig %files %defattr(-,root,root) -%_initddir/varnish -%_initddir/varnishlog -%if 0%{?_unitdir:1} -%_unitdir -%endif +%_unitdir/*.service %config(noreplace) %_sysconfdir/logrotate.d/varnish %dir %attr(0750,root,varnish) %_sysconfdir/%name/ %config(noreplace) %attr(0640,root,varnish) %_sysconfdir/%name/vcl.conf @@ -202,13 +176,7 @@ cp -a ChangeLog LICENSE README "$b/%_docdir/%name/" %dir %attr(0750,varnish,varnish) %pkg_home %dir %attr(0750,varnish,varnish) %pkg_cachedir %dir %attr(0750,varnish,varnish) %pkg_logdir - -%if 0%{?suse_version} %_localstatedir/adm/fillup-templates/sysconfig.%name -%else -%config(noreplace) %_sysconfdir/sysconfig/%name -%doc redhat/README.redhat -%endif %files -n %library_name %defattr(-,root,root,-) From 4fe9ebeb7803db113a8efa325e98f473f1a69d6d507457220ba30d7d50ead880 Mon Sep 17 00:00:00 2001 From: Jan Engelhardt Date: Fri, 27 Mar 2015 20:31:00 +0000 Subject: [PATCH 3/4] Drop unmaintained init scripts OBS-URL: https://build.opensuse.org/package/show/server:http/varnish?expand=0&rev=69 --- varnish.init | 185 ------------------------------------------------ varnishlog.init | 164 ------------------------------------------ 2 files changed, 349 deletions(-) delete mode 100644 varnish.init delete mode 100644 varnishlog.init diff --git a/varnish.init b/varnish.init deleted file mode 100644 index 0b3c2d9..0000000 --- a/varnish.init +++ /dev/null @@ -1,185 +0,0 @@ -#!/bin/sh -# -### BEGIN INIT INFO -# Provides: varnish -# Required-Start: $syslog $remote_fs -# Should-Start: $time ypbind sendmail -# Required-Stop: $syslog $remote_fs -# Should-Stop: $time ypbind sendmail -# Default-Start: 3 5 -# Default-Stop: 0 1 2 6 -# Short-Description: varnish HTTP accelerator -# Description: varnish HTTP accelerator -### END INIT INFO - -# Check for missing binaries (stale symlinks should not happen) -# Note: Special treatment of stop for LSB conformance -VARNISH_BIN=/usr/sbin/varnishd -test -x $VARNISH_BIN || { echo "$VARNISH_BIN not installed"; - if [ "$1" = "stop" ]; then exit 0; - else exit 5; fi; } - -# Check for existence of needed config file and read it -VARNISH_CONFIG=/etc/sysconfig/varnish -test -r $VARNISH_CONFIG || { echo "$VARNISH_CONFIG not existing"; - if [ "$1" = "stop" ]; then exit 0; - else exit 6; fi; } - -VARNISHD_BIN="$VARNISH_BIN" -VARNISHD_PID=/var/run/varnishd.pid -VARNISHLOG_BIN=/usr/sbin/varnishncsa -VARNISHLOG_PID=/var/run/varnishlog.pid - -# Read config -. $VARNISH_CONFIG - -# Source LSB init functions -# providing start_daemon, killproc, pidofproc, -# log_success_msg, log_failure_msg and log_warning_msg. -# This is currently not used by UnitedLinux based distributions and -# not needed for init scripts for UnitedLinux only. If it is used, -# the functions from rc.status should not be sourced or used. -#. /lib/lsb/init-functions - -# Shell functions sourced from /etc/rc.status: -# rc_check check and set local and overall rc status -# rc_status check and set local and overall rc status -# rc_status -v be verbose in local rc status and clear it afterwards -# rc_status -v -r ditto and clear both the local and overall rc status -# rc_status -s display "skipped" and exit with status 3 -# rc_status -u display "unused" and exit with status 3 -# rc_failed set local and overall rc status to failed -# rc_failed set local and overall rc status to -# rc_reset clear both the local and overall rc status -# rc_exit exit appropriate to overall rc status -# rc_active checks whether a service is activated by symlinks -. /etc/rc.status - -# Reset status of this service -rc_reset - -# Return values acc. to LSB for all commands but status: -# 0 - success -# 1 - generic or unspecified error -# 2 - invalid or excess argument(s) -# 3 - unimplemented feature (e.g. "reload") -# 4 - user had insufficient privileges -# 5 - program is not installed -# 6 - program is not configured -# 7 - program is not running -# 8--199 - reserved (8--99 LSB, 100--149 distrib, 150--199 appl) -# -# Note that starting an already running service, stopping -# or restarting a not-running service as well as the restart -# with force-reload (in case signaling is not supported) are -# considered a success. - -case "$1" in - start) - echo -n "Starting varnish " - ## Start daemon with startproc(8). If this fails - ## the return value is set appropriately by startproc. - /sbin/startproc "$VARNISHD_BIN" -P "$VARNISHD_PID" ${VARNISHD_PARAMS:--f /etc/varnish/vcl.conf -T:6082 -s file,/var/cache/varnish,1M -u varnish} - - # Remember status and be verbose - rc_status -v - ;; - stop) - echo -n "Shutting down varnish " - ## Stop daemon with killproc(8) and if this fails - ## killproc sets the return value according to LSB. - - /sbin/killproc -p "$VARNISHD_PID" "$VARNISHD_BIN" - - # Remember status and be verbose - rc_status -v - ;; - try-restart|condrestart) - ## Do a restart only if the service was active before. - ## Note: try-restart is now part of LSB (as of 1.9). - ## RH has a similar command named condrestart. - if test "$1" = "condrestart"; then - echo "${attn} Use try-restart ${done}(LSB)${attn} rather than condrestart ${warn}(RH)${norm}" - fi - $0 status - if test $? = 0; then - $0 restart - else - rc_reset # Not running is not a failure. - fi - # Remember status and be quiet - rc_status - ;; - restart) - ## Stop the service and regardless of whether it was - ## running or not, start it again. - $0 stop - $0 start - - # Remember status and be quiet - rc_status - ;; - force-reload) - ## Signal the daemon to reload its config. Most daemons - ## do this on signal 1 (SIGHUP). - ## If it does not support it, restart the service if it - ## is running. - - echo -n "Reload service varnish " - ## if it supports it: - /sbin/killproc -HUP $VARNISH_BIN - #touch /var/run/varnish.pid - rc_status -v - - ## Otherwise: - #$0 try-restart - #rc_status - ;; - reload) - ## Like force-reload, but if daemon does not support - ## signaling, do nothing (!) - - # If it supports signaling: - echo -n "Reload service varnish " - /sbin/killproc -p "$VARNISHD_PID" -HUP "$VARNISHD_BIN" - #touch /var/run/varnish.pid - rc_status -v - - ## Otherwise if it does not support reload: - #rc_failed 3 - #rc_status -v - ;; - status) - echo -n "Checking for service varnish " - ## Check status with checkproc(8), if process is running - ## checkproc will return with exit status 0. - - # Return value is slightly different for the status command: - # 0 - service up and running - # 1 - service dead, but /var/run/ pid file exists - # 2 - service dead, but /var/lock/ lock file exists - # 3 - service not running (unused) - # 4 - service status unknown :-( - # 5--199 reserved (5--99 LSB, 100--149 distro, 150--199 appl.) - - # NOTE: checkproc returns LSB compliant status values. - /sbin/checkproc -p "$VARNISHD_PID" "$VARNISHD_BIN" - # NOTE: rc_status knows that we called this init script with - # "status" option and adapts its messages accordingly. - rc_status -v - ;; - probe) - ## Optional: Probe for the necessity of a reload, print out the - ## argument to this init script which is required for a reload. - ## Note: probe is not (yet) part of LSB (as of 1.9) - - test /etc/sysconfig/varnish -nt "$VARNISHD_PID" && \ - test -f /etc/varnish/default.vcl.net -nt "$VARNISHD_PID" && \ - echo reload - ;; - *) - echo "Usage: $0 {start|stop|status|try-restart|restart|force-reload|reload|probe}" - exit 1 - ;; -esac -rc_exit diff --git a/varnishlog.init b/varnishlog.init deleted file mode 100644 index fa4ca35..0000000 --- a/varnishlog.init +++ /dev/null @@ -1,164 +0,0 @@ -#!/bin/sh -# -### BEGIN INIT INFO -# Provides: varnishlog -# Required-Start: $syslog $remote_fs -# Should-Start: $time ypbind sendmail -# Required-Stop: $syslog $remote_fs -# Should-Stop: $time ypbind sendmail -# Default-Start: 3 5 -# Default-Stop: 0 1 2 6 -# Short-Description: varnish logger -# Description: varnish logger -### END INIT INFO - -# Check for missing binaries (stale symlinks should not happen) -# Note: Special treatment of stop for LSB conformance -VARNISH_BIN=/usr/sbin/varnishd -test -x $VARNISH_BIN || { echo "$VARNISH_BIN not installed"; - if [ "$1" = "stop" ]; then exit 0; - else exit 5; fi; } - -# Check for existence of needed config file and read it -VARNISH_CONFIG=/etc/sysconfig/varnish -test -r $VARNISH_CONFIG || { echo "$VARNISH_CONFIG not existing"; - if [ "$1" = "stop" ]; then exit 0; - else exit 6; fi; } - -VARNISHD_BIN="$VARNISH_BIN" -VARNISHD_PID=/var/run/varnishd.pid -VARNISHLOG_BIN=/usr/sbin/varnishncsa -VARNISHLOG_PID=/var/run/varnishlog.pid - -# Read config -. $VARNISH_CONFIG - -# Source LSB init functions -# providing start_daemon, killproc, pidofproc, -# log_success_msg, log_failure_msg and log_warning_msg. -# This is currently not used by UnitedLinux based distributions and -# not needed for init scripts for UnitedLinux only. If it is used, -# the functions from rc.status should not be sourced or used. -#. /lib/lsb/init-functions - -# Shell functions sourced from /etc/rc.status: -# rc_check check and set local and overall rc status -# rc_status check and set local and overall rc status -# rc_status -v be verbose in local rc status and clear it afterwards -# rc_status -v -r ditto and clear both the local and overall rc status -# rc_status -s display "skipped" and exit with status 3 -# rc_status -u display "unused" and exit with status 3 -# rc_failed set local and overall rc status to failed -# rc_failed set local and overall rc status to -# rc_reset clear both the local and overall rc status -# rc_exit exit appropriate to overall rc status -# rc_active checks whether a service is activated by symlinks -. /etc/rc.status - -# Reset status of this service -rc_reset - -# Return values acc. to LSB for all commands but status: -# 0 - success -# 1 - generic or unspecified error -# 2 - invalid or excess argument(s) -# 3 - unimplemented feature (e.g. "reload") -# 4 - user had insufficient privileges -# 5 - program is not installed -# 6 - program is not configured -# 7 - program is not running -# 8--199 - reserved (8--99 LSB, 100--149 distrib, 150--199 appl) -# -# Note that starting an already running service, stopping -# or restarting a not-running service as well as the restart -# with force-reload (in case signaling is not supported) are -# considered a success. - -case "$1" in - start) - echo -n "Starting varnishlog " - /sbin/startproc "$VARNISHLOG_BIN" -P "$VARNISHLOG_PID" ${VARNISHLOG_PARAMS:--a -w /var/log/varnish/varnish.log} - rc_status -v - ;; - stop) - echo -n "Shutting down varnishlog " - /sbin/killproc -p "$VARNISHLOG_PID" "$VARNISHLOG_BIN" - rc_status -v - ;; - try-restart|condrestart) - ## Do a restart only if the service was active before. - ## Note: try-restart is now part of LSB (as of 1.9). - ## RH has a similar command named condrestart. - if test "$1" = "condrestart"; then - echo "${attn} Use try-restart ${done}(LSB)${attn} rather than condrestart ${warn}(RH)${norm}" - fi - $0 status - if test $? = 0; then - $0 restart - else - rc_reset # Not running is not a failure. - fi - # Remember status and be quiet - rc_status - ;; - restart) - ## Stop the service and regardless of whether it was - ## running or not, start it again. - $0 stop - $0 start - - # Remember status and be quiet - rc_status - ;; - force-reload) - ## Signal the daemon to reload its config. Most daemons - ## do this on signal 1 (SIGHUP). - ## If it does not support it, restart the service if it - ## is running. - - "$0" reload - rc_status - - ## Otherwise: - #$0 try-restart - #rc_status - ;; - reload) - ## Like force-reload, but if daemon does not support - ## signaling, do nothing (!) - - echo -n "Reload service varnishlog " - /sbin/killproc -p "$VARNISHLOG_PID" -HUP "$VARNISHLOG_BIN" - rc_status -v - ;; - status) - ## Check status with checkproc(8), if process is running - ## checkproc will return with exit status 0. - - # Return value is slightly different for the status command: - # 0 - service up and running - # 1 - service dead, but /var/run/ pid file exists - # 2 - service dead, but /var/lock/ lock file exists - # 3 - service not running (unused) - # 4 - service status unknown :-( - # 5--199 reserved (5--99 LSB, 100--149 distro, 150--199 appl.) - - echo -n "Checking for service varnishlog " - /sbin/checkproc -p "$VARNISHLOG_PID" "$VARNISHLOG_BIN" - rc_status -v - ;; - probe) - ## Optional: Probe for the necessity of a reload, print out the - ## argument to this init script which is required for a reload. - ## Note: probe is not (yet) part of LSB (as of 1.9) - - test /etc/sysconfig/varnish -nt "$VARNISHD_PID" && \ - test -f /etc/varnish/default.vcl.net -nt "$VARNISHD_PID" && \ - echo reload - ;; - *) - echo "Usage: $0 {start|stop|status|try-restart|restart|force-reload|reload|probe}" - exit 1 - ;; -esac -rc_exit From 749ca9df991224100c524a066d5f3f9c071e8cd62fe19e4f6beb3bffacbc5299 Mon Sep 17 00:00:00 2001 From: Jan Engelhardt Date: Fri, 27 Mar 2015 20:36:01 +0000 Subject: [PATCH 4/4] Use shipped vcl example file, rather than our own OBS-URL: https://build.opensuse.org/package/show/server:http/varnish?expand=0&rev=70 --- varnish.spec | 8 ++------ vcl.conf | 30 ------------------------------ 2 files changed, 2 insertions(+), 36 deletions(-) delete mode 100644 vcl.conf diff --git a/varnish.spec b/varnish.spec index 19f886a..d083459 100644 --- a/varnish.spec +++ b/varnish.spec @@ -28,11 +28,8 @@ Url: http://varnish-cache.org/ #Git-Clone: git://git.varnish-cache.org/varnish-cache #Git-Web: https://varnish-cache.org/trac/browser Source: https://repo.varnish-cache.org/source/%name-%version.tar.gz -Source2: varnish.init Source3: varnish.sysconfig -Source4: vcl.conf Source5: varnish.logrotate -Source6: varnishlog.init Source7: varnish.service Source8: varnishlog.service Patch1: 0001-Fail-fetch-on-malformed-Content-Length-header.patch @@ -128,8 +125,8 @@ ln -s service "$b/%_sbindir/rcvarnish"; ln -s service "$b/%_sbindir/rcvarnishlog"; # ##config files -install -Dpm 0644 %{S:4} "$b/%_sysconfdir/%name/vcl.conf"; -install -Dpm 0644 %{S:4} "$b/%_sysconfdir/%name/vcl.conf.example"; +mkdir -p "$b/%_sysconfdir/%name" +cp "$b/%_docdir/%name/example.vcl" "$b/%_sysconfdir/%name/vcl.conf" find "$b" -type f -name "*.la" -delete mkdir -p "$b/%pkg_logdir" @@ -166,7 +163,6 @@ cp -a ChangeLog LICENSE README "$b/%_docdir/%name/" %config(noreplace) %_sysconfdir/logrotate.d/varnish %dir %attr(0750,root,varnish) %_sysconfdir/%name/ %config(noreplace) %attr(0640,root,varnish) %_sysconfdir/%name/vcl.conf -%config %attr(0640,root,varnish) %_sysconfdir/%name/vcl.conf.example %_libdir/varnish %_sbindir/varnish* %_sbindir/rcvarnish* diff --git a/vcl.conf b/vcl.conf deleted file mode 100644 index a4e9dcd..0000000 --- a/vcl.conf +++ /dev/null @@ -1,30 +0,0 @@ -# -# This is a basic VCL configuration file for varnish. See the vcl(7) -# man page for details on VCL syntax and semantics. -# -# $Id: vcl.conf 1200 2006-10-19 09:21:42Z des $ -# - -backend default { - .host = "127.0.0.1"; - .port = "8080"; -} - -sub vcl_recv { - # pass mode can't handle POST (yet) - if (req.request == "POST") { - return(pipe); - } - - # don't bother caching large files - if(req.url ~ "\.(pdf|mp3|flv|mov|mp4|mpg|mpeg|avi|dmg)") { - return(pipe); - } - - # force lookup even when cookies are present - if (req.request == "GET" && req.http.cookie) { - return(lookup); - } - - -}