Re: Dual cache key calculation and build planning modes
- From: Tristan Van Berkom <tristan vanberkom codethink co uk>
- To: Jürg Billeter <j bitron ch>, buildstream-list gnome org
- Subject: Re: Dual cache key calculation and build planning modes
- Date: Wed, 05 Jul 2017 23:32:31 +0900
On Wed, 2017-07-05 at 22:51 +0900, Tristan Van Berkom wrote:
Sorry for the extra email... it's getting late and just putting some
extra thoughts before calling it a day...
o With dual cache key calculation modes, we should be continuously
attempting to download a "strong" artifact whenever launching a
build (so if a strong artifact is available, it is preferred).
o We should be able to show decent feedback at build launch time
about which artifacts are strong.
So at the very least, a developer would know if they are building
mostly weak or mostly strong artifacts.
This could be done perhaps by using a different color to display
weak cache keys (maybe green ones are the ones where they have
a strong backing artifact, when building in weak mode).
o After a bit more thought on manual revisioning, maybe we could have
an entirely hypothetical version number on elements which could be
manually bumped, and we could use them to limit which weak
artifacts are acceptable for a build ?
I.e. I think the main concern here, is building a very new "foo"
against a very old "bar" and not really knowing that there is
an API break on "bar", and "foo" expects a newer version of "bar".
Rather than handling this with minimal bound dependency
revisioning, I guess we could say that a project expects all
weak artifacts of "revision 5", and somehow artificially bump
that across the board when releasing a new stack ?
I'm really unsure of what artificial revisioning scheme we could use
that is not a pain in the ass to use, though, at the same time I'm not
that worried that the output will be unreliable in weak mode.
Anyway, maybe you can elaborate a bit more on how your approach would
work.
Cheers,
-Tristan
On Wed, 2017-07-05 at 15:10 +0200, Jürg Billeter wrote:
Hi Tristan,
thanks for the write-up. It looks like a reasonable plan for handling
dual cache keys / build planning modes. That said, I'm not very fond of
having such a non-predictable build planning mode at all. If there is
no other way to fulfill the requirements, so be it, but maybe the
following idea would be an acceptable alternative.
I'm not sure I'm fond of the alternative proposal here, but I'm not
sure I understand exactly how it works or how it solves the problem in
a cleaner, more comprehensive way.
I should stress that keeping the user facing interfaces as simple as
possible is a big priority.
That said, if it's only the predictability of builds passing or failing
with such an approach; maybe something else can be cooked up to address
that concern; for instance, we might be able to pin certain groups of
elements to not behave this way, when plotting the build planning mode.
This way one could select only a specific group of elements suitable
for weak planning mode ?
The underlying reason why weak build planning modes will (mostly) work
is that shared library interfaces are reasonably stable, at least in
the GNOME ecosystem. Instead of using weak cache keys, hoping for the
best, and manually intervening when something breaks, we could supply a
bit more information to BuildStream such that it can avoid rebuilding
reverse dependencies for minor library changes without losing the
predictability we have right now. It could even become the default
mode.
My proposal is to add a secondary ref to sources of library elements.
That secondary ref points to the oldest revision that has the same API
and ABI as the primary ref (and doesn't contain any major bugs that
would break build tools). Whenever such a library is staged as a
dependency of a build process (directly or indirectly), the artifact
built from the secondary ref is used.
Currently the solution handles stable vs. experimental, and which
versions of things to build/combine together by:
A.) Revisioning the buildstream project itself with something
like git, so we have stable vs dev branches of a buildstream
project.
B.) Using stable branch names as tracking refs for stable branches
of the buildstream project itself.
So when you are building stable branches of every element in
the project, these interfaces are inherently never expected
to break (however mileage of course will vary, pinning to exact
release tags or tarballs is also a possible countermeasure).
Would this also mean we would have to have 2 tracking references ?
I'm open to trying to find another less complex solution, but this is starting to look like a more complex
project definition than a simpler one.
The artifact built from the
primary ref is used only when composing a system.
I'm not sure what you are proposing with this exactly, are you saying
that we have some kind of semantic for assembling artifacts together,
which have never previously been built against eachother ?
Also, I dont know what a "system" is in this context, we dont have such
a concept really, maybe you are alluding to what happens with a
'compose' element.
This will require building all libraries with differing refs twice, but
only when building from scratch. Artifact sharing should be very
effective with this approach.
I haven't worked out all the details yet but I would appreciate input
on whether it makes sense to continue in this direction or if this is
not suitable to fulfill the requirements. One question is how to handle
bumps of secondary refs for fully automated build systems. Is a manual
action on interface breaks and additions acceptable?
I'm not completely averse to manual intervention on interface breaks
and have considered this for different reasons in the past.
I'm not sure how this would work in practice, especially in conjunction
with `bst track` (how do we determine that a tracked source has passed
the manually specified version boundary, in a VCS agnostic way ?).
Cheers,
-Tristan
_______________________________________________
Buildstream-list mailing list
Buildstream-list gnome org
https://mail.gnome.org/mailman/listinfo/buildstream-list
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]