Grid computing explained

Grid computing is the use of widely distributed computer resources to reach a common goal. A computing grid can be thought of as a distributed system with non-interactive workloads that involve many files. Grid computing is distinguished from conventional high-performance computing systems such as cluster computing in that grid computers have each node set to perform a different task/application. Grid computers also tend to be more heterogeneous and geographically dispersed (thus not physically coupled) than cluster computers.[1] Although a single grid can be dedicated to a particular application, commonly a grid is used for a variety of purposes. Grids are often constructed with general-purpose grid middleware software libraries. Grid sizes can be quite large.[2]

Grids are a form of distributed computing composed of many networked loosely coupled computers acting together to perform large tasks. For certain applications, distributed or grid computing can be seen as a special type of parallel computing that relies on complete computers (with onboard CPUs, storage, power supplies, network interfaces, etc.) connected to a computer network (private or public) by a conventional network interface, such as Ethernet. This is in contrast to the traditional notion of a supercomputer, which has many processors connected by a local high-speed computer bus. This technology has been applied to computationally intensive scientific, mathematical, and academic problems through volunteer computing, and it is used in commercial enterprises for such diverse applications as drug discovery, economic forecasting, seismic analysis, and back office data processing in support for e-commerce and Web services.

Grid computing combines computers from multiple administrative domains to reach a common goal,[3] to solve a single task, and may then disappear just as quickly. The size of a grid may vary from small—confined to a network of computer workstations within a corporation, for example—to large, public collaborations across many companies and networks. "The notion of a confined grid may also be known as an intra-nodes cooperation whereas the notion of a larger, wider grid may thus refer to an inter-nodes cooperation".[4]

Coordinating applications on Grids can be a complex task, especially when coordinating the flow of information across distributed computing resources. Grid workflow systems have been developed as a specialized form of a workflow management system designed specifically to compose and execute a series of computational or data manipulation steps, or a workflow, in the grid context.

Comparison of grids and conventional supercomputers

“Distributed” or “grid” computing in general is a special type of parallel computing that relies on complete computers (with onboard CPUs, storage, power supplies, network interfaces, etc.) connected to a network (private, public or the Internet) by a conventional network interface producing commodity hardware, compared to the lower efficiency of designing and constructing a small number of custom supercomputers. The primary performance disadvantage is that the various processors and local storage areas do not have high-speed connections. This arrangement is thus well-suited to applications in which multiple parallel computations can take place independently, without the need to communicate intermediate results between processors.[5] The high-end scalability of geographically dispersed grids is generally favorable, due to the low need for connectivity between nodes relative to the capacity of the public Internet.[6]

There are also some differences between programming for a supercomputer and programming for a grid computing system. It can be costly and difficult to write programs that can run in the environment of a supercomputer, which may have a custom operating system, or require the program to address concurrency issues. If a problem can be adequately parallelized, a “thin” layer of “grid” infrastructure can allow conventional, standalone programs, given a different part of the same problem, to run on multiple machines. This makes it possible to write and debug on a single conventional machine and eliminates complications due to multiple instances of the same program running in the same shared memory and storage space at the same time.

Design considerations and variations

One feature of distributed grids is that they can be formed from computing resources belonging to one or multiple individuals or organizations (known as multiple administrative domains). This can facilitate commercial transactions, as in utility computing, or make it easier to assemble volunteer computing networks.

One disadvantage of this feature is that the computers which are actually performing the calculations might not be entirely trustworthy. The designers of the system must thus introduce measures to prevent malfunctions or malicious participants from producing false, misleading, or erroneous results, and from using the system as an attack vector. This often involves assigning work randomly to different nodes (presumably with different owners) and checking that at least two different nodes report the same answer for a given work unit. Discrepancies would identify malfunctioning and malicious nodes. However, due to the lack of central control over the hardware, there is no way to guarantee that nodes will not drop out of the network at random times. Some nodes (like laptops or dial-up Internet customers) may also be available for computation but not network communications for unpredictable periods. These variations can be accommodated by assigning large work units (thus reducing the need for continuous network connectivity) and reassigning work units when a given node fails to report its results in the expected time.

