1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859 |
- package daemon
- import (
- "fmt"
- "io"
- "runtime"
- "github.com/docker/docker/container"
- "github.com/docker/docker/pkg/archive"
- "github.com/docker/docker/pkg/ioutils"
- )
- // ContainerExport writes the contents of the container to the given
- // writer. An error is returned if the container cannot be found.
- func (daemon *Daemon) ContainerExport(name string, out io.Writer) error {
- container, err := daemon.GetContainer(name)
- if err != nil {
- return err
- }
- if runtime.GOOS == "windows" && container.Platform == "windows" {
- return fmt.Errorf("the daemon on this platform does not support exporting Windows containers")
- }
- data, err := daemon.containerExport(container)
- if err != nil {
- return fmt.Errorf("Error exporting container %s: %v", name, err)
- }
- defer data.Close()
- // Stream the entire contents of the container (basically a volatile snapshot)
- if _, err := io.Copy(out, data); err != nil {
- return fmt.Errorf("Error exporting container %s: %v", name, err)
- }
- return nil
- }
- func (daemon *Daemon) containerExport(container *container.Container) (io.ReadCloser, error) {
- if err := daemon.Mount(container); err != nil {
- return nil, err
- }
- archive, err := archivePath(container.BaseFS, container.BaseFS.Path(), &archive.TarOptions{
- Compression: archive.Uncompressed,
- UIDMaps: daemon.idMappings.UIDs(),
- GIDMaps: daemon.idMappings.GIDs(),
- })
- if err != nil {
- daemon.Unmount(container)
- return nil, err
- }
- arch := ioutils.NewReadCloserWrapper(archive, func() error {
- err := archive.Close()
- daemon.Unmount(container)
- return err
- })
- daemon.LogContainerEvent(container, "export")
- return arch, err
- }
|