Welcome!

You will be redirected in 30 seconds or close now.

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

Related Topics: ColdFusion

ColdFusion: Article

Scalability and Rapid Development

Scalability and Rapid Development

One of ColdFusion's long-standing advantages over other Web development environments is time-to-market. It's not uncommon to hear stories of start-to-finish ColdFusion projects that take less than a month...or even a week. But these ultratight schedules allow little or no time for proper planning and testing prior to launch.

ColdFusion's simplicity and speed of development, which allows for the creation of powerful applications, doesn't reduce the importance of appropriate planning and testing in developing scalable applications. In the end, every Web application undergoes testing for both functionality and scalability. Some are tested prior to release as part of the development process. Others aren't fully tested until after their release, and by unsuspecting customers.

A firm understanding of the nature of rapid development and a brief review of the processes that lay the foundation for scalable application development will allow us to better understand how to achieve scalable applications rapidly.

Rapid Development for the Web
ColdFusion isn't the first product to offer rapid development other non-Web tools have similar accelerated development cycles. What is special about rapid development for the Web? The big difference lies in the deployment environment.

First, in the client/server world applications are generally released to a predictable, relatively small, restricted number of users in a controlled environment.

Web applications on the other hand are often released to an un-known, virtually unlimited number of potentially simultaneous users in the frequently unpredictable environment of the Web.

Second, while rolling out a client/server application often requires a significant effort, the effort required to deploy a Web application can be minimal. By simply deploying a code set to a single Web server, you can immediately reach thousands of users.

The possibility that you could so easily deploy an application to hundreds of thousands of simultaneous users adds significant risk to an application that wasn't developed with proper development methodology - and to the company behind it. With sound development practices, however, these risks can be minimized while still achieving rapid application development.

Scalable Application Development
Regardless of the development tools you use, the same basic principles of sound development hold. Appropriate resources need to be allocated for architectural planning, site reporting, database tuning, code analysis and tuning, representative staging, load and regression testing, server tuning, spike readiness, recovery planning and monitoring. While ColdFusion can substantially compress the time needed for some of these stages, it doesn't reduce the need for a proper development process.

A number of key considerations come into play when developing and deploying scalable Web applications. The information below is excerpted from a more detailed Allaire Knowledge Base article, #12970, available at http://www2.allaire.com/Handlers/index.cfm?ID=12970&Method=Full:

1. Architectural Planning
Plan the deployment, staging and development environments before launching your Web application. At the same time, growth requirements, security, proper testing and potential points of failure should be kept in mind. To better structure your code, understand your application's scalability requirements and existing constraints before starting development.

2. Site Reporting
Design your site with reporting in mind. Site reporting can range from log analysis to business and marketing trends to usage analysis. At its most basic level, it can provide useful diagnostic information about the relative traffic to different portions of your application or Web site. This information can be invaluable for troubleshooting and site planning. More sophisticated reporting can sometimes offer detailed information about site traffic, including the correlation of such information to back-end databases for more descriptive reporting. Some development architectures facilitate reporting while others hinder it.

3. Database Tuning
Run the database server(s) well below 50% of capacity to allow for load spikes. The vast majority of performance bottlenecks in database-driven applications stem from poorly tuned databases and queries. Every database-driven application can benefit from the active participation of a skilled database administrator (DBA) for both query and database tuning.

4. Code Analysis and Tuning
Consider a variety of alternative coding constructs to achieve optimum functionality and performance. Bear in mind that some are more efficient than others for a given task. Best-practices documents and the ColdFusion Server debugging features, including page-processing statistics, can facilitate your code quality analysis.

5. Representative Staging
Include allowances for application testing in a representative staging environment. You can use this environment to detect and correct deployment configuration issues before reaching final deployment.

6. Load and Regression Testing
Test your applications thoroughly for both functionality and performance under load. Many Web applications and sites in use have been only marginally tested under load prior to deployment, if at all. These applications often work fine under minimal or moderate load, but become unstable or unbearably lethargic under heavy load.

7. Server Tuning
Tune your servers thoroughly. Proper and thorough server tuning can often achieve significant performance improvements. Each Web application has its own distinct demands, stressing specific server resources and often requiring a distinct server configuration for optimal performance.

8. Spike Readiness
Plan for load spikes and develop contingency plans for rapid emergency system expansion. Load spikes can come when you least expect them. Your systems should be able to handle at least twice the regular peak load without additional resources. The extra bandwidth not only protects you against unexpected load spikes, it also can ensure application availability during unexpected partial outages or system maintenance.

9. Recovery Planning
Make a contingency plan for every possible failure point in your application deployment environment. Determine your acceptable downtime threshold, and plan your contingency plans accordingly.

10. Monitoring
Plan for monitoring. A scalable, stable Web project often involves various forms of monitoring, be they implicit or explicit. Any portion of your deployment environment that can fail is a candidate for some form of monitoring, be it periodic manual verification or some form of automated detection.

