You will be redirected in 30 seconds or close now.

ColdFusion Authors: Yakov Fain, Jeremy Geelan, Maureen O'Gara, Nancy Y. Nee, Tad Anderson

Related Topics: ColdFusion

ColdFusion: Article

Compilation and Precompilation in CFMX Templates Part 1

Compilation and Precompilation in CFMX Templates Part 1

Most of you have heard by now that ColdFusion MX templates are compiled into Java. Some may wonder what the big deal is.

Many more of you may be surprised to learn that you can precompile CFMX templates. Do you know why you might want to? And if you've known previously about how to precompile CFMX templates, did you find that trying to do so with code outside the default\coldfusionmx\wwwroot directory (or \inetpub\wwwroot for IIS users) was troublesome?

I've got the solution to that problem as well. First, some background to bring everyone up to speed on the subject of compilation and precompilation in CFMX.

CFMX Templates Are Compiled
One of the great new benefits of ColdFusion MX is that, because it's built on an underlying Java platform, our ColdFusion templates are actually compiled into Java classes. They're not really executables, though, and they're not self-sufficient programs that can run on any Java (or even J2EE) platform, but the compilation takes place nonetheless.

Unlike in Java and many other languages, however, this compilation takes place automatically. Just as with previous releases of ColdFusion, you can create or edit your templates, and ColdFusion simply runs them as soon as they're changed. (Actually, JSP templates in the J2EE world work the same way.)

You needn't really concern yourself with the mechanisms of automatic compilation. It works without your doing anything. So why this article?

The Onetime Cost of Compilation to a User
Each of these features, the automatic compilation and the automatic detection of code changes, is a two-edged sword. There's the cost borne by the first user to execute a page after it's been created or edited. The request for that Web page will be delayed for a few seconds while CFMX compiles the code the first time. Some find this cause for concern.

The benefit of compiling, of course, is that once this "cost" has been paid by the first user to hit the page, each subsequent page hit is very fast; this is a onetime cost and recurs only if the file is later changed. That compiled code is saved and stored on disk (as a .class file that CF knows how to find and execute), and even if the server is restarted, that previously compiled file will be reused by the server to serve that template. There won't be any more waits for compilation until a developer changes the template again. (Well, almost. More about that in Part 2.)

But what if you deploy a large number of newly created or edited templates in your application? Or what if you frequently change them throughout the day? Then the number of automatic compilations grows. Consider the impact on the first users who hit such changed pages, or the first user hitting your multipage site after you've deployed a number of new templates. That first user may suffer delays on every page as he or she traverses through your site. Ouch.

Anyone who has gone through the ColdFusion Administrator for the first time after installing CFMX will understand the experience. At least that code doesn't change again after CFMX is installed. But you may hit a page some days later that no one else has hit yet, and you'll wait for that compilation then.

First-Time Wait Not Entirely New
Actually, the penalty borne by the first user to run a template after it's created or edited isn't exclusive to CFMX. In CF5 and before, CF also "interpreted" any new or changed CF template, saving the resulting p-code to memory in CF's template cache. But since the process was writing to memory rather than disk, it wasn't quite as noticeable.

Then again, because it wasn't saved to disk, this first-time interpretation had to take place whenever the ColdFusion server was restarted. (The template cache will be discussed further in Part 2.) This need to reinterpret templates on restart led many to complain about the need for real compilation of code to disk.

So compilation is good. But is there anything you can do to avoid the wait by the first executing user? Is this just the price to be paid for the power of automatic compilation?

Precompilation: Avoiding First-User Cost
Part of the answer lies in the question itself. We're relying on the automatic compilation that occurs when the first user runs the template after it's created or edited. What if you could somehow tell ColdFusion to perform that compilation manually? Wouldn't it be useful if there were a command you could issue against your template directory to say "compile all those templates"?

Macromedia didn't provide us with that, and there may be very good reasons (put the conspiracy theories on hold - we're talking about the same compilation that takes place automatically, so protecting intellectual property is not what kept them from offering it).

But a simple three-line batch file has been making the rounds of various mailing lists and blogs (mine included, www.cfmxplus.blogspot.com). The initial version of this batch file seemed to give us the apparent silver bullet we've sought for slaying the first-time delay. The problem was, it only worked for code that was in the default webroot if you followed its original instructions.

