mirror of
				https://github.com/containers/podman.git
				synced 2025-10-25 18:25:59 +08:00 
			
		
		
		
	 997de2f8e9
			
		
	
	997de2f8e9
	
	
	
		
			
			Basic theory: We remove the container, but *only from the DB*. We leave it in c/storage, we leave the lock allocated, we leave it running (if it is). Then we create an identical container with an altered name, and add that back to the database. Theoretically we now have a renamed container. The advantage of this approach is that it doesn't just apply to rename - we can use this to make *any* configuration change to a container that does not alter its container ID. Potential problems are numerous. This process is *THOROUGHLY* non-atomic at present - if you `kill -9` Podman mid-rename things will be in a bad place, for example. Also, we can't rename containers that can't be removed normally - IE, containers with dependencies (pod infra containers, for example). The largest potential improvement will be to move the majority of the work into the DB, with a `RecreateContainer()` method - that will add atomicity, and let us remove the container without worrying about depencies and similar issues. Potential problems: long-running processes that edit the DB and may have an older version of the configuration around. Most notable example is `podman run --rm` - the removal command needed to be manually edited to avoid this one. This begins to get at the heart of me not wanting to do this in the first place... This provides CLI and API implementations for frontend, but no tunnel implementation. It will be added in a future release (just held back for time now - we need this in 3.0 and are running low on time). This is honestly kind of horrifying, but I think it will work. Signed-off-by: Matthew Heon <mheon@redhat.com>
		
			
				
	
	
		
			52 lines
		
	
	
		
			5.3 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
			
		
		
	
	
			52 lines
		
	
	
		
			5.3 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
| % podman-container(1)
 | |
| 
 | |
| ## NAME
 | |
| podman\-container - Manage containers
 | |
| 
 | |
| ## SYNOPSIS
 | |
| **podman container** *subcommand*
 | |
| 
 | |
| ## DESCRIPTION
 | |
| The container command allows you to manage containers
 | |
| 
 | |
| ## COMMANDS
 | |
| 
 | |
| | Command    | Man Page                                            | Description                                                                  |
 | |
| | ---------  | --------------------------------------------------- | ---------------------------------------------------------------------------- |
 | |
| | attach     | [podman-attach(1)](podman-attach.1.md)              | Attach to a running container.                                               |
 | |
| | checkpoint | [podman-container-checkpoint(1)](podman-container-checkpoint.1.md)  | Checkpoints one or more running containers.                  |
 | |
| | cleanup    | [podman-container-cleanup(1)](podman-container-cleanup.1.md)    | Cleanup the container's network and mountpoints.                 |
 | |
| | commit     | [podman-commit(1)](podman-commit.1.md)              | Create new image based on the changed container.                             |
 | |
| | cp         | [podman-cp(1)](podman-cp.1.md)                      | Copy files/folders between a container and the local filesystem.             |
 | |
| | create     | [podman-create(1)](podman-create.1.md)              | Create a new container.                                                      |
 | |
| | diff       | [podman-diff(1)](podman-diff.1.md)                  | Inspect changes on a container or image's filesystem.                        |
 | |
| | exec       | [podman-exec(1)](podman-exec.1.md)                  | Execute a command in a running container.                                    |
 | |
| | exists     | [podman-container-exists(1)](podman-container-exists.1.md)  | Check if a container exists in local storage                         |
 | |
| | export     | [podman-export(1)](podman-export.1.md)              | Export a container's filesystem contents as a tar archive.                   |
 | |
| | init       | [podman-init(1)](podman-init.1.md)                  | Initialize a container                                                       |
 | |
| | inspect    | [podman-inspect(1)](podman-inspect.1.md)            | Display a container or image's configuration.                                |
 | |
| | kill       | [podman-kill(1)](podman-kill.1.md)                  | Kill the main process in one or more containers.                             |
 | |
| | list       | [podman-ps(1)](podman-ps.1.md)                      | List the containers on the system.(alias ls)                                 |
 | |
| | logs       | [podman-logs(1)](podman-logs.1.md)                  | Display the logs of a container.                                             |
 | |
| | mount      | [podman-mount(1)](podman-mount.1.md)                | Mount a working container's root filesystem.                                 |
 | |
| | pause      | [podman-pause(1)](podman-pause.1.md)                | Pause one or more containers.                                                |
 | |
| | port       | [podman-port(1)](podman-port.1.md)                  | List port mappings for the container.                                        |
 | |
| | prune      | [podman-container-prune(1)](podman-container-prune.1.md)| Remove all stopped containers from local storage.                        |
 | |
| | ps         | [podman-ps(1)](podman-ps.1.md)                      | Prints out information about containers.                                     |
 | |
| | rename     | [podman-rename(1)](podman-rename.1.md)              | Rename an existing container.                                                |
 | |
| | restart    | [podman-restart(1)](podman-restart.1.md)            | Restart one or more containers.                                              |
 | |
| | restore    | [podman-container-restore(1)](podman-container-restore.1.md)  | Restores one or more containers from a checkpoint.                 |
 | |
| | rm         | [podman-rm(1)](podman-rm.1.md)                      | Remove one or more containers.                                               |
 | |
| | run        | [podman-run(1)](podman-run.1.md)                    | Run a command in a container.                                                |
 | |
| | runlabel   | [podman-container-runlabel(1)](podman-container-runlabel.1.md)  | Executes a command as described by a container image label.      |
 | |
| | start      | [podman-start(1)](podman-start.1.md)                | Starts one or more containers.                                               |
 | |
| | stats      | [podman-stats(1)](podman-stats.1.md)                | Display a live stream of one or more container's resource usage statistics.  |
 | |
| | stop       | [podman-stop(1)](podman-stop.1.md)                  | Stop one or more running containers.                                         |
 | |
| | top        | [podman-top(1)](podman-top.1.md)                    | Display the running processes of a container.                                |
 | |
| | unmount    | [podman-unmount(1)](podman-unmount.1.md)            | Unmount a working container's root filesystem.(Alias unmount)                |
 | |
| | unpause    | [podman-unpause(1)](podman-unpause.1.md)            | Unpause one or more containers.                                              |
 | |
| | wait       | [podman-wait(1)](podman-wait.1.md)                  | Wait on one or more containers to stop and print their exit codes.           |
 | |
| 
 | |
| ## SEE ALSO
 | |
| podman, podman-exec, podman-run
 |