Another set of what could be termed social compatibility issues in the early days of grid computing related to the goals of grid developers to carry their innovation beyond the original field of high-performance computing and across disciplinary boundaries into new fields, like that of high-energy physics.[7]

The impacts of trust and availability on performance and development difficulty can influence the choice of whether to deploy onto a dedicated cluster, to idle machines internal to the developing organization, or to an open external network of volunteers or contractors. In many cases, the participating nodes must trust the central system not to abuse the access that is being granted, by interfering with the operation of other programs, mangling stored information, transmitting private data, or creating new security holes. Other systems employ measures to reduce the amount of trust “client” nodes must place in the central system such as placing applications in virtual machines.

Public systems or those crossing administrative domains (including different departments in the same organization) often result in the need to run on heterogeneous systems, using different operating systems and hardware architectures. With many languages, there is a trade-off between investment in software development and the number of platforms that can be supported (and thus the size of the resulting network). Cross-platform languages can reduce the need to make this tradeoff, though potentially at the expense of high performance on any given node (due to run-time interpretation or lack of optimization for the particular platform). Various middleware projects have created generic infrastructure to allow diverse scientific and commercial projects to harness a particular associated grid or for the purpose of setting up new grids. BOINC is a common one for various academic projects seeking public volunteers; more are listed at the end of the article.

In fact, the middleware can be seen as a layer between the hardware and the software. On top of the middleware, a number of technical areas have to be considered, and these may or may not be middleware independent. Example areas include SLA management, Trust, and Security, Virtual organization management, License Management, Portals and Data Management. These technical areas may be taken care of in a commercial solution, though the cutting edge of each area is often found within specific research projects examining the field.

Market segmentation of the grid computing market

For the segmentation of the grid computing market, two perspectives need to be considered: the provider side and the user side:

The provider side

The overall grid market comprises several specific markets. These are the grid middleware market, the market for grid-enabled applications, the utility computing market, and the software-as-a-service (SaaS) market.

Grid middleware is a specific software product, which enables the sharing of heterogeneous resources, and Virtual Organizations. It is installed and integrated into the existing infrastructure of the involved company or companies and provides a special layer placed among the heterogeneous infrastructure and the specific user applications. Major grid middlewares are Globus Toolkit, gLite, and UNICORE.

Utility computing is referred to as the provision of grid computing and applications as service either as an open grid utility or as a hosting solution for one organization or a VO. Major players in the utility computing market are Sun Microsystems, IBM, and HP.

Grid-enabled applications are specific software applications that can utilize grid infrastructure. This is made possible by the use of grid middleware, as pointed out above.

Software as a service (SaaS) is “software that is owned, delivered and managed remotely by one or more providers.” (Gartner 2007) Additionally, SaaS applications are based on a single set of common code and data definitions. They are consumed in a one-to-many model, and SaaS uses a Pay As You Go (PAYG) model or a subscription model that is based on usage. Providers of SaaS do not necessarily own the computing resources themselves, which are required to run their SaaS. Therefore, SaaS providers may draw upon the utility computing market. The utility computing market provides computing resources for SaaS providers.

The user side

For companies on the demand or user side of the grid computing market, the different segments have significant implications for their IT deployment strategy. The IT deployment strategy as well as the type of IT investments made are relevant aspects for potential grid users and play an important role for grid adoption.

CPU scavenging

CPU-scavenging, cycle-scavenging, or shared computing creates a “grid” from the idle resources in a network of participants (whether worldwide or internal to an organization). Typically, this technique exploits the 'spare' instruction cycles resulting from the intermittent inactivity that typically occurs at night, during lunch breaks, or even during the (comparatively minuscule, though numerous) moments of idle waiting that modern desktop CPU's experience throughout the day (when the computer is waiting on IO from the user, network, or storage). In practice, participating computers also donate some supporting amount of disk storage space, RAM, and network bandwidth, in addition to raw CPU power.