I present here a version that does work for CFMX code in any directory. I've also reduced it to just two lines. Simply create a file called precompile.bat with the following lines:

set MX_INSTALL=c:\cfusionmx
%MX_INSTALL%\lib\cfusion.jar coldfusion.tools.Compiler
-webroot %1 -webinf %MX_INSTALL%\wwwroot\WEB-INF %1

Just to be clear, there should be two lines in the file: one starting with "set" and one starting with "%MX_INSTALL%".

Replace the first line's c:\cfusionmx value with the location of the CFMX installation. Again, don't worry if your code isn't stored under the wwwroot in that directory. I'll show in a moment that the batch file will accept a parameter that tells it where your code is actually stored, so you can use this over and over to precompile code in different directories.

Save this file as precompile.bat anywhere on your system. Then, from the DOS command prompt, run it from whatever directory you saved the batch file in. If you're not familiar with getting to the DOS command prompt or running .bat files from a specific directory, please seek help from someone with that knowledge.

Now you can execute it, naming the directory whose files (and subdirectories of files) you want to compile, as in:

precompile c:\cfusionmx\wwwroot\mydir


precompile d:\inetpub\wwwroot\somedir


precompile d:\myotherdir

That third example demonstrates the compilation of code that isn't stored in the normal webroot. To learn how to be able to access such a directory using the built-in CFMX Web server, see the entry at my blog site, http://cfmxplus.blogspot.com/2002_08_11_ cfmxplus_archive.html#85347963.

The point is, this version of the batch file will compile any directory of CF templates as long as you specify the complete path to the file (see the next section for other differences between this batch file and the one that was passed around the community a couple of months ago).

Again, note that I said it will compile the files in the named directory and any subdirectories. That's useful if you're expecting it, but annoying if you aren't. I haven't figured out how to keep it from recursing through the subdirectories. If anyone has figured that out, please let me know by e-mail or via the online version of this article at the www.sys-con.com/coldfusion Web site.

If the command is successful, you'll see a display (perhaps a lengthy one) indicating that it's compiling each file, one at a time, and reporting how long it takes. It also reports any syntax errors in the code. Very nifty!

It even repeats the list of errors at the end of the display for easy review. Depending on your operating system, you may be able to scroll up and down in the command window to review the results that have scrolled off the page. Of course, the compiler is smart enough not to try to compile anything other than .cfm and .cfc files.

Note that you could use this to precompile all the files in your entire wwwroot (including subdirectories), using the command:

precompile c:\cfusionmx\wwwroot\

as an example, assuming that's where the default webroot is, or on IIS:

precompile c:\inetpub\wwwroot\

Just be aware that this will also ask it to compile such things as the CFDOCS and CFIDE directories that come installed with CFMX. That's over 2,000 files, not counting your own! Use the tool wisely.

And it may be useful to some to be able to compile just a single file, rather than an entire directory and its subdirectories. You can do that, too, as in:

precompile c:\cfusionmx\wwwroot\myfile.cfm

Finally, I haven't been able to get it to accept a pattern, at least not in this simple two-line version of the batch file.

As an aside, you may wonder if the compiler called by the precompile batch file knows to skip files it's already compiled. It doesn't skip them, but you'll notice that as it reports on each template it finds, the compilation time reported will usually be zero seconds for a file that hasn't changed since the last compile.

Indeed, I've learned from Spike Washburn's blog (thanks to a pointer from Dave Watts) that there's an available "-f" directive to force a compilation of the templates even if they've already been compiled once. One possible use for this is when something seems stuck in the way CF is interpreting a template and you want to force a recompile.

You could modify the script to add a -f argument before the -webroot argument. You could also enable it as a parameter to be passed with a few extra lines of batch file code.

Other Versions of precompile.bat
As I mentioned, the batch file I offer above is slightly different from one that was passed around among beta testers and early users of CFMX a couple of months ago. That version used a value for the -webroot directive on the compiler command line (the "java" line) that caused it not to work for compiling code outside the default webroot.

Some learned that they could change that value to point to their desired directory, but then they learned that in order for it to work, they had to go through some more hoops. What was lacking was two things. First, the critical -webinf compiler directive, a hidden gem I learned from Harry Klein of CONTENS Software in Germany.

