Skip to content
Snippets Groups Projects
  • Eelco Dolstra's avatar
    a8306cb9
    * The build hooks used to implement distributed builds can now be run · a8306cb9
    Eelco Dolstra authored
      in parallel.  Hooks are more efficient: locks on output paths are
      only acquired when the hook says that it is willing to accept a
      build job.  Hooks now work in two phases.  First, they should first
      tell Nix whether they are willing to accept a job.  Nix guarantuees
      that no two hooks will ever be in the first phase at the same time
      (this simplifies the implementation of hooks, since they don't have
      to perform locking (?)).  Second, if they accept a job, they are
      then responsible for building it (on the remote system), and copying
      the result back.  These can be run in parallel with other hooks and
      locally executed jobs.
    
      The implementation is a bit messy right now, though.  
    
    * The directory `distributed' shows a (hacky) example of a hook that
      distributes build jobs over a set of machines listed in a
      configuration file.
      
    a8306cb9
    History
    * The build hooks used to implement distributed builds can now be run
    Eelco Dolstra authored
      in parallel.  Hooks are more efficient: locks on output paths are
      only acquired when the hook says that it is willing to accept a
      build job.  Hooks now work in two phases.  First, they should first
      tell Nix whether they are willing to accept a job.  Nix guarantuees
      that no two hooks will ever be in the first phase at the same time
      (this simplifies the implementation of hooks, since they don't have
      to perform locking (?)).  Second, if they accept a job, they are
      then responsible for building it (on the remote system), and copying
      the result back.  These can be run in parallel with other hooks and
      locally executed jobs.
    
      The implementation is a bit messy right now, though.  
    
    * The directory `distributed' shows a (hacky) example of a hook that
      distributes build jobs over a set of machines listed in a
      configuration file.