Many volunteer computing projects, such as BOINC, use the CPU scavenging model. Since nodes are likely to go "offline" from time to time, as their owners use their resources for their primary purpose, this model must be designed to handle such contingencies.

Creating an Opportunistic Environment is another implementation of CPU-scavenging where special workload management system harvests the idle desktop computers for compute-intensive jobs, it also refers as Enterprise Desktop Grid (EDG). For instance, HTCondor[8] (the open-source high-throughput computing software framework for coarse-grained distributed rationalization of computationally intensive tasks) can be configured to only use desktop machines where the keyboard and mouse are idle to effectively harness wasted CPU power from otherwise idle desktop workstations. Like other full-featured batch systems, HTCondor provides a job queueing mechanism, scheduling policy, priority scheme, resource monitoring, and resource management. It can be used to manage workload on a dedicated cluster of computers as well or it can seamlessly integrate both dedicated resources (rack-mounted clusters) and non-dedicated desktop machines (cycle scavenging) into one computing environment.

History

The term grid computing originated in the early 1990s as a metaphor for making computer power as easy to access as an electric power grid. The power grid metaphor for accessible computing quickly became canonical when Ian Foster and Carl Kesselman published their seminal work, "The Grid: Blueprint for a new computing infrastructure" (1999). This was preceded by decades by the metaphor of utility computing (1961): computing as a public utility, analogous to the phone system.[9] [10]

CPU scavenging and volunteer computing were popularized beginning in 1997 by distributed.net and later in 1999 by SETI@home to harness the power of networked PCs worldwide, in order to solve CPU-intensive research problems.[11] [12]

The ideas of the grid (including those from distributed computing, object-oriented programming, and Web services) were brought together by Ian Foster and Steve Tuecke of the University of Chicago, and Carl Kesselman of the University of Southern California's Information Sciences Institute.[13] The trio, who led the effort to create the Globus Toolkit, is widely regarded as the "fathers of the grid".[14] The toolkit incorporates not just computation management but also storage management, security provisioning, data movement, monitoring, and a toolkit for developing additional services based on the same infrastructure, including agreement negotiation, notification mechanisms, trigger services, and information aggregation.[15] While the Globus Toolkit remains the de facto standard for building grid solutions, a number of other tools have been built that answer some subset of services needed to create an enterprise or global grid.

In 2007 the term cloud computing came into popularity, which is conceptually similar to the canonical Foster definition of grid computing (in terms of computing resources being consumed as electricity is from the power grid) and earlier utility computing.

Progress

In November 2006, Seidel received the Sidney Fernbach Award at the Supercomputing Conference in Tampa, Florida.[16] "For outstanding contributions to the development of software for HPC and Grid computing to enable the collaborative numerical investigation of complex problems in physics; in particular, modeling black hole collisions."[17] This award, which is one of the highest honors in computing, was awarded for his achievements in numerical relativity.

Fastest virtual supercomputers

Also, as of March 2019, the Bitcoin Network had a measured computing power equivalent to over 80,000 exaFLOPS (Floating-point Operations Per Second).[25] This measurement reflects the number of FLOPS required to equal the hash output of the Bitcoin network rather than its capacity for general floating-point arithmetic operations, since the elements of the Bitcoin network (Bitcoin mining ASICs) perform only the specific cryptographic hash computation required by the Bitcoin protocol.

Projects and applications

Grid computing offers a way to solve Grand Challenge problems such as protein folding, financial modeling, earthquake simulation, and climate/weather modeling, and was integral in enabling the Large Hadron Collider at CERN.[26] Grids offer a way of using information technology resources optimally inside an organization. They also provide a means for offering information technology as a utility for commercial and noncommercial clients, with those clients paying only for what they use, as with electricity or water.

As of October 2016, over 4 million machines running the open-source Berkeley Open Infrastructure for Network Computing (BOINC) platform are members of the World Community Grid. One of the projects using BOINC is SETI@home, which was using more than 400,000 computers to achieve 0.828 TFLOPS as of October 2016. As of October 2016 Folding@home, which is not part of BOINC, achieved more than 101 x86-equivalent petaflops on over 110,000 machines.

