| By Wolf Hengevoss, Chris Hearn | Article Rating: |
|
| October 22, 2004 12:00 AM EDT | Reads: |
24,211 |
Click Here to Download this story's .pdf file!
You know how to write good Java code and deployment to a server is no mystery either. But have you ever had to work in large development teams, maybe geographically dispersed (off-shoring...)? Ever had to address the pain of application software updates?
So often, when evaluating Java development tools, the focus is on productivity in writing code. While this is clearly important, it is essential not to underestimate the importance of managing the entire life cycle of an application - from setting up the development environment, to managing software delivery and maintaining the applications over the life cycle. The larger the project, the more critical this is, both from an efficiency and a financial point of view.
Over the past 30 years SAP has gathered in-depth experience in developing applications with large, geographically dispersed development teams. The delivery of software to the customer and the management of software upgrades and synchronizing these updates with customized code at the customer site are all issues that SAP has mastered. Now SAP is bringing the same high-quality approach to the Java world.
SAP Web Application Server
SAP Web Application Server is a key component of SAP's integration and application platform. SAP NetWeaver provides tool support for productive, model-driven and service-oriented Java development, but also, and this is key, an infrastructure that provides full-scale support for all phases of the life cycle - the Java Development Infrastructure (JDI). This infrastructure - tightly integrated with the SAP NetWeaver Developer Studio, delivered with the application server - reduces overall development TCO and provides for reliability and flexibility in the deployment and change management process.
Synchronized Team Development Made Easy
The JDI gives you the best of both worlds - you can still develop in Java in your local environment, but your team's work is also synchronized via a central development environment.
Within the JDI, the Design Time Repository (DTR) handles file versioning to ensure that all developers are working from the same set of code. Developers access the central service via the SAP NetWeaver Developer Studio, check out files, produce new versions in the local file system, and check them back in after successful local testing. In the DTR perspective, you can compare versions, check version or revision history, and so on. During development, you can synchronize repository and local file systems whenever you wish, or even interrupt the connection between the two and reconnect later.
From the DTR you can manage:
- Different versions of a development object in the same repository
- Multiple states of a software component (development and consolidation of several releases)
- Multiple users making modifications to the same development object (with conflict detection)
The DTR provides features for change management in a distributed, multiuser development environment. As you replace older versions of files with newer ones, the DTR handles this process centrally and keeps the version history. For more complex projects, though, you'll need more than that. Suppose modifications are occurring directly in end-users' systems, so various versions are being developed in parallel and multiple DTRs are in place. The version history is always deployed along with the files for global version history of the DTR. As a result, versions created in parallel are detected automatically across repository boundaries. Then there are times when, during code modifications, you may not want to have an earlier version automatically overwritten by updates - instead, the DTR supports the merging of two colliding versions, allowing you to combine the advantages of the newer version with your modifications. What's more, to reduce the maintenance effort as much as possible, you would want to integrate bug fixes from older releases into newer ones from the maintenance cycle. The DTR supports this, since changes are always deployed as a whole set of versions, instead of individually. This approach to change management means that the results are unaffected by the sequence in which the changes are applied. With its innovative approach to distributed development, the DTR enhances productivity and reduces costs of development throughout the whole product life cycle.
Component-Based Development for Efficient Projects
The JDI takes a component-based approach to development. A component hierarchy distinguishes multiple levels of granularity:
- Development objects - the finest level of granularity: Tables, Java classes, and project files that are stored as versioned files.
- Development components (DCs): The units of the development and build process - they group development objects into larger development components, whereby one DC can contain multiple DCs.
- Software components: The deployment and installation units that are made up of DCs represent larger building blocks of products.
- Product: The complete solution.
Component Build Service
Speed up the build process and avoid errors with the Component Build Service. Ever experience night-builds of complete applications that fail - followed by another 24-hour wait for the next build? With the JDI, these days are over.
Like the DTR, the Component Build Service (CBS) is a J2EE application that uses a database. It hosts all Java archives needed or produced during software development. For each software component state, a buildspace is set up to contain these archives. You can trigger a central build in the CBS at any time. Central builds apply to modified DCs only, along with any DCs that have dependencies with the changed archives.
This DC build approach allows you to correct errors in smaller chunks, reducing bug-fix cycle times. A failed build process will not affect the build process of any other DC.
The CBS also provides:
- J2EE cluster support for high performance
- Automated build scripts for Java development
- Automatic rebuild of dependent development components after changes to objects
Managing the Development Environment
The development process starts with the definition of a product in the Software Landscape Directory. Here you define which software components are used in the product and the dependencies between them.
This information is imported into the Change Management Service (CMS) where you define the environment for the developers. You create workspaces and buildspaces by defining a track that's used to describe the development environment for one software component state. Fill the buildspaces with all the libraries required for a development configuration. This in turn is imported as an XML file into the SAP NetWeaver Developer Studio, defining the access to those objects the developer needs for his/her task.
After development, the developer releases his/her work to the CMS again. Here the QM triggers the import into the consolidation system, after central releases approves and assembles a software component release. For the next release, it's not necessary to physically set up a new system; simply define a new track.
This gives you complete control of the product life cycle from product definition to application patches.
Key Takeaways
Let's summarize the advantages of this approach:
- The development infrastructure is set up and managed centrally.
- All sources are stored centrally in the DTR and retrieved for the central build process, and all archives are stored in the CBS, ensuring that you use the latest version of sources. You're assured a greater degree of safety when using archives.
- Clearly defining dependencies and encapsulating functions facilitates reuse and maintenance of development components.
- Distributed versioning and concurrency control allow you to manage large development projects taking place in different locations. Due to the DTR's versioning capabilities, modifications are not overwritten during updates, but can be integrated into the new version.
- You'll find a centrally managed system landscape - there's no need for each developer to know precisely where to deploy an archive.
Published October 22, 2004 Reads 24,211
Copyright © 2004 SYS-CON Media, Inc. — All Rights Reserved.
Syndicated stories and blog feeds, all rights reserved by the author.
More Stories By Wolf Hengevoss
Wolf Hengevoss is a member of the SAP NetWeaver product management team.
More Stories By Chris Hearn
Chris Hearn is the product marketing director, SAP NetWeaver. Educated at Oxford University, England, Chris has 20 years of experience in IT in a variety of roles.
![]() |
Unimpressed SAP dev team member 10/25/04 09:41:35 AM EDT | |||
Omigod! SAP now has software configuration management, incremental build and J2EE capabilities...stuff that's been around for years...and sounds like they invented it. All yours for mega Deutsch marks. Any other infomercials coming from other companies just thinking about joining the 21st century? |
||||
![]() |
Surprised 10/24/04 09:34:02 AM EDT | |||
Is this an advert or an article? How much do you think they get for it? |
||||
![]() |
Jeff Nowakowski 10/23/04 12:54:07 PM EDT | |||
I wonder how much SAP paid for this advertisement? By the way, CVS is free. |
||||
- Cloud People: A Who's Who of Cloud Computing
- New Relic Q1 2013 Blazes Past Growth Targets and Reaches 40,000 Active Customer Accounts
- Learn How To Use Google Apps Script
- Cloud Expo New York: Rethink IT and Reinvent Business with IBM SmartCloud
- Cloud Expo New York: API Security, Does My Business Need an OAuth Server?
- Session Topics: 12th Cloud Expo / Cloud Expo New York
- Cloud Expo NY: Best Practices for Delivering Oracle Database as a Service
- Measuring the Business Value of Cloud Computing
- Cloud Expo New York: Build Modern Business Applications
- Cloud Expo New York: Using APIs for Better Business Partnerships
- Five Big Data Features in SQL Server
- Cloud Expo New York: Evolving Cloud Computing Models
- Cloud People: A Who's Who of Cloud Computing
- New Relic Q1 2013 Blazes Past Growth Targets and Reaches 40,000 Active Customer Accounts
- Cloud Expo New York: Delivering Digital Marketing on the Cloud
- Learn How To Use Google Apps Script
- Cloud Expo New York: Rethink IT and Reinvent Business with IBM SmartCloud
- Cloud Expo New York: API Security, Does My Business Need an OAuth Server?
- Cloudant to Exhibit at Cloud Expo & Big Data Expo New York
- Cloud Expo New York: Basics of SSD Technology and Its Use in Cloud
- Session Topics: 12th Cloud Expo / Cloud Expo New York
- The Accessibility of the Cloud
- Cloud Expo NY: Best Practices for Delivering Oracle Database as a Service
- Cloud Expo New York: Real-Time Analytics Using an In-Memory Data Grid
- A Cup of AJAX? Nay, Just Regular Java Please
- Java Developer's Journal Exclusive: 2006 "JDJ Editors' Choice" Awards
- JavaServer Faces (JSF) vs Struts
- The i-Technology Right Stuff
- Rich Internet Applications with Adobe Flex 2 and Java
- Java vs C++ "Shootout" Revisited
- Bean-Managed Persistence Using a Proxy List
- Reporting Made Easy with JasperReports and Hibernate
- Creating a Pet Store Application with JavaServer Faces, Spring, and Hibernate
- Why Do 'Cool Kids' Choose Ruby or PHP to Build Websites Instead of Java?
- What's New in Eclipse?
- Where Are RIA Technologies Headed in 2008?





















