< Back to Blog

How Microsoft Is Taking Over The Cloud

Industry

Microsoft Azure is accelerating past every other cloud infrastructure provider. Amazon, Apple, Google, Rackspace, and all the others are being left in the dust.

If you want virtual machines Amazon is the big dog. And there’s a lot of major players here, not just Microsoft, Apple & Rackspace but all the usual suspects including AT&T and IBM. And this is irrelevant. While virtual machines will continue to see a lot of use, they are an obsolete technology surpassed by PAAS and SAAS. They’re also a commodity that you can easily move from one vendor to another, a recipe to a race to minimal profits.

image_thumb_01108FBD[1]

Why Azure is the only game in town

Our experience developing Enforced Vacation (EV) opened our eyes to this new world. We figured at first we would use a hosted VM and throw SQL Server and IIS on it. That’s what we had done in the past for hosted apps and it does work. But we had selected Azure (because Microsoft has been very transparent when they hit issues). And we found all these other services in Azure.

Ok, so looking at what is offered we figured instead of a VM we would use a SQL Database and a website. That way we could scale each by changing settings and did not need to administer a VM, Windows, SQL Server, & IIS. Straightforward shift, but with this we had moved from purchasing VMs to purchasing services. This is a substantial shift and one that once you have done it, you’re hooked. The ease of scaling the database and web service up/out, while not having to screw around with keeping them up to date and running is a gigantic shift.

And there’s more

As we started diving in to using this we asked Microsoft support questions. Lots and lots of questions. Starting with basic ones and from those diving in further. (I don’t care how stupid I sound from asking questions, I want to fully understand how best to do something.) And from this we learned – a lot.

We need to update the database based on activity. We can do that on each call to our service, but that slows down the response time. We’d always used a worker thread in our IIS app but that is problematic when you have multiple instances that can be spun up, because what can be spun up can also be spun down and that’s a problem. So Azure has worker roles. This are essentially worker threads, but each runs in its own VM and has a controlled shut down process.

You need to communicate with the worker threads, and for that they have queues that persist their data and can be written to and read from by multiple services. So each web service writes its update data to the queue. This is very fast and so has no impact on our service. Each worker role can read from the queue and so one of the roles reads the message and writes that data to the SQL Database.

This is a small example of the beauty of the set of services Azure offers. By using two simple specific services we could simply and safely update our database in a way that did not slow down our response to users querying EV. And Azure has this architected in a way that is infinitely scalable. Larger queues, more requests, just spin up more worker roles.

And even more

As we progressed we discovered more services that help, some we’re using now and some we’ll use if EV is successful enough that we have to scale out. Cloud services is a raw network server, that you can write for using ASP.NET. We use it for our IMAP network services. Traffic Manager will send requests to the closest server we have running. Redis provides caching of objects across all of our services. Web jobs is great for the nightly billing processing. And the list goes on (DocumentDB is solely for storing JSON documents – talk about specific functionality.)

What makes this all work so well is each service in Azure is designed to perform a specific type of task. By designing each to perform just one task, Microsoft has been able to design each to be simple to understand and use. As you understand each service you need, how to use it becomes natural. And that makes it easy to split out how you architect your app.

Equally important, architecting a cloud app correctly requires that you embrace delay and failure, not fight it. A query against a database might take a minute (the VM its on is rebooting due to a service pack). A data center might be down and services there are unavailable. Your app might be so popular requests to it have to be throttled (please, please let that be the case with EV). You might have 100,000 web services all running at 100%.

All of Azure is architected around this. It gives you the tools which not only helps you handle the problems you get in the cloud, it forces you to embrace architecting your application to work well in the cloud. This is why Microsoft is coming to own the cloud. It not only gives you an incredibly well designed toolbox of services to create a well architected cloud app, it guides you into creating an app that works well in the cloud.

Microsoft owns the future

Once a developer understands what they can do with Azure, and why that is so valuable to them, Microsoft has them. I can’t imagine going back to using a VM. I can’t imaging going back to using just a web service and database. As Microsoft grows the number of Azure services from 15 to 50 to 500, how will the other out there ever catch up. They could, Amazon, Apple, & Google in particular have very talented people. But I don’t think they’re even aware that the future, even the now, is no longer VMs and web servers.

Microsoft also has another giant advantage – they “get” developers. Better than any other large company. Far far better. The support from Microsoft as we’ve learned Azure has been superlative (especially the SQL Database group). They need to educate developers on how to best use Azure to pull more in, and they’re doing it really well.

Microsoft may be losing in social, search, & mobile, but they’re well on their way to owning the cloud server stack.

Tags Start & End

Tags Can Start & End Anywhere

Appendix B

.NET code for multi-page image output

Appendix A

Java code for multi-page image output

Data Bin Search

The Data Bin can now be searched to find a table, column, node or other piece of data without scrolling through it all.

Shrink to Fit

This will shrink the contents of a cell until it fits the defined cell size.

Time Zone Conversion

A new Windward macro has been added to help with converting dates and times from UTC time to the local time zone.

Image Output Format

New image output formats added.

PostScript Output Format

PostScript, commonly used with printers and printing companies, has been added as an additional output format.

New and Improved Datasets (Designer, Java Engine, .NET Engine)