As my batch file code above shows, it names the path to the wwwroot\WEB-INF directory where CFMX is installed. Without this, if you pointed the -webroot directive at some location other than the default wwwroot, the compiler would fail because it expected to find that WEB-INF directory and several subdirectories of it under the directory you named in the -webroot directive.

Furthermore, I've set the -webroot directive to be whatever directory you pass on the call to the precompile.bat, rather than pointing it at the default webroot. These two things were the missing pieces that kept the previous versions of this precompile.bat file from working against any directory.

I've also changed it so that you must provide the complete path to the directory containing the code you want to compile (whereas the older one worked with relative paths depending on where you placed the precompile.bat file). This makes mine more robust for a few reasons, at the cost of a few extra keystrokes when passing directory names to the precompile batch file.

Readers familiar with batch file variables will notice that I've also set it up to accept only a single argument naming the directory path or file holding the code to be compiled. The older version allowed specification of multiple directories or files. Again, it worked fine with code in the default webroot, but in order to support code in any directory in just two lines, that feature had to be eliminated.

Indeed, you could change it to accept multiple directories, but with the way the batch file is currently written, they'd have to be subdirectories of the first one named, and that's not useful since it already compiles all the subdirectories of any provided. You couldn't name a parent and only one of its children, for instance, since the naming of the parent would already compile all the children.

One other minor change in this version and others offered previously is that I'm prefixing the call to the java interpreter (in the second line of the batch file) with the location within the CFMX install directory where the default Java Virtual Machine is installed. This might prevent some confusion if multiple JVMs are installed.

With more tweaking and some additional DOS commands and conditional tests, the batch file code could be made to provide additional functionality and address some of these issues. I think most will be glad simply to be able to precompile code at all, in more than just the default webroot, and in just two simple lines of code.

Finally, for those working on Solaris and Linux, ColdFusion developer Matt Liotta has offered a version of that batch file as a shell script:


$MX_INSTALL/jre/bin/java -class
lib/cfusion.jar \coldfusion.
tools.Compiler -webroot $1\
-webinf $MX_INSTALL/wwwroot/

Just to be clear, there should be three lines of code in the file, one starting with "MX_INSTALL", one starting with "PATH", and one starting with "$MX_INSTALL/jre/bin/java".

Again, be sure to change line one to the location where CFMX is installed. Thanks, Matt!

*  *  *

We could stop at this point - and will. The problem of precompiling code is solved. But there will be curious folks (and bit-twiddlers) among you who will want to know more, maybe lots more.

How much time is this really saving? If it's compiled to disk, how and when does CFMX read it into memory to execute it? What's the cost of that? What happens with CF-INCLUDEd files? Where does the compiled code go? Can I look at it? Can I just delete the generated class files instead? How do I determine which class file was generated for which CF template? Can I distribute the compiled code on other servers without the source code? (The answer to the last question, sadly, is no.)

We'll discuss that and the rest of these questions next month. Otherwise, you've got all you need to know to start precompiling code in CFMX.

More Stories By Charlie Arehart

A veteran ColdFusion developer since 1997, Charlie Arehart is a long-time contributor to the community and a recognized Adobe Community Expert. He's a certified Advanced CF Developer and Instructor for CF 4/5/6/7 and served as tech editor of CFDJ until 2003. Now an independent contractor (carehart.org) living in Alpharetta, GA, Charlie provides high-level troubleshooting/tuning assistance and training/mentoring for CF teams. He helps run the Online ColdFusion Meetup (coldfusionmeetup.com, an online CF user group), is a contributor to the CF8 WACK books by Ben Forta, and is frequently invited to speak at developer conferences and user groups worldwide.

Comments (9) View Comments

Share your thoughts on this story.

Add your comment
You must be signed in to add a comment. Sign-in | Register

In accordance with our Comment Policy, we encourage comments that are on topic, relevant and to-the-point. We will remove comments that include profanity, personal attacks, racial slurs, threats of violence, or other inappropriate material that violates our Terms and Conditions, and will block users who make repeated violations. We ask all readers to expect diversity of opinion and to treat one another with dignity and respect.

Most Recent Comments
charlie arehart 03/26/03 04:35:00 PM EST

Grr. This comment system doesn't respect line breaks, so here it all is again:

