Merge pull request #1103 from jedevc/remote-driver-bootstrap

Use --bootstrap to wait for remote to become active
This commit is contained in:
Tõnis Tiigi 2022-05-12 10:21:15 -07:00 committed by GitHub
commit 062cf29de2
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
3 changed files with 30 additions and 21 deletions

View File

@ -139,28 +139,13 @@ jobs:
name: Launch remote buildkitd name: Launch remote buildkitd
if: matrix.driver == 'remote' if: matrix.driver == 'remote'
run: | run: |
docker run -d --privileged \ docker run -d \
--privileged \
--name=remote-buildkit \ --name=remote-buildkit \
-p 1234:1234 \ -p 1234:1234 \
--health-cmd "buildctl debug workers" \
--health-interval 1s \
${{ matrix.buildkit }} \ ${{ matrix.buildkit }} \
--addr unix:///run/buildkit/buildkitd.sock \ --addr unix:///run/buildkit/buildkitd.sock \
--addr tcp://0.0.0.0:1234 --addr tcp://0.0.0.0:1234
-
name: Check remote buildkitd
if: matrix.driver == 'remote'
run: |
try=0
max=10
until [ "$(docker container inspect remote-buildkit --format '{{ .State.Health.Status }}')" = "healthy" ]; do
if [ $try -gt $max ]; then
echo >&2 "healthcheck failed after $max trials"
exit 1
fi
sleep $(awk "BEGIN{print (100 + $try * 20) * 0.002}")
try=$(expr $try + 1)
done
- -
name: Test name: Test
run: | run: |

View File

@ -2,11 +2,11 @@ package remote
import ( import (
"context" "context"
"time"
"github.com/docker/buildx/driver" "github.com/docker/buildx/driver"
"github.com/docker/buildx/util/progress" "github.com/docker/buildx/util/progress"
"github.com/moby/buildkit/client" "github.com/moby/buildkit/client"
"github.com/pkg/errors"
) )
type Driver struct { type Driver struct {
@ -23,17 +23,39 @@ type tlsOpts struct {
} }
func (d *Driver) Bootstrap(ctx context.Context, l progress.Logger) error { func (d *Driver) Bootstrap(ctx context.Context, l progress.Logger) error {
return nil for i := 0; ; i++ {
info, err := d.Info(ctx)
if err != nil {
return err
}
if info.Status != driver.Inactive {
return nil
}
select {
case <-ctx.Done():
return ctx.Err()
default:
if i > 10 {
i = 10
}
time.Sleep(time.Duration(i) * time.Second)
}
}
} }
func (d *Driver) Info(ctx context.Context) (*driver.Info, error) { func (d *Driver) Info(ctx context.Context) (*driver.Info, error) {
c, err := d.Client(ctx) c, err := d.Client(ctx)
if err != nil { if err != nil {
return nil, errors.Wrapf(driver.ErrNotConnecting, err.Error()) return &driver.Info{
Status: driver.Inactive,
}, nil
} }
if _, err := c.ListWorkers(ctx); err != nil { if _, err := c.ListWorkers(ctx); err != nil {
return nil, errors.Wrapf(driver.ErrNotConnecting, err.Error()) return &driver.Info{
Status: driver.Inactive,
}, nil
} }
return &driver.Info{ return &driver.Info{

View File

@ -55,6 +55,7 @@ if [ "$DRIVER" != "docker" ]; then
createFlags="$createFlags --append" createFlags="$createFlags --append"
fi fi
buildxCmd create ${createFlags} \ buildxCmd create ${createFlags} \
--bootstrap \
--name="${builderName}" \ --name="${builderName}" \
--node="${builderName}-${platform/\//-}" \ --node="${builderName}-${platform/\//-}" \
--platform="${platform}" \ --platform="${platform}" \
@ -69,6 +70,7 @@ if [ "$DRIVER" != "docker" ]; then
createFlags="$createFlags --config=${BUILDKIT_CFG}" createFlags="$createFlags --config=${BUILDKIT_CFG}"
fi fi
buildxCmd create ${createFlags} \ buildxCmd create ${createFlags} \
--bootstrap \
--name="${builderName}" \ --name="${builderName}" \
--platform="${PLATFORMS}" \ --platform="${PLATFORMS}" \
--driver="${DRIVER}" \ --driver="${DRIVER}" \