Page MenuHomeFreeBSD

www/varnish4: fix race condition on start, new features
ClosedPublic

Authored by feld on Oct 27 2015, 4:41 PM.
Tags
None
Referenced Files
F133252935: D4016.id9821.diff
Fri, Oct 24, 8:44 AM
F133192120: D4016.id9768.diff
Thu, Oct 23, 8:18 PM
Unknown Object (File)
Thu, Oct 23, 9:29 AM
Unknown Object (File)
Thu, Oct 23, 2:39 AM
Unknown Object (File)
Wed, Oct 22, 4:55 AM
Unknown Object (File)
Tue, Oct 21, 3:06 AM
Unknown Object (File)
Sun, Oct 19, 2:25 PM
Unknown Object (File)
Sun, Oct 19, 7:24 AM
Subscribers

Details

Summary

Fix race condition by removing _.vsm on start

  • varnishncsa and varnishlog wait for this file before starting.
  • varnishd does not clean this up which causes them to think varnishd is successfully running. This causes them to fail to start.

Fix default description of varnishd_flags

Add a "configtest" option to test your configuration

Run configtest in start_precmd to ensure config is good before starting

  • This provides good positive feedback to the user and clearly points out which config they are using

Run configtest before restarting to ensure config is good

  • Prevent foot-shooting

Add a "reload" option to reload your VCL file

  • It does a configtest to make sure you don't break your running service. More foot protection.

Install pid files on first-run as mode 644 instead of default 775.

Install log files on first-run as mode 640 instead of default 775.

Diff Detail

Repository
rP FreeBSD ports repository
Lint
No Lint Coverage
Unit
No Test Coverage
Build Status
Buildable 968
Build 968: arc lint + arc unit

Event Timeline

feld retitled this revision from to www/varnish4: fix race condition on start, new features.
feld updated this object.
feld edited the test plan for this revision. (Show Details)
feld added a reviewer: peter.

add "restart_precmd" to run the configtest

Don't allow a restart unless the VCL config is valid

Mode 664 -> 644 for pid files

www/varnish4/files/varnishd.in
128

I think this is OK.

https://www.varnish-cache.org/docs/trunk/reference/vsm.html

We do not yet support multiple varnish instances via rc script (-n foo instead of $(hostname) ), but if we did this is easily updated to handle that.

mat added inline comments.
www/varnish4/files/varnishd.in
45

So, if varnishd_config is unset you add -f ${varnishd_config} to the command line ? this feels wrong.

www/varnish4/files/varnishd.in
45

oh, these descriptions are swapped. I'll fix, thanks!

Fix varnishd_flags description: varnishd_config set vs unset examples were swapped

feld marked an inline comment as done.Oct 28 2015, 1:19 PM

fixed swapped descriptions

www/varnish4/files/varnishncsa.in
62

Why 664 ?

Log files should be 640 by default

feld marked an inline comment as done.Oct 28 2015, 3:28 PM
feld added inline comments.
www/varnish4/files/varnishncsa.in
62

good catch. I intended this to be 640 so users in the varnish group could read the logs, but they're not world-readable.

feld marked an inline comment as done.

varnishlog and varnishncsa have a built-in "wait for varnishd" via -t

setting "-t 0" will allow them to wait indefinitely for varnishd to attach
to the _.vsm file

I misread the docs.

-t 0 tries once and fails immediately.
-t off tries indefinitely.

feld marked an inline comment as done.Oct 29 2015, 2:16 PM

rc script docs for varnishlog_flags and varnishncsa_flags didn't match
reality

www/varnish4/files/varnishncsa.in
28

A small reminder, this does not work ?

remove _.vsm wait code for varnishncsa rc script, too

Fix ability to specify varnishncsa_logformat

Due to shell quoting hell that comes from rc.subr combined with
$name_user="" privilege dropping feature there's no way to get
varnishncsa_logformat to work. The solution is to lean on daemon(8) to
handle starting the process with the right uid. This will permit us to
pass escaped quotes through as an argument and preserve the entire
string.

As a result, do the same for varnishlog for consistency.

The privsep was a new feature and there's not a great reason for general
users to require the ability to change UID that the daemons run as.

feld marked 3 inline comments as done.Oct 29 2015, 7:24 PM

I think all concerns have been addressed. Please test if you can!

Macro doitllive:

I missed removing $varnishlog_user and $varnishncsa_user from the
install commands in start_precmd

This revision was automatically updated to reflect the committed changes.