OK, back in December I learned of one last refinement of my precompile.bat file. I'm so sorry that I've had to offer so many versions. I think this is the last, ultimate, one. And it solves various problems that had occurred while I tried to find this ultimate solution. Again, the following is just 3 lines, 2 sets and the java command:

set MX_INSTALL=c:\CFusionMX
set PATH=%MX_INSTALL%\runtime\bin;%MX_INSTALL%\runtime\jre\bin;%PATH%
java -classpath %MX_INSTALL%\lib\cfusion.jar coldfusion.tools.Compiler
-webroot %1 -webinf %MX_INSTALL%\wwwroot\WEB-INF %1

BTW, even though Updater 3 offers a new updater_compile.bat file, it's still not able to address some of the problems that this example does (like compiling code outside the cf root where the WEB-INF directory is).

charlie arehart 03/26/03 04:33:00 PM EST

OK, back in December I learned of one last refinement of my precompile.bat file. I'm so sorry that I've had to offer so many versions. I think this is the last, ultimate, one. And it solves various problems that had occurred while I tried to find this ultimate solution. Again, the following is just 3 lines, 2 sets and the java command:

set MX_INSTALL=c:\CFusionMX
set PATH=%MX_INSTALL%\runtime\bin;%MX_INSTALL%\runtime\jre\bin;%PATH%
java -classpath %MX_INSTALL%\lib\cfusion.jar coldfusion.tools.Compiler
-webroot %1 -webinf %MX_INSTALL%\wwwroot\WEB-INF %1

BTW, even though Updater 3 offers a new updater_compile.bat file, it's still not able to address some of the problems that this example does (like compiling code outside the cf root where the WEB-INF directory is).

Charles Arehart 12/05/02 12:42:00 AM EST

Oops. Forgot to list the first line of the file. Here it is, now, complete:

set MX_INSTALL=c:\cfusionMX
%MX_INSTALL%\runtime\bin\java -classpath %MX_INSTALL%\lib\cfusion.jar coldfusion.tools.Compiler -webroot %1 -webinf %MX_INSTALL%\wwwroot\WEB-INF %1

Again, you need to change the first line to reflect wherever you installed CFusionmx.