The European Union funded projects through the framework programmes of the European Commission. BEinGRID (Business Experiments in Grid) was a research project funded by the European Commission[27] as an Integrated Project under the Sixth Framework Programme (FP6) sponsorship program. Started on June 1, 2006, the project ran 42 months, until November 2009. The project was coordinated by Atos Origin. According to the project fact sheet, their mission is “to establish effective routes to foster the adoption of grid computing across the EU and to stimulate research into innovative business models using Grid technologies”. To extract best practice and common themes from the experimental implementations, two groups of consultants are analyzing a series of pilots, one technical, one business. The project is significant not only for its long duration but also for its budget, which at 24.8 million Euros, is the largest of any FP6 integrated project. Of this, 15.7 million is provided by the European Commission and the remainder by its 98 contributing partner companies. Since the end of the project, the results of BEinGRID have been taken up and carried forward by IT-Tude.com.

The Enabling Grids for E-sciencE project, based in the European Union and included sites in Asia and the United States, was a follow-up project to the European DataGrid (EDG) and evolved into the European Grid Infrastructure. This, along with the Worldwide LHC Computing Grid[28] (WLCG), was developed to support experiments using the CERN Large Hadron Collider. A list of active sites participating within WLCG can be found online[29] as can real time monitoring of the EGEE infrastructure.[30] The relevant software and documentation is also publicly accessible.[31] There is speculation that dedicated fiber optic links, such as those installed by CERN to address the WLCG's data-intensive needs, may one day be available to home users thereby providing internet services at speeds up to 10,000 times faster than a traditional broadband connection.[32] The European Grid Infrastructure has been also used for other research activities and experiments such as the simulation of oncological clinical trials.[33]

The distributed.net project was started in 1997.The NASA Advanced Supercomputing facility (NAS) ran genetic algorithms using the Condor cycle scavenger running on about 350 Sun Microsystems and SGI workstations.

In 2001, United Devices operated the United Devices Cancer Research Project based on its Grid MP product, which cycle-scavenges on volunteer PCs connected to the Internet. The project ran on about 3.1 million machines before its close in 2007.[34]

Definitions

Today there are many definitions of grid computing:

See also

List of grid computing projects

Related concepts

Alliances and organizations

Production grids

International projects

NameRegionStartEnd
European Grid Infrastructure (EGI)EuropeMay 2010Dec 2014
Open Middleware Infrastructure Institute Europe (OMII-Europe)EuropeMay 2006May 2008
Enabling Grids for E-sciencE (EGEE, EGEE II and EGEE III)EuropeMarch 2004April 2010
Grid enabled Remote Instrumentation with Distributed Control and Computation (GridCC)EuropeSeptember 2005September 2008
European Middleware Initiative (EMI)EuropeMay 2010active
KnowARCEuropeJune 2006November 2009
Nordic Data Grid FacilityScandinavia and FinlandJune 2006December 2012
World Community GridGlobalNovember 2004active
XtreemOSEuropeJune 2006(May 2010) ext. to September 2010
OurGridBrazilDecember 2004active

National projects

Standards and APIs

Monitoring frameworks

References

Bibliography

