Addressing Selfishness in the Design of Cooperative Systems

Addressing Selfishness in the Design of Cooperative Systems

DOCTORAL THESIS Cotutelle-de-thèse INSTITUT NATIONAL DES SCIENCES APPLIQUÉES DE LYON ÉCOLE DOCTORALE ED 512 – INFORMATIQUE ET MATHÉMATIQUES DE LYON SPÉCIALITÉ INFORMATIQUE DIRECTOR: PROF. LUCA Q. ZAMBONI UNIVERSITÁ DEGLI STUDI DI MILANO DEPARTMENT OF COMPUTER SCIENCE CORSO DI DOTTORATO IN INFORMATICA (XXVIII CYCLE) – INF/01 COORDINATOR: PROF. PAOLO BOLDI Defended on 24 March 2017, by : Guido LENA COTA Addressing Selfishness in the Design of Cooperative Systems Supervisors: Prof. Lionel BRUNIE INSA de Lyon Prof. Ernesto DAMIANI Università degli Studi di Milano Cosupervisors: Dr. Sonia BEN MOKHTAR INSA de Lyon Dr. Gabriele GIANINI Università degli Studi di Milano EXAMINATION COMMITTEE: Reviewers: Prof. Harald KOSCH Universität Passau, Germany Prof. Vivien QUEMA Grenoble INP / ENSIMAG, France Reviewer (Università degli Studi di Milano) , Examiner: Dr. Julia LAWALL Sorbonne Universités, UPMC, LIP6, France Examiners: Prof. Sara BOUCHENAK INSA de Lyon, France Prof. Paola BONIZZONI Università degli Studi di Milano-Bicocca, Italy Prof. Mariagrazia FUGINI Politecnico di Milano, Italy ABSTRACT Cooperative distributed systems, particularly peer-to-peer systems, are the basis of several mainstream Internet applications (e.g., file-sharing, media streaming) and the key enablers of new and emerging technologies, including Blockchain and the Internet of Things. Essential to the success of cooperative systems is that nodes are willing to cooperate with each other by sharing part of their resources, e.g., network bandwidth, CPU capability, storage space. How- ever, as nodes are autonomous entities, they may be tempted to behave in a selfish manner by not contributing their fair share, potentially causing system performance degradation and insta- bility. Addressing selfish nodes is, therefore, key to building efficient and reliable cooperative systems. Yet, it is a challenging task, as current techniques for analysing selfishness and design- ing effective countermeasures remain manual and time-consuming, requiring multi-domain expertise. In this thesis, we aim to provide practical and conceptual tools to help system designers in dealing with selfish nodes. First, based on a comprehensive survey of existing work on selfishness, we develop a classification framework to identify and understand the most impor- tant selfish behaviours to focus on when designing a cooperative system. Second, we propose RACOON, a unifying framework for the selfishness-aware design and configuration of cooper- ative systems. RACOON provides a semi-automatic methodology to integrate a given system with practical and finely tuned mechanisms to meet specified resilience and performance objec- tives, using game theory and simulations to predict the behaviour of the system when subjected to selfish nodes. An extension of the framework (RACOON++) is also proposed to improve the accuracy, flexibility, and usability of RACOON. Finally, we propose SEINE, a framework for fast modelling and evaluation of various types of selfish behaviour in a given cooperative system. SEINE relies on a domain-specific language for describing the selfishness scenario to evaluate and provides semi-automatic support for its implementation and study in a state-of-the-art simulator. iii CONTENTS 1 INTRODUCTION 1 1.1 Selfishness in cooperative systems . .2 1.1.1 Example: selfishness in P2P file-sharing . .2 1.1.2 Example: selfishness in P2P live streaming . .3 1.1.3 Example: selfishness in volunteer computing . .3 1.2 Dealing with selfishness in cooperative systems . .4 1.3 Research challenges . .6 1.4 Thesis contributions & outline . .7 ISELFISHNESSINCOOPERATIVEDISTRIBUTEDSYSTEMS 11 2 ASURVEYONSELFISHNESSINCOOPERATIVESYSTEMS 13 2.1 An overview of cooperative systems . 13 2.2 Selfish behaviour in cooperative systems . 14 2.3 A classification framework for selfish behaviours . 19 2.3.1 Motivation . 20 2.3.2 Execution . 21 2.3.3 Details of the papers included in the review . 24 2.4 Examples of selfish behaviour classification . 25 2.4.1 BAR Gossip, Li et al. [111]............................ 25 2.4.2 BOINC client, Anta et al. [20], Anderson [18], Yurkewych et al. [180]... 28 2.4.3 Delay tolerant network, Zhu et al. [188].................... 29 2.4.4 Tor network, Dingledine et al. [135]...................... 30 2.5 General analysis of selfishness in cooperative systems . 32 2.5.1 Analysis of the motivations . 32 2.5.2 Analysis of the executions . 33 2.6 Summary . 36 3 ANALYSINGSELFISHNESSINCOOPERATIVESYSTEMS 37 3.1 Approaches to selfishness analysis . 37 3.1.1 Analytical approaches . 37 3.1.2 Experimental approaches . 38 3.2 Related research: Game Theory . 41 3.2.1 Basic concepts . 41 3.2.2 Game types and applications to cooperative systems . 42 3.2.3 Discussion and open issues . 45 3.3 Evaluation of the approaches to selfishness analysis . 46 3.3.1 Evaluation methodology . 46 3.3.2 Evaluation results . 48 3.4 Summary . 49 v vi CONTENTS 4 DEALINGWITHSELFISHNESSINCOOPERATIVESYSTEMS 51 4.1 Incentive mechanisms . 51 4.1.1 Classification of incentive mechanisms . 52 4.1.2 Classification of incentive mechanisms from relevant studies . 58 4.1.3 Desirable requirements for incentive schemes in cooperative systems . 59 4.1.4 Perspectives on the research challenges . 61 4.2 Accountability in distributed systems . 62 4.2.1 Basic concepts . 62 4.2.2 Related work: FullReview . 64 4.2.3 Discussion and open issues . 66 4.3 Summary . 69 II SELFISHNESS - AWAREDESIGNOFCOOPERATIVESYSTEMS 71 5 THERACOONFRAMEWORK 73 5.1 Overview . 74 5.2 Illustrative example: the O&A protocol . 76 5.3 RACOON Design Phase . 76 5.3.1 Input of the Design Phase . 77 5.3.2 Cooperation enforcement . 82 5.3.3 Selfishness injection . 86 5.3.4 Rationality injection . 90 5.4 RACOON Tuning phase . 99 5.4.1 Input of the Tuning phase . 99 5.4.2 Configuration evaluation and exploration . 101 5.5 Evaluation . 103 5.5.1 Design and development effort . 103 5.5.2 Meeting design objectives using RACOON . 104 5.5.3 Simulation compared to real system deployment . 105 5.5.4 Execution time . 107 5.5.5 Expressiveness . 107 5.6 Summary . 109 6 THERACOON + + FRAMEWORK : RACOONMEETSEVOLUTION 113 6.1 Overview . 115 6.2 Illustrative example: the S-R-R protocol . 115 6.3 RACOON++ Design phase . 115 6.3.1 Input of the Design phase . 116 6.3.2 Cooperation enforcement . 123 6.3.3 Selfishness injection . 124 6.3.4 Rationality injection . 127 6.4 RACOON++ Tuning phase . 131 6.4.1 Input of the Tuning phase . 131 6.4.2 Configuration evaluation . 132 CONTENTS vii 6.4.3 Configuration Exploration . 137 6.5 Evaluation . 143 6.5.1 Use cases . 143 6.5.2 Design and development effort . 144 6.5.3 Meeting design objectives using RACOON++ ................. 146 6.5.4 RACOON++ effectiveness . 148 6.5.5 RACOON++ vs FullReview . 149 6.6 Summary . 152 III SELFISHNESS INJECTION ANALYSIS IN COOPERATIVE SYSTEMS 155 7 THESEINEFRAMEWORK 157 7.1 Domain Analysis . 158 7.2 SEINE Overview . 162 7.3 Modelling selfishness in SEINE-L . 163 7.4 Injecting selfishness in PeerSim using SEINE . 168 7.4.1 Library of Annotations . 168 7.4.2 SEINE-L Compiler . 169 7.4.3 Selfishness scenario generation . 171 7.4.4 SEINE Implementation . 172 7.5 Evaluation . 172 7.5.1 Generality and expressiveness of SEINE-L .................. 173 7.5.2 Accuracy of SEINE-R ............................... 174 7.5.3 Development effort . 176 7.5.4 Simulation time . 179 7.6 Summary . 180 IV CONCLUSIONS AND FUTURE WORK 181 8 CONCLUSIONS 183 8.1 Summary . 183 8.2 Possible improvements and future research directions . 186 8.2.1 Integration of RACOON and SEINE . 186 8.2.2 Additional types of selfish deviations . 187 8.2.3 Extending the RACOON framework ..

View Full Text

Details

  • File Type
    pdf
  • Upload Time
    -
  • Content Languages
    English
  • Upload User
    Anonymous/Not logged-in
  • File Pages
    242 Page
  • File Size
    -

Download

Channel Download Status
Express Download Enable

Copyright

We respect the copyrights and intellectual property rights of all users. All uploaded documents are either original works of the uploader or authorized works of the rightful owners.

  • Not to be reproduced or distributed without explicit permission.
  • Not used for commercial purposes outside of approved use cases.
  • Not used to infringe on the rights of the original creators.
  • If you believe any content infringes your copyright, please contact us immediately.

Support

For help with questions, suggestions, or problems, please contact us