mirror of
https://gitea.com/Lydanne/buildx.git
synced 2025-05-18 00:47:48 +08:00
driver: add docker driver
Signed-off-by: Tonis Tiigi <tonistiigi@gmail.com>
This commit is contained in:
parent
c31fd95212
commit
68cad8e46b
@ -8,6 +8,7 @@ import (
|
|||||||
"github.com/tonistiigi/buildx/commands"
|
"github.com/tonistiigi/buildx/commands"
|
||||||
"github.com/tonistiigi/buildx/version"
|
"github.com/tonistiigi/buildx/version"
|
||||||
|
|
||||||
|
_ "github.com/tonistiigi/buildx/driver/docker"
|
||||||
_ "github.com/tonistiigi/buildx/driver/docker-container"
|
_ "github.com/tonistiigi/buildx/driver/docker-container"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
@ -7,6 +7,9 @@ import (
|
|||||||
"github.com/tonistiigi/buildx/driver"
|
"github.com/tonistiigi/buildx/driver"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
const prioritySupported = 30
|
||||||
|
const priorityUnsupported = 70
|
||||||
|
|
||||||
func init() {
|
func init() {
|
||||||
driver.Register(&factory{})
|
driver.Register(&factory{})
|
||||||
}
|
}
|
||||||
@ -22,13 +25,16 @@ func (*factory) Usage() string {
|
|||||||
return "docker-container"
|
return "docker-container"
|
||||||
}
|
}
|
||||||
|
|
||||||
func (*factory) Priority() int {
|
func (*factory) Priority(cfg driver.InitConfig) int {
|
||||||
return 30
|
if cfg.DockerAPI == nil {
|
||||||
|
return priorityUnsupported
|
||||||
|
}
|
||||||
|
return prioritySupported
|
||||||
}
|
}
|
||||||
|
|
||||||
func (*factory) New(ctx context.Context, cfg driver.InitConfig) (driver.Driver, error) {
|
func (f *factory) New(ctx context.Context, cfg driver.InitConfig) (driver.Driver, error) {
|
||||||
if cfg.DockerAPI == nil {
|
if cfg.DockerAPI == nil {
|
||||||
return nil, errors.Errorf("docker driver requires docker API access")
|
return nil, errors.Errorf("%s driver requires docker API access", f.Name())
|
||||||
}
|
}
|
||||||
|
|
||||||
v, err := cfg.DockerAPI.ServerVersion(ctx)
|
v, err := cfg.DockerAPI.ServerVersion(ctx)
|
||||||
|
48
driver/docker/driver.go
Normal file
48
driver/docker/driver.go
Normal file
@ -0,0 +1,48 @@
|
|||||||
|
package docker
|
||||||
|
|
||||||
|
import (
|
||||||
|
"context"
|
||||||
|
"net"
|
||||||
|
"time"
|
||||||
|
|
||||||
|
dockertypes "github.com/docker/docker/api/types"
|
||||||
|
"github.com/moby/buildkit/client"
|
||||||
|
"github.com/pkg/errors"
|
||||||
|
"github.com/tonistiigi/buildx/driver"
|
||||||
|
"github.com/tonistiigi/buildx/util/progress"
|
||||||
|
)
|
||||||
|
|
||||||
|
var buildkitImage = "moby/buildkit:master" // TODO: make this verified and configuratble
|
||||||
|
|
||||||
|
type Driver struct {
|
||||||
|
driver.InitConfig
|
||||||
|
version dockertypes.Version
|
||||||
|
}
|
||||||
|
|
||||||
|
func (d *Driver) Bootstrap(ctx context.Context, l progress.Logger) error {
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func (d *Driver) Info(ctx context.Context) (*driver.Info, error) {
|
||||||
|
_, err := d.DockerAPI.ServerVersion(ctx)
|
||||||
|
if err != nil {
|
||||||
|
return nil, errors.Wrapf(driver.ErrNotConnecting, err.Error())
|
||||||
|
}
|
||||||
|
return &driver.Info{
|
||||||
|
Status: driver.Running,
|
||||||
|
}, nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func (d *Driver) Stop(ctx context.Context, force bool) error {
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func (d *Driver) Rm(ctx context.Context, force bool) error {
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func (d *Driver) Client(ctx context.Context) (*client.Client, error) {
|
||||||
|
return client.New(ctx, "", client.WithDialer(func(string, time.Duration) (net.Conn, error) {
|
||||||
|
return d.DockerAPI.DialHijack(ctx, "/grpc", "h2c", nil)
|
||||||
|
}))
|
||||||
|
}
|
53
driver/docker/factory.go
Normal file
53
driver/docker/factory.go
Normal file
@ -0,0 +1,53 @@
|
|||||||
|
package docker
|
||||||
|
|
||||||
|
import (
|
||||||
|
"context"
|
||||||
|
|
||||||
|
"github.com/pkg/errors"
|
||||||
|
"github.com/tonistiigi/buildx/driver"
|
||||||
|
)
|
||||||
|
|
||||||
|
const prioritySupported = 10
|
||||||
|
const priorityUnsupported = 99
|
||||||
|
|
||||||
|
func init() {
|
||||||
|
driver.Register(&factory{})
|
||||||
|
}
|
||||||
|
|
||||||
|
type factory struct {
|
||||||
|
}
|
||||||
|
|
||||||
|
func (*factory) Name() string {
|
||||||
|
return "docker"
|
||||||
|
}
|
||||||
|
|
||||||
|
func (*factory) Usage() string {
|
||||||
|
return "docker"
|
||||||
|
}
|
||||||
|
|
||||||
|
func (*factory) Priority(cfg driver.InitConfig) int {
|
||||||
|
if cfg.DockerAPI == nil {
|
||||||
|
return priorityUnsupported
|
||||||
|
}
|
||||||
|
|
||||||
|
c, err := cfg.DockerAPI.DialHijack(context.TODO(), "/grpc", "h2c", nil)
|
||||||
|
if err != nil {
|
||||||
|
return priorityUnsupported
|
||||||
|
}
|
||||||
|
c.Close()
|
||||||
|
|
||||||
|
return prioritySupported
|
||||||
|
}
|
||||||
|
|
||||||
|
func (*factory) New(ctx context.Context, cfg driver.InitConfig) (driver.Driver, error) {
|
||||||
|
if cfg.DockerAPI == nil {
|
||||||
|
return nil, errors.Errorf("docker driver requires docker API access")
|
||||||
|
}
|
||||||
|
|
||||||
|
v, err := cfg.DockerAPI.ServerVersion(ctx)
|
||||||
|
if err != nil {
|
||||||
|
return nil, errors.Wrapf(driver.ErrNotConnecting, err.Error())
|
||||||
|
}
|
||||||
|
|
||||||
|
return &Driver{InitConfig: cfg, version: v}, nil
|
||||||
|
}
|
@ -11,7 +11,7 @@ import (
|
|||||||
type Factory interface {
|
type Factory interface {
|
||||||
Name() string
|
Name() string
|
||||||
Usage() string
|
Usage() string
|
||||||
Priority() int // take initConfig?
|
Priority(cfg InitConfig) int
|
||||||
New(ctx context.Context, cfg InitConfig) (Driver, error)
|
New(ctx context.Context, cfg InitConfig) (Driver, error)
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -37,7 +37,7 @@ func Register(f Factory) {
|
|||||||
drivers[f.Name()] = f
|
drivers[f.Name()] = f
|
||||||
}
|
}
|
||||||
|
|
||||||
func GetDefaultFactory() (Factory, error) {
|
func GetDefaultFactory(ic InitConfig) (Factory, error) {
|
||||||
if len(drivers) == 0 {
|
if len(drivers) == 0 {
|
||||||
return nil, errors.Errorf("no drivers available")
|
return nil, errors.Errorf("no drivers available")
|
||||||
}
|
}
|
||||||
@ -47,7 +47,7 @@ func GetDefaultFactory() (Factory, error) {
|
|||||||
}
|
}
|
||||||
dd := make([]p, 0, len(drivers))
|
dd := make([]p, 0, len(drivers))
|
||||||
for _, f := range drivers {
|
for _, f := range drivers {
|
||||||
dd = append(dd, p{f: f, priority: f.Priority()})
|
dd = append(dd, p{f: f, priority: f.Priority(ic)})
|
||||||
}
|
}
|
||||||
sort.Slice(dd, func(i, j int) bool {
|
sort.Slice(dd, func(i, j int) bool {
|
||||||
return dd[i].priority < dd[j].priority
|
return dd[i].priority < dd[j].priority
|
||||||
@ -56,15 +56,16 @@ func GetDefaultFactory() (Factory, error) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func GetDriver(ctx context.Context, name string, f Factory, api dockerclient.APIClient) (Driver, error) {
|
func GetDriver(ctx context.Context, name string, f Factory, api dockerclient.APIClient) (Driver, error) {
|
||||||
|
ic := InitConfig{
|
||||||
|
DockerAPI: api,
|
||||||
|
Name: name,
|
||||||
|
}
|
||||||
if f == nil {
|
if f == nil {
|
||||||
var err error
|
var err error
|
||||||
f, err = GetDefaultFactory()
|
f, err = GetDefaultFactory(ic)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return f.New(ctx, InitConfig{
|
return f.New(ctx, ic)
|
||||||
Name: name,
|
|
||||||
DockerAPI: api,
|
|
||||||
})
|
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user