|By Brian Surkan||
|June 22, 2000 12:00 AM EDT||
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.
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.
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.
"Once customers get a year into their IoT deployments, they start to realize that they may have been shortsighted in the ways they built out their deployment and the key thing I see a lot of people looking at is - how can I take equipment data, pull it back in an IoT solution and show it in a dashboard," stated Dave McCarthy, Director of Products at Bsquare Corporation, in this SYS-CON.tv interview at @ThingsExpo, held November 1-3, 2016, at the Santa Clara Convention Center in Santa Clara, CA.
Dec. 3, 2016 11:00 PM EST Reads: 949
The cloud promises new levels of agility and cost-savings for Big Data, data warehousing and analytics. But it’s challenging to understand all the options – from IaaS and PaaS to newer services like HaaS (Hadoop as a Service) and BDaaS (Big Data as a Service). In her session at @BigDataExpo at @ThingsExpo, Hannah Smalltree, a director at Cazena, provided an educational overview of emerging “as-a-service” options for Big Data in the cloud. This is critical background for IT and data professionals...
Dec. 3, 2016 11:00 PM EST Reads: 4,131
Fact is, enterprises have significant legacy voice infrastructure that’s costly to replace with pure IP solutions. How can we bring this analog infrastructure into our shiny new cloud applications? There are proven methods to bind both legacy voice applications and traditional PSTN audio into cloud-based applications and services at a carrier scale. Some of the most successful implementations leverage WebRTC, WebSockets, SIP and other open source technologies. In his session at @ThingsExpo, Da...
Dec. 3, 2016 09:30 PM EST Reads: 1,599
As data explodes in quantity, importance and from new sources, the need for managing and protecting data residing across physical, virtual, and cloud environments grow with it. Managing data includes protecting it, indexing and classifying it for true, long-term management, compliance and E-Discovery. Commvault can ensure this with a single pane of glass solution – whether in a private cloud, a Service Provider delivered public cloud or a hybrid cloud environment – across the heterogeneous enter...
Dec. 3, 2016 06:15 PM EST Reads: 1,513
"IoT is going to be a huge industry with a lot of value for end users, for industries, for consumers, for manufacturers. How can we use cloud to effectively manage IoT applications," stated Ian Khan, Innovation & Marketing Manager at Solgeniakhela, in this SYS-CON.tv interview at @ThingsExpo, held November 3-5, 2015, at the Santa Clara Convention Center in Santa Clara, CA.
Dec. 3, 2016 05:30 PM EST Reads: 4,045
Today we can collect lots and lots of performance data. We build beautiful dashboards and even have fancy query languages to access and transform the data. Still performance data is a secret language only a couple of people understand. The more business becomes digital the more stakeholders are interested in this data including how it relates to business. Some of these people have never used a monitoring tool before. They have a question on their mind like “How is my application doing” but no id...
Dec. 3, 2016 05:15 PM EST Reads: 2,138
@GonzalezCarmen has been ranked the Number One Influencer and @ThingsExpo has been named the Number One Brand in the “M2M 2016: Top 100 Influencers and Brands” by Onalytica. Onalytica analyzed tweets over the last 6 months mentioning the keywords M2M OR “Machine to Machine.” They then identified the top 100 most influential brands and individuals leading the discussion on Twitter.
Dec. 3, 2016 05:15 PM EST Reads: 2,001
Information technology is an industry that has always experienced change, and the dramatic change sweeping across the industry today could not be truthfully described as the first time we've seen such widespread change impacting customer investments. However, the rate of the change, and the potential outcomes from today's digital transformation has the distinct potential to separate the industry into two camps: Organizations that see the change coming, embrace it, and successful leverage it; and...
Dec. 3, 2016 03:15 PM EST Reads: 3,225
The Internet of Things (IoT) promises to simplify and streamline our lives by automating routine tasks that distract us from our goals. This promise is based on the ubiquitous deployment of smart, connected devices that link everything from industrial control systems to automobiles to refrigerators. Unfortunately, comparatively few of the devices currently deployed have been developed with an eye toward security, and as the DDoS attacks of late October 2016 have demonstrated, this oversight can ...
Dec. 3, 2016 02:45 PM EST Reads: 715
Extracting business value from Internet of Things (IoT) data doesn’t happen overnight. There are several requirements that must be satisfied, including IoT device enablement, data analysis, real-time detection of complex events and automated orchestration of actions. Unfortunately, too many companies fall short in achieving their business goals by implementing incomplete solutions or not focusing on tangible use cases. In his general session at @ThingsExpo, Dave McCarthy, Director of Products...
Dec. 3, 2016 02:45 PM EST Reads: 529
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 impr...
Dec. 3, 2016 02:15 PM EST Reads: 6,957
More and more brands have jumped on the IoT bandwagon. We have an excess of wearables – activity trackers, smartwatches, smart glasses and sneakers, and more that track seemingly endless datapoints. However, most consumers have no idea what “IoT” means. Creating more wearables that track data shouldn't be the aim of brands; delivering meaningful, tangible relevance to their users should be. We're in a period in which the IoT pendulum is still swinging. Initially, it swung toward "smart for smar...
Dec. 3, 2016 02:00 PM EST Reads: 483
20th Cloud Expo, taking place June 6-8, 2017, at the Javits Center in New York City, NY, 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.
Dec. 3, 2016 01:30 PM EST Reads: 2,131
Businesses and business units of all sizes can benefit from cloud computing, but many don't want the cost, performance and security concerns of public cloud nor the complexity of building their own private clouds. Today, some cloud vendors are using artificial intelligence (AI) to simplify cloud deployment and management. In his session at 20th Cloud Expo, Ajay Gulati, Co-founder and CEO of ZeroStack, will discuss how AI can simplify cloud operations. He will cover the following topics: why clou...
Dec. 3, 2016 01:15 PM EST Reads: 634
Internet of @ThingsExpo, taking place June 6-8, 2017 at the Javits Center in New York City, New York, is co-located with the 20th International Cloud Expo and will feature technical sessions from a rock star conference faculty and the leading industry players in the world. @ThingsExpo New York Call for Papers is now open.
Dec. 3, 2016 01:00 PM EST Reads: 1,876
"ReadyTalk is an audio and web video conferencing provider. We've really come to embrace WebRTC as the platform for our future of technology," explained Dan Cunningham, CTO of ReadyTalk, in this SYS-CON.tv interview at WebRTC Summit at 19th Cloud Expo, held November 1-3, 2016, at the Santa Clara Convention Center in Santa Clara, CA.
Dec. 3, 2016 01:00 PM EST Reads: 331
Successful digital transformation requires new organizational competencies and capabilities. Research tells us that the biggest impediment to successful transformation is human; consequently, the biggest enabler is a properly skilled and empowered workforce. In the digital age, new individual and collective competencies are required. In his session at 19th Cloud Expo, Bob Newhouse, CEO and founder of Agilitiv, drew together recent research and lessons learned from emerging and established compa...
Dec. 3, 2016 12:45 PM EST Reads: 741
Data is the fuel that drives the machine learning algorithmic engines and ultimately provides the business value. In his session at Cloud Expo, Ed Featherston, a director and senior enterprise architect at Collaborative Consulting, discussed the key considerations around quality, volume, timeliness, and pedigree that must be dealt with in order to properly fuel that engine.
Dec. 3, 2016 12:45 PM EST Reads: 1,956
Everyone knows that truly innovative companies learn as they go along, pushing boundaries in response to market changes and demands. What's more of a mystery is how to balance innovation on a fresh platform built from scratch with the legacy tech stack, product suite and customers that continue to serve as the business' foundation. In his General Session at 19th Cloud Expo, Michael Chambliss, Head of Engineering at ReadyTalk, discussed why and how ReadyTalk diverted from healthy revenue and mor...
Dec. 3, 2016 12:15 PM EST Reads: 1,512
We are always online. We access our data, our finances, work, and various services on the Internet. But we live in a congested world of information in which the roads were built two decades ago. The quest for better, faster Internet routing has been around for a decade, but nobody solved this problem. We’ve seen band-aid approaches like CDNs that attack a niche's slice of static content part of the Internet, but that’s it. It does not address the dynamic services-based Internet of today. It does...
Dec. 3, 2016 11:30 AM EST Reads: 857