Datasets have been re-written from scratch to be more powerful and easier to use.

Stored Procedure Wizard (Designer)

This works for all tag types that are connected to a SQL-based data source (Microsoft SQL Server, Oracle, MySQL, or DB2).

Boolean Conditional Wizard (Designer)

Before, conditional statements could only be written manually. Now they can also be built using our intuitive Wizard interface.

Reorganized Ribbon

The ribbon menus have been re-organized and consolidated to improve the report design workflow.

XPath 2.0 as Data Source

Adds various capabilities such as inequalities,descending sort, joins, and other functions.

SQL Select Debugger

SQL Select  Debugger

  • The look and feel was improved
  • Stored Procedure Wizard
  • Improved Exceptions pane

Tag Editor/Tag Selector

Added a Query tab as a field for typing or pasting in a select statement

  • Color Coding of Keywords
  • TypeAhead
  • Evaluate is now "Preview"

Rename a Datasource

All tags using that Data source will be automatically updated with that name.

Connecting to a Data Source

New single interface to replace 2 separate dialog boxes

Tag Tree

Provides a display of all the tags in the template, structures as they are placed in the template. Provides an easy way to see the structure, go to any tag, and see the properties of a tag.

Added Javelin into the RESTful Engine

Support for Google Application Engine Integration

The ability to integrate the Windward Engine into Google’s cloud computing platform for developing and hosting web applications dubbed Google Applications Engine (GAE).

Additional Refinement for HTML Output

  • Improved indentation for ordered and unordered lists
  • Better handling of template header and footer images
  • Better handling for background images and colors

Redesigned PDF Output Support

This new  integration will allow for processing of complex scripts and bi-directional  text such as Arabic.  Your PDF output  will be much tighter and more closely match your template, and we’ll be able  to respond rapidly to PDF requests and fixes.

PowerPoint Support

Includes support for new ForEach and slide break handling, table header row repeat across slide breaks, and native Microsoft support for charts and images.

Tags are Color Coded

Tags are color coded in the template by type, making it easy to visually identify them.

Increased Performance

Version 13’s core code has been reworked and optimized to offer a reduced memory footprint, faster PDF generation and full documentation of supported features and limitations in the specifications for DOCX, XLSX and PPTX.

Advanced Image Properties

Documents can include advanced Word image properties such as shadows, borders, and styles.

Improved HTML Output

Windward has updated HTML output to reflect changing HTML standards.

Version 13 New Data Sources

Windward now works with a slew of new datasources: MongoDB, JSON, Cassandra, OData, Salesforce.com

Generate Code

Designer (fka AutoTag) Generate Code tool allows you to open an existing template and, with a click of a button, automatically create a window with the code needed to run your current template with all data sources and variables in your .NET or Java project. The process is quick, shortens delivery time and helps alleviate any bumps in the road.

Pivot Tables Adjusted in Output

Any pivot tables in the template are carried over to XLSX output. The ranges in the pivot ranges are adjusted to match the generated output. So your final XLSX will be pivot tables set as expected in the generated file.

Imported Template Can be Set to Match the Parent Styles

In an imported sub-template, if its properties for a style (ex. Normal) differ from the parent template's properties for the style, the use in the sub-template can be set to either use the properties in the sub-template, ot the properties in the parent.

Tags can be Placed in Text Boxes

Tags can be placed in text boxes. Including linked text boxes. This gives you the ability to set the text in a textbox from your data.

Tags can be Placed in Shapes & Smart Art

Tags can be placed in shapes & smart art. This gives you the ability to set the text in a shape from your data.

HTML Output Supports Embedded Images

When generating HTML output, the engine can either write bitmaps as distinct files the generate HTML references, or it can embed the images in the HTML providing a single file for the output.

Footnotes & Endnotes can Have Tags

You can place tags in pretty much any part of a template, including in footnotes & endnotes.

Document Locking Supported in DOCX & XLSX

Any parts of a DOCX or XLSX (PowerPoint does not support this) file that are locked in the template, will be locked the same in the output.

Specify Font Substitution

If a font used in the template does not exist on the server generating a report, the font to substitute can be specified.
In addition, if a glyph to be rendered does not exist in the font specified, you can specify the replacement font. This can be set distinctly for European, Bi-Directional, and Far East fonts.

Process Multiple Datasources Simultaneously

When Windward is merging the data into a template, it process the template handling each tag in order, and the tags can pull from different datasources. This allows the select in a tag to use data from other datasources in the select.

David Thielen

President/CEO at Windward Studios

From his early years as a Senior Developer at Microsoft, to legendary designer of the popular Enemy Nations strategy game, to reporting and document generation guru, Dave has never lost his passion for building superb software and teams.

david@windward.nethttps://www.linkedin.com/in/davethielen/

For over 10 years, Windward has lead the industry with our world-class document generation platform that creates visually stunning, data-powered documents designed exactly the way users want and are created in a fraction of the time and cost compared to existing solutions. Proudly located in Boulder, Colorado, Windward Studios is the premier solution for developers and business users adding reporting and document generation capabilities to their applications in over 70 countries around the world.

© 2019 Windward Studios Inc.

Contact

Got questions about reporting and document generation? We've got answers—let's connect!
Send a note