Notes and References

  1. http://www.e-sciencecity.org/EN/gridcafe/what-is-the-grid.html What is grid computing? - Gridcafe
  2. Web site: Scale grid computing down to size . NetworkWorld.com . 2003-01-27 . 2015-04-21 . 2023-12-06 . https://web.archive.org/web/20231206075823/https://www.networkworld.com/article/893875/software-scale-grid-computing-down-to-size.html . live .
  3. Web site: What is the Grid? A Three Point Checklist. 2010-10-21. 2014-11-22. https://web.archive.org/web/20141122035905/http://dlib.cs.odu.edu/WhatIsTheGrid.pdf. dead.
  4. Web site: Pervasive and Artificial Intelligence Group :: publications [Pervasive and Artificial Intelligence Research Group] |publisher=Diuf.unifr.ch |date=May 18, 2009 |access-date=July 29, 2010 |archive-url=https://web.archive.org/web/20110707004350/http://diuf.unifr.ch/pai/wiki/doku.php?id=Publications&page=publication&kind=single&ID=276 |archive-date=July 7, 2011 |url-status=dead ].
  5. http://www.e-sciencecity.org/EN/gridcafe/computational-problems.html Computational problems - Gridcafe
  6. Web site: What is grid computing? . 2022-03-23 . IONOS Digitalguide . en . 2022-01-28 . https://web.archive.org/web/20220128110848/https://www.ionos.com/digitalguide/server/know-how/grid-computing/ . live .
  7. Kertcher. Zack. Coslor. Erica. 2018-07-10. Boundary Objects and the Technical Culture Divide: Successful Practices for Voluntary Innovation Teams Crossing Scientific and Professional Fields. Journal of Management Inquiry. 29. en. 76–91. 10.1177/1056492618783875. 1056-4926. 11343/212143. 149911242. free. 2019-09-18. 2022-03-28. https://web.archive.org/web/20220328181127/https://minerva-access.unimelb.edu.au/bitstream/11343/212143/5/Kertcher%20%26%20Coslor%20-%20Boundary%20Objects%20and%20the%20Technical%20Culture%20Divide%202018-02-13.pdf. live.
  8. Web site: HTCondor - Home. research.cs.wisc.edu. 14 March 2018. 2 March 2018. https://web.archive.org/web/20180302205500/http://research.cs.wisc.edu/htcondor/. live.
  9. [John McCarthy (computer scientist)|John McCarthy]
  10. Book: Architects of the Information Society, Thirty-Five Years of the Laboratory for Computer Science at MIT. Hal. Abelson. Simson. Garfinkel. 978-0-262-07196-3. MIT Press. 1999. registration.
  11. Anderson. David P. Cobb. etal. Jeff. SETI@home: an experiment in public-resource computing. Communications of the ACM. November 2002. 45. 11. 56–61. 10.1145/581571.581573. 15439521.
  12. Nouman Durrani. Muhammad. Shamsi. Jawwad A.. Volunteer computing: requirements, challenges, and solutions. Journal of Network and Computer Applications. March 2014. 39. 369–380. 10.1016/j.jnca.2013.07.006.
  13. Web site: Johnson . Bridget . 2019-11-06 . Grid Computing Pioneer Steve Tuecke Passes Away at 52 . 2022-11-04 . en-US . 2022-11-04 . https://web.archive.org/web/20221104213215/https://www.hstoday.us/subject-matter-areas/cybersecurity/grid-computing-pioneer-steve-tuecke-passes-away-at-52/ . live .
  14. Web site: Father of the Grid. 2007-04-15. 2012-03-01. https://web.archive.org/web/20120301194142/http://magazine.uchicago.edu/0404/features/index.shtml. live.
  15. Book: Salem, M. . Grid Computing: A New Paradigm for Healthcare Technologies/Applications . 2007 . 2022-08-30.
  16. Web site: Edward Seidel 2006 Sidney Fernbach Award Recipient. IEEE Computer Society Awards. IEEE Computer Society. 14 October 2011. https://web.archive.org/web/20110815212928/http://www.computer.org/portal/web/awards/seidel. 15 August 2011. dead.
  17. Web site: Edward Seidel • IEEE Computer Society. www.computer.org. 14 March 2018. https://web.archive.org/web/20110815212928/http://www.computer.org/portal/web/awards/seidel. 15 August 2011. dead.
  18. Web site: Pande lab . Client Statistics by OS . live . https://archive.today/20200412111010/https://stats.foldingathome.org/os . April 12, 2020 . March 26, 2020 . Folding@home . Stanford University.
  19. Web site: BOINCstats – BOINC combined credit overview. October 30, 2016. January 22, 2013. https://web.archive.org/web/20130122022019/http://boincstats.com/en/stats/-1/project/detail/. live.
  20. Web site: SDSC, Wisconsin U IceCube Center Conduct GPU Cloudburst Experiment. SDSC. April 22, 2022. September 14, 2022. https://web.archive.org/web/20220914153408/https://www.sdsc.edu/News%20Items/PR20191119_GPU_Cloudburst.html. live.
  21. Web site: Einstein@Home Credit overview. BOINC. October 30, 2016. August 27, 2016. https://web.archive.org/web/20160827063611/http://boincstats.com/en/stats/5/project/detail. live.
  22. Web site: SETI@Home Credit overview. BOINC. October 30, 2016. July 3, 2013. https://web.archive.org/web/20130703143037/http://boincstats.com/en/stats/0/project/detail. live.
  23. Web site: MilkyWay@Home Credit overview. BOINC. October 30, 2016. May 20, 2012. https://web.archive.org/web/20120520164005/http://boincstats.com/en/stats/61/project/detail. live.
  24. Web site: Internet PrimeNet Server Distributed Computing Technology for the Great Internet Mersenne Prime Search. GIMPS. March 12, 2019. May 25, 2019. https://web.archive.org/web/20190525223313/https://www.mersenne.org/primenet/. live.
  25. Web site: Bitcoin Network Statistics. bitcoinwatch.com. Bitcoin. March 12, 2019. January 20, 2023. https://web.archive.org/web/20230120182533/https://bitcoincharts.com/. live.
  26. Kertcher . Zack . Venkatraman . Rohan . Coslor . Erica . Pleasingly parallel: Early cross-disciplinary work for innovation diffusion across boundaries in grid computing . Journal of Business Research . 23 April 2020 . 116 . 581–594 . 10.1016/j.jbusres.2020.04.018 . 219048576 . 11343/237477 . free .
  27. Web site: beingrid.eu: Stromkosten Vergleiche -. beingrid.eu: Stromkosten Vergleiche. 14 March 2018. https://web.archive.org/web/20110723100417/http://www.beingrid.eu/. 23 July 2011. dead.
  28. Web site: Welcome to the Worldwide LHC Computing Grid - WLCG. wlcg.web.cern.ch. 14 March 2018. 25 July 2018. https://web.archive.org/web/20180725112849/http://wlcg.web.cern.ch/. live.
  29. Web site: GStat 2.0 – Summary View – GRID EGEE . Goc.grid.sinica.edu.tw . July 29, 2010 . https://web.archive.org/web/20080320145926/http://goc.grid.sinica.edu.tw/gstat/ . March 20, 2008 . dead .
  30. Web site: Real Time Monitor . Gridportal.hep.ph.ic.ac.uk . July 29, 2010 . dead . https://web.archive.org/web/20091216124323/http://gridportal.hep.ph.ic.ac.uk/rtm/ . December 16, 2009 .
  31. Web site: LCG – Deployment . Lcg.web.cern.ch . July 29, 2010 . https://web.archive.org/web/20101117002656/http://lcg.web.cern.ch/LCG/activities/deployment.html . November 17, 2010 . dead .
  32. Web site: The Times & The Sunday Times. thetimes.co.uk. 14 March 2018. 25 February 2021. https://web.archive.org/web/20210225020225/https://www.thetimes.co.uk/. live.
  33. Athanaileas, Theodoros. Exploiting grid technologies for the simulation of clinical trials: the paradigm of in silico radiation oncology . SIMULATION: Transactions of the Society for Modeling and Simulation International . 87 . 10 . 893–910 . 2011 . 10.1177/0037549710375437. 206429690 . etal.
  34. http://www.grid.org/stats/
  35. P Plaszczak, R Wellner, Grid computing, 2005, Elsevier/Morgan Kaufmann, San Francisco
  36. IBM Solutions Grid for Business Partners: Helping IBM Business Partners to Grid-enable applications for the next phase of e-business on demand
  37. http://www.multicians.org/fjcc3.html Structure of the Multics Supervisor
  38. Web site: A Gentle Introduction to Grid Computing and Technologies. May 6, 2005. March 24, 2006. https://web.archive.org/web/20060324161402/http://www.buyya.com/papers/GridIntro-CSI2005.pdf. live.