Welcome to Amsterdam

Posted by Jim Jagielski on Thursday, February 22. 2007 in ASF

Sander and Nick somewhat recently blogged about how we're working on the "next generation" of the Apache web server, code named "amsterdam." My own personal codename for my design concept is "outback" and we'll see why in a bit. To be sure, we are at the very early stages, basically conceptual whiteboarding, if even there, right now. But some things are clear, at least in what major direction Apache will be taking. With 1.2 the big news was HTTP/1.1 compliance; with 1.3 it was Windows compatibility; with 2.0 it was threading; with 2.2 it's proxy, cache and large file improvements. With next-gen, it will be asynchronous, event-based processing... The real advantage of this can best be made clear using an analogy. I like to think of the way Apache works as similar to checking out at a grocery store. As people check out (requests come in), the are handled by a "dedicated" cashier (process or thread). The cashier is busy with that single person, and if more people need to check out, they need to be handled by other cashiers (the store manager, who then calls in extra cashiers, is the Apache parent process). As we all know, the problem occurs when there are more people checking out at the same time, and there aren't enough cashiers around; they queue up or are simply denied. To handle this, the move is more towards a restaurant and waiter-type design format. In this scenario, your "server" doesn't just sit there at your table, dedicated just to you. Instead, they move about, responsible for several diners, taking drink orders here, dessert orders there, delivering food hither and yon. This is much more efficient. Of course, there is a step even further, which some of you may have already guessed upon. There are, after all, times when your waiter is handling a lot of tables, and other waiters are handling almost none; your waiter may not be dedicated to you, but they are dedicated to their "section." The improvement is the way Outback Steakhouse tries to operate, where all waiters kind of do everything, and sometimes a different waiter will take your dinner order as compared to the one who took your drinks, etc. This is the most efficient, but also the trickiest one to pull off in a hybrid (process and thread based) server (the waiter "sections" could be considered process bound, in a way). It's also the source of my design codename: outback. This will be fun, but hard, especially when we want to maintain as much backwards compatibility as possible, as well as allowing the server to be useful on OS's that may lack the network calls (like epoll and kqueue) that make it "straightforward." Add in the current filter design and you can start seeing a lot of work needs to be done. But with serf, we may already have a good foundation to start off with.
More...

Easy to fudge

Posted by Jim Jagielski on Friday, February 9. 2007 in ASF

A few people have expressed... well... "concern" is *way* too strong a word, but maybe "curiosity" is better, regarding the latest Netcraft survey in which Apache has seen a dip and IIS has seen a jump. Make no mistake: chipping away at Apache's lead is something that MS really, really wants to do, even if it's just for the numbers game and the PR aspects. That's why they are throwing money around to several hosting centers "encouraging" them to move their parked domains to IIS. It's also why they try as many tricks as possible to drive the numbers in their direction (hint: when you own a "community" service, it's trivially easy to quickly create thousands of "new sites" that show up on these surveys). Meanwhile, the ASF does *none* of these things. People depend on Apache because they are smart and they know better, not because we're "convincing" them to do so, or doing things to fudge the numbers. Just remember, unless you are running Windows, you *aren't* running IIS. And even then, a lot of really smart people are running Apache on Windows environments as well. So "misleading" numbers also serve another goal: "proving" that Linux/Solaris/BSD/whatever aren't really as popular as people say they are: after all, if a site is IIS, it must be Windows. Of course, this smacks down right in the face of what everyone sees and admits: open source is more popular than ever, and people are either migrating to it or starting off with it. And if someone is using Linux/Solaris/BSD/whatever, then they aren't going to be using IIS; maybe not Apache, but certainly not IIS. What's more interesting to me, in addition to the fact that Apache still has a commanding "lead" (whatever that means), is the fact that people who know, people whose business depend on the web, far and away rely on Apache over IIS. Apache handles much more traffic, by far, than IIS, and the traffic of high-end, "important" sites... Apache is popular because of what it *is* , not because of anything we do to "push it." Update: counter-point
More...

Page 1 of 1, totaling 2 entries

Quicksearch

Search for an entry in IMO:

Did not find what you were looking for? Post a comment for an entry or contact us via email!