mirror of
				https://github.com/containers/podman.git
				synced 2025-10-25 18:25:59 +08:00 
			
		
		
		
	 b53cb57680
			
		
	
	b53cb57680
	
	
	
		
			
			This implements support for mounting and unmounting volumes backed by volume plugins. Support for actually retrieving plugins requires a pull request to land in containers.conf and then that to be vendored, and as such is not yet ready. Given this, this code is only compile tested. However, the code for everything past retrieving the plugin has been written - there is support for creating, removing, mounting, and unmounting volumes, which should allow full functionality once the c/common PR is merged. A major change is the signature of the MountPoint function for volumes, which now, by necessity, returns an error. Named volumes managed by a plugin do not have a mountpoint we control; instead, it is managed entirely by the plugin. As such, we need to cache the path in the DB, and calls to retrieve it now need to access the DB (and may fail as such). Notably absent is support for SELinux relabelling and chowning these volumes. Given that we don't manage the mountpoint for these volumes, I am extremely reluctant to try and modify it - we could easily break the plugin trying to chown or relabel it. Also, we had no less than *5* separate implementations of inspecting a volume floating around in pkg/infra/abi and pkg/api/handlers/libpod. And none of them used volume.Inspect(), the only correct way of inspecting volumes. Remove them all and consolidate to using the correct way. Compat API is likely still doing things the wrong way, but that is an issue for another day. Fixes #4304 Signed-off-by: Matthew Heon <matthew.heon@pm.me>
		
			
				
	
	
		
			71 lines
		
	
	
		
			1.7 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			71 lines
		
	
	
		
			1.7 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| package libpod
 | |
| 
 | |
| import (
 | |
| 	"os"
 | |
| 	"path/filepath"
 | |
| 
 | |
| 	"github.com/containers/podman/v2/libpod/define"
 | |
| 	"github.com/pkg/errors"
 | |
| )
 | |
| 
 | |
| // Creates a new volume
 | |
| func newVolume(runtime *Runtime) *Volume {
 | |
| 	volume := new(Volume)
 | |
| 	volume.config = new(VolumeConfig)
 | |
| 	volume.state = new(VolumeState)
 | |
| 	volume.runtime = runtime
 | |
| 	volume.config.Labels = make(map[string]string)
 | |
| 	volume.config.Options = make(map[string]string)
 | |
| 	volume.state.NeedsCopyUp = true
 | |
| 	return volume
 | |
| }
 | |
| 
 | |
| // teardownStorage deletes the volume from volumePath
 | |
| func (v *Volume) teardownStorage() error {
 | |
| 	if v.UsesVolumeDriver() {
 | |
| 		return nil
 | |
| 	}
 | |
| 
 | |
| 	// TODO: Should this be converted to use v.config.MountPoint?
 | |
| 	return os.RemoveAll(filepath.Join(v.runtime.config.Engine.VolumePath, v.Name()))
 | |
| }
 | |
| 
 | |
| // Volumes with options set, or a filesystem type, or a device to mount need to
 | |
| // be mounted and unmounted.
 | |
| func (v *Volume) needsMount() bool {
 | |
| 	// Non-local driver always needs mount
 | |
| 	if v.UsesVolumeDriver() {
 | |
| 		return true
 | |
| 	}
 | |
| 
 | |
| 	// Local driver with options needs mount
 | |
| 	return len(v.config.Options) > 0
 | |
| }
 | |
| 
 | |
| // update() updates the volume state from the DB.
 | |
| func (v *Volume) update() error {
 | |
| 	if err := v.runtime.state.UpdateVolume(v); err != nil {
 | |
| 		return err
 | |
| 	}
 | |
| 	if !v.valid {
 | |
| 		return define.ErrVolumeRemoved
 | |
| 	}
 | |
| 	return nil
 | |
| }
 | |
| 
 | |
| // save() saves the volume state to the DB
 | |
| func (v *Volume) save() error {
 | |
| 	return v.runtime.state.SaveVolume(v)
 | |
| }
 | |
| 
 | |
| // Refresh volume state after a restart.
 | |
| func (v *Volume) refresh() error {
 | |
| 	lock, err := v.runtime.lockManager.AllocateAndRetrieveLock(v.config.LockID)
 | |
| 	if err != nil {
 | |
| 		return errors.Wrapf(err, "error acquiring lock %d for volume %s", v.config.LockID, v.Name())
 | |
| 	}
 | |
| 	v.lock = lock
 | |
| 
 | |
| 	return nil
 | |
| }
 |