(It's a shame we can't edit these comments. I'd like to go in and clean them all up!)

Charles Arehart 12/05/02 12:39:00 AM EST

OK, sorry to have to correct things yet again, but it turns out that the solution to the updater 1 problem is really the fact that part of the compile process (when using the -f directive) seems to be needing the 1.4 JDK. You can get that (at least in my testing) by changing the second line in the command above to start with this instead:

%MX_INSTALL%\runtime\bin\java %MX_INSTALL%\lib\cfusion.jar coldfusion.tools.Compiler -webroot %1 -webinf %MX_INSTALL%\wwwroot\WEB-INF %1

That's 2 lines, with the second starting with a pointer to the runtim=bin rather than the runtime\jre\bin that I pointed to in the previous comment. Hope that helps folks.

Charles Arehart 11/23/02 10:06:00 AM EST

Folks, I've learned that since the writing of this, the (Updater 1 for CFMX ) has broken the -f switch I mention for forcing a recompile. There's hope that this is addressed in Updater 2, as I've heard from some in MM.

charles arehart 11/11/02 03:36:00 PM EST

Folks, while I warn in the article that you should not try to precompile your entire default cfusionmx\wwwroot directory, someone has just shared with me an experience that offers another reason not to. I'll share it for those who may be interested.

He had tried to run the precompile against it and got thousands of pages in error. Now, why he got so many errors is one thing. It may have been that his directory names included some with blank spaces (the precompiler doesn't like that, and will cause errors in compiling templates within them).

But more curious was that because of the errors, he was then unable to then execute the code in CFMX. Here are his comments:

> Those who want to compile an entire site or massive directory, may want to proceed with extreme caution. When I tried to do that it and got a boatload of error messages, it had a NASTY side effect.

>After compiling I did a refresh on my local site and BOOM; gone, dead. Every CFM template including the CF admin site, all resulted in page cannot be displayed. Restarting the CFMX server did no good. Finally the only thing that worked was to delete all of the java files that I had compiled and reboot the box. This finally restored CFMX to service again.


So, forewarned is forearmed. It seems that failures during the compile process cause a .java file to be left in the CFCLASSES directory (mentioned in the article) that then prevent the normal automatic compilation of code to even work. Yikes!

charles arehart 11/04/02 05:01:00 PM EST

Let's see if I can format this well for display. It should be:

set MX_INSTALL=d:\cfusionMX
%MX_INSTALL%\runtime\jre\bin\java -classpath %MX_INSTALL%\lib\cfusion.jar coldfusion.tools.Compiler -webroot %1 -webinf %MX_INSTALL%\wwwroot\WEB-INF %1

charles arehart 11/04/02 04:53:00 PM EST

Gads! Somehow the version of the precompile.bat file that was printed is missing some important code! :-(

It should be:

set MX_INSTALL=d:\cfusionMX
%MX_INSTALL%\runtime\jre\bin\java -classpath %MX_INSTALL%\lib\cfusion.jar coldfusion.tools.Compiler -webroot %1 -webinf %MX_INSTALL%\wwwroot\WEB-INF %1

As the article indicates, it's just 2 lines, the first being the SET and the second starting with %MX_INSTALL%.

But the printed version was somehow missing the beginning of the second line:

%MX_INSTALL%\runtime\jre\bin\java -classpath

So sorry for that printing mistake!

One other thing I've learned since writing the article is that it seems to fail to work if a directory name or file name being precompiled has spaces in the name.

Dennis Kovalev 10/18/02 07:33:00 AM EDT
@ThingsExpo Stories
Business professionals no longer wonder if they'll migrate to the cloud; it's now a matter of when. The cloud environment has proved to be a major force in transitioning to an agile business model that enables quick decisions and fast implementation that solidify customer relationships. And when the cloud is combined with the power of cognitive computing, it drives innovation and transformation that achieves astounding competitive advantage.
As IoT continues to increase momentum, so does the associated risk. Secure Device Lifecycle Management (DLM) is ranked as one of the most important technology areas of IoT. Driving this trend is the realization that secure support for IoT devices provides companies the ability to deliver high-quality, reliable, secure offerings faster, create new revenue streams, and reduce support costs, all while building a competitive advantage in their markets. In this session, we will use customer use cases...
Digital Transformation: Preparing Cloud & IoT Security for the Age of Artificial Intelligence. As automation and artificial intelligence (AI) power solution development and delivery, many businesses need to build backend cloud capabilities. Well-poised organizations, marketing smart devices with AI and BlockChain capabilities prepare to refine compliance and regulatory capabilities in 2018. Volumes of health, financial, technical and privacy data, along with tightening compliance requirements by...
The IoT Will Grow: In what might be the most obvious prediction of the decade, the IoT will continue to expand next year, with more and more devices coming online every single day. What isn’t so obvious about this prediction: where that growth will occur. The retail, healthcare, and industrial/supply chain industries will likely see the greatest growth. Forrester Research has predicted the IoT will become “the backbone” of customer value as it continues to grow. It is no surprise that retail is ...
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 settlement products to hedge funds and investment banks. After, he co-founded a revenue cycle management company where he learned about Bitcoin and eventually Ethereal. Andrew's role at ConsenSys Enterprise is a mul...
The best way to leverage your Cloud Expo presence as a sponsor and exhibitor is to plan your news announcements around our events. The press covering Cloud Expo and @ThingsExpo will have access to these releases and will amplify your news announcements. More than two dozen Cloud companies either set deals at our shows or have announced their mergers and acquisitions at Cloud Expo. Product announcements during our show provide your company with the most reach through our targeted audiences.
DevOpsSummit New York 2018, colocated with CloudEXPO | DXWorldEXPO New York 2018 will be held November 11-13, 2018, in New York City. Digital Transformation (DX) is a major focus with the introduction of DXWorldEXPO within the program. Successful transformation requires a laser focus on being data-driven and on using all the tools available that enable transformation if they plan to survive over the long term. A total of 88% of Fortune 500 companies from a generation ago are now out of bus...
With 10 simultaneous tracks, keynotes, general sessions and targeted breakout classes, @CloudEXPO and DXWorldEXPO are two of the most important technology events of the year. Since its launch over eight years ago, @CloudEXPO and DXWorldEXPO have presented a rock star faculty as well as showcased hundreds of sponsors and exhibitors! In this blog post, we provide 7 tips on how, as part of our world-class faculty, you can deliver one of the most popular sessions at our events. But before reading...
DXWorldEXPO LLC announced today that "Miami Blockchain Event by FinTechEXPO" has announced that its Call for Papers is now open. The two-day event will present 20 top Blockchain experts. All speaking inquiries which covers the following information can be submitted by email to [email protected] Financial enterprises in New York City, London, Singapore, and other world financial capitals are embracing a new generation of smart, automated FinTech that eliminates many cumbersome, slow, and expe...
Cloud Expo | DXWorld Expo have announced the conference tracks for Cloud Expo 2018. Cloud Expo will be held June 5-7, 2018, at the Javits Center in New York City, and November 6-8, 2018, at the Santa Clara Convention Center, Santa Clara, CA. Digital Transformation (DX) is a major focus with the introduction of DX Expo within the program. Successful transformation requires a laser focus on being data-driven and on using all the tools available that enable transformation if they plan to survive ov...
DXWordEXPO New York 2018, colocated with CloudEXPO New York 2018 will be held November 11-13, 2018, in New York City and will bring together Cloud Computing, FinTech and Blockchain, Digital Transformation, Big Data, Internet of Things, DevOps, AI, Machine Learning and WebRTC to one location.
DXWorldEXPO | CloudEXPO are the world's most influential, independent events where Cloud Computing was coined and where technology buyers and vendors meet to experience and discuss the big picture of Digital Transformation and all of the strategies, tactics, and tools they need to realize their goals. Sponsors of DXWorldEXPO | CloudEXPO benefit from unmatched branding, profile building and lead generation opportunities.
DXWorldEXPO LLC announced today that ICOHOLDER named "Media Sponsor" of Miami Blockchain Event by FinTechEXPO. ICOHOLDER give you detailed information and help the community to invest in the trusty projects. Miami Blockchain Event by FinTechEXPO has opened its Call for Papers. The two-day event will present 20 top Blockchain experts. All speaking inquiries which covers the following information can be submitted by email to [email protected] Miami Blockchain Event by FinTechEXPO also offers s...
Dion Hinchcliffe is an internationally recognized digital expert, bestselling book author, frequent keynote speaker, analyst, futurist, and transformation expert based in Washington, DC. He is currently Chief Strategy Officer at the industry-leading digital strategy and online community solutions firm, 7Summits.
Widespread fragmentation is stalling the growth of the IIoT and making it difficult for partners to work together. The number of software platforms, apps, hardware and connectivity standards is creating paralysis among businesses that are afraid of being locked into a solution. EdgeX Foundry is unifying the community around a common IoT edge framework and an ecosystem of interoperable components.
Digital Transformation and Disruption, Amazon Style - What You Can Learn. Chris Kocher is a co-founder of Grey Heron, a management and strategic marketing consulting firm. He has 25+ years in both strategic and hands-on operating experience helping executives and investors build revenues and shareholder value. He has consulted with over 130 companies on innovating with new business models, product strategies and monetization. Chris has held management positions at HP and Symantec in addition to ...
Cloud-enabled transformation has evolved from cost saving measure to business innovation strategy -- one that combines the cloud with cognitive capabilities to drive market disruption. Learn how you can achieve the insight and agility you need to gain a competitive advantage. Industry-acclaimed CTO and cloud expert, Shankar Kalyana presents. Only the most exceptional IBMers are appointed with the rare distinction of IBM Fellow, the highest technical honor in the company. Shankar has also receive...
Enterprises have taken advantage of IoT to achieve important revenue and cost advantages. What is less apparent is how incumbent enterprises operating at scale have, following success with IoT, built analytic, operations management and software development capabilities - ranging from autonomous vehicles to manageable robotics installations. They have embraced these capabilities as if they were Silicon Valley startups.
The standardization of container runtimes and images has sparked the creation of an almost overwhelming number of new open source projects that build on and otherwise work with these specifications. Of course, there's Kubernetes, which orchestrates and manages collections of containers. It was one of the first and best-known examples of projects that make containers truly useful for production use. However, more recently, the container ecosystem has truly exploded. A service mesh like Istio addr...
Predicting the future has never been more challenging - not because of the lack of data but because of the flood of ungoverned and risk laden information. Microsoft states that 2.5 exabytes of data are created every day. Expectations and reliance on data are being pushed to the limits, as demands around hybrid options continue to grow.