|By Jason Bloomberg||
|June 16, 2014 09:45 AM EDT||
My five months with EnterpriseWeb have run their course, and I’m returning to the world of advisory, analysis, and architecture training with my new company, Intellyx, and this, the inaugural issue of our Cortex newsletter. After a dozen years with ZapThink, doing my best to help organizations around the globe get architecture right, you might wonder why I took a detour as Chief Evangelist for a vendor. The answer: EnterpriseWeb has brought technology to market that can upend the entire Agile Architecture discussion. They have set the bar for what it means to build a platform that can enable organizations to achieve the elusive business agility benefits that SOA promised but never delivered. And if a five-person company out of upstate New York can do that, then anybody can.
As of today I return full time to being a chief evangelist for the style of Enterprise Architecture I refer to as Agile Architecture in my book, The Agile Architecture Revolution. In that book I talk about REST-Based SOA, Cloud Computing, mobile technologies, and a host of other modern enterprise technology trends that are shaking up IT departments as they try to get a handle on the business value such technologies promise. And yet, I’ll be the first to admit that the book didn’t go far enough. You could take every word I wrote to heart and still not know how to architect agility in your organization. There were pieces missing from the story – and all these missing elements centered on the fundamental challenge of distributed computing.
The central challenge of distributed computing, of course, is how to get your various distributed bits to communicate with each other properly. Since those distributed components are typically heterogeneous, we must somehow come up with a common means of establishing interaction among components everybody can agree on. Yet, once we do that, we’ve necessarily compromised on flexibility, because changing how our components interact is a difficult, complex endeavor. Agile Architecture must solve this problem.
This problem pervades the entire history of APIs, from remote procedure calls to Web Services to RESTful APIs and everything in between. We must somehow contract interfaces in order to abstract the underlying functionality, thus providing loose coupling and with it, some measure of flexibility within the underlying code. Yet the very act of introducing such contracts (including REST’s uniform interface) is a compromise, since the interface itself now lacks flexibility. Basically, we look at the world of distributed computing and convince ourselves that the only way to get this stuff to work at all is to give up agility. The end result? Instead of being an enabler of business agility, enterprise IT is now cast in the role of limiter of business agility.
The central technical challenge for Agile Architecture, therefore, is how to achieve functionality and performance without having to trade off flexibility. This central compromise of distributed computing is the nut that EnterpriseWeb has been able to crack by adding an additional layer of abstraction over the entire distributed environment, coupled with an agent-oriented runtime engine that resolves abstracted references dynamically in real time. The bottom line: at least one vendor in the marketplace has shown that it is possible to deliver on the promise of Agile Architecture. And if one can, so can others.
The Four Central Patterns of Agile Architecture
Now it’s time for me to take off my EnterpriseWeb hat and put it in a drawer. In its place goes the Intellyx hat, blue brain and all. After all, the point of this article isn’t to talk about what a single vendor has accomplished. Rather, my goal is to lay out the essential patterns of Agile Architecture that heretofore have been difficult or impossible to implement in practice.
The context for these central patterns of Agile Architecture is the concept of architecting at the “meta” level I discuss in my book – the higher level of abstraction that EnterpriseWeb has been able to implement. At this meta level, there are four central patterns of Agile Architecture that are essential to resolving the fundamental compromise of distributed computing:
Dynamic Coupling. Tightly coupled interfaces require detailed knowledge of both sides of a distributed computing interaction, and any change on one side might break the other. Contracted interfaces introduce loose coupling, implementing an abstraction that separates interface from implementation, thus allowing changes to the implementation, but at the expense of a static interface. With dynamic coupling, interface differences are resolved dynamically at run time. The underlying integration engine must be able to find all relevant metadata and resolve any interaction issues in real time in order to allow the metadata to change from one request to the next.
Dynamic Schemas. Neither the WSDL files that specify Web Services, nor the URIs, HTTP verbs, and Internet Media Types that specify RESTful APIs adequately contract the message semantics for any interaction. As a result, metadata describing such semantics are scattered about in XML schemas or Custom Media Types or other arbitrary places, leading to the reintroduction of tight coupling and inflexibility. Dynamic schemas abstract all such semantic metadata in a consistent way, relying once again upon the integration engine to resolve these dynamic schemas for each interaction at run time.
Extreme Late Binding. Remember the original promise of SOA registries and the ungainly UDDI standard? The idea was that a Service consumer could automatically look up a Web Service at run time, and based upon the WSDL file it found as a result, bind to the newly discovered service in real time, potentially choosing a different Web Service for each interaction. Unfortunately, Web Services rarely if ever worked this way. Registries ended up doing little more than resolving endpoint references at run time, similar to the way DNS resolves domain names – in other words, they provided late binding. Such late binding adds some flexibility to an interaction, but typically at the expense of performance. Today, however, dynamic coupling and dynamic schemas enable any client to discover at run time all the metadata it requires to interact with any endpoint, without sacrificing performance – what I call extreme late binding.
- Dynamic Constraint Satisfaction. The publication of Services at design time for later discovery shifted SOA’s focus from integration to governance. How are you going to manage all the Services in your directory – let alone actually reuse any of them – unless you are able to create and enforce policies across your organization for how to do so properly? Yes, SOA management tools (helpfully renamed API management tools for the 2010s) provide some measure of API governance, but typically constrained to the technical context of software interactions. However, ask a business stakeholder what governance means to them, and you’ll get an entirely different context for the word. While some policies are technical in nature and apply narrowly to specific APIs or applications, others are more business-centric and apply broadly across departments or even entire organizations. To enforce the full breadth of such policies properly, your run time environment must essentially solve for the combination of all applicable policies dynamically at run time across the entire application environment – a classic dynamic constraint satisfaction problem.
If you believe any of these patterns is nothing more than an old pattern warmed over with a new name, you may be missing something important. True, each of these patterns builds upon patterns that came before, but they all advance the discussion of Agile Architecture to a new level. On the other hand, if you think any of the above patterns are too difficult to implement – if it sounds like you need some kind of magic wand to make this vision work – then I’m here to tell you, I’ve seen a platform that can implement all four patterns, and furthermore, can do so without sacrificing performance. Thus we know they are possible. The question now is, why isn’t everyone doing them?
You may, however, believe that you’re actually implementing some or all of these patterns, either as an architect or as a vendor whose product supports such patterns for your customers. If so, I want to hear from you. Intellyx wants to tell your story.
The Intellyx Take
The Agile Architecture bar is set. Vendors should know what their products must do. Architects have some insight into the patterns they must follow. And business stakeholders can finally rest assured that at least it’s possible to achieve technology-enabled business agility. True, it’s difficult. Many of the pieces are only just now falling into place. Levels of maturity are low across the board. But we’re on our way.
I’m looking forward to helping organizations like yours by leading the Agile Architecture story. I hope to see you in one of my all-new Bloomberg Agile Architecture courses, the sequel to my popular Licensed ZapThink Architect course, coming to Seattle, Dubai, Sydney, Washington DC, and London in the next few months. Or perhaps I can present a keynote at your corporate event or conference, or if you’re a vendor or service provider, consider an Intellyx unlimited advisory subscription or participating in our upcoming Agile Architecture Vendor Landscape Report. You can also join our LinkedIn group or subscribe to the Cortex newsletter. And don’t forget to see me speak on Breaking Down Enterprise Silos in the Cloud next week at Cloud Expo in New York City, where I’ll be giving away a copy of my book. I’m looking forward to working with you again!
DevOps at Cloud Expo – being held November 1-3, 2016, at the Santa Clara Convention Center in Santa Clara, CA – announces that its Call for Papers is open. Born out of proven success in agile development, cloud computing, and process automation, DevOps is a macro trend you cannot afford to miss. From showcase success stories from early adopters and web-scale businesses, DevOps is expanding to organizations of all sizes, including the world's largest enterprises – and delivering real results. Am...
Aug. 25, 2016 12:15 PM EDT Reads: 3,373
Modern organizations face great challenges as they embrace innovation and integrate new tools and services. They begin to mature and move away from the complacency of maintaining traditional technologies and systems that only solve individual, siloed problems and work “well enough.” In order to build...
Cloud Expo 2016 New York at the Javits Center New York was characterized by increased attendance and a new focus on operations. These were both encouraging signs for all involved in Cloud Computing and all that it touches. As Conference Chair, I work with the Cloud Expo team to structure three keynotes, numerous general sessions, and more than 150 breakout sessions along 10 tracks. Our job is to balance the state of enterprise IT today with the trends that will be commonplace tomorrow. Mobile...
Aug. 25, 2016 11:00 AM EDT Reads: 3,232
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...
Aug. 25, 2016 09:00 AM EDT Reads: 3,866
SYS-CON Events announced today that eCube Systems, a leading provider of middleware modernization, integration, and management solutions, will exhibit at @DevOpsSummit at 19th International Cloud Expo, which will take place on November 1–3, 2016, at the Santa Clara Convention Center in Santa Clara, CA. eCube Systems offers a family of middleware evolution products and services that maximize return on technology investment by leveraging existing technical equity to meet evolving business needs. ...
Aug. 25, 2016 09:00 AM EDT Reads: 479
To leverage Continuous Delivery, enterprises must consider impacts that span functional silos, as well as applications that touch older, slower moving components. Managing the many dependencies can cause slowdowns. See how to achieve continuous delivery in the enterprise.
Aug. 25, 2016 08:15 AM EDT Reads: 1,497
Using new techniques of information modeling, indexing, and processing, new cloud-based systems can support cloud-based workloads previously not possible for high-throughput insurance, banking, and case-based applications. In his session at 18th Cloud Expo, John Newton, CTO, Founder and Chairman of Alfresco, described how to scale cloud-based content management repositories to store, manage, and retrieve billions of documents and related information with fast and linear scalability. He addres...
Aug. 25, 2016 07:15 AM EDT Reads: 1,889
Akana has announced the availability of version 8 of its API Management solution. The Akana Platform provides an end-to-end API Management solution for designing, implementing, securing, managing, monitoring, and publishing APIs. It is available as a SaaS platform, on-premises, and as a hybrid deployment. Version 8 introduces a lot of new functionality, all aimed at offering customers the richest API Management capabilities in a way that is easier than ever for API and app developers to use.
Aug. 25, 2016 06:00 AM EDT Reads: 1,427
SYS-CON Events announced today that Isomorphic Software will exhibit at DevOps Summit at 19th International Cloud Expo, which will take place on November 1–3, 2016, at the Santa Clara Convention Center in Santa Clara, CA. Isomorphic Software provides the SmartClient HTML5/AJAX platform, the most advanced technology for building rich, cutting-edge enterprise web applications for desktop and mobile. SmartClient combines the productivity and performance of traditional desktop software with the simp...
Aug. 25, 2016 03:30 AM EDT Reads: 2,141
DevOps at Cloud Expo, taking place Nov 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 widespread success of cloud computing is driving the DevOps revolution in enterprise IT. Now as never before, development teams must communicate and collaborate in a dynamic, 24/7/365 environment. There is no time to wait for long dev...
Aug. 25, 2016 02:30 AM EDT Reads: 2,168
The burgeoning trends around DevOps are translating into new types of IT infrastructure that both developers and operators can take advantage of. The next BriefingsDirect Voice of the Customer thought leadership discussion focuses on the burgeoning trends around DevOps and how that’s translating into new types of IT infrastructure that both developers and operators can take advantage of.
Aug. 25, 2016 02:00 AM EDT Reads: 2,424
SYS-CON Events announced today that 910Telecom will exhibit 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. Housed in the classic Denver Gas & Electric Building, 910 15th St., 910Telecom is a carrier-neutral telecom hotel located in the heart of Denver. Adjacent to CenturyLink, AT&T, and Denver Main, 910Telecom offers connectivity to all major carriers, Internet service providers, Internet backbones and ...
Aug. 25, 2016 02:00 AM EDT Reads: 1,796
With so much going on in this space you could be forgiven for thinking you were always working with yesterday’s technologies. So much change, so quickly. What do you do if you have to build a solution from the ground up that is expected to live in the field for at least 5-10 years? This is the challenge we faced when we looked to refresh our existing 10-year-old custom hardware stack to measure the fullness of trash cans and compactors.
Aug. 25, 2016 01:15 AM EDT Reads: 1,623
The emerging Internet of Everything creates tremendous new opportunities for customer engagement and business model innovation. However, enterprises must overcome a number of critical challenges to bring these new solutions to market. In his session at @ThingsExpo, Michael Martin, CTO/CIO at nfrastructure, outlined these key challenges and recommended approaches for overcoming them to achieve speed and agility in the design, development and implementation of Internet of Everything solutions wi...
Aug. 25, 2016 12:45 AM EDT Reads: 1,918
This digest provides an overview of good resources that are well worth reading. We’ll be updating this page as new content becomes available, so I suggest you bookmark it. Also, expect more digests to come on different topics that make all of our IT-hearts go boom!
Aug. 25, 2016 12:45 AM EDT Reads: 4,686
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...
Aug. 25, 2016 12:00 AM EDT Reads: 2,990
Sharding has become a popular means of achieving scalability in application architectures in which read/write data separation is not only possible, but desirable to achieve new heights of concurrency. The premise is that by splitting up read and write duties, it is possible to get better overall performance at the cost of a slight delay in consistency. That is, it takes a bit of time to replicate changes initiated by a "write" to the read-only master database. It's eventually consistent, and it'...
Aug. 24, 2016 11:30 PM EDT Reads: 3,098
Aug. 24, 2016 09:45 PM EDT Reads: 4,810
Thomas Bitman of Gartner wrote a blog post last year about why OpenStack projects fail. In that article, he outlined three particular metrics which together cause 60% of OpenStack projects to fall short of expectations: Wrong people (31% of failures): a successful cloud needs commitment both from the operations team as well as from "anchor" tenants. Wrong processes (19% of failures): a successful cloud automates across silos in the software development lifecycle, not just within silos.
Aug. 24, 2016 08:15 PM EDT Reads: 2,024
There's a lot of things we do to improve the performance of web and mobile applications. We use caching. We use compression. We offload security (SSL and TLS) to a proxy with greater compute capacity. We apply image optimization and minification to content. We do all that because performance is king. Failure to perform can be, for many businesses, equivalent to an outage with increased abandonment rates and angry customers taking to the Internet to express their extreme displeasure.
Aug. 24, 2016 07:45 PM EDT Reads: 2,361