Looking for breakthrough ideas for innovation challenges? Try Patsnap Eureka!

System and method for intelligently distributing source files within a distributed program build architecture

a distributed program and build architecture technology, applied in the field of computer aided software engineering, can solve the problems of unsatisfactory dependency information in makefiles, complex dependency structure, and complex build process

Active Publication Date: 2009-05-26
CLOUDBEES INC +1
View PDF23 Cites 65 Cited by
  • Summary
  • Abstract
  • Description
  • Claims
  • Application Information

AI Technical Summary

Benefits of technology

, each of the approaches described above offers the potential for speeding up builds, but each makes the build process more brittle by increasing the risk that a build will fail or that it will be inconsistent with the sources. Of the 30 commercial software development teams surveyed, none had been able to achieve more than a 5-10× speedup in a reliable enough way to use for production builds, and only a very few have achieved even a 5× speedup. Most organizations run their builds completely sequentially or with only a small speedup, in order to keep the process as reliable as possible.

Problems solved by technology

Even a modest-size project can have thousands of files, resulting in an extremely complex dependency structure.
In addition, Makefiles may be arranged in a hierarchical structure with higher-level Makefiles invoking lower-level Makefiles to build pieces of the project, adding additional complexity to the build process.
In principle, nightly builds could be incremental, but in practice the dependency information in Makefiles isn't perfect, so the only way to guarantee consistency between the sources and the compiled version is to build from scratch.
Furthermore, integration points (where developers update their personal workspaces with all the recent changes to the shared repository) typically result in massive recompilation.
Because of the size of modern software projects, clean builds can take a long time.
Long build times have a high cost for companies where software development is mission-critical.
Unfortunately, the dependency information in Makefiles is rarely perfect, especially in large projects with hierarchical Makefiles.
As a result, parallel builds tend to reorder the build steps in ways that break the build.
For example, a library might be used to link an application before the library has been regenerated, so the resulting application does not accurately reflect the state of the library's sources.
Bugs like these are very difficult to track down (the source looks good, but the application doesn't behave correctly).
In addition to out-of-order problems, multiprocessor scalability limits parallel build speed.
Multiprocessor servers typically have only 2-8 CPUs, which limits the potential speedup.
Larger-scale multiprocessors may have as many as 32 or 64 CPUs, but these machines are quite expensive ($30K per CPU or more, compared to $1-2K per CPU for workstations and small servers).
In addition, bottlenecks within the operating system may prevent an application from taking full advantage of large-scale multiprocessors.
This approach solves the scalability and cost issues with a multiprocessor, but still suffers from out-of-order issues.
In addition, distributed builds can be impacted by a variety of distributed-system issues including, for example, high overheads for invoking tasks on remote machines which can limit performance; clocks on each of the machines must be carefully synchronized or file timestamps won't be consistent and future builds may fail (a target may appear to be up-to-date even when it isn't); reliability drops as the cluster size increases due to the lack of recovery mechanisms; and cluster nodes typically use a network file system to access files, which can be considerably slower than accessing files locally on a single build machine.
Furthermore, reliability issues in the network file system can affect build reliability.
In summary, each of the approaches described above offers the potential for speeding up builds, but each makes the build process more brittle by increasing the risk that a build will fail or that it will be inconsistent with the sources.
Of the 30 commercial software development teams surveyed, none had been able to achieve more than a 5-10× speedup in a reliable enough way to use for production builds, and only a very few have achieved even a 5× speedup.

Method used

the structure of the environmentally friendly knitted fabric provided by the present invention; figure 2 Flow chart of the yarn wrapping machine for environmentally friendly knitted fabrics and storage devices; image 3 Is the parameter map of the yarn covering machine
View more

Image

Smart Image Click on the blue labels to locate them in the text.
Viewing Examples
Smart Image
  • System and method for intelligently distributing source files within a distributed program build architecture
  • System and method for intelligently distributing source files within a distributed program build architecture
  • System and method for intelligently distributing source files within a distributed program build architecture

Examples

Experimental program
Comparison scheme
Effect test

Embodiment Construction

[0050]In the following description, for the purposes of explanation, numerous specific details are set forth in order to provide a thorough understanding of the present invention. It will be apparent, however, to one skilled in the art that the present invention may be practiced without some of these specific details. In other instances, well-known structures and devices are shown in block diagram form to avoid obscuring the underlying principles of the present invention.

[0051]The assignee of the present application has developed a distributed build system which employs sophisticated techniques for monitoring and analysis during the program build process to enable high levels of parallelism. Many of these techniques are described in the co-pending applications entitled Architecture and Method For Executing Program Builds, Filed Mar. 25, 2003, Ser. No. 10 / 397,995. Certain aspects of the distributed build system will now be described followed by a description of a system and method fo...

the structure of the environmentally friendly knitted fabric provided by the present invention; figure 2 Flow chart of the yarn wrapping machine for environmentally friendly knitted fabrics and storage devices; image 3 Is the parameter map of the yarn covering machine
Login to View More

PUM

No PUM Login to View More

Abstract

A method implemented within a distributed build system is described comprising: transmitting a first source file from a program build file repository to a first node, the first node using the source file to generate a target file identified in the build process; receiving a request for the first source file from a second node; and redirecting the second node to retrieve the first source file from the first node rather than from the program build file repository.

Description

PRIORITY[0001]This application is a continuation-in-part of the following applications:[0002]U.S. application Ser. No. 10 / 397,995, filed Mar. 25, 2003, entitled Architecture and Method for Executing Program Builds;[0003]U.S. application Ser. No. 10 / 397,573, filed Mar. 25, 2003, now U.S. Pat. No. 7,263,695 entitled System and Method for Processing Recursive Invocations Within a Program Build;[0004]U.S. application Ser. No. 10 / 397,139, filed Mar. 25, 2003, now U.S. Pat. No. 7,086,063 entitled System and Method for File Caching Within a Distributed Program Build Environment;[0005]U.S. application Ser. No. 10 / 397,690, filed Mar. 25, 2003, entitled Conflict Detection and Correction in a Program Build Environment; and[0006]U.S. application Ser. No. 10 / 397,880, filed Mar. 25, 2003, now U.S. Pat. No. 7,168,064 entitled System and Method for Supplementing Program Builds With File Usage Information.BACKGROUND[0007]1. Field of the Invention[0008]This invention relates generally to the field of...

Claims

the structure of the environmentally friendly knitted fabric provided by the present invention; figure 2 Flow chart of the yarn wrapping machine for environmentally friendly knitted fabrics and storage devices; image 3 Is the parameter map of the yarn covering machine
Login to View More

Application Information

Patent Timeline
no application Login to View More
IPC IPC(8): G06F9/44
CPCG06F8/71
Inventor OUSTERHOUT, JOHNDELMAS, SVENMELSKI, JOHN ERICSTANTON, SCOTTTAMHANKAR, SANDEEP
Owner CLOUDBEES INC
Who we serve
  • R&D Engineer
  • R&D Manager
  • IP Professional
Why Patsnap Eureka
  • Industry Leading Data Capabilities
  • Powerful AI technology
  • Patent DNA Extraction
Social media
Patsnap Eureka Blog
Learn More
PatSnap group products