Making Scientific Software Installation Reproducible on Cray Systems

Total Page:16

File Type:pdf, Size:1020Kb

Making Scientific Software Installation Reproducible on Cray Systems Making Scientific Software Installation Reproducible On Cray Systems Using EasyBuild Petar Forai Kenneth Hoste Research Institute of Ghent University Molecular Pathology Krijgslaan 281, S9 Dr Bohrgasse 7 B-9000 Ghent, Belgium A-1030 Vienna, Austria [email protected] [email protected] Guilherme Peretti-Pezzi Brett Bode Swiss National National Center for Supercomputing Centre Supercomputing Applications Via Trevano, 131 University of Illinois 6900 Lugano, Switzerland 1205 W. Clark St. [email protected] Urbana, IL 61801 [email protected] ABSTRACT 1. INTRODUCTION Cray provides a tuned and supported OS and programming The job of High-Performance Computing (HPC) support environment (PE), including compilers and libraries inte- teams is to enable the productive and efficient use of HPC grated with the modules system. While the Cray PE is resources. This ranges from helping out users by resolving updated frequently, tools and libraries not in it quickly be- issues like login problems or unexpected software crashes, come outdated. In addition, the amount of tools, libraries providing detailed answers to both simple and deeply tech- and scientific applications that HPC user support teams are nical questions, installing requested software libraries, tools expected to provide support for is increasing significantly. and applications, to providing services such as performance The uniformity of the software environment across Cray sites analysis and optimization of scientific software being devel- makes it an attractive target for to share this ubiquitous oped. burden, and to collaborate on a common solution. One particularly time-consuming task for HPC support teams EasyBuild is an open-source, community-driven framework is installing (scientific) software. Due to the advanced na- to automatically and reproducibly install (scientific) soft- ture of supercomputers (i.e., multiple multi-core processors, ware on HPC systems. This paper presents how EasyBuild high performance network interconnect, need for most re- has been integrated with the Cray PE, in order to leverage cent compilers and libraries, etc.), compiling software from the provided optimized components and support an easy source on the actual operating system and for the system way to deploy tools, libraries and scientific applications on architecture that it is going to be used on is typically highly Cray systems. preferred, if not required, as opposed to using readily avail- able binary packages that were built in a generic way. We will discuss the changes that needed to be made to Easy- Build to achieve this, and outline the use case of providing Support teams at HPC sites worldwide typically invest large the Python distribution and accompanying Python packages amounts of time and manpower tackling this tedious and on top of the Cray PE, to obtain a fully featured `batter- time consuming task of installing the (scientific) software ies included' optimized Python installation that integrates tools, libraries, and applications that researchers are re- with the Cray-provided software stack. In addition, we will questing, while trying to maintain a coherent software stack. outline how EasyBuild was deployed at the Swiss National Supercomputing Centre CSCS and how it is leveraged to EasyBuild is a recent software build and installation frame- obtain a consistent software stack and installation workflow work that intends to relieve HPC support teams from the across multiple Cray (XC, CS-Storm) and non-Cray HPC ubiquitous burden of installing scientific software on HPC systems. systems. It supports fully automating the (often complex) installation procedure of scientific software, and includes fea- tures specifically targeted towards HPC systems while pro- viding a flexible yet powerful interface. As such, it has quickly grown to become a platform for collaboration be- tween HPC sites worldwide. We discuss EasyBuild in more detail in Section 2. The time-consuming problem of getting scientific software installed also presents itself on Cray systems, despite the extensive programming environment that Cray usually pro- vides. Both HPC support teams and end users of Cray systems struggle on a daily basis with getting the required tools and applications up and running (let alone doing so in a somewhat optimal way). While a policy for providing and the particular compiler and libraries being employed; software installations in a consistent way to end users is a see also Section 2.3.6. common goal, the reality more often than not is that short- cuts are being taken to speed up the process, resulting in a software stack that is organised in a suboptimal (and some- 2.2 Terminology times outright confusing) manner, with little consistency in Before going into more detail, we introduce some terminol- the software stacks provided on different systems beyond ogy specific to EasyBuild that will be used throughout this what is provided by Cray. Hence, it is clear that EasyBuild paper. could also be useful on Cray systems. 2.2.1 EasyBuild framework Originally, the main target of EasyBuild was the standard The EasyBuild framework is the core of the tool that pro- GNU/Linux 64-bit x86 system architecture that is common- vides the functionality that is commonly needed for building place on today's HPC systems. On these systems there typ- and installing scientific software on HPC systems. It consists ically is an abundant lack of a decent (recent) basic software of a collection of Python modules that implement: stack, i.e., compilers and libraries for MPI, linear algebra, etc., to build scientific applications on top of. EasyBuild was designed to deal with this, by supporting the installation of compilers and accompanying libraries, and through the • the eb command line interface toolchain mechanism it employs (see Section 2.2.4). As such, it was not well suited to Cray systems, where a well equipped • an abstract software installation procedure, split up programming environment is provided that is highly recom- into different steps including configuring, building, test- mended to be used. ing, installing, etc. (see Section 2.3.1) • functions to perform common tasks like downloading In this paper, we present the changes that had to made to and unpacking source tarballs, applying patch files, au- EasyBuild to provide stable integration with the available tonomously running (interactive) shell commands and programming environment on Cray systems (see Section 3). capturing output & exit codes, generating module files, In addition, we outline the use case of installing Python and etc. several common Python libraries using EasyBuild on Cray systems (Section 4), and discuss how EasyBuild deployed • an interface to interact with the modules tool, to check at the Swiss National Supercomputing Centre CSCS (Sec- which modules are available, to load modules, etc. tion 5). • a mechanism to define the environment in which the 2. EASYBUILD installation will be performed, based on the compiler, EasyBuild [17{19] is a tool for building and installing scien- libraries and dependencies being used (see also Sec- tific software on HPC systems, implemented in Python. It tion 2.2.4) was originally created by the HPC support team at Ghent University (Belgium) in 2009, and was publicly released in 2012 under an open-source software license (GPLv2). Soon 2.2.2 Easyblocks after, it was adopted by various HPC sites and an active The implementation of a particular software installation pro- community formed around it. Today, it is used by institu- cedure is done in an easyblock, a Python module that defines, tions worldwide that provide HPC services to the scientific extends and/or replaces one or more of the steps of the ab- research community (see Section 2.4). stract procedure defined by the EasyBuild framework. Easy- blocks leverage the supporting functionality provided by the EasyBuild framework, and can be viewed as `plugins'. 2.1 Goals The main goal of EasyBuild is to fully automate the task A distinction is made between software-specific and generic of building and installing (scientific) software on HPC sys- easyblocks. Software-specific easyblocks implement a proce- tems, including taking care of the required dependencies and dure that is entirely custom to one particular software pack- generating environment module files that match the instal- age (e.g., OpenFOAM), while generic easyblocks implement lations. It aims to be an expert system with which all as- a procedure using standard tools (e.g., CMake, make). pects of software installation procedures can be performed autonomously, adhering to the provided specifications. Each easyblock must define the configuration, build and in- stall steps in one way or another; the EasyBuild framework In addition, EasyBuild serves as a platform for collaboration leaves these steps purposely unimplemented since their im- where different HPC support teams, who likely apply differ- plementation heavily depends on the tools being used in the ent site policies concerning scientific software installations, installation procedure. Since easyblocks are implemented in can efficiently work together to implement best practices and an object-oriented scheme, the step methods implemented benefit from each others expertise. by a particular easyblock can be reused in others through inheritance, enabling code reuse across easyblocks. It aims to support achieving reproducibility in science, by enabling to easilyreproduce software installations that were For each software package being installed, the EasyBuild performed previously.
Recommended publications
  • Linux and Electronics
    Linux and Electronics Urs Lindegger Linux and Electronics Urs Lindegger Copyright © 2019-11-25 Urs Lindegger Table of Contents 1. Introduction .......................................................................................................... 1 Note ................................................................................................................ 1 2. Printed Circuits ...................................................................................................... 2 Printed Circuit Board design ................................................................................ 2 Kicad ....................................................................................................... 2 Eagle ..................................................................................................... 13 Simulation ...................................................................................................... 13 Spice ..................................................................................................... 13 Digital simulation .................................................................................... 18 Wings 3D ....................................................................................................... 18 User interface .......................................................................................... 19 Modeling ................................................................................................ 19 Making holes in Wings 3D .......................................................................
    [Show full text]
  • BSD – Alternativen Zu Linux
    ∗BSD { Alternativen zu Linux Karl Lockhoff March 19, 2015 Inhaltsverzeichnis I Woher kommt BSD? I Was ist BSD? I Was ist sind die Unterschiede zwischen FreeBSD, NetBSD und OpenBSD? I Warum soll ich *BSD statt Linux einsetzen? I Chuck Haley und Bill Joy entwickeln den vi in Berkeley I Bill Joy erstellt eine Sammlung von Tools, 1BSD I Unix Version 7 erscheint I 2BSD erscheint (Basis f¨urdie Weiterentwicklung PDP-11) I 3BSD erscheint (erstmalig mit einen eigenen Kernel) I 4BSD erscheint (enth¨altdas fast file system (ffs)) I Bill Joy wechselt zu Sun Microsystems I Kirk McKusick ¨ubernimmt die Entwicklung von BSD I 1978 I 1979 I 1980 I 1981 Woher kommt BSD? I 1976 I Unix Version 6 erscheint I 2BSD erscheint (Basis f¨urdie Weiterentwicklung PDP-11) I 3BSD erscheint (erstmalig mit einen eigenen Kernel) I 4BSD erscheint (enth¨altdas fast file system (ffs)) I Bill Joy wechselt zu Sun Microsystems I Kirk McKusick ¨ubernimmt die Entwicklung von BSD I Bill Joy erstellt eine Sammlung von Tools, 1BSD I Unix Version 7 erscheint I 1979 I 1980 I 1981 Woher kommt BSD? I 1976 I Unix Version 6 erscheint I 1978 I Chuck Haley und Bill Joy entwickeln den vi in Berkeley I 2BSD erscheint (Basis f¨urdie Weiterentwicklung PDP-11) I 3BSD erscheint (erstmalig mit einen eigenen Kernel) I 4BSD erscheint (enth¨altdas fast file system (ffs)) I Bill Joy wechselt zu Sun Microsystems I Kirk McKusick ¨ubernimmt die Entwicklung von BSD I Unix Version 7 erscheint I 1979 I 1980 I 1981 Woher kommt BSD? I 1976 I Unix Version 6 erscheint I 1978 I Chuck Haley und Bill Joy entwickeln den
    [Show full text]
  • Open Babel Documentation Release 2.3.1
    Open Babel Documentation Release 2.3.1 Geoffrey R Hutchison Chris Morley Craig James Chris Swain Hans De Winter Tim Vandermeersch Noel M O’Boyle (Ed.) December 05, 2011 Contents 1 Introduction 3 1.1 Goals of the Open Babel project ..................................... 3 1.2 Frequently Asked Questions ....................................... 4 1.3 Thanks .................................................. 7 2 Install Open Babel 9 2.1 Install a binary package ......................................... 9 2.2 Compiling Open Babel .......................................... 9 3 obabel and babel - Convert, Filter and Manipulate Chemical Data 17 3.1 Synopsis ................................................. 17 3.2 Options .................................................. 17 3.3 Examples ................................................. 19 3.4 Differences between babel and obabel .................................. 21 3.5 Format Options .............................................. 22 3.6 Append property values to the title .................................... 22 3.7 Filtering molecules from a multimolecule file .............................. 22 3.8 Substructure and similarity searching .................................. 25 3.9 Sorting molecules ............................................ 25 3.10 Remove duplicate molecules ....................................... 25 3.11 Aliases for chemical groups ....................................... 26 4 The Open Babel GUI 29 4.1 Basic operation .............................................. 29 4.2 Options .................................................
    [Show full text]
  • Embedded Linux Systems with the Yocto Project™
    OPEN SOURCE SOFTWARE DEVELOPMENT SERIES Embedded Linux Systems with the Yocto Project" FREE SAMPLE CHAPTER SHARE WITH OTHERS �f, � � � � Embedded Linux Systems with the Yocto ProjectTM This page intentionally left blank Embedded Linux Systems with the Yocto ProjectTM Rudolf J. Streif Boston • Columbus • Indianapolis • New York • San Francisco • Amsterdam • Cape Town Dubai • London • Madrid • Milan • Munich • Paris • Montreal • Toronto • Delhi • Mexico City São Paulo • Sidney • Hong Kong • Seoul • Singapore • Taipei • Tokyo Many of the designations used by manufacturers and sellers to distinguish their products are claimed as trademarks. Where those designations appear in this book, and the publisher was aware of a trademark claim, the designations have been printed with initial capital letters or in all capitals. The author and publisher have taken care in the preparation of this book, but make no expressed or implied warranty of any kind and assume no responsibility for errors or omissions. No liability is assumed for incidental or consequential damages in connection with or arising out of the use of the information or programs contained herein. For information about buying this title in bulk quantities, or for special sales opportunities (which may include electronic versions; custom cover designs; and content particular to your business, training goals, marketing focus, or branding interests), please contact our corporate sales depart- ment at [email protected] or (800) 382-3419. For government sales inquiries, please contact [email protected]. For questions about sales outside the U.S., please contact [email protected]. Visit us on the Web: informit.com Cataloging-in-Publication Data is on file with the Library of Congress.
    [Show full text]
  • GNU Guix Cookbook Tutorials and Examples for Using the GNU Guix Functional Package Manager
    GNU Guix Cookbook Tutorials and examples for using the GNU Guix Functional Package Manager The GNU Guix Developers Copyright c 2019 Ricardo Wurmus Copyright c 2019 Efraim Flashner Copyright c 2019 Pierre Neidhardt Copyright c 2020 Oleg Pykhalov Copyright c 2020 Matthew Brooks Copyright c 2020 Marcin Karpezo Copyright c 2020 Brice Waegeneire Copyright c 2020 Andr´eBatista Copyright c 2020 Christine Lemmer-Webber Copyright c 2021 Joshua Branson Permission is granted to copy, distribute and/or modify this document under the terms of the GNU Free Documentation License, Version 1.3 or any later version published by the Free Software Foundation; with no Invariant Sections, no Front-Cover Texts, and no Back-Cover Texts. A copy of the license is included in the section entitled \GNU Free Documentation License". i Table of Contents GNU Guix Cookbook ::::::::::::::::::::::::::::::: 1 1 Scheme tutorials ::::::::::::::::::::::::::::::::: 2 1.1 A Scheme Crash Course :::::::::::::::::::::::::::::::::::::::: 2 2 Packaging :::::::::::::::::::::::::::::::::::::::: 5 2.1 Packaging Tutorial:::::::::::::::::::::::::::::::::::::::::::::: 5 2.1.1 A \Hello World" package :::::::::::::::::::::::::::::::::: 5 2.1.2 Setup:::::::::::::::::::::::::::::::::::::::::::::::::::::: 8 2.1.2.1 Local file ::::::::::::::::::::::::::::::::::::::::::::: 8 2.1.2.2 `GUIX_PACKAGE_PATH' ::::::::::::::::::::::::::::::::: 9 2.1.2.3 Guix channels ::::::::::::::::::::::::::::::::::::::: 10 2.1.2.4 Direct checkout hacking:::::::::::::::::::::::::::::: 10 2.1.3 Extended example ::::::::::::::::::::::::::::::::::::::::
    [Show full text]
  • Table of Contents Modules and Packages
    Table of Contents Modules and Packages...........................................................................................1 Software on NAS Systems..................................................................................................1 Using Software Packages in pkgsrc...................................................................................4 Using Software Modules....................................................................................................7 Modules and Packages Software on NAS Systems UPDATE IN PROGRESS: Starting with version 2.17, SGI MPT is officially known as HPE MPT. Use the command module load mpi-hpe/mpt to get the recommended version of MPT library on NAS systems. This article is being updated to reflect this change. Software programs on NAS systems are managed as modules or packages. Available programs are listed in tables below. Note: The name of a software module or package may contain additional information, such as the vendor name, version number, or what compiler/library is used to build the software. For example: • comp-intel/2016.2.181 - Intel Compiler version 2016.2.181 • mpi-sgi/mpt.2.15r20 - SGI MPI library version 2.15r20 • netcdf/4.4.1.1_mpt - NetCDF version 4.4.1.1, built with SGI MPT Modules Use the module avail command to see all available software modules. Run module whatis to view a short description of every module. For more information about a specific module, run module help modulename. See Using Software Modules for more information. Available Modules (as
    [Show full text]
  • Lmod Or How to Protect Your Sanity from Dependency Hell
    Lmod or how to protect your sanity from dependency hell Steffen Müthing Interdisciplinary Center for Scientific Computing Heidelberg University Dune User Meeting Aachen September 26, 2013 1 Steffen Müthing | Lmod or how to protect your sanity from dependency hell ⇒ Have to keep around multiple versions of MPI, BLAS, ParMetis, ALUGrid, UGGrid, . The Issue • DUNE has a number of non-packaged dependencies • Some of those contain libraries that are bound to a compiler / MPI version • You have to support multiple compilers / MPIs • Library developer (we try to be good about this...) • Clusters with different compiler / MPI combinations • Easily switch between release / debug version of MPI (only with dynamic linking) • Use GCC in general, but switch to clang during the “fix compilation errors” stage 2 Steffen Müthing | Lmod or how to protect your sanity from dependency hell The Issue • DUNE has a number of non-packaged dependencies • Some of those contain libraries that are bound to a compiler / MPI version • You have to support multiple compilers / MPIs • Library developer (we try to be good about this...) • Clusters with different compiler / MPI combinations • Easily switch between release / debug version of MPI (only with dynamic linking) • Use GCC in general, but switch to clang during the “fix compilation errors” stage ⇒ Have to keep around multiple versions of MPI, BLAS, ParMetis, ALUGrid, UGGrid, . 2 Steffen Müthing | Lmod or how to protect your sanity from dependency hell Problems • Do I already have ALUGrid for MPICH? • If yes, where on earth did I put it? • Did I really build it with the correct dependencies? • Why does my build fail? Do all the libraries in my nice --with= actually work together? 3 Steffen Müthing | Lmod or how to protect your sanity from dependency hell • Look around for something that’s already there • Distribution package managers (APT, rpm, Portage, MacPorts, homebrew,.
    [Show full text]
  • Introduction to Gentoo Linux
    Introduction to Gentoo Linux Ulrich Müller Developer and Council member, Gentoo Linux <[email protected]> Institut für Kernphysik, Universität Mainz <[email protected]> Seminar “Learn Linux the hard way”, Mainz, 2012-10-23 Ulrich Müller (Gentoo Linux) Introduction to Gentoo Linux Mainz 2012 1 / 35 Table of contents 1 History 2 Why Gentoo? 3 Compile everything? – Differences to other distros 4 Gentoo features 5 Gentoo as metadistribution 6 Organisation of the Gentoo project 7 Example of developer’s work Ulrich Müller (Gentoo Linux) Introduction to Gentoo Linux Mainz 2012 2 / 35 /"dZEntu:/ Pygoscelis papua Fastest swimming penguin Source: Wikimedia Commons License: CC-BY-SA-2.5, Attribution: Stan Shebs Ulrich Müller (Gentoo Linux) Introduction to Gentoo Linux Mainz 2012 3 / 35 How I came to Gentoo UNIX since 1987 (V7 on Perkin-Elmer 3220, later Ultrix, OSF/1, etc.) GNU/Linux since 1995 (Slackware, then S.u.S.E.) Switched to Gentoo in January 2004 Developer since April 2007 Council Mai 2009–June 2010 and since July 2011 Projects: GNU Emacs, eselect, PMS, QA Ulrich Müller (Gentoo Linux) Introduction to Gentoo Linux Mainz 2012 4 / 35 Overview Based on GNU/Linux, FreeBSD, etc. Source-based metadistribution Can be optimised and customised for any purpose Extremely configurable, portable, easy-to-maintain Active all-volunteer developer community Social contract GPL, LGPL, or other OSI-approved licenses Will never depend on non-free software Is and will always remain Free Software Commitment to giving back to the FLOSS community, e.g. submit bugs
    [Show full text]
  • With Yocto/Openembedded
    PORTING NEW CODE TO RISC-V WITH YOCTO/OPENEMBEDDED Martin Maas ([email protected]) 1st RISC-V Workshop, January 15, 2015 Monterey, CA WHY WE NEED A LINUX DISTRIBUTION • To build an application for RISC-V, you need to: – Download and build the RISC-V toolchain + Linux – Download, patch and build application + dependencies – Create an image and run it in QEMU or on hardware • Problems with this approach: – Error-prone: Easy to corrupt FS or get a step wrong – Reproducibility: Others can’t easily reuse your work – Rigidity: If a dependency changes, need to do it all over • We need a Linux distribution! – Automatic build process with dependency tracking – Ability to distribute binary packages and SDKs 2 RISCV-POKY: A PORT OF THE YOCTO PROJECT • We ported the Yocto Project – Official Linux Foundation Workgroup, supported by a large number of industry partners – Part I: Collection of hundreds of recipes (scripts that describe how to build packages for different platforms), shared with OpenEmbedded project – Part II: Bitbake, a parallel build system that takes recipes and fetches, patches, cross-compiles and produces packages (RPM/DEB), images, SDKs, etc. • Focus on build process and customizability 3 GETTING STARTED WITH RISCV-POKY • Let’s build a full Linux system including the GCC toolchain, Linux, QEMU + a large set of packages (including bash, ssh, python, perl, apt, wget,…) • Step I: Clone riscv-poky: git clone [email protected]:ucb-bar/riscv-poky.git • Step II: Set up the build system: source oe-init-build-env • Step III: Build an image (may
    [Show full text]
  • Functional Package and Configuration Management with GNU Guix
    Functional Package and Configuration Management with GNU Guix David Thompson Wednesday, January 20th, 2016 About me GNU project volunteer GNU Guile user and contributor since 2012 GNU Guix contributor since 2013 Day job: Ruby + JavaScript web development / “DevOps” 2 Overview • Problems with application packaging and deployment • Intro to functional package and configuration management • Towards the future • How you can help 3 User autonomy and control It is becoming increasingly difficult to have control over your own computing: • GNU/Linux package managers not meeting user needs • Self-hosting web applications requires too much time and effort • Growing number of projects recommend installation via curl | sudo bash 1 or otherwise avoid using system package managers • Users unable to verify that a given binary corresponds to the source code 1http://curlpipesh.tumblr.com/ 4 User autonomy and control “Debian and other distributions are going to be that thing you run Docker on, little more.” 2 2“ownCloud and distribution packaging” http://lwn.net/Articles/670566/ 5 User autonomy and control This is very bad for desktop users and system administrators alike. We must regain control! 6 What’s wrong with Apt/Yum/Pacman/etc.? Global state (/usr) that prevents multiple versions of a package from coexisting. Non-atomic installation, removal, upgrade of software. No way to roll back. Nondeterminstic package builds and maintainer-uploaded binaries. (though this is changing!) Reliance on pre-built binaries provided by a single point of trust. Requires superuser privileges. 7 The problem is bigger Proliferation of language-specific package managers and binary bundles that complicate secure system maintenance.
    [Show full text]
  • Bulletin Issue 25
    Issue 25 Bulletin November 2014 Contents Free software needs your vote Free software needs your 1 by John Sullivan vote Executive Director What would a free 3 t the Free Software Foundation, software world look like? Awe want to empower all computer GNU Guix and GNU’s 4 users everywhere to do everything they 31st Birthday might need or want to do on any com- Appropriate legal 5 puter, using only free software, with- notices out having to ask permission. Free tools for the FSF 6 By definition, proprietary software Common misconceptions 7 does not empower users in this way. in licensing It places limits on what they can do, Volunteer opportunities 9 such as preventing sharing of the soft- at the FSF ware, or looking at its code to see how See you at LibrePlanet 10 it works. 2015! Proprietary software enables users Around the world in (a 11 to pursue everything they might need hundred and) eighty or want to do, only as long as the soft- days ware distributor approves. The four freedoms that define free software — to run the program (0), to study and modify it (1), to share it (2), and to share modifications (3) — are meant for everyone, in their inter- actions with any program. Free soft- ware is a means to protect the individ- ual freedom of computer users. But why would someone who has Register for LibrePlanet at u.fsf.org/14w. no intention of ever reading the source code of programs running on their computer, much less in modifying it, care about Freedom 1, or Freedom 3? Why do they need or want the freedom to do things they might never need or want to do? 1 One reason is that any computer general, the right to vote can be a pow- user can ask someone else to do those erful check on government behavior.
    [Show full text]
  • Pacloud: Towards a Universal Cloud-Based Linux Package Manager
    Pacloud: Towards a Universal Cloud-based Linux Package Manager Olivier Bal-Pétré Pierre Varlez Fernando Perez-Tellez Technological University Dublin Technological University Dublin Technological University Dublin Dublin, Ireland Dublin, Ireland Dublin, Ireland [email protected] [email protected] [email protected] ABSTRACT or Qt framework. The LibreOffice package is built to be Package managers are a very important part of Linux distributions compatible with every user interface framework, hence heavier but we have noticed two weaknesses in them: They use pre-built than necessary: only one framework will be used for this software packages that are not optimised for specific hardware and often installation. they are too heavy for a specific need, or packages may require To optimise configuration and installation performance, source- plenty of time and resources to be compiled. In this paper, we based Linux distributions are used, one of the most famous being present a novel Linux package manager which uses cloud Gentoo Linux. computing features to compile and distribute Linux packages without impacting the end user's performance. We also show how Gentoo's package manager (Portage) builds packages from source Portage, Gentoo's package manager can be optimised for code and allows for specific compilation flags. This feature allows customisation and performance, along with the cloud computing to have packages that are optimised for a specific hardware. features to compile Linux packages more efficiently. All of this Portage also allows to build and install packages for specific resulting in a new cloud-based Linux package manager that is system requirements, with the help of USE flags [4].
    [Show full text]