Hello,
    If you recall, I am working on Squid that starts multiple processes,
each doing similar things. Even with this simple design, folks want to
(a) have differently configured processes (e.g., a process that is
dedicated to a given http_port or even a cache_dir option); and
(b) bind processes to specific CPU cores (i.e., support CPU affinity)
I propose the following configuration approach that I think is simple to
implement but allows a lot of flexibility:
1. Each forked process gets a unique process name, which is just a
number from 1 to N. The process knows its name. If a forked process dies
and is reforked, the reforked process keeps the original name.
2. The squid.conf parser substitutes ${process_name} strings with the
process name doing the parsing. This substitution is performed before
individual options are parsed.
3. The squid.conf parser supports if-statement blocks. Each if-statement
must start on its own line (as if there is an option called "if"). Each
if-statement block ends with "endif" on its own line (as if there is an
"endif" option). The only two supported conditions for now are a simple
comparison:
if ${process_name} = 1
... regular squid.conf options for the first forked process ....
... regular squid.conf options for the first forked process ....
... regular squid.conf options for the first forked process ....
endif
and a set membership test, for when we want to specify options for
multiple processes:
if ${process_name} in {1,7,8}
... regular squid.conf options for the selected forked process ....
... regular squid.conf options for the selected forked process ....
... regular squid.conf options for the selected forked process ....
endif
If the condition is false, the parser skips all regular squid.conf
options inside the block until the matching endif. Otherwise, the parser
behaves as if the if-statement was not there.
This approach supports process-specific options without rewriting the
existing options or the squid.conf parser. I think the implementation is
straightforward, even if we want to support nested if-statements. We
just push the current if-statement condition on stack and either skip or
honor options until we find endif and pop the current condition.
As a side effect, we can use the same if-statement approach to quickly
disable large portions of the configuration file using conditions that
are always false.
4. CPU affinity is supported using a new cpu_affinity option that
specifies either a single CPU core ID (1..C) or the affinity mask:
  # start this (and each) process on its own core:
  cpu_affinity core=${process_name}
  # use any first four cores for this (and each) process:
  cpu_affinity mask=0xF
  # place process5 on CPU core1:
  if ${process_name} = 5
    cpu_affinity core=1
  endif
Any objections, improvement suggestions, or better ideas?
Thank you,
Alex.
Received on Sun Feb 21 2010 - 02:15:06 MST
This archive was generated by hypermail 2.2.0 : Mon Feb 22 2010 - 12:00:07 MST