A lot of systems are built in layers. Games are often split into engines and scripts. Another classic is the "three tier" architecture with data storage, application model, and view-controllers split out onto individual machines.
But more often, I run into systems where code is taking a core sample instead of building on the layers.
Monday, October 29, 2012
Thursday, October 25, 2012
War Story: Apache, SSL, and name-based vhosts
Note: this post was written about a year ago, before we completed some major upgrades to our infrastructure. I meant to post it as soon as we were done, but it got buried under too many other posts and drafts. The original post follows, without edits for temporal accuracy.
You can do it The Right Way and use SNI if:
Otherwise, you have to try a bit harder.
You can do it The Right Way and use SNI if:
- You don't care about Internet Explorer (7 and 8) on Windows XP.
- You have Apache 2.2.12 or newer.
- You have openssl 0.9.8f or newer with TLS extensions; extensions are included by default in 1.0.
Otherwise, you have to try a bit harder.
Tuesday, October 23, 2012
Labels
I figured out my underlying problem with Yegge's liberal/conservative (libertarian/authoritarian) division of programming cultures.
People like looking down on those considered inferior. "Conservative" adds another way to do just that.
People like looking down on those considered inferior. "Conservative" adds another way to do just that.
Tuesday, October 2, 2012
Compile Time
You might have heard that in Lisp, the whole language is there all the time. You can read while compiling, eval while reading, and so on. This isn't necessarily exclusive to Lisp—Perl offers BEGIN/CHECK/UNITCHECK—but it isn't exactly common in mainstream languages.
At first, it sounds brilliant. "I can use my whole language to {read the configuration | filter some code on-the-fly | whatever} for super fast run-time performance!" But there's a consequence that nobody seems to realize until they've gone far down that path: if you have a compile-test switch like
This is almost a trivial statement: compile testing has to compile the code; you're running code at compile time; ergo, your compile-time code will run. But beware of the details:
At first, it sounds brilliant. "I can use my whole language to {read the configuration | filter some code on-the-fly | whatever} for super fast run-time performance!" But there's a consequence that nobody seems to realize until they've gone far down that path: if you have a compile-test switch like
perl -c
, you can no longer guarantee that using it is safe if you wrote code that runs during compilation.This is almost a trivial statement: compile testing has to compile the code; you're running code at compile time; ergo, your compile-time code will run. But beware of the details:
- If you read your configuration files and exit if something's wrong, then you must now have a valid configuration to run a compile test.
- Generalizing the previous: if you pull anything from an external service, your compile test depends on that service being up. It may also depend on having your credentials for that service available.
- If you do a ton of work to prepare a cache for runtime, you have to wait for that—then the compile test finishes and throws it all away.
- If you have an infinite loop in compile-time code, the compilation test never completes. Not a problem for a human at the keyboard, but could be difficult in a script (e.g. VCS commit hooks).
- If the language allows you to define reader macros or source filters at compile time, then you can't even syntax-check the source without running the compile-time code; the lex phase now depends on the execution state that accumulates during compilation.
- If your code assumes the underlying platform is Unix because that's what the server is, you can't compile test on Windows. Or, you have to write your whole compile phase cross-platform.
Subscribe to:
Posts (Atom)