Pretty much everybody in the developed world (and most of the developing world) interacts with Facebook as an application. Not many people have to actually deal with Facebook from an API level. I’ve spent a few months writing some code that tries to perform a few simple tasks on Facebook, and it’s been rough. Here’s a random collection of things I’ve learned, gotchas, and other points worth noting in the process. As a brief point of reference, most of my interaction with Facebook comes from the server-side code, written in Java, although I’ve played around with Facebook’s JavaScript SDK as well.
- 
Why do people use physical servers again?This post was originally going to be something marveling at how StackExchange only has 25 servers, but could probably run on 5 as well as wondering why nobody else seems to be able to do that, but the more I thought about that, the less convinced I was in that premise. With all the advances in cloud-provided servers, I’m less and less convinced about the need for people to run their own servers exclusively in a physical datacenter. 
- 
Elasticsearch…probably a lot better past the learning curve1 of the last projects I worked on at my previous job involved aggregating, storing, and querying log data into and from Elasticsearch (yes, I know that Logstash does that – and in reality I should have gone that route). That, along with some lookups on the data outside of the code, gave me a chance to start playing with Elasticsearch. After my brief experience with it, I can tell you there’s a lot of power in Elasticsesarch, but it’s going to take you a surprisingly longer to figure out how to tap it than you would expect. (more…) 
- 
Why is everyone so down on long-term planning?I was listening to an old Java Posse episode, when the topic of a 5-year plan came up, only to be immediately be met with disdain and contempt. In fact, nobody took the idea of long-term planning seriously. What I don’t understand is, why? What’s wrong with having a plan beyond the next iteration or 2? Personally, I think with agile development we’ve gotten so used to short development cycles and rapid release and pivots that we’ve completely lost any and all sense of the point of having a long-term plan. The fact is, if you don’t have any type of long-term plan, then your entire business strategy can be summed up as “we’re putting out this fire and hoping for the best.” 
- 
Move fast, break things, fix them (preferrably faster), and then blog about themOn August 1, 2014, Facebook went down. It came back after a few hours or less, but it was a visible reminder of their (now-former) motto of “Move fast and break things.” I made a joke about the issue, but I appreciate the philosophy, even if Facebook’s since tried to move away from it. I think it has a lot to do with their new model of “Move fast with stable infrastructure.” In fact, I think moving fast and breaking things is how they got their stable infrastructure. (more…) 
- 
It’s secret sauce, not nuclear deploymentsA while back, my friend Warren answered somebody’s question on Quora about a name for their startup. Another college friend and I saw this and had some fun with it, but it does bring up an important point that needs to be pointed out – not everything you’re doing is some type of magical secret sauce. 
- 
Coursera’s introductory Scala courseFor the first half of the summer, I took the online Functional Programming Principles in Scala course on Coursera. I should probably point out that I didn’t take the $50 official I’d heard good things about the language, mostly from Dick Wall on Java Posse podcasts, and it seemed like a good way to try functional programming again after a brief, rather unpleasant, introduction to Lisp in college. Overall, my main goals were to a) re-acquaint myself with functional programming and b) get a basic, can-start-on-some-code-now understanding of Scala. 
- 
It’s not the moneyA couple of months ago, Mayday.us launched a big crowdfunding push to raise a crapton of money to form their own Super PAC, meant to fund and support candidates who would run on campaign platforms of reducing the influence of Super PAC money in elections. The overall goal, reduce corruption in federal politics, is a great agenda, but a SuperPAC built around limiting how much money people can spend in elections isn’t actually solving problems with American democracy. (more…) 
- 
A new kind of social network revisitedAfter a lot of thinking a blogging aloud about what I think social networks are and what I think a social network (and social applications) should be, it’s time to revisit my original thoughts about a next-generation social network and see how well they stand up, as well as flesh out just what features a social network should support. After trying to get myself to separate the social network itself from the application people may be using to tap into their particular social networks, I wanted to re-visit how my original app idea and see what features should be moved to the actual network itself. 
- 
Down with 1 social app to rule them all!I wasn’t very happy with where my last post ended. It all boiled down to “I wish Facebook was open source” or “I wish App.net had worked out better”. Part of that was that I spent the whole post operating on the assumption that underneath any application using this social network would be, well, 1 central model that everything would use. I think that assumption may be flawed. What if there wasn’t a central model behind all of these applications, but rather just a single protocol creating multiple models of people we connect to and how.