|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.
Connected devices and the industrial internet are growing exponentially every year with Cisco expecting 50 billion devices to be in operation by 2020. In this period of growth, location-based insights are becoming invaluable to many businesses as they adopt new connected technologies. Knowing when and where these devices connect from is critical for a number of scenarios in supply chain management, disaster management, emergency response, M2M, location marketing and more. In his session at @Th...
Jun. 26, 2016 03:00 PM EDT Reads: 909
It is one thing to build single industrial IoT applications, but what will it take to build the Smart Cities and truly society changing applications of the future? The technology won’t be the problem, it will be the number of parties that need to work together and be aligned in their motivation to succeed. In his Day 2 Keynote at @ThingsExpo, Henrik Kenani Dahlgren, Portfolio Marketing Manager at Ericsson, discussed how to plan to cooperate, partner, and form lasting all-star teams to change t...
Jun. 26, 2016 02:00 PM EDT Reads: 1,108
The cloud market growth today is largely in public clouds. While there is a lot of spend in IT departments in virtualization, these aren’t yet translating into a true “cloud” experience within the enterprise. What is stopping the growth of the “private cloud” market? In his general session at 18th Cloud Expo, Nara Rajagopalan, CEO of Accelerite, explored the challenges in deploying, managing, and getting adoption for a private cloud within an enterprise. What are the key differences between wh...
Jun. 26, 2016 01:00 PM EDT Reads: 720
There is little doubt that Big Data solutions will have an increasing role in the Enterprise IT mainstream over time. Big Data at Cloud Expo - to be held November 1-3, 2016, at the Santa Clara Convention Center in Santa Clara, CA - has announced its Call for Papers is open. Cloud computing is being adopted in one form or another by 94% of enterprises today. Tens of billions of new devices are being connected to The Internet of Things. And Big Data is driving this bus. An exponential increase is...
Jun. 26, 2016 12:00 PM EDT Reads: 1,326
In his general session at 18th Cloud Expo, Lee Atchison, Principal Cloud Architect and Advocate at New Relic, discussed cloud as a ‘better data center’ and how it adds new capacity (faster) and improves application availability (redundancy). The cloud is a ‘Dynamic Tool for Dynamic Apps’ and resource allocation is an integral part of your application architecture, so use only the resources you need and allocate /de-allocate resources on the fly.
Jun. 26, 2016 12:00 PM EDT Reads: 1,052
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, Digital Transformation, 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 opportuni...
Jun. 26, 2016 12:00 PM EDT Reads: 1,269
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 Silicon Valley Call for Papers is now open.
Jun. 26, 2016 12:00 PM EDT Reads: 1,095
In his keynote at 18th Cloud Expo, Andrew Keys, Co-Founder of ConsenSys Enterprise, provided 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 sett...
Jun. 26, 2016 11:00 AM EDT Reads: 1,037
Machine Learning helps make complex systems more efficient. By applying advanced Machine Learning techniques such as Cognitive Fingerprinting, wind project operators can utilize these tools to learn from collected data, detect regular patterns, and optimize their own operations. In his session at 18th Cloud Expo, Stuart Gillen, Director of Business Development at SparkCognition, discussed how research has demonstrated the value of Machine Learning in delivering next generation analytics to imp...
Jun. 26, 2016 09:45 AM EDT Reads: 562
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, Bradley Holt, Developer Advocate a...
Jun. 26, 2016 08:45 AM EDT Reads: 706
Cognitive Computing is becoming the foundation for a new generation of solutions that have the potential to transform business. Unlike traditional approaches to building solutions, a cognitive computing approach allows the data to help determine the way applications are designed. This contrasts with conventional software development that begins with defining logic based on the current way a business operates. In her session at 18th Cloud Expo, Judith S. Hurwitz, President and CEO of Hurwitz & ...
Jun. 25, 2016 03:00 PM EDT Reads: 1,562
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...
Jun. 25, 2016 01:45 PM EDT Reads: 901
19th Cloud Expo, taking place November 1-3, 2016, at the Santa Clara Convention Center in Santa Clara, CA, will feature technical sessions from a rock star conference faculty and the leading industry players in the world. Cloud computing is now being embraced by a majority of enterprises of all sizes. Yesterday's debate about public vs. private has transformed into the reality of hybrid cloud: a recent survey shows that 74% of enterprises have a hybrid cloud strategy. Meanwhile, 94% of enterpri...
Jun. 25, 2016 01:15 PM EDT Reads: 1,237
SYS-CON Events announced today that Bsquare has been named “Silver Sponsor” of SYS-CON's @ThingsExpo, which will take place on November 1–3, 2016, at the Santa Clara Convention Center in Santa Clara, CA. For more than two decades, Bsquare has helped its customers extract business value from a broad array of physical assets by making them intelligent, connecting them, and using the data they generate to optimize business processes.
Jun. 25, 2016 11:45 AM EDT Reads: 1,186
Internet of @ThingsExpo, taking place November 1-3, 2016, at the Santa Clara Convention Center in Santa Clara, CA, is co-located with 19th Cloud Expo and will feature technical sessions from a rock star conference faculty and the leading industry players in the world. The Internet of Things (IoT) is the most profound change in personal and enterprise IT since the creation of the Worldwide Web more than 20 years ago. All major researchers estimate there will be tens of billions devices - comp...
Jun. 25, 2016 11:15 AM EDT Reads: 1,211
Cloud computing is being adopted in one form or another by 94% of enterprises today. Tens of billions of new devices are being connected to The Internet of Things. And Big Data is driving this bus. An exponential increase is expected in the amount of information being processed, managed, analyzed, and acted upon by enterprise IT. This amazing is not part of some distant future - it is happening today. One report shows a 650% increase in enterprise data by 2020. Other estimates are even higher....
Jun. 25, 2016 10:15 AM EDT Reads: 1,270
SYS-CON Events announced today that ReadyTalk, a leading provider of online conferencing and webinar services, has been named Vendor Presentation Sponsor at the 19th International Cloud Expo, which will take place on November 1–3, 2016, at the Santa Clara Convention Center in Santa Clara, CA. ReadyTalk delivers audio and web conferencing services that inspire collaboration and enable the Future of Work for today’s increasingly digital and mobile workforce. By combining intuitive, innovative tec...
Jun. 24, 2016 01:00 PM EDT Reads: 1,341
Amazon has gradually rolled out parts of its IoT offerings, but these are just the tip of the iceberg. In addition to optimizing their backend AWS offerings, Amazon is laying the ground work to be a major force in IoT - especially in the connected home and office. In his session at @ThingsExpo, Chris Kocher, founder and managing director of Grey Heron, explained how Amazon is extending its reach to become a major force in IoT by building on its dominant cloud IoT platform, its Dash Button strat...
Jun. 24, 2016 12:00 PM EDT Reads: 1,616
industrial company for a multi-year contract initially valued at over $4.0 million. In addition to DataV software, Bsquare will also provide comprehensive systems integration, support and maintenance services. DataV leverages advanced data analytics, predictive reasoning, data-driven diagnostics, and automated orchestration of remediation actions in order to improve asset uptime while reducing service and warranty costs.
Jun. 22, 2016 11:00 AM EDT Reads: 1,361
Vidyo, Inc., has joined the Alliance for Open Media. The Alliance for Open Media is a non-profit organization working to define and develop media technologies that address the need for an open standard for video compression and delivery over the web. As a member of the Alliance, Vidyo will collaborate with industry leaders in pursuit of an open and royalty-free AOMedia Video codec, AV1. Vidyo’s contributions to the organization will bring to bear its long history of expertise in codec technolo...
Jun. 19, 2016 12:45 PM EDT Reads: 1,257