Dieser Inhalt ist in der von Ihnen ausgewählten Sprache nicht verfügbar.
Chapter 21. Using the container-tools API
The new REST based Podman 2.0 API replaces the old remote API for Podman that used the varlink library. The new API works in both a rootful and a rootless environment.
The Podman v2.0 RESTful API consists of the Libpod API providing support for Podman, and Docker-compatible API. With this new REST API, you can call Podman from platforms such as cURL, Postman, Google’s Advanced REST client, and many others.
				As the podman service supports socket activation, unless connections on the socket are active, podman service will not run. Hence, to enable socket activation functionality, you need to manually start the podman.socket service. When a connection becomes active on the socket, it starts the podman service and runs the requested API action. Once the action is completed, the podman process ends, and the podman service returns to an inactive state.
			
21.1. Enabling the Podman API using systemd in root mode
You can do the following:
- 
						Use systemdto activate the Podman API socket.
- Use a Podman client to perform basic commands.
Prerequisites
- The - podman-remotepackage is installed.- dnf install podman-remote - # dnf install podman-remote- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
Procedure
- Start the service immediately: - systemctl enable --now podman.socket - # systemctl enable --now podman.socket- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- To enable the link to - var/lib/docker.sockby using the- docker-podmanpackage:- dnf install podman-docker - # dnf install podman-docker- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
Verification
- Display system information of Podman: - podman-remote info - # podman-remote info- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Verify the link: - ls -al /var/run/docker.sock - # ls -al /var/run/docker.sock lrwxrwxrwx. 1 root root 23 Nov 4 10:19 /var/run/docker.sock -> /run/podman/podman.sock- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
21.2. Enabling the Podman API using systemd in rootless mode
				You can use systemd to activate the Podman API socket and podman API service.
			
Prerequisites
- The - podman-remotepackage is installed.- dnf install podman-remote - # dnf install podman-remote- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
Procedure
- Enable and start the service immediately: - systemctl --user enable --now podman.socket - $ systemctl --user enable --now podman.socket- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Optional: To enable programs by using Docker to interact with the rootless Podman socket: - export DOCKER_HOST=unix:///run/user/<uid>/podman//podman.sock - $ export DOCKER_HOST=unix:///run/user/<uid>/podman//podman.sock- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
Verification
- Check the status of the socket: - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - The - podman.socketis active and is listening at- /run/user/<uid>/podman.podman.sock, where- <uid>is the user’s ID.
- Display system information of Podman: - podman-remote info - $ podman-remote info- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
21.3. Running the Podman API manually
You can run the Podman API. This is useful for debugging API calls, especially when using the Docker compatibility layer.
Prerequisites
- The - podman-remotepackage is installed.- dnf install podman-remote - # dnf install podman-remote- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
Procedure
- Run the service for the REST API: - podman system service -t 0 --log-level=debug - # podman system service -t 0 --log-level=debug- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 
								The value of 0 means no timeout. The default endpoint for a rootful service is unix:/run/podman/podman.sock.
- 
								The --log-level <level>option sets the logging level. The standard logging levels aredebug,info,warn,error,fatal, andpanic.
 
- 
								The value of 0 means no timeout. The default endpoint for a rootful service is 
- In another terminal, display system information of Podman. The - podman-remotecommand, unlike the regular- podmancommand, communicates through the Podman socket:- podman-remote info - # podman-remote info- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- To troubleshoot the Podman API and display request and responses, use the - curlcomman. To get the information about the Podman installation on the Linux server in JSON format:- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - A - jqutility is a command-line JSON processor.
- Pull the - registry.access.redhat.com/ubi8/ubicontainer image:- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Display the pulled image: - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow