@ -52,10 +52,21 @@ func NewRemoteBuildxController(ctx context.Context, dockerCli command.Cli, opts
rootDir = rootDataDir ( dockerCli )
rootDir = rootDataDir ( dockerCli )
}
}
serverRoot := filepath . Join ( rootDir , "shared" )
serverRoot := filepath . Join ( rootDir , "shared" )
c , err := newBuildxClientAndCheck ( filepath . Join ( serverRoot , "buildx.sock" ) , 1 , 0 )
// connect to buildx server if it is already running
ctx2 , cancel := context . WithTimeout ( ctx , 1 * time . Second )
c , err := newBuildxClientAndCheck ( ctx2 , filepath . Join ( serverRoot , "buildx.sock" ) )
cancel ( )
if err != nil {
if err != nil {
if ! errors . Is ( err , context . DeadlineExceeded ) {
return nil , errors . Wrap ( err , "cannot connect to the buildx server" )
}
} else {
return & buildxController { c , serverRoot } , nil
}
// start buildx server via subcommand
logrus . Info ( "no buildx server found; launching..." )
logrus . Info ( "no buildx server found; launching..." )
// start buildx server via subcommand
launchFlags := [ ] string { }
launchFlags := [ ] string { }
if opts . ServerConfig != "" {
if opts . ServerConfig != "" {
launchFlags = append ( launchFlags , "--config" , opts . ServerConfig )
launchFlags = append ( launchFlags , "--config" , opts . ServerConfig )
@ -69,11 +80,14 @@ func NewRemoteBuildxController(ctx context.Context, dockerCli command.Cli, opts
return nil , err
return nil , err
}
}
go wait ( )
go wait ( )
c , err = newBuildxClientAndCheck ( filepath . Join ( serverRoot , "buildx.sock" ) , 10 , time . Second )
// wait for buildx server to be ready
ctx2 , cancel = context . WithTimeout ( ctx , 10 * time . Second )
c , err = newBuildxClientAndCheck ( ctx2 , filepath . Join ( serverRoot , "buildx.sock" ) )
cancel ( )
if err != nil {
if err != nil {
return nil , errors . Wrap ( err , "cannot connect to the buildx server" )
return nil , errors . Wrap ( err , "cannot connect to the buildx server" )
}
}
}
return & buildxController { c , serverRoot } , nil
return & buildxController { c , serverRoot } , nil
}
}
@ -180,15 +194,14 @@ func getLogFilePath(dockerCli command.Cli, configPath string) (string, error) {
if err != nil {
if err != nil {
return "" , err
return "" , err
}
}
logFile := config . LogFile
if config . LogFile == "" {
if logFile == "" {
root , err := prepareRootDir ( dockerCli , config )
root , err := prepareRootDir ( dockerCli , config )
if err != nil {
if err != nil {
return "" , err
return "" , err
}
}
logFile = filepath . Join ( root , "log" )
return filepath . Join ( root , "log" ) , nil
}
}
return l ogFile, nil
return config. L ogFile, nil
}
}
func getConfig ( dockerCli command . Cli , configPath string ) ( * serverConfig , error ) {
func getConfig ( dockerCli command . Cli , configPath string ) ( * serverConfig , error ) {
@ -232,34 +245,18 @@ func rootDataDir(dockerCli command.Cli) string {
return filepath . Join ( confutil . ConfigDir ( dockerCli ) , "controller" )
return filepath . Join ( confutil . ConfigDir ( dockerCli ) , "controller" )
}
}
func newBuildxClientAndCheck ( addr string , checkNum int , duration time . Duration ) ( * Client , error ) {
func newBuildxClientAndCheck ( ctx context . Context , addr string ) ( * Client , error ) {
c , err := NewClient ( addr)
c , err := NewClient ( ctx, addr)
if err != nil {
if err != nil {
return nil , err
return nil , err
}
}
var lastErr error
p , v , r , err := c . Version ( ctx )
for i := 0 ; i < checkNum ; i ++ {
_ , err := c . List ( context . TODO ( ) )
if err == nil {
lastErr = nil
break
}
err = errors . Wrapf ( err , "failed to access server (tried %d times)" , i )
logrus . Debugf ( "connection failure: %v" , err )
lastErr = err
time . Sleep ( duration )
}
if lastErr != nil {
return nil , lastErr
}
p , v , r , err := c . Version ( context . TODO ( ) )
if err != nil {
if err != nil {
return nil , err
return nil , err
}
}
logrus . Debugf ( "connected to server (\"%v %v %v\")" , p , v , r )
logrus . Debugf ( "connected to server (\"%v %v %v\")" , p , v , r )
if ! ( p == version . Package && v == version . Version && r == version . Revision ) {
if ! ( p == version . Package && v == version . Version && r == version . Revision ) {
logrus . Warnf ( "version mismatch (server: \"%v %v %v\", client: \"%v %v %v\"); please kill and restart buildx server" ,
return nil , errors . Errorf ( "version mismatch (client: \"%v %v %v\", server: \"%v %v %v\")" , version . Package , version . Version , version . Revision , p , v , r )
p , v , r , version . Package , version . Version , version . Revision )
}
}
return c , nil
return c , nil
}
}