Conclusion
Tag-based technologies like ColdFusion provide extremely productive, scalable, rapid-development tools that can substantially reduce your time and costs of developing, deploying and maintaining Web applications. Remember, however, that they're not alternatives to proper development methodologies. They are catalysts to accelerate various stages of those methodologies.

As Web technology evolves, we'll continue to evolve our products to make those technologies imminently usable and accessible to Web developers. Web technologies will come and go, but sound development practices are here to stay.

More Stories By Brian Surkan

Brian Surkan has been with Allaire for almost three years. For the last year and a half he has focused on the day-to-day product management of ColdFusion Server. As a technical product
manager, he stewards the ongoing evolution of the ColdFusion product.

Comments (0)

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.


@ThingsExpo Stories
"For over 25 years we have been working with a lot of enterprise customers and we have seen how companies create applications. And now that we have moved to cloud computing, mobile, social and the Internet of Things, we see that the market needs a new way of creating applications," stated Jesse Shiah, CEO, President and Co-Founder of AgilePoint Inc., in this SYS-CON.tv interview at 15th Cloud Expo, held Nov 4–6, 2014, at the Santa Clara Convention Center in Santa Clara, CA.
The 3rd International Internet of @ThingsExpo, co-located with the 16th International Cloud Expo - to be held June 9-11, 2015, at the Javits Center in New York City, NY - announces that its Call for Papers is now open. The Internet of Things (IoT) is the biggest idea since the creation of the Worldwide Web more than 20 years ago.
The Industrial Internet revolution is now underway, enabled by connected machines and billions of devices that communicate and collaborate. The massive amounts of Big Data requiring real-time analysis is flooding legacy IT systems and giving way to cloud environments that can handle the unpredictable workloads. Yet many barriers remain until we can fully realize the opportunities and benefits from the convergence of machines and devices with Big Data and the cloud, including interoperability, data security and privacy.
Things are being built upon cloud foundations to transform organizations. This CEO Power Panel at 15th Cloud Expo, moderated by Roger Strukhoff, Cloud Expo and @ThingsExpo conference chair, addressed the big issues involving these technologies and, more important, the results they will achieve. Rodney Rogers, chairman and CEO of Virtustream; Brendan O'Brien, co-founder of Aria Systems, Bart Copeland, president and CEO of ActiveState Software; Jim Cowie, chief scientist at Dyn; Dave Wagstaff, VP and chief architect at BSQUARE Corporation; Seth Proctor, CTO of NuoDB, Inc.; and Andris Gailitis, C...
Since 2008 and for the first time in history, more than half of humans live in urban areas, urging cities to become “smart.” Today, cities can leverage the wide availability of smartphones combined with new technologies such as Beacons or NFC to connect their urban furniture and environment to create citizen-first services that improve transportation, way-finding and information delivery. In her session at @ThingsExpo, Laetitia Gazel-Anthoine, CEO of Connecthings, will focus on successful use cases.
The industrial software market has treated data with the mentality of “collect everything now, worry about how to use it later.” We now find ourselves buried in data, with the pervasive connectivity of the (Industrial) Internet of Things only piling on more numbers. There’s too much data and not enough information. In his session at @ThingsExpo, Bob Gates, Global Marketing Director, GE’s Intelligent Platforms business, to discuss how realizing the power of IoT, software developers are now focused on understanding how industrial data can create intelligence for industrial operations. Imagine ...
Today’s enterprise is being driven by disruptive competitive and human capital requirements to provide enterprise application access through not only desktops, but also mobile devices. To retrofit existing programs across all these devices using traditional programming methods is very costly and time consuming – often prohibitively so. In his session at @ThingsExpo, Jesse Shiah, CEO, President, and Co-Founder of AgilePoint Inc., discussed how you can create applications that run on all mobile devices as well as laptops and desktops using a visual drag-and-drop application – and eForms-buildi...
The Internet of Things is tied together with a thin strand that is known as time. Coincidentally, at the core of nearly all data analytics is a timestamp. When working with time series data there are a few core principles that everyone should consider, especially across datasets where time is the common boundary. In his session at Internet of @ThingsExpo, Jim Scott, Director of Enterprise Strategy & Architecture at MapR Technologies, discussed single-value, geo-spatial, and log time series data. By focusing on enterprise applications and the data center, he will use OpenTSDB as an example t...
Cultural, regulatory, environmental, political and economic (CREPE) conditions over the past decade are creating cross-industry solution spaces that require processes and technologies from both the Internet of Things (IoT), and Data Management and Analytics (DMA). These solution spaces are evolving into Sensor Analytics Ecosystems (SAE) that represent significant new opportunities for organizations of all types. Public Utilities throughout the world, providing electricity, natural gas and water, are pursuing SmartGrid initiatives that represent one of the more mature examples of SAE. We have s...
SYS-CON Media announced that Splunk, a provider of the leading software platform for real-time Operational Intelligence, has launched an ad campaign on Big Data Journal. Splunk software and cloud services enable organizations to search, monitor, analyze and visualize machine-generated big data coming from websites, applications, servers, networks, sensors and mobile devices. The ads focus on delivering ROI - how improved uptime delivered $6M in annual ROI, improving customer operations by mining large volumes of unstructured data, and how data tracking delivers uptime when it matters most.
The true value of the Internet of Things (IoT) lies not just in the data, but through the services that protect the data, perform the analysis and present findings in a usable way. With many IoT elements rooted in traditional IT components, Big Data and IoT isn’t just a play for enterprise. In fact, the IoT presents SMBs with the prospect of launching entirely new activities and exploring innovative areas. CompTIA research identifies several areas where IoT is expected to have the greatest impact.
There is no doubt that Big Data is here and getting bigger every day. Building a Big Data infrastructure today is no easy task. There are an enormous number of choices for database engines and technologies. To make things even more challenging, requirements are getting more sophisticated, and the standard paradigm of supporting historical analytics queries is often just one facet of what is needed. As Big Data growth continues, organizations are demanding real-time access to data, allowing immediate and actionable interpretation of events as they happen. Another aspect concerns how to deliver ...
The Internet of Things will greatly expand the opportunities for data collection and new business models driven off of that data. In her session at @ThingsExpo, Esmeralda Swartz, CMO of MetraTech, discussed how for this to be effective you not only need to have infrastructure and operational models capable of utilizing this new phenomenon, but increasingly service providers will need to convince a skeptical public to participate. Get ready to show them the money!
Scott Jenson leads a project called The Physical Web within the Chrome team at Google. Project members are working to take the scalability and openness of the web and use it to talk to the exponentially exploding range of smart devices. Nearly every company today working on the IoT comes up with the same basic solution: use my server and you'll be fine. But if we really believe there will be trillions of these devices, that just can't scale. We need a system that is open a scalable and by using the URL as a basic building block, we open this up and get the same resilience that the web enjoys.
Code Halos - aka "digital fingerprints" - are the key organizing principle to understand a) how dumb things become smart and b) how to monetize this dynamic. In his session at @ThingsExpo, Robert Brown, AVP, Center for the Future of Work at Cognizant Technology Solutions, outlined research, analysis and recommendations from his recently published book on this phenomena on the way leading edge organizations like GE and Disney are unlocking the Internet of Things opportunity and what steps your organization should be taking to position itself for the next platform of digital competition.
In their session at @ThingsExpo, Shyam Varan Nath, Principal Architect at GE, and Ibrahim Gokcen, who leads GE's advanced IoT analytics, focused on the Internet of Things / Industrial Internet and how to make it operational for business end-users. Learn about the challenges posed by machine and sensor data and how to marry it with enterprise data. They also discussed the tips and tricks to provide the Industrial Internet as an end-user consumable service using Big Data Analytics and Industrial Cloud.
How do APIs and IoT relate? The answer is not as simple as merely adding an API on top of a dumb device, but rather about understanding the architectural patterns for implementing an IoT fabric. There are typically two or three trends: Exposing the device to a management framework Exposing that management framework to a business centric logic Exposing that business layer and data to end users. This last trend is the IoT stack, which involves a new shift in the separation of what stuff happens, where data lives and where the interface lies. For instance, it's a mix of architectural styles ...
IoT is still a vague buzzword for many people. In his session at @ThingsExpo, Mike Kavis, Vice President & Principal Cloud Architect at Cloud Technology Partners, discussed the business value of IoT that goes far beyond the general public's perception that IoT is all about wearables and home consumer services. He also discussed how IoT is perceived by investors and how venture capitalist access this space. Other topics discussed were barriers to success, what is new, what is old, and what the future may hold. Mike Kavis is Vice President & Principal Cloud Architect at Cloud Technology Pa...
Dale Kim is the Director of Industry Solutions at MapR. His background includes a variety of technical and management roles at information technology companies. While his experience includes work with relational databases, much of his career pertains to non-relational data in the areas of search, content management, and NoSQL, and includes senior roles in technical marketing, sales engineering, and support engineering. Dale holds an MBA from Santa Clara University, and a BA in Computer Science from the University of California, Berkeley.
The Internet of Things (IoT) is rapidly in the process of breaking from its heretofore relatively obscure enterprise applications (such as plant floor control and supply chain management) and going mainstream into the consumer space. More and more creative folks are interconnecting everyday products such as household items, mobile devices, appliances and cars, and unleashing new and imaginative scenarios. We are seeing a lot of excitement around applications in home automation, personal fitness, and in-car entertainment and this excitement will bleed into other areas. On the commercial side, m...