|By Derek Ferguson||
|August 10, 2004 12:00 AM EDT||
.NETDJ: What is your official title and department?
Don Box: I am an architect in the Distributed Systems Group. I am responsible for the protocols and the plumbing that we do in that group. I'm on an architecture team, so the responsibility is distributed, but basically five other architects and I work on the WS-* protocols, Indigo, and the stuff that leads up to Indigo, such as work on ASMX and Web Services Enhancements (WSE).
.NETDJ: How did you get started in computer technologies?
DB: I started programming in 1983 as an undergraduate math student. After that, I went to graduate school, then started a company and had a ton of fun in the 1990s doing COM. In 2001, I decided to get a real job so I came to Microsoft. At the ripe old age of 39, I had my first HR review (where I was on the receiving side). It was pretty wild, actually.
.NETDJ: Tell us about founding your company.
DB: Let's see - a good friend of mine, Andrew Harrison, was teaching at University of California (UC) Irvine Extension. He was the TA in all of the hardest theory classes and the smartest guy I knew at UC Irvine. Andrew made teaching seem both easy and fun, so I talked to him about it and we wrote a class together. After teaching it at Oregon Graduate Institute (OGI), I said "Wow - this is a very easy and fun way to make money, so maybe I'll start a company." And then I brought in my grad student cronies and the rest is history.
.NETDJ: What was your first class?
DB: Essential Windows was our first class in 1994. In that same year, I wrote the Essential COM class. August 8 was the first day I delivered that class. I remember it vividly because that was the day I figured out COM. Prior to that, I was able to make things work and I knew a lot of facts, but I had no insight and no intuitive understanding. In August, I was in Oregon teaching my first Essential COM class to a packed room of 24 people. It was in the first lecture that I made the connection between dynamic_cast and QueryInterface and that was when it all became obvious.
I taught COM for a good two years before I seriously entertained writing a book, and then it took two years to write.
.NETDJ: That book, Essential COM (Addison-Wesley), was released in 1998, then. Can you tell us about writing that book?
DB: When I tried to figure COM out, there was nothing to guide me. There was a Brockshmidt book that was decent and the Dale Rogersson book - which is a very "how" oriented book, but nothing really ever spoke to me as to what the real principles were. I figured it out in 1994 and traveled the world telling the story with Chris Sells, Tim Ewald, and Keith Brown. Over time, the story crystallized and the book spoke to people.
.NETDJ: What about David Chappell's book on COM - wasn't that out then?
DB: Chappell's book came out a little before mine, although mine was already "in the can" when his book was done. I remember he sent me a copy from the first batch and he put a note in it that there wasn't one line of code in the whole book. While his book was excellent and I recommend it as the prerequisite to reading my book, it doesn't help you really to understand it from a programmer's view. For most software engineers, it won't directly answer the question, "How does COM relate to me?" Even though I'm an architect and I do think about very broad issues, at the end of the day someone has to write a program and I'm fortunate to stay grounded at that level - even though I'm in my advanced years with a high falutin' title.
.NETDJ: Tell us about your first experiences with Web services? How did you come to be involved in the standardization of SOAP?
DB: Back in 1995, Microsoft wanted to see Distributed COM (DCOM) everywhere. They had contracted with Software AG to do COM on Unix - and Microsoft recommended that they get me to help them. I worked in Germany for a while and we basically did it by emulating NT on Unix and because of that, it wasn't a smashing success. Microsoft had hoped that that would be the big thing that brought everyone together, but the engineering didn't work out.
In 1997, Bob Atkinson and Mohsen Al Goshein of Microsoft had decided to go off and try RPC using XML. Dave Reed, the general manager of COM at the time, said that they should get me because I know platforms and so they brought me and Dave Winer to Microsoft to write the first SOAP specification in March of 1998. We wrote it in two days. The three of us worked on the first SOAP specification and within a couple of weeks we had Interop working between COM and Java.
.NETDJ: Tell us about leaving DevelopMentor to go to Microsoft.
DB: Keith Brown, Chris Sells, and I were visiting Microsoft. Someone wanted us to meet with someone who was working on Web services in late 2001. All the .NET stuff was in late beta at that point, but we'd already published the SOAP specification and I knew how the Web services stuff all worked. I met with Mark Lucovsky and Mark Burner from the Hailstorm team and I also met with Robert Wahbe, John Shewchuk, and Andrew Layman of the Indigo team.
I had some very interesting conversations with the Hailstorm guys, but there was something about what the Indigo folks were working on - basically that they were going to take the idea of XML-based messaging and make it as ubiquitous as possible. I asked them how widespread they were going to make it and they said, "How far do you want to go?" That was the moment when I decided.
At that point in time, I was in the process of trying to separate myself from my then-partner at Develop Mentor and was trying to figure out what the next decade of my life would look like. When I saw Indigo, I knew I had found my new tribe, so things got remarkably clear after that. There was a Microsoft Professional Developers Conference (PDC) shortly after that and I sat down with Eric Rudder in Los Angeles and I came up and interviewed with the folks on the Indigo team and that was it. We loaded up the truck and moved to Bellevue (Washington, that is).
.NETDJ: I'm perfectly happy using ASMX for Web services - why should I care about Indigo?
DB: ASMX is the closest to "the truth" of all our shipping technologies for distributed computing. If you are doing service-oriented programming, ASMX is the easiest to use and the most likely to keep you on the straight and narrow. You have to work harder to do the wrong thing. .NET remoting is more unbounded and happily allows you to do both right and wrong things with equal ease.
There is nothing wrong with ASMX. It has some limitations. One of the limitations is that the current implementation is bound to ASP.NET and pragmatically, that means it is really about working over HTTP. It can work over other transports, but there is no easy way to do that...some assembly is required. So, as people want to use other transports, ASMX won't be enough.
ASMX also has a very coarse-grained extensibility model. SOAP Extensions allow you to replace pieces of the plumbing, but only with a very coarse-grained tool. If I want to see the actual bits as they go in or come out, or the stack frame, there are integration points exposed for this. However, if I want to see the intermediate XML, I have a lot of work to do. For example, Web Services Enhancements (WSE), has to do some fairly obscure back-flips in order to fit into this model and to do XML-based processing. The ASMX/WSE user doesn't see this, but it's definitely more work for us than it should have been.
.NETDJ: So, how will Indigo be better than WSE 2.0?
DB: WSE 2.0 brings end-to-end security to the current ASMX code base, but it has to do some rather "interesting" engineering to make that happen. Since we built Indigo from the ground up with XML messaging as "the thing" it is a lot easier to plumb.
There are a lot of implementation choices in ASMX we wouldn't make again. For example, there is a high reliance on code generation under ASMX. If you look at Indigo, we don't do code generation - we let the runtime do stack-to-message translations.
Indigo will still support the [WebMethod] attribute and friends if developers want to use the old names. There is a compatibility namespace so that the right namespaces are in scope and we will support most of the current attributes out of the box. If you want to think of Indigo as just a new implementation of the Web services plumbing, go ahead - there is a class of developers who will just do this.
.NETDJ: So, is Indigo mainly for SOA, then?
DB: It is very obvious how to do service-oriented development with ASMX - you don't need Indigo for that. What Indigo enables is if you want to do more advanced messaging - such as rich support for intermediaries and end-to-end security. Indigo is a great solution if you want integration with our transactional plumbing.
.NETDJ: I happened to see you performing with Band on the Runtime at the PDC last October (2003) in Los Angeles. What can you tell us about that?
DB: Ted Pattison, David Chappell ,and I are all friends and David had suggested playing music together in the past, as had Ted. We did a conference in San Francisco where we said, "Let's do some Filk" - which is the art of taking popular songs and rewriting the lyrics to be about something else. Any time the three of us would be at a conference together, we'd try to put the band together and play a gig.
.NETDJ: I especially liked your song Miguel - a Filk version of the Beatles' Michelle about Ximian's Miguel de Icaza, no?
DB: Yes it is. The song was really a recruiting tune, as I think Miguel should work at Microsoft. He's got a lot of energy and a lot of creativity, and I think he would have an excellent time working at "the Firm." I think it would be good for him and good for us.
.NETDJ: While we're on the topic of music, Jeff Richter told us a few months ago that you are a Progressive Rock fan. Who are your favorite artists?
DB: Jeff and I went to see King Crimson last time they were in Seattle. Jeff is much more fanatical about it than I am. I like the stuff - I have a lot of CDs and had a lot of vinyl back in the day, but Jeff is...I don't know anyone as fanatical about a kind of music as Jeff!
.NETDJ: What are your thoughts on Tech Ed this year?
DB: I've been giving my talks. I had an extremely fun time giving the devices talk. Those guys have some fun technology that I like to play with. And I got to show my COM underwear on the wolf vision projector.
.NETDJ: Yes, I saw that! Where, exactly, does one even buy COM underwear?
DB: COM underwear is a collector's item. We probably made several thousand pairs back in the day and I peeled 14 off one of the shipments to take home. For a while, that was the only underwear I wore. For years of my life I always was wearing COM underwear. Now I only wear it on special occasions. For example, I am not wearing COM underwear right now.
.NETDJ: Have you ever been mistaken for Jon Box (NETDJ's Mobility Editor)?
DB: The first time that ever happened was at Tech Ed this year. I went to register and they wanted to give me Jon Box's badge. I'm sure David Chappell was really pissed off when that guy from the J2EE world started using his name - at least Jon Box is on my side of the fence!
.NETDJ: Tell us about Essential .NET.
DB: So, I wrote Essential .NET, Volume I: The Common Language Runtime (Addison-Wesley, 2003) about the CLR and I tried to do what I did with Essential COM, which was to answer the questions that I had. It was to answer the questions about why .NET is the way that it is. I'm not very good at writing tutorials - but I'm pretty good at figuring out design motivations. As I get older, I have more historical context. I can see the echoes of old things in new things.
.NETDJ: What path would you recommend for someone with a background in non-native platforms such as Visual Basic or Java, who wants to learn .NET internals?
DB: I think the best preparation is to write code - a good programmer will inevitably ask, "Why is it this way?" The book is really an exploration of how .NET is designed and why. If you are a person who benefits from that kind of analysis, it will benefit you. If you aren't, then my stuff is just esoteric ravings.
.NETDJ: What is your order of preference between speaking, coding, and writing?
DB: I like to write, then code, and then speak. Of all the things I can do, writing is the one that gives me the best catharsis. For me at least, writing starts with a story inside of me that I need to get out and then propagate it efficiently. There is nothing like writing!
Finishing a writing project gives you a feeling like having a baby. It's like, "Finally, this thing is outside of my body!" but - unlike a baby - a book doesn't need to be changed or breastfed. You get a sense of release when you get done writing something.
Coding is what I do to understand. I find that coding is an exercise in self-education - that's how I get my ideas.
I also get ideas through speaking, but speaking is just what one does everyday. I'm speaking right now...whether I do this in front of 1000, 5000, or 3 people doesn't matter. Some people are listening and some people aren't, but speaking is as natural to me as eating. Actually, I like eating better!
.NETDJ: Who do you most like to hear speaking about development nowadays?
DB: I love listening to David Chappell - I just think he is great. I also like listening to Ted Pattison - he is a great guy. Pat Helland is wonderful to listen to. That is my short list, I think.
.NETDJ: What do you make of the recent warming of relations between Microsoft, Sun, and Oracle?
DB: We all share the same customers and our customers want our stuff to work together. The whole premise of doing this kind of integration is all about making our stuff work with everyone else's - realizing that we can't get NT running on every box. People are nice enough to invite us into their datacenters, and interop is just good manners. Our customers are going to have non-Microsoft systems and we want to make sure that we are good guests.
.NETDJ: What are your thoughts on global outsourcing?
DB: (Thoughtful pause)...Can't ignore it! It is very real. Developers should perceive outsourcing as an opportunity. What choice do we have? Seeing it as a threat doesn't buy you anything - you have nothing to gain from that. A much more interesting approach is to say, "How can I take the fact that I have less expensive labor and harness it to my benefit?"
.NETDJ: Do you hold any software certifications - MCP, MCAD, MCSD, etc.? Why or why not?
DB: I have an MS in computer science. Why do I have that? Because I was in grad school for a very long time and they give you a Masters somewhere along the way to a PhD. Beyond that, I just never had a need for certification.
.NETDJ: You talked about the failure of Java and the illusion of choice during your general session at Tech Ed yesterday? Could you elaborate on that topic a little more?
DB: I've had a really lucky life. The DCOM experience was very illustrative...the notion that we could get OLE32 to run on every machine on the planet. The plan was to take the COM runtime and make that run on every computing device on the planet and that was going to be the way we got reach. That was just utter folly. It ignored the fact that not only do people have lots of investments that they hold dear for good reasons, but that there are all kinds of cultural differences. There are all kinds of different programmers and it is crazy to think that everyone is going to want to program the same way, which is what OLE32 imposed on the programmer. The practice of COM assumed that the entire programming universe will have the same kind of aesthetic.
We learned such a lesson with DCOM that now, with Web services, we are just saying, "Everyone programs in something different, so let's just do protocol-based integration, where we will just agree on the format of the messages we are going to exchange over the wire." We came to that realization in 1997, when Sun was full steam into that Java thing, which was very similar to the experience we had had with OLE32. They were even more intrusive than us because they had a runtime and a language, and to think that everyone in the world wants to use the same programming language is just naïve.
I can say this because I had exactly that belief when I was sitting in the cold parts of Germany porting DCOM to Unix and I saw what happened. I think the Java community has come around and realized that they are also guests in any given datacenter and that protocol-based integration is where it is at. I'm happy to see all of the Java vendors signing up to do XML-based messaging with the rest of us.
.NETDJ: What was your worst-ever moment on stage and how did you handle it?
DB: I have two experiences that stick out - one was the talk on Monday morning...I can't remember ever giving a talk and being that sick. I am in the middle of one of the most hellacious flus I have ever had and I know that I didn't do my best.
The other time, I had to sub for someone to teach an MFC class very early in the history of my teaching career and I just didn't care. I had no real passion for it and while I understood it and knew it, I didn't care about it and it was just utter torture for me. And so what I've really figured out from that was that I have to have skin in the game. If I'm going to talk, I really have to have an investment. So I started doing stunts so I would feel emotionally invested.
.NETDJ: What kind of stunts?
DB: I once gave a talk wearing only a speaker shirt, and then took that speaker shirt off in a room of 3000-4000 people...that was my first real stunt. I had toyed with things before, like to illustrate how apartments worked, I had people in the audience come up and hug and then I took it further to see if I could get people to kiss! I really want people to have an experience when they come to one of my talks. I want there to be something memorable. I started with that, then I did a couple of various stages of undress, with bathtubs and dancers.
If you Google me, you can find the bathtub images.
.NETDJ: What technologies coming out of Microsoft - besides Indigo - do you find most exciting?
DB: I love the devices stuff - that stuff is just so amazing. I am also having a wonderful time working with the new C# language features - it is very hard to go back. I had fallen in love with Standard ML and functional programming in general. When we started getting drops of the new C# compiler and between anonymous methods, iterators, and parameterized types, things felt exceedingly familiar.
.NETDJ: If you had to do your whole career over again thus far, what would you do differently?
DB: I wish I would have finished my PhD. I also would have paid more attention in the early years to the business side of DevelopMentor. I naively had the attitude that I could trust someone else to lead and run my company while I focused 100% on technology. I don't plan to ever make that mistake again. Lesson learned.
.NETDJ: What are your career goals at this point?
DB: To ship Indigo. After that, I'm confident the future will present itself - it always has in the past.
SYS-CON Events announced today that 24Notion has been named “Bronze Sponsor” of SYS-CON's 18th Cloud Expo, which will take place on June 7-9, 2016, at the Javits Center in New York, New York. 24Notion is full-service global creative digital marketing, technology and lifestyle agency that combines strategic ideas with customized tactical execution. With a broad understand of the art of traditional marketing, new media, communications and social influence, 24Notion uniquely understands how to con...
May. 24, 2016 09:30 AM EDT Reads: 1,659
The essence of data analysis involves setting up data pipelines that consist of several operations that are chained together – starting from data collection, data quality checks, data integration, data analysis and data visualization (including the setting up of interaction paths in that visualization). In our opinion, the challenges stem from the technology diversity at each stage of the data pipeline as well as the lack of process around the analysis.
May. 24, 2016 09:15 AM EDT Reads: 752
The demand for organizations to expand their infrastructure to multiple IT environments like the cloud, on-premise, mobile, bring your own device (BYOD) and the Internet of Things (IoT) continues to grow. As this hybrid infrastructure increases, the challenge to monitor the security of these systems increases in volume and complexity. In his session at 18th Cloud Expo, Stephen Coty, Chief Security Evangelist at Alert Logic, will show how properly configured and managed security architecture can...
May. 24, 2016 09:00 AM EDT Reads: 1,920
What a difference a year makes. Organizations aren’t just talking about IoT possibilities, it is now baked into their core business strategy. With IoT, billions of devices generating data from different companies on different networks around the globe need to interact. From efficiency to better customer insights to completely new business models, IoT will turn traditional business models upside down. In the new customer-centric age, the key to success is delivering critical services and apps wit...
May. 24, 2016 08:30 AM EDT Reads: 492
When it comes to IoT in the enterprise, namely the commercial building and hospitality markets, a benefit not getting the attention it deserves is energy efficiency, and IoT's direct impact on a cleaner, greener environment when installed in smart buildings. Until now clean technology was offered piecemeal and led with point solutions that require significant systems integration to orchestrate and deploy. There didn't exist a 'top down' approach that can manage and monitor the way a Smart Buildi...
May. 24, 2016 08:30 AM EDT Reads: 2,018
SYS-CON Events announced today BZ Media LLC has been named “Media Sponsor” of SYS-CON's 19th International Cloud Expo, which will take place on November 1–3, 2016, at the Santa Clara Convention Center in Santa Clara, CA. BZ Media LLC is a high-tech media company that produces technical conferences and expositions, and publishes a magazine, newsletters and websites in the software development, SharePoint, mobile development and Commercial Drone markets.
May. 24, 2016 06:00 AM EDT Reads: 3,363
WebRTC is bringing significant change to the communications landscape that will bridge the worlds of web and telephony, making the Internet the new standard for communications. Cloud9 took the road less traveled and used WebRTC to create a downloadable enterprise-grade communications platform that is changing the communication dynamic in the financial sector. In his session at @ThingsExpo, Leo Papadopoulos, CTO of Cloud9, will discuss the importance of WebRTC and how it enables companies to fo...
May. 24, 2016 04:30 AM EDT Reads: 2,375
SYS-CON Events announced today TechTarget has been named “Media Sponsor” of SYS-CON's 18th International Cloud Expo, which will take place on June 7–9, 2016, at the Javits Center in New York City, NY, and the 19th International Cloud Expo, which will take place on November 1–3, 2016, at the Santa Clara Convention Center in Santa Clara, CA. TechTarget is the Web’s leading destination for serious technology buyers researching and making enterprise technology decisions. Its extensive global networ...
May. 24, 2016 04:00 AM EDT Reads: 2,993
With major technology companies and startups seriously embracing IoT strategies, now is the perfect time to attend @ThingsExpo 2016 in New York and Silicon Valley. Learn what is going on, contribute to the discussions, and ensure that your enterprise is as "IoT-Ready" as it can be! Internet of @ThingsExpo, taking place Nov 3-5, 2015, at the Santa Clara Convention Center in Santa Clara, CA, is co-located with 17th Cloud Expo and will feature technical sessions from a rock star conference faculty ...
May. 23, 2016 05:00 PM EDT Reads: 4,606
The 19th International Cloud Expo has announced that its Call for Papers is open. Cloud Expo, to be held November 1-3, 2016, at the Santa Clara Convention Center in Santa Clara, CA, brings together Cloud Computing, Big Data, Internet of Things, DevOps, Containers, Microservices and WebRTC to one location. With cloud computing driving a higher percentage of enterprise IT budgets every year, it becomes increasingly important to plant your flag in this fast-expanding business opportunity. Submit y...
May. 23, 2016 04:00 PM EDT Reads: 1,813
Internet of @ThingsExpo, taking place November 1-3, 2016, at the Santa Clara Convention Center in Santa Clara, CA, is co-located with the 19th International Cloud Expo and will feature technical sessions from a rock star conference faculty and the leading industry players in the world and ThingsExpo New York Call for Papers is now open.
May. 23, 2016 03:00 PM EDT Reads: 1,656
SYS-CON Events announced today that ContentMX, the marketing technology and services company with a singular mission to increase engagement and drive more conversations for enterprise, channel and SMB technology marketers, has been named “Sponsor & Exhibitor Lounge Sponsor” of SYS-CON's 18th Cloud Expo, which will take place on June 7-9, 2016, at the Javits Center in New York City, New York. “CloudExpo is a great opportunity to start a conversation with new prospects, but what happens after the...
May. 23, 2016 03:00 PM EDT Reads: 604
In his keynote at 18th Cloud Expo, Andrew Keys, Co-Founder of ConsenSys Enterprise, will provide an overview of the evolution of the Internet and the Database and the future of their combination – the Blockchain. Andrew Keys is Co-Founder of ConsenSys Enterprise. He comes to ConsenSys Enterprise with capital markets, technology and entrepreneurial experience. Previously, he worked for UBS investment bank in equities analysis. Later, he was responsible for the creation and distribution of life ...
May. 23, 2016 02:30 PM EDT Reads: 1,693
There are several IoTs: the Industrial Internet, Consumer Wearables, Wearables and Healthcare, Supply Chains, and the movement toward Smart Grids, Cities, Regions, and Nations. There are competing communications standards every step of the way, a bewildering array of sensors and devices, and an entire world of competing data analytics platforms. To some this appears to be chaos. In this power panel at @ThingsExpo, moderated by Conference Chair Roger Strukhoff, panelists will discuss the vast to...
May. 23, 2016 02:00 PM EDT Reads: 2,332
SYS-CON Events announced today that Enzu, a leading provider of cloud hosting solutions, will exhibit at SYS-CON's 18th International Cloud Expo®, which will take place on June 7-9, 2016, at the Javits Center in New York City, NY. Enzu’s mission is to be the leading provider of enterprise cloud solutions worldwide. Enzu enables online businesses to use its IT infrastructure to their competitive advantage. By offering a suite of proven hosting and management services, Enzu wants companies to foc...
May. 23, 2016 01:45 PM EDT Reads: 2,053
Customer experience has become a competitive differentiator for companies, and it’s imperative that brands seamlessly connect the customer journey across all platforms. With the continued explosion of IoT, join us for a look at how to build a winning digital foundation in the connected era – today and in the future. In his session at @ThingsExpo, Chris Nguyen, Group Product Marketing Manager at Adobe, will discuss how to successfully leverage mobile, rapidly deploy content, capture real-time d...
May. 23, 2016 12:45 PM EDT Reads: 1,323
A strange thing is happening along the way to the Internet of Things, namely far too many devices to work with and manage. It has become clear that we'll need much higher efficiency user experiences that can allow us to more easily and scalably work with the thousands of devices that will soon be in each of our lives. Enter the conversational interface revolution, combining bots we can literally talk with, gesture to, and even direct with our thoughts, with embedded artificial intelligence, wh...
May. 23, 2016 12:30 PM EDT Reads: 1,787
IoT generates lots of temporal data. But how do you unlock its value? How do you coordinate the diverse moving parts that must come together when developing your IoT product? What are the key challenges addressed by Data as a Service? How does cloud computing underlie and connect the notions of Digital and DevOps What is the impact of the API economy? What is the business imperative for Cognitive Computing? Get all these questions and hundreds more like them answered at the 18th Cloud Expo...
May. 23, 2016 12:30 PM EDT Reads: 2,027
Whether your IoT service is connecting cars, homes, appliances, wearable, cameras or other devices, one question hangs in the balance – how do you actually make money from this service? The ability to turn your IoT service into profit requires the ability to create a monetization strategy that is flexible, scalable and working for you in real-time. It must be a transparent, smoothly implemented strategy that all stakeholders – from customers to the board – will be able to understand and comprehe...
May. 23, 2016 08:15 AM EDT Reads: 2,371
Korean Broadcasting System (KBS) will feature the upcoming 18th Cloud Expo | @ThingsExpo in a New York news documentary about the "New IT for the Future." The documentary will cover how big companies are transmitting or adopting the new IT for the future and will be filmed on the expo floor between June 7-June 9, 2016, at the Javits Center in New York City, New York. KBS has long been a leader in the development of the broadcasting culture of Korea. As the key public service broadcaster of Korea...
May. 23, 2016 03:45 AM EDT Reads: 1,668