From cf55e09e2df51ce17138f319eef2850a6b932a00 Mon Sep 17 00:00:00 2001 From: "github-actions[bot]" <41898282+github-actions[bot]@users.noreply.github.com> Date: Fri, 17 Nov 2023 14:14:06 +0000 Subject: [PATCH] deploy: b0c33f3dd488da9aef23480a570b7f069378263e --- 404.html | 4 ++-- assets/js/006e489c.691b93c2.js | 1 - assets/js/006e489c.ddaf0a3e.js | 1 + assets/js/014457dd.ca826858.js | 1 + assets/js/014457dd.f3f94425.js | 1 - assets/js/021eaa84.6dede19a.js | 1 - assets/js/021eaa84.adb70247.js | 1 + assets/js/07f59c2a.6701e01f.js | 1 + assets/js/07f59c2a.7bc1a408.js | 1 - assets/js/09b168a7.23336dd5.js | 1 - assets/js/09b168a7.b8dde927.js | 1 + assets/js/10ce918d.31bdb7d6.js | 1 + assets/js/10ce918d.f4a75fd4.js | 1 - assets/js/{17896441.1a690c9c.js => 17896441.edf3f98f.js} | 2 +- assets/js/1a16e8bf.1fb6071f.js | 1 + assets/js/1a16e8bf.e37eaeb3.js | 1 - assets/js/25622900.a5170eed.js | 1 + assets/js/25622900.f0255b71.js | 1 - assets/js/2d629ea6.f60fd6be.js | 1 - assets/js/2d629ea6.f8d34b3d.js | 1 + assets/js/330dfcdb.5351f9c1.js | 1 + assets/js/330dfcdb.a0707feb.js | 1 - assets/js/33a21d7d.993d4689.js | 1 + assets/js/33a21d7d.fbbea2a5.js | 1 - assets/js/368cce37.1900730d.js | 1 - assets/js/368cce37.37faff5c.js | 1 + assets/js/4213e5b1.2a5e16f5.js | 1 - assets/js/4213e5b1.eb013531.js | 1 + assets/js/473de3ed.9ed7082a.js | 1 - assets/js/473de3ed.ac1acbcd.js | 1 + assets/js/4816649b.13b901ec.js | 1 - assets/js/4816649b.e532397c.js | 1 + assets/js/4b8121dd.12bc2380.js | 1 + assets/js/4b8121dd.24fea72f.js | 1 - assets/js/51e516cc.b48a3263.js | 1 + assets/js/51e516cc.e1bb3a48.js | 1 - assets/js/54590fd2.05d927ca.js | 1 + assets/js/54590fd2.8a802f7b.js | 1 - assets/js/562ca3e9.c43abc7d.js | 1 + assets/js/562ca3e9.e6938fa9.js | 1 - assets/js/{5660752d.3fd29c77.js => 5660752d.7df7d400.js} | 2 +- assets/js/5df556a2.045cc138.js | 1 - assets/js/5df556a2.74568e5d.js | 1 + assets/js/64abd3af.769a0da2.js | 1 + assets/js/64abd3af.d733c2bb.js | 1 - assets/js/{6875c492.51bd3ba5.js => 6875c492.58abc53b.js} | 2 +- assets/js/6bf124c2.2d89c3a9.js | 1 + assets/js/6bf124c2.5d83dfab.js | 1 - assets/js/{81e486a8.e2d287c9.js => 81e486a8.9db760d6.js} | 2 +- assets/js/{94f3d131.91c40158.js => 94f3d131.fd0510fd.js} | 2 +- assets/js/959a8cfe.d67837c1.js | 1 + assets/js/959a8cfe.e598f70b.js | 1 - assets/js/9dce5486.1c39382d.js | 1 - assets/js/9dce5486.1e0f7d27.js | 1 + assets/js/{9e8f4e9c.ead1b706.js => 9e8f4e9c.d3f71dc8.js} | 2 +- assets/js/a00af9f0.76d3862d.js | 1 - assets/js/a00af9f0.ba62cf4a.js | 1 + assets/js/a0323d9f.2002b11a.js | 1 - assets/js/a0323d9f.5edc8952.js | 1 + assets/js/{a6aa9e1f.cf7d6632.js => a6aa9e1f.a7e9e028.js} | 2 +- assets/js/a8ce95ee.3dd3ba53.js | 1 - assets/js/a8ce95ee.49c3ddcc.js | 1 + assets/js/aaabcfd8.1dc6e4a1.js | 1 + assets/js/aaabcfd8.c58bf8b6.js | 1 - assets/js/{abc85917.d2b27867.js => abc85917.a2923a83.js} | 2 +- assets/js/af231220.6661ae24.js | 1 + assets/js/af231220.de109415.js | 1 - assets/js/b104dd1e.7db7c3e0.js | 1 - assets/js/b104dd1e.e06e9c08.js | 1 + assets/js/{b2f554cd.7afd319e.js => b2f554cd.12630173.js} | 2 +- assets/js/{bd80aa65.f0f8caf8.js => bd80aa65.07ae56ee.js} | 2 +- assets/js/{c5b2f0f9.c0c9ba07.js => c5b2f0f9.4d4620c9.js} | 2 +- assets/js/{ccc49370.0a9a510b.js => ccc49370.1191af98.js} | 2 +- assets/js/d1b15a6d.51e398af.js | 1 + assets/js/d1b15a6d.58a24c58.js | 1 - assets/js/d651e2ee.43a52878.js | 1 + assets/js/d651e2ee.ae1174d6.js | 1 - assets/js/de311ed4.0d61b40e.js | 1 + assets/js/de311ed4.7419c21d.js | 1 - assets/js/e44de27e.bbd5ecaa.js | 1 + assets/js/e44de27e.bf2c1cc8.js | 1 - assets/js/eb17771c.21d051e3.js | 1 + assets/js/eb17771c.f1561fea.js | 1 - assets/js/ed75cfcb.4a5a7db3.js | 1 - assets/js/ed75cfcb.b0f7a881.js | 1 + assets/js/f425c855.23009f9f.js | 1 + assets/js/f425c855.f323ad1d.js | 1 - assets/js/fb50ea3a.17de80bc.js | 1 - assets/js/fb50ea3a.9166135e.js | 1 + assets/js/fc8a94e3.1bd597cd.js | 1 - assets/js/fc8a94e3.3370fdba.js | 1 + .../js/{runtime~main.33da2221.js => runtime~main.4bd03f2f.js} | 2 +- blog.html | 4 ++-- blog/5-things-to-know-for-a-docker-user.html | 4 ++-- blog/archive.html | 4 ++-- blog/develop-using-devcontainer.html | 4 ++-- blog/podman-desktop-release-0.10.html | 4 ++-- blog/podman-desktop-release-0.11.html | 4 ++-- blog/podman-desktop-release-0.12.html | 4 ++-- blog/podman-desktop-release-0.13.html | 4 ++-- blog/podman-desktop-release-0.14.html | 4 ++-- blog/podman-desktop-release-0.15.html | 4 ++-- blog/podman-desktop-release-1.0.html | 4 ++-- blog/podman-desktop-release-1.1.html | 4 ++-- blog/podman-desktop-release-1.2.html | 4 ++-- blog/podman-desktop-release-1.3.html | 4 ++-- blog/podman-desktop-release-1.4.html | 4 ++-- blog/podman-desktop-release-1.5.html | 4 ++-- ...unning-a-local-kubernetes-cluster-with-podman-desktop.html | 4 ++-- blog/tags.html | 4 ++-- blog/tags/codespaces.html | 4 ++-- blog/tags/compose.html | 4 ++-- blog/tags/devcontainer.html | 4 ++-- blog/tags/docker.html | 4 ++-- blog/tags/extensions.html | 4 ++-- blog/tags/kind.html | 4 ++-- blog/tags/kubernetes.html | 4 ++-- blog/tags/migrating.html | 4 ++-- blog/tags/onboarding.html | 4 ++-- blog/tags/openshift.html | 4 ++-- blog/tags/podman-desktop.html | 4 ++-- blog/tags/release.html | 4 ++-- blog/tags/settings.html | 4 ++-- blog/tags/story.html | 4 ++-- core-values.html | 4 ++-- docs/compose.html | 4 ++-- docs/compose/running-compose.html | 4 ++-- docs/compose/setting-up-compose.html | 4 ++-- docs/containers.html | 4 ++-- docs/containers/creating-a-pod.html | 4 ++-- docs/containers/images.html | 4 ++-- docs/containers/images/building-an-image.html | 4 ++-- docs/containers/images/pulling-an-image.html | 4 ++-- docs/containers/images/pushing-an-image-to-a-registry.html | 4 ++-- docs/containers/onboarding.html | 4 ++-- docs/containers/registries.html | 4 ++-- .../authenticating-to-a-preconfigured-registry.html | 4 ++-- docs/containers/registries/insecure-registry.html | 4 ++-- docs/containers/starting-a-container.html | 4 ++-- docs/extensions.html | 4 ++-- docs/extensions/install.html | 4 ++-- docs/extensions/publish.html | 4 ++-- docs/extensions/write.html | 4 ++-- docs/extensions/write/when-clause-context.html | 4 ++-- docs/installation.html | 4 ++-- docs/installation/linux-install.html | 4 ++-- .../installing-podman-desktop-from-a-compressed-tar-file.html | 4 ++-- .../installing-podman-desktop-from-a-flatpak-bundle.html | 4 ++-- docs/installation/macos-install.html | 4 ++-- docs/installation/windows-install.html | 4 ++-- ...podman-desktop-and-podman-in-a-restricted-environment.html | 4 ++-- ...ng-podman-desktop-silently-with-the-windows-installer.html | 4 ++-- .../installing-podman-desktop-with-chocolatey.html | 4 ++-- .../windows-install/installing-podman-desktop-with-scoop.html | 4 ++-- .../installing-podman-desktop-with-winget.html | 4 ++-- docs/intro.html | 4 ++-- docs/kind.html | 4 ++-- docs/kind/building-an-image-and-testing-it-in-kind.html | 4 ++-- docs/kind/configuring-podman-for-kind-on-windows.html | 4 ++-- docs/kind/creating-a-kind-cluster.html | 4 ++-- docs/kind/deleting-your-kind-cluster.html | 4 ++-- docs/kind/installing.html | 4 ++-- docs/kind/pushing-an-image-to-kind.html | 4 ++-- docs/kind/restarting-your-kind-cluster.html | 4 ++-- docs/kind/working-with-your-local-kind-cluster.html | 4 ++-- docs/kubernetes.html | 4 ++-- docs/kubernetes/deploying-a-container-to-kubernetes.html | 4 ++-- docs/kubernetes/deploying-a-pod-to-kubernetes.html | 4 ++-- docs/kubernetes/existing-kubernetes.html | 4 ++-- docs/kubernetes/kind/pushing-an-image-to-kind.html | 4 ++-- ...selecting-current-kubernete-context-in-the-status-bar.html | 4 ++-- .../viewing-and-selecting-current-kubernete-context.html | 4 ++-- docs/lima.html | 4 ++-- docs/lima/creating-a-kubernetes-instance.html | 4 ++-- docs/lima/creating-a-lima-instance.html | 4 ++-- docs/lima/customizing.html | 4 ++-- docs/lima/installing.html | 4 ++-- docs/migrating-from-docker.html | 4 ++-- .../emulating-docker-cli-with-podman.html | 4 ++-- docs/migrating-from-docker/importing-saved-containers.html | 4 ++-- docs/migrating-from-docker/using-podman-mac-helper.html | 4 ++-- .../using-the-docker_host-environment-variable.html | 4 ++-- .../verifying-your-tools-are-using-podman.html | 4 ++-- docs/minikube.html | 4 ++-- .../building-an-image-and-testing-it-in-minikube.html | 4 ++-- docs/minikube/configuring-podman-for-minikube-on-windows.html | 4 ++-- docs/minikube/creating-a-minikube-cluster.html | 4 ++-- docs/minikube/deleting-your-minikube-cluster.html | 4 ++-- docs/minikube/installing.html | 4 ++-- docs/minikube/pushing-an-image-to-minikube.html | 4 ++-- docs/minikube/restarting-your-minikube-cluster.html | 4 ++-- docs/minikube/working-with-your-local-minikube-cluster.html | 4 ++-- docs/openshift.html | 4 ++-- docs/openshift/developer-sandbox.html | 4 ++-- docs/openshift/openshift-local.html | 4 ++-- docs/podman.html | 4 ++-- docs/podman/creating-a-podman-machine.html | 4 ++-- .../installing-podman-with-openshift-local-on-windows.html | 4 ++-- docs/podman/installing.html | 4 ++-- docs/podman/setting-podman-machine-default-connection.html | 4 ++-- docs/proxy.html | 4 ++-- docs/proxy/using-a-proxy-in-your-containers.html | 4 ++-- docs/proxy/using-a-proxy-on-linux.html | 4 ++-- docs/proxy/using-a-proxy-requiring-a-custom-ca.html | 4 ++-- docs/proxy/using-a-proxy.html | 4 ++-- docs/proxy/using-a-vpn-on-windows.html | 4 ++-- docs/tags.html | 4 ++-- docs/tags/chocolatey.html | 4 ++-- docs/tags/compose.html | 4 ++-- docs/tags/containers.html | 4 ++-- docs/tags/docker.html | 4 ++-- docs/tags/extension.html | 4 ++-- docs/tags/flathub.html | 4 ++-- docs/tags/flatpak.html | 4 ++-- docs/tags/images.html | 4 ++-- docs/tags/installing.html | 4 ++-- docs/tags/kind.html | 4 ++-- docs/tags/kubernetes.html | 4 ++-- docs/tags/lima.html | 4 ++-- docs/tags/linux.html | 4 ++-- docs/tags/mac-0-s.html | 4 ++-- docs/tags/mac-os.html | 4 ++-- docs/tags/macos.html | 4 ++-- docs/tags/migrating-from-docker.html | 4 ++-- docs/tags/migrating-to-kubernetes.html | 4 ++-- docs/tags/minikube.html | 4 ++-- docs/tags/onboarding.html | 4 ++-- docs/tags/openshift-local.html | 4 ++-- docs/tags/openshift.html | 4 ++-- docs/tags/podman-desktop.html | 4 ++-- docs/tags/podman.html | 4 ++-- docs/tags/pods.html | 4 ++-- docs/tags/proxy.html | 4 ++-- docs/tags/publishing.html | 4 ++-- docs/tags/registries.html | 4 ++-- docs/tags/restricted-environment.html | 4 ++-- docs/tags/scoop.html | 4 ++-- docs/tags/vpn.html | 4 ++-- docs/tags/when-clause.html | 4 ++-- docs/tags/windows.html | 4 ++-- docs/tags/winget.html | 4 ++-- docs/tags/writing.html | 4 ++-- docs/troubleshooting.html | 4 ++-- docs/troubleshooting/troubleshooting-openshift-local.html | 4 ++-- docs/troubleshooting/troubleshooting-podman-on-linux.html | 4 ++-- docs/troubleshooting/troubleshooting-podman-on-macos.html | 4 ++-- docs/troubleshooting/troubleshooting-podman-on-windows.html | 4 ++-- docs/troubleshooting/troubleshooting-podman.html | 4 ++-- downloads.html | 4 ++-- downloads/linux.html | 4 ++-- downloads/macos.html | 4 ++-- downloads/windows.html | 4 ++-- extend.html | 4 ++-- features.html | 4 ++-- index.html | 4 ++-- search.html | 4 ++-- 256 files changed, 382 insertions(+), 382 deletions(-) delete mode 100644 assets/js/006e489c.691b93c2.js create mode 100644 assets/js/006e489c.ddaf0a3e.js create mode 100644 assets/js/014457dd.ca826858.js delete mode 100644 assets/js/014457dd.f3f94425.js delete mode 100644 assets/js/021eaa84.6dede19a.js create mode 100644 assets/js/021eaa84.adb70247.js create mode 100644 assets/js/07f59c2a.6701e01f.js delete mode 100644 assets/js/07f59c2a.7bc1a408.js delete mode 100644 assets/js/09b168a7.23336dd5.js create mode 100644 assets/js/09b168a7.b8dde927.js create mode 100644 assets/js/10ce918d.31bdb7d6.js delete mode 100644 assets/js/10ce918d.f4a75fd4.js rename assets/js/{17896441.1a690c9c.js => 17896441.edf3f98f.js} (99%) create mode 100644 assets/js/1a16e8bf.1fb6071f.js delete mode 100644 assets/js/1a16e8bf.e37eaeb3.js create mode 100644 assets/js/25622900.a5170eed.js delete mode 100644 assets/js/25622900.f0255b71.js delete mode 100644 assets/js/2d629ea6.f60fd6be.js create mode 100644 assets/js/2d629ea6.f8d34b3d.js create mode 100644 assets/js/330dfcdb.5351f9c1.js delete mode 100644 assets/js/330dfcdb.a0707feb.js create mode 100644 assets/js/33a21d7d.993d4689.js delete mode 100644 assets/js/33a21d7d.fbbea2a5.js delete mode 100644 assets/js/368cce37.1900730d.js create mode 100644 assets/js/368cce37.37faff5c.js delete mode 100644 assets/js/4213e5b1.2a5e16f5.js create mode 100644 assets/js/4213e5b1.eb013531.js delete mode 100644 assets/js/473de3ed.9ed7082a.js create mode 100644 assets/js/473de3ed.ac1acbcd.js delete mode 100644 assets/js/4816649b.13b901ec.js create mode 100644 assets/js/4816649b.e532397c.js create mode 100644 assets/js/4b8121dd.12bc2380.js delete mode 100644 assets/js/4b8121dd.24fea72f.js create mode 100644 assets/js/51e516cc.b48a3263.js delete mode 100644 assets/js/51e516cc.e1bb3a48.js create mode 100644 assets/js/54590fd2.05d927ca.js delete mode 100644 assets/js/54590fd2.8a802f7b.js create mode 100644 assets/js/562ca3e9.c43abc7d.js delete mode 100644 assets/js/562ca3e9.e6938fa9.js rename assets/js/{5660752d.3fd29c77.js => 5660752d.7df7d400.js} (50%) delete mode 100644 assets/js/5df556a2.045cc138.js create mode 100644 assets/js/5df556a2.74568e5d.js create mode 100644 assets/js/64abd3af.769a0da2.js delete mode 100644 assets/js/64abd3af.d733c2bb.js rename assets/js/{6875c492.51bd3ba5.js => 6875c492.58abc53b.js} (98%) create mode 100644 assets/js/6bf124c2.2d89c3a9.js delete mode 100644 assets/js/6bf124c2.5d83dfab.js rename assets/js/{81e486a8.e2d287c9.js => 81e486a8.9db760d6.js} (54%) rename assets/js/{94f3d131.91c40158.js => 94f3d131.fd0510fd.js} (50%) create mode 100644 assets/js/959a8cfe.d67837c1.js delete mode 100644 assets/js/959a8cfe.e598f70b.js delete mode 100644 assets/js/9dce5486.1c39382d.js create mode 100644 assets/js/9dce5486.1e0f7d27.js rename assets/js/{9e8f4e9c.ead1b706.js => 9e8f4e9c.d3f71dc8.js} (58%) delete mode 100644 assets/js/a00af9f0.76d3862d.js create mode 100644 assets/js/a00af9f0.ba62cf4a.js delete mode 100644 assets/js/a0323d9f.2002b11a.js create mode 100644 assets/js/a0323d9f.5edc8952.js rename assets/js/{a6aa9e1f.cf7d6632.js => a6aa9e1f.a7e9e028.js} (97%) delete mode 100644 assets/js/a8ce95ee.3dd3ba53.js create mode 100644 assets/js/a8ce95ee.49c3ddcc.js create mode 100644 assets/js/aaabcfd8.1dc6e4a1.js delete mode 100644 assets/js/aaabcfd8.c58bf8b6.js rename assets/js/{abc85917.d2b27867.js => abc85917.a2923a83.js} (59%) create mode 100644 assets/js/af231220.6661ae24.js delete mode 100644 assets/js/af231220.de109415.js delete mode 100644 assets/js/b104dd1e.7db7c3e0.js create mode 100644 assets/js/b104dd1e.e06e9c08.js rename assets/js/{b2f554cd.7afd319e.js => b2f554cd.12630173.js} (98%) rename assets/js/{bd80aa65.f0f8caf8.js => bd80aa65.07ae56ee.js} (68%) rename assets/js/{c5b2f0f9.c0c9ba07.js => c5b2f0f9.4d4620c9.js} (52%) rename assets/js/{ccc49370.0a9a510b.js => ccc49370.1191af98.js} (99%) create mode 100644 assets/js/d1b15a6d.51e398af.js delete mode 100644 assets/js/d1b15a6d.58a24c58.js create mode 100644 assets/js/d651e2ee.43a52878.js delete mode 100644 assets/js/d651e2ee.ae1174d6.js create mode 100644 assets/js/de311ed4.0d61b40e.js delete mode 100644 assets/js/de311ed4.7419c21d.js create mode 100644 assets/js/e44de27e.bbd5ecaa.js delete mode 100644 assets/js/e44de27e.bf2c1cc8.js create mode 100644 assets/js/eb17771c.21d051e3.js delete mode 100644 assets/js/eb17771c.f1561fea.js delete mode 100644 assets/js/ed75cfcb.4a5a7db3.js create mode 100644 assets/js/ed75cfcb.b0f7a881.js create mode 100644 assets/js/f425c855.23009f9f.js delete mode 100644 assets/js/f425c855.f323ad1d.js delete mode 100644 assets/js/fb50ea3a.17de80bc.js create mode 100644 assets/js/fb50ea3a.9166135e.js delete mode 100644 assets/js/fc8a94e3.1bd597cd.js create mode 100644 assets/js/fc8a94e3.3370fdba.js rename assets/js/{runtime~main.33da2221.js => runtime~main.4bd03f2f.js} (70%) diff --git a/404.html b/404.html index 4b14c83daba..255df829a8c 100644 --- a/404.html +++ b/404.html @@ -13,13 +13,13 @@ - +
Skip to main content

Page Not Found

We could not find what you were looking for.

Please contact the owner of the site that linked you to the original URL and let them know their link is broken.

- + \ No newline at end of file diff --git a/assets/js/006e489c.691b93c2.js b/assets/js/006e489c.691b93c2.js deleted file mode 100644 index adceefe7a69..00000000000 --- a/assets/js/006e489c.691b93c2.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[8145],{3064:(e,t,a)=>{a.r(t),a.d(t,{assets:()=>r,contentTitle:()=>p,default:()=>u,frontMatter:()=>l,metadata:()=>i,toc:()=>m});var n=a(25773),o=(a(27378),a(35318)),s=a(92975);const l={title:"Release Notes - Podman Desktop 0.13",description:"Podman Desktop 0.13 has been released!",slug:"podman-desktop-release-0.13",authors:["deboer"],tags:["podman-desktop","release","kubernetes","compose"],hide_table_of_contents:!1},p=void 0,i={permalink:"/blog/podman-desktop-release-0.13",source:"@site/blog/2023-03-29-release-0.13.md",title:"Release Notes - Podman Desktop 0.13",description:"Podman Desktop 0.13 has been released!",date:"2023-03-29T00:00:00.000Z",formattedDate:"March 29, 2023",tags:[{label:"podman-desktop",permalink:"/blog/tags/podman-desktop"},{label:"release",permalink:"/blog/tags/release"},{label:"kubernetes",permalink:"/blog/tags/kubernetes"},{label:"compose",permalink:"/blog/tags/compose"}],readingTime:3.155,hasTruncateMarker:!0,authors:[{name:"Tim deBoer",title:"Architect",url:"https://github.com/deboer-tim",imageURL:"https://github.com/deboer-tim.png",key:"deboer"}],frontMatter:{title:"Release Notes - Podman Desktop 0.13",description:"Podman Desktop 0.13 has been released!",slug:"podman-desktop-release-0.13",authors:["deboer"],tags:["podman-desktop","release","kubernetes","compose"],hide_table_of_contents:!1},prevItem:{title:"Release Notes - Podman Desktop 0.14",permalink:"/blog/podman-desktop-release-0.14"},nextItem:{title:"5 things to know about Podman Desktop for a Docker user",permalink:"/blog/5-things-to-know-for-a-docker-user"}},r={authorsImageUrls:[void 0]},m=[{value:"Release details",id:"release-details",level:2},{value:"Update to Podman v4.4.4",id:"update-to-podman-v444",level:3},{value:"Compose support",id:"compose-support",level:3},{value:"Extensions",id:"extensions",level:3},{value:"UI and UX improvements",id:"ui-and-ux-improvements",level:3},{value:"Welcome page #1726",id:"welcome-page-1726",level:4},{value:"New Task Manager #1724",id:"new-task-manager-1724",level:4},{value:"Updated Resources Settings #1582",id:"updated-resources-settings-1582",level:4},{value:"Update Alerts #1827",id:"update-alerts-1827",level:4},{value:"Prune buttons #1481, #1482, #1484",id:"prune-buttons-1481-1482-1484",level:4},{value:"Other notable enhancements",id:"other-notable-enhancements",level:2},{value:"Documentation",id:"documentation",level:2},{value:"Notable bug fixes",id:"notable-bug-fixes",level:2},{value:"Community thank you",id:"community-thank-you",level:2},{value:"Final notes",id:"final-notes",level:2}],d={toc:m};function u(e){let{components:t,...l}=e;return(0,o.kt)("wrapper",(0,n.Z)({},d,l,{components:t,mdxType:"MDXLayout"}),(0,o.kt)("p",null,"This release note covers Podman Desktop 0.13 release changes."),(0,o.kt)("ul",null,(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("strong",{parentName:"li"},"Podman Version"),": Podman 4.4.4 now included in Windows and Mac installers."),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("strong",{parentName:"li"},"Compose"),": Support for installing Docker Compose."),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("strong",{parentName:"li"},"Extensions"),": Improved extension support for Podman Desktop with additional capabilities."),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("strong",{parentName:"li"},"UX and UI Improvements"),": Welcome page, task manager, resources, and update alerts.")),(0,o.kt)("p",null,"Podman Desktop 0.13 is now available. ",(0,o.kt)("a",{parentName:"p",href:"/downloads"},"Click here to download it"),"!"),(0,o.kt)("p",null,(0,o.kt)("img",{alt:"Podman-desktop-0-13-hero",src:a(75771).Z,width:"1852",height:"1323"})),(0,o.kt)("hr",null),(0,o.kt)("h2",{id:"release-details"},"Release details"),(0,o.kt)("h3",{id:"update-to-podman-v444"},"Update to Podman v4.4.4"),(0,o.kt)("p",null,"Podman Desktop 0.13 embeds ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman/releases/tag/v4.4.4"},"Podman 4.4.4")," in\nWindows and macOS installers ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/1456"},"#1456"),"."),(0,o.kt)("h3",{id:"compose-support"},"Compose support"),(0,o.kt)("p",null,"You can install Docker Compose from the Podman Desktop UI ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/1578"},"#1578"),". This will allow you use Compose workflows using Podman."),(0,o.kt)("h3",{id:"extensions"},"Extensions"),(0,o.kt)("p",null,"To make it easier to extend Podman Desktop we have:"),(0,o.kt)("ul",null,(0,o.kt)("li",{parentName:"ul"},"Published the ",(0,o.kt)("a",{parentName:"li",href:"https://www.npmjs.com/package/@podman-desktop/api"},"Podman Desktop Extension API")," to npmjs ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/1727"},"#1727")),(0,o.kt)("li",{parentName:"ul"},"Documented ",(0,o.kt)("a",{parentName:"li",href:"https://podman-desktop.io/docs/extensions"},"how to create, publish, and install your own extensions")),(0,o.kt)("li",{parentName:"ul"},"Expanded the API for ",(0,o.kt)("inlineCode",{parentName:"li"},"QuickPickInput")," ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/1839"},"#1839"))),(0,o.kt)("h3",{id:"ui-and-ux-improvements"},"UI and UX improvements"),(0,o.kt)("h4",{id:"welcome-page-1726"},"Welcome page ",(0,o.kt)("a",{parentName:"h4",href:"https://github.com/containers/podman-desktop/pull/1726"},"#1726")),(0,o.kt)("p",null,"The first time every user starts Podman Desktop, they will see a welcome page:"),(0,o.kt)("p",null,(0,o.kt)("img",{parentName:"p",src:"https://user-images.githubusercontent.com/19958075/225682776-e016ba31-5bb9-41d5-87ed-f93caeb3fb84.png",alt:"welcome-page"})),(0,o.kt)("p",null,"Note that the Welcome page will only appear the first time you run Podman Desktop 0.13.0, and none of your settings or assets in Podman Desktop will be affected by it.\nOver time, this page will be expanded to help with initial setup and configuration."),(0,o.kt)("h4",{id:"new-task-manager-1724"},"New Task Manager ",(0,o.kt)("a",{parentName:"h4",href:"https://github.com/containers/podman-desktop/pull/1724"},"#1724")),(0,o.kt)("p",null,"A new Task Manager has been added to the status bar to see the progress (or return to) long running tasks. To start with, building images ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/1725"},"#1725")," and Podman machine ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/1742"},"#1742")," are using the task manager."),(0,o.kt)("p",null,(0,o.kt)("img",{alt:"task-manager",src:a(9184).Z,width:"2082",height:"1198"})),(0,o.kt)("h4",{id:"updated-resources-settings-1582"},"Updated Resources Settings ",(0,o.kt)("a",{parentName:"h4",href:"https://github.com/containers/podman-desktop/pull/1582"},"#1582")),(0,o.kt)("p",null,"The ",(0,o.kt)("strong",{parentName:"p"},(0,o.kt)("icon",{icon:"fa-solid fa-cog",size:"lg"})," Settings > Resources")," page has been updated with a new design, making it easier to see and control your providers from a single place."),(0,o.kt)("p",null,(0,o.kt)("img",{parentName:"p",src:"https://user-images.githubusercontent.com/49404737/221908815-595715fe-4c95-4087-89e0-45e5544ed5c9.gif",alt:"resources"})),(0,o.kt)("p",null,"The other settings pages have been updated for consistency with this new design."),(0,o.kt)("h4",{id:"update-alerts-1827"},"Update Alerts ",(0,o.kt)("a",{parentName:"h4",href:"https://github.com/containers/podman-desktop/pull/1827"},"#1827")),(0,o.kt)("p",null,"A new alert button will appear in the status bar when future updates are available."),(0,o.kt)(s.Z,{playing:!0,controls:!0,url:"https://user-images.githubusercontent.com/436777/227596136-c6123d5c-d9ae-4fb3-a569-0cfaaeebf09c.mp4",width:"100%",height:"100%",mdxType:"ReactPlayer"}),(0,o.kt)("h4",{id:"prune-buttons-1481-1482-1484"},"Prune buttons ",(0,o.kt)("a",{parentName:"h4",href:"https://github.com/containers/podman-desktop/pull/1481"},"#1481"),", ",(0,o.kt)("a",{parentName:"h4",href:"https://github.com/containers/podman-desktop/pull/1482"},"#1482"),", ",(0,o.kt)("a",{parentName:"h4",href:"https://github.com/containers/podman-desktop/pull/1484"},"#1484")),(0,o.kt)("p",null,"We've added buttons to prune unused volumes ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/1481"},"#1481"),", images ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/1482"},"#1482")," and pods ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/1484"},"#1484"),"."),(0,o.kt)("p",null,(0,o.kt)("img",{alt:"prune-image",src:a(66557).Z,width:"2074",height:"570"})),(0,o.kt)("hr",null),(0,o.kt)("h2",{id:"other-notable-enhancements"},"Other notable enhancements"),(0,o.kt)("ul",null,(0,o.kt)("li",{parentName:"ul"},"Kubernetes pods are now shown in the Pods view ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/1312"},"#1312")),(0,o.kt)("li",{parentName:"ul"},"Easy button to fix Docker compatibility mode on macOS ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/1697"},"#1697")),(0,o.kt)("li",{parentName:"ul"},"Display extension icons ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/1058"},"#1058")),(0,o.kt)("li",{parentName:"ul"},"API to cancel long running tasks ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/1777"},"#1777"))),(0,o.kt)("hr",null),(0,o.kt)("h2",{id:"documentation"},"Documentation"),(0,o.kt)("p",null,"The documentation has new content:"),(0,o.kt)("ul",null,(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("a",{parentName:"li",href:"https://podman-desktop.io/docs/extensions"},"How to create, publish, and install your own Podman Desktop extensions")),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("a",{parentName:"li",href:"https://podman-desktop.io/docs/compose/podman-compose"},"Using Compose")),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("a",{parentName:"li",href:"https://podman-desktop.io/docs/kind"},"Restarting Kind"))),(0,o.kt)("hr",null),(0,o.kt)("h2",{id:"notable-bug-fixes"},"Notable bug fixes"),(0,o.kt)("ul",null,(0,o.kt)("li",{parentName:"ul"},"Periodically check and refresh Podman connection on Windows and Mac ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/1662"},"#1662")),(0,o.kt)("li",{parentName:"ul"},"Fix inconsistent Log view behaviour ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/1710"},"#1710")),(0,o.kt)("li",{parentName:"ul"},"Don't create route for regular Kubernetes clusters ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/1707"},"#1707")),(0,o.kt)("li",{parentName:"ul"},"Fix copy button on empty screen ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/1804"},"#1804")),(0,o.kt)("li",{parentName:"ul"},"Register extension tray items correctly ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/1778"},"#1778")," and handle updates ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/1800"},"#1800"))),(0,o.kt)("hr",null),(0,o.kt)("h2",{id:"community-thank-you"},"Community thank you"),(0,o.kt)("p",null,"\ud83c\udf89 We\u2019d like to say a big thank you to everyone who helped to make Podman Desktop 0.13 even better:"),(0,o.kt)("ul",null,(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("a",{parentName:"li",href:"https://github.com/Tony-Sol"},(0,o.kt)("inlineCode",{parentName:"a"},"Tony Soloveyv"))," in ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/1605"},"#1605 - Fix directories inconsistency in ",(0,o.kt)("inlineCode",{parentName:"a"},"~/.local/share/"))),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("a",{parentName:"li",href:"https://github.com/RobotSail"},(0,o.kt)("inlineCode",{parentName:"a"},"Oleg"))," in ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/1567"},"#1567 - Check for Flatpak when calling command from exec")),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("a",{parentName:"li",href:"https://github.com/cblecker"},(0,o.kt)("inlineCode",{parentName:"a"},"Christoph Blecker"))," in ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/1556"},"#1556 - Fix: Hide dock icon on macOS if starting minimized")),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("a",{parentName:"li",href:"https://github.com/pwright"},(0,o.kt)("inlineCode",{parentName:"a"},"Paul Wright"))," in ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/1604"},"#1604 - Docs: correct syntax of kind doc")),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("a",{parentName:"li",href:"https://github.com/dgolovin"},(0,o.kt)("inlineCode",{parentName:"a"},"Denis Golovin"))," in ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/1790"},"#1790 - Feat: add EventEmitter class to extension API")),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("a",{parentName:"li",href:"https://github.com/cfergeau"},(0,o.kt)("inlineCode",{parentName:"a"},"Christophe Fergeau"))," in ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/1642"},'#1642 - Fix: Pod list "an pod" typing error'))),(0,o.kt)("h2",{id:"final-notes"},"Final notes"),(0,o.kt)("p",null,"The complete list of issues fixed in this release is available ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/issues?q=is%3Aclosed+milestone%3A0.13.0"},"here"),"."),(0,o.kt)("p",null,"Get the latest release from the ",(0,o.kt)("a",{parentName:"p",href:"/downloads"},"Downloads")," section of the website and boost your development journey with Podman Desktop. Additionally, visit the ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop"},"GitHub repository")," and see how you can help us make Podman Desktop better."))}u.isMDXComponent=!0},75771:(e,t,a)=>{a.d(t,{Z:()=>n});const n=a.p+"assets/images/podman-desktop-release-0.13-a15251500e13ad05b8a7b404ab301f34.png"},66557:(e,t,a)=>{a.d(t,{Z:()=>n});const n=a.p+"assets/images/prune-image-96f9366ae264c822b47bfc350d987451.png"},9184:(e,t,a)=>{a.d(t,{Z:()=>n});const n=a.p+"assets/images/task-manager-2c9725a8db209c3607e83a24d9ea1582.png"}}]); \ No newline at end of file diff --git a/assets/js/006e489c.ddaf0a3e.js b/assets/js/006e489c.ddaf0a3e.js new file mode 100644 index 00000000000..10218ea1e53 --- /dev/null +++ b/assets/js/006e489c.ddaf0a3e.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[8145],{3064:(e,t,a)=>{a.r(t),a.d(t,{assets:()=>r,contentTitle:()=>p,default:()=>k,frontMatter:()=>l,metadata:()=>i,toc:()=>m});var n=a(25773),o=(a(27378),a(35318)),s=a(92975);const l={title:"Release Notes - Podman Desktop 0.13",description:"Podman Desktop 0.13 has been released!",slug:"podman-desktop-release-0.13",authors:["deboer"],tags:["podman-desktop","release","kubernetes","compose"],hide_table_of_contents:!1},p=void 0,i={permalink:"/blog/podman-desktop-release-0.13",source:"@site/blog/2023-03-29-release-0.13.md",title:"Release Notes - Podman Desktop 0.13",description:"Podman Desktop 0.13 has been released!",date:"2023-03-29T00:00:00.000Z",formattedDate:"March 29, 2023",tags:[{label:"podman-desktop",permalink:"/blog/tags/podman-desktop"},{label:"release",permalink:"/blog/tags/release"},{label:"kubernetes",permalink:"/blog/tags/kubernetes"},{label:"compose",permalink:"/blog/tags/compose"}],readingTime:3.155,hasTruncateMarker:!0,authors:[{name:"Tim deBoer",title:"Architect",url:"https://github.com/deboer-tim",imageURL:"https://github.com/deboer-tim.png",key:"deboer"}],frontMatter:{title:"Release Notes - Podman Desktop 0.13",description:"Podman Desktop 0.13 has been released!",slug:"podman-desktop-release-0.13",authors:["deboer"],tags:["podman-desktop","release","kubernetes","compose"],hide_table_of_contents:!1},prevItem:{title:"Release Notes - Podman Desktop 0.14",permalink:"/blog/podman-desktop-release-0.14"},nextItem:{title:"5 things to know about Podman Desktop for a Docker user",permalink:"/blog/5-things-to-know-for-a-docker-user"}},r={authorsImageUrls:[void 0]},m=[{value:"Release details",id:"release-details",level:2},{value:"Update to Podman v4.4.4",id:"update-to-podman-v444",level:3},{value:"Compose support",id:"compose-support",level:3},{value:"Extensions",id:"extensions",level:3},{value:"UI and UX improvements",id:"ui-and-ux-improvements",level:3},{value:"Welcome page #1726",id:"welcome-page-1726",level:4},{value:"New Task Manager #1724",id:"new-task-manager-1724",level:4},{value:"Updated Resources Settings #1582",id:"updated-resources-settings-1582",level:4},{value:"Update Alerts #1827",id:"update-alerts-1827",level:4},{value:"Prune buttons #1481, #1482, #1484",id:"prune-buttons-1481-1482-1484",level:4},{value:"Other notable enhancements",id:"other-notable-enhancements",level:2},{value:"Documentation",id:"documentation",level:2},{value:"Notable bug fixes",id:"notable-bug-fixes",level:2},{value:"Community thank you",id:"community-thank-you",level:2},{value:"Final notes",id:"final-notes",level:2}],d=(u="Icon",function(e){return console.warn("Component "+u+" was not imported, exported, or provided by MDXProvider as global scope"),(0,o.kt)("div",e)});var u;const h={toc:m};function k(e){let{components:t,...l}=e;return(0,o.kt)("wrapper",(0,n.Z)({},h,l,{components:t,mdxType:"MDXLayout"}),(0,o.kt)("p",null,"This release note covers Podman Desktop 0.13 release changes."),(0,o.kt)("ul",null,(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("strong",{parentName:"li"},"Podman Version"),": Podman 4.4.4 now included in Windows and Mac installers."),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("strong",{parentName:"li"},"Compose"),": Support for installing Docker Compose."),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("strong",{parentName:"li"},"Extensions"),": Improved extension support for Podman Desktop with additional capabilities."),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("strong",{parentName:"li"},"UX and UI Improvements"),": Welcome page, task manager, resources, and update alerts.")),(0,o.kt)("p",null,"Podman Desktop 0.13 is now available. ",(0,o.kt)("a",{parentName:"p",href:"/downloads"},"Click here to download it"),"!"),(0,o.kt)("p",null,(0,o.kt)("img",{alt:"Podman-desktop-0-13-hero",src:a(75771).Z,width:"1852",height:"1323"})),(0,o.kt)("hr",null),(0,o.kt)("h2",{id:"release-details"},"Release details"),(0,o.kt)("h3",{id:"update-to-podman-v444"},"Update to Podman v4.4.4"),(0,o.kt)("p",null,"Podman Desktop 0.13 embeds ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman/releases/tag/v4.4.4"},"Podman 4.4.4")," in\nWindows and macOS installers ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/1456"},"#1456"),"."),(0,o.kt)("h3",{id:"compose-support"},"Compose support"),(0,o.kt)("p",null,"You can install Docker Compose from the Podman Desktop UI ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/1578"},"#1578"),". This will allow you use Compose workflows using Podman."),(0,o.kt)("h3",{id:"extensions"},"Extensions"),(0,o.kt)("p",null,"To make it easier to extend Podman Desktop we have:"),(0,o.kt)("ul",null,(0,o.kt)("li",{parentName:"ul"},"Published the ",(0,o.kt)("a",{parentName:"li",href:"https://www.npmjs.com/package/@podman-desktop/api"},"Podman Desktop Extension API")," to npmjs ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/1727"},"#1727")),(0,o.kt)("li",{parentName:"ul"},"Documented ",(0,o.kt)("a",{parentName:"li",href:"https://podman-desktop.io/docs/extensions"},"how to create, publish, and install your own extensions")),(0,o.kt)("li",{parentName:"ul"},"Expanded the API for ",(0,o.kt)("inlineCode",{parentName:"li"},"QuickPickInput")," ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/1839"},"#1839"))),(0,o.kt)("h3",{id:"ui-and-ux-improvements"},"UI and UX improvements"),(0,o.kt)("h4",{id:"welcome-page-1726"},"Welcome page ",(0,o.kt)("a",{parentName:"h4",href:"https://github.com/containers/podman-desktop/pull/1726"},"#1726")),(0,o.kt)("p",null,"The first time every user starts Podman Desktop, they will see a welcome page:"),(0,o.kt)("p",null,(0,o.kt)("img",{parentName:"p",src:"https://user-images.githubusercontent.com/19958075/225682776-e016ba31-5bb9-41d5-87ed-f93caeb3fb84.png",alt:"welcome-page"})),(0,o.kt)("p",null,"Note that the Welcome page will only appear the first time you run Podman Desktop 0.13.0, and none of your settings or assets in Podman Desktop will be affected by it.\nOver time, this page will be expanded to help with initial setup and configuration."),(0,o.kt)("h4",{id:"new-task-manager-1724"},"New Task Manager ",(0,o.kt)("a",{parentName:"h4",href:"https://github.com/containers/podman-desktop/pull/1724"},"#1724")),(0,o.kt)("p",null,"A new Task Manager has been added to the status bar to see the progress (or return to) long running tasks. To start with, building images ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/1725"},"#1725")," and Podman machine ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/1742"},"#1742")," are using the task manager."),(0,o.kt)("p",null,(0,o.kt)("img",{alt:"task-manager",src:a(9184).Z,width:"2082",height:"1198"})),(0,o.kt)("h4",{id:"updated-resources-settings-1582"},"Updated Resources Settings ",(0,o.kt)("a",{parentName:"h4",href:"https://github.com/containers/podman-desktop/pull/1582"},"#1582")),(0,o.kt)("p",null,"The ",(0,o.kt)("strong",{parentName:"p"},(0,o.kt)(d,{icon:"fa-solid fa-cog",size:"lg",mdxType:"Icon"})," Settings > Resources")," page has been updated with a new design, making it easier to see and control your providers from a single place."),(0,o.kt)("p",null,(0,o.kt)("img",{parentName:"p",src:"https://user-images.githubusercontent.com/49404737/221908815-595715fe-4c95-4087-89e0-45e5544ed5c9.gif",alt:"resources"})),(0,o.kt)("p",null,"The other settings pages have been updated for consistency with this new design."),(0,o.kt)("h4",{id:"update-alerts-1827"},"Update Alerts ",(0,o.kt)("a",{parentName:"h4",href:"https://github.com/containers/podman-desktop/pull/1827"},"#1827")),(0,o.kt)("p",null,"A new alert button will appear in the status bar when future updates are available."),(0,o.kt)(s.Z,{playing:!0,controls:!0,url:"https://user-images.githubusercontent.com/436777/227596136-c6123d5c-d9ae-4fb3-a569-0cfaaeebf09c.mp4",width:"100%",height:"100%",mdxType:"ReactPlayer"}),(0,o.kt)("h4",{id:"prune-buttons-1481-1482-1484"},"Prune buttons ",(0,o.kt)("a",{parentName:"h4",href:"https://github.com/containers/podman-desktop/pull/1481"},"#1481"),", ",(0,o.kt)("a",{parentName:"h4",href:"https://github.com/containers/podman-desktop/pull/1482"},"#1482"),", ",(0,o.kt)("a",{parentName:"h4",href:"https://github.com/containers/podman-desktop/pull/1484"},"#1484")),(0,o.kt)("p",null,"We've added buttons to prune unused volumes ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/1481"},"#1481"),", images ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/1482"},"#1482")," and pods ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/1484"},"#1484"),"."),(0,o.kt)("p",null,(0,o.kt)("img",{alt:"prune-image",src:a(66557).Z,width:"2074",height:"570"})),(0,o.kt)("hr",null),(0,o.kt)("h2",{id:"other-notable-enhancements"},"Other notable enhancements"),(0,o.kt)("ul",null,(0,o.kt)("li",{parentName:"ul"},"Kubernetes pods are now shown in the Pods view ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/1312"},"#1312")),(0,o.kt)("li",{parentName:"ul"},"Easy button to fix Docker compatibility mode on macOS ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/1697"},"#1697")),(0,o.kt)("li",{parentName:"ul"},"Display extension icons ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/1058"},"#1058")),(0,o.kt)("li",{parentName:"ul"},"API to cancel long running tasks ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/1777"},"#1777"))),(0,o.kt)("hr",null),(0,o.kt)("h2",{id:"documentation"},"Documentation"),(0,o.kt)("p",null,"The documentation has new content:"),(0,o.kt)("ul",null,(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("a",{parentName:"li",href:"https://podman-desktop.io/docs/extensions"},"How to create, publish, and install your own Podman Desktop extensions")),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("a",{parentName:"li",href:"https://podman-desktop.io/docs/compose/podman-compose"},"Using Compose")),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("a",{parentName:"li",href:"https://podman-desktop.io/docs/kind"},"Restarting Kind"))),(0,o.kt)("hr",null),(0,o.kt)("h2",{id:"notable-bug-fixes"},"Notable bug fixes"),(0,o.kt)("ul",null,(0,o.kt)("li",{parentName:"ul"},"Periodically check and refresh Podman connection on Windows and Mac ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/1662"},"#1662")),(0,o.kt)("li",{parentName:"ul"},"Fix inconsistent Log view behaviour ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/1710"},"#1710")),(0,o.kt)("li",{parentName:"ul"},"Don't create route for regular Kubernetes clusters ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/1707"},"#1707")),(0,o.kt)("li",{parentName:"ul"},"Fix copy button on empty screen ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/1804"},"#1804")),(0,o.kt)("li",{parentName:"ul"},"Register extension tray items correctly ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/1778"},"#1778")," and handle updates ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/1800"},"#1800"))),(0,o.kt)("hr",null),(0,o.kt)("h2",{id:"community-thank-you"},"Community thank you"),(0,o.kt)("p",null,"\ud83c\udf89 We\u2019d like to say a big thank you to everyone who helped to make Podman Desktop 0.13 even better:"),(0,o.kt)("ul",null,(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("a",{parentName:"li",href:"https://github.com/Tony-Sol"},(0,o.kt)("inlineCode",{parentName:"a"},"Tony Soloveyv"))," in ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/1605"},"#1605 - Fix directories inconsistency in ",(0,o.kt)("inlineCode",{parentName:"a"},"~/.local/share/"))),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("a",{parentName:"li",href:"https://github.com/RobotSail"},(0,o.kt)("inlineCode",{parentName:"a"},"Oleg"))," in ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/1567"},"#1567 - Check for Flatpak when calling command from exec")),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("a",{parentName:"li",href:"https://github.com/cblecker"},(0,o.kt)("inlineCode",{parentName:"a"},"Christoph Blecker"))," in ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/1556"},"#1556 - Fix: Hide dock icon on macOS if starting minimized")),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("a",{parentName:"li",href:"https://github.com/pwright"},(0,o.kt)("inlineCode",{parentName:"a"},"Paul Wright"))," in ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/1604"},"#1604 - Docs: correct syntax of kind doc")),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("a",{parentName:"li",href:"https://github.com/dgolovin"},(0,o.kt)("inlineCode",{parentName:"a"},"Denis Golovin"))," in ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/1790"},"#1790 - Feat: add EventEmitter class to extension API")),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("a",{parentName:"li",href:"https://github.com/cfergeau"},(0,o.kt)("inlineCode",{parentName:"a"},"Christophe Fergeau"))," in ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/1642"},'#1642 - Fix: Pod list "an pod" typing error'))),(0,o.kt)("h2",{id:"final-notes"},"Final notes"),(0,o.kt)("p",null,"The complete list of issues fixed in this release is available ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/issues?q=is%3Aclosed+milestone%3A0.13.0"},"here"),"."),(0,o.kt)("p",null,"Get the latest release from the ",(0,o.kt)("a",{parentName:"p",href:"/downloads"},"Downloads")," section of the website and boost your development journey with Podman Desktop. Additionally, visit the ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop"},"GitHub repository")," and see how you can help us make Podman Desktop better."))}k.isMDXComponent=!0},75771:(e,t,a)=>{a.d(t,{Z:()=>n});const n=a.p+"assets/images/podman-desktop-release-0.13-a15251500e13ad05b8a7b404ab301f34.png"},66557:(e,t,a)=>{a.d(t,{Z:()=>n});const n=a.p+"assets/images/prune-image-96f9366ae264c822b47bfc350d987451.png"},9184:(e,t,a)=>{a.d(t,{Z:()=>n});const n=a.p+"assets/images/task-manager-2c9725a8db209c3607e83a24d9ea1582.png"}}]); \ No newline at end of file diff --git a/assets/js/014457dd.ca826858.js b/assets/js/014457dd.ca826858.js new file mode 100644 index 00000000000..f913a93ab90 --- /dev/null +++ b/assets/js/014457dd.ca826858.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[6521],{35318:(e,t,n)=>{n.d(t,{Zo:()=>c,kt:()=>d});var i=n(27378);function a(e,t,n){return t in e?Object.defineProperty(e,t,{value:n,enumerable:!0,configurable:!0,writable:!0}):e[t]=n,e}function r(e,t){var n=Object.keys(e);if(Object.getOwnPropertySymbols){var i=Object.getOwnPropertySymbols(e);t&&(i=i.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),n.push.apply(n,i)}return n}function o(e){for(var t=1;t=0||(a[n]=e[n]);return a}(e,t);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(e);for(i=0;i=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(a[n]=e[n])}return a}var s=i.createContext({}),m=function(e){var t=i.useContext(s),n=t;return e&&(n="function"==typeof e?e(t):o(o({},t),e)),n},c=function(e){var t=m(e.components);return i.createElement(s.Provider,{value:t},e.children)},p={inlineCode:"code",wrapper:function(e){var t=e.children;return i.createElement(i.Fragment,{},t)}},u=i.forwardRef((function(e,t){var n=e.components,a=e.mdxType,r=e.originalType,s=e.parentName,c=l(e,["components","mdxType","originalType","parentName"]),u=m(n),d=a,g=u["".concat(s,".").concat(d)]||u[d]||p[d]||r;return n?i.createElement(g,o(o({ref:t},c),{},{components:n})):i.createElement(g,o({ref:t},c))}));function d(e,t){var n=arguments,a=t&&t.mdxType;if("string"==typeof e||a){var r=n.length,o=new Array(r);o[0]=u;var l={};for(var s in t)hasOwnProperty.call(t,s)&&(l[s]=t[s]);l.originalType=e,l.mdxType="string"==typeof e?e:a,o[1]=l;for(var m=2;m{n.r(t),n.d(t,{assets:()=>s,contentTitle:()=>o,default:()=>d,frontMatter:()=>r,metadata:()=>l,toc:()=>m});var i=n(25773),a=(n(27378),n(35318));const r={sidebar_position:20,title:"Building an image",description:"Building an image on your container engine.",keywords:["podman desktop","podman","containers","images"],tags:["images"]},o="Building an image on your container engine",l={unversionedId:"containers/images/building-an-image",id:"containers/images/building-an-image",title:"Building an image",description:"Building an image on your container engine.",source:"@site/docs/containers/images/building-an-image.md",sourceDirName:"containers/images",slug:"/containers/images/building-an-image",permalink:"/docs/containers/images/building-an-image",draft:!1,editUrl:"https://github.com/containers/podman-desktop/tree/main/website/docs/containers/images/building-an-image.md",tags:[{label:"images",permalink:"/docs/tags/images"}],version:"current",sidebarPosition:20,frontMatter:{sidebar_position:20,title:"Building an image",description:"Building an image on your container engine.",keywords:["podman desktop","podman","containers","images"],tags:["images"]},sidebar:"mySidebar",previous:{title:"Images",permalink:"/docs/containers/images/"},next:{title:"Pushing an image to a registry",permalink:"/docs/containers/images/pushing-an-image-to-a-registry"}},s={},m=[{value:"Prerequisites",id:"prerequisites",level:4},{value:"Procedure",id:"procedure",level:4},{value:"Verification",id:"verification",level:4}],c=(p="Icon",function(e){return console.warn("Component "+p+" was not imported, exported, or provided by MDXProvider as global scope"),(0,a.kt)("div",e)});var p;const u={toc:m};function d(e){let{components:t,...n}=e;return(0,a.kt)("wrapper",(0,i.Z)({},u,n,{components:t,mdxType:"MDXLayout"}),(0,a.kt)("h1",{id:"building-an-image-on-your-container-engine"},"Building an image on your container engine"),(0,a.kt)("p",null,"With Podman Desktop, you can build an image from a Containerfile on your container engine."),(0,a.kt)("h4",{id:"prerequisites"},"Prerequisites"),(0,a.kt)("ul",null,(0,a.kt)("li",{parentName:"ul"},"Your Containerfile: ",(0,a.kt)("inlineCode",{parentName:"li"},"Containerfile")," or ",(0,a.kt)("inlineCode",{parentName:"li"},"Dockerfile"),".")),(0,a.kt)("h4",{id:"procedure"},"Procedure"),(0,a.kt)("ol",null,(0,a.kt)("li",{parentName:"ol"},"Go to ",(0,a.kt)("strong",{parentName:"li"},(0,a.kt)(c,{icon:"fa-solid fa-cloud",size:"lg",mdxType:"Icon"})," Images"),"."),(0,a.kt)("li",{parentName:"ol"},"Click ",(0,a.kt)("strong",{parentName:"li"},(0,a.kt)(c,{icon:"fa-solid fa-cube",size:"lg",mdxType:"Icon"})," Build an image"),"."),(0,a.kt)("li",{parentName:"ol"},"On the ",(0,a.kt)("strong",{parentName:"li"},"Build Image from Containerfile")," screen",(0,a.kt)("ol",{parentName:"li"},(0,a.kt)("li",{parentName:"ol"},(0,a.kt)("strong",{parentName:"li"},"Containerfile path"),": select the ",(0,a.kt)("inlineCode",{parentName:"li"},"Containerfile")," or ",(0,a.kt)("inlineCode",{parentName:"li"},"Dockerfile")," to build."),(0,a.kt)("li",{parentName:"ol"},(0,a.kt)("strong",{parentName:"li"},"Image Name"),": enter your image name, such as ",(0,a.kt)("inlineCode",{parentName:"li"},"my-image"),". If you want to push the image to a registry, use the fully qualified image name that your registry requires, such as ",(0,a.kt)("inlineCode",{parentName:"li"},"quay.io/my-repository/my-image"),", ",(0,a.kt)("inlineCode",{parentName:"li"},"ghcr.io/my-repository/my-image"),", or ",(0,a.kt)("inlineCode",{parentName:"li"},"docker.io/my-repository/my-image"),"."),(0,a.kt)("li",{parentName:"ol"},"Click ",(0,a.kt)("strong",{parentName:"li"},(0,a.kt)(c,{icon:"fa-solid fa-cubes",size:"lg",mdxType:"Icon"})," Build"),"."),(0,a.kt)("li",{parentName:"ol"},"Click ",(0,a.kt)("strong",{parentName:"li"},"Done"),".")))),(0,a.kt)("h4",{id:"verification"},"Verification"),(0,a.kt)("ol",null,(0,a.kt)("li",{parentName:"ol"},"Go to ",(0,a.kt)("strong",{parentName:"li"},(0,a.kt)(c,{icon:"fa-solid fa-cloud",size:"lg",mdxType:"Icon"})," Images"),"."),(0,a.kt)("li",{parentName:"ol"},(0,a.kt)("strong",{parentName:"li"},(0,a.kt)(c,{icon:"fa-solid fa-search",size:"lg",mdxType:"Icon"})),": Enter your image name, such as ",(0,a.kt)("inlineCode",{parentName:"li"},"quay.io/my-repository/my-image"),", ",(0,a.kt)("inlineCode",{parentName:"li"},"ghcr.io/my-repository/my-image"),", or ",(0,a.kt)("inlineCode",{parentName:"li"},"docker.io/my-repository/my-image"),"."),(0,a.kt)("li",{parentName:"ol"},"Click the line with your image name."),(0,a.kt)("li",{parentName:"ol"},"Go to ",(0,a.kt)("strong",{parentName:"li"},"History"),".",(0,a.kt)("ol",{parentName:"li"},(0,a.kt)("li",{parentName:"ol"},"Click the content area to activate it."),(0,a.kt)("li",{parentName:"ol"},"Enter ",(0,a.kt)("kbd",null,"Ctrl")," + ",(0,a.kt)("kbd",null,"F")," on Windows and Linux, or ",(0,a.kt)("kbd",null,"\u2318")," + ",(0,a.kt)("kbd",null,"F")," on macOS to start searching in the content."))),(0,a.kt)("li",{parentName:"ol"},"Go to ",(0,a.kt)("strong",{parentName:"li"},"Inspect"),".",(0,a.kt)("ol",{parentName:"li"},(0,a.kt)("li",{parentName:"ol"},"Click the content area to activate it."),(0,a.kt)("li",{parentName:"ol"},"Enter ",(0,a.kt)("kbd",null,"Ctrl")," + ",(0,a.kt)("kbd",null,"F")," on Windows and Linux, or ",(0,a.kt)("kbd",null,"\u2318")," + ",(0,a.kt)("kbd",null,"F")," on macOS to start searching in the content."))),(0,a.kt)("li",{parentName:"ol"},"Click ",(0,a.kt)("strong",{parentName:"li"},(0,a.kt)(c,{icon:"fa-solid fa-play",size:"lg",mdxType:"Icon"})),"..",(0,a.kt)("ol",{parentName:"li"},(0,a.kt)("li",{parentName:"ol"},"You see the ",(0,a.kt)("strong",{parentName:"li"},"Create a container")," screen.")))))}d.isMDXComponent=!0}}]); \ No newline at end of file diff --git a/assets/js/014457dd.f3f94425.js b/assets/js/014457dd.f3f94425.js deleted file mode 100644 index 1e2defe5b6d..00000000000 --- a/assets/js/014457dd.f3f94425.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[6521],{35318:(e,t,n)=>{n.d(t,{Zo:()=>c,kt:()=>g});var i=n(27378);function a(e,t,n){return t in e?Object.defineProperty(e,t,{value:n,enumerable:!0,configurable:!0,writable:!0}):e[t]=n,e}function r(e,t){var n=Object.keys(e);if(Object.getOwnPropertySymbols){var i=Object.getOwnPropertySymbols(e);t&&(i=i.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),n.push.apply(n,i)}return n}function o(e){for(var t=1;t=0||(a[n]=e[n]);return a}(e,t);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(e);for(i=0;i=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(a[n]=e[n])}return a}var s=i.createContext({}),m=function(e){var t=i.useContext(s),n=t;return e&&(n="function"==typeof e?e(t):o(o({},t),e)),n},c=function(e){var t=m(e.components);return i.createElement(s.Provider,{value:t},e.children)},p={inlineCode:"code",wrapper:function(e){var t=e.children;return i.createElement(i.Fragment,{},t)}},u=i.forwardRef((function(e,t){var n=e.components,a=e.mdxType,r=e.originalType,s=e.parentName,c=l(e,["components","mdxType","originalType","parentName"]),u=m(n),g=a,d=u["".concat(s,".").concat(g)]||u[g]||p[g]||r;return n?i.createElement(d,o(o({ref:t},c),{},{components:n})):i.createElement(d,o({ref:t},c))}));function g(e,t){var n=arguments,a=t&&t.mdxType;if("string"==typeof e||a){var r=n.length,o=new Array(r);o[0]=u;var l={};for(var s in t)hasOwnProperty.call(t,s)&&(l[s]=t[s]);l.originalType=e,l.mdxType="string"==typeof e?e:a,o[1]=l;for(var m=2;m{n.r(t),n.d(t,{assets:()=>s,contentTitle:()=>o,default:()=>p,frontMatter:()=>r,metadata:()=>l,toc:()=>m});var i=n(25773),a=(n(27378),n(35318));const r={sidebar_position:20,title:"Building an image",description:"Building an image on your container engine.",keywords:["podman desktop","podman","containers","images"],tags:["images"]},o="Building an image on your container engine",l={unversionedId:"containers/images/building-an-image",id:"containers/images/building-an-image",title:"Building an image",description:"Building an image on your container engine.",source:"@site/docs/containers/images/building-an-image.md",sourceDirName:"containers/images",slug:"/containers/images/building-an-image",permalink:"/docs/containers/images/building-an-image",draft:!1,editUrl:"https://github.com/containers/podman-desktop/tree/main/website/docs/containers/images/building-an-image.md",tags:[{label:"images",permalink:"/docs/tags/images"}],version:"current",sidebarPosition:20,frontMatter:{sidebar_position:20,title:"Building an image",description:"Building an image on your container engine.",keywords:["podman desktop","podman","containers","images"],tags:["images"]},sidebar:"mySidebar",previous:{title:"Images",permalink:"/docs/containers/images/"},next:{title:"Pushing an image to a registry",permalink:"/docs/containers/images/pushing-an-image-to-a-registry"}},s={},m=[{value:"Prerequisites",id:"prerequisites",level:4},{value:"Procedure",id:"procedure",level:4},{value:"Verification",id:"verification",level:4}],c={toc:m};function p(e){let{components:t,...n}=e;return(0,a.kt)("wrapper",(0,i.Z)({},c,n,{components:t,mdxType:"MDXLayout"}),(0,a.kt)("h1",{id:"building-an-image-on-your-container-engine"},"Building an image on your container engine"),(0,a.kt)("p",null,"With Podman Desktop, you can build an image from a Containerfile on your container engine."),(0,a.kt)("h4",{id:"prerequisites"},"Prerequisites"),(0,a.kt)("ul",null,(0,a.kt)("li",{parentName:"ul"},"Your Containerfile: ",(0,a.kt)("inlineCode",{parentName:"li"},"Containerfile")," or ",(0,a.kt)("inlineCode",{parentName:"li"},"Dockerfile"),".")),(0,a.kt)("h4",{id:"procedure"},"Procedure"),(0,a.kt)("ol",null,(0,a.kt)("li",{parentName:"ol"},"Go to ",(0,a.kt)("strong",{parentName:"li"},(0,a.kt)("icon",{icon:"fa-solid fa-cloud",size:"lg"})," Images"),"."),(0,a.kt)("li",{parentName:"ol"},"Click ",(0,a.kt)("strong",{parentName:"li"},(0,a.kt)("icon",{icon:"fa-solid fa-cube",size:"lg"})," Build an image"),"."),(0,a.kt)("li",{parentName:"ol"},"On the ",(0,a.kt)("strong",{parentName:"li"},"Build Image from Containerfile")," screen",(0,a.kt)("ol",{parentName:"li"},(0,a.kt)("li",{parentName:"ol"},(0,a.kt)("strong",{parentName:"li"},"Containerfile path"),": select the ",(0,a.kt)("inlineCode",{parentName:"li"},"Containerfile")," or ",(0,a.kt)("inlineCode",{parentName:"li"},"Dockerfile")," to build."),(0,a.kt)("li",{parentName:"ol"},(0,a.kt)("strong",{parentName:"li"},"Image Name"),": enter your image name, such as ",(0,a.kt)("inlineCode",{parentName:"li"},"my-image"),". If you want to push the image to a registry, use the fully qualified image name that your registry requires, such as ",(0,a.kt)("inlineCode",{parentName:"li"},"quay.io/my-repository/my-image"),", ",(0,a.kt)("inlineCode",{parentName:"li"},"ghcr.io/my-repository/my-image"),", or ",(0,a.kt)("inlineCode",{parentName:"li"},"docker.io/my-repository/my-image"),"."),(0,a.kt)("li",{parentName:"ol"},"Click ",(0,a.kt)("strong",{parentName:"li"},(0,a.kt)("icon",{icon:"fa-solid fa-cubes",size:"lg"})," Build"),"."),(0,a.kt)("li",{parentName:"ol"},"Click ",(0,a.kt)("strong",{parentName:"li"},"Done"),".")))),(0,a.kt)("h4",{id:"verification"},"Verification"),(0,a.kt)("ol",null,(0,a.kt)("li",{parentName:"ol"},"Go to ",(0,a.kt)("strong",{parentName:"li"},(0,a.kt)("icon",{icon:"fa-solid fa-cloud",size:"lg"})," Images"),"."),(0,a.kt)("li",{parentName:"ol"},(0,a.kt)("strong",{parentName:"li"},(0,a.kt)("icon",{icon:"fa-solid fa-search",size:"lg"})),": Enter your image name, such as ",(0,a.kt)("inlineCode",{parentName:"li"},"quay.io/my-repository/my-image"),", ",(0,a.kt)("inlineCode",{parentName:"li"},"ghcr.io/my-repository/my-image"),", or ",(0,a.kt)("inlineCode",{parentName:"li"},"docker.io/my-repository/my-image"),"."),(0,a.kt)("li",{parentName:"ol"},"Click the line with your image name."),(0,a.kt)("li",{parentName:"ol"},"Go to ",(0,a.kt)("strong",{parentName:"li"},"History"),".",(0,a.kt)("ol",{parentName:"li"},(0,a.kt)("li",{parentName:"ol"},"Click the content area to activate it."),(0,a.kt)("li",{parentName:"ol"},"Enter ",(0,a.kt)("kbd",null,"Ctrl")," + ",(0,a.kt)("kbd",null,"F")," on Windows and Linux, or ",(0,a.kt)("kbd",null,"\u2318")," + ",(0,a.kt)("kbd",null,"F")," on macOS to start searching in the content."))),(0,a.kt)("li",{parentName:"ol"},"Go to ",(0,a.kt)("strong",{parentName:"li"},"Inspect"),".",(0,a.kt)("ol",{parentName:"li"},(0,a.kt)("li",{parentName:"ol"},"Click the content area to activate it."),(0,a.kt)("li",{parentName:"ol"},"Enter ",(0,a.kt)("kbd",null,"Ctrl")," + ",(0,a.kt)("kbd",null,"F")," on Windows and Linux, or ",(0,a.kt)("kbd",null,"\u2318")," + ",(0,a.kt)("kbd",null,"F")," on macOS to start searching in the content."))),(0,a.kt)("li",{parentName:"ol"},"Click ",(0,a.kt)("strong",{parentName:"li"},(0,a.kt)("icon",{icon:"fa-solid fa-play",size:"lg"})),"..",(0,a.kt)("ol",{parentName:"li"},(0,a.kt)("li",{parentName:"ol"},"You see the ",(0,a.kt)("strong",{parentName:"li"},"Create a container")," screen.")))))}p.isMDXComponent=!0}}]); \ No newline at end of file diff --git a/assets/js/021eaa84.6dede19a.js b/assets/js/021eaa84.6dede19a.js deleted file mode 100644 index 081ac33e526..00000000000 --- a/assets/js/021eaa84.6dede19a.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[7875],{4065:(e,t,a)=>{a.r(t),a.d(t,{assets:()=>l,contentTitle:()=>r,default:()=>h,frontMatter:()=>i,metadata:()=>p,toc:()=>m});var n=a(25773),o=(a(27378),a(35318)),s=a(92975);const i={title:"Release Notes - Podman Desktop 1.5",description:"Podman Desktop 1.5 has been released!",slug:"podman-desktop-release-1.5",authors:"duffy",tags:["podman-desktop","release","kubernetes","openshift","onboarding","compose","extensions","settings"],hide_table_of_contents:!1,image:"/blog/img/podman-desktop-release-1.5/onboarding-selkies.png"},r=void 0,p={permalink:"/blog/podman-desktop-release-1.5",source:"@site/blog/2023-11-03-release-1.5.md",title:"Release Notes - Podman Desktop 1.5",description:"Podman Desktop 1.5 has been released!",date:"2023-11-03T00:00:00.000Z",formattedDate:"November 3, 2023",tags:[{label:"podman-desktop",permalink:"/blog/tags/podman-desktop"},{label:"release",permalink:"/blog/tags/release"},{label:"kubernetes",permalink:"/blog/tags/kubernetes"},{label:"openshift",permalink:"/blog/tags/openshift"},{label:"onboarding",permalink:"/blog/tags/onboarding"},{label:"compose",permalink:"/blog/tags/compose"},{label:"extensions",permalink:"/blog/tags/extensions"},{label:"settings",permalink:"/blog/tags/settings"}],readingTime:8.14,hasTruncateMarker:!1,authors:[{name:"M\xe1ir\xedn Duffy",title:"User Experience Designer",url:"https://github.com/mairin",imageURL:"https://github.com/mairin.png",key:"duffy"}],frontMatter:{title:"Release Notes - Podman Desktop 1.5",description:"Podman Desktop 1.5 has been released!",slug:"podman-desktop-release-1.5",authors:"duffy",tags:["podman-desktop","release","kubernetes","openshift","onboarding","compose","extensions","settings"],hide_table_of_contents:!1,image:"/blog/img/podman-desktop-release-1.5/onboarding-selkies.png"},nextItem:{title:"Release Notes - Podman Desktop 1.4",permalink:"/blog/podman-desktop-release-1.4"}},l={authorsImageUrls:[void 0]},m=[{value:"Release Details",id:"release-details",level:2},{value:"Onboarding",id:"onboarding",level:3},{value:"Command Palette",id:"command-palette",level:3},{value:"Expanded "Summary" tab for Kubernetes pods",id:"expanded-summary-tab-for-kubernetes-pods",level:3},{value:"Environment file support",id:"environment-file-support",level:3},{value:"Enhancements to the Settings area",id:"enhancements-to-the-settings-area",level:3},{value:"Improved user experience for state changes",id:"improved-user-experience-for-state-changes",level:3},{value:"Extension API improvements",id:"extension-api-improvements",level:3},{value:"Other Notable Enhancements",id:"other-notable-enhancements",level:2},{value:"Notable Bug Fixes",id:"notable-bug-fixes",level:2},{value:"Community Thank You",id:"community-thank-you",level:2},{value:"Final notes",id:"final-notes",level:2},{value:"Known Issues",id:"known-issues",level:3},{value:"Known Issues: Podman Desktop 1.5.2",id:"known-issues-podman-desktop-152",level:4},{value:"Fixed Issues",id:"fixed-issues",level:3},{value:"Where to Download",id:"where-to-download",level:3}],d={toc:m};function h(e){let{components:t,...i}=e;return(0,o.kt)("wrapper",(0,n.Z)({},d,i,{components:t,mdxType:"MDXLayout"}),(0,o.kt)("p",null,"Podman Desktop 1.5 Release! \ud83c\udf89"),(0,o.kt)("p",null,"With this release of Podman Desktop, we're introducing ",(0,o.kt)("strong",{parentName:"p"},"a new onboarding feature")," that we hope will earn your \ud83e\uddad seal of approval! But wait... there's so much more!"),(0,o.kt)("ul",null,(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("strong",{parentName:"li"},"Onboarding"),": Guided setup and configuration of ",(0,o.kt)("strong",{parentName:"li"},"Podman")," and ",(0,o.kt)("strong",{parentName:"li"},"Compose")),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("strong",{parentName:"li"},"Podman 4.7.2"),": ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman/releases"},"Podman 4.7.2")," is now included in Windows and Mac installers"),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("strong",{parentName:"li"},"Command Palette"),": Gain easy access to various commands via a new keyboard-driven command palette"),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("strong",{parentName:"li"},'Expanded "Summary" tab for Kubernetes pods'),': Go deep with extended details on Kubernetes pods in the pod "Summary" tab'),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("strong",{parentName:"li"},"Environment file support"),": Chart out environment variables for new containers to access on creation"),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("strong",{parentName:"li"},"Enhancements to the Settings area"),": Get your bearings with improved Docker compatibility mode controls"),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("strong",{parentName:"li"},"Improved user experience for state changes"),": No more dead reckoning on container state with improved visual indication of status"),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("strong",{parentName:"li"},"Extension API improvements"),": A boatload of improvements to the extension API enabling more goodness from \ud83e\uddad Podman Desktop's extensions")),(0,o.kt)("p",null,"Podman Desktop 1.5 is now available. ",(0,o.kt)("a",{parentName:"p",href:"/downloads"},"Click here to download it"),"!"),(0,o.kt)("p",null,(0,o.kt)("img",{alt:"Podman-desktop-1-5-hero",src:a(90973).Z,width:"1920",height:"1080"})),(0,o.kt)("hr",null),(0,o.kt)("h2",{id:"release-details"},"Release Details"),(0,o.kt)("h3",{id:"onboarding"},"Onboarding"),(0,o.kt)("p",null,"We are introducing a new feature providing guided flows for the initial setup of specific \ud83e\uddad Podman Desktop extensions. Release 1.5 features two new onboarding flows: Podman and Compose."),(0,o.kt)("p",null,'To start the Podman onboarding flow, you can start from the dashboard notification by clicking the "Set up" button:\n',(0,o.kt)("img",{parentName:"p",src:"https://user-images.githubusercontent.com/799683/280362279-598cc052-5ea4-4c31-849c-da9bbbcc3e42.png",alt:"podman-onboarding-start"}),"\n",(0,o.kt)("img",{parentName:"p",src:"https://user-images.githubusercontent.com/799683/280363859-f35b85f8-1dd4-4b7f-a995-25fe5d1ccced.png",alt:"podman-onboarding"})),(0,o.kt)("p",null,"Visit ",(0,o.kt)("strong",{parentName:"p"},(0,o.kt)("icon",{icon:"fa-solid fa-cog",size:"lg"}),"Settings > Resources"),' screen and click the Compose "Setup ..." button in order to start Compose onboarding:\n',(0,o.kt)("img",{parentName:"p",src:"https://user-images.githubusercontent.com/799683/280276847-ca0558ab-70ad-48cc-8dd5-67e3eb465a62.png",alt:"compose-onboarding-start"}),"\n",(0,o.kt)("img",{parentName:"p",src:"https://user-images.githubusercontent.com/799683/280277936-77ba0fb2-5cb0-41de-a7cf-1a3d6400fd89.png",alt:"compose-onboarding"})),(0,o.kt)("h3",{id:"command-palette"},"Command Palette"),(0,o.kt)("p",null,"A new, search-driven command palette is now available to enable quick access to various commands available across \ud83e\uddad Podman Desktop. You can try this new tool out by hitting the F1 key. ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/4081"},"#4081")," ","&","&"," ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/3979"},"#3979")),(0,o.kt)(s.Z,{playing:!0,controls:!0,url:"https://user-images.githubusercontent.com/436777/270362431-5aaa6a1b-6df5-4b66-a811-cdd148d02ad6.mp4",width:"100%",height:"100%",mdxType:"ReactPlayer"}),(0,o.kt)("h3",{id:"expanded-summary-tab-for-kubernetes-pods"},'Expanded "Summary" tab for Kubernetes pods'),(0,o.kt)("p",null,'Kubernetes pods now offer a more comprehensive set of information under the "Summary" tab, including networking, volumes, environment variables, and other key metadata.'),(0,o.kt)(s.Z,{playing:!0,controls:!0,url:"https://user-images.githubusercontent.com/6422176/272972815-bed96f3a-6b13-45d3-a13b-74eacb27a4cd.mov",width:"100%",height:"100%",mdxType:"ReactPlayer"}),(0,o.kt)("h3",{id:"environment-file-support"},"Environment file support"),(0,o.kt)("p",null,"When creating a container from the Images list, there's now an option to provide an environment file to set env variables for the new container. ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/4026"},"#4026")," ","&","&"," ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/4025"},"#4025")),(0,o.kt)("h3",{id:"enhancements-to-the-settings-area"},"Enhancements to the Settings area"),(0,o.kt)("p",null,"The user experience for enabling or disabling Docker compatibility is improved, with a new entry in the ",(0,o.kt)("strong",{parentName:"p"},(0,o.kt)("icon",{icon:"fa-solid fa-cog",size:"lg"}),"Settings > Preferences")," screen that includes contextual guidance. ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/4093"},"#4093")),(0,o.kt)(s.Z,{playing:!0,controls:!0,url:"https://user-images.githubusercontent.com/6422176/270497318-902b2566-62ad-4ee6-87af-6a9a2705de99.mov",width:"100%",height:"100%",mdxType:"ReactPlayer"}),(0,o.kt)("h3",{id:"improved-user-experience-for-state-changes"},"Improved user experience for state changes"),(0,o.kt)("p",null,"The user experience around state changes for containers, pods, and other objects in the UI is improved, with clear status messages and improved animated visual indicator of state changes. ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/4056"},"#4056")),(0,o.kt)(s.Z,{playing:!0,controls:!0,url:"https://user-images.githubusercontent.com/19958075/270027524-f5176cf9-462f-4024-920a-b4a906c7d30d.mov",width:"100%",height:"100%",mdxType:"ReactPlayer"}),(0,o.kt)(s.Z,{playing:!0,controls:!0,url:"https://user-images.githubusercontent.com/19958075/270027533-70e152ec-5bbf-45ad-9f1d-563752464655.mov",width:"100%",height:"100%",mdxType:"ReactPlayer"}),(0,o.kt)("h3",{id:"extension-api-improvements"},"Extension API improvements"),(0,o.kt)("p",null,"The \ud83e\uddad Podman Desktop extension API received many improvements, including:"),(0,o.kt)("ul",null,(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},"In addition to pushing and listing image from an extension, it's now possible to pull images from a \ud83e\uddad Podman Desktop extension ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/4155"},"#4155"))),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},"The \ud83e\uddad Podman Desktop extension API has been enhanced with both the ability to list images ","&"," networks and the ability to create containers ","&"," networks. ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/4172"},"#4172"))),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},"\ud83e\uddad Podman Desktop extensions now have a consistent way to run administrative tasks. ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/4049"},"#4049"))),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},"Extensions now have the ability to register a custom Kubernetes config generator. ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/3970"},"#3970"))),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},"The ability of extensions to add commands to UI menus has been extended; previously for action menus it was only available in the Image list screen. It is now possible for extensions to add commands to the action menus of items listed on the Containers list screen as well. ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/3947"},"#3947")," ","&"," ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/3963"},"#3963"))),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},"Extensions have gained the ability to contribute menu items in the UI based on specific conditions. ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/3959"},"#3959"))),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},"Enhanced logic for displaying or hiding properties listed under the ",(0,o.kt)("strong",{parentName:"p"},(0,o.kt)("icon",{icon:"fa-solid fa-cog",size:"lg"}),"Settings > Preferences")," screens is now available. ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/4159"},"#4159")))),(0,o.kt)(s.Z,{playing:!0,controls:!0,url:"https://user-images.githubusercontent.com/6422176/271650937-3991565c-12a4-4e6c-a315-9343bfa25f65.mov",width:"100%",height:"100%",mdxType:"ReactPlayer"}),(0,o.kt)("hr",null),(0,o.kt)("h2",{id:"other-notable-enhancements"},"Other Notable Enhancements"),(0,o.kt)("ul",null,(0,o.kt)("li",{parentName:"ul"},"The progress of loading an image into Kind is now visible as a task in the task manager. ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/4061"},"#4061"))),(0,o.kt)("p",null,(0,o.kt)("img",{parentName:"p",src:"https://user-images.githubusercontent.com/42176370/270154775-eb7007b4-fd0e-4287-be9e-40ffc412de35.png",alt:"kind-progress-task"})),(0,o.kt)("ul",null,(0,o.kt)("li",{parentName:"ul"},"It's now possible to start a new Podman machine right after creation, or you can create it and wait to start it later. It's up to you! ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/4046"},"#4046"))),(0,o.kt)("p",null,(0,o.kt)("img",{parentName:"p",src:"https://user-images.githubusercontent.com/49404737/269941187-f4768833-ecfc-4d0b-8acf-d4afedb428d9.png",alt:"podman-start-now-or-later"})),(0,o.kt)("ul",null,(0,o.kt)("li",{parentName:"ul"},"The Podman machine and Kubernetes provider creation forms have an updated look & feel consisted with other forms in the user interface, along with minor bug fixes. ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/4317"},"#4317"))),(0,o.kt)("p",null,(0,o.kt)("img",{parentName:"p",src:"https://user-images.githubusercontent.com/19958075/274694157-fe89f3bc-e5b8-4735-96e9-669fe52c7a41.png",alt:"Updated provider creation forms"})),(0,o.kt)("ul",null,(0,o.kt)("li",{parentName:"ul"},"The empty screen message shown when a search filter results in no matches now provides a message specific to filter matching, including the specific filter terms and an explicit button for clearing the filter. Previously, the screen displayed a generic message about how to create new objects of the type displayed on the screen, which led to some confusion about the status of the system. ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/3988"},"#3988"))),(0,o.kt)(s.Z,{playing:!0,controls:!0,url:"https://user-images.githubusercontent.com/19958075/269291090-13e724f7-252f-4915-bb04-00665001d21d.mov",width:"100%",height:"100%",mdxType:"ReactPlayer"}),(0,o.kt)("ul",null,(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},"New support for adding spin animations to icons is now available. ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/4188"},"#4188"))),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},"There is a new indeterminate progress bar type available for the task manager; this is meant for providing limited status for actions whose APIs do not provide detailed status information. ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/4016"},"#4016"))),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},"For authenticating as admin to perform administrative tasks, \ud83e\uddad Podman Desktop now provides touchID support for macOS. ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/4050"},"#4050")))),(0,o.kt)("p",null,(0,o.kt)("img",{parentName:"p",src:"https://user-images.githubusercontent.com/436777/248588015-f08115bd-d211-43ad-bddd-286d7b3a7056.png",alt:"touchID-support"})),(0,o.kt)(s.Z,{playing:!0,controls:!0,url:"https://user-images.githubusercontent.com/436777/269859758-47581e2b-8469-4e9c-822c-f4fddf46684d.mp4",width:"100%",height:"100%",mdxType:"ReactPlayer"}),(0,o.kt)("ul",null,(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},"Support for connecting to interactive terminals for containers via tty was added. ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/3900"},"#3900"))),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},"It's now more clear which container/pod providers will autostart when \ud83e\uddad Podman Desktop starts. Previously autostart had both a global and a per-provider setting. It has been simplified by removing the global setting. ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/3840"},"#3840"))),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},'The "Working with containers" section of the documentation has been reworked and improved. ',(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/3951"},"#3951")))),(0,o.kt)("hr",null),(0,o.kt)("h2",{id:"notable-bug-fixes"},"Notable Bug Fixes"),(0,o.kt)("ul",null,(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},"The disable registry command was not blocking subsequent pulls from disabled registries. This has been corrected. ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/4183"},"#4183"))),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},"Some users behind network proxies were unable to complete workflow involving the download of online resources. The mechanism for fetching these resources has been fixed to be proxy compatible to address this issue. ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/3994"},"#3994"))),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},"The status of pods running in Kubernetes that are undergoing the deletion process is now accurately reflected in the \ud83e\uddad Podman Desktop UI. ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/3877"},"#3877"))),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},'The image details page always listed the image as being "not used" even when it was. This has been corrected. ',(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/3985"},"#3985"))),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},"Previously, deleting a specific image tag would cause all tags with the same Image ID to be deleted. This has been fixed so only the selected image tag will be deleted. ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/3837"},"#3837"))),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},"Could not view the pod details for some remote Kubernetes cluster pods due to an encoding error. ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/4371"},"#4371"))),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},"Error logs were being tracked separately from the actions they applied to. This has been addressed for kind cluster creation failure ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/4427"},"#4427")," and Compose installation failure ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/4407"},"#4407"),".")),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},'For Linux users, \ud83e\uddad Podman Desktop previously did not appear under the "Development" menu when installed via Flatpak; it appeared under "Utilities." \ud83e\uddad Podman Desktop now appears under the "Development" menu. ',(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/3911"},"#3911"))),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},'Podman Machine names are no longer prefixed with the "Podman Machine" string. ',(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/3878"},"#3878")))),(0,o.kt)("p",null,(0,o.kt)("img",{parentName:"p",src:"https://user-images.githubusercontent.com/19958075/267378447-aafdfbd7-f005-4b94-8626-9e11eec61b95.png",alt:"touchID-support"})),(0,o.kt)("ul",null,(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},'The initial action state of pods and containers was being displayed as "STARTING" regardless of actual state; this has been corrected. ',(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/3889"},"#3889"))),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},"Resizing the application window no longer makes the last lines of a container's terminal invisible. ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/3993"},"#3993"))),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},"An issue with incorrect terminal behavior in response to long lines in the terminal attached to a container has been resolved. ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/3955"},"#3955"))),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},"A spacing issue on the run image form has been corrected. ","[#4089]",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/4089"},"https://github.com/containers/podman-desktop/pull/4089"))),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},'The "podify" icon & button on the Containers list was unusually large in release 1.4. That regression has been corrected in this release. ',(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/4122"},"#4122"))),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},"An error in the instructions for Windows users on migrating from Docker has been corrected. ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/4157"},"#4157")))),(0,o.kt)("hr",null),(0,o.kt)("h2",{id:"community-thank-you"},"Community Thank You"),(0,o.kt)("p",null,"\ud83c\udf89 We\u2019d like to say a big thank you to everyone who helped to make \ud83e\uddad Podman Desktop even better. In this\nrelease we received pull requests from the following people:"),(0,o.kt)("ul",null,(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},(0,o.kt)("a",{parentName:"p",href:"https://github.com/afbjorklund"},"afbjorklund")," in ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/4373"},"#4373 - docs: fix broken links and add lima onboarding"),", ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/4372"},"#4372 - docs: clear up lima column on containers page"),", ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/4091"},"#4091 - fix: avoid errors with unexpected JSON input"),", ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/4098"},"#4098 - docs: Lima onboarding details"),", and ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/3854"},"#3854 - fix: check if machine init rootful flag supported"))),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},(0,o.kt)("a",{parentName:"p",href:"https://github.com/axel7083"},"axel7083")," in ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/4061"},"#4061 - feat: adding task progress for kind"),", ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/3970"},"#3970 - feat: extension can register custom kube generator"),", ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/3959"},"#3959 - feat: add when property to extensions menus"),", ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/4016"},"#4016 - feat: indeterminate progress bar"),", ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/3963"},"#3963 - fix: ContainerList propagating containers in ComposeActions and PodActions"),", and ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/3947"},"#3947 - feat: extend menus capabilities"))),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},(0,o.kt)("a",{parentName:"p",href:"https://github.com/ayushrakesh"},"ayushrakesh")," in ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/4415#"},"#4415 - Update README.md"))),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},(0,o.kt)("a",{parentName:"p",href:"https://github.com/eltociear"},"eltociear")," in ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/4194"},"#4194 - Update README.md"))),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},(0,o.kt)("a",{parentName:"p",href:"https://github.com/foxydevloper"},"foxydeveloper")," in ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/4157"},"#4157 - docs: Correct windows instructions for migrating from docker"))),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},(0,o.kt)("a",{parentName:"p",href:"https://github.com/harsh-solanki21"},"harsh-solanki21")," in ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/4162"},"#4162 - fix: Removed fullstop from summary"))),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},(0,o.kt)("a",{parentName:"p",href:"https://github.com/rahul0x00"},"rahul0x00")," in ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/4240"},"#4240 - fix typos in README.md"))),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},(0,o.kt)("a",{parentName:"p",href:"https://github.com/shelar1423"},"shelar1423")," in ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/4221"},"#4221 - chore: document property setting in EXTENSIONS.md")))),(0,o.kt)("hr",null),(0,o.kt)("h2",{id:"final-notes"},"Final notes"),(0,o.kt)("h3",{id:"known-issues"},"Known Issues"),(0,o.kt)("p",null,"We have a discussion board topic where we have posted known issues with this release. If you run into problems, please check this list before filing a bug - if we already have an issue open for it, it saves you the time and trouble of filing, and there may be a workaround posted in the issue."),(0,o.kt)("h4",{id:"known-issues-podman-desktop-152"},(0,o.kt)("a",{parentName:"h4",href:"https://github.com/containers/podman-desktop/discussions/4635"},"Known Issues: Podman Desktop 1.5.2")),(0,o.kt)("h3",{id:"fixed-issues"},"Fixed Issues"),(0,o.kt)("p",null,"The complete list of issues fixed in this release is available ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/issues?q=is%3Aclosed+milestone%3A1.5.0"},"here"),"."),(0,o.kt)("h3",{id:"where-to-download"},"Where to Download"),(0,o.kt)("p",null,"Get the latest release from the ",(0,o.kt)("a",{parentName:"p",href:"/downloads"},"Downloads")," section of the website and boost your development journey with Podman Desktop. Additionally, visit the ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop"},"GitHub repository")," and see how you can help us make Podman Desktop better."))}h.isMDXComponent=!0},90973:(e,t,a)=>{a.d(t,{Z:()=>n});const n=a.p+"assets/images/onboarding-selkies-3ddb7cb6ee2cf9abed002b01f63b1822.png"}}]); \ No newline at end of file diff --git a/assets/js/021eaa84.adb70247.js b/assets/js/021eaa84.adb70247.js new file mode 100644 index 00000000000..b375fb4f5dc --- /dev/null +++ b/assets/js/021eaa84.adb70247.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[7875],{4065:(e,t,a)=>{a.r(t),a.d(t,{assets:()=>l,contentTitle:()=>r,default:()=>c,frontMatter:()=>i,metadata:()=>p,toc:()=>m});var n=a(25773),o=(a(27378),a(35318)),s=a(92975);const i={title:"Release Notes - Podman Desktop 1.5",description:"Podman Desktop 1.5 has been released!",slug:"podman-desktop-release-1.5",authors:"duffy",tags:["podman-desktop","release","kubernetes","openshift","onboarding","compose","extensions","settings"],hide_table_of_contents:!1,image:"/blog/img/podman-desktop-release-1.5/onboarding-selkies.png"},r=void 0,p={permalink:"/blog/podman-desktop-release-1.5",source:"@site/blog/2023-11-03-release-1.5.md",title:"Release Notes - Podman Desktop 1.5",description:"Podman Desktop 1.5 has been released!",date:"2023-11-03T00:00:00.000Z",formattedDate:"November 3, 2023",tags:[{label:"podman-desktop",permalink:"/blog/tags/podman-desktop"},{label:"release",permalink:"/blog/tags/release"},{label:"kubernetes",permalink:"/blog/tags/kubernetes"},{label:"openshift",permalink:"/blog/tags/openshift"},{label:"onboarding",permalink:"/blog/tags/onboarding"},{label:"compose",permalink:"/blog/tags/compose"},{label:"extensions",permalink:"/blog/tags/extensions"},{label:"settings",permalink:"/blog/tags/settings"}],readingTime:8.14,hasTruncateMarker:!1,authors:[{name:"M\xe1ir\xedn Duffy",title:"User Experience Designer",url:"https://github.com/mairin",imageURL:"https://github.com/mairin.png",key:"duffy"}],frontMatter:{title:"Release Notes - Podman Desktop 1.5",description:"Podman Desktop 1.5 has been released!",slug:"podman-desktop-release-1.5",authors:"duffy",tags:["podman-desktop","release","kubernetes","openshift","onboarding","compose","extensions","settings"],hide_table_of_contents:!1,image:"/blog/img/podman-desktop-release-1.5/onboarding-selkies.png"},nextItem:{title:"Release Notes - Podman Desktop 1.4",permalink:"/blog/podman-desktop-release-1.4"}},l={authorsImageUrls:[void 0]},m=[{value:"Release Details",id:"release-details",level:2},{value:"Onboarding",id:"onboarding",level:3},{value:"Command Palette",id:"command-palette",level:3},{value:"Expanded "Summary" tab for Kubernetes pods",id:"expanded-summary-tab-for-kubernetes-pods",level:3},{value:"Environment file support",id:"environment-file-support",level:3},{value:"Enhancements to the Settings area",id:"enhancements-to-the-settings-area",level:3},{value:"Improved user experience for state changes",id:"improved-user-experience-for-state-changes",level:3},{value:"Extension API improvements",id:"extension-api-improvements",level:3},{value:"Other Notable Enhancements",id:"other-notable-enhancements",level:2},{value:"Notable Bug Fixes",id:"notable-bug-fixes",level:2},{value:"Community Thank You",id:"community-thank-you",level:2},{value:"Final notes",id:"final-notes",level:2},{value:"Known Issues",id:"known-issues",level:3},{value:"Known Issues: Podman Desktop 1.5.2",id:"known-issues-podman-desktop-152",level:4},{value:"Fixed Issues",id:"fixed-issues",level:3},{value:"Where to Download",id:"where-to-download",level:3}],d=(h="Icon",function(e){return console.warn("Component "+h+" was not imported, exported, or provided by MDXProvider as global scope"),(0,o.kt)("div",e)});var h;const u={toc:m};function c(e){let{components:t,...i}=e;return(0,o.kt)("wrapper",(0,n.Z)({},u,i,{components:t,mdxType:"MDXLayout"}),(0,o.kt)("p",null,"Podman Desktop 1.5 Release! \ud83c\udf89"),(0,o.kt)("p",null,"With this release of Podman Desktop, we're introducing ",(0,o.kt)("strong",{parentName:"p"},"a new onboarding feature")," that we hope will earn your \ud83e\uddad seal of approval! But wait... there's so much more!"),(0,o.kt)("ul",null,(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("strong",{parentName:"li"},"Onboarding"),": Guided setup and configuration of ",(0,o.kt)("strong",{parentName:"li"},"Podman")," and ",(0,o.kt)("strong",{parentName:"li"},"Compose")),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("strong",{parentName:"li"},"Podman 4.7.2"),": ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman/releases"},"Podman 4.7.2")," is now included in Windows and Mac installers"),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("strong",{parentName:"li"},"Command Palette"),": Gain easy access to various commands via a new keyboard-driven command palette"),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("strong",{parentName:"li"},'Expanded "Summary" tab for Kubernetes pods'),': Go deep with extended details on Kubernetes pods in the pod "Summary" tab'),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("strong",{parentName:"li"},"Environment file support"),": Chart out environment variables for new containers to access on creation"),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("strong",{parentName:"li"},"Enhancements to the Settings area"),": Get your bearings with improved Docker compatibility mode controls"),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("strong",{parentName:"li"},"Improved user experience for state changes"),": No more dead reckoning on container state with improved visual indication of status"),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("strong",{parentName:"li"},"Extension API improvements"),": A boatload of improvements to the extension API enabling more goodness from \ud83e\uddad Podman Desktop's extensions")),(0,o.kt)("p",null,"Podman Desktop 1.5 is now available. ",(0,o.kt)("a",{parentName:"p",href:"/downloads"},"Click here to download it"),"!"),(0,o.kt)("p",null,(0,o.kt)("img",{alt:"Podman-desktop-1-5-hero",src:a(90973).Z,width:"1920",height:"1080"})),(0,o.kt)("hr",null),(0,o.kt)("h2",{id:"release-details"},"Release Details"),(0,o.kt)("h3",{id:"onboarding"},"Onboarding"),(0,o.kt)("p",null,"We are introducing a new feature providing guided flows for the initial setup of specific \ud83e\uddad Podman Desktop extensions. Release 1.5 features two new onboarding flows: Podman and Compose."),(0,o.kt)("p",null,'To start the Podman onboarding flow, you can start from the dashboard notification by clicking the "Set up" button:\n',(0,o.kt)("img",{parentName:"p",src:"https://user-images.githubusercontent.com/799683/280362279-598cc052-5ea4-4c31-849c-da9bbbcc3e42.png",alt:"podman-onboarding-start"}),"\n",(0,o.kt)("img",{parentName:"p",src:"https://user-images.githubusercontent.com/799683/280363859-f35b85f8-1dd4-4b7f-a995-25fe5d1ccced.png",alt:"podman-onboarding"})),(0,o.kt)("p",null,"Visit ",(0,o.kt)("strong",{parentName:"p"},(0,o.kt)(d,{icon:"fa-solid fa-cog",size:"lg",mdxType:"Icon"}),"Settings > Resources"),' screen and click the Compose "Setup ..." button in order to start Compose onboarding:\n',(0,o.kt)("img",{parentName:"p",src:"https://user-images.githubusercontent.com/799683/280276847-ca0558ab-70ad-48cc-8dd5-67e3eb465a62.png",alt:"compose-onboarding-start"}),"\n",(0,o.kt)("img",{parentName:"p",src:"https://user-images.githubusercontent.com/799683/280277936-77ba0fb2-5cb0-41de-a7cf-1a3d6400fd89.png",alt:"compose-onboarding"})),(0,o.kt)("h3",{id:"command-palette"},"Command Palette"),(0,o.kt)("p",null,"A new, search-driven command palette is now available to enable quick access to various commands available across \ud83e\uddad Podman Desktop. You can try this new tool out by hitting the F1 key. ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/4081"},"#4081")," ","&","&"," ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/3979"},"#3979")),(0,o.kt)(s.Z,{playing:!0,controls:!0,url:"https://user-images.githubusercontent.com/436777/270362431-5aaa6a1b-6df5-4b66-a811-cdd148d02ad6.mp4",width:"100%",height:"100%",mdxType:"ReactPlayer"}),(0,o.kt)("h3",{id:"expanded-summary-tab-for-kubernetes-pods"},'Expanded "Summary" tab for Kubernetes pods'),(0,o.kt)("p",null,'Kubernetes pods now offer a more comprehensive set of information under the "Summary" tab, including networking, volumes, environment variables, and other key metadata.'),(0,o.kt)(s.Z,{playing:!0,controls:!0,url:"https://user-images.githubusercontent.com/6422176/272972815-bed96f3a-6b13-45d3-a13b-74eacb27a4cd.mov",width:"100%",height:"100%",mdxType:"ReactPlayer"}),(0,o.kt)("h3",{id:"environment-file-support"},"Environment file support"),(0,o.kt)("p",null,"When creating a container from the Images list, there's now an option to provide an environment file to set env variables for the new container. ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/4026"},"#4026")," ","&","&"," ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/4025"},"#4025")),(0,o.kt)("h3",{id:"enhancements-to-the-settings-area"},"Enhancements to the Settings area"),(0,o.kt)("p",null,"The user experience for enabling or disabling Docker compatibility is improved, with a new entry in the ",(0,o.kt)("strong",{parentName:"p"},(0,o.kt)(d,{icon:"fa-solid fa-cog",size:"lg",mdxType:"Icon"}),"Settings > Preferences")," screen that includes contextual guidance. ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/4093"},"#4093")),(0,o.kt)(s.Z,{playing:!0,controls:!0,url:"https://user-images.githubusercontent.com/6422176/270497318-902b2566-62ad-4ee6-87af-6a9a2705de99.mov",width:"100%",height:"100%",mdxType:"ReactPlayer"}),(0,o.kt)("h3",{id:"improved-user-experience-for-state-changes"},"Improved user experience for state changes"),(0,o.kt)("p",null,"The user experience around state changes for containers, pods, and other objects in the UI is improved, with clear status messages and improved animated visual indicator of state changes. ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/4056"},"#4056")),(0,o.kt)(s.Z,{playing:!0,controls:!0,url:"https://user-images.githubusercontent.com/19958075/270027524-f5176cf9-462f-4024-920a-b4a906c7d30d.mov",width:"100%",height:"100%",mdxType:"ReactPlayer"}),(0,o.kt)(s.Z,{playing:!0,controls:!0,url:"https://user-images.githubusercontent.com/19958075/270027533-70e152ec-5bbf-45ad-9f1d-563752464655.mov",width:"100%",height:"100%",mdxType:"ReactPlayer"}),(0,o.kt)("h3",{id:"extension-api-improvements"},"Extension API improvements"),(0,o.kt)("p",null,"The \ud83e\uddad Podman Desktop extension API received many improvements, including:"),(0,o.kt)("ul",null,(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},"In addition to pushing and listing image from an extension, it's now possible to pull images from a \ud83e\uddad Podman Desktop extension ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/4155"},"#4155"))),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},"The \ud83e\uddad Podman Desktop extension API has been enhanced with both the ability to list images ","&"," networks and the ability to create containers ","&"," networks. ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/4172"},"#4172"))),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},"\ud83e\uddad Podman Desktop extensions now have a consistent way to run administrative tasks. ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/4049"},"#4049"))),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},"Extensions now have the ability to register a custom Kubernetes config generator. ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/3970"},"#3970"))),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},"The ability of extensions to add commands to UI menus has been extended; previously for action menus it was only available in the Image list screen. It is now possible for extensions to add commands to the action menus of items listed on the Containers list screen as well. ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/3947"},"#3947")," ","&"," ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/3963"},"#3963"))),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},"Extensions have gained the ability to contribute menu items in the UI based on specific conditions. ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/3959"},"#3959"))),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},"Enhanced logic for displaying or hiding properties listed under the ",(0,o.kt)("strong",{parentName:"p"},(0,o.kt)(d,{icon:"fa-solid fa-cog",size:"lg",mdxType:"Icon"}),"Settings > Preferences")," screens is now available. ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/4159"},"#4159")))),(0,o.kt)(s.Z,{playing:!0,controls:!0,url:"https://user-images.githubusercontent.com/6422176/271650937-3991565c-12a4-4e6c-a315-9343bfa25f65.mov",width:"100%",height:"100%",mdxType:"ReactPlayer"}),(0,o.kt)("hr",null),(0,o.kt)("h2",{id:"other-notable-enhancements"},"Other Notable Enhancements"),(0,o.kt)("ul",null,(0,o.kt)("li",{parentName:"ul"},"The progress of loading an image into Kind is now visible as a task in the task manager. ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/4061"},"#4061"))),(0,o.kt)("p",null,(0,o.kt)("img",{parentName:"p",src:"https://user-images.githubusercontent.com/42176370/270154775-eb7007b4-fd0e-4287-be9e-40ffc412de35.png",alt:"kind-progress-task"})),(0,o.kt)("ul",null,(0,o.kt)("li",{parentName:"ul"},"It's now possible to start a new Podman machine right after creation, or you can create it and wait to start it later. It's up to you! ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/4046"},"#4046"))),(0,o.kt)("p",null,(0,o.kt)("img",{parentName:"p",src:"https://user-images.githubusercontent.com/49404737/269941187-f4768833-ecfc-4d0b-8acf-d4afedb428d9.png",alt:"podman-start-now-or-later"})),(0,o.kt)("ul",null,(0,o.kt)("li",{parentName:"ul"},"The Podman machine and Kubernetes provider creation forms have an updated look & feel consisted with other forms in the user interface, along with minor bug fixes. ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/4317"},"#4317"))),(0,o.kt)("p",null,(0,o.kt)("img",{parentName:"p",src:"https://user-images.githubusercontent.com/19958075/274694157-fe89f3bc-e5b8-4735-96e9-669fe52c7a41.png",alt:"Updated provider creation forms"})),(0,o.kt)("ul",null,(0,o.kt)("li",{parentName:"ul"},"The empty screen message shown when a search filter results in no matches now provides a message specific to filter matching, including the specific filter terms and an explicit button for clearing the filter. Previously, the screen displayed a generic message about how to create new objects of the type displayed on the screen, which led to some confusion about the status of the system. ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/3988"},"#3988"))),(0,o.kt)(s.Z,{playing:!0,controls:!0,url:"https://user-images.githubusercontent.com/19958075/269291090-13e724f7-252f-4915-bb04-00665001d21d.mov",width:"100%",height:"100%",mdxType:"ReactPlayer"}),(0,o.kt)("ul",null,(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},"New support for adding spin animations to icons is now available. ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/4188"},"#4188"))),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},"There is a new indeterminate progress bar type available for the task manager; this is meant for providing limited status for actions whose APIs do not provide detailed status information. ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/4016"},"#4016"))),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},"For authenticating as admin to perform administrative tasks, \ud83e\uddad Podman Desktop now provides touchID support for macOS. ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/4050"},"#4050")))),(0,o.kt)("p",null,(0,o.kt)("img",{parentName:"p",src:"https://user-images.githubusercontent.com/436777/248588015-f08115bd-d211-43ad-bddd-286d7b3a7056.png",alt:"touchID-support"})),(0,o.kt)(s.Z,{playing:!0,controls:!0,url:"https://user-images.githubusercontent.com/436777/269859758-47581e2b-8469-4e9c-822c-f4fddf46684d.mp4",width:"100%",height:"100%",mdxType:"ReactPlayer"}),(0,o.kt)("ul",null,(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},"Support for connecting to interactive terminals for containers via tty was added. ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/3900"},"#3900"))),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},"It's now more clear which container/pod providers will autostart when \ud83e\uddad Podman Desktop starts. Previously autostart had both a global and a per-provider setting. It has been simplified by removing the global setting. ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/3840"},"#3840"))),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},'The "Working with containers" section of the documentation has been reworked and improved. ',(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/3951"},"#3951")))),(0,o.kt)("hr",null),(0,o.kt)("h2",{id:"notable-bug-fixes"},"Notable Bug Fixes"),(0,o.kt)("ul",null,(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},"The disable registry command was not blocking subsequent pulls from disabled registries. This has been corrected. ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/4183"},"#4183"))),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},"Some users behind network proxies were unable to complete workflow involving the download of online resources. The mechanism for fetching these resources has been fixed to be proxy compatible to address this issue. ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/3994"},"#3994"))),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},"The status of pods running in Kubernetes that are undergoing the deletion process is now accurately reflected in the \ud83e\uddad Podman Desktop UI. ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/3877"},"#3877"))),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},'The image details page always listed the image as being "not used" even when it was. This has been corrected. ',(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/3985"},"#3985"))),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},"Previously, deleting a specific image tag would cause all tags with the same Image ID to be deleted. This has been fixed so only the selected image tag will be deleted. ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/3837"},"#3837"))),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},"Could not view the pod details for some remote Kubernetes cluster pods due to an encoding error. ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/4371"},"#4371"))),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},"Error logs were being tracked separately from the actions they applied to. This has been addressed for kind cluster creation failure ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/4427"},"#4427")," and Compose installation failure ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/4407"},"#4407"),".")),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},'For Linux users, \ud83e\uddad Podman Desktop previously did not appear under the "Development" menu when installed via Flatpak; it appeared under "Utilities." \ud83e\uddad Podman Desktop now appears under the "Development" menu. ',(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/3911"},"#3911"))),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},'Podman Machine names are no longer prefixed with the "Podman Machine" string. ',(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/3878"},"#3878")))),(0,o.kt)("p",null,(0,o.kt)("img",{parentName:"p",src:"https://user-images.githubusercontent.com/19958075/267378447-aafdfbd7-f005-4b94-8626-9e11eec61b95.png",alt:"touchID-support"})),(0,o.kt)("ul",null,(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},'The initial action state of pods and containers was being displayed as "STARTING" regardless of actual state; this has been corrected. ',(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/3889"},"#3889"))),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},"Resizing the application window no longer makes the last lines of a container's terminal invisible. ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/3993"},"#3993"))),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},"An issue with incorrect terminal behavior in response to long lines in the terminal attached to a container has been resolved. ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/3955"},"#3955"))),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},"A spacing issue on the run image form has been corrected. ","[#4089]",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/4089"},"https://github.com/containers/podman-desktop/pull/4089"))),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},'The "podify" icon & button on the Containers list was unusually large in release 1.4. That regression has been corrected in this release. ',(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/4122"},"#4122"))),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},"An error in the instructions for Windows users on migrating from Docker has been corrected. ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/4157"},"#4157")))),(0,o.kt)("hr",null),(0,o.kt)("h2",{id:"community-thank-you"},"Community Thank You"),(0,o.kt)("p",null,"\ud83c\udf89 We\u2019d like to say a big thank you to everyone who helped to make \ud83e\uddad Podman Desktop even better. In this\nrelease we received pull requests from the following people:"),(0,o.kt)("ul",null,(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},(0,o.kt)("a",{parentName:"p",href:"https://github.com/afbjorklund"},"afbjorklund")," in ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/4373"},"#4373 - docs: fix broken links and add lima onboarding"),", ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/4372"},"#4372 - docs: clear up lima column on containers page"),", ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/4091"},"#4091 - fix: avoid errors with unexpected JSON input"),", ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/4098"},"#4098 - docs: Lima onboarding details"),", and ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/3854"},"#3854 - fix: check if machine init rootful flag supported"))),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},(0,o.kt)("a",{parentName:"p",href:"https://github.com/axel7083"},"axel7083")," in ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/4061"},"#4061 - feat: adding task progress for kind"),", ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/3970"},"#3970 - feat: extension can register custom kube generator"),", ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/3959"},"#3959 - feat: add when property to extensions menus"),", ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/4016"},"#4016 - feat: indeterminate progress bar"),", ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/3963"},"#3963 - fix: ContainerList propagating containers in ComposeActions and PodActions"),", and ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/3947"},"#3947 - feat: extend menus capabilities"))),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},(0,o.kt)("a",{parentName:"p",href:"https://github.com/ayushrakesh"},"ayushrakesh")," in ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/4415#"},"#4415 - Update README.md"))),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},(0,o.kt)("a",{parentName:"p",href:"https://github.com/eltociear"},"eltociear")," in ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/4194"},"#4194 - Update README.md"))),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},(0,o.kt)("a",{parentName:"p",href:"https://github.com/foxydevloper"},"foxydeveloper")," in ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/4157"},"#4157 - docs: Correct windows instructions for migrating from docker"))),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},(0,o.kt)("a",{parentName:"p",href:"https://github.com/harsh-solanki21"},"harsh-solanki21")," in ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/4162"},"#4162 - fix: Removed fullstop from summary"))),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},(0,o.kt)("a",{parentName:"p",href:"https://github.com/rahul0x00"},"rahul0x00")," in ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/4240"},"#4240 - fix typos in README.md"))),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},(0,o.kt)("a",{parentName:"p",href:"https://github.com/shelar1423"},"shelar1423")," in ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/4221"},"#4221 - chore: document property setting in EXTENSIONS.md")))),(0,o.kt)("hr",null),(0,o.kt)("h2",{id:"final-notes"},"Final notes"),(0,o.kt)("h3",{id:"known-issues"},"Known Issues"),(0,o.kt)("p",null,"We have a discussion board topic where we have posted known issues with this release. If you run into problems, please check this list before filing a bug - if we already have an issue open for it, it saves you the time and trouble of filing, and there may be a workaround posted in the issue."),(0,o.kt)("h4",{id:"known-issues-podman-desktop-152"},(0,o.kt)("a",{parentName:"h4",href:"https://github.com/containers/podman-desktop/discussions/4635"},"Known Issues: Podman Desktop 1.5.2")),(0,o.kt)("h3",{id:"fixed-issues"},"Fixed Issues"),(0,o.kt)("p",null,"The complete list of issues fixed in this release is available ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/issues?q=is%3Aclosed+milestone%3A1.5.0"},"here"),"."),(0,o.kt)("h3",{id:"where-to-download"},"Where to Download"),(0,o.kt)("p",null,"Get the latest release from the ",(0,o.kt)("a",{parentName:"p",href:"/downloads"},"Downloads")," section of the website and boost your development journey with Podman Desktop. Additionally, visit the ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop"},"GitHub repository")," and see how you can help us make Podman Desktop better."))}c.isMDXComponent=!0},90973:(e,t,a)=>{a.d(t,{Z:()=>n});const n=a.p+"assets/images/onboarding-selkies-3ddb7cb6ee2cf9abed002b01f63b1822.png"}}]); \ No newline at end of file diff --git a/assets/js/07f59c2a.6701e01f.js b/assets/js/07f59c2a.6701e01f.js new file mode 100644 index 00000000000..e34ff745e3d --- /dev/null +++ b/assets/js/07f59c2a.6701e01f.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[9372],{35318:(e,t,n)=>{n.d(t,{Zo:()=>d,kt:()=>c});var a=n(27378);function o(e,t,n){return t in e?Object.defineProperty(e,t,{value:n,enumerable:!0,configurable:!0,writable:!0}):e[t]=n,e}function i(e,t){var n=Object.keys(e);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);t&&(a=a.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),n.push.apply(n,a)}return n}function r(e){for(var t=1;t=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var i=Object.getOwnPropertySymbols(e);for(a=0;a=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var l=a.createContext({}),p=function(e){var t=a.useContext(l),n=t;return e&&(n="function"==typeof e?e(t):r(r({},t),e)),n},d=function(e){var t=p(e.components);return a.createElement(l.Provider,{value:t},e.children)},m={inlineCode:"code",wrapper:function(e){var t=e.children;return a.createElement(a.Fragment,{},t)}},u=a.forwardRef((function(e,t){var n=e.components,o=e.mdxType,i=e.originalType,l=e.parentName,d=s(e,["components","mdxType","originalType","parentName"]),u=p(n),c=o,h=u["".concat(l,".").concat(c)]||u[c]||m[c]||i;return n?a.createElement(h,r(r({ref:t},d),{},{components:n})):a.createElement(h,r({ref:t},d))}));function c(e,t){var n=arguments,o=t&&t.mdxType;if("string"==typeof e||o){var i=n.length,r=new Array(i);r[0]=u;var s={};for(var l in t)hasOwnProperty.call(t,l)&&(s[l]=t[l]);s.originalType=e,s.mdxType="string"==typeof e?e:o,r[1]=s;for(var p=2;p{n.r(t),n.d(t,{assets:()=>l,contentTitle:()=>r,default:()=>c,frontMatter:()=>i,metadata:()=>s,toc:()=>p});var a=n(25773),o=(n(27378),n(35318));const i={title:"Release Notes - Podman Desktop 0.10",description:"Podman Desktop 0.10 has been released! New Create Container Wizard, improved Kubernetes workflows, revamped registries configuration, and more!",slug:"podman-desktop-release-0.10",authors:["deekay2310"],tags:["podman-desktop","release","kubernetes"],hide_table_of_contents:!1},r=void 0,s={permalink:"/blog/podman-desktop-release-0.10",source:"@site/blog/2022-12-01-release-0.10-blog.md",title:"Release Notes - Podman Desktop 0.10",description:"Podman Desktop 0.10 has been released! New Create Container Wizard, improved Kubernetes workflows, revamped registries configuration, and more!",date:"2022-12-01T00:00:00.000Z",formattedDate:"December 1, 2022",tags:[{label:"podman-desktop",permalink:"/blog/tags/podman-desktop"},{label:"release",permalink:"/blog/tags/release"},{label:"kubernetes",permalink:"/blog/tags/kubernetes"}],readingTime:4.115,hasTruncateMarker:!0,authors:[{name:"Dev Kumar",title:"Technical PMM Intern",url:"https://github.com/deekay2310",imageURL:"https://github.com/deekay2310.png",key:"deekay2310"}],frontMatter:{title:"Release Notes - Podman Desktop 0.10",description:"Podman Desktop 0.10 has been released! New Create Container Wizard, improved Kubernetes workflows, revamped registries configuration, and more!",slug:"podman-desktop-release-0.10",authors:["deekay2310"],tags:["podman-desktop","release","kubernetes"],hide_table_of_contents:!1},prevItem:{title:"Release Notes - Podman Desktop 0.11",permalink:"/blog/podman-desktop-release-0.11"},nextItem:{title:"Build & run Podman Desktop in a DevContainer",permalink:"/blog/develop-using-devcontainer"}},l={authorsImageUrls:[void 0]},p=[{value:"Release Details",id:"release-details",level:2},{value:"New configuration wizzard to create containers (#773)",id:"new-configuration-wizzard-to-create-containers-773",level:3},{value:"Kubernetes Capabilities Improvements",id:"kubernetes-capabilities-improvements",level:3},{value:"Revamped Container Registries UI (#446)",id:"revamped-container-registries-ui-446",level:3},{value:"Update to Podman 4.3.1 (#913)",id:"update-to-podman-431-913",level:3},{value:"UI/UX Improvements",id:"uiux-improvements",level:3},{value:"Other Notable Enhancements",id:"other-notable-enhancements",level:2},{value:"Notable bug fixes",id:"notable-bug-fixes",level:2},{value:"Community Thank You",id:"community-thank-you",level:2},{value:"Final Notes",id:"final-notes",level:2}],d=(m="Icon",function(e){return console.warn("Component "+m+" was not imported, exported, or provided by MDXProvider as global scope"),(0,o.kt)("div",e)});var m;const u={toc:p};function c(e){let{components:t,...i}=e;return(0,o.kt)("wrapper",(0,a.Z)({},u,i,{components:t,mdxType:"MDXLayout"}),(0,o.kt)("p",null,"This release note covers Podman Desktop 0.10 release changes."),(0,o.kt)("ul",null,(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("strong",{parentName:"li"},"Containers Configuration"),": Container creation wizzard allowing to define environment variables, networking and more configuration options."),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("strong",{parentName:"li"},"Kubernetes Improvements"),": Play Kubernetes YAML, custom Kubeconfig path support, reload of kube context."),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("strong",{parentName:"li"},"Registries Configuration"),": Revamped registries configuration UI."),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("strong",{parentName:"li"},"Podman Version"),": Podman 4.3.1 now included in Windows and Mac installers."),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("strong",{parentName:"li"},"UX/UI Improvements"),": Improved lists, better contrast, and more.")),(0,o.kt)("p",null,"Podman Desktop 0.10 is now available. ",(0,o.kt)("a",{parentName:"p",href:"/downloads"},"Click here to download it"),"!"),(0,o.kt)("hr",null),(0,o.kt)("h2",{id:"release-details"},"Release Details"),(0,o.kt)("h3",{id:"new-configuration-wizzard-to-create-containers-773"},"New configuration wizzard to create containers (",(0,o.kt)("a",{parentName:"h3",href:"https://github.com/containers/podman-desktop/pull/773"},"#773"),")"),(0,o.kt)("p",null,"Until now, we could only specify port binding when building images to start containers. The create container wizzard now includes several options enabling configuring volumes, environment variables, restart policy and settings on networking and security. It is also possible to reuse an existing (and already configured) a network when creating containers."),(0,o.kt)("p",null,(0,o.kt)("img",{alt:"new container creation wizard",src:n(21093).Z,width:"800",height:"465"})),(0,o.kt)("h3",{id:"kubernetes-capabilities-improvements"},"Kubernetes Capabilities Improvements"),(0,o.kt)("p",null,(0,o.kt)("strong",{parentName:"p"},"Custom Kubeconfig file path (",(0,o.kt)("a",{parentName:"strong",href:"https://github.com/containers/podman-desktop/pull/780"},"#780"),")")),(0,o.kt)("p",null,"Kubeconfig path location is now configurable from ",(0,o.kt)("strong",{parentName:"p"},(0,o.kt)(d,{icon:"fa-solid fa-cog",size:"lg",mdxType:"Icon"})," Settings > Preferences > Kubernetes: Kubeconfig")," and can be set to a custom path. By default, Podman Desktop use the path ",(0,o.kt)("inlineCode",{parentName:"p"},"$HOME/.kube/config")," for the Kubeconfig file."),(0,o.kt)("p",null,(0,o.kt)("img",{alt:"custom kubeconfig file path",src:n(65747).Z,width:"2324",height:"1424"})),(0,o.kt)("p",null,(0,o.kt)("strong",{parentName:"p"},"Play Kubernetes YAML from the Pods list (",(0,o.kt)("a",{parentName:"strong",href:"https://github.com/containers/podman-desktop/pull/739"},"#739"),")")),(0,o.kt)("p",null,"Podman Desktop enables to play existing Kubernetes YAML files. This is now available from ",(0,o.kt)("inlineCode",{parentName:"p"},"Play Kubernetes YAML")," button added to the Pods list, in addition to the Containers list."),(0,o.kt)("p",null,(0,o.kt)("img",{alt:"play k8s yaml",src:n(96917).Z,width:"800",height:"500"})),(0,o.kt)("p",null,(0,o.kt)("strong",{parentName:"p"},"Kube context automatically reloaded when updated (",(0,o.kt)("a",{parentName:"strong",href:"https://github.com/containers/podman-desktop/pull/813"},"#813"),")")),(0,o.kt)("p",null,"Any change to the kube context will now be detected by Podman Desktop in its running state. The system tray, allowing to select which Kubernetes environment to work with, will now reload the kube context without restarting Podman Desktop."),(0,o.kt)("h3",{id:"revamped-container-registries-ui-446"},"Revamped Container Registries UI (",(0,o.kt)("a",{parentName:"h3",href:"https://github.com/containers/podman-desktop/issues/446"},"#446"),")"),(0,o.kt)("p",null,"The registries configuration UI has been revamped. Instead of using tiles for displaying the registries, now it uses a list where each registry can be added or edited directly in the list. The kebab menu provides options to edit or remove a registry from the list."),(0,o.kt)("p",null,(0,o.kt)("img",{alt:"registries",src:n(63959).Z,width:"2428",height:"1494"})),(0,o.kt)("h3",{id:"update-to-podman-431-913"},"Update to Podman 4.3.1 (",(0,o.kt)("a",{parentName:"h3",href:"https://github.com/containers/podman-desktop/issues/913"},"#913"),")"),(0,o.kt)("p",null,"Podman Desktop 0.10 is now embedding ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman/releases/tag/v4.3.1"},"Podman 4.3.1")," in Windows and macOS installers."),(0,o.kt)("h3",{id:"uiux-improvements"},"UI/UX Improvements"),(0,o.kt)("p",null,(0,o.kt)("strong",{parentName:"p"},"Improved lists UX (",(0,o.kt)("a",{parentName:"strong",href:"https://github.com/containers/podman-desktop/pull/877"},"#877"),")")),(0,o.kt)("p",null,"To reduce the width used in the lists when displaying all the icons, main actions icons are now always displayed (before it was on hover) and the secondary actions are displayed in a kebab menu. For example Start/Stop and delete are primary actions while open the browser, inspect, generate kube yaml, etc. are secondary options."),(0,o.kt)("p",null,(0,o.kt)("img",{alt:"kebab menu",src:n(77610).Z,width:"2324",height:"1424"})),(0,o.kt)("p",null,(0,o.kt)("strong",{parentName:"p"},"Delay appearance of text in navbar (",(0,o.kt)("a",{parentName:"strong",href:"https://github.com/containers/podman-desktop/pull/767"},"#767"),")")),(0,o.kt)("p",null,"When minimizing or expanding the navbar, the text was overlapping for a few second the page. Now it's displayed with a fading animation."),(0,o.kt)("p",null,(0,o.kt)("strong",{parentName:"p"},"Selected state: better text color contrast (",(0,o.kt)("a",{parentName:"strong",href:"https://github.com/containers/podman-desktop/pull/802"},"#802"),")")),(0,o.kt)("p",null,"In the ",(0,o.kt)("inlineCode",{parentName:"p"},"Images")," page, on hover for both the image and the name column, the text contrast has been increased for better visibility: violet indicates that you have selected it."),(0,o.kt)("p",null,(0,o.kt)("img",{alt:"text color when hover",src:n(65848).Z,width:"800",height:"451"})),(0,o.kt)("p",null,(0,o.kt)("strong",{parentName:"p"},"On Linux and Windows, the menu bar is now hidden by default (",(0,o.kt)("a",{parentName:"strong",href:"https://github.com/containers/podman-desktop/pull/668"},"#668"),")")),(0,o.kt)("p",null,"With this change, the menu bar looks more integrated to the Operating System. The menu can appear if you hit the ",(0,o.kt)("inlineCode",{parentName:"p"},"Alt")," key. Thanks to ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/dylanmtaylor"},"Dylan M. Taylor")," for contributing to fix this."),(0,o.kt)("p",null,(0,o.kt)("strong",{parentName:"p"},"Exit when clicking on the close icon of the dashboard on Linux (",(0,o.kt)("a",{parentName:"strong",href:"https://github.com/containers/podman-desktop/pull/671"},"#671"),")")),(0,o.kt)("p",null,"For most users on Linux, there is no tray icon support. In this situation, when closed, Podman Desktop continues to run in background. ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/dylanmtaylor"},"Dylan M. Taylor")," added a property to exit the app by default when clicking on the close icon. For people having tray icon support or with the desire of a different behavior, it is possible to disable it from the Settings."),(0,o.kt)("hr",null),(0,o.kt)("h2",{id:"other-notable-enhancements"},"Other Notable Enhancements"),(0,o.kt)("ul",null,(0,o.kt)("li",{parentName:"ul"},"Rename ",(0,o.kt)("inlineCode",{parentName:"li"},"Started")," into ",(0,o.kt)("inlineCode",{parentName:"li"},"Age")," in Containers list.(",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/878"},"#878"),")"),(0,o.kt)("li",{parentName:"ul"},"Added domain validation when adding a registry. (",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/838"},"#838"),")"),(0,o.kt)("li",{parentName:"ul"},"Provided a consistent behavior with Podman CLI, ",(0,o.kt)("inlineCode",{parentName:"li"},"podman-machine-default")," is now the default name when creating a Podman machine from Podman Desktop. (",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/775"},"#775"),")")),(0,o.kt)("hr",null),(0,o.kt)("h2",{id:"notable-bug-fixes"},"Notable bug fixes"),(0,o.kt)("ul",null,(0,o.kt)("li",{parentName:"ul"},"Fixed error handling when pulling images of Desktop Extensions. (",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/782"},"#782"),")"),(0,o.kt)("li",{parentName:"ul"},"Fixed use of the full height of the screen when displaying log in the details of a container. (",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/discussions/946"},"#946"),")"),(0,o.kt)("li",{parentName:"ul"},"Fixed First start of Podman Desktop on flatpak was not seeing the podman engine (",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/860"},"#860"),")")),(0,o.kt)("h2",{id:"community-thank-you"},"Community Thank You"),(0,o.kt)("p",null,"\ud83c\udf89 We\u2019d like to say a big thank you to everyone who helped to make Podman Desktop 0.10 even better:"),(0,o.kt)("ul",null,(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("a",{parentName:"li",href:"https://github.com/dylanmtaylor"},"Dylan M. Taylor")," in ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/671"},"#671")),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("a",{parentName:"li",href:"https://github.com/osslate"},"Fionn Kelleher")," in ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/713"},"#713")),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("a",{parentName:"li",href:"https://github.com/rsvoboda"},"Rostislav Svoboda")," in ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/737"},"#737")),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("a",{parentName:"li",href:"https://github.com/shemanaev"},"Denis Shemanaev")," in ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/783"},"#783")),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("a",{parentName:"li",href:"https://github.com/themr0c"},"Fabrice Flore-Th\xe9bault")," in ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/856"},"#856")),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("a",{parentName:"li",href:"https://github.com/KevinAtSesam"},"Kevin")," in ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/864"},"#864")),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("a",{parentName:"li",href:"https://github.com/sfrunza13"},"@sfrunza13")," in ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/872"},"#872")),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("a",{parentName:"li",href:"https://github.com/anjannath"},"Anjan Nath")," in ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/918"},"#918"))),(0,o.kt)("h2",{id:"final-notes"},"Final Notes"),(0,o.kt)("p",null,"The complete list of issues fixed in this release is available ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/issues?q=is%3Aclosed+milestone%3A0.10.0"},"here"),"."),(0,o.kt)("p",null,"Get the latest release from the ",(0,o.kt)("a",{parentName:"p",href:"/downloads"},"Downloads")," section of the website and boost your development journey with Podman Desktop. Additionally, visit the ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop"},"GitHub repository")," and see how you can help us make Podman Desktop better."))}c.isMDXComponent=!0},65747:(e,t,n)=>{n.d(t,{Z:()=>a});const a=n.p+"assets/images/custom-kubeconfig-a1b21477c3bc825c93f8a789292de160.png"},77610:(e,t,n)=>{n.d(t,{Z:()=>a});const a=n.p+"assets/images/kebab-menu-caf501d63e7e0c8a8e957c55093b0f7b.png"},21093:(e,t,n)=>{n.d(t,{Z:()=>a});const a=n.p+"assets/images/new_container_creation_wizard-530d6cccba3d06b5c8db1b9e387a31c7.gif"},96917:(e,t,n)=>{n.d(t,{Z:()=>a});const a=n.p+"assets/images/play_k8s_yaml-3f66f50aa7135e66a436b02c1b278dfc.gif"},63959:(e,t,n)=>{n.d(t,{Z:()=>a});const a=n.p+"assets/images/registries-1194f05e7d35fe4544c74a513d1dc0ed.png"},65848:(e,t,n)=>{n.d(t,{Z:()=>a});const a=n.p+"assets/images/text-color-14e899e089464c8f18a597217045a317.gif"}}]); \ No newline at end of file diff --git a/assets/js/07f59c2a.7bc1a408.js b/assets/js/07f59c2a.7bc1a408.js deleted file mode 100644 index b858bdb7828..00000000000 --- a/assets/js/07f59c2a.7bc1a408.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[9372],{35318:(e,t,n)=>{n.d(t,{Zo:()=>m,kt:()=>h});var a=n(27378);function o(e,t,n){return t in e?Object.defineProperty(e,t,{value:n,enumerable:!0,configurable:!0,writable:!0}):e[t]=n,e}function i(e,t){var n=Object.keys(e);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);t&&(a=a.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),n.push.apply(n,a)}return n}function r(e){for(var t=1;t=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var i=Object.getOwnPropertySymbols(e);for(a=0;a=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var l=a.createContext({}),p=function(e){var t=a.useContext(l),n=t;return e&&(n="function"==typeof e?e(t):r(r({},t),e)),n},m=function(e){var t=p(e.components);return a.createElement(l.Provider,{value:t},e.children)},d={inlineCode:"code",wrapper:function(e){var t=e.children;return a.createElement(a.Fragment,{},t)}},u=a.forwardRef((function(e,t){var n=e.components,o=e.mdxType,i=e.originalType,l=e.parentName,m=s(e,["components","mdxType","originalType","parentName"]),u=p(n),h=o,c=u["".concat(l,".").concat(h)]||u[h]||d[h]||i;return n?a.createElement(c,r(r({ref:t},m),{},{components:n})):a.createElement(c,r({ref:t},m))}));function h(e,t){var n=arguments,o=t&&t.mdxType;if("string"==typeof e||o){var i=n.length,r=new Array(i);r[0]=u;var s={};for(var l in t)hasOwnProperty.call(t,l)&&(s[l]=t[l]);s.originalType=e,s.mdxType="string"==typeof e?e:o,r[1]=s;for(var p=2;p{n.r(t),n.d(t,{assets:()=>l,contentTitle:()=>r,default:()=>d,frontMatter:()=>i,metadata:()=>s,toc:()=>p});var a=n(25773),o=(n(27378),n(35318));const i={title:"Release Notes - Podman Desktop 0.10",description:"Podman Desktop 0.10 has been released! New Create Container Wizard, improved Kubernetes workflows, revamped registries configuration, and more!",slug:"podman-desktop-release-0.10",authors:["deekay2310"],tags:["podman-desktop","release","kubernetes"],hide_table_of_contents:!1},r=void 0,s={permalink:"/blog/podman-desktop-release-0.10",source:"@site/blog/2022-12-01-release-0.10-blog.md",title:"Release Notes - Podman Desktop 0.10",description:"Podman Desktop 0.10 has been released! New Create Container Wizard, improved Kubernetes workflows, revamped registries configuration, and more!",date:"2022-12-01T00:00:00.000Z",formattedDate:"December 1, 2022",tags:[{label:"podman-desktop",permalink:"/blog/tags/podman-desktop"},{label:"release",permalink:"/blog/tags/release"},{label:"kubernetes",permalink:"/blog/tags/kubernetes"}],readingTime:4.115,hasTruncateMarker:!0,authors:[{name:"Dev Kumar",title:"Technical PMM Intern",url:"https://github.com/deekay2310",imageURL:"https://github.com/deekay2310.png",key:"deekay2310"}],frontMatter:{title:"Release Notes - Podman Desktop 0.10",description:"Podman Desktop 0.10 has been released! New Create Container Wizard, improved Kubernetes workflows, revamped registries configuration, and more!",slug:"podman-desktop-release-0.10",authors:["deekay2310"],tags:["podman-desktop","release","kubernetes"],hide_table_of_contents:!1},prevItem:{title:"Release Notes - Podman Desktop 0.11",permalink:"/blog/podman-desktop-release-0.11"},nextItem:{title:"Build & run Podman Desktop in a DevContainer",permalink:"/blog/develop-using-devcontainer"}},l={authorsImageUrls:[void 0]},p=[{value:"Release Details",id:"release-details",level:2},{value:"New configuration wizzard to create containers (#773)",id:"new-configuration-wizzard-to-create-containers-773",level:3},{value:"Kubernetes Capabilities Improvements",id:"kubernetes-capabilities-improvements",level:3},{value:"Revamped Container Registries UI (#446)",id:"revamped-container-registries-ui-446",level:3},{value:"Update to Podman 4.3.1 (#913)",id:"update-to-podman-431-913",level:3},{value:"UI/UX Improvements",id:"uiux-improvements",level:3},{value:"Other Notable Enhancements",id:"other-notable-enhancements",level:2},{value:"Notable bug fixes",id:"notable-bug-fixes",level:2},{value:"Community Thank You",id:"community-thank-you",level:2},{value:"Final Notes",id:"final-notes",level:2}],m={toc:p};function d(e){let{components:t,...i}=e;return(0,o.kt)("wrapper",(0,a.Z)({},m,i,{components:t,mdxType:"MDXLayout"}),(0,o.kt)("p",null,"This release note covers Podman Desktop 0.10 release changes."),(0,o.kt)("ul",null,(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("strong",{parentName:"li"},"Containers Configuration"),": Container creation wizzard allowing to define environment variables, networking and more configuration options."),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("strong",{parentName:"li"},"Kubernetes Improvements"),": Play Kubernetes YAML, custom Kubeconfig path support, reload of kube context."),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("strong",{parentName:"li"},"Registries Configuration"),": Revamped registries configuration UI."),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("strong",{parentName:"li"},"Podman Version"),": Podman 4.3.1 now included in Windows and Mac installers."),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("strong",{parentName:"li"},"UX/UI Improvements"),": Improved lists, better contrast, and more.")),(0,o.kt)("p",null,"Podman Desktop 0.10 is now available. ",(0,o.kt)("a",{parentName:"p",href:"/downloads"},"Click here to download it"),"!"),(0,o.kt)("hr",null),(0,o.kt)("h2",{id:"release-details"},"Release Details"),(0,o.kt)("h3",{id:"new-configuration-wizzard-to-create-containers-773"},"New configuration wizzard to create containers (",(0,o.kt)("a",{parentName:"h3",href:"https://github.com/containers/podman-desktop/pull/773"},"#773"),")"),(0,o.kt)("p",null,"Until now, we could only specify port binding when building images to start containers. The create container wizzard now includes several options enabling configuring volumes, environment variables, restart policy and settings on networking and security. It is also possible to reuse an existing (and already configured) a network when creating containers."),(0,o.kt)("p",null,(0,o.kt)("img",{alt:"new container creation wizard",src:n(21093).Z,width:"800",height:"465"})),(0,o.kt)("h3",{id:"kubernetes-capabilities-improvements"},"Kubernetes Capabilities Improvements"),(0,o.kt)("p",null,(0,o.kt)("strong",{parentName:"p"},"Custom Kubeconfig file path (",(0,o.kt)("a",{parentName:"strong",href:"https://github.com/containers/podman-desktop/pull/780"},"#780"),")")),(0,o.kt)("p",null,"Kubeconfig path location is now configurable from ",(0,o.kt)("strong",{parentName:"p"},(0,o.kt)("icon",{icon:"fa-solid fa-cog",size:"lg"})," Settings > Preferences > Kubernetes: Kubeconfig")," and can be set to a custom path. By default, Podman Desktop use the path ",(0,o.kt)("inlineCode",{parentName:"p"},"$HOME/.kube/config")," for the Kubeconfig file."),(0,o.kt)("p",null,(0,o.kt)("img",{alt:"custom kubeconfig file path",src:n(65747).Z,width:"2324",height:"1424"})),(0,o.kt)("p",null,(0,o.kt)("strong",{parentName:"p"},"Play Kubernetes YAML from the Pods list (",(0,o.kt)("a",{parentName:"strong",href:"https://github.com/containers/podman-desktop/pull/739"},"#739"),")")),(0,o.kt)("p",null,"Podman Desktop enables to play existing Kubernetes YAML files. This is now available from ",(0,o.kt)("inlineCode",{parentName:"p"},"Play Kubernetes YAML")," button added to the Pods list, in addition to the Containers list."),(0,o.kt)("p",null,(0,o.kt)("img",{alt:"play k8s yaml",src:n(96917).Z,width:"800",height:"500"})),(0,o.kt)("p",null,(0,o.kt)("strong",{parentName:"p"},"Kube context automatically reloaded when updated (",(0,o.kt)("a",{parentName:"strong",href:"https://github.com/containers/podman-desktop/pull/813"},"#813"),")")),(0,o.kt)("p",null,"Any change to the kube context will now be detected by Podman Desktop in its running state. The system tray, allowing to select which Kubernetes environment to work with, will now reload the kube context without restarting Podman Desktop."),(0,o.kt)("h3",{id:"revamped-container-registries-ui-446"},"Revamped Container Registries UI (",(0,o.kt)("a",{parentName:"h3",href:"https://github.com/containers/podman-desktop/issues/446"},"#446"),")"),(0,o.kt)("p",null,"The registries configuration UI has been revamped. Instead of using tiles for displaying the registries, now it uses a list where each registry can be added or edited directly in the list. The kebab menu provides options to edit or remove a registry from the list."),(0,o.kt)("p",null,(0,o.kt)("img",{alt:"registries",src:n(63959).Z,width:"2428",height:"1494"})),(0,o.kt)("h3",{id:"update-to-podman-431-913"},"Update to Podman 4.3.1 (",(0,o.kt)("a",{parentName:"h3",href:"https://github.com/containers/podman-desktop/issues/913"},"#913"),")"),(0,o.kt)("p",null,"Podman Desktop 0.10 is now embedding ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman/releases/tag/v4.3.1"},"Podman 4.3.1")," in Windows and macOS installers."),(0,o.kt)("h3",{id:"uiux-improvements"},"UI/UX Improvements"),(0,o.kt)("p",null,(0,o.kt)("strong",{parentName:"p"},"Improved lists UX (",(0,o.kt)("a",{parentName:"strong",href:"https://github.com/containers/podman-desktop/pull/877"},"#877"),")")),(0,o.kt)("p",null,"To reduce the width used in the lists when displaying all the icons, main actions icons are now always displayed (before it was on hover) and the secondary actions are displayed in a kebab menu. For example Start/Stop and delete are primary actions while open the browser, inspect, generate kube yaml, etc. are secondary options."),(0,o.kt)("p",null,(0,o.kt)("img",{alt:"kebab menu",src:n(77610).Z,width:"2324",height:"1424"})),(0,o.kt)("p",null,(0,o.kt)("strong",{parentName:"p"},"Delay appearance of text in navbar (",(0,o.kt)("a",{parentName:"strong",href:"https://github.com/containers/podman-desktop/pull/767"},"#767"),")")),(0,o.kt)("p",null,"When minimizing or expanding the navbar, the text was overlapping for a few second the page. Now it's displayed with a fading animation."),(0,o.kt)("p",null,(0,o.kt)("strong",{parentName:"p"},"Selected state: better text color contrast (",(0,o.kt)("a",{parentName:"strong",href:"https://github.com/containers/podman-desktop/pull/802"},"#802"),")")),(0,o.kt)("p",null,"In the ",(0,o.kt)("inlineCode",{parentName:"p"},"Images")," page, on hover for both the image and the name column, the text contrast has been increased for better visibility: violet indicates that you have selected it."),(0,o.kt)("p",null,(0,o.kt)("img",{alt:"text color when hover",src:n(65848).Z,width:"800",height:"451"})),(0,o.kt)("p",null,(0,o.kt)("strong",{parentName:"p"},"On Linux and Windows, the menu bar is now hidden by default (",(0,o.kt)("a",{parentName:"strong",href:"https://github.com/containers/podman-desktop/pull/668"},"#668"),")")),(0,o.kt)("p",null,"With this change, the menu bar looks more integrated to the Operating System. The menu can appear if you hit the ",(0,o.kt)("inlineCode",{parentName:"p"},"Alt")," key. Thanks to ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/dylanmtaylor"},"Dylan M. Taylor")," for contributing to fix this."),(0,o.kt)("p",null,(0,o.kt)("strong",{parentName:"p"},"Exit when clicking on the close icon of the dashboard on Linux (",(0,o.kt)("a",{parentName:"strong",href:"https://github.com/containers/podman-desktop/pull/671"},"#671"),")")),(0,o.kt)("p",null,"For most users on Linux, there is no tray icon support. In this situation, when closed, Podman Desktop continues to run in background. ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/dylanmtaylor"},"Dylan M. Taylor")," added a property to exit the app by default when clicking on the close icon. For people having tray icon support or with the desire of a different behavior, it is possible to disable it from the Settings."),(0,o.kt)("hr",null),(0,o.kt)("h2",{id:"other-notable-enhancements"},"Other Notable Enhancements"),(0,o.kt)("ul",null,(0,o.kt)("li",{parentName:"ul"},"Rename ",(0,o.kt)("inlineCode",{parentName:"li"},"Started")," into ",(0,o.kt)("inlineCode",{parentName:"li"},"Age")," in Containers list.(",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/878"},"#878"),")"),(0,o.kt)("li",{parentName:"ul"},"Added domain validation when adding a registry. (",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/838"},"#838"),")"),(0,o.kt)("li",{parentName:"ul"},"Provided a consistent behavior with Podman CLI, ",(0,o.kt)("inlineCode",{parentName:"li"},"podman-machine-default")," is now the default name when creating a Podman machine from Podman Desktop. (",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/775"},"#775"),")")),(0,o.kt)("hr",null),(0,o.kt)("h2",{id:"notable-bug-fixes"},"Notable bug fixes"),(0,o.kt)("ul",null,(0,o.kt)("li",{parentName:"ul"},"Fixed error handling when pulling images of Desktop Extensions. (",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/782"},"#782"),")"),(0,o.kt)("li",{parentName:"ul"},"Fixed use of the full height of the screen when displaying log in the details of a container. (",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/discussions/946"},"#946"),")"),(0,o.kt)("li",{parentName:"ul"},"Fixed First start of Podman Desktop on flatpak was not seeing the podman engine (",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/860"},"#860"),")")),(0,o.kt)("h2",{id:"community-thank-you"},"Community Thank You"),(0,o.kt)("p",null,"\ud83c\udf89 We\u2019d like to say a big thank you to everyone who helped to make Podman Desktop 0.10 even better:"),(0,o.kt)("ul",null,(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("a",{parentName:"li",href:"https://github.com/dylanmtaylor"},"Dylan M. Taylor")," in ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/671"},"#671")),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("a",{parentName:"li",href:"https://github.com/osslate"},"Fionn Kelleher")," in ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/713"},"#713")),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("a",{parentName:"li",href:"https://github.com/rsvoboda"},"Rostislav Svoboda")," in ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/737"},"#737")),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("a",{parentName:"li",href:"https://github.com/shemanaev"},"Denis Shemanaev")," in ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/783"},"#783")),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("a",{parentName:"li",href:"https://github.com/themr0c"},"Fabrice Flore-Th\xe9bault")," in ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/856"},"#856")),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("a",{parentName:"li",href:"https://github.com/KevinAtSesam"},"Kevin")," in ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/864"},"#864")),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("a",{parentName:"li",href:"https://github.com/sfrunza13"},"@sfrunza13")," in ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/872"},"#872")),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("a",{parentName:"li",href:"https://github.com/anjannath"},"Anjan Nath")," in ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/918"},"#918"))),(0,o.kt)("h2",{id:"final-notes"},"Final Notes"),(0,o.kt)("p",null,"The complete list of issues fixed in this release is available ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/issues?q=is%3Aclosed+milestone%3A0.10.0"},"here"),"."),(0,o.kt)("p",null,"Get the latest release from the ",(0,o.kt)("a",{parentName:"p",href:"/downloads"},"Downloads")," section of the website and boost your development journey with Podman Desktop. Additionally, visit the ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop"},"GitHub repository")," and see how you can help us make Podman Desktop better."))}d.isMDXComponent=!0},65747:(e,t,n)=>{n.d(t,{Z:()=>a});const a=n.p+"assets/images/custom-kubeconfig-a1b21477c3bc825c93f8a789292de160.png"},77610:(e,t,n)=>{n.d(t,{Z:()=>a});const a=n.p+"assets/images/kebab-menu-caf501d63e7e0c8a8e957c55093b0f7b.png"},21093:(e,t,n)=>{n.d(t,{Z:()=>a});const a=n.p+"assets/images/new_container_creation_wizard-530d6cccba3d06b5c8db1b9e387a31c7.gif"},96917:(e,t,n)=>{n.d(t,{Z:()=>a});const a=n.p+"assets/images/play_k8s_yaml-3f66f50aa7135e66a436b02c1b278dfc.gif"},63959:(e,t,n)=>{n.d(t,{Z:()=>a});const a=n.p+"assets/images/registries-1194f05e7d35fe4544c74a513d1dc0ed.png"},65848:(e,t,n)=>{n.d(t,{Z:()=>a});const a=n.p+"assets/images/text-color-14e899e089464c8f18a597217045a317.gif"}}]); \ No newline at end of file diff --git a/assets/js/09b168a7.23336dd5.js b/assets/js/09b168a7.23336dd5.js deleted file mode 100644 index 596aef294c0..00000000000 --- a/assets/js/09b168a7.23336dd5.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[9579],{35318:(e,n,t)=>{t.d(n,{Zo:()=>m,kt:()=>p});var i=t(27378);function r(e,n,t){return n in e?Object.defineProperty(e,n,{value:t,enumerable:!0,configurable:!0,writable:!0}):e[n]=t,e}function o(e,n){var t=Object.keys(e);if(Object.getOwnPropertySymbols){var i=Object.getOwnPropertySymbols(e);n&&(i=i.filter((function(n){return Object.getOwnPropertyDescriptor(e,n).enumerable}))),t.push.apply(t,i)}return t}function a(e){for(var n=1;n=0||(r[t]=e[t]);return r}(e,n);if(Object.getOwnPropertySymbols){var o=Object.getOwnPropertySymbols(e);for(i=0;i=0||Object.prototype.propertyIsEnumerable.call(e,t)&&(r[t]=e[t])}return r}var s=i.createContext({}),l=function(e){var n=i.useContext(s),t=n;return e&&(t="function"==typeof e?e(n):a(a({},n),e)),t},m=function(e){var n=l(e.components);return i.createElement(s.Provider,{value:n},e.children)},k={inlineCode:"code",wrapper:function(e){var n=e.children;return i.createElement(i.Fragment,{},n)}},c=i.forwardRef((function(e,n){var t=e.components,r=e.mdxType,o=e.originalType,s=e.parentName,m=u(e,["components","mdxType","originalType","parentName"]),c=l(t),p=r,d=c["".concat(s,".").concat(p)]||c[p]||k[p]||o;return t?i.createElement(d,a(a({ref:n},m),{},{components:t})):i.createElement(d,a({ref:n},m))}));function p(e,n){var t=arguments,r=n&&n.mdxType;if("string"==typeof e||r){var o=t.length,a=new Array(o);a[0]=c;var u={};for(var s in n)hasOwnProperty.call(n,s)&&(u[s]=n[s]);u.originalType=e,u.mdxType="string"==typeof e?e:r,a[1]=u;for(var l=2;l{t.r(n),t.d(n,{assets:()=>s,contentTitle:()=>a,default:()=>k,frontMatter:()=>o,metadata:()=>u,toc:()=>l});var i=t(25773),r=(t(27378),t(35318));const o={sidebar_position:80,title:"Minikube",description:"Minikube is one way to get Kubernetes running on your workstation.",keywords:["podman desktop","podman","containers","migrating","kubernetes","minikube"],tags:["migrating-to-kubernetes","minikube"]},a="Running Kubernetes on your workstation with Minikube and Podman",u={unversionedId:"minikube/index",id:"minikube/index",title:"Minikube",description:"Minikube is one way to get Kubernetes running on your workstation.",source:"@site/docs/minikube/index.md",sourceDirName:"minikube",slug:"/minikube/",permalink:"/docs/minikube/",draft:!1,editUrl:"https://github.com/containers/podman-desktop/tree/main/website/docs/minikube/index.md",tags:[{label:"migrating-to-kubernetes",permalink:"/docs/tags/migrating-to-kubernetes"},{label:"minikube",permalink:"/docs/tags/minikube"}],version:"current",sidebarPosition:80,frontMatter:{sidebar_position:80,title:"Minikube",description:"Minikube is one way to get Kubernetes running on your workstation.",keywords:["podman desktop","podman","containers","migrating","kubernetes","minikube"],tags:["migrating-to-kubernetes","minikube"]},sidebar:"mySidebar",previous:{title:"Push an image to Kind",permalink:"/docs/kind/pushing-an-image-to-kind"},next:{title:"Installing the `minikube` CLI",permalink:"/docs/minikube/installing"}},s={},l=[{value:"Procedure",id:"procedure",level:4},{value:"Next steps",id:"next-steps",level:4}],m={toc:l};function k(e){let{components:n,...t}=e;return(0,r.kt)("wrapper",(0,i.Z)({},m,t,{components:n,mdxType:"MDXLayout"}),(0,r.kt)("h1",{id:"running-kubernetes-on-your-workstation-with-minikube-and-podman"},"Running Kubernetes on your workstation with Minikube and Podman"),(0,r.kt)("p",null,"Podman Desktop can help you run ",(0,r.kt)("a",{parentName:"p",href:"https://minikube.sigs.k8s.io/"},"Minikube-powered")," local Kubernetes clusters on a container engine, such as Podman."),(0,r.kt)("h4",{id:"procedure"},"Procedure"),(0,r.kt)("ol",null,(0,r.kt)("li",{parentName:"ol"},"Go to ",(0,r.kt)("strong",{parentName:"li"},(0,r.kt)("icon",{icon:"fa-solid fa-cog",size:"lg"})," Settings > Extensions"),"."),(0,r.kt)("li",{parentName:"ol"},"Install the ",(0,r.kt)("em",{parentName:"li"},"Minikube")," extension:",(0,r.kt)("ol",{parentName:"li"},(0,r.kt)("li",{parentName:"ol"},"Go to ",(0,r.kt)("strong",{parentName:"li"},"Install a new extension from OCI Image")),(0,r.kt)("li",{parentName:"ol"},"Enter the ",(0,r.kt)("strong",{parentName:"li"},"Name of the Image"),": ",(0,r.kt)("inlineCode",{parentName:"li"},"ghcr.io/containers/podman-desktop-extension-minikube")),(0,r.kt)("li",{parentName:"ol"},"Click ",(0,r.kt)("strong",{parentName:"li"},(0,r.kt)("icon",{icon:"fa-solid fa-download",size:"lg"})," Install extension from the OCI image")))),(0,r.kt)("li",{parentName:"ol"},(0,r.kt)("a",{parentName:"li",href:"/docs/minikube/installing"},"Install the ",(0,r.kt)("inlineCode",{parentName:"a"},"minikube")," CLI"),"."),(0,r.kt)("li",{parentName:"ol"},(0,r.kt)("a",{parentName:"li",href:"/docs/minikube/configuring-podman-for-minikube-on-windows"},"On Windows, configure Podman in rootful mode"),"."),(0,r.kt)("li",{parentName:"ol"},(0,r.kt)("a",{parentName:"li",href:"/docs/minikube/creating-a-minikube-cluster"},"Create a Minikube cluster"),".")),(0,r.kt)("h4",{id:"next-steps"},"Next steps"),(0,r.kt)("ol",null,(0,r.kt)("li",{parentName:"ol"},(0,r.kt)("a",{parentName:"li",href:"/docs/minikube/working-with-your-local-minikube-cluster"},"Set your Kubernetes context to your Minikube cluster"),"."),(0,r.kt)("li",{parentName:"ol"},(0,r.kt)("a",{parentName:"li",href:"/docs/minikube/building-an-image-and-testing-it-in-minikube"},"Build an image and test it in Minikube"),"."),(0,r.kt)("li",{parentName:"ol"},(0,r.kt)("a",{parentName:"li",href:"/docs/minikube/pushing-an-image-to-minikube"},"Push an image to Minikube"),"."),(0,r.kt)("li",{parentName:"ol"},(0,r.kt)("a",{parentName:"li",href:"/docs/minikube/restarting-your-minikube-cluster"},"Restart your Minikube cluster"),"."),(0,r.kt)("li",{parentName:"ol"},(0,r.kt)("a",{parentName:"li",href:"/docs/minikube/deleting-your-minikube-cluster"},"Delete your Minikube cluster"),".")))}k.isMDXComponent=!0}}]); \ No newline at end of file diff --git a/assets/js/09b168a7.b8dde927.js b/assets/js/09b168a7.b8dde927.js new file mode 100644 index 00000000000..b5c845d5a78 --- /dev/null +++ b/assets/js/09b168a7.b8dde927.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[9579],{35318:(e,n,t)=>{t.d(n,{Zo:()=>m,kt:()=>k});var i=t(27378);function r(e,n,t){return n in e?Object.defineProperty(e,n,{value:t,enumerable:!0,configurable:!0,writable:!0}):e[n]=t,e}function o(e,n){var t=Object.keys(e);if(Object.getOwnPropertySymbols){var i=Object.getOwnPropertySymbols(e);n&&(i=i.filter((function(n){return Object.getOwnPropertyDescriptor(e,n).enumerable}))),t.push.apply(t,i)}return t}function a(e){for(var n=1;n=0||(r[t]=e[t]);return r}(e,n);if(Object.getOwnPropertySymbols){var o=Object.getOwnPropertySymbols(e);for(i=0;i=0||Object.prototype.propertyIsEnumerable.call(e,t)&&(r[t]=e[t])}return r}var u=i.createContext({}),l=function(e){var n=i.useContext(u),t=n;return e&&(t="function"==typeof e?e(n):a(a({},n),e)),t},m=function(e){var n=l(e.components);return i.createElement(u.Provider,{value:n},e.children)},p={inlineCode:"code",wrapper:function(e){var n=e.children;return i.createElement(i.Fragment,{},n)}},c=i.forwardRef((function(e,n){var t=e.components,r=e.mdxType,o=e.originalType,u=e.parentName,m=s(e,["components","mdxType","originalType","parentName"]),c=l(t),k=r,d=c["".concat(u,".").concat(k)]||c[k]||p[k]||o;return t?i.createElement(d,a(a({ref:n},m),{},{components:t})):i.createElement(d,a({ref:n},m))}));function k(e,n){var t=arguments,r=n&&n.mdxType;if("string"==typeof e||r){var o=t.length,a=new Array(o);a[0]=c;var s={};for(var u in n)hasOwnProperty.call(n,u)&&(s[u]=n[u]);s.originalType=e,s.mdxType="string"==typeof e?e:r,a[1]=s;for(var l=2;l{t.r(n),t.d(n,{assets:()=>u,contentTitle:()=>a,default:()=>k,frontMatter:()=>o,metadata:()=>s,toc:()=>l});var i=t(25773),r=(t(27378),t(35318));const o={sidebar_position:80,title:"Minikube",description:"Minikube is one way to get Kubernetes running on your workstation.",keywords:["podman desktop","podman","containers","migrating","kubernetes","minikube"],tags:["migrating-to-kubernetes","minikube"]},a="Running Kubernetes on your workstation with Minikube and Podman",s={unversionedId:"minikube/index",id:"minikube/index",title:"Minikube",description:"Minikube is one way to get Kubernetes running on your workstation.",source:"@site/docs/minikube/index.md",sourceDirName:"minikube",slug:"/minikube/",permalink:"/docs/minikube/",draft:!1,editUrl:"https://github.com/containers/podman-desktop/tree/main/website/docs/minikube/index.md",tags:[{label:"migrating-to-kubernetes",permalink:"/docs/tags/migrating-to-kubernetes"},{label:"minikube",permalink:"/docs/tags/minikube"}],version:"current",sidebarPosition:80,frontMatter:{sidebar_position:80,title:"Minikube",description:"Minikube is one way to get Kubernetes running on your workstation.",keywords:["podman desktop","podman","containers","migrating","kubernetes","minikube"],tags:["migrating-to-kubernetes","minikube"]},sidebar:"mySidebar",previous:{title:"Push an image to Kind",permalink:"/docs/kind/pushing-an-image-to-kind"},next:{title:"Installing the `minikube` CLI",permalink:"/docs/minikube/installing"}},u={},l=[{value:"Procedure",id:"procedure",level:4},{value:"Next steps",id:"next-steps",level:4}],m=(p="Icon",function(e){return console.warn("Component "+p+" was not imported, exported, or provided by MDXProvider as global scope"),(0,r.kt)("div",e)});var p;const c={toc:l};function k(e){let{components:n,...t}=e;return(0,r.kt)("wrapper",(0,i.Z)({},c,t,{components:n,mdxType:"MDXLayout"}),(0,r.kt)("h1",{id:"running-kubernetes-on-your-workstation-with-minikube-and-podman"},"Running Kubernetes on your workstation with Minikube and Podman"),(0,r.kt)("p",null,"Podman Desktop can help you run ",(0,r.kt)("a",{parentName:"p",href:"https://minikube.sigs.k8s.io/"},"Minikube-powered")," local Kubernetes clusters on a container engine, such as Podman."),(0,r.kt)("h4",{id:"procedure"},"Procedure"),(0,r.kt)("ol",null,(0,r.kt)("li",{parentName:"ol"},"Go to ",(0,r.kt)("strong",{parentName:"li"},(0,r.kt)(m,{icon:"fa-solid fa-cog",size:"lg",mdxType:"Icon"})," Settings > Extensions"),"."),(0,r.kt)("li",{parentName:"ol"},"Install the ",(0,r.kt)("em",{parentName:"li"},"Minikube")," extension:",(0,r.kt)("ol",{parentName:"li"},(0,r.kt)("li",{parentName:"ol"},"Go to ",(0,r.kt)("strong",{parentName:"li"},"Install a new extension from OCI Image")),(0,r.kt)("li",{parentName:"ol"},"Enter the ",(0,r.kt)("strong",{parentName:"li"},"Name of the Image"),": ",(0,r.kt)("inlineCode",{parentName:"li"},"ghcr.io/containers/podman-desktop-extension-minikube")),(0,r.kt)("li",{parentName:"ol"},"Click ",(0,r.kt)("strong",{parentName:"li"},(0,r.kt)(m,{icon:"fa-solid fa-download",size:"lg",mdxType:"Icon"})," Install extension from the OCI image")))),(0,r.kt)("li",{parentName:"ol"},(0,r.kt)("a",{parentName:"li",href:"/docs/minikube/installing"},"Install the ",(0,r.kt)("inlineCode",{parentName:"a"},"minikube")," CLI"),"."),(0,r.kt)("li",{parentName:"ol"},(0,r.kt)("a",{parentName:"li",href:"/docs/minikube/configuring-podman-for-minikube-on-windows"},"On Windows, configure Podman in rootful mode"),"."),(0,r.kt)("li",{parentName:"ol"},(0,r.kt)("a",{parentName:"li",href:"/docs/minikube/creating-a-minikube-cluster"},"Create a Minikube cluster"),".")),(0,r.kt)("h4",{id:"next-steps"},"Next steps"),(0,r.kt)("ol",null,(0,r.kt)("li",{parentName:"ol"},(0,r.kt)("a",{parentName:"li",href:"/docs/minikube/working-with-your-local-minikube-cluster"},"Set your Kubernetes context to your Minikube cluster"),"."),(0,r.kt)("li",{parentName:"ol"},(0,r.kt)("a",{parentName:"li",href:"/docs/minikube/building-an-image-and-testing-it-in-minikube"},"Build an image and test it in Minikube"),"."),(0,r.kt)("li",{parentName:"ol"},(0,r.kt)("a",{parentName:"li",href:"/docs/minikube/pushing-an-image-to-minikube"},"Push an image to Minikube"),"."),(0,r.kt)("li",{parentName:"ol"},(0,r.kt)("a",{parentName:"li",href:"/docs/minikube/restarting-your-minikube-cluster"},"Restart your Minikube cluster"),"."),(0,r.kt)("li",{parentName:"ol"},(0,r.kt)("a",{parentName:"li",href:"/docs/minikube/deleting-your-minikube-cluster"},"Delete your Minikube cluster"),".")))}k.isMDXComponent=!0}}]); \ No newline at end of file diff --git a/assets/js/10ce918d.31bdb7d6.js b/assets/js/10ce918d.31bdb7d6.js new file mode 100644 index 00000000000..10e66b87118 --- /dev/null +++ b/assets/js/10ce918d.31bdb7d6.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[7918],{35318:(e,t,a)=>{a.d(t,{Zo:()=>m,kt:()=>u});var n=a(27378);function r(e,t,a){return t in e?Object.defineProperty(e,t,{value:a,enumerable:!0,configurable:!0,writable:!0}):e[t]=a,e}function i(e,t){var a=Object.keys(e);if(Object.getOwnPropertySymbols){var n=Object.getOwnPropertySymbols(e);t&&(n=n.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),a.push.apply(a,n)}return a}function o(e){for(var t=1;t=0||(r[a]=e[a]);return r}(e,t);if(Object.getOwnPropertySymbols){var i=Object.getOwnPropertySymbols(e);for(n=0;n=0||Object.prototype.propertyIsEnumerable.call(e,a)&&(r[a]=e[a])}return r}var s=n.createContext({}),c=function(e){var t=n.useContext(s),a=t;return e&&(a="function"==typeof e?e(t):o(o({},t),e)),a},m=function(e){var t=c(e.components);return n.createElement(s.Provider,{value:t},e.children)},p={inlineCode:"code",wrapper:function(e){var t=e.children;return n.createElement(n.Fragment,{},t)}},d=n.forwardRef((function(e,t){var a=e.components,r=e.mdxType,i=e.originalType,s=e.parentName,m=l(e,["components","mdxType","originalType","parentName"]),d=c(a),u=r,k=d["".concat(s,".").concat(u)]||d[u]||p[u]||i;return a?n.createElement(k,o(o({ref:t},m),{},{components:a})):n.createElement(k,o({ref:t},m))}));function u(e,t){var a=arguments,r=t&&t.mdxType;if("string"==typeof e||r){var i=a.length,o=new Array(i);o[0]=d;var l={};for(var s in t)hasOwnProperty.call(t,s)&&(l[s]=t[s]);l.originalType=e,l.mdxType="string"==typeof e?e:r,o[1]=l;for(var c=2;c{a.r(t),a.d(t,{assets:()=>s,contentTitle:()=>o,default:()=>u,frontMatter:()=>i,metadata:()=>l,toc:()=>c});var n=a(25773),r=(a(27378),a(35318));const i={sidebar_position:2,title:"Lima instance for containers",description:"Podman Desktop can assist you to create a custom Lima instance on Linux and macOS.",tags:["podman-desktop","podman","docker","containers","onboarding","linux","macOS"],keywords:["podman desktop","containers","lima","onboarding","linux","macos"]},o="Creating a Lima instance for container workloads with Podman Desktop",l={unversionedId:"lima/creating-a-lima-instance",id:"lima/creating-a-lima-instance",title:"Lima instance for containers",description:"Podman Desktop can assist you to create a custom Lima instance on Linux and macOS.",source:"@site/docs/lima/creating-a-lima-instance.md",sourceDirName:"lima",slug:"/lima/creating-a-lima-instance",permalink:"/docs/lima/creating-a-lima-instance",draft:!1,editUrl:"https://github.com/containers/podman-desktop/tree/main/website/docs/lima/creating-a-lima-instance.md",tags:[{label:"podman-desktop",permalink:"/docs/tags/podman-desktop"},{label:"podman",permalink:"/docs/tags/podman"},{label:"docker",permalink:"/docs/tags/docker"},{label:"containers",permalink:"/docs/tags/containers"},{label:"onboarding",permalink:"/docs/tags/onboarding"},{label:"linux",permalink:"/docs/tags/linux"},{label:"macOS",permalink:"/docs/tags/mac-os"}],version:"current",sidebarPosition:2,frontMatter:{sidebar_position:2,title:"Lima instance for containers",description:"Podman Desktop can assist you to create a custom Lima instance on Linux and macOS.",tags:["podman-desktop","podman","docker","containers","onboarding","linux","macOS"],keywords:["podman desktop","containers","lima","onboarding","linux","macos"]},sidebar:"mySidebar",previous:{title:"Installing the `lima` CLI",permalink:"/docs/lima/installing"},next:{title:"Lima instance for Kubernetes",permalink:"/docs/lima/creating-a-kubernetes-instance"}},s={},c=[{value:"Prerequisites",id:"prerequisites",level:4},{value:"Procedure",id:"procedure",level:4},{value:"Verification",id:"verification",level:4}],m=(p="Icon",function(e){return console.warn("Component "+p+" was not imported, exported, or provided by MDXProvider as global scope"),(0,r.kt)("div",e)});var p;const d={toc:c};function u(e){let{components:t,...i}=e;return(0,r.kt)("wrapper",(0,n.Z)({},d,i,{components:t,mdxType:"MDXLayout"}),(0,r.kt)("h1",{id:"creating-a-lima-instance-for-container-workloads-with-podman-desktop"},"Creating a Lima instance for container workloads with Podman Desktop"),(0,r.kt)("p",null,"To use the Lima provider you need a Lima instance running a Linux virtual machine."),(0,r.kt)("p",null,"In the future, Podman Desktop might be able to create Lima instances."),(0,r.kt)("p",null,"Consider creating a custom Lima instance to:"),(0,r.kt)("ul",null,(0,r.kt)("li",{parentName:"ul"},"Control the assigned resources: CPUs, memory, and disk size."),(0,r.kt)("li",{parentName:"ul"},"Use the rootful connection by default, for example to run Kind.")),(0,r.kt)("h4",{id:"prerequisites"},"Prerequisites"),(0,r.kt)("ol",null,(0,r.kt)("li",{parentName:"ol"},(0,r.kt)("a",{parentName:"li",href:"/docs/lima/installing"},"Install the ",(0,r.kt)("inlineCode",{parentName:"a"},"lima")," CLI"),".")),(0,r.kt)("h4",{id:"procedure"},"Procedure"),(0,r.kt)("ol",null,(0,r.kt)("li",{parentName:"ol"},(0,r.kt)("p",{parentName:"li"},"In a terminal, create the Lima instance."),(0,r.kt)("ul",{parentName:"li"},(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("p",{parentName:"li"},"To create a Lima instance with rootless Podman, use the ",(0,r.kt)("inlineCode",{parentName:"p"},"podman")," template:"),(0,r.kt)("pre",{parentName:"li"},(0,r.kt)("code",{parentName:"pre",className:"language-shell-session"},"$ limactl start --name=podman template://podman\n"))),(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("p",{parentName:"li"},"To create a Lima instance with rootful Podman, use the ",(0,r.kt)("inlineCode",{parentName:"p"},"podman-rootful")," template:"),(0,r.kt)("pre",{parentName:"li"},(0,r.kt)("code",{parentName:"pre",className:"language-shell-session"},"$ limactl start --name=podman template://podman-rootful\n"))),(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("p",{parentName:"li"},"To create an Lima instance with rootless Docker, use the ",(0,r.kt)("inlineCode",{parentName:"p"},"docker")," template:"),(0,r.kt)("pre",{parentName:"li"},(0,r.kt)("code",{parentName:"pre",className:"language-shell-session"},"$ limactl start --name=docker template://docker\n"))),(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("p",{parentName:"li"},"To create an Lima instance with rootful Docker, use the ",(0,r.kt)("inlineCode",{parentName:"p"},"docker-rootful")," template:"),(0,r.kt)("pre",{parentName:"li"},(0,r.kt)("code",{parentName:"pre",className:"language-shell-session"},"$ limactl start --name=docker template://docker-rootful\n"))),(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("p",{parentName:"li"},"To select the number of CPUs, the memory, and the disk size, add the options to the ",(0,r.kt)("inlineCode",{parentName:"p"},"limactl start")," command:"),(0,r.kt)("pre",{parentName:"li"},(0,r.kt)("code",{parentName:"pre",className:"language-shell-session"},"--cpus=2 --memory=2 --disk=50\n"))))),(0,r.kt)("li",{parentName:"ol"},(0,r.kt)("p",{parentName:"li"},"Wait for the instance to start, and restart the Lima extension."),(0,r.kt)("ul",{parentName:"li"},(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("p",{parentName:"li"},"Go to ",(0,r.kt)("strong",{parentName:"p"},(0,r.kt)(m,{icon:"fa-solid fa-cog",size:"lg",mdxType:"Icon"})," Settings > Preferences > Extension: Lima"),", to change the instance name and type."),(0,r.kt)("ul",{parentName:"li"},(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("p",{parentName:"li"},"Podman (default)"),(0,r.kt)("ul",{parentName:"li"},(0,r.kt)("li",{parentName:"ul"},"Type: podman"),(0,r.kt)("li",{parentName:"ul"},"Name: podman\n",(0,r.kt)("img",{alt:"Lima preferences Podman",src:a(8667).Z,width:"602",height:"199"})))),(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("p",{parentName:"li"},"Docker"),(0,r.kt)("ul",{parentName:"li"},(0,r.kt)("li",{parentName:"ul"},"Type: docker"),(0,r.kt)("li",{parentName:"ul"},"Name: docker\n",(0,r.kt)("img",{alt:"Lima preferences Docker",src:a(70134).Z,width:"607",height:"205"})))))),(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("p",{parentName:"li"},"Go to ",(0,r.kt)("strong",{parentName:"p"},(0,r.kt)(m,{icon:"fa-solid fa-cog",size:"lg",mdxType:"Icon"})," Settings > Extensions > Lima"),", to disable and enable the extension after changes."))))),(0,r.kt)("h4",{id:"verification"},"Verification"),(0,r.kt)("ul",null,(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("p",{parentName:"li"},'To verify the connection to a running "podman" instance:'),(0,r.kt)("pre",{parentName:"li"},(0,r.kt)("code",{parentName:"pre",className:"language-shell-session"},"$ podman.lima version\n"))),(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("p",{parentName:"li"},'To verify the connection to a running "docker" instance:'),(0,r.kt)("pre",{parentName:"li"},(0,r.kt)("code",{parentName:"pre",className:"language-shell-session"},"$ docker.lima version\n")))))}u.isMDXComponent=!0},70134:(e,t,a)=>{a.d(t,{Z:()=>n});const n=a.p+"assets/images/lima-preferences-docker-2a17aa75bf2d45cb2850ce869016acea.png"},8667:(e,t,a)=>{a.d(t,{Z:()=>n});const n=a.p+"assets/images/lima-preferences-podman-1bc867f183e9e7cc1eb9bfc1f4e695c1.png"}}]); \ No newline at end of file diff --git a/assets/js/10ce918d.f4a75fd4.js b/assets/js/10ce918d.f4a75fd4.js deleted file mode 100644 index 2a5eb6aa6cf..00000000000 --- a/assets/js/10ce918d.f4a75fd4.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[7918],{35318:(e,t,a)=>{a.d(t,{Zo:()=>m,kt:()=>u});var n=a(27378);function r(e,t,a){return t in e?Object.defineProperty(e,t,{value:a,enumerable:!0,configurable:!0,writable:!0}):e[t]=a,e}function i(e,t){var a=Object.keys(e);if(Object.getOwnPropertySymbols){var n=Object.getOwnPropertySymbols(e);t&&(n=n.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),a.push.apply(a,n)}return a}function o(e){for(var t=1;t=0||(r[a]=e[a]);return r}(e,t);if(Object.getOwnPropertySymbols){var i=Object.getOwnPropertySymbols(e);for(n=0;n=0||Object.prototype.propertyIsEnumerable.call(e,a)&&(r[a]=e[a])}return r}var s=n.createContext({}),c=function(e){var t=n.useContext(s),a=t;return e&&(a="function"==typeof e?e(t):o(o({},t),e)),a},m=function(e){var t=c(e.components);return n.createElement(s.Provider,{value:t},e.children)},p={inlineCode:"code",wrapper:function(e){var t=e.children;return n.createElement(n.Fragment,{},t)}},d=n.forwardRef((function(e,t){var a=e.components,r=e.mdxType,i=e.originalType,s=e.parentName,m=l(e,["components","mdxType","originalType","parentName"]),d=c(a),u=r,k=d["".concat(s,".").concat(u)]||d[u]||p[u]||i;return a?n.createElement(k,o(o({ref:t},m),{},{components:a})):n.createElement(k,o({ref:t},m))}));function u(e,t){var a=arguments,r=t&&t.mdxType;if("string"==typeof e||r){var i=a.length,o=new Array(i);o[0]=d;var l={};for(var s in t)hasOwnProperty.call(t,s)&&(l[s]=t[s]);l.originalType=e,l.mdxType="string"==typeof e?e:r,o[1]=l;for(var c=2;c{a.r(t),a.d(t,{assets:()=>s,contentTitle:()=>o,default:()=>p,frontMatter:()=>i,metadata:()=>l,toc:()=>c});var n=a(25773),r=(a(27378),a(35318));const i={sidebar_position:2,title:"Lima instance for containers",description:"Podman Desktop can assist you to create a custom Lima instance on Linux and macOS.",tags:["podman-desktop","podman","docker","containers","onboarding","linux","macOS"],keywords:["podman desktop","containers","lima","onboarding","linux","macos"]},o="Creating a Lima instance for container workloads with Podman Desktop",l={unversionedId:"lima/creating-a-lima-instance",id:"lima/creating-a-lima-instance",title:"Lima instance for containers",description:"Podman Desktop can assist you to create a custom Lima instance on Linux and macOS.",source:"@site/docs/lima/creating-a-lima-instance.md",sourceDirName:"lima",slug:"/lima/creating-a-lima-instance",permalink:"/docs/lima/creating-a-lima-instance",draft:!1,editUrl:"https://github.com/containers/podman-desktop/tree/main/website/docs/lima/creating-a-lima-instance.md",tags:[{label:"podman-desktop",permalink:"/docs/tags/podman-desktop"},{label:"podman",permalink:"/docs/tags/podman"},{label:"docker",permalink:"/docs/tags/docker"},{label:"containers",permalink:"/docs/tags/containers"},{label:"onboarding",permalink:"/docs/tags/onboarding"},{label:"linux",permalink:"/docs/tags/linux"},{label:"macOS",permalink:"/docs/tags/mac-os"}],version:"current",sidebarPosition:2,frontMatter:{sidebar_position:2,title:"Lima instance for containers",description:"Podman Desktop can assist you to create a custom Lima instance on Linux and macOS.",tags:["podman-desktop","podman","docker","containers","onboarding","linux","macOS"],keywords:["podman desktop","containers","lima","onboarding","linux","macos"]},sidebar:"mySidebar",previous:{title:"Installing the `lima` CLI",permalink:"/docs/lima/installing"},next:{title:"Lima instance for Kubernetes",permalink:"/docs/lima/creating-a-kubernetes-instance"}},s={},c=[{value:"Prerequisites",id:"prerequisites",level:4},{value:"Procedure",id:"procedure",level:4},{value:"Verification",id:"verification",level:4}],m={toc:c};function p(e){let{components:t,...i}=e;return(0,r.kt)("wrapper",(0,n.Z)({},m,i,{components:t,mdxType:"MDXLayout"}),(0,r.kt)("h1",{id:"creating-a-lima-instance-for-container-workloads-with-podman-desktop"},"Creating a Lima instance for container workloads with Podman Desktop"),(0,r.kt)("p",null,"To use the Lima provider you need a Lima instance running a Linux virtual machine."),(0,r.kt)("p",null,"In the future, Podman Desktop might be able to create Lima instances."),(0,r.kt)("p",null,"Consider creating a custom Lima instance to:"),(0,r.kt)("ul",null,(0,r.kt)("li",{parentName:"ul"},"Control the assigned resources: CPUs, memory, and disk size."),(0,r.kt)("li",{parentName:"ul"},"Use the rootful connection by default, for example to run Kind.")),(0,r.kt)("h4",{id:"prerequisites"},"Prerequisites"),(0,r.kt)("ol",null,(0,r.kt)("li",{parentName:"ol"},(0,r.kt)("a",{parentName:"li",href:"/docs/lima/installing"},"Install the ",(0,r.kt)("inlineCode",{parentName:"a"},"lima")," CLI"),".")),(0,r.kt)("h4",{id:"procedure"},"Procedure"),(0,r.kt)("ol",null,(0,r.kt)("li",{parentName:"ol"},(0,r.kt)("p",{parentName:"li"},"In a terminal, create the Lima instance."),(0,r.kt)("ul",{parentName:"li"},(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("p",{parentName:"li"},"To create a Lima instance with rootless Podman, use the ",(0,r.kt)("inlineCode",{parentName:"p"},"podman")," template:"),(0,r.kt)("pre",{parentName:"li"},(0,r.kt)("code",{parentName:"pre",className:"language-shell-session"},"$ limactl start --name=podman template://podman\n"))),(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("p",{parentName:"li"},"To create a Lima instance with rootful Podman, use the ",(0,r.kt)("inlineCode",{parentName:"p"},"podman-rootful")," template:"),(0,r.kt)("pre",{parentName:"li"},(0,r.kt)("code",{parentName:"pre",className:"language-shell-session"},"$ limactl start --name=podman template://podman-rootful\n"))),(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("p",{parentName:"li"},"To create an Lima instance with rootless Docker, use the ",(0,r.kt)("inlineCode",{parentName:"p"},"docker")," template:"),(0,r.kt)("pre",{parentName:"li"},(0,r.kt)("code",{parentName:"pre",className:"language-shell-session"},"$ limactl start --name=docker template://docker\n"))),(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("p",{parentName:"li"},"To create an Lima instance with rootful Docker, use the ",(0,r.kt)("inlineCode",{parentName:"p"},"docker-rootful")," template:"),(0,r.kt)("pre",{parentName:"li"},(0,r.kt)("code",{parentName:"pre",className:"language-shell-session"},"$ limactl start --name=docker template://docker-rootful\n"))),(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("p",{parentName:"li"},"To select the number of CPUs, the memory, and the disk size, add the options to the ",(0,r.kt)("inlineCode",{parentName:"p"},"limactl start")," command:"),(0,r.kt)("pre",{parentName:"li"},(0,r.kt)("code",{parentName:"pre",className:"language-shell-session"},"--cpus=2 --memory=2 --disk=50\n"))))),(0,r.kt)("li",{parentName:"ol"},(0,r.kt)("p",{parentName:"li"},"Wait for the instance to start, and restart the Lima extension."),(0,r.kt)("ul",{parentName:"li"},(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("p",{parentName:"li"},"Go to ",(0,r.kt)("strong",{parentName:"p"},(0,r.kt)("icon",{icon:"fa-solid fa-cog",size:"lg"})," Settings > Preferences > Extension: Lima"),", to change the instance name and type."),(0,r.kt)("ul",{parentName:"li"},(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("p",{parentName:"li"},"Podman (default)"),(0,r.kt)("ul",{parentName:"li"},(0,r.kt)("li",{parentName:"ul"},"Type: podman"),(0,r.kt)("li",{parentName:"ul"},"Name: podman\n",(0,r.kt)("img",{alt:"Lima preferences Podman",src:a(8667).Z,width:"602",height:"199"})))),(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("p",{parentName:"li"},"Docker"),(0,r.kt)("ul",{parentName:"li"},(0,r.kt)("li",{parentName:"ul"},"Type: docker"),(0,r.kt)("li",{parentName:"ul"},"Name: docker\n",(0,r.kt)("img",{alt:"Lima preferences Docker",src:a(70134).Z,width:"607",height:"205"})))))),(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("p",{parentName:"li"},"Go to ",(0,r.kt)("strong",{parentName:"p"},(0,r.kt)("icon",{icon:"fa-solid fa-cog",size:"lg"})," Settings > Extensions > Lima"),", to disable and enable the extension after changes."))))),(0,r.kt)("h4",{id:"verification"},"Verification"),(0,r.kt)("ul",null,(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("p",{parentName:"li"},'To verify the connection to a running "podman" instance:'),(0,r.kt)("pre",{parentName:"li"},(0,r.kt)("code",{parentName:"pre",className:"language-shell-session"},"$ podman.lima version\n"))),(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("p",{parentName:"li"},'To verify the connection to a running "docker" instance:'),(0,r.kt)("pre",{parentName:"li"},(0,r.kt)("code",{parentName:"pre",className:"language-shell-session"},"$ docker.lima version\n")))))}p.isMDXComponent=!0},70134:(e,t,a)=>{a.d(t,{Z:()=>n});const n=a.p+"assets/images/lima-preferences-docker-2a17aa75bf2d45cb2850ce869016acea.png"},8667:(e,t,a)=>{a.d(t,{Z:()=>n});const n=a.p+"assets/images/lima-preferences-podman-1bc867f183e9e7cc1eb9bfc1f4e695c1.png"}}]); \ No newline at end of file diff --git a/assets/js/17896441.1a690c9c.js b/assets/js/17896441.edf3f98f.js similarity index 99% rename from assets/js/17896441.1a690c9c.js rename to assets/js/17896441.edf3f98f.js index 0e77a049bf4..2fb0287e9e4 100644 --- a/assets/js/17896441.1a690c9c.js +++ b/assets/js/17896441.edf3f98f.js @@ -1 +1 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[2339],{87823:(e,t,n)=>{n.r(t),n.d(t,{default:()=>ve});var a=n(27378),l=n(1123),r=n(41763);const s=a.createContext(null);function o(e){let{children:t,content:n}=e;const l=function(e){return(0,a.useMemo)((()=>({metadata:e.metadata,frontMatter:e.frontMatter,assets:e.assets,contentTitle:e.contentTitle,toc:e.toc})),[e])}(n);return a.createElement(s.Provider,{value:l},t)}function c(){const e=(0,a.useContext)(s);if(null===e)throw new r.i6("DocProvider");return e}function i(){const{metadata:e,frontMatter:t,assets:n}=c();return a.createElement(l.d,{title:e.title,description:e.description,keywords:t.keywords,image:n.image??t.image})}var d=n(38944),m=n(58357),u=n(25773),v=n(99213),b=n(14582);function h(e){const{previous:t,next:n}=e;return a.createElement("nav",{className:"pagination-nav docusaurus-mt-lg","aria-label":(0,v.I)({id:"theme.docs.paginator.navAriaLabel",message:"Docs pages",description:"The ARIA label for the docs pagination"})},t&&a.createElement(b.Z,(0,u.Z)({},t,{subLabel:a.createElement(v.Z,{id:"theme.docs.paginator.previous",description:"The label used to navigate to the previous doc"},"Previous")})),n&&a.createElement(b.Z,(0,u.Z)({},n,{subLabel:a.createElement(v.Z,{id:"theme.docs.paginator.next",description:"The label used to navigate to the next doc"},"Next"),isNext:!0})))}function f(){const{metadata:e}=c();return a.createElement(h,{previous:e.previous,next:e.next})}var p=n(50353),E=n(81884),g=n(62935),L=n(75484),N=n(24453),Z=n(25611);const k={unreleased:function(e){let{siteTitle:t,versionMetadata:n}=e;return a.createElement(v.Z,{id:"theme.docs.versions.unreleasedVersionLabel",description:"The label used to tell the user that he's browsing an unreleased doc version",values:{siteTitle:t,versionLabel:a.createElement("b",null,n.label)}},"This is unreleased documentation for {siteTitle} {versionLabel} version.")},unmaintained:function(e){let{siteTitle:t,versionMetadata:n}=e;return a.createElement(v.Z,{id:"theme.docs.versions.unmaintainedVersionLabel",description:"The label used to tell the user that he's browsing an unmaintained doc version",values:{siteTitle:t,versionLabel:a.createElement("b",null,n.label)}},"This is documentation for {siteTitle} {versionLabel}, which is no longer actively maintained.")}};function _(e){const t=k[e.versionMetadata.banner];return a.createElement(t,e)}function C(e){let{versionLabel:t,to:n,onClick:l}=e;return a.createElement(v.Z,{id:"theme.docs.versions.latestVersionSuggestionLabel",description:"The label used to tell the user to check the latest version",values:{versionLabel:t,latestVersionLink:a.createElement("b",null,a.createElement(E.Z,{to:n,onClick:l},a.createElement(v.Z,{id:"theme.docs.versions.latestVersionLinkLabel",description:"The label used for the latest version suggestion link label"},"latest version")))}},"For up-to-date documentation, see the {latestVersionLink} ({versionLabel}).")}function x(e){let{className:t,versionMetadata:n}=e;const{siteConfig:{title:l}}=(0,p.Z)(),{pluginId:r}=(0,g.gA)({failfast:!0}),{savePreferredVersionName:s}=(0,N.J)(r),{latestDocSuggestion:o,latestVersionSuggestion:c}=(0,g.Jo)(r),i=o??(m=c).docs.find((e=>e.id===m.mainDocId));var m;return a.createElement("div",{className:(0,d.Z)(t,L.k.docs.docVersionBanner,"alert alert--warning margin-bottom--md"),role:"alert"},a.createElement("div",null,a.createElement(_,{siteTitle:l,versionMetadata:n})),a.createElement("div",{className:"margin-top--md"},a.createElement(C,{versionLabel:c.label,to:i.path,onClick:()=>s(c.name)})))}function H(e){let{className:t}=e;const n=(0,Z.E)();return n.banner?a.createElement(x,{className:t,versionMetadata:n}):null}function T(e){let{className:t}=e;const n=(0,Z.E)();return n.badge?a.createElement("span",{className:(0,d.Z)(t,L.k.docs.docVersionBadge,"badge badge--secondary")},a.createElement(v.Z,{id:"theme.docs.versionBadge.label",values:{versionLabel:n.label}},"Version: {versionLabel}")):null}function y(e){let{lastUpdatedAt:t,formattedLastUpdatedAt:n}=e;return a.createElement(v.Z,{id:"theme.lastUpdated.atDate",description:"The words used to describe on which date a page has been last updated",values:{date:a.createElement("b",null,a.createElement("time",{dateTime:new Date(1e3*t).toISOString()},n))}}," on {date}")}function U(e){let{lastUpdatedBy:t}=e;return a.createElement(v.Z,{id:"theme.lastUpdated.byUser",description:"The words used to describe by who the page has been last updated",values:{user:a.createElement("b",null,t)}}," by {user}")}function A(e){let{lastUpdatedAt:t,formattedLastUpdatedAt:n,lastUpdatedBy:l}=e;return a.createElement("span",{className:L.k.common.lastUpdated},a.createElement(v.Z,{id:"theme.lastUpdated.lastUpdatedAtBy",description:"The sentence used to display when a page has been last updated, and by who",values:{atDate:t&&n?a.createElement(y,{lastUpdatedAt:t,formattedLastUpdatedAt:n}):"",byUser:l?a.createElement(U,{lastUpdatedBy:l}):""}},"Last updated{atDate}{byUser}"),!1)}var w=n(34565),M=n(28349);const B="lastUpdated_pbO5";function I(e){return a.createElement("div",{className:(0,d.Z)(L.k.docs.docFooterTagsRow,"row margin-bottom--sm")},a.createElement("div",{className:"col"},a.createElement(M.Z,e)))}function O(e){let{editUrl:t,lastUpdatedAt:n,lastUpdatedBy:l,formattedLastUpdatedAt:r}=e;return a.createElement("div",{className:(0,d.Z)(L.k.docs.docFooterEditMetaRow,"row")},a.createElement("div",{className:"col"},t&&a.createElement(w.Z,{editUrl:t})),a.createElement("div",{className:(0,d.Z)("col",B)},(n||l)&&a.createElement(A,{lastUpdatedAt:n,formattedLastUpdatedAt:r,lastUpdatedBy:l})))}function S(){const{metadata:e}=c(),{editUrl:t,lastUpdatedAt:n,formattedLastUpdatedAt:l,lastUpdatedBy:r,tags:s}=e,o=s.length>0,i=!!(t||n||r);return o||i?a.createElement("footer",{className:(0,d.Z)(L.k.docs.docFooter,"docusaurus-mt-lg")},o&&a.createElement(I,{tags:s}),i&&a.createElement(O,{editUrl:t,lastUpdatedAt:n,lastUpdatedBy:r,formattedLastUpdatedAt:l})):null}var V=n(80376),P=n(36033);const R="tocCollapsibleButton_iI2p",D="tocCollapsibleButtonExpanded_cHjC";function F(e){let{collapsed:t,...n}=e;return a.createElement("button",(0,u.Z)({type:"button"},n,{className:(0,d.Z)("clean-btn",R,!t&&D,n.className)}),a.createElement(v.Z,{id:"theme.TOCCollapsible.toggleButtonLabel",description:"The label used by the button on the collapsible TOC component"},"On this page"))}const z="tocCollapsible_wXna",j="tocCollapsibleContent_vea0",$="tocCollapsibleExpanded_BbRn";function q(e){let{toc:t,className:n,minHeadingLevel:l,maxHeadingLevel:r}=e;const{collapsed:s,toggleCollapsed:o}=(0,V.u)({initialState:!0});return a.createElement("div",{className:(0,d.Z)(z,!s&&$,n)},a.createElement(F,{collapsed:s,onClick:o}),a.createElement(V.z,{lazy:!0,className:j,collapsed:s},a.createElement(P.Z,{toc:t,minHeadingLevel:l,maxHeadingLevel:r})))}const G="tocMobile_Ojys";function X(){const{toc:e,frontMatter:t}=c();return a.createElement(q,{toc:e,minHeadingLevel:t.toc_min_heading_level,maxHeadingLevel:t.toc_max_heading_level,className:(0,d.Z)(L.k.docs.docTocMobile,G)})}var J=n(17061);function Q(){const{toc:e,frontMatter:t}=c();return a.createElement(J.Z,{toc:e,minHeadingLevel:t.toc_min_heading_level,maxHeadingLevel:t.toc_max_heading_level,className:L.k.docs.docTocDesktop})}var K=n(1999),W=n(40450);function Y(e){let{children:t}=e;const n=function(){const{metadata:e,frontMatter:t,contentTitle:n}=c();return t.hide_title||void 0!==n?null:e.title}();return a.createElement("div",{className:(0,d.Z)(L.k.docs.docMarkdown,"markdown")},n&&a.createElement("header",null,a.createElement(K.Z,{as:"h1"},n)),a.createElement(W.Z,null,t))}var ee=n(45161),te=n(8862),ne=n(98948);function ae(e){return a.createElement("svg",(0,u.Z)({viewBox:"0 0 24 24"},e),a.createElement("path",{d:"M10 19v-5h4v5c0 .55.45 1 1 1h3c.55 0 1-.45 1-1v-7h1.7c.46 0 .68-.57.33-.87L12.67 3.6c-.38-.34-.96-.34-1.34 0l-8.36 7.53c-.34.3-.13.87.33.87H5v7c0 .55.45 1 1 1h3c.55 0 1-.45 1-1z",fill:"currentColor"}))}const le="breadcrumbHomeIcon_sfvy";function re(){const e=(0,ne.Z)("/");return a.createElement("li",{className:"breadcrumbs__item"},a.createElement(E.Z,{"aria-label":(0,v.I)({id:"theme.docs.breadcrumbs.home",message:"Home page",description:"The ARIA label for the home page in the breadcrumbs"}),className:"breadcrumbs__link",href:e},a.createElement(ae,{className:le})))}const se="breadcrumbsContainer_T5ub";function oe(e){let{children:t,href:n,isLast:l}=e;const r="breadcrumbs__link";return l?a.createElement("span",{className:r,itemProp:"name"},t):n?a.createElement(E.Z,{className:r,href:n,itemProp:"item"},a.createElement("span",{itemProp:"name"},t)):a.createElement("span",{className:r},t)}function ce(e){let{children:t,active:n,index:l,addMicrodata:r}=e;return a.createElement("li",(0,u.Z)({},r&&{itemScope:!0,itemProp:"itemListElement",itemType:"https://schema.org/ListItem"},{className:(0,d.Z)("breadcrumbs__item",{"breadcrumbs__item--active":n})}),t,a.createElement("meta",{itemProp:"position",content:String(l+1)}))}function ie(){const e=(0,ee.s1)(),t=(0,te.Ns)();return e?a.createElement("nav",{className:(0,d.Z)(L.k.docs.docBreadcrumbs,se),"aria-label":(0,v.I)({id:"theme.docs.breadcrumbs.navAriaLabel",message:"Breadcrumbs",description:"The ARIA label for the breadcrumbs"})},a.createElement("ul",{className:"breadcrumbs",itemScope:!0,itemType:"https://schema.org/BreadcrumbList"},t&&a.createElement(re,null),e.map(((t,n)=>{const l=n===e.length-1;return a.createElement(ce,{key:n,active:l,index:n,addMicrodata:!!t.href},a.createElement(oe,{href:t.href,isLast:l},t.label))})))):null}const de="docItemContainer_tjFy",me="docItemCol_Qr34";function ue(e){let{children:t}=e;const n=function(){const{frontMatter:e,toc:t}=c(),n=(0,m.i)(),l=e.hide_table_of_contents,r=!l&&t.length>0;return{hidden:l,mobile:r?a.createElement(X,null):void 0,desktop:!r||"desktop"!==n&&"ssr"!==n?void 0:a.createElement(Q,null)}}();return a.createElement("div",{className:"row"},a.createElement("div",{className:(0,d.Z)("col",!n.hidden&&me)},a.createElement(H,null),a.createElement("div",{className:de},a.createElement("article",null,a.createElement(ie,null),a.createElement(T,null),n.mobile,a.createElement(Y,null,t),a.createElement(S,null)),a.createElement(f,null))),n.desktop&&a.createElement("div",{className:"col col--3"},n.desktop))}function ve(e){const t=`docs-doc-id-${e.content.metadata.unversionedId}`,n=e.content;return a.createElement(o,{content:e.content},a.createElement(l.FG,{className:t},a.createElement(i,null),a.createElement(ue,null,a.createElement(n,null))))}},17061:(e,t,n)=>{n.d(t,{Z:()=>c});var a=n(25773),l=n(27378),r=n(38944),s=n(36033);const o="tableOfContents_XG6w";function c(e){let{className:t,...n}=e;return l.createElement("div",{className:(0,r.Z)(o,"thin-scrollbar",t)},l.createElement(s.Z,(0,a.Z)({},n,{linkClassName:"table-of-contents__link toc-highlight",linkActiveClassName:"table-of-contents__link--active"})))}},36033:(e,t,n)=>{n.d(t,{Z:()=>b});var a=n(25773),l=n(27378),r=n(20624);function s(e){const t=e.map((e=>({...e,parentIndex:-1,children:[]}))),n=Array(7).fill(-1);t.forEach(((e,t)=>{const a=n.slice(2,e.level);e.parentIndex=Math.max(...a),n[e.level]=t}));const a=[];return t.forEach((e=>{const{parentIndex:n,...l}=e;n>=0?t[n].children.push(l):a.push(l)})),a}function o(e){let{toc:t,minHeadingLevel:n,maxHeadingLevel:a}=e;return t.flatMap((e=>{const t=o({toc:e.children,minHeadingLevel:n,maxHeadingLevel:a});return function(e){return e.level>=n&&e.level<=a}(e)?[{...e,children:t}]:t}))}function c(e){const t=e.getBoundingClientRect();return t.top===t.bottom?c(e.parentNode):t}function i(e,t){let{anchorTopOffset:n}=t;const a=e.find((e=>c(e).top>=n));if(a){return function(e){return e.top>0&&e.bottom{e.current=t?0:document.querySelector(".navbar").clientHeight}),[t]),e}function m(e){const t=(0,l.useRef)(void 0),n=d();(0,l.useEffect)((()=>{if(!e)return()=>{};const{linkClassName:a,linkActiveClassName:l,minHeadingLevel:r,maxHeadingLevel:s}=e;function o(){const e=function(e){return Array.from(document.getElementsByClassName(e))}(a),o=function(e){let{minHeadingLevel:t,maxHeadingLevel:n}=e;const a=[];for(let l=t;l<=n;l+=1)a.push(`h${l}.anchor`);return Array.from(document.querySelectorAll(a.join()))}({minHeadingLevel:r,maxHeadingLevel:s}),c=i(o,{anchorTopOffset:n.current}),d=e.find((e=>c&&c.id===function(e){return decodeURIComponent(e.href.substring(e.href.indexOf("#")+1))}(e)));e.forEach((e=>{!function(e,n){n?(t.current&&t.current!==e&&t.current.classList.remove(l),e.classList.add(l),t.current=e):e.classList.remove(l)}(e,e===d)}))}return document.addEventListener("scroll",o),document.addEventListener("resize",o),o(),()=>{document.removeEventListener("scroll",o),document.removeEventListener("resize",o)}}),[e,n])}function u(e){let{toc:t,className:n,linkClassName:a,isChild:r}=e;return t.length?l.createElement("ul",{className:r?void 0:n},t.map((e=>l.createElement("li",{key:e.id},l.createElement("a",{href:`#${e.id}`,className:a??void 0,dangerouslySetInnerHTML:{__html:e.value}}),l.createElement(u,{isChild:!0,toc:e.children,className:n,linkClassName:a}))))):null}const v=l.memo(u);function b(e){let{toc:t,className:n="table-of-contents table-of-contents__left-border",linkClassName:c="table-of-contents__link",linkActiveClassName:i,minHeadingLevel:d,maxHeadingLevel:u,...b}=e;const h=(0,r.L)(),f=d??h.tableOfContents.minHeadingLevel,p=u??h.tableOfContents.maxHeadingLevel,E=function(e){let{toc:t,minHeadingLevel:n,maxHeadingLevel:a}=e;return(0,l.useMemo)((()=>o({toc:s(t),minHeadingLevel:n,maxHeadingLevel:a})),[t,n,a])}({toc:t,minHeadingLevel:f,maxHeadingLevel:p});return m((0,l.useMemo)((()=>{if(c&&i)return{linkClassName:c,linkActiveClassName:i,minHeadingLevel:f,maxHeadingLevel:p}}),[c,i,f,p])),l.createElement(v,(0,a.Z)({toc:E,className:n,linkClassName:c},b))}},25611:(e,t,n)=>{n.d(t,{E:()=>o,q:()=>s});var a=n(27378),l=n(41763);const r=a.createContext(null);function s(e){let{children:t,version:n}=e;return a.createElement(r.Provider,{value:n},t)}function o(){const e=(0,a.useContext)(r);if(null===e)throw new l.i6("DocsVersionProvider");return e}},85978:(e,t,n)=>{n.d(t,{Z:()=>r});var a=n(27378),l=n(10610);function r(e){const t={...e};return t?.code?.length>2&&("$ "===t.code.substring(0,2)||"# "===t.code.substring(0,2)||"> "===t.code.substring(0,2))&&(t.code=t.code.substring(2)),a.createElement(a.Fragment,null,a.createElement(l.Z,t))}},35654:(e,t,n)=>{n.d(t,{Z:()=>c});var a=n(80256),l=n(92739),r=n(30537),s=n(9928),o=n(19374);r.vI.add(s.vnX,o.mRB);const c={...a.Z,icon:l.G}}}]); \ No newline at end of file +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[2339],{87823:(e,t,n)=>{n.r(t),n.d(t,{default:()=>ve});var a=n(27378),l=n(1123),r=n(41763);const s=a.createContext(null);function o(e){let{children:t,content:n}=e;const l=function(e){return(0,a.useMemo)((()=>({metadata:e.metadata,frontMatter:e.frontMatter,assets:e.assets,contentTitle:e.contentTitle,toc:e.toc})),[e])}(n);return a.createElement(s.Provider,{value:l},t)}function c(){const e=(0,a.useContext)(s);if(null===e)throw new r.i6("DocProvider");return e}function i(){const{metadata:e,frontMatter:t,assets:n}=c();return a.createElement(l.d,{title:e.title,description:e.description,keywords:t.keywords,image:n.image??t.image})}var d=n(38944),m=n(58357),u=n(25773),v=n(99213),b=n(14582);function h(e){const{previous:t,next:n}=e;return a.createElement("nav",{className:"pagination-nav docusaurus-mt-lg","aria-label":(0,v.I)({id:"theme.docs.paginator.navAriaLabel",message:"Docs pages",description:"The ARIA label for the docs pagination"})},t&&a.createElement(b.Z,(0,u.Z)({},t,{subLabel:a.createElement(v.Z,{id:"theme.docs.paginator.previous",description:"The label used to navigate to the previous doc"},"Previous")})),n&&a.createElement(b.Z,(0,u.Z)({},n,{subLabel:a.createElement(v.Z,{id:"theme.docs.paginator.next",description:"The label used to navigate to the next doc"},"Next"),isNext:!0})))}function f(){const{metadata:e}=c();return a.createElement(h,{previous:e.previous,next:e.next})}var p=n(50353),E=n(81884),g=n(62935),L=n(75484),N=n(24453),Z=n(25611);const k={unreleased:function(e){let{siteTitle:t,versionMetadata:n}=e;return a.createElement(v.Z,{id:"theme.docs.versions.unreleasedVersionLabel",description:"The label used to tell the user that he's browsing an unreleased doc version",values:{siteTitle:t,versionLabel:a.createElement("b",null,n.label)}},"This is unreleased documentation for {siteTitle} {versionLabel} version.")},unmaintained:function(e){let{siteTitle:t,versionMetadata:n}=e;return a.createElement(v.Z,{id:"theme.docs.versions.unmaintainedVersionLabel",description:"The label used to tell the user that he's browsing an unmaintained doc version",values:{siteTitle:t,versionLabel:a.createElement("b",null,n.label)}},"This is documentation for {siteTitle} {versionLabel}, which is no longer actively maintained.")}};function _(e){const t=k[e.versionMetadata.banner];return a.createElement(t,e)}function C(e){let{versionLabel:t,to:n,onClick:l}=e;return a.createElement(v.Z,{id:"theme.docs.versions.latestVersionSuggestionLabel",description:"The label used to tell the user to check the latest version",values:{versionLabel:t,latestVersionLink:a.createElement("b",null,a.createElement(E.Z,{to:n,onClick:l},a.createElement(v.Z,{id:"theme.docs.versions.latestVersionLinkLabel",description:"The label used for the latest version suggestion link label"},"latest version")))}},"For up-to-date documentation, see the {latestVersionLink} ({versionLabel}).")}function x(e){let{className:t,versionMetadata:n}=e;const{siteConfig:{title:l}}=(0,p.Z)(),{pluginId:r}=(0,g.gA)({failfast:!0}),{savePreferredVersionName:s}=(0,N.J)(r),{latestDocSuggestion:o,latestVersionSuggestion:c}=(0,g.Jo)(r),i=o??(m=c).docs.find((e=>e.id===m.mainDocId));var m;return a.createElement("div",{className:(0,d.Z)(t,L.k.docs.docVersionBanner,"alert alert--warning margin-bottom--md"),role:"alert"},a.createElement("div",null,a.createElement(_,{siteTitle:l,versionMetadata:n})),a.createElement("div",{className:"margin-top--md"},a.createElement(C,{versionLabel:c.label,to:i.path,onClick:()=>s(c.name)})))}function H(e){let{className:t}=e;const n=(0,Z.E)();return n.banner?a.createElement(x,{className:t,versionMetadata:n}):null}function T(e){let{className:t}=e;const n=(0,Z.E)();return n.badge?a.createElement("span",{className:(0,d.Z)(t,L.k.docs.docVersionBadge,"badge badge--secondary")},a.createElement(v.Z,{id:"theme.docs.versionBadge.label",values:{versionLabel:n.label}},"Version: {versionLabel}")):null}function y(e){let{lastUpdatedAt:t,formattedLastUpdatedAt:n}=e;return a.createElement(v.Z,{id:"theme.lastUpdated.atDate",description:"The words used to describe on which date a page has been last updated",values:{date:a.createElement("b",null,a.createElement("time",{dateTime:new Date(1e3*t).toISOString()},n))}}," on {date}")}function U(e){let{lastUpdatedBy:t}=e;return a.createElement(v.Z,{id:"theme.lastUpdated.byUser",description:"The words used to describe by who the page has been last updated",values:{user:a.createElement("b",null,t)}}," by {user}")}function A(e){let{lastUpdatedAt:t,formattedLastUpdatedAt:n,lastUpdatedBy:l}=e;return a.createElement("span",{className:L.k.common.lastUpdated},a.createElement(v.Z,{id:"theme.lastUpdated.lastUpdatedAtBy",description:"The sentence used to display when a page has been last updated, and by who",values:{atDate:t&&n?a.createElement(y,{lastUpdatedAt:t,formattedLastUpdatedAt:n}):"",byUser:l?a.createElement(U,{lastUpdatedBy:l}):""}},"Last updated{atDate}{byUser}"),!1)}var w=n(34565),M=n(28349);const B="lastUpdated_pbO5";function I(e){return a.createElement("div",{className:(0,d.Z)(L.k.docs.docFooterTagsRow,"row margin-bottom--sm")},a.createElement("div",{className:"col"},a.createElement(M.Z,e)))}function O(e){let{editUrl:t,lastUpdatedAt:n,lastUpdatedBy:l,formattedLastUpdatedAt:r}=e;return a.createElement("div",{className:(0,d.Z)(L.k.docs.docFooterEditMetaRow,"row")},a.createElement("div",{className:"col"},t&&a.createElement(w.Z,{editUrl:t})),a.createElement("div",{className:(0,d.Z)("col",B)},(n||l)&&a.createElement(A,{lastUpdatedAt:n,formattedLastUpdatedAt:r,lastUpdatedBy:l})))}function S(){const{metadata:e}=c(),{editUrl:t,lastUpdatedAt:n,formattedLastUpdatedAt:l,lastUpdatedBy:r,tags:s}=e,o=s.length>0,i=!!(t||n||r);return o||i?a.createElement("footer",{className:(0,d.Z)(L.k.docs.docFooter,"docusaurus-mt-lg")},o&&a.createElement(I,{tags:s}),i&&a.createElement(O,{editUrl:t,lastUpdatedAt:n,lastUpdatedBy:r,formattedLastUpdatedAt:l})):null}var V=n(80376),P=n(36033);const R="tocCollapsibleButton_iI2p",D="tocCollapsibleButtonExpanded_cHjC";function F(e){let{collapsed:t,...n}=e;return a.createElement("button",(0,u.Z)({type:"button"},n,{className:(0,d.Z)("clean-btn",R,!t&&D,n.className)}),a.createElement(v.Z,{id:"theme.TOCCollapsible.toggleButtonLabel",description:"The label used by the button on the collapsible TOC component"},"On this page"))}const z="tocCollapsible_wXna",j="tocCollapsibleContent_vea0",$="tocCollapsibleExpanded_BbRn";function q(e){let{toc:t,className:n,minHeadingLevel:l,maxHeadingLevel:r}=e;const{collapsed:s,toggleCollapsed:o}=(0,V.u)({initialState:!0});return a.createElement("div",{className:(0,d.Z)(z,!s&&$,n)},a.createElement(F,{collapsed:s,onClick:o}),a.createElement(V.z,{lazy:!0,className:j,collapsed:s},a.createElement(P.Z,{toc:t,minHeadingLevel:l,maxHeadingLevel:r})))}const G="tocMobile_Ojys";function X(){const{toc:e,frontMatter:t}=c();return a.createElement(q,{toc:e,minHeadingLevel:t.toc_min_heading_level,maxHeadingLevel:t.toc_max_heading_level,className:(0,d.Z)(L.k.docs.docTocMobile,G)})}var J=n(17061);function Q(){const{toc:e,frontMatter:t}=c();return a.createElement(J.Z,{toc:e,minHeadingLevel:t.toc_min_heading_level,maxHeadingLevel:t.toc_max_heading_level,className:L.k.docs.docTocDesktop})}var K=n(1999),W=n(40450);function Y(e){let{children:t}=e;const n=function(){const{metadata:e,frontMatter:t,contentTitle:n}=c();return t.hide_title||void 0!==n?null:e.title}();return a.createElement("div",{className:(0,d.Z)(L.k.docs.docMarkdown,"markdown")},n&&a.createElement("header",null,a.createElement(K.Z,{as:"h1"},n)),a.createElement(W.Z,null,t))}var ee=n(45161),te=n(8862),ne=n(98948);function ae(e){return a.createElement("svg",(0,u.Z)({viewBox:"0 0 24 24"},e),a.createElement("path",{d:"M10 19v-5h4v5c0 .55.45 1 1 1h3c.55 0 1-.45 1-1v-7h1.7c.46 0 .68-.57.33-.87L12.67 3.6c-.38-.34-.96-.34-1.34 0l-8.36 7.53c-.34.3-.13.87.33.87H5v7c0 .55.45 1 1 1h3c.55 0 1-.45 1-1z",fill:"currentColor"}))}const le="breadcrumbHomeIcon_sfvy";function re(){const e=(0,ne.Z)("/");return a.createElement("li",{className:"breadcrumbs__item"},a.createElement(E.Z,{"aria-label":(0,v.I)({id:"theme.docs.breadcrumbs.home",message:"Home page",description:"The ARIA label for the home page in the breadcrumbs"}),className:"breadcrumbs__link",href:e},a.createElement(ae,{className:le})))}const se="breadcrumbsContainer_T5ub";function oe(e){let{children:t,href:n,isLast:l}=e;const r="breadcrumbs__link";return l?a.createElement("span",{className:r,itemProp:"name"},t):n?a.createElement(E.Z,{className:r,href:n,itemProp:"item"},a.createElement("span",{itemProp:"name"},t)):a.createElement("span",{className:r},t)}function ce(e){let{children:t,active:n,index:l,addMicrodata:r}=e;return a.createElement("li",(0,u.Z)({},r&&{itemScope:!0,itemProp:"itemListElement",itemType:"https://schema.org/ListItem"},{className:(0,d.Z)("breadcrumbs__item",{"breadcrumbs__item--active":n})}),t,a.createElement("meta",{itemProp:"position",content:String(l+1)}))}function ie(){const e=(0,ee.s1)(),t=(0,te.Ns)();return e?a.createElement("nav",{className:(0,d.Z)(L.k.docs.docBreadcrumbs,se),"aria-label":(0,v.I)({id:"theme.docs.breadcrumbs.navAriaLabel",message:"Breadcrumbs",description:"The ARIA label for the breadcrumbs"})},a.createElement("ul",{className:"breadcrumbs",itemScope:!0,itemType:"https://schema.org/BreadcrumbList"},t&&a.createElement(re,null),e.map(((t,n)=>{const l=n===e.length-1;return a.createElement(ce,{key:n,active:l,index:n,addMicrodata:!!t.href},a.createElement(oe,{href:t.href,isLast:l},t.label))})))):null}const de="docItemContainer_tjFy",me="docItemCol_Qr34";function ue(e){let{children:t}=e;const n=function(){const{frontMatter:e,toc:t}=c(),n=(0,m.i)(),l=e.hide_table_of_contents,r=!l&&t.length>0;return{hidden:l,mobile:r?a.createElement(X,null):void 0,desktop:!r||"desktop"!==n&&"ssr"!==n?void 0:a.createElement(Q,null)}}();return a.createElement("div",{className:"row"},a.createElement("div",{className:(0,d.Z)("col",!n.hidden&&me)},a.createElement(H,null),a.createElement("div",{className:de},a.createElement("article",null,a.createElement(ie,null),a.createElement(T,null),n.mobile,a.createElement(Y,null,t),a.createElement(S,null)),a.createElement(f,null))),n.desktop&&a.createElement("div",{className:"col col--3"},n.desktop))}function ve(e){const t=`docs-doc-id-${e.content.metadata.unversionedId}`,n=e.content;return a.createElement(o,{content:e.content},a.createElement(l.FG,{className:t},a.createElement(i,null),a.createElement(ue,null,a.createElement(n,null))))}},17061:(e,t,n)=>{n.d(t,{Z:()=>c});var a=n(25773),l=n(27378),r=n(38944),s=n(36033);const o="tableOfContents_XG6w";function c(e){let{className:t,...n}=e;return l.createElement("div",{className:(0,r.Z)(o,"thin-scrollbar",t)},l.createElement(s.Z,(0,a.Z)({},n,{linkClassName:"table-of-contents__link toc-highlight",linkActiveClassName:"table-of-contents__link--active"})))}},36033:(e,t,n)=>{n.d(t,{Z:()=>b});var a=n(25773),l=n(27378),r=n(20624);function s(e){const t=e.map((e=>({...e,parentIndex:-1,children:[]}))),n=Array(7).fill(-1);t.forEach(((e,t)=>{const a=n.slice(2,e.level);e.parentIndex=Math.max(...a),n[e.level]=t}));const a=[];return t.forEach((e=>{const{parentIndex:n,...l}=e;n>=0?t[n].children.push(l):a.push(l)})),a}function o(e){let{toc:t,minHeadingLevel:n,maxHeadingLevel:a}=e;return t.flatMap((e=>{const t=o({toc:e.children,minHeadingLevel:n,maxHeadingLevel:a});return function(e){return e.level>=n&&e.level<=a}(e)?[{...e,children:t}]:t}))}function c(e){const t=e.getBoundingClientRect();return t.top===t.bottom?c(e.parentNode):t}function i(e,t){let{anchorTopOffset:n}=t;const a=e.find((e=>c(e).top>=n));if(a){return function(e){return e.top>0&&e.bottom{e.current=t?0:document.querySelector(".navbar").clientHeight}),[t]),e}function m(e){const t=(0,l.useRef)(void 0),n=d();(0,l.useEffect)((()=>{if(!e)return()=>{};const{linkClassName:a,linkActiveClassName:l,minHeadingLevel:r,maxHeadingLevel:s}=e;function o(){const e=function(e){return Array.from(document.getElementsByClassName(e))}(a),o=function(e){let{minHeadingLevel:t,maxHeadingLevel:n}=e;const a=[];for(let l=t;l<=n;l+=1)a.push(`h${l}.anchor`);return Array.from(document.querySelectorAll(a.join()))}({minHeadingLevel:r,maxHeadingLevel:s}),c=i(o,{anchorTopOffset:n.current}),d=e.find((e=>c&&c.id===function(e){return decodeURIComponent(e.href.substring(e.href.indexOf("#")+1))}(e)));e.forEach((e=>{!function(e,n){n?(t.current&&t.current!==e&&t.current.classList.remove(l),e.classList.add(l),t.current=e):e.classList.remove(l)}(e,e===d)}))}return document.addEventListener("scroll",o),document.addEventListener("resize",o),o(),()=>{document.removeEventListener("scroll",o),document.removeEventListener("resize",o)}}),[e,n])}function u(e){let{toc:t,className:n,linkClassName:a,isChild:r}=e;return t.length?l.createElement("ul",{className:r?void 0:n},t.map((e=>l.createElement("li",{key:e.id},l.createElement("a",{href:`#${e.id}`,className:a??void 0,dangerouslySetInnerHTML:{__html:e.value}}),l.createElement(u,{isChild:!0,toc:e.children,className:n,linkClassName:a}))))):null}const v=l.memo(u);function b(e){let{toc:t,className:n="table-of-contents table-of-contents__left-border",linkClassName:c="table-of-contents__link",linkActiveClassName:i,minHeadingLevel:d,maxHeadingLevel:u,...b}=e;const h=(0,r.L)(),f=d??h.tableOfContents.minHeadingLevel,p=u??h.tableOfContents.maxHeadingLevel,E=function(e){let{toc:t,minHeadingLevel:n,maxHeadingLevel:a}=e;return(0,l.useMemo)((()=>o({toc:s(t),minHeadingLevel:n,maxHeadingLevel:a})),[t,n,a])}({toc:t,minHeadingLevel:f,maxHeadingLevel:p});return m((0,l.useMemo)((()=>{if(c&&i)return{linkClassName:c,linkActiveClassName:i,minHeadingLevel:f,maxHeadingLevel:p}}),[c,i,f,p])),l.createElement(v,(0,a.Z)({toc:E,className:n,linkClassName:c},b))}},25611:(e,t,n)=>{n.d(t,{E:()=>o,q:()=>s});var a=n(27378),l=n(41763);const r=a.createContext(null);function s(e){let{children:t,version:n}=e;return a.createElement(r.Provider,{value:n},t)}function o(){const e=(0,a.useContext)(r);if(null===e)throw new l.i6("DocsVersionProvider");return e}},85978:(e,t,n)=>{n.d(t,{Z:()=>r});var a=n(27378),l=n(10610);function r(e){const t={...e};return t?.code?.length>2&&("$ "===t.code.substring(0,2)||"# "===t.code.substring(0,2)||"> "===t.code.substring(0,2))&&(t.code=t.code.substring(2)),a.createElement(a.Fragment,null,a.createElement(l.Z,t))}},35654:(e,t,n)=>{n.d(t,{Z:()=>c});var a=n(80256),l=n(92739),r=n(30537),s=n(9928),o=n(19374);r.vI.add(s.vnX,o.mRB);const c={...a.Z,Icon:l.G}}}]); \ No newline at end of file diff --git a/assets/js/1a16e8bf.1fb6071f.js b/assets/js/1a16e8bf.1fb6071f.js new file mode 100644 index 00000000000..976fc9089fc --- /dev/null +++ b/assets/js/1a16e8bf.1fb6071f.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[2079],{58960:(e,t,a)=>{a.r(t),a.d(t,{assets:()=>r,contentTitle:()=>i,default:()=>k,frontMatter:()=>l,metadata:()=>p,toc:()=>m});var n=a(25773),o=(a(27378),a(35318)),s=a(92975);const l={title:"Release Notes - Podman Desktop 1.1",description:"Podman Desktop 1.1 has been released!",slug:"podman-desktop-release-1.1",authors:["deboer"],tags:["podman-desktop","release","kubernetes","openshift"],hide_table_of_contents:!1,image:"/img/blog/podman-desktop-release-1.1.webp"},i=void 0,p={permalink:"/blog/podman-desktop-release-1.1",source:"@site/blog/2023-06-08-release-1.1.md",title:"Release Notes - Podman Desktop 1.1",description:"Podman Desktop 1.1 has been released!",date:"2023-06-08T00:00:00.000Z",formattedDate:"June 8, 2023",tags:[{label:"podman-desktop",permalink:"/blog/tags/podman-desktop"},{label:"release",permalink:"/blog/tags/release"},{label:"kubernetes",permalink:"/blog/tags/kubernetes"},{label:"openshift",permalink:"/blog/tags/openshift"}],readingTime:2.465,hasTruncateMarker:!0,authors:[{name:"Tim deBoer",title:"Architect",url:"https://github.com/deboer-tim",imageURL:"https://github.com/deboer-tim.png",key:"deboer"}],frontMatter:{title:"Release Notes - Podman Desktop 1.1",description:"Podman Desktop 1.1 has been released!",slug:"podman-desktop-release-1.1",authors:["deboer"],tags:["podman-desktop","release","kubernetes","openshift"],hide_table_of_contents:!1,image:"/img/blog/podman-desktop-release-1.1.webp"},prevItem:{title:"Release Notes - Podman Desktop 1.2",permalink:"/blog/podman-desktop-release-1.2"},nextItem:{title:"Release Notes - Podman Desktop 1.0",permalink:"/blog/podman-desktop-release-1.0"}},r={authorsImageUrls:[void 0]},m=[{value:"Release Details",id:"release-details",level:2},{value:"Podman v4.5.1",id:"podman-v451",level:3},{value:"Extensions",id:"extensions",level:3},{value:"Lima Support",id:"lima-support",level:3},{value:"Other UI and UX Improvements",id:"other-ui-and-ux-improvements",level:3},{value:"New Loading Screen",id:"new-loading-screen",level:4},{value:"Other Notable Enhancements",id:"other-notable-enhancements",level:2},{value:"Notable Bug Fixes",id:"notable-bug-fixes",level:2},{value:"Community Thank You",id:"community-thank-you",level:2},{value:"Final notes",id:"final-notes",level:2}],d=(u="Icon",function(e){return console.warn("Component "+u+" was not imported, exported, or provided by MDXProvider as global scope"),(0,o.kt)("div",e)});var u;const h={toc:m};function k(e){let{components:t,...l}=e;return(0,o.kt)("wrapper",(0,n.Z)({},h,l,{components:t,mdxType:"MDXLayout"}),(0,o.kt)("p",null,"Podman Desktop 1.1 Release! \ud83c\udf89"),(0,o.kt)("p",null,"This is primarily a bug-fix release to fix a few important issues, but we've managed to squeeze in a few enhancements\nalong the way."),(0,o.kt)("ul",null,(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("strong",{parentName:"li"},"Podman 4.5.1"),": Podman 4.5.1 now included in Windows and Mac installers."),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("strong",{parentName:"li"},"Extensions"),": Update extensions from within Podman Desktop."),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("strong",{parentName:"li"},"Lima Support"),": Choose engine type and override its name from the settings."),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("strong",{parentName:"li"},"UX and UI Improvements"),": New loading screen.")),(0,o.kt)("p",null,"Podman Desktop 1.1 is now available. ",(0,o.kt)("a",{parentName:"p",href:"/downloads"},"Click here to download it"),"!"),(0,o.kt)("p",null,(0,o.kt)("img",{alt:"Podman-desktop-1-1-hero",src:a(24825).Z,width:"3958",height:"2308"})),(0,o.kt)("hr",null),(0,o.kt)("h2",{id:"release-details"},"Release Details"),(0,o.kt)("h3",{id:"podman-v451"},"Podman v4.5.1"),(0,o.kt)("p",null,"Podman Desktop 1.1 moves up to ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman/releases/tag/v4.5.1"},"Podman 4.5.1"),"."),(0,o.kt)("h3",{id:"extensions"},"Extensions"),(0,o.kt)("p",null,"Optional extensions will follow their own lifecycle and update independently from Podman Desktop. As of\nthis release you'll be able to see when there is an update available and install from within\nPodman Desktop ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/2655"},"#2655"),"."),(0,o.kt)("p",null,"We've also added options in ",(0,o.kt)("strong",{parentName:"p"},(0,o.kt)(d,{icon:"fa-solid fa-cog",size:"lg",mdxType:"Icon"}),"Settings > Preferences")," to\nautomatically check for and install extension updates."),(0,o.kt)(s.Z,{playing:!0,controls:!0,url:"https://user-images.githubusercontent.com/436777/241246481-305d215f-2a5c-46e8-9cc3-ecd90a6bd2bc.mp4",width:"100%",height:"100%",mdxType:"ReactPlayer"}),(0,o.kt)("p",null,(0,o.kt)("img",{alt:"Update extensions",src:a(78687).Z,width:"1324",height:"364"})),(0,o.kt)("h3",{id:"lima-support"},"Lima Support"),(0,o.kt)("p",null,"Thanks to contributor ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/afbjorklund"},"Anders Bj\xf6rklund"),", we have some improvements to the\nLima extension! In ",(0,o.kt)("strong",{parentName:"p"},(0,o.kt)(d,{icon:"fa-solid fa-cog",size:"lg",mdxType:"Icon"}),"Settings > Preferences")," you can select which\nengine type Lima runs on and override the instance name ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/2674"},"#2674"),"."),(0,o.kt)("p",null,(0,o.kt)("img",{parentName:"p",src:"https://user-images.githubusercontent.com/10364051/241755966-0a6a293b-b18e-4222-9c40-abd6c114d464.png",alt:"Lima preferences"})),(0,o.kt)("h3",{id:"other-ui-and-ux-improvements"},"Other UI and UX Improvements"),(0,o.kt)("h4",{id:"new-loading-screen"},"New Loading Screen"),(0,o.kt)("p",null,"We have a new loading screen, Podman Desktop style! ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/2743"},"#2743"),"."),(0,o.kt)(s.Z,{playing:!0,controls:!0,url:"https://user-images.githubusercontent.com/436777/243706137-324b5870-f6a0-4bc1-ac91-e8b45c374c90.mp4",width:"100%",height:"100%",mdxType:"ReactPlayer"}),(0,o.kt)("hr",null),(0,o.kt)("h2",{id:"other-notable-enhancements"},"Other Notable Enhancements"),(0,o.kt)("ul",null,(0,o.kt)("li",{parentName:"ul"},"Docker-compose can be installed system-wide ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/2718"},"#2718"),"."),(0,o.kt)("li",{parentName:"ul"},"Show warning when creating a pod with two containers that use the same port ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/2671"},"#2671"),"."),(0,o.kt)("li",{parentName:"ul"},"Display Kubernetes context name in pod label ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/2634"},"#2634"),"."),(0,o.kt)("li",{parentName:"ul"},"Add Docker compatibility button using flatpak-spawn ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/1925"},"#1925"),"."),(0,o.kt)("li",{parentName:"ul"},"Improve UI consistency of Pull Image page ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/2604"},"#2604"),".")),(0,o.kt)("hr",null),(0,o.kt)("h2",{id:"notable-bug-fixes"},"Notable Bug Fixes"),(0,o.kt)("ul",null,(0,o.kt)("li",{parentName:"ul"},"Could not install extensions on Windows 10 ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/2762"},"#2762"),"."),(0,o.kt)("li",{parentName:"ul"},"Could not use locally built images on Kubernetes ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/2710"},"#2710"),"."),(0,o.kt)("li",{parentName:"ul"},"Dashboard still suggests update after installation ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/2648"},"#2648"),"."),(0,o.kt)("li",{parentName:"ul"},"Could not Play Kubernetes YAML to Podman on Windows ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/2594"},"#2594"),"."),(0,o.kt)("li",{parentName:"ul"},"Pod label wasn't always shown in list ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/2614"},"#2614"),"."),(0,o.kt)("li",{parentName:"ul"},"Dashboard button state was resetting ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/2584"},"#2584"),"."),(0,o.kt)("li",{parentName:"ul"},"Change checkbox style so they don't look like stop buttons ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/2723"},"#2723"),".")),(0,o.kt)("hr",null),(0,o.kt)("h2",{id:"community-thank-you"},"Community Thank You"),(0,o.kt)("p",null,"\ud83c\udf89 We\u2019d like to say a big thank you to everyone who helped to make Podman Desktop even better. In this\nsprint we received pull requests from the following people:"),(0,o.kt)("ul",null,(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("a",{parentName:"li",href:"https://github.com/fatelei"},"wangxiaolei")," in ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/2602"},"#2602 - Add meaningful tooltips to build, pull, prune buttons")),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("a",{parentName:"li",href:"https://github.com/AsciiWolf"},"AsciiWolf")," in ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/2607"},"#2607 - fix typing error in Flathub name")," and ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/2609"},"#2609 - fix Flatpak install instructions")),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("a",{parentName:"li",href:"https://github.com/afbjorklund"},"Anders Bj\xf6rklund")," in ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/2674"},"#2674 - Select engine for Lima provider"))),(0,o.kt)("hr",null),(0,o.kt)("h2",{id:"final-notes"},"Final notes"),(0,o.kt)("p",null,"The complete list of issues fixed in this release is available ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/issues?q=is%3Aclosed+milestone%3A1.1.0"},"here")," and ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/issues?q=is%3Aclosed+milestone%3A1.1.0"},"here"),"."),(0,o.kt)("p",null,"Get the latest release from the ",(0,o.kt)("a",{parentName:"p",href:"/downloads"},"Downloads")," section of the website and boost your development journey with Podman Desktop. Additionally, visit the ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop"},"GitHub repository")," and see how you can help us make Podman Desktop better."))}k.isMDXComponent=!0},24825:(e,t,a)=>{a.d(t,{Z:()=>n});const n=a.p+"assets/images/podman-desktop-release-1.1-44e0feeaa28730210c0fbecda0193b95.png"},78687:(e,t,a)=>{a.d(t,{Z:()=>n});const n=a.p+"assets/images/update-extensions-6b1ea25170c2f1b7608d8f5a887d902a.png"}}]); \ No newline at end of file diff --git a/assets/js/1a16e8bf.e37eaeb3.js b/assets/js/1a16e8bf.e37eaeb3.js deleted file mode 100644 index 74f392fba32..00000000000 --- a/assets/js/1a16e8bf.e37eaeb3.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[2079],{58960:(e,t,a)=>{a.r(t),a.d(t,{assets:()=>r,contentTitle:()=>i,default:()=>u,frontMatter:()=>l,metadata:()=>p,toc:()=>m});var n=a(25773),o=(a(27378),a(35318)),s=a(92975);const l={title:"Release Notes - Podman Desktop 1.1",description:"Podman Desktop 1.1 has been released!",slug:"podman-desktop-release-1.1",authors:["deboer"],tags:["podman-desktop","release","kubernetes","openshift"],hide_table_of_contents:!1,image:"/img/blog/podman-desktop-release-1.1.webp"},i=void 0,p={permalink:"/blog/podman-desktop-release-1.1",source:"@site/blog/2023-06-08-release-1.1.md",title:"Release Notes - Podman Desktop 1.1",description:"Podman Desktop 1.1 has been released!",date:"2023-06-08T00:00:00.000Z",formattedDate:"June 8, 2023",tags:[{label:"podman-desktop",permalink:"/blog/tags/podman-desktop"},{label:"release",permalink:"/blog/tags/release"},{label:"kubernetes",permalink:"/blog/tags/kubernetes"},{label:"openshift",permalink:"/blog/tags/openshift"}],readingTime:2.465,hasTruncateMarker:!0,authors:[{name:"Tim deBoer",title:"Architect",url:"https://github.com/deboer-tim",imageURL:"https://github.com/deboer-tim.png",key:"deboer"}],frontMatter:{title:"Release Notes - Podman Desktop 1.1",description:"Podman Desktop 1.1 has been released!",slug:"podman-desktop-release-1.1",authors:["deboer"],tags:["podman-desktop","release","kubernetes","openshift"],hide_table_of_contents:!1,image:"/img/blog/podman-desktop-release-1.1.webp"},prevItem:{title:"Release Notes - Podman Desktop 1.2",permalink:"/blog/podman-desktop-release-1.2"},nextItem:{title:"Release Notes - Podman Desktop 1.0",permalink:"/blog/podman-desktop-release-1.0"}},r={authorsImageUrls:[void 0]},m=[{value:"Release Details",id:"release-details",level:2},{value:"Podman v4.5.1",id:"podman-v451",level:3},{value:"Extensions",id:"extensions",level:3},{value:"Lima Support",id:"lima-support",level:3},{value:"Other UI and UX Improvements",id:"other-ui-and-ux-improvements",level:3},{value:"New Loading Screen",id:"new-loading-screen",level:4},{value:"Other Notable Enhancements",id:"other-notable-enhancements",level:2},{value:"Notable Bug Fixes",id:"notable-bug-fixes",level:2},{value:"Community Thank You",id:"community-thank-you",level:2},{value:"Final notes",id:"final-notes",level:2}],d={toc:m};function u(e){let{components:t,...l}=e;return(0,o.kt)("wrapper",(0,n.Z)({},d,l,{components:t,mdxType:"MDXLayout"}),(0,o.kt)("p",null,"Podman Desktop 1.1 Release! \ud83c\udf89"),(0,o.kt)("p",null,"This is primarily a bug-fix release to fix a few important issues, but we've managed to squeeze in a few enhancements\nalong the way."),(0,o.kt)("ul",null,(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("strong",{parentName:"li"},"Podman 4.5.1"),": Podman 4.5.1 now included in Windows and Mac installers."),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("strong",{parentName:"li"},"Extensions"),": Update extensions from within Podman Desktop."),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("strong",{parentName:"li"},"Lima Support"),": Choose engine type and override its name from the settings."),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("strong",{parentName:"li"},"UX and UI Improvements"),": New loading screen.")),(0,o.kt)("p",null,"Podman Desktop 1.1 is now available. ",(0,o.kt)("a",{parentName:"p",href:"/downloads"},"Click here to download it"),"!"),(0,o.kt)("p",null,(0,o.kt)("img",{alt:"Podman-desktop-1-1-hero",src:a(24825).Z,width:"3958",height:"2308"})),(0,o.kt)("hr",null),(0,o.kt)("h2",{id:"release-details"},"Release Details"),(0,o.kt)("h3",{id:"podman-v451"},"Podman v4.5.1"),(0,o.kt)("p",null,"Podman Desktop 1.1 moves up to ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman/releases/tag/v4.5.1"},"Podman 4.5.1"),"."),(0,o.kt)("h3",{id:"extensions"},"Extensions"),(0,o.kt)("p",null,"Optional extensions will follow their own lifecycle and update independently from Podman Desktop. As of\nthis release you'll be able to see when there is an update available and install from within\nPodman Desktop ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/2655"},"#2655"),"."),(0,o.kt)("p",null,"We've also added options in ",(0,o.kt)("strong",{parentName:"p"},(0,o.kt)("icon",{icon:"fa-solid fa-cog",size:"lg"}),"Settings > Preferences")," to\nautomatically check for and install extension updates."),(0,o.kt)(s.Z,{playing:!0,controls:!0,url:"https://user-images.githubusercontent.com/436777/241246481-305d215f-2a5c-46e8-9cc3-ecd90a6bd2bc.mp4",width:"100%",height:"100%",mdxType:"ReactPlayer"}),(0,o.kt)("p",null,(0,o.kt)("img",{alt:"Update extensions",src:a(78687).Z,width:"1324",height:"364"})),(0,o.kt)("h3",{id:"lima-support"},"Lima Support"),(0,o.kt)("p",null,"Thanks to contributor ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/afbjorklund"},"Anders Bj\xf6rklund"),", we have some improvements to the\nLima extension! In ",(0,o.kt)("strong",{parentName:"p"},(0,o.kt)("icon",{icon:"fa-solid fa-cog",size:"lg"}),"Settings > Preferences")," you can select which\nengine type Lima runs on and override the instance name ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/2674"},"#2674"),"."),(0,o.kt)("p",null,(0,o.kt)("img",{parentName:"p",src:"https://user-images.githubusercontent.com/10364051/241755966-0a6a293b-b18e-4222-9c40-abd6c114d464.png",alt:"Lima preferences"})),(0,o.kt)("h3",{id:"other-ui-and-ux-improvements"},"Other UI and UX Improvements"),(0,o.kt)("h4",{id:"new-loading-screen"},"New Loading Screen"),(0,o.kt)("p",null,"We have a new loading screen, Podman Desktop style! ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/2743"},"#2743"),"."),(0,o.kt)(s.Z,{playing:!0,controls:!0,url:"https://user-images.githubusercontent.com/436777/243706137-324b5870-f6a0-4bc1-ac91-e8b45c374c90.mp4",width:"100%",height:"100%",mdxType:"ReactPlayer"}),(0,o.kt)("hr",null),(0,o.kt)("h2",{id:"other-notable-enhancements"},"Other Notable Enhancements"),(0,o.kt)("ul",null,(0,o.kt)("li",{parentName:"ul"},"Docker-compose can be installed system-wide ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/2718"},"#2718"),"."),(0,o.kt)("li",{parentName:"ul"},"Show warning when creating a pod with two containers that use the same port ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/2671"},"#2671"),"."),(0,o.kt)("li",{parentName:"ul"},"Display Kubernetes context name in pod label ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/2634"},"#2634"),"."),(0,o.kt)("li",{parentName:"ul"},"Add Docker compatibility button using flatpak-spawn ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/1925"},"#1925"),"."),(0,o.kt)("li",{parentName:"ul"},"Improve UI consistency of Pull Image page ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/2604"},"#2604"),".")),(0,o.kt)("hr",null),(0,o.kt)("h2",{id:"notable-bug-fixes"},"Notable Bug Fixes"),(0,o.kt)("ul",null,(0,o.kt)("li",{parentName:"ul"},"Could not install extensions on Windows 10 ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/2762"},"#2762"),"."),(0,o.kt)("li",{parentName:"ul"},"Could not use locally built images on Kubernetes ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/2710"},"#2710"),"."),(0,o.kt)("li",{parentName:"ul"},"Dashboard still suggests update after installation ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/2648"},"#2648"),"."),(0,o.kt)("li",{parentName:"ul"},"Could not Play Kubernetes YAML to Podman on Windows ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/2594"},"#2594"),"."),(0,o.kt)("li",{parentName:"ul"},"Pod label wasn't always shown in list ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/2614"},"#2614"),"."),(0,o.kt)("li",{parentName:"ul"},"Dashboard button state was resetting ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/2584"},"#2584"),"."),(0,o.kt)("li",{parentName:"ul"},"Change checkbox style so they don't look like stop buttons ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/2723"},"#2723"),".")),(0,o.kt)("hr",null),(0,o.kt)("h2",{id:"community-thank-you"},"Community Thank You"),(0,o.kt)("p",null,"\ud83c\udf89 We\u2019d like to say a big thank you to everyone who helped to make Podman Desktop even better. In this\nsprint we received pull requests from the following people:"),(0,o.kt)("ul",null,(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("a",{parentName:"li",href:"https://github.com/fatelei"},"wangxiaolei")," in ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/2602"},"#2602 - Add meaningful tooltips to build, pull, prune buttons")),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("a",{parentName:"li",href:"https://github.com/AsciiWolf"},"AsciiWolf")," in ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/2607"},"#2607 - fix typing error in Flathub name")," and ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/2609"},"#2609 - fix Flatpak install instructions")),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("a",{parentName:"li",href:"https://github.com/afbjorklund"},"Anders Bj\xf6rklund")," in ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/2674"},"#2674 - Select engine for Lima provider"))),(0,o.kt)("hr",null),(0,o.kt)("h2",{id:"final-notes"},"Final notes"),(0,o.kt)("p",null,"The complete list of issues fixed in this release is available ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/issues?q=is%3Aclosed+milestone%3A1.1.0"},"here")," and ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/issues?q=is%3Aclosed+milestone%3A1.1.0"},"here"),"."),(0,o.kt)("p",null,"Get the latest release from the ",(0,o.kt)("a",{parentName:"p",href:"/downloads"},"Downloads")," section of the website and boost your development journey with Podman Desktop. Additionally, visit the ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop"},"GitHub repository")," and see how you can help us make Podman Desktop better."))}u.isMDXComponent=!0},24825:(e,t,a)=>{a.d(t,{Z:()=>n});const n=a.p+"assets/images/podman-desktop-release-1.1-44e0feeaa28730210c0fbecda0193b95.png"},78687:(e,t,a)=>{a.d(t,{Z:()=>n});const n=a.p+"assets/images/update-extensions-6b1ea25170c2f1b7608d8f5a887d902a.png"}}]); \ No newline at end of file diff --git a/assets/js/25622900.a5170eed.js b/assets/js/25622900.a5170eed.js new file mode 100644 index 00000000000..3c47135791f --- /dev/null +++ b/assets/js/25622900.a5170eed.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[1896],{35318:(e,t,n)=>{n.d(t,{Zo:()=>s,kt:()=>k});var r=n(27378);function i(e,t,n){return t in e?Object.defineProperty(e,t,{value:n,enumerable:!0,configurable:!0,writable:!0}):e[t]=n,e}function o(e,t){var n=Object.keys(e);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(e);t&&(r=r.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),n.push.apply(n,r)}return n}function a(e){for(var t=1;t=0||(i[n]=e[n]);return i}(e,t);if(Object.getOwnPropertySymbols){var o=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(i[n]=e[n])}return i}var u=r.createContext({}),c=function(e){var t=r.useContext(u),n=t;return e&&(n="function"==typeof e?e(t):a(a({},t),e)),n},s=function(e){var t=c(e.components);return r.createElement(u.Provider,{value:t},e.children)},p={inlineCode:"code",wrapper:function(e){var t=e.children;return r.createElement(r.Fragment,{},t)}},m=r.forwardRef((function(e,t){var n=e.components,i=e.mdxType,o=e.originalType,u=e.parentName,s=l(e,["components","mdxType","originalType","parentName"]),m=c(n),k=i,d=m["".concat(u,".").concat(k)]||m[k]||p[k]||o;return n?r.createElement(d,a(a({ref:t},s),{},{components:n})):r.createElement(d,a({ref:t},s))}));function k(e,t){var n=arguments,i=t&&t.mdxType;if("string"==typeof e||i){var o=n.length,a=new Array(o);a[0]=m;var l={};for(var u in t)hasOwnProperty.call(t,u)&&(l[u]=t[u]);l.originalType=e,l.mdxType="string"==typeof e?e:i,a[1]=l;for(var c=2;c{n.r(t),n.d(t,{assets:()=>u,contentTitle:()=>a,default:()=>k,frontMatter:()=>o,metadata:()=>l,toc:()=>c});var r=n(25773),i=(n(27378),n(35318));const o={sidebar_position:4,title:"Creating a Minikube cluster",description:"Creating a local Minikube-powered Kubernetes cluster.",keywords:["podman desktop","podman","containers","migrating","kubernetes","minikube"],tags:["migrating-to-kubernetes","minikube"]},a="Creating a local Minikube-powered Kubernetes cluster",l={unversionedId:"minikube/creating-a-minikube-cluster",id:"minikube/creating-a-minikube-cluster",title:"Creating a Minikube cluster",description:"Creating a local Minikube-powered Kubernetes cluster.",source:"@site/docs/minikube/creating-a-minikube-cluster.md",sourceDirName:"minikube",slug:"/minikube/creating-a-minikube-cluster",permalink:"/docs/minikube/creating-a-minikube-cluster",draft:!1,editUrl:"https://github.com/containers/podman-desktop/tree/main/website/docs/minikube/creating-a-minikube-cluster.md",tags:[{label:"migrating-to-kubernetes",permalink:"/docs/tags/migrating-to-kubernetes"},{label:"minikube",permalink:"/docs/tags/minikube"}],version:"current",sidebarPosition:4,frontMatter:{sidebar_position:4,title:"Creating a Minikube cluster",description:"Creating a local Minikube-powered Kubernetes cluster.",keywords:["podman desktop","podman","containers","migrating","kubernetes","minikube"],tags:["migrating-to-kubernetes","minikube"]},sidebar:"mySidebar",previous:{title:"Configuring Podman for Minikube",permalink:"/docs/minikube/configuring-podman-for-minikube-on-windows"},next:{title:"Working with your Minikube cluster",permalink:"/docs/minikube/working-with-your-local-minikube-cluster"}},u={},c=[{value:"Prerequisites",id:"prerequisites",level:4},{value:"Procedure",id:"procedure",level:4},{value:"Verification",id:"verification",level:4}],s=(p="Icon",function(e){return console.warn("Component "+p+" was not imported, exported, or provided by MDXProvider as global scope"),(0,i.kt)("div",e)});var p;const m={toc:c};function k(e){let{components:t,...n}=e;return(0,i.kt)("wrapper",(0,r.Z)({},m,n,{components:t,mdxType:"MDXLayout"}),(0,i.kt)("h1",{id:"creating-a-local-minikube-powered-kubernetes-cluster"},"Creating a local Minikube-powered Kubernetes cluster"),(0,i.kt)("p",null,"You can create multiple local Minikube-powered Kubernetes clusters."),(0,i.kt)("h4",{id:"prerequisites"},"Prerequisites"),(0,i.kt)("ul",null,(0,i.kt)("li",{parentName:"ul"},(0,i.kt)("a",{parentName:"li",href:"/docs/minikube/installing"},"You installed Minikube"),"."),(0,i.kt)("li",{parentName:"ul"},(0,i.kt)("a",{parentName:"li",href:"/docs/minikube/configuring-podman-for-minikube-on-windows"},"On Windows, you configured Podman"),".")),(0,i.kt)("h4",{id:"procedure"},"Procedure"),(0,i.kt)("ol",null,(0,i.kt)("li",{parentName:"ol"},(0,i.kt)("p",{parentName:"li"},"Go to ",(0,i.kt)("strong",{parentName:"p"},(0,i.kt)(s,{icon:"fa-solid fa-cog",size:"lg",mdxType:"Icon"})," Settings > Resources"))),(0,i.kt)("li",{parentName:"ol"},(0,i.kt)("p",{parentName:"li"},"In the Minikube tile, click on the ",(0,i.kt)("strong",{parentName:"p"},"Create new ...")," button.")),(0,i.kt)("li",{parentName:"ol"},(0,i.kt)("p",{parentName:"li"},"Choose your options, and click the ",(0,i.kt)("strong",{parentName:"p"},"Create")," button."),(0,i.kt)("p",{parentName:"li"},"The defaults are:"),(0,i.kt)("ul",{parentName:"li"},(0,i.kt)("li",{parentName:"ul"},"Name: ",(0,i.kt)("inlineCode",{parentName:"li"},"minikube")),(0,i.kt)("li",{parentName:"ul"},"Driver: ",(0,i.kt)("inlineCode",{parentName:"li"},"podman")),(0,i.kt)("li",{parentName:"ul"},"Container runtime: ",(0,i.kt)("inlineCode",{parentName:"li"},"cri-o")))),(0,i.kt)("li",{parentName:"ol"},(0,i.kt)("p",{parentName:"li"},"(Optionally) Click the ",(0,i.kt)("strong",{parentName:"p"},"Show logs")," button to display the logs.")),(0,i.kt)("li",{parentName:"ol"},(0,i.kt)("p",{parentName:"li"},"After successful creation, click on the ",(0,i.kt)("strong",{parentName:"p"},"Go back to resources")," button"))),(0,i.kt)("h4",{id:"verification"},"Verification"),(0,i.kt)("ol",null,(0,i.kt)("li",{parentName:"ol"},"In ",(0,i.kt)("strong",{parentName:"li"},(0,i.kt)(s,{icon:"fa-solid fa-cog",size:"lg",mdxType:"Icon"})," Settings > Resources"),", in the ",(0,i.kt)("strong",{parentName:"li"},"Minikube")," tile, your ",(0,i.kt)("inlineCode",{parentName:"li"},"")," instance is running."),(0,i.kt)("li",{parentName:"ol"},"In the Podman Desktop tray, open the ",(0,i.kt)("strong",{parentName:"li"},"Kubernetes")," menu, you can set the context to your Minikube cluster: ",(0,i.kt)("inlineCode",{parentName:"li"},"minikube"),".")))}k.isMDXComponent=!0}}]); \ No newline at end of file diff --git a/assets/js/25622900.f0255b71.js b/assets/js/25622900.f0255b71.js deleted file mode 100644 index 637e1550ab9..00000000000 --- a/assets/js/25622900.f0255b71.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[1896],{35318:(e,t,n)=>{n.d(t,{Zo:()=>s,kt:()=>k});var i=n(27378);function r(e,t,n){return t in e?Object.defineProperty(e,t,{value:n,enumerable:!0,configurable:!0,writable:!0}):e[t]=n,e}function a(e,t){var n=Object.keys(e);if(Object.getOwnPropertySymbols){var i=Object.getOwnPropertySymbols(e);t&&(i=i.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),n.push.apply(n,i)}return n}function o(e){for(var t=1;t=0||(r[n]=e[n]);return r}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(i=0;i=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(r[n]=e[n])}return r}var u=i.createContext({}),c=function(e){var t=i.useContext(u),n=t;return e&&(n="function"==typeof e?e(t):o(o({},t),e)),n},s=function(e){var t=c(e.components);return i.createElement(u.Provider,{value:t},e.children)},p={inlineCode:"code",wrapper:function(e){var t=e.children;return i.createElement(i.Fragment,{},t)}},m=i.forwardRef((function(e,t){var n=e.components,r=e.mdxType,a=e.originalType,u=e.parentName,s=l(e,["components","mdxType","originalType","parentName"]),m=c(n),k=r,b=m["".concat(u,".").concat(k)]||m[k]||p[k]||a;return n?i.createElement(b,o(o({ref:t},s),{},{components:n})):i.createElement(b,o({ref:t},s))}));function k(e,t){var n=arguments,r=t&&t.mdxType;if("string"==typeof e||r){var a=n.length,o=new Array(a);o[0]=m;var l={};for(var u in t)hasOwnProperty.call(t,u)&&(l[u]=t[u]);l.originalType=e,l.mdxType="string"==typeof e?e:r,o[1]=l;for(var c=2;c{n.r(t),n.d(t,{assets:()=>u,contentTitle:()=>o,default:()=>p,frontMatter:()=>a,metadata:()=>l,toc:()=>c});var i=n(25773),r=(n(27378),n(35318));const a={sidebar_position:4,title:"Creating a Minikube cluster",description:"Creating a local Minikube-powered Kubernetes cluster.",keywords:["podman desktop","podman","containers","migrating","kubernetes","minikube"],tags:["migrating-to-kubernetes","minikube"]},o="Creating a local Minikube-powered Kubernetes cluster",l={unversionedId:"minikube/creating-a-minikube-cluster",id:"minikube/creating-a-minikube-cluster",title:"Creating a Minikube cluster",description:"Creating a local Minikube-powered Kubernetes cluster.",source:"@site/docs/minikube/creating-a-minikube-cluster.md",sourceDirName:"minikube",slug:"/minikube/creating-a-minikube-cluster",permalink:"/docs/minikube/creating-a-minikube-cluster",draft:!1,editUrl:"https://github.com/containers/podman-desktop/tree/main/website/docs/minikube/creating-a-minikube-cluster.md",tags:[{label:"migrating-to-kubernetes",permalink:"/docs/tags/migrating-to-kubernetes"},{label:"minikube",permalink:"/docs/tags/minikube"}],version:"current",sidebarPosition:4,frontMatter:{sidebar_position:4,title:"Creating a Minikube cluster",description:"Creating a local Minikube-powered Kubernetes cluster.",keywords:["podman desktop","podman","containers","migrating","kubernetes","minikube"],tags:["migrating-to-kubernetes","minikube"]},sidebar:"mySidebar",previous:{title:"Configuring Podman for Minikube",permalink:"/docs/minikube/configuring-podman-for-minikube-on-windows"},next:{title:"Working with your Minikube cluster",permalink:"/docs/minikube/working-with-your-local-minikube-cluster"}},u={},c=[{value:"Prerequisites",id:"prerequisites",level:4},{value:"Procedure",id:"procedure",level:4},{value:"Verification",id:"verification",level:4}],s={toc:c};function p(e){let{components:t,...n}=e;return(0,r.kt)("wrapper",(0,i.Z)({},s,n,{components:t,mdxType:"MDXLayout"}),(0,r.kt)("h1",{id:"creating-a-local-minikube-powered-kubernetes-cluster"},"Creating a local Minikube-powered Kubernetes cluster"),(0,r.kt)("p",null,"You can create multiple local Minikube-powered Kubernetes clusters."),(0,r.kt)("h4",{id:"prerequisites"},"Prerequisites"),(0,r.kt)("ul",null,(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("a",{parentName:"li",href:"/docs/minikube/installing"},"You installed Minikube"),"."),(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("a",{parentName:"li",href:"/docs/minikube/configuring-podman-for-minikube-on-windows"},"On Windows, you configured Podman"),".")),(0,r.kt)("h4",{id:"procedure"},"Procedure"),(0,r.kt)("ol",null,(0,r.kt)("li",{parentName:"ol"},(0,r.kt)("p",{parentName:"li"},"Go to ",(0,r.kt)("strong",{parentName:"p"},(0,r.kt)("icon",{icon:"fa-solid fa-cog",size:"lg"})," Settings > Resources"))),(0,r.kt)("li",{parentName:"ol"},(0,r.kt)("p",{parentName:"li"},"In the Minikube tile, click on the ",(0,r.kt)("strong",{parentName:"p"},"Create new ...")," button.")),(0,r.kt)("li",{parentName:"ol"},(0,r.kt)("p",{parentName:"li"},"Choose your options, and click the ",(0,r.kt)("strong",{parentName:"p"},"Create")," button."),(0,r.kt)("p",{parentName:"li"},"The defaults are:"),(0,r.kt)("ul",{parentName:"li"},(0,r.kt)("li",{parentName:"ul"},"Name: ",(0,r.kt)("inlineCode",{parentName:"li"},"minikube")),(0,r.kt)("li",{parentName:"ul"},"Driver: ",(0,r.kt)("inlineCode",{parentName:"li"},"podman")),(0,r.kt)("li",{parentName:"ul"},"Container runtime: ",(0,r.kt)("inlineCode",{parentName:"li"},"cri-o")))),(0,r.kt)("li",{parentName:"ol"},(0,r.kt)("p",{parentName:"li"},"(Optionally) Click the ",(0,r.kt)("strong",{parentName:"p"},"Show logs")," button to display the logs.")),(0,r.kt)("li",{parentName:"ol"},(0,r.kt)("p",{parentName:"li"},"After successful creation, click on the ",(0,r.kt)("strong",{parentName:"p"},"Go back to resources")," button"))),(0,r.kt)("h4",{id:"verification"},"Verification"),(0,r.kt)("ol",null,(0,r.kt)("li",{parentName:"ol"},"In ",(0,r.kt)("strong",{parentName:"li"},(0,r.kt)("icon",{icon:"fa-solid fa-cog",size:"lg"})," Settings > Resources"),", in the ",(0,r.kt)("strong",{parentName:"li"},"Minikube")," tile, your ",(0,r.kt)("inlineCode",{parentName:"li"},"")," instance is running."),(0,r.kt)("li",{parentName:"ol"},"In the Podman Desktop tray, open the ",(0,r.kt)("strong",{parentName:"li"},"Kubernetes")," menu, you can set the context to your Minikube cluster: ",(0,r.kt)("inlineCode",{parentName:"li"},"minikube"),".")))}p.isMDXComponent=!0}}]); \ No newline at end of file diff --git a/assets/js/2d629ea6.f60fd6be.js b/assets/js/2d629ea6.f60fd6be.js deleted file mode 100644 index d319f85491b..00000000000 --- a/assets/js/2d629ea6.f60fd6be.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[3879],{35318:(e,t,n)=>{n.d(t,{Zo:()=>c,kt:()=>m});var r=n(27378);function o(e,t,n){return t in e?Object.defineProperty(e,t,{value:n,enumerable:!0,configurable:!0,writable:!0}):e[t]=n,e}function a(e,t){var n=Object.keys(e);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(e);t&&(r=r.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),n.push.apply(n,r)}return n}function i(e){for(var t=1;t=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var l=r.createContext({}),p=function(e){var t=r.useContext(l),n=t;return e&&(n="function"==typeof e?e(t):i(i({},t),e)),n},c=function(e){var t=p(e.components);return r.createElement(l.Provider,{value:t},e.children)},u={inlineCode:"code",wrapper:function(e){var t=e.children;return r.createElement(r.Fragment,{},t)}},d=r.forwardRef((function(e,t){var n=e.components,o=e.mdxType,a=e.originalType,l=e.parentName,c=s(e,["components","mdxType","originalType","parentName"]),d=p(n),m=o,k=d["".concat(l,".").concat(m)]||d[m]||u[m]||a;return n?r.createElement(k,i(i({ref:t},c),{},{components:n})):r.createElement(k,i({ref:t},c))}));function m(e,t){var n=arguments,o=t&&t.mdxType;if("string"==typeof e||o){var a=n.length,i=new Array(a);i[0]=d;var s={};for(var l in t)hasOwnProperty.call(t,l)&&(s[l]=t[l]);s.originalType=e,s.mdxType="string"==typeof e?e:o,i[1]=s;for(var p=2;p{n.r(t),n.d(t,{assets:()=>l,contentTitle:()=>i,default:()=>u,frontMatter:()=>a,metadata:()=>s,toc:()=>p});var r=n(25773),o=(n(27378),n(35318));const a={sidebar_position:10,title:"Deploying a container",description:"Deploying a container to Kubernetes",keywords:["podman desktop","podman","containers","migrating","kubernetes"],tags:["migrating-to-kubernetes"]},i="Deploying a container to Kubernetes",s={unversionedId:"kubernetes/deploying-a-container-to-kubernetes",id:"kubernetes/deploying-a-container-to-kubernetes",title:"Deploying a container",description:"Deploying a container to Kubernetes",source:"@site/docs/kubernetes/deploying-a-container-to-kubernetes.md",sourceDirName:"kubernetes",slug:"/kubernetes/deploying-a-container-to-kubernetes",permalink:"/docs/kubernetes/deploying-a-container-to-kubernetes",draft:!1,editUrl:"https://github.com/containers/podman-desktop/tree/main/website/docs/kubernetes/deploying-a-container-to-kubernetes.md",tags:[{label:"migrating-to-kubernetes",permalink:"/docs/tags/migrating-to-kubernetes"}],version:"current",sidebarPosition:10,frontMatter:{sidebar_position:10,title:"Deploying a container",description:"Deploying a container to Kubernetes",keywords:["podman desktop","podman","containers","migrating","kubernetes"],tags:["migrating-to-kubernetes"]},sidebar:"mySidebar",previous:{title:"Selecting a context",permalink:"/docs/kubernetes/viewing-and-selecting-current-kubernete-context"},next:{title:"Deploying a pod",permalink:"/docs/kubernetes/deploying-a-pod-to-kubernetes"}},l={},p=[{value:"Prerequisites",id:"prerequisites",level:4},{value:"Procedure",id:"procedure",level:4},{value:"Verification",id:"verification",level:4}],c={toc:p};function u(e){let{components:t,...a}=e;return(0,o.kt)("wrapper",(0,r.Z)({},c,a,{components:t,mdxType:"MDXLayout"}),(0,o.kt)("h1",{id:"deploying-a-container-to-kubernetes"},"Deploying a container to Kubernetes"),(0,o.kt)("p",null,"With Podman Desktop, you can deploy a container to your Kubernetes cluster."),(0,o.kt)("h4",{id:"prerequisites"},"Prerequisites"),(0,o.kt)("ul",null,(0,o.kt)("li",{parentName:"ul"},"Your are using the Podman container engine."),(0,o.kt)("li",{parentName:"ul"},"Your container, running or stopped, is available on the ",(0,o.kt)("strong",{parentName:"li"},"Containers")," page: ",(0,o.kt)("em",{parentName:"li"},"<","your_container",">"),"."),(0,o.kt)("li",{parentName:"ul"},"You registered the Kubernetes cluster in your kubeconfig file: ",(0,o.kt)("em",{parentName:"li"},"<","your_kubernetes_cluster",">"),". For example, ",(0,o.kt)("a",{parentName:"li",href:"/docs/kind/creating-a-kind-cluster"},"Creating a kind cluster"),"."),(0,o.kt)("li",{parentName:"ul"},"The Kubernetes namespace to deploy to already exists.")),(0,o.kt)("h4",{id:"procedure"},"Procedure"),(0,o.kt)("ol",null,(0,o.kt)("li",{parentName:"ol"},"Click ",(0,o.kt)("strong",{parentName:"li"},"Podman Desktop tray ",">"," Kubernetes ",">"," Context ",">"," ",(0,o.kt)("em",{parentName:"strong"},"<","your_kubernetes_cluster",">"))," to set your Kubernetes context."),(0,o.kt)("li",{parentName:"ol"},"Open ",(0,o.kt)("strong",{parentName:"li"},"Podman Desktop dashboard > ",(0,o.kt)("icon",{icon:"fa-solid fa-cubes",size:"lg"})," Containers > ",(0,o.kt)("em",{parentName:"strong"},"<","your_container",">"))," to see the ",(0,o.kt)("strong",{parentName:"li"},"Container Details")," page."),(0,o.kt)("li",{parentName:"ol"},"Click ",(0,o.kt)("icon",{icon:"fa-solid fa-rocket",size:"lg"})," to generate a Kubernetes pod."),(0,o.kt)("li",{parentName:"ol"},"On the ",(0,o.kt)("strong",{parentName:"li"},"Deploy generated pod to Kubernetes")," screen, choose your options:",(0,o.kt)("ol",{parentName:"li"},(0,o.kt)("li",{parentName:"ol"},(0,o.kt)("strong",{parentName:"li"},"Pod Name"),": edit the proposed name."),(0,o.kt)("li",{parentName:"ol"},(0,o.kt)("strong",{parentName:"li"},"Use Kubernetes Services"),": enable or disable ",(0,o.kt)("strong",{parentName:"li"},"Replace ",(0,o.kt)("inlineCode",{parentName:"strong"},"hostPort")," exposure on containers by Services. It is the recommended way to expose ports, as a cluster policy might prevent to use ",(0,o.kt)("inlineCode",{parentName:"strong"},"hostPort"),".")),(0,o.kt)("li",{parentName:"ol"},(0,o.kt)("strong",{parentName:"li"},"Kubernetes namespace"),": select in the list the namespace to deploy the pod to."))),(0,o.kt)("li",{parentName:"ol"},"Click the ",(0,o.kt)("strong",{parentName:"li"},(0,o.kt)("icon",{icon:"fa-solid fa-rocket",size:"lg"})," Deploy")," button.")),(0,o.kt)("h4",{id:"verification"},"Verification"),(0,o.kt)("ul",null,(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},"On the ",(0,o.kt)("strong",{parentName:"p"},"Deploy generated pod to Kubernetes")," screen, the created pod status is ",(0,o.kt)("em",{parentName:"p"},"Phase: Running")),(0,o.kt)("p",{parentName:"li"},(0,o.kt)("img",{alt:"Deploying a container",src:n(60976).Z,width:"816",height:"715"}))),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},"Go to ",(0,o.kt)("strong",{parentName:"p"},"Containers"),": your pod is in the list."))))}u.isMDXComponent=!0},60976:(e,t,n)=>{n.d(t,{Z:()=>r});const r=n.p+"assets/images/deploying-a-container-8164e9fef034a6ef69ebd4940a325271.png"}}]); \ No newline at end of file diff --git a/assets/js/2d629ea6.f8d34b3d.js b/assets/js/2d629ea6.f8d34b3d.js new file mode 100644 index 00000000000..b2e5cee8849 --- /dev/null +++ b/assets/js/2d629ea6.f8d34b3d.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[3879],{35318:(e,t,n)=>{n.d(t,{Zo:()=>c,kt:()=>m});var r=n(27378);function o(e,t,n){return t in e?Object.defineProperty(e,t,{value:n,enumerable:!0,configurable:!0,writable:!0}):e[t]=n,e}function a(e,t){var n=Object.keys(e);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(e);t&&(r=r.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),n.push.apply(n,r)}return n}function i(e){for(var t=1;t=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var l=r.createContext({}),p=function(e){var t=r.useContext(l),n=t;return e&&(n="function"==typeof e?e(t):i(i({},t),e)),n},c=function(e){var t=p(e.components);return r.createElement(l.Provider,{value:t},e.children)},u={inlineCode:"code",wrapper:function(e){var t=e.children;return r.createElement(r.Fragment,{},t)}},d=r.forwardRef((function(e,t){var n=e.components,o=e.mdxType,a=e.originalType,l=e.parentName,c=s(e,["components","mdxType","originalType","parentName"]),d=p(n),m=o,k=d["".concat(l,".").concat(m)]||d[m]||u[m]||a;return n?r.createElement(k,i(i({ref:t},c),{},{components:n})):r.createElement(k,i({ref:t},c))}));function m(e,t){var n=arguments,o=t&&t.mdxType;if("string"==typeof e||o){var a=n.length,i=new Array(a);i[0]=d;var s={};for(var l in t)hasOwnProperty.call(t,l)&&(s[l]=t[l]);s.originalType=e,s.mdxType="string"==typeof e?e:o,i[1]=s;for(var p=2;p{n.r(t),n.d(t,{assets:()=>l,contentTitle:()=>i,default:()=>m,frontMatter:()=>a,metadata:()=>s,toc:()=>p});var r=n(25773),o=(n(27378),n(35318));const a={sidebar_position:10,title:"Deploying a container",description:"Deploying a container to Kubernetes",keywords:["podman desktop","podman","containers","migrating","kubernetes"],tags:["migrating-to-kubernetes"]},i="Deploying a container to Kubernetes",s={unversionedId:"kubernetes/deploying-a-container-to-kubernetes",id:"kubernetes/deploying-a-container-to-kubernetes",title:"Deploying a container",description:"Deploying a container to Kubernetes",source:"@site/docs/kubernetes/deploying-a-container-to-kubernetes.md",sourceDirName:"kubernetes",slug:"/kubernetes/deploying-a-container-to-kubernetes",permalink:"/docs/kubernetes/deploying-a-container-to-kubernetes",draft:!1,editUrl:"https://github.com/containers/podman-desktop/tree/main/website/docs/kubernetes/deploying-a-container-to-kubernetes.md",tags:[{label:"migrating-to-kubernetes",permalink:"/docs/tags/migrating-to-kubernetes"}],version:"current",sidebarPosition:10,frontMatter:{sidebar_position:10,title:"Deploying a container",description:"Deploying a container to Kubernetes",keywords:["podman desktop","podman","containers","migrating","kubernetes"],tags:["migrating-to-kubernetes"]},sidebar:"mySidebar",previous:{title:"Selecting a context",permalink:"/docs/kubernetes/viewing-and-selecting-current-kubernete-context"},next:{title:"Deploying a pod",permalink:"/docs/kubernetes/deploying-a-pod-to-kubernetes"}},l={},p=[{value:"Prerequisites",id:"prerequisites",level:4},{value:"Procedure",id:"procedure",level:4},{value:"Verification",id:"verification",level:4}],c=(u="Icon",function(e){return console.warn("Component "+u+" was not imported, exported, or provided by MDXProvider as global scope"),(0,o.kt)("div",e)});var u;const d={toc:p};function m(e){let{components:t,...a}=e;return(0,o.kt)("wrapper",(0,r.Z)({},d,a,{components:t,mdxType:"MDXLayout"}),(0,o.kt)("h1",{id:"deploying-a-container-to-kubernetes"},"Deploying a container to Kubernetes"),(0,o.kt)("p",null,"With Podman Desktop, you can deploy a container to your Kubernetes cluster."),(0,o.kt)("h4",{id:"prerequisites"},"Prerequisites"),(0,o.kt)("ul",null,(0,o.kt)("li",{parentName:"ul"},"Your are using the Podman container engine."),(0,o.kt)("li",{parentName:"ul"},"Your container, running or stopped, is available on the ",(0,o.kt)("strong",{parentName:"li"},"Containers")," page: ",(0,o.kt)("em",{parentName:"li"},"<","your_container",">"),"."),(0,o.kt)("li",{parentName:"ul"},"You registered the Kubernetes cluster in your kubeconfig file: ",(0,o.kt)("em",{parentName:"li"},"<","your_kubernetes_cluster",">"),". For example, ",(0,o.kt)("a",{parentName:"li",href:"/docs/kind/creating-a-kind-cluster"},"Creating a kind cluster"),"."),(0,o.kt)("li",{parentName:"ul"},"The Kubernetes namespace to deploy to already exists.")),(0,o.kt)("h4",{id:"procedure"},"Procedure"),(0,o.kt)("ol",null,(0,o.kt)("li",{parentName:"ol"},"Click ",(0,o.kt)("strong",{parentName:"li"},"Podman Desktop tray ",">"," Kubernetes ",">"," Context ",">"," ",(0,o.kt)("em",{parentName:"strong"},"<","your_kubernetes_cluster",">"))," to set your Kubernetes context."),(0,o.kt)("li",{parentName:"ol"},"Open ",(0,o.kt)("strong",{parentName:"li"},"Podman Desktop dashboard > ",(0,o.kt)(c,{icon:"fa-solid fa-cubes",size:"lg",mdxType:"Icon"})," Containers > ",(0,o.kt)("em",{parentName:"strong"},"<","your_container",">"))," to see the ",(0,o.kt)("strong",{parentName:"li"},"Container Details")," page."),(0,o.kt)("li",{parentName:"ol"},"Click ",(0,o.kt)(c,{icon:"fa-solid fa-rocket",size:"lg",mdxType:"Icon"})," to generate a Kubernetes pod."),(0,o.kt)("li",{parentName:"ol"},"On the ",(0,o.kt)("strong",{parentName:"li"},"Deploy generated pod to Kubernetes")," screen, choose your options:",(0,o.kt)("ol",{parentName:"li"},(0,o.kt)("li",{parentName:"ol"},(0,o.kt)("strong",{parentName:"li"},"Pod Name"),": edit the proposed name."),(0,o.kt)("li",{parentName:"ol"},(0,o.kt)("strong",{parentName:"li"},"Use Kubernetes Services"),": enable or disable ",(0,o.kt)("strong",{parentName:"li"},"Replace ",(0,o.kt)("inlineCode",{parentName:"strong"},"hostPort")," exposure on containers by Services. It is the recommended way to expose ports, as a cluster policy might prevent to use ",(0,o.kt)("inlineCode",{parentName:"strong"},"hostPort"),".")),(0,o.kt)("li",{parentName:"ol"},(0,o.kt)("strong",{parentName:"li"},"Kubernetes namespace"),": select in the list the namespace to deploy the pod to."))),(0,o.kt)("li",{parentName:"ol"},"Click the ",(0,o.kt)("strong",{parentName:"li"},(0,o.kt)(c,{icon:"fa-solid fa-rocket",size:"lg",mdxType:"Icon"})," Deploy")," button.")),(0,o.kt)("h4",{id:"verification"},"Verification"),(0,o.kt)("ul",null,(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},"On the ",(0,o.kt)("strong",{parentName:"p"},"Deploy generated pod to Kubernetes")," screen, the created pod status is ",(0,o.kt)("em",{parentName:"p"},"Phase: Running")),(0,o.kt)("p",{parentName:"li"},(0,o.kt)("img",{alt:"Deploying a container",src:n(60976).Z,width:"816",height:"715"}))),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},"Go to ",(0,o.kt)("strong",{parentName:"p"},"Containers"),": your pod is in the list."))))}m.isMDXComponent=!0},60976:(e,t,n)=>{n.d(t,{Z:()=>r});const r=n.p+"assets/images/deploying-a-container-8164e9fef034a6ef69ebd4940a325271.png"}}]); \ No newline at end of file diff --git a/assets/js/330dfcdb.5351f9c1.js b/assets/js/330dfcdb.5351f9c1.js new file mode 100644 index 00000000000..3d15428b7fa --- /dev/null +++ b/assets/js/330dfcdb.5351f9c1.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[4929],{35318:(e,t,n)=>{n.d(t,{Zo:()=>d,kt:()=>c});var r=n(27378);function o(e,t,n){return t in e?Object.defineProperty(e,t,{value:n,enumerable:!0,configurable:!0,writable:!0}):e[t]=n,e}function a(e,t){var n=Object.keys(e);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(e);t&&(r=r.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),n.push.apply(n,r)}return n}function l(e){for(var t=1;t=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var i=r.createContext({}),p=function(e){var t=r.useContext(i),n=t;return e&&(n="function"==typeof e?e(t):l(l({},t),e)),n},d=function(e){var t=p(e.components);return r.createElement(i.Provider,{value:t},e.children)},u={inlineCode:"code",wrapper:function(e){var t=e.children;return r.createElement(r.Fragment,{},t)}},m=r.forwardRef((function(e,t){var n=e.components,o=e.mdxType,a=e.originalType,i=e.parentName,d=s(e,["components","mdxType","originalType","parentName"]),m=p(n),c=o,b=m["".concat(i,".").concat(c)]||m[c]||u[c]||a;return n?r.createElement(b,l(l({ref:t},d),{},{components:n})):r.createElement(b,l({ref:t},d))}));function c(e,t){var n=arguments,o=t&&t.mdxType;if("string"==typeof e||o){var a=n.length,l=new Array(a);l[0]=m;var s={};for(var i in t)hasOwnProperty.call(t,i)&&(s[i]=t[i]);s.originalType=e,s.mdxType="string"==typeof e?e:o,l[1]=s;for(var p=2;p{n.r(t),n.d(t,{assets:()=>i,contentTitle:()=>l,default:()=>c,frontMatter:()=>a,metadata:()=>s,toc:()=>p});var r=n(25773),o=(n(27378),n(35318));const a={title:"Release Notes - Podman Desktop 0.14",description:"Podman Desktop 0.14 has been released!",slug:"podman-desktop-release-0.14",authors:["deboer"],tags:["podman-desktop","release","kubernetes","kind"],hide_table_of_contents:!1},l=void 0,s={permalink:"/blog/podman-desktop-release-0.14",source:"@site/blog/2023-04-14-release-0.14.md",title:"Release Notes - Podman Desktop 0.14",description:"Podman Desktop 0.14 has been released!",date:"2023-04-14T00:00:00.000Z",formattedDate:"April 14, 2023",tags:[{label:"podman-desktop",permalink:"/blog/tags/podman-desktop"},{label:"release",permalink:"/blog/tags/release"},{label:"kubernetes",permalink:"/blog/tags/kubernetes"},{label:"kind",permalink:"/blog/tags/kind"}],readingTime:4.025,hasTruncateMarker:!0,authors:[{name:"Tim deBoer",title:"Architect",url:"https://github.com/deboer-tim",imageURL:"https://github.com/deboer-tim.png",key:"deboer"}],frontMatter:{title:"Release Notes - Podman Desktop 0.14",description:"Podman Desktop 0.14 has been released!",slug:"podman-desktop-release-0.14",authors:["deboer"],tags:["podman-desktop","release","kubernetes","kind"],hide_table_of_contents:!1},prevItem:{title:"Setting up and running a Kubernetes cluster locally with Podman Desktop",permalink:"/blog/running-a-local-kubernetes-cluster-with-podman-desktop"},nextItem:{title:"Release Notes - Podman Desktop 0.13",permalink:"/blog/podman-desktop-release-0.13"}},i={authorsImageUrls:[void 0]},p=[],d=(u="Icon",function(e){return console.warn("Component "+u+" was not imported, exported, or provided by MDXProvider as global scope"),(0,o.kt)("div",e)});var u;const m={toc:p};function c(e){let{components:t,...a}=e;return(0,o.kt)("wrapper",(0,r.Z)({},m,a,{components:t,mdxType:"MDXLayout"}),(0,o.kt)("p",null,"Podman Desktop 0.14 - Our Kind-est release yet!"),(0,o.kt)("p",null,"We have been working on a Kind extension for a while now, and decided it is time to promote it\ninto a release just in time for KubeCon and CloudNativeCon Europe!"),(0,o.kt)("p",null,"We're especially excited about releasing Kind because it finally shows the full purpose\nof Podman Desktop: not just local container engines, but Kubernetes too. More importantly,\nproviding tools that allow you to manage both environments and seamlessly move between them."),(0,o.kt)("p",null,"Some of these features were available in development mode over the last few releases,\nbut since they are now in the release build, we will do a full roundup and talk about\nall the Kind features."),(0,o.kt)("ul",null,(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("strong",{parentName:"li"},"Kind Installation"),": Install Kind from the status bar"),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("strong",{parentName:"li"},"Manage Kind Clusters"),": Create and manage Kind clusters from ",(0,o.kt)("strong",{parentName:"li"},(0,o.kt)(d,{icon:"fa-solid fa-cog",size:"lg",mdxType:"Icon"})," Settings > Resources")),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("strong",{parentName:"li"},"Using Kind"),": Deploying YAML and sharing images to a cluster"),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("strong",{parentName:"li"},"Kind Ingress"),": Install a Contour ingress controller"),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("strong",{parentName:"li"},"UX and UI Improvements"),": Updated preferences and telemetry prompt")),(0,o.kt)("p",null,"Podman Desktop 0.14 is now available. ",(0,o.kt)("a",{parentName:"p",href:"/downloads"},"Click here to download it"),"!"),(0,o.kt)("p",null,(0,o.kt)("img",{alt:"Podman-desktop-0-14-hero",src:n(41767).Z,width:"1140",height:"1097"})))}c.isMDXComponent=!0},41767:(e,t,n)=>{n.d(t,{Z:()=>r});const r=n.p+"assets/images/podman-desktop-release-0.14-5d7adb6814b7191ab2623cdd431642f3.png"}}]); \ No newline at end of file diff --git a/assets/js/330dfcdb.a0707feb.js b/assets/js/330dfcdb.a0707feb.js deleted file mode 100644 index 2c676ccd615..00000000000 --- a/assets/js/330dfcdb.a0707feb.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[4929],{35318:(e,t,n)=>{n.d(t,{Zo:()=>d,kt:()=>c});var r=n(27378);function a(e,t,n){return t in e?Object.defineProperty(e,t,{value:n,enumerable:!0,configurable:!0,writable:!0}):e[t]=n,e}function o(e,t){var n=Object.keys(e);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(e);t&&(r=r.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),n.push.apply(n,r)}return n}function l(e){for(var t=1;t=0||(a[n]=e[n]);return a}(e,t);if(Object.getOwnPropertySymbols){var o=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(a[n]=e[n])}return a}var i=r.createContext({}),p=function(e){var t=r.useContext(i),n=t;return e&&(n="function"==typeof e?e(t):l(l({},t),e)),n},d=function(e){var t=p(e.components);return r.createElement(i.Provider,{value:t},e.children)},u={inlineCode:"code",wrapper:function(e){var t=e.children;return r.createElement(r.Fragment,{},t)}},m=r.forwardRef((function(e,t){var n=e.components,a=e.mdxType,o=e.originalType,i=e.parentName,d=s(e,["components","mdxType","originalType","parentName"]),m=p(n),c=a,b=m["".concat(i,".").concat(c)]||m[c]||u[c]||o;return n?r.createElement(b,l(l({ref:t},d),{},{components:n})):r.createElement(b,l({ref:t},d))}));function c(e,t){var n=arguments,a=t&&t.mdxType;if("string"==typeof e||a){var o=n.length,l=new Array(o);l[0]=m;var s={};for(var i in t)hasOwnProperty.call(t,i)&&(s[i]=t[i]);s.originalType=e,s.mdxType="string"==typeof e?e:a,l[1]=s;for(var p=2;p{n.r(t),n.d(t,{assets:()=>i,contentTitle:()=>l,default:()=>u,frontMatter:()=>o,metadata:()=>s,toc:()=>p});var r=n(25773),a=(n(27378),n(35318));const o={title:"Release Notes - Podman Desktop 0.14",description:"Podman Desktop 0.14 has been released!",slug:"podman-desktop-release-0.14",authors:["deboer"],tags:["podman-desktop","release","kubernetes","kind"],hide_table_of_contents:!1},l=void 0,s={permalink:"/blog/podman-desktop-release-0.14",source:"@site/blog/2023-04-14-release-0.14.md",title:"Release Notes - Podman Desktop 0.14",description:"Podman Desktop 0.14 has been released!",date:"2023-04-14T00:00:00.000Z",formattedDate:"April 14, 2023",tags:[{label:"podman-desktop",permalink:"/blog/tags/podman-desktop"},{label:"release",permalink:"/blog/tags/release"},{label:"kubernetes",permalink:"/blog/tags/kubernetes"},{label:"kind",permalink:"/blog/tags/kind"}],readingTime:4.025,hasTruncateMarker:!0,authors:[{name:"Tim deBoer",title:"Architect",url:"https://github.com/deboer-tim",imageURL:"https://github.com/deboer-tim.png",key:"deboer"}],frontMatter:{title:"Release Notes - Podman Desktop 0.14",description:"Podman Desktop 0.14 has been released!",slug:"podman-desktop-release-0.14",authors:["deboer"],tags:["podman-desktop","release","kubernetes","kind"],hide_table_of_contents:!1},prevItem:{title:"Setting up and running a Kubernetes cluster locally with Podman Desktop",permalink:"/blog/running-a-local-kubernetes-cluster-with-podman-desktop"},nextItem:{title:"Release Notes - Podman Desktop 0.13",permalink:"/blog/podman-desktop-release-0.13"}},i={authorsImageUrls:[void 0]},p=[],d={toc:p};function u(e){let{components:t,...o}=e;return(0,a.kt)("wrapper",(0,r.Z)({},d,o,{components:t,mdxType:"MDXLayout"}),(0,a.kt)("p",null,"Podman Desktop 0.14 - Our Kind-est release yet!"),(0,a.kt)("p",null,"We have been working on a Kind extension for a while now, and decided it is time to promote it\ninto a release just in time for KubeCon and CloudNativeCon Europe!"),(0,a.kt)("p",null,"We're especially excited about releasing Kind because it finally shows the full purpose\nof Podman Desktop: not just local container engines, but Kubernetes too. More importantly,\nproviding tools that allow you to manage both environments and seamlessly move between them."),(0,a.kt)("p",null,"Some of these features were available in development mode over the last few releases,\nbut since they are now in the release build, we will do a full roundup and talk about\nall the Kind features."),(0,a.kt)("ul",null,(0,a.kt)("li",{parentName:"ul"},(0,a.kt)("strong",{parentName:"li"},"Kind Installation"),": Install Kind from the status bar"),(0,a.kt)("li",{parentName:"ul"},(0,a.kt)("strong",{parentName:"li"},"Manage Kind Clusters"),": Create and manage Kind clusters from ",(0,a.kt)("strong",{parentName:"li"},(0,a.kt)("icon",{icon:"fa-solid fa-cog",size:"lg"})," Settings > Resources")),(0,a.kt)("li",{parentName:"ul"},(0,a.kt)("strong",{parentName:"li"},"Using Kind"),": Deploying YAML and sharing images to a cluster"),(0,a.kt)("li",{parentName:"ul"},(0,a.kt)("strong",{parentName:"li"},"Kind Ingress"),": Install a Contour ingress controller"),(0,a.kt)("li",{parentName:"ul"},(0,a.kt)("strong",{parentName:"li"},"UX and UI Improvements"),": Updated preferences and telemetry prompt")),(0,a.kt)("p",null,"Podman Desktop 0.14 is now available. ",(0,a.kt)("a",{parentName:"p",href:"/downloads"},"Click here to download it"),"!"),(0,a.kt)("p",null,(0,a.kt)("img",{alt:"Podman-desktop-0-14-hero",src:n(41767).Z,width:"1140",height:"1097"})))}u.isMDXComponent=!0},41767:(e,t,n)=>{n.d(t,{Z:()=>r});const r=n.p+"assets/images/podman-desktop-release-0.14-5d7adb6814b7191ab2623cdd431642f3.png"}}]); \ No newline at end of file diff --git a/assets/js/33a21d7d.993d4689.js b/assets/js/33a21d7d.993d4689.js new file mode 100644 index 00000000000..cc1dd03be78 --- /dev/null +++ b/assets/js/33a21d7d.993d4689.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[3152],{35318:(g,A,I)=>{I.d(A,{Zo:()=>a,kt:()=>s});var C=I(27378);function e(g,A,I){return A in g?Object.defineProperty(g,A,{value:I,enumerable:!0,configurable:!0,writable:!0}):g[A]=I,g}function n(g,A){var I=Object.keys(g);if(Object.getOwnPropertySymbols){var C=Object.getOwnPropertySymbols(g);A&&(C=C.filter((function(A){return Object.getOwnPropertyDescriptor(g,A).enumerable}))),I.push.apply(I,C)}return I}function t(g){for(var A=1;A=0||(e[I]=g[I]);return e}(g,A);if(Object.getOwnPropertySymbols){var n=Object.getOwnPropertySymbols(g);for(C=0;C=0||Object.prototype.propertyIsEnumerable.call(g,I)&&(e[I]=g[I])}return e}var r=C.createContext({}),o=function(g){var A=C.useContext(r),I=A;return g&&(I="function"==typeof g?g(A):t(t({},A),g)),I},a=function(g){var A=o(g.components);return C.createElement(r.Provider,{value:A},g.children)},l={inlineCode:"code",wrapper:function(g){var A=g.children;return C.createElement(C.Fragment,{},A)}},c=C.forwardRef((function(g,A){var I=g.components,e=g.mdxType,n=g.originalType,r=g.parentName,a=i(g,["components","mdxType","originalType","parentName"]),c=o(I),s=e,u=c["".concat(r,".").concat(s)]||c[s]||l[s]||n;return I?C.createElement(u,t(t({ref:A},a),{},{components:I})):C.createElement(u,t({ref:A},a))}));function s(g,A){var I=arguments,e=A&&A.mdxType;if("string"==typeof g||e){var n=I.length,t=new Array(n);t[0]=c;var i={};for(var r in A)hasOwnProperty.call(A,r)&&(i[r]=A[r]);i.originalType=g,i.mdxType="string"==typeof g?g:e,t[1]=i;for(var o=2;o{I.r(A),I.d(A,{assets:()=>r,contentTitle:()=>t,default:()=>s,frontMatter:()=>n,metadata:()=>i,toc:()=>o});var C=I(25773),e=(I(27378),I(35318));const n={sidebar_position:2,title:"Installing the `minikube` CLI",description:"Minikube is one way to get Kubernetes running on your workstation.",keywords:["podman desktop","podman","containers","migrating","kubernetes","minikube"],tags:["migrating-to-kubernetes","minikube"]},t="Installing the minikube CLI",i={unversionedId:"minikube/installing",id:"minikube/installing",title:"Installing the `minikube` CLI",description:"Minikube is one way to get Kubernetes running on your workstation.",source:"@site/docs/minikube/installing.md",sourceDirName:"minikube",slug:"/minikube/installing",permalink:"/docs/minikube/installing",draft:!1,editUrl:"https://github.com/containers/podman-desktop/tree/main/website/docs/minikube/installing.md",tags:[{label:"migrating-to-kubernetes",permalink:"/docs/tags/migrating-to-kubernetes"},{label:"minikube",permalink:"/docs/tags/minikube"}],version:"current",sidebarPosition:2,frontMatter:{sidebar_position:2,title:"Installing the `minikube` CLI",description:"Minikube is one way to get Kubernetes running on your workstation.",keywords:["podman desktop","podman","containers","migrating","kubernetes","minikube"],tags:["migrating-to-kubernetes","minikube"]},sidebar:"mySidebar",previous:{title:"Minikube",permalink:"/docs/minikube/"},next:{title:"Configuring Podman for Minikube",permalink:"/docs/minikube/configuring-podman-for-minikube-on-windows"}},r={},o=[{value:"Procedure",id:"procedure",level:4},{value:"Verification",id:"verification",level:4}],a=(l="Icon",function(g){return console.warn("Component "+l+" was not imported, exported, or provided by MDXProvider as global scope"),(0,e.kt)("div",g)});var l;const c={toc:o};function s(g){let{components:A,...n}=g;return(0,e.kt)("wrapper",(0,C.Z)({},c,n,{components:A,mdxType:"MDXLayout"}),(0,e.kt)("h1",{id:"installing-the-minikube-cli"},"Installing the ",(0,e.kt)("inlineCode",{parentName:"h1"},"minikube")," CLI"),(0,e.kt)("h4",{id:"procedure"},"Procedure"),(0,e.kt)("ul",null,(0,e.kt)("li",{parentName:"ul"},"In the status bar, click on ",(0,e.kt)("strong",{parentName:"li"},"Minikube"),", and follow the prompts.\n",(0,e.kt)("img",{alt:"Minikube in the status bar",src:I(46232).Z,width:"193",height:"43"}))),(0,e.kt)("h4",{id:"verification"},"Verification"),(0,e.kt)("ol",null,(0,e.kt)("li",{parentName:"ol"},(0,e.kt)("p",{parentName:"li"},"The status bar doesn't display ",(0,e.kt)("strong",{parentName:"p"},"Minikube"),".")),(0,e.kt)("li",{parentName:"ol"},(0,e.kt)("p",{parentName:"li"},(0,e.kt)("strong",{parentName:"p"},(0,e.kt)(a,{icon:"fa-solid fa-cog",size:"lg",mdxType:"Icon"})," Settings > Resources")," contain a ",(0,e.kt)("strong",{parentName:"p"},"Minikube")," tile.\n",(0,e.kt)("img",{alt:"Minikube resource tile",src:I(82491).Z,width:"302",height:"247"}))),(0,e.kt)("li",{parentName:"ol"},(0,e.kt)("p",{parentName:"li"},"You can run the ",(0,e.kt)("inlineCode",{parentName:"p"},"minikube")," CLI:"),(0,e.kt)("pre",{parentName:"li"},(0,e.kt)("code",{parentName:"pre",className:"language-shell-session"},"$ minikube profile list\n")))))}s.isMDXComponent=!0},82491:(g,A,I)=>{I.d(A,{Z:()=>C});const C=I.p+"assets/images/minikube-resource-db4c28c5a3d6060cd135cbd8f2d49266.png"},46232:(g,A,I)=>{I.d(A,{Z:()=>C});const C="data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAMEAAAArCAYAAADBnex4AAAAwnpUWHRSYXcgcHJvZmlsZSB0eXBlIGV4aWYAAHjabVBbDsMgDPvnFDsCJIGG49DHpN1gx58hqVbWWcJxHjKBcLxfz/DooCRB8qKllhIBqVKpQWg0tMEpyuCBzSPyqR5o9QahxIhsqRafP+tfAwsNKl+MdPPGOjequL/+GJEF7ht1vbtRdSMmayQ3aPasWKou1yesR5yhdkIn0XntW77g9/aMe5jo4MQRzCy2APfDgRtEBhMXDKahMQSGdjN8yL9/OhE+awtZc/Z2Pf0AAAGEaUNDUElDQyBwcm9maWxlAAB4nH2RPUjDQBzFX1uLIi0OdpDiEKF2siAq4qhVKEKFUCu06mBy6Rc0aUhSXBwF14KDH4tVBxdnXR1cBUHwA8TVxUnRRUr8X1JoEePBcT/e3XvcvQP8zSpTzZ5xQNUsI5NKCrn8qtD7iiCiCGMEcYmZ+pwopuE5vu7h4+tdgmd5n/tzhJWCyQCfQDzLdMMi3iCe3rR0zvvEEVaWFOJz4jGDLkj8yHXZ5TfOJYf9PDNiZDPzxBFiodTFchezsqESTxHHFFWjfH/OZYXzFme1Wmfte/IXhgrayjLXaQ4jhUUsQYQAGXVUUIWFBK0aKSYytJ/08Ecdv0gumVwVMHIsoAYVkuMH/4Pf3ZrFyQk3KZQEgi+2/TEK9O4CrYZtfx/bdusECDwDV1rHX2sCM5+kNzpa7AgY2AYurjuavAdc7gBDT7pkSI4UoOkvFoH3M/qmPDB4C/Svub2193H6AGSpq/QNcHAIxEuUve7x7r7u3v490+7vB5EVcrPIAHuvAAANeGlUWHRYTUw6Y29tLmFkb2JlLnhtcAAAAAAAPD94cGFja2V0IGJlZ2luPSLvu78iIGlkPSJXNU0wTXBDZWhpSHpyZVN6TlRjemtjOWQiPz4KPHg6eG1wbWV0YSB4bWxuczp4PSJhZG9iZTpuczptZXRhLyIgeDp4bXB0az0iWE1QIENvcmUgNC40LjAtRXhpdjIiPgogPHJkZjpSREYgeG1sbnM6cmRmPSJodHRwOi8vd3d3LnczLm9yZy8xOTk5LzAyLzIyLXJkZi1zeW50YXgtbnMjIj4KICA8cmRmOkRlc2NyaXB0aW9uIHJkZjphYm91dD0iIgogICAgeG1sbnM6eG1wTU09Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC9tbS8iCiAgICB4bWxuczpzdEV2dD0iaHR0cDovL25zLmFkb2JlLmNvbS94YXAvMS4wL3NUeXBlL1Jlc291cmNlRXZlbnQjIgogICAgeG1sbnM6ZGM9Imh0dHA6Ly9wdXJsLm9yZy9kYy9lbGVtZW50cy8xLjEvIgogICAgeG1sbnM6R0lNUD0iaHR0cDovL3d3dy5naW1wLm9yZy94bXAvIgogICAgeG1sbnM6dGlmZj0iaHR0cDovL25zLmFkb2JlLmNvbS90aWZmLzEuMC8iCiAgICB4bWxuczp4bXA9Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC8iCiAgIHhtcE1NOkRvY3VtZW50SUQ9ImdpbXA6ZG9jaWQ6Z2ltcDozZDM4ZTFlYi1hOTA2LTQ2YWUtYTM2OS04OWYxYjIyMGI3ZjEiCiAgIHhtcE1NOkluc3RhbmNlSUQ9InhtcC5paWQ6NWJjYjQ5ZGYtYjY3Ny00NDk0LWI4MWQtZTVjZjFhZDVmYTkxIgogICB4bXBNTTpPcmlnaW5hbERvY3VtZW50SUQ9InhtcC5kaWQ6ZDk4NzZiMTItNGRkMy00YTU2LTk1ZWItNTYwZGE1YzA1ODc2IgogICBkYzpGb3JtYXQ9ImltYWdlL3BuZyIKICAgR0lNUDpBUEk9IjIuMCIKICAgR0lNUDpQbGF0Zm9ybT0iTGludXgiCiAgIEdJTVA6VGltZVN0YW1wPSIxNjg1MTA4MDU1MjA1MjEzIgogICBHSU1QOlZlcnNpb249IjIuMTAuMzQiCiAgIHRpZmY6T3JpZW50YXRpb249IjEiCiAgIHhtcDpDcmVhdG9yVG9vbD0iR0lNUCAyLjEwIgogICB4bXA6TWV0YWRhdGFEYXRlPSIyMDIzOjA1OjI2VDE1OjM0OjE1KzAyOjAwIgogICB4bXA6TW9kaWZ5RGF0ZT0iMjAyMzowNToyNlQxNTozNDoxNSswMjowMCI+CiAgIDx4bXBNTTpIaXN0b3J5PgogICAgPHJkZjpTZXE+CiAgICAgPHJkZjpsaQogICAgICBzdEV2dDphY3Rpb249InNhdmVkIgogICAgICBzdEV2dDpjaGFuZ2VkPSIvIgogICAgICBzdEV2dDppbnN0YW5jZUlEPSJ4bXAuaWlkOjE5OTI1NDdmLWRlNzItNGE0Yi1hYzNjLWI5MWFhMGJhYTZlMiIKICAgICAgc3RFdnQ6c29mdHdhcmVBZ2VudD0iR2ltcCAyLjEwIChMaW51eCkiCiAgICAgIHN0RXZ0OndoZW49IjIwMjMtMDUtMjZUMTU6MzQ6MTUrMDI6MDAiLz4KICAgIDwvcmRmOlNlcT4KICAgPC94bXBNTTpIaXN0b3J5PgogIDwvcmRmOkRlc2NyaXB0aW9uPgogPC9yZGY6UkRGPgo8L3g6eG1wbWV0YT4KICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgIAo8P3hwYWNrZXQgZW5kPSJ3Ij8+gnF+SAAAAAZiS0dEAP8A/wD/oL2nkwAAAAlwSFlzAAALEwAACxMBAJqcGAAAAAd0SU1FB+cFGg0iDw8EcfMAAAwsSURBVHja7Z13XJRHGse/u3QEBSkKCEGNIiAiUkRdRYpZFVREDCXSUQSN0VgiGiSCJnfJxVw0p55dgyXGcheseFETjVERTWKsOTsSxSgSEFbq/UHcu5VlKcIq5/v9fPiDmXdm3p2Z38zzPDMLot5dRlcjIPASIxa6QEAQgYCAIAIBAUEEAgKCCAQEXmY0n1fDXbvbIPFy4V5+AVl7jlFRXiGMhsDLIwKJtyufrkhGLK7ZiMaGSxn/xjwqKiqFERH4/zeHdPV0mLcwUS4AgN5u9oREDBdGQ+DlEEH8pGDMOrSvlZ4w5XWM27cVRkTg/1sElp3MiYgbqTTPsG0bkqaFCSPyjJiYGjHIxw0DQ321tWlja4GXr7vgEzSEt+dEo62tVWd+UOgQvty4n8sXr6vtnbx83ZEM7gPAj6cvsWvn4UaV95V64ilxBuB09nn2fnVEIX9uegK+Uk8WfbC+0XXXhZ1DZz5eOov8uw+YHJtOySOZPO+L3YswMTVipE8SxUUlLd5/tl2s2HlgCfl37vPN19nCTqAKt76O+Eo9Vb+MWMzMlFi1dkBP524Eh0sJDpfyTmo8bQz0Gr6CaGnyTmq8vHwfd4da/k9wuBRjk3aERjWfzzN81CCsrDvg4mZPHw9HYftrDSIQiUTMnBfXMLF49qxXLC2FgaE+r48b1uDnR4werNS/eYKs9DE7thyg4MHvbNu4v9nec1/mEfJy8/npzGV+OHVBmMWtQQRjwl6jew/bBj8/LTlKpdnUEhw9fBqAN2ICGtS2SCQiakIgACeO/VTnc+lzl+HjHs0/vvy62d71ws9X8feaSFTwbLWYPIIInhFDQ/1GO7xW1h2IiB+l1o64eO4q331zBhNTI0aN9an3eb+h/XilsyUXfr7KsW/OCDNJEEHdJLwVUiv0mbEmE/9BCfKfscOn1lrR4hKDMDM3VmtnrFq6DYDI+ECFcwxlRCeMVigj0Hpp0eiQbRcrQpTY2L9cukHe7XsKacVFJQphPT19XabMiiBlxmK1dcYPpy6Qc/Icrh6OSAMG1Ir0PMFzgDMOTl25+u9cDu4/TqSKXSssyh/nPnZs25zFqeM/y9P79u/F6BA/TmdfYGvGXnq5dCc0cjjde9iioanBL5dusDVjn0KZJ5iZGzN9bgyFD4v4IHVloz5j1IRA7B27cOWXW6z87MuaBScpmG52Nmxat4ufzlxWWm6Alwsjgrw5+f1Zdmw5UGf9llZmBIUOoZeLHfoGetzJ+41DWSfYl3mEysqqBgVQRo31xc6hMzo62uTevMPX+47z1faDLXajoEV3gulzY9DU0lRqIilzSp/GP9CLns7d1Lsb/G2bwkqvjJiJQQCsWba93vqc+9ghDZBgbdNRId3a1gJpgATnPnZExI1k7db38ejfC7GGGMtO5gwZ1p+VG9OISwquVWcbA32kARIG+3k06rPNfm88U9+JpJNNR7Zm7JWnu/friTRAgoWVucoFTRogUTkeI8d4sz1rCXFJwbi4O+Do9Cq+Uk8WfPwWWzIXYWXdoc6yWtqaLFw0lZWb0gkYPRgLSzMMDPXpP8iFlPcT+WKX6vIvpAgk3q7y+Ht9E14kEikNTYpEImY1MKrUXBw/+iPnzv6b7j1skXi71sp3dHoVj/5O3L51l32ZR565PRd3ewJf9yMuLAW/vrEEvTYFb7coNq/fDcDk6eF49Hd6tkEWi0n7aAohEcPI/v4sE8bNo/BhcbP2W3tTI5LTEvh81T8Z4Z2Iu91Y+tqH8Gb8Qi5fvM6rdjas2bKgzlsBf/rr2wwfNYgrl28SF/ouA3uPw9cjBn+vifxr3/d06WbNqk3ptG1n0DpEoKmpwfQ50XXmGxi2eWpl00MkEil91ql3d/wDvdQqhNVLa1b42D9W/P8lNrEmbe3fdzZoe693AERi4kLnKoQ6Sx7J+DBtNSePna0xqSL9mz4WWpp89NkMRgQN5vC/TjI5doHC4VpzUV1VTVLUfJZ+spncm3cBKCsr5+ihHKLGzOZ09nnMO5owfW5MrbLSAAk+Uk/y79wnLuxdTmefl+fl5eYzc9JHfHvwFB0tTXlzxhutQwShkcOx7WKlQgT69ZpC/8tbsyLQ1dNRmwgOZZ3gyuWbuLjZ09vNXp7+SmdLBg/x4F5+AV9tP9gsbeWcPMfDgiKleZvW7QLAzrFzk+rW1dVmyaq5+Eg92bXzMDOSPqSsrLxF+qzgQSFn6jizkMnKSJ76CWVl5QwdMbDW2UpEfM1Vmj/NX1XnDpWWvJSK8gpGBvugp6/7YovAuH1bEqaEqHymsSIw69Ce+KQx6t0Nlu2otRvETAxCLBazYeU/KC9r+e8/XL96u6Z/DBp/D8jAUJ9l61PxlDizef1uUmYsbpadq6nk37nPtwdPoaEhZsAgF3m6kbEhDj27UvJIxpFDOXWWv//bQ37IuYi2thZ93O1f7OjQpLfD653UT+cbPmUeKWNc3Eh2bDlQK6rUUuzfdZTEqaEM9Halm90rFBYW4z9qEA8Liti2OUst71Ba+ljuGzWWRctm09HSlHV/38mnH37+QoQiL567ht/QftjYWsjTrKw7IBKJ0NTS4Ms9n6gsb2JqBKDSgX/uIujew5bRIX71h047W9G5aycey2oG2bVv/fdfdHS0mTYnmpmTPlLLgFVVVbFuxU5SFiYSMzGIB/cfoqmlyca1mcj+mJwvMk/MHhd3B9oY6PGouPT5v9PjMgC0dbQUfBaAwofFdZpTT5N7886LK4JZ8+LqPWQC6Ghpyo6sxRQ8+B1DQ32lYVRl+A3th1tfR06dOKeWQftq+yES3nyd1/wHUF5WTnFRCV9s2ENrYNabfyH5vfE4u/Zg2fpUkqLT6r1i0ZCxexYsO9Ws4PfyC+Rp9+4+AOCxrIy05KXPpa+a7VP7De3XoBUd4PfCYuLDUvBxj2agS0SjrhjPTIlrknnQFCrKK9iw6p9oaIjR1dNh68Z9FLWSuzolj0pJjE7jzKkLOPXuzvIN7yk9n6lZocsVJmlLoKEhZpCPGwCnTypGf37Nu0cnmw7YOXRuvSLQ1tZiWnJUg59fsWQrOSdrVnNZ6WPS5izlwf3Chplc9rYEhQ5RWwdt35xFwf1CZLIyMtZk0pooLZExKSad09nncez1Kss/n49h29r+160bNeaFxMulzrosrMxUtqWnr6vSF4wcH4hlJ3N+uXSDsz8onko/uWE7a14cmpoarVMEkeNHNWoVuXbltsLv5WUV5OXmN9z5nhZW56rW3MhkZWxcu6vmSnQDhfoiCiHn5DkcnLqyImN+rQOnrD3fATXf9Q6NrP29h8Cxvox9Y6jKdgzbtmH5hvcUnN4nJlZ0wmgmTw+nsrKKD9NW1yq7ad0urly+SR93Bz5ZPhtjk3YK+SKRiGEjB/LnxdMbbDqr1ScwMzdWeqikCk+JM8e+/e/NS1MzY7p2s25weWOTdkyYEsLHC9eqZSJ9kbG32WPT6kRW+pjJsQv4bPW7uPZ1ZEXGfBIiUuUx+R9zLrJ9cxZjwl7jndR4hgZIyMk+j6amBu6eThi1NyRjTabKcb539wEV5RXsPLCEM9kXuHYlFz19Xdz69qSDhQkVFZWkz1mq9C6UTFbGlPHv87e1KUi8XdnzzXKOH/2RvNv3aGdkgKuHIx0tTamsrCJr93d8vf/4iyWCxGlhjZ4g4dEBPCou4cDe7zE3b8+05KhG1xEaMYzN63c3agdpKsVFJa3+3n6NENJZvGou7v2cWLExjYRxqfKDugXvLif31l2ixgfi7NoDZ9ceVFRUcijrBJNj0xk2cmC9O+aEcanEJY1hbLhU7h9WVFRy9FAOny3axKXz1+osn5ebT/iomcRODGJ0iB+Dh3go1H1gzzFWL9uuso6mInrWP81+OGcD7YwMnsvAfpC6UuEimEAz2MdiMTa2FmhpaZJ3O79JoVWxWIyFlRk6Olr8mvcbpSWNu6YhEomwfqUjxu3bUlxcyo1reS36x9meeScoeVT63ERQXPRImLXNTFVVlfyk+lnquH3rbpPLV1dXc/P6r9y8/mvrcIyXf7qF6mr1/5+PyxevczDrhDBrBZ6/OQQ114vd+zuhq6vd4i9cXV3Nnbzf2Jd5lMd/nEAKCDx3EQgItGo/SOgCAUEEAgKCCAQEBBEICAgiEBAQRCAgIIhAQODl5T8fAA0jNG++OQAAAABJRU5ErkJggg=="}}]); \ No newline at end of file diff --git a/assets/js/33a21d7d.fbbea2a5.js b/assets/js/33a21d7d.fbbea2a5.js deleted file mode 100644 index e5ef3eb5a17..00000000000 --- a/assets/js/33a21d7d.fbbea2a5.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[3152],{35318:(g,A,I)=>{I.d(A,{Zo:()=>a,kt:()=>u});var C=I(27378);function e(g,A,I){return A in g?Object.defineProperty(g,A,{value:I,enumerable:!0,configurable:!0,writable:!0}):g[A]=I,g}function n(g,A){var I=Object.keys(g);if(Object.getOwnPropertySymbols){var C=Object.getOwnPropertySymbols(g);A&&(C=C.filter((function(A){return Object.getOwnPropertyDescriptor(g,A).enumerable}))),I.push.apply(I,C)}return I}function i(g){for(var A=1;A=0||(e[I]=g[I]);return e}(g,A);if(Object.getOwnPropertySymbols){var n=Object.getOwnPropertySymbols(g);for(C=0;C=0||Object.prototype.propertyIsEnumerable.call(g,I)&&(e[I]=g[I])}return e}var r=C.createContext({}),o=function(g){var A=C.useContext(r),I=A;return g&&(I="function"==typeof g?g(A):i(i({},A),g)),I},a=function(g){var A=o(g.components);return C.createElement(r.Provider,{value:A},g.children)},l={inlineCode:"code",wrapper:function(g){var A=g.children;return C.createElement(C.Fragment,{},A)}},c=C.forwardRef((function(g,A){var I=g.components,e=g.mdxType,n=g.originalType,r=g.parentName,a=t(g,["components","mdxType","originalType","parentName"]),c=o(I),u=e,s=c["".concat(r,".").concat(u)]||c[u]||l[u]||n;return I?C.createElement(s,i(i({ref:A},a),{},{components:I})):C.createElement(s,i({ref:A},a))}));function u(g,A){var I=arguments,e=A&&A.mdxType;if("string"==typeof g||e){var n=I.length,i=new Array(n);i[0]=c;var t={};for(var r in A)hasOwnProperty.call(A,r)&&(t[r]=A[r]);t.originalType=g,t.mdxType="string"==typeof g?g:e,i[1]=t;for(var o=2;o{I.r(A),I.d(A,{assets:()=>r,contentTitle:()=>i,default:()=>l,frontMatter:()=>n,metadata:()=>t,toc:()=>o});var C=I(25773),e=(I(27378),I(35318));const n={sidebar_position:2,title:"Installing the `minikube` CLI",description:"Minikube is one way to get Kubernetes running on your workstation.",keywords:["podman desktop","podman","containers","migrating","kubernetes","minikube"],tags:["migrating-to-kubernetes","minikube"]},i="Installing the minikube CLI",t={unversionedId:"minikube/installing",id:"minikube/installing",title:"Installing the `minikube` CLI",description:"Minikube is one way to get Kubernetes running on your workstation.",source:"@site/docs/minikube/installing.md",sourceDirName:"minikube",slug:"/minikube/installing",permalink:"/docs/minikube/installing",draft:!1,editUrl:"https://github.com/containers/podman-desktop/tree/main/website/docs/minikube/installing.md",tags:[{label:"migrating-to-kubernetes",permalink:"/docs/tags/migrating-to-kubernetes"},{label:"minikube",permalink:"/docs/tags/minikube"}],version:"current",sidebarPosition:2,frontMatter:{sidebar_position:2,title:"Installing the `minikube` CLI",description:"Minikube is one way to get Kubernetes running on your workstation.",keywords:["podman desktop","podman","containers","migrating","kubernetes","minikube"],tags:["migrating-to-kubernetes","minikube"]},sidebar:"mySidebar",previous:{title:"Minikube",permalink:"/docs/minikube/"},next:{title:"Configuring Podman for Minikube",permalink:"/docs/minikube/configuring-podman-for-minikube-on-windows"}},r={},o=[{value:"Procedure",id:"procedure",level:4},{value:"Verification",id:"verification",level:4}],a={toc:o};function l(g){let{components:A,...n}=g;return(0,e.kt)("wrapper",(0,C.Z)({},a,n,{components:A,mdxType:"MDXLayout"}),(0,e.kt)("h1",{id:"installing-the-minikube-cli"},"Installing the ",(0,e.kt)("inlineCode",{parentName:"h1"},"minikube")," CLI"),(0,e.kt)("h4",{id:"procedure"},"Procedure"),(0,e.kt)("ul",null,(0,e.kt)("li",{parentName:"ul"},"In the status bar, click on ",(0,e.kt)("strong",{parentName:"li"},"Minikube"),", and follow the prompts.\n",(0,e.kt)("img",{alt:"Minikube in the status bar",src:I(46232).Z,width:"193",height:"43"}))),(0,e.kt)("h4",{id:"verification"},"Verification"),(0,e.kt)("ol",null,(0,e.kt)("li",{parentName:"ol"},(0,e.kt)("p",{parentName:"li"},"The status bar doesn't display ",(0,e.kt)("strong",{parentName:"p"},"Minikube"),".")),(0,e.kt)("li",{parentName:"ol"},(0,e.kt)("p",{parentName:"li"},(0,e.kt)("strong",{parentName:"p"},(0,e.kt)("icon",{icon:"fa-solid fa-cog",size:"lg"})," Settings > Resources")," contain a ",(0,e.kt)("strong",{parentName:"p"},"Minikube")," tile.\n",(0,e.kt)("img",{alt:"Minikube resource tile",src:I(82491).Z,width:"302",height:"247"}))),(0,e.kt)("li",{parentName:"ol"},(0,e.kt)("p",{parentName:"li"},"You can run the ",(0,e.kt)("inlineCode",{parentName:"p"},"minikube")," CLI:"),(0,e.kt)("pre",{parentName:"li"},(0,e.kt)("code",{parentName:"pre",className:"language-shell-session"},"$ minikube profile list\n")))))}l.isMDXComponent=!0},82491:(g,A,I)=>{I.d(A,{Z:()=>C});const C=I.p+"assets/images/minikube-resource-db4c28c5a3d6060cd135cbd8f2d49266.png"},46232:(g,A,I)=>{I.d(A,{Z:()=>C});const C="data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAMEAAAArCAYAAADBnex4AAAAwnpUWHRSYXcgcHJvZmlsZSB0eXBlIGV4aWYAAHjabVBbDsMgDPvnFDsCJIGG49DHpN1gx58hqVbWWcJxHjKBcLxfz/DooCRB8qKllhIBqVKpQWg0tMEpyuCBzSPyqR5o9QahxIhsqRafP+tfAwsNKl+MdPPGOjequL/+GJEF7ht1vbtRdSMmayQ3aPasWKou1yesR5yhdkIn0XntW77g9/aMe5jo4MQRzCy2APfDgRtEBhMXDKahMQSGdjN8yL9/OhE+awtZc/Z2Pf0AAAGEaUNDUElDQyBwcm9maWxlAAB4nH2RPUjDQBzFX1uLIi0OdpDiEKF2siAq4qhVKEKFUCu06mBy6Rc0aUhSXBwF14KDH4tVBxdnXR1cBUHwA8TVxUnRRUr8X1JoEePBcT/e3XvcvQP8zSpTzZ5xQNUsI5NKCrn8qtD7iiCiCGMEcYmZ+pwopuE5vu7h4+tdgmd5n/tzhJWCyQCfQDzLdMMi3iCe3rR0zvvEEVaWFOJz4jGDLkj8yHXZ5TfOJYf9PDNiZDPzxBFiodTFchezsqESTxHHFFWjfH/OZYXzFme1Wmfte/IXhgrayjLXaQ4jhUUsQYQAGXVUUIWFBK0aKSYytJ/08Ecdv0gumVwVMHIsoAYVkuMH/4Pf3ZrFyQk3KZQEgi+2/TEK9O4CrYZtfx/bdusECDwDV1rHX2sCM5+kNzpa7AgY2AYurjuavAdc7gBDT7pkSI4UoOkvFoH3M/qmPDB4C/Svub2193H6AGSpq/QNcHAIxEuUve7x7r7u3v490+7vB5EVcrPIAHuvAAANeGlUWHRYTUw6Y29tLmFkb2JlLnhtcAAAAAAAPD94cGFja2V0IGJlZ2luPSLvu78iIGlkPSJXNU0wTXBDZWhpSHpyZVN6TlRjemtjOWQiPz4KPHg6eG1wbWV0YSB4bWxuczp4PSJhZG9iZTpuczptZXRhLyIgeDp4bXB0az0iWE1QIENvcmUgNC40LjAtRXhpdjIiPgogPHJkZjpSREYgeG1sbnM6cmRmPSJodHRwOi8vd3d3LnczLm9yZy8xOTk5LzAyLzIyLXJkZi1zeW50YXgtbnMjIj4KICA8cmRmOkRlc2NyaXB0aW9uIHJkZjphYm91dD0iIgogICAgeG1sbnM6eG1wTU09Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC9tbS8iCiAgICB4bWxuczpzdEV2dD0iaHR0cDovL25zLmFkb2JlLmNvbS94YXAvMS4wL3NUeXBlL1Jlc291cmNlRXZlbnQjIgogICAgeG1sbnM6ZGM9Imh0dHA6Ly9wdXJsLm9yZy9kYy9lbGVtZW50cy8xLjEvIgogICAgeG1sbnM6R0lNUD0iaHR0cDovL3d3dy5naW1wLm9yZy94bXAvIgogICAgeG1sbnM6dGlmZj0iaHR0cDovL25zLmFkb2JlLmNvbS90aWZmLzEuMC8iCiAgICB4bWxuczp4bXA9Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC8iCiAgIHhtcE1NOkRvY3VtZW50SUQ9ImdpbXA6ZG9jaWQ6Z2ltcDozZDM4ZTFlYi1hOTA2LTQ2YWUtYTM2OS04OWYxYjIyMGI3ZjEiCiAgIHhtcE1NOkluc3RhbmNlSUQ9InhtcC5paWQ6NWJjYjQ5ZGYtYjY3Ny00NDk0LWI4MWQtZTVjZjFhZDVmYTkxIgogICB4bXBNTTpPcmlnaW5hbERvY3VtZW50SUQ9InhtcC5kaWQ6ZDk4NzZiMTItNGRkMy00YTU2LTk1ZWItNTYwZGE1YzA1ODc2IgogICBkYzpGb3JtYXQ9ImltYWdlL3BuZyIKICAgR0lNUDpBUEk9IjIuMCIKICAgR0lNUDpQbGF0Zm9ybT0iTGludXgiCiAgIEdJTVA6VGltZVN0YW1wPSIxNjg1MTA4MDU1MjA1MjEzIgogICBHSU1QOlZlcnNpb249IjIuMTAuMzQiCiAgIHRpZmY6T3JpZW50YXRpb249IjEiCiAgIHhtcDpDcmVhdG9yVG9vbD0iR0lNUCAyLjEwIgogICB4bXA6TWV0YWRhdGFEYXRlPSIyMDIzOjA1OjI2VDE1OjM0OjE1KzAyOjAwIgogICB4bXA6TW9kaWZ5RGF0ZT0iMjAyMzowNToyNlQxNTozNDoxNSswMjowMCI+CiAgIDx4bXBNTTpIaXN0b3J5PgogICAgPHJkZjpTZXE+CiAgICAgPHJkZjpsaQogICAgICBzdEV2dDphY3Rpb249InNhdmVkIgogICAgICBzdEV2dDpjaGFuZ2VkPSIvIgogICAgICBzdEV2dDppbnN0YW5jZUlEPSJ4bXAuaWlkOjE5OTI1NDdmLWRlNzItNGE0Yi1hYzNjLWI5MWFhMGJhYTZlMiIKICAgICAgc3RFdnQ6c29mdHdhcmVBZ2VudD0iR2ltcCAyLjEwIChMaW51eCkiCiAgICAgIHN0RXZ0OndoZW49IjIwMjMtMDUtMjZUMTU6MzQ6MTUrMDI6MDAiLz4KICAgIDwvcmRmOlNlcT4KICAgPC94bXBNTTpIaXN0b3J5PgogIDwvcmRmOkRlc2NyaXB0aW9uPgogPC9yZGY6UkRGPgo8L3g6eG1wbWV0YT4KICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgIAo8P3hwYWNrZXQgZW5kPSJ3Ij8+gnF+SAAAAAZiS0dEAP8A/wD/oL2nkwAAAAlwSFlzAAALEwAACxMBAJqcGAAAAAd0SU1FB+cFGg0iDw8EcfMAAAwsSURBVHja7Z13XJRHGse/u3QEBSkKCEGNIiAiUkRdRYpZFVREDCXSUQSN0VgiGiSCJnfJxVw0p55dgyXGcheseFETjVERTWKsOTsSxSgSEFbq/UHcu5VlKcIq5/v9fPiDmXdm3p2Z38zzPDMLot5dRlcjIPASIxa6QEAQgYCAIAIBAUEEAgKCCAQEXmY0n1fDXbvbIPFy4V5+AVl7jlFRXiGMhsDLIwKJtyufrkhGLK7ZiMaGSxn/xjwqKiqFERH4/zeHdPV0mLcwUS4AgN5u9oREDBdGQ+DlEEH8pGDMOrSvlZ4w5XWM27cVRkTg/1sElp3MiYgbqTTPsG0bkqaFCSPyjJiYGjHIxw0DQ321tWlja4GXr7vgEzSEt+dEo62tVWd+UOgQvty4n8sXr6vtnbx83ZEM7gPAj6cvsWvn4UaV95V64ilxBuB09nn2fnVEIX9uegK+Uk8WfbC+0XXXhZ1DZz5eOov8uw+YHJtOySOZPO+L3YswMTVipE8SxUUlLd5/tl2s2HlgCfl37vPN19nCTqAKt76O+Eo9Vb+MWMzMlFi1dkBP524Eh0sJDpfyTmo8bQz0Gr6CaGnyTmq8vHwfd4da/k9wuBRjk3aERjWfzzN81CCsrDvg4mZPHw9HYftrDSIQiUTMnBfXMLF49qxXLC2FgaE+r48b1uDnR4werNS/eYKs9DE7thyg4MHvbNu4v9nec1/mEfJy8/npzGV+OHVBmMWtQQRjwl6jew/bBj8/LTlKpdnUEhw9fBqAN2ICGtS2SCQiakIgACeO/VTnc+lzl+HjHs0/vvy62d71ws9X8feaSFTwbLWYPIIInhFDQ/1GO7xW1h2IiB+l1o64eO4q331zBhNTI0aN9an3eb+h/XilsyUXfr7KsW/OCDNJEEHdJLwVUiv0mbEmE/9BCfKfscOn1lrR4hKDMDM3VmtnrFq6DYDI+ECFcwxlRCeMVigj0Hpp0eiQbRcrQpTY2L9cukHe7XsKacVFJQphPT19XabMiiBlxmK1dcYPpy6Qc/Icrh6OSAMG1Ir0PMFzgDMOTl25+u9cDu4/TqSKXSssyh/nPnZs25zFqeM/y9P79u/F6BA/TmdfYGvGXnq5dCc0cjjde9iioanBL5dusDVjn0KZJ5iZGzN9bgyFD4v4IHVloz5j1IRA7B27cOWXW6z87MuaBScpmG52Nmxat4ufzlxWWm6Alwsjgrw5+f1Zdmw5UGf9llZmBIUOoZeLHfoGetzJ+41DWSfYl3mEysqqBgVQRo31xc6hMzo62uTevMPX+47z1faDLXajoEV3gulzY9DU0lRqIilzSp/GP9CLns7d1Lsb/G2bwkqvjJiJQQCsWba93vqc+9ghDZBgbdNRId3a1gJpgATnPnZExI1k7db38ejfC7GGGMtO5gwZ1p+VG9OISwquVWcbA32kARIG+3k06rPNfm88U9+JpJNNR7Zm7JWnu/friTRAgoWVucoFTRogUTkeI8d4sz1rCXFJwbi4O+Do9Cq+Uk8WfPwWWzIXYWXdoc6yWtqaLFw0lZWb0gkYPRgLSzMMDPXpP8iFlPcT+WKX6vIvpAgk3q7y+Ht9E14kEikNTYpEImY1MKrUXBw/+iPnzv6b7j1skXi71sp3dHoVj/5O3L51l32ZR565PRd3ewJf9yMuLAW/vrEEvTYFb7coNq/fDcDk6eF49Hd6tkEWi0n7aAohEcPI/v4sE8bNo/BhcbP2W3tTI5LTEvh81T8Z4Z2Iu91Y+tqH8Gb8Qi5fvM6rdjas2bKgzlsBf/rr2wwfNYgrl28SF/ouA3uPw9cjBn+vifxr3/d06WbNqk3ptG1n0DpEoKmpwfQ50XXmGxi2eWpl00MkEil91ql3d/wDvdQqhNVLa1b42D9W/P8lNrEmbe3fdzZoe693AERi4kLnKoQ6Sx7J+DBtNSePna0xqSL9mz4WWpp89NkMRgQN5vC/TjI5doHC4VpzUV1VTVLUfJZ+spncm3cBKCsr5+ihHKLGzOZ09nnMO5owfW5MrbLSAAk+Uk/y79wnLuxdTmefl+fl5eYzc9JHfHvwFB0tTXlzxhutQwShkcOx7WKlQgT69ZpC/8tbsyLQ1dNRmwgOZZ3gyuWbuLjZ09vNXp7+SmdLBg/x4F5+AV9tP9gsbeWcPMfDgiKleZvW7QLAzrFzk+rW1dVmyaq5+Eg92bXzMDOSPqSsrLxF+qzgQSFn6jizkMnKSJ76CWVl5QwdMbDW2UpEfM1Vmj/NX1XnDpWWvJSK8gpGBvugp6/7YovAuH1bEqaEqHymsSIw69Ce+KQx6t0Nlu2otRvETAxCLBazYeU/KC9r+e8/XL96u6Z/DBp/D8jAUJ9l61PxlDizef1uUmYsbpadq6nk37nPtwdPoaEhZsAgF3m6kbEhDj27UvJIxpFDOXWWv//bQ37IuYi2thZ93O1f7OjQpLfD653UT+cbPmUeKWNc3Eh2bDlQK6rUUuzfdZTEqaEM9Halm90rFBYW4z9qEA8Liti2OUst71Ba+ljuGzWWRctm09HSlHV/38mnH37+QoQiL567ht/QftjYWsjTrKw7IBKJ0NTS4Ms9n6gsb2JqBKDSgX/uIujew5bRIX71h047W9G5aycey2oG2bVv/fdfdHS0mTYnmpmTPlLLgFVVVbFuxU5SFiYSMzGIB/cfoqmlyca1mcj+mJwvMk/MHhd3B9oY6PGouPT5v9PjMgC0dbQUfBaAwofFdZpTT5N7886LK4JZ8+LqPWQC6Ghpyo6sxRQ8+B1DQ32lYVRl+A3th1tfR06dOKeWQftq+yES3nyd1/wHUF5WTnFRCV9s2ENrYNabfyH5vfE4u/Zg2fpUkqLT6r1i0ZCxexYsO9Ws4PfyC+Rp9+4+AOCxrIy05KXPpa+a7VP7De3XoBUd4PfCYuLDUvBxj2agS0SjrhjPTIlrknnQFCrKK9iw6p9oaIjR1dNh68Z9FLWSuzolj0pJjE7jzKkLOPXuzvIN7yk9n6lZocsVJmlLoKEhZpCPGwCnTypGf37Nu0cnmw7YOXRuvSLQ1tZiWnJUg59fsWQrOSdrVnNZ6WPS5izlwf3Chplc9rYEhQ5RWwdt35xFwf1CZLIyMtZk0pooLZExKSad09nncez1Kss/n49h29r+160bNeaFxMulzrosrMxUtqWnr6vSF4wcH4hlJ3N+uXSDsz8onko/uWE7a14cmpoarVMEkeNHNWoVuXbltsLv5WUV5OXmN9z5nhZW56rW3MhkZWxcu6vmSnQDhfoiCiHn5DkcnLqyImN+rQOnrD3fATXf9Q6NrP29h8Cxvox9Y6jKdgzbtmH5hvcUnN4nJlZ0wmgmTw+nsrKKD9NW1yq7ad0urly+SR93Bz5ZPhtjk3YK+SKRiGEjB/LnxdMbbDqr1ScwMzdWeqikCk+JM8e+/e/NS1MzY7p2s25weWOTdkyYEsLHC9eqZSJ9kbG32WPT6kRW+pjJsQv4bPW7uPZ1ZEXGfBIiUuUx+R9zLrJ9cxZjwl7jndR4hgZIyMk+j6amBu6eThi1NyRjTabKcb539wEV5RXsPLCEM9kXuHYlFz19Xdz69qSDhQkVFZWkz1mq9C6UTFbGlPHv87e1KUi8XdnzzXKOH/2RvNv3aGdkgKuHIx0tTamsrCJr93d8vf/4iyWCxGlhjZ4g4dEBPCou4cDe7zE3b8+05KhG1xEaMYzN63c3agdpKsVFJa3+3n6NENJZvGou7v2cWLExjYRxqfKDugXvLif31l2ixgfi7NoDZ9ceVFRUcijrBJNj0xk2cmC9O+aEcanEJY1hbLhU7h9WVFRy9FAOny3axKXz1+osn5ebT/iomcRODGJ0iB+Dh3go1H1gzzFWL9uuso6mInrWP81+OGcD7YwMnsvAfpC6UuEimEAz2MdiMTa2FmhpaZJ3O79JoVWxWIyFlRk6Olr8mvcbpSWNu6YhEomwfqUjxu3bUlxcyo1reS36x9meeScoeVT63ERQXPRImLXNTFVVlfyk+lnquH3rbpPLV1dXc/P6r9y8/mvrcIyXf7qF6mr1/5+PyxevczDrhDBrBZ6/OQQ114vd+zuhq6vd4i9cXV3Nnbzf2Jd5lMd/nEAKCDx3EQgItGo/SOgCAUEEAgKCCAQEBBEICAgiEBAQRCAgIIhAQODl5T8fAA0jNG++OQAAAABJRU5ErkJggg=="}}]); \ No newline at end of file diff --git a/assets/js/368cce37.1900730d.js b/assets/js/368cce37.1900730d.js deleted file mode 100644 index 85b49406b4a..00000000000 --- a/assets/js/368cce37.1900730d.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[2667],{35318:(e,t,a)=>{a.d(t,{Zo:()=>h,kt:()=>u});var n=a(27378);function o(e,t,a){return t in e?Object.defineProperty(e,t,{value:a,enumerable:!0,configurable:!0,writable:!0}):e[t]=a,e}function r(e,t){var a=Object.keys(e);if(Object.getOwnPropertySymbols){var n=Object.getOwnPropertySymbols(e);t&&(n=n.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),a.push.apply(a,n)}return a}function i(e){for(var t=1;t=0||(o[a]=e[a]);return o}(e,t);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(e);for(n=0;n=0||Object.prototype.propertyIsEnumerable.call(e,a)&&(o[a]=e[a])}return o}var p=n.createContext({}),l=function(e){var t=n.useContext(p),a=t;return e&&(a="function"==typeof e?e(t):i(i({},t),e)),a},h=function(e){var t=l(e.components);return n.createElement(p.Provider,{value:t},e.children)},m={inlineCode:"code",wrapper:function(e){var t=e.children;return n.createElement(n.Fragment,{},t)}},d=n.forwardRef((function(e,t){var a=e.components,o=e.mdxType,r=e.originalType,p=e.parentName,h=s(e,["components","mdxType","originalType","parentName"]),d=l(a),u=o,c=d["".concat(p,".").concat(u)]||d[u]||m[u]||r;return a?n.createElement(c,i(i({ref:t},h),{},{components:a})):n.createElement(c,i({ref:t},h))}));function u(e,t){var a=arguments,o=t&&t.mdxType;if("string"==typeof e||o){var r=a.length,i=new Array(r);i[0]=d;var s={};for(var p in t)hasOwnProperty.call(t,p)&&(s[p]=t[p]);s.originalType=e,s.mdxType="string"==typeof e?e:o,i[1]=s;for(var l=2;l{a.r(t),a.d(t,{assets:()=>p,contentTitle:()=>i,default:()=>m,frontMatter:()=>r,metadata:()=>s,toc:()=>l});var n=a(25773),o=(a(27378),a(35318));const r={title:"Release Notes - Podman Desktop 1.0",description:"Podman Desktop 1.0 has been released!",slug:"podman-desktop-release-1.0",authors:["deboer"],tags:["podman-desktop","release","kubernetes","kind","openshift"],hide_table_of_contents:!1,image:"/img/blog/podman-desktop-release-1.0.jpg"},i=void 0,s={permalink:"/blog/podman-desktop-release-1.0",source:"@site/blog/2023-05-17-release-1.0.md",title:"Release Notes - Podman Desktop 1.0",description:"Podman Desktop 1.0 has been released!",date:"2023-05-17T00:00:00.000Z",formattedDate:"May 17, 2023",tags:[{label:"podman-desktop",permalink:"/blog/tags/podman-desktop"},{label:"release",permalink:"/blog/tags/release"},{label:"kubernetes",permalink:"/blog/tags/kubernetes"},{label:"kind",permalink:"/blog/tags/kind"},{label:"openshift",permalink:"/blog/tags/openshift"}],readingTime:5,hasTruncateMarker:!0,authors:[{name:"Tim deBoer",title:"Architect",url:"https://github.com/deboer-tim",imageURL:"https://github.com/deboer-tim.png",key:"deboer"}],frontMatter:{title:"Release Notes - Podman Desktop 1.0",description:"Podman Desktop 1.0 has been released!",slug:"podman-desktop-release-1.0",authors:["deboer"],tags:["podman-desktop","release","kubernetes","kind","openshift"],hide_table_of_contents:!1,image:"/img/blog/podman-desktop-release-1.0.jpg"},prevItem:{title:"Release Notes - Podman Desktop 1.1",permalink:"/blog/podman-desktop-release-1.1"},nextItem:{title:"Release Notes - Podman Desktop 0.15",permalink:"/blog/podman-desktop-release-0.15"}},p={authorsImageUrls:[void 0]},l=[{value:"Release Details",id:"release-details",level:2},{value:"Highlighting Featured Extensions",id:"highlighting-featured-extensions",level:3},{value:"Featured Extensions",id:"featured-extensions",level:3},{value:"Red Hat OpenShift Local",id:"red-hat-openshift-local",level:4},{value:"Developer Sandbox for Red Hat OpenShift",id:"developer-sandbox-for-red-hat-openshift",level:4},{value:"Podman Machine as Root",id:"podman-machine-as-root",level:3},{value:"Other UI and UX Improvements",id:"other-ui-and-ux-improvements",level:3},{value:"Prompt to Open External Website",id:"prompt-to-open-external-website",level:4},{value:"Editable Numeric Preferences",id:"editable-numeric-preferences",level:4},{value:"Navigation tooltips",id:"navigation-tooltips",level:4},{value:"Other Notable Enhancements",id:"other-notable-enhancements",level:2},{value:"Notable Bug Fixes",id:"notable-bug-fixes",level:2},{value:"Community Thank You",id:"community-thank-you",level:2},{value:"Final notes",id:"final-notes",level:2}],h={toc:l};function m(e){let{components:t,...r}=e;return(0,o.kt)("wrapper",(0,n.Z)({},h,r,{components:t,mdxType:"MDXLayout"}),(0,o.kt)("p",null,"Podman Desktop 1.0 Release! \ud83c\udf89"),(0,o.kt)("p",null,"We still have many things planned, but with a little polish and a few more bug fixes we\nfelt we've reached a level of maturity and it is now time to declare our 1.0 release."),(0,o.kt)("p",null,"Thank you to everyone who has been with us on this journey so far! Please keep the\nfeedback coming!"),(0,o.kt)("ul",null,(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("strong",{parentName:"li"},"Highlighting Featured Extensions"),": Easily find and install new extensions."),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("strong",{parentName:"li"},"Featured Extensions"),": Two new extensions supporting OpenShift."),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("strong",{parentName:"li"},"Podman Machine as Root"),": Ability to run a Podman machine as root."),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("strong",{parentName:"li"},"UX and UI Improvements"),": Opening external websites, editing numbers, and tooltips.")),(0,o.kt)("p",null,"Podman Desktop 1.0 is now available. ",(0,o.kt)("a",{parentName:"p",href:"/downloads"},"Click here to download it"),"!"),(0,o.kt)("p",null,(0,o.kt)("img",{alt:"Podman-desktop-1-0-hero",src:a(66663).Z,width:"1620",height:"1080"})),(0,o.kt)("hr",null),(0,o.kt)("h2",{id:"release-details"},"Release Details"),(0,o.kt)("h3",{id:"highlighting-featured-extensions"},"Highlighting Featured Extensions"),(0,o.kt)("p",null,"A critical part of our vision for Podman Desktop is the ability to install extensions to\nsupport additional container engines, Kubernetes providers, or other tools. However, it\nhas not been easy to discover new extensions."),(0,o.kt)("p",null,"With 1.0 we show a list of featured extensions in the ",(0,o.kt)("strong",{parentName:"p"},"Welcome"),"\n",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/2354"},"#2354"),", the ",(0,o.kt)("strong",{parentName:"p"},"Dashboard")," and in\n",(0,o.kt)("strong",{parentName:"p"},(0,o.kt)("icon",{icon:"fa-solid fa-cog",size:"lg"})," Settings > Extensions"),"\n",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/2355"},"#2355"),". Check out the new\nextensions for ",(0,o.kt)("strong",{parentName:"p"},"Red Hat OpenShift Local")," and the ",(0,o.kt)("strong",{parentName:"p"},"Developer Sandbox for Red Hat OpenShift"),"!"),(0,o.kt)("p",null,(0,o.kt)("img",{alt:"Featured extensions",src:a(80680).Z,width:"1926",height:"474"})),(0,o.kt)("h3",{id:"featured-extensions"},"Featured Extensions"),(0,o.kt)("p",null,"Speaking of extensions, let's take a minute to turn the spotlight on these two!"),(0,o.kt)("p",null,"Have another idea for extending Podman Desktop? We would love to hear from you or see\nwhat you can create with the ",(0,o.kt)("a",{parentName:"p",href:"/docs/extensions"},"Extension documentation"),",\nand feature your extension here."),(0,o.kt)("h4",{id:"red-hat-openshift-local"},"Red Hat OpenShift Local"),(0,o.kt)("p",null,"OpenShift Local is a fully-featured single-node OpenShift cluster designed to run on your local computer.\nWith this extension you can install, start/stop, and deploy pods or YAML to OpenShift Local,\nallowing you to test your applications on a full OpenShift environment, ensuring a consistent\nexperience between development, test, and production."),(0,o.kt)("p",null,"The recent addition of the MicroShift preset provides a lighter, optimized option that\nstarts faster and uses less resources for deployments that still want OpenShift compatibility\nwithout the full set of OpenShift services."),(0,o.kt)("p",null,(0,o.kt)("img",{alt:"OpenShift Local",src:a(3874).Z,width:"1496",height:"350"})),(0,o.kt)("h4",{id:"developer-sandbox-for-red-hat-openshift"},"Developer Sandbox for Red Hat OpenShift"),(0,o.kt)("p",null,"The OpenShift Developer Sandbox is a free, cloud-based OpenShift environment that allows developers to\ncreate, build, and deploy applications to OpenShift for 30 days. With this extension you can sign up\nand easily deploy pods or YAML to a hosted OpenShift environment without a local installation or\nleaving Podman Desktop."),(0,o.kt)("p",null,(0,o.kt)("img",{alt:"Developer Sandbox",src:a(84249).Z,width:"1484",height:"1016"})),(0,o.kt)("h3",{id:"podman-machine-as-root"},"Podman Machine as Root"),(0,o.kt)("p",null,"When creating a Podman machine you can now decide to run as root ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/2427"},"#2427"),". This is a prerequisite for some scenarios, such as running Kind on Windows."),(0,o.kt)("p",null,(0,o.kt)("img",{alt:"Podman machine as root",src:a(53172).Z,width:"350",height:"122"})),(0,o.kt)("h3",{id:"other-ui-and-ux-improvements"},"Other UI and UX Improvements"),(0,o.kt)("h4",{id:"prompt-to-open-external-website"},"Prompt to Open External Website"),(0,o.kt)("p",null,"In the previous release links to external websites were blocked due to the security risk.\nIn 1.0 you can click to see the URL and have the option of opening or copying it\n",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/2414"},"#2414"),"."),(0,o.kt)("p",null,(0,o.kt)("img",{alt:"External link dialog",src:a(44294).Z,width:"1102",height:"434"})),(0,o.kt)("h4",{id:"editable-numeric-preferences"},"Editable Numeric Preferences"),(0,o.kt)("p",null,"Tired of clicking +, +, +? Us too. Numeric preferences are now editable so\nyou can directly enter the value you want\n",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/2368"},"#2368"),"."),(0,o.kt)("p",null,(0,o.kt)("img",{alt:"Editing numbers",src:a(24875).Z,width:"1334",height:"192"})),(0,o.kt)("h4",{id:"navigation-tooltips"},"Navigation tooltips"),(0,o.kt)("p",null,"We like our new navigation bar, but the tooltips were slow to appear. This made it harder for new\nusers to discover the pages and for power users to see the container/pod/image counts. The\ntooltips are now a little nicer and appear immediately\n",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/2286"},"#2286"),"."),(0,o.kt)("p",null,(0,o.kt)("img",{alt:"Navigation tooltips",src:a(45365).Z,width:"734",height:"192"})),(0,o.kt)("hr",null),(0,o.kt)("h2",{id:"other-notable-enhancements"},"Other Notable Enhancements"),(0,o.kt)("ul",null,(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},"If you use a non-default Podman machine you are now prompted to make it the default, so\nthat command line tools will use the same machine ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/2205"},"#2205"),".")),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},"Extensions can now be installed without requiring a running local container engine\n",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/2273"},"#2273"),".")),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},"When extensions fail to load there is a new state (failed!) and an error message\nto help you fix or report the problem ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/2424"},"#2424"),".")),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},"The showInputBox API has support for Markdown ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/2418"},"#2418"),"."))),(0,o.kt)("hr",null),(0,o.kt)("h2",{id:"notable-bug-fixes"},"Notable Bug Fixes"),(0,o.kt)("ul",null,(0,o.kt)("li",{parentName:"ul"},"Fixed shared status when using multiple Podman 4.5 machines ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/2441"},"#2441"),"."),(0,o.kt)("li",{parentName:"ul"},"Fixed hang on exit when telemetry is unreachable ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/2431"},"#2431"),"."),(0,o.kt)("li",{parentName:"ul"},"Reduced initial Podman REST API calls to improve performance ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/2419"},"#2419"),"."),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("strong",{parentName:"li"},"Play Kubernetes YAML")," now honors the namespace ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/2509"},"#2509"),"."),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("strong",{parentName:"li"},"Container")," list was not remembering expand/collapsed status ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/2491"},"#2491"),"."),(0,o.kt)("li",{parentName:"ul"},"Clear previous error when installing Docker extension ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/2469"},"#2469"),"."),(0,o.kt)("li",{parentName:"ul"},"Ensure correct path with running Kind CLI ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/2455"},"#2455"),"."),(0,o.kt)("li",{parentName:"ul"},"Use IPv4 over IPv6 by default ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/2398"},"#2398"),"."),(0,o.kt)("li",{parentName:"ul"},"When changing the Kubernetes pod name, change the app name to match ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/2389"},"#2389"),"."),(0,o.kt)("li",{parentName:"ul"},"Fixed incorrect pod status in ",(0,o.kt)("strong",{parentName:"li"},"Containers")," view ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/2387"},"#2387"),"."),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("strong",{parentName:"li"},"Dashboard")," wasn't correctly refreshing Podman status ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/2359"},"#2359"),".")),(0,o.kt)("hr",null),(0,o.kt)("h2",{id:"community-thank-you"},"Community Thank You"),(0,o.kt)("p",null,"\ud83c\udf89 We\u2019d like to say a big thank you to everyone who helped to make Podman Desktop even better. In this final\nsprint we received pull requests from the following people:"),(0,o.kt)("ul",null,(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("a",{parentName:"li",href:"https://github.com/TahaAttari"},"Taha Attari")," in ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/2470"},"#2470 - Update docker command in importing-saved-containers.md")),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("a",{parentName:"li",href:"https://github.com/n1hility"},"Jason Greene")," in ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/2431"},"#2431 - Fix hang on exit when telemetry endpoint is unreachable")),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("a",{parentName:"li",href:"https://github.com/afbjorklund"},"Anders Bj\xf6rklund")," in ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/2571"},"#2571 - Fix the location of the lima podman socket")," and ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/2572"},"#2572 - Fix the state of the lima container provider")),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("a",{parentName:"li",href:"https://github.com/tuckerrc"},"Tucker Chapman")," in ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/2567"},"#2567 - Add example image name in placeholder"))),(0,o.kt)("p",null,"There are now a total of 54 people (and two bots!) who have contributed PRs to Podman Desktop, and we'd\nlike to extend an extra thanks to all of those outside of the immediate development team who contributed\nto get us here:"),(0,o.kt)("p",null,(0,o.kt)("a",{parentName:"p",href:"https://github.com/afbjorklund"},"afbjorklund"),",\n",(0,o.kt)("a",{parentName:"p",href:"https://github.com/alv67"},"alv67"),",\n",(0,o.kt)("a",{parentName:"p",href:"https://github.com/anjannath"},"anjannath"),",\n",(0,o.kt)("a",{parentName:"p",href:"https://github.com/ankanroy-code"},"ankanroy-code"),",\n",(0,o.kt)("a",{parentName:"p",href:"https://github.com/arixmkii"},"arixmkii"),",\n",(0,o.kt)("a",{parentName:"p",href:"https://github.com/cblecker"},"cblecker"),",\n",(0,o.kt)("a",{parentName:"p",href:"https://github.com/cfergeau"},"cfergeau"),",\n",(0,o.kt)("a",{parentName:"p",href:"https://github.com/chevdor"},"chevdor"),",\n",(0,o.kt)("a",{parentName:"p",href:"https://github.com/chrisjsimpson"},"chrisjsimpson"),",\n",(0,o.kt)("a",{parentName:"p",href:"https://github.com/cu8code"},"cu8code"),",\n",(0,o.kt)("a",{parentName:"p",href:"https://github.com/doehyunbaek"},"doehyunbaek"),",\n",(0,o.kt)("a",{parentName:"p",href:"https://github.com/dylanmtaylor"},"dylanmtaylor"),",\n",(0,o.kt)("a",{parentName:"p",href:"https://github.com/eidottermihi"},"eidottermihi"),",\n",(0,o.kt)("a",{parentName:"p",href:"https://github.com/elervik"},"elervik"),",\n",(0,o.kt)("a",{parentName:"p",href:"https://github.com/emmanuelbernard"},"emmanuelbernard"),",\n",(0,o.kt)("a",{parentName:"p",href:"https://github.com/evanfpearson"},"evanfpearson"),",\n",(0,o.kt)("a",{parentName:"p",href:"https://github.com/gorkem"},"gorkem"),",\n",(0,o.kt)("a",{parentName:"p",href:"https://github.com/idjohnson"},"idjohnson"),",\n",(0,o.kt)("a",{parentName:"p",href:"https://github.com/imphil"},"imphil"),",\n",(0,o.kt)("a",{parentName:"p",href:"https://github.com/iongion"},"iongion"),",\n",(0,o.kt)("a",{parentName:"p",href:"https://github.com/jlosito"},"jlosito"),",\n",(0,o.kt)("a",{parentName:"p",href:"https://github.com/KevinAtSesam"},"KevinAtSesam"),",\n",(0,o.kt)("a",{parentName:"p",href:"https://github.com/lsm5"},"lsm5"),",\n",(0,o.kt)("a",{parentName:"p",href:"https://github.com/Mitch9378"},"Mitch9378"),",\n",(0,o.kt)("a",{parentName:"p",href:"https://github.com/n1hility"},"n1hility"),",\n",(0,o.kt)("a",{parentName:"p",href:"https://github.com/osslate"},"osslate"),",\n",(0,o.kt)("a",{parentName:"p",href:"https://github.com/PatentLobster"},"PatentLobster"),",\n",(0,o.kt)("a",{parentName:"p",href:"https://github.com/pwright"},"pwright"),",\n",(0,o.kt)("a",{parentName:"p",href:"https://github.com/rdwz"},"rdwz"),",\n",(0,o.kt)("a",{parentName:"p",href:"https://github.com/redhatrises"},"redhatrises"),",\n",(0,o.kt)("a",{parentName:"p",href:"https://github.com/rhatdan"},"rhatdan"),",\n",(0,o.kt)("a",{parentName:"p",href:"https://github.com/RobotSail"},"RobotSail"),",\n",(0,o.kt)("a",{parentName:"p",href:"https://github.com/rohit-rambade"},"rohit-rambade"),",\n",(0,o.kt)("a",{parentName:"p",href:"https://github.com/rsvoboda"},"rsvoboda"),",\n",(0,o.kt)("a",{parentName:"p",href:"https://github.com/sfrunza13"},"sfrunza13"),",\n",(0,o.kt)("a",{parentName:"p",href:"https://github.com/shemanaev"},"shemanaev"),",\n",(0,o.kt)("a",{parentName:"p",href:"https://github.com/sstosh"},"sstosh"),",\n",(0,o.kt)("a",{parentName:"p",href:"https://github.com/stickster"},"stickster"),",\n",(0,o.kt)("a",{parentName:"p",href:"https://github.com/TahaAttari"},"TahaAttari"),",\n",(0,o.kt)("a",{parentName:"p",href:"https://github.com/ths83"},"ths83"),",\n",(0,o.kt)("a",{parentName:"p",href:"https://github.com/Tony-Sol"},"Tony-Sol"),",\n",(0,o.kt)("a",{parentName:"p",href:"https://github.com/tuckerrc"},"tuckerrc"),",\n",(0,o.kt)("a",{parentName:"p",href:"https://github.com/ucomesdag"},"ucomesdag"),",\n",(0,o.kt)("a",{parentName:"p",href:"https://github.com/xbabalov"},"xbabalov"),",\nzezo2019."),(0,o.kt)("hr",null),(0,o.kt)("h2",{id:"final-notes"},"Final notes"),(0,o.kt)("p",null,"The complete list of issues fixed in this release is available ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/issues?q=is%3Aclosed+milestone%3A1.0.0"},"here")," and ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/issues?q=is%3Aclosed+milestone%3A1.0.1"},"here"),"."),(0,o.kt)("p",null,"Get the latest release from the ",(0,o.kt)("a",{parentName:"p",href:"/downloads"},"Downloads")," section of the website and boost your development journey with Podman Desktop. Additionally, visit the ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop"},"GitHub repository")," and see how you can help us make Podman Desktop better."))}m.isMDXComponent=!0},24875:(e,t,a)=>{a.d(t,{Z:()=>n});const n=a.p+"assets/images/edit-number-8da457a123eb3cd6afc3dca7eda00870.png"},44294:(e,t,a)=>{a.d(t,{Z:()=>n});const n=a.p+"assets/images/external-link-d70735d4fe675915dd25761daf1f1684.png"},80680:(e,t,a)=>{a.d(t,{Z:()=>n});const n=a.p+"assets/images/featured-extensions-52dff6ccab42c42fd50f37bdf870f19f.png"},45365:(e,t,a)=>{a.d(t,{Z:()=>n});const n=a.p+"assets/images/nav-tooltips-000f080b595ddbdd177b7004f23aea5b.png"},3874:(e,t,a)=>{a.d(t,{Z:()=>n});const n=a.p+"assets/images/openshift-local-39a086441b856524414c7a8d9370ce14.png"},66663:(e,t,a)=>{a.d(t,{Z:()=>n});const n=a.p+"assets/images/podman-desktop-release-1.0-b1e0008ec8a98fcc5628fa05b667d802.jpg"},53172:(e,t,a)=>{a.d(t,{Z:()=>n});const n=a.p+"assets/images/podman-root-afa83c0f605f6db26dc237d45ccdbe94.png"},84249:(e,t,a)=>{a.d(t,{Z:()=>n});const n=a.p+"assets/images/sandbox-1957747367cc8134b7a178347a952886.png"}}]); \ No newline at end of file diff --git a/assets/js/368cce37.37faff5c.js b/assets/js/368cce37.37faff5c.js new file mode 100644 index 00000000000..5285be2ff9a --- /dev/null +++ b/assets/js/368cce37.37faff5c.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[2667],{35318:(e,t,a)=>{a.d(t,{Zo:()=>h,kt:()=>u});var n=a(27378);function o(e,t,a){return t in e?Object.defineProperty(e,t,{value:a,enumerable:!0,configurable:!0,writable:!0}):e[t]=a,e}function r(e,t){var a=Object.keys(e);if(Object.getOwnPropertySymbols){var n=Object.getOwnPropertySymbols(e);t&&(n=n.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),a.push.apply(a,n)}return a}function i(e){for(var t=1;t=0||(o[a]=e[a]);return o}(e,t);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(e);for(n=0;n=0||Object.prototype.propertyIsEnumerable.call(e,a)&&(o[a]=e[a])}return o}var p=n.createContext({}),l=function(e){var t=n.useContext(p),a=t;return e&&(a="function"==typeof e?e(t):i(i({},t),e)),a},h=function(e){var t=l(e.components);return n.createElement(p.Provider,{value:t},e.children)},m={inlineCode:"code",wrapper:function(e){var t=e.children;return n.createElement(n.Fragment,{},t)}},d=n.forwardRef((function(e,t){var a=e.components,o=e.mdxType,r=e.originalType,p=e.parentName,h=s(e,["components","mdxType","originalType","parentName"]),d=l(a),u=o,c=d["".concat(p,".").concat(u)]||d[u]||m[u]||r;return a?n.createElement(c,i(i({ref:t},h),{},{components:a})):n.createElement(c,i({ref:t},h))}));function u(e,t){var a=arguments,o=t&&t.mdxType;if("string"==typeof e||o){var r=a.length,i=new Array(r);i[0]=d;var s={};for(var p in t)hasOwnProperty.call(t,p)&&(s[p]=t[p]);s.originalType=e,s.mdxType="string"==typeof e?e:o,i[1]=s;for(var l=2;l{a.r(t),a.d(t,{assets:()=>p,contentTitle:()=>i,default:()=>u,frontMatter:()=>r,metadata:()=>s,toc:()=>l});var n=a(25773),o=(a(27378),a(35318));const r={title:"Release Notes - Podman Desktop 1.0",description:"Podman Desktop 1.0 has been released!",slug:"podman-desktop-release-1.0",authors:["deboer"],tags:["podman-desktop","release","kubernetes","kind","openshift"],hide_table_of_contents:!1,image:"/img/blog/podman-desktop-release-1.0.jpg"},i=void 0,s={permalink:"/blog/podman-desktop-release-1.0",source:"@site/blog/2023-05-17-release-1.0.md",title:"Release Notes - Podman Desktop 1.0",description:"Podman Desktop 1.0 has been released!",date:"2023-05-17T00:00:00.000Z",formattedDate:"May 17, 2023",tags:[{label:"podman-desktop",permalink:"/blog/tags/podman-desktop"},{label:"release",permalink:"/blog/tags/release"},{label:"kubernetes",permalink:"/blog/tags/kubernetes"},{label:"kind",permalink:"/blog/tags/kind"},{label:"openshift",permalink:"/blog/tags/openshift"}],readingTime:5,hasTruncateMarker:!0,authors:[{name:"Tim deBoer",title:"Architect",url:"https://github.com/deboer-tim",imageURL:"https://github.com/deboer-tim.png",key:"deboer"}],frontMatter:{title:"Release Notes - Podman Desktop 1.0",description:"Podman Desktop 1.0 has been released!",slug:"podman-desktop-release-1.0",authors:["deboer"],tags:["podman-desktop","release","kubernetes","kind","openshift"],hide_table_of_contents:!1,image:"/img/blog/podman-desktop-release-1.0.jpg"},prevItem:{title:"Release Notes - Podman Desktop 1.1",permalink:"/blog/podman-desktop-release-1.1"},nextItem:{title:"Release Notes - Podman Desktop 0.15",permalink:"/blog/podman-desktop-release-0.15"}},p={authorsImageUrls:[void 0]},l=[{value:"Release Details",id:"release-details",level:2},{value:"Highlighting Featured Extensions",id:"highlighting-featured-extensions",level:3},{value:"Featured Extensions",id:"featured-extensions",level:3},{value:"Red Hat OpenShift Local",id:"red-hat-openshift-local",level:4},{value:"Developer Sandbox for Red Hat OpenShift",id:"developer-sandbox-for-red-hat-openshift",level:4},{value:"Podman Machine as Root",id:"podman-machine-as-root",level:3},{value:"Other UI and UX Improvements",id:"other-ui-and-ux-improvements",level:3},{value:"Prompt to Open External Website",id:"prompt-to-open-external-website",level:4},{value:"Editable Numeric Preferences",id:"editable-numeric-preferences",level:4},{value:"Navigation tooltips",id:"navigation-tooltips",level:4},{value:"Other Notable Enhancements",id:"other-notable-enhancements",level:2},{value:"Notable Bug Fixes",id:"notable-bug-fixes",level:2},{value:"Community Thank You",id:"community-thank-you",level:2},{value:"Final notes",id:"final-notes",level:2}],h=(m="Icon",function(e){return console.warn("Component "+m+" was not imported, exported, or provided by MDXProvider as global scope"),(0,o.kt)("div",e)});var m;const d={toc:l};function u(e){let{components:t,...r}=e;return(0,o.kt)("wrapper",(0,n.Z)({},d,r,{components:t,mdxType:"MDXLayout"}),(0,o.kt)("p",null,"Podman Desktop 1.0 Release! \ud83c\udf89"),(0,o.kt)("p",null,"We still have many things planned, but with a little polish and a few more bug fixes we\nfelt we've reached a level of maturity and it is now time to declare our 1.0 release."),(0,o.kt)("p",null,"Thank you to everyone who has been with us on this journey so far! Please keep the\nfeedback coming!"),(0,o.kt)("ul",null,(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("strong",{parentName:"li"},"Highlighting Featured Extensions"),": Easily find and install new extensions."),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("strong",{parentName:"li"},"Featured Extensions"),": Two new extensions supporting OpenShift."),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("strong",{parentName:"li"},"Podman Machine as Root"),": Ability to run a Podman machine as root."),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("strong",{parentName:"li"},"UX and UI Improvements"),": Opening external websites, editing numbers, and tooltips.")),(0,o.kt)("p",null,"Podman Desktop 1.0 is now available. ",(0,o.kt)("a",{parentName:"p",href:"/downloads"},"Click here to download it"),"!"),(0,o.kt)("p",null,(0,o.kt)("img",{alt:"Podman-desktop-1-0-hero",src:a(66663).Z,width:"1620",height:"1080"})),(0,o.kt)("hr",null),(0,o.kt)("h2",{id:"release-details"},"Release Details"),(0,o.kt)("h3",{id:"highlighting-featured-extensions"},"Highlighting Featured Extensions"),(0,o.kt)("p",null,"A critical part of our vision for Podman Desktop is the ability to install extensions to\nsupport additional container engines, Kubernetes providers, or other tools. However, it\nhas not been easy to discover new extensions."),(0,o.kt)("p",null,"With 1.0 we show a list of featured extensions in the ",(0,o.kt)("strong",{parentName:"p"},"Welcome"),"\n",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/2354"},"#2354"),", the ",(0,o.kt)("strong",{parentName:"p"},"Dashboard")," and in\n",(0,o.kt)("strong",{parentName:"p"},(0,o.kt)(h,{icon:"fa-solid fa-cog",size:"lg",mdxType:"Icon"})," Settings > Extensions"),"\n",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/2355"},"#2355"),". Check out the new\nextensions for ",(0,o.kt)("strong",{parentName:"p"},"Red Hat OpenShift Local")," and the ",(0,o.kt)("strong",{parentName:"p"},"Developer Sandbox for Red Hat OpenShift"),"!"),(0,o.kt)("p",null,(0,o.kt)("img",{alt:"Featured extensions",src:a(80680).Z,width:"1926",height:"474"})),(0,o.kt)("h3",{id:"featured-extensions"},"Featured Extensions"),(0,o.kt)("p",null,"Speaking of extensions, let's take a minute to turn the spotlight on these two!"),(0,o.kt)("p",null,"Have another idea for extending Podman Desktop? We would love to hear from you or see\nwhat you can create with the ",(0,o.kt)("a",{parentName:"p",href:"/docs/extensions"},"Extension documentation"),",\nand feature your extension here."),(0,o.kt)("h4",{id:"red-hat-openshift-local"},"Red Hat OpenShift Local"),(0,o.kt)("p",null,"OpenShift Local is a fully-featured single-node OpenShift cluster designed to run on your local computer.\nWith this extension you can install, start/stop, and deploy pods or YAML to OpenShift Local,\nallowing you to test your applications on a full OpenShift environment, ensuring a consistent\nexperience between development, test, and production."),(0,o.kt)("p",null,"The recent addition of the MicroShift preset provides a lighter, optimized option that\nstarts faster and uses less resources for deployments that still want OpenShift compatibility\nwithout the full set of OpenShift services."),(0,o.kt)("p",null,(0,o.kt)("img",{alt:"OpenShift Local",src:a(3874).Z,width:"1496",height:"350"})),(0,o.kt)("h4",{id:"developer-sandbox-for-red-hat-openshift"},"Developer Sandbox for Red Hat OpenShift"),(0,o.kt)("p",null,"The OpenShift Developer Sandbox is a free, cloud-based OpenShift environment that allows developers to\ncreate, build, and deploy applications to OpenShift for 30 days. With this extension you can sign up\nand easily deploy pods or YAML to a hosted OpenShift environment without a local installation or\nleaving Podman Desktop."),(0,o.kt)("p",null,(0,o.kt)("img",{alt:"Developer Sandbox",src:a(84249).Z,width:"1484",height:"1016"})),(0,o.kt)("h3",{id:"podman-machine-as-root"},"Podman Machine as Root"),(0,o.kt)("p",null,"When creating a Podman machine you can now decide to run as root ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/2427"},"#2427"),". This is a prerequisite for some scenarios, such as running Kind on Windows."),(0,o.kt)("p",null,(0,o.kt)("img",{alt:"Podman machine as root",src:a(53172).Z,width:"350",height:"122"})),(0,o.kt)("h3",{id:"other-ui-and-ux-improvements"},"Other UI and UX Improvements"),(0,o.kt)("h4",{id:"prompt-to-open-external-website"},"Prompt to Open External Website"),(0,o.kt)("p",null,"In the previous release links to external websites were blocked due to the security risk.\nIn 1.0 you can click to see the URL and have the option of opening or copying it\n",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/2414"},"#2414"),"."),(0,o.kt)("p",null,(0,o.kt)("img",{alt:"External link dialog",src:a(44294).Z,width:"1102",height:"434"})),(0,o.kt)("h4",{id:"editable-numeric-preferences"},"Editable Numeric Preferences"),(0,o.kt)("p",null,"Tired of clicking +, +, +? Us too. Numeric preferences are now editable so\nyou can directly enter the value you want\n",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/2368"},"#2368"),"."),(0,o.kt)("p",null,(0,o.kt)("img",{alt:"Editing numbers",src:a(24875).Z,width:"1334",height:"192"})),(0,o.kt)("h4",{id:"navigation-tooltips"},"Navigation tooltips"),(0,o.kt)("p",null,"We like our new navigation bar, but the tooltips were slow to appear. This made it harder for new\nusers to discover the pages and for power users to see the container/pod/image counts. The\ntooltips are now a little nicer and appear immediately\n",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/2286"},"#2286"),"."),(0,o.kt)("p",null,(0,o.kt)("img",{alt:"Navigation tooltips",src:a(45365).Z,width:"734",height:"192"})),(0,o.kt)("hr",null),(0,o.kt)("h2",{id:"other-notable-enhancements"},"Other Notable Enhancements"),(0,o.kt)("ul",null,(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},"If you use a non-default Podman machine you are now prompted to make it the default, so\nthat command line tools will use the same machine ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/2205"},"#2205"),".")),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},"Extensions can now be installed without requiring a running local container engine\n",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/2273"},"#2273"),".")),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},"When extensions fail to load there is a new state (failed!) and an error message\nto help you fix or report the problem ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/2424"},"#2424"),".")),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},"The showInputBox API has support for Markdown ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/2418"},"#2418"),"."))),(0,o.kt)("hr",null),(0,o.kt)("h2",{id:"notable-bug-fixes"},"Notable Bug Fixes"),(0,o.kt)("ul",null,(0,o.kt)("li",{parentName:"ul"},"Fixed shared status when using multiple Podman 4.5 machines ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/2441"},"#2441"),"."),(0,o.kt)("li",{parentName:"ul"},"Fixed hang on exit when telemetry is unreachable ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/2431"},"#2431"),"."),(0,o.kt)("li",{parentName:"ul"},"Reduced initial Podman REST API calls to improve performance ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/2419"},"#2419"),"."),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("strong",{parentName:"li"},"Play Kubernetes YAML")," now honors the namespace ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/2509"},"#2509"),"."),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("strong",{parentName:"li"},"Container")," list was not remembering expand/collapsed status ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/2491"},"#2491"),"."),(0,o.kt)("li",{parentName:"ul"},"Clear previous error when installing Docker extension ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/2469"},"#2469"),"."),(0,o.kt)("li",{parentName:"ul"},"Ensure correct path with running Kind CLI ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/2455"},"#2455"),"."),(0,o.kt)("li",{parentName:"ul"},"Use IPv4 over IPv6 by default ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/2398"},"#2398"),"."),(0,o.kt)("li",{parentName:"ul"},"When changing the Kubernetes pod name, change the app name to match ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/2389"},"#2389"),"."),(0,o.kt)("li",{parentName:"ul"},"Fixed incorrect pod status in ",(0,o.kt)("strong",{parentName:"li"},"Containers")," view ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/2387"},"#2387"),"."),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("strong",{parentName:"li"},"Dashboard")," wasn't correctly refreshing Podman status ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/2359"},"#2359"),".")),(0,o.kt)("hr",null),(0,o.kt)("h2",{id:"community-thank-you"},"Community Thank You"),(0,o.kt)("p",null,"\ud83c\udf89 We\u2019d like to say a big thank you to everyone who helped to make Podman Desktop even better. In this final\nsprint we received pull requests from the following people:"),(0,o.kt)("ul",null,(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("a",{parentName:"li",href:"https://github.com/TahaAttari"},"Taha Attari")," in ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/2470"},"#2470 - Update docker command in importing-saved-containers.md")),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("a",{parentName:"li",href:"https://github.com/n1hility"},"Jason Greene")," in ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/2431"},"#2431 - Fix hang on exit when telemetry endpoint is unreachable")),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("a",{parentName:"li",href:"https://github.com/afbjorklund"},"Anders Bj\xf6rklund")," in ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/2571"},"#2571 - Fix the location of the lima podman socket")," and ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/2572"},"#2572 - Fix the state of the lima container provider")),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("a",{parentName:"li",href:"https://github.com/tuckerrc"},"Tucker Chapman")," in ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/2567"},"#2567 - Add example image name in placeholder"))),(0,o.kt)("p",null,"There are now a total of 54 people (and two bots!) who have contributed PRs to Podman Desktop, and we'd\nlike to extend an extra thanks to all of those outside of the immediate development team who contributed\nto get us here:"),(0,o.kt)("p",null,(0,o.kt)("a",{parentName:"p",href:"https://github.com/afbjorklund"},"afbjorklund"),",\n",(0,o.kt)("a",{parentName:"p",href:"https://github.com/alv67"},"alv67"),",\n",(0,o.kt)("a",{parentName:"p",href:"https://github.com/anjannath"},"anjannath"),",\n",(0,o.kt)("a",{parentName:"p",href:"https://github.com/ankanroy-code"},"ankanroy-code"),",\n",(0,o.kt)("a",{parentName:"p",href:"https://github.com/arixmkii"},"arixmkii"),",\n",(0,o.kt)("a",{parentName:"p",href:"https://github.com/cblecker"},"cblecker"),",\n",(0,o.kt)("a",{parentName:"p",href:"https://github.com/cfergeau"},"cfergeau"),",\n",(0,o.kt)("a",{parentName:"p",href:"https://github.com/chevdor"},"chevdor"),",\n",(0,o.kt)("a",{parentName:"p",href:"https://github.com/chrisjsimpson"},"chrisjsimpson"),",\n",(0,o.kt)("a",{parentName:"p",href:"https://github.com/cu8code"},"cu8code"),",\n",(0,o.kt)("a",{parentName:"p",href:"https://github.com/doehyunbaek"},"doehyunbaek"),",\n",(0,o.kt)("a",{parentName:"p",href:"https://github.com/dylanmtaylor"},"dylanmtaylor"),",\n",(0,o.kt)("a",{parentName:"p",href:"https://github.com/eidottermihi"},"eidottermihi"),",\n",(0,o.kt)("a",{parentName:"p",href:"https://github.com/elervik"},"elervik"),",\n",(0,o.kt)("a",{parentName:"p",href:"https://github.com/emmanuelbernard"},"emmanuelbernard"),",\n",(0,o.kt)("a",{parentName:"p",href:"https://github.com/evanfpearson"},"evanfpearson"),",\n",(0,o.kt)("a",{parentName:"p",href:"https://github.com/gorkem"},"gorkem"),",\n",(0,o.kt)("a",{parentName:"p",href:"https://github.com/idjohnson"},"idjohnson"),",\n",(0,o.kt)("a",{parentName:"p",href:"https://github.com/imphil"},"imphil"),",\n",(0,o.kt)("a",{parentName:"p",href:"https://github.com/iongion"},"iongion"),",\n",(0,o.kt)("a",{parentName:"p",href:"https://github.com/jlosito"},"jlosito"),",\n",(0,o.kt)("a",{parentName:"p",href:"https://github.com/KevinAtSesam"},"KevinAtSesam"),",\n",(0,o.kt)("a",{parentName:"p",href:"https://github.com/lsm5"},"lsm5"),",\n",(0,o.kt)("a",{parentName:"p",href:"https://github.com/Mitch9378"},"Mitch9378"),",\n",(0,o.kt)("a",{parentName:"p",href:"https://github.com/n1hility"},"n1hility"),",\n",(0,o.kt)("a",{parentName:"p",href:"https://github.com/osslate"},"osslate"),",\n",(0,o.kt)("a",{parentName:"p",href:"https://github.com/PatentLobster"},"PatentLobster"),",\n",(0,o.kt)("a",{parentName:"p",href:"https://github.com/pwright"},"pwright"),",\n",(0,o.kt)("a",{parentName:"p",href:"https://github.com/rdwz"},"rdwz"),",\n",(0,o.kt)("a",{parentName:"p",href:"https://github.com/redhatrises"},"redhatrises"),",\n",(0,o.kt)("a",{parentName:"p",href:"https://github.com/rhatdan"},"rhatdan"),",\n",(0,o.kt)("a",{parentName:"p",href:"https://github.com/RobotSail"},"RobotSail"),",\n",(0,o.kt)("a",{parentName:"p",href:"https://github.com/rohit-rambade"},"rohit-rambade"),",\n",(0,o.kt)("a",{parentName:"p",href:"https://github.com/rsvoboda"},"rsvoboda"),",\n",(0,o.kt)("a",{parentName:"p",href:"https://github.com/sfrunza13"},"sfrunza13"),",\n",(0,o.kt)("a",{parentName:"p",href:"https://github.com/shemanaev"},"shemanaev"),",\n",(0,o.kt)("a",{parentName:"p",href:"https://github.com/sstosh"},"sstosh"),",\n",(0,o.kt)("a",{parentName:"p",href:"https://github.com/stickster"},"stickster"),",\n",(0,o.kt)("a",{parentName:"p",href:"https://github.com/TahaAttari"},"TahaAttari"),",\n",(0,o.kt)("a",{parentName:"p",href:"https://github.com/ths83"},"ths83"),",\n",(0,o.kt)("a",{parentName:"p",href:"https://github.com/Tony-Sol"},"Tony-Sol"),",\n",(0,o.kt)("a",{parentName:"p",href:"https://github.com/tuckerrc"},"tuckerrc"),",\n",(0,o.kt)("a",{parentName:"p",href:"https://github.com/ucomesdag"},"ucomesdag"),",\n",(0,o.kt)("a",{parentName:"p",href:"https://github.com/xbabalov"},"xbabalov"),",\nzezo2019."),(0,o.kt)("hr",null),(0,o.kt)("h2",{id:"final-notes"},"Final notes"),(0,o.kt)("p",null,"The complete list of issues fixed in this release is available ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/issues?q=is%3Aclosed+milestone%3A1.0.0"},"here")," and ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/issues?q=is%3Aclosed+milestone%3A1.0.1"},"here"),"."),(0,o.kt)("p",null,"Get the latest release from the ",(0,o.kt)("a",{parentName:"p",href:"/downloads"},"Downloads")," section of the website and boost your development journey with Podman Desktop. Additionally, visit the ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop"},"GitHub repository")," and see how you can help us make Podman Desktop better."))}u.isMDXComponent=!0},24875:(e,t,a)=>{a.d(t,{Z:()=>n});const n=a.p+"assets/images/edit-number-8da457a123eb3cd6afc3dca7eda00870.png"},44294:(e,t,a)=>{a.d(t,{Z:()=>n});const n=a.p+"assets/images/external-link-d70735d4fe675915dd25761daf1f1684.png"},80680:(e,t,a)=>{a.d(t,{Z:()=>n});const n=a.p+"assets/images/featured-extensions-52dff6ccab42c42fd50f37bdf870f19f.png"},45365:(e,t,a)=>{a.d(t,{Z:()=>n});const n=a.p+"assets/images/nav-tooltips-000f080b595ddbdd177b7004f23aea5b.png"},3874:(e,t,a)=>{a.d(t,{Z:()=>n});const n=a.p+"assets/images/openshift-local-39a086441b856524414c7a8d9370ce14.png"},66663:(e,t,a)=>{a.d(t,{Z:()=>n});const n=a.p+"assets/images/podman-desktop-release-1.0-b1e0008ec8a98fcc5628fa05b667d802.jpg"},53172:(e,t,a)=>{a.d(t,{Z:()=>n});const n=a.p+"assets/images/podman-root-afa83c0f605f6db26dc237d45ccdbe94.png"},84249:(e,t,a)=>{a.d(t,{Z:()=>n});const n=a.p+"assets/images/sandbox-1957747367cc8134b7a178347a952886.png"}}]); \ No newline at end of file diff --git a/assets/js/4213e5b1.2a5e16f5.js b/assets/js/4213e5b1.2a5e16f5.js deleted file mode 100644 index 9ed8ec2607e..00000000000 --- a/assets/js/4213e5b1.2a5e16f5.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[9973],{35318:(e,t,n)=>{n.d(t,{Zo:()=>p,kt:()=>u});var a=n(27378);function r(e,t,n){return t in e?Object.defineProperty(e,t,{value:n,enumerable:!0,configurable:!0,writable:!0}):e[t]=n,e}function o(e,t){var n=Object.keys(e);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);t&&(a=a.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),n.push.apply(n,a)}return n}function i(e){for(var t=1;t=0||(r[n]=e[n]);return r}(e,t);if(Object.getOwnPropertySymbols){var o=Object.getOwnPropertySymbols(e);for(a=0;a=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(r[n]=e[n])}return r}var c=a.createContext({}),s=function(e){var t=a.useContext(c),n=t;return e&&(n="function"==typeof e?e(t):i(i({},t),e)),n},p=function(e){var t=s(e.components);return a.createElement(c.Provider,{value:t},e.children)},m={inlineCode:"code",wrapper:function(e){var t=e.children;return a.createElement(a.Fragment,{},t)}},k=a.forwardRef((function(e,t){var n=e.components,r=e.mdxType,o=e.originalType,c=e.parentName,p=l(e,["components","mdxType","originalType","parentName"]),k=s(n),u=r,d=k["".concat(c,".").concat(u)]||k[u]||m[u]||o;return n?a.createElement(d,i(i({ref:t},p),{},{components:n})):a.createElement(d,i({ref:t},p))}));function u(e,t){var n=arguments,r=t&&t.mdxType;if("string"==typeof e||r){var o=n.length,i=new Array(o);i[0]=k;var l={};for(var c in t)hasOwnProperty.call(t,c)&&(l[c]=t[c]);l.originalType=e,l.mdxType="string"==typeof e?e:r,i[1]=l;for(var s=2;s{n.r(t),n.d(t,{assets:()=>c,contentTitle:()=>i,default:()=>m,frontMatter:()=>o,metadata:()=>l,toc:()=>s});var a=n(25773),r=(n(27378),n(35318));const o={sidebar_position:30,title:"Containers",description:"Starting a container on your container engine.",keywords:["podman desktop","podman","containers","images"],tags:["images"]},i="Starting a container on your container engine",l={unversionedId:"containers/starting-a-container",id:"containers/starting-a-container",title:"Containers",description:"Starting a container on your container engine.",source:"@site/docs/containers/starting-a-container.md",sourceDirName:"containers",slug:"/containers/starting-a-container",permalink:"/docs/containers/starting-a-container",draft:!1,editUrl:"https://github.com/containers/podman-desktop/tree/main/website/docs/containers/starting-a-container.md",tags:[{label:"images",permalink:"/docs/tags/images"}],version:"current",sidebarPosition:30,frontMatter:{sidebar_position:30,title:"Containers",description:"Starting a container on your container engine.",keywords:["podman desktop","podman","containers","images"],tags:["images"]},sidebar:"mySidebar",previous:{title:"Pulling an image",permalink:"/docs/containers/images/pulling-an-image"},next:{title:"Pods",permalink:"/docs/containers/creating-a-pod"}},c={},s=[{value:"Prerequisites",id:"prerequisites",level:4},{value:"Procedure",id:"procedure",level:4},{value:"Verification",id:"verification",level:4}],p={toc:s};function m(e){let{components:t,...n}=e;return(0,r.kt)("wrapper",(0,a.Z)({},p,n,{components:t,mdxType:"MDXLayout"}),(0,r.kt)("h1",{id:"starting-a-container-on-your-container-engine"},"Starting a container on your container engine"),(0,r.kt)("p",null,"With Podman Desktop, you can start a container from an image on your container engine.\nYou can interact with the running container by using the terminal in Podman Desktop, or by opening your browser to the exposed ports."),(0,r.kt)("h4",{id:"prerequisites"},"Prerequisites"),(0,r.kt)("ul",null,(0,r.kt)("li",{parentName:"ul"},"The ",(0,r.kt)("strong",{parentName:"li"},(0,r.kt)("icon",{icon:"fa-solid fa-cloud",size:"lg"})," Images")," list has your image, such as ",(0,r.kt)("inlineCode",{parentName:"li"},"quay.io/podman/hello"),".")),(0,r.kt)("h4",{id:"procedure"},"Procedure"),(0,r.kt)("ol",null,(0,r.kt)("li",{parentName:"ol"},"Go to ",(0,r.kt)("strong",{parentName:"li"},(0,r.kt)("icon",{icon:"fa-solid fa-cloud",size:"lg"})," Images"),"."),(0,r.kt)("li",{parentName:"ol"},"On the line with your image name, such as ",(0,r.kt)("inlineCode",{parentName:"li"},"quay.io/podman/hello"),", click ",(0,r.kt)("strong",{parentName:"li"},(0,r.kt)("icon",{icon:"fa-solid fa-play",size:"lg"})),"."),(0,r.kt)("li",{parentName:"ol"},"On the ",(0,r.kt)("strong",{parentName:"li"},"Create a container")," screen, review the configuration."),(0,r.kt)("li",{parentName:"ol"},"Click ",(0,r.kt)("strong",{parentName:"li"},(0,r.kt)("icon",{icon:"fa-solid fa-play",size:"lg"})," Start Container"),".")),(0,r.kt)("h4",{id:"verification"},"Verification"),(0,r.kt)("ol",null,(0,r.kt)("li",{parentName:"ol"},"Go to ",(0,r.kt)("strong",{parentName:"li"},(0,r.kt)("icon",{icon:"fa-solid fa-cubes",size:"lg"})," Containers"),"."),(0,r.kt)("li",{parentName:"ol"},(0,r.kt)("strong",{parentName:"li"},(0,r.kt)("icon",{icon:"fa-solid fa-search",size:"lg"})),": Enter your image name, such as ",(0,r.kt)("inlineCode",{parentName:"li"},"quay.io/podman/hello"),", to find your running container."),(0,r.kt)("li",{parentName:"ol"},"Click your running container name."),(0,r.kt)("li",{parentName:"ol"},"To view logs:",(0,r.kt)("ol",{parentName:"li"},(0,r.kt)("li",{parentName:"ol"},"Go to ",(0,r.kt)("strong",{parentName:"li"},"Logs"),"."),(0,r.kt)("li",{parentName:"ol"},"Browse the content."))),(0,r.kt)("li",{parentName:"ol"},"To inspect the container:",(0,r.kt)("ol",{parentName:"li"},(0,r.kt)("li",{parentName:"ol"},"Go to ",(0,r.kt)("strong",{parentName:"li"},"Inspect"),"."),(0,r.kt)("li",{parentName:"ol"},"Click the content area to activate it."),(0,r.kt)("li",{parentName:"ol"},"Enter ",(0,r.kt)("kbd",null,"Ctrl")," + ",(0,r.kt)("kbd",null,"F")," on Windows and Linux, or ",(0,r.kt)("kbd",null,"\u2318")," + ",(0,r.kt)("kbd",null,"F")," on macOS to start searching in the content."))),(0,r.kt)("li",{parentName:"ol"},"To generate Kubernetes YAML, when your container engine is Podman:",(0,r.kt)("ol",{parentName:"li"},(0,r.kt)("li",{parentName:"ol"},"Go to ",(0,r.kt)("strong",{parentName:"li"},"Kube"),"."),(0,r.kt)("li",{parentName:"ol"},"Click the content area to activate it."),(0,r.kt)("li",{parentName:"ol"},"Enter ",(0,r.kt)("kbd",null,"Ctrl")," + ",(0,r.kt)("kbd",null,"F")," on Windows and Linux, or ",(0,r.kt)("kbd",null,"\u2318")," + ",(0,r.kt)("kbd",null,"F")," on macOS to start searching in the content."),(0,r.kt)("li",{parentName:"ol"},"Copy the content to a YAML file."),(0,r.kt)("li",{parentName:"ol"},"Later, you can reuse this file to start a container in Podman from Kubernetes YAML, or to start a pod in Kubernetes."))),(0,r.kt)("li",{parentName:"ol"},"To interact with the container terminal:",(0,r.kt)("ol",{parentName:"li"},(0,r.kt)("li",{parentName:"ol"},"Go to ",(0,r.kt)("strong",{parentName:"li"},"Terminal"),"."),(0,r.kt)("li",{parentName:"ol"},"Click the content area to activate the terminal."),(0,r.kt)("li",{parentName:"ol"},"Enter your commands."))),(0,r.kt)("li",{parentName:"ol"},"To interact with the exposed ports:",(0,r.kt)("ol",{parentName:"li"},(0,r.kt)("li",{parentName:"ol"},"Click ",(0,r.kt)("strong",{parentName:"li"},(0,r.kt)("icon",{icon:"fa-solid fa-external-link",size:"lg"})),"."),(0,r.kt)("li",{parentName:"ol"},"Your browser opens a page to the first exposed port on ",(0,r.kt)("inlineCode",{parentName:"li"},"localhost"),"."))),(0,r.kt)("li",{parentName:"ol"},"To deploy to your current Kubernetes context, when you container engine is Podman:",(0,r.kt)("ol",{parentName:"li"},(0,r.kt)("li",{parentName:"ol"},"Click ",(0,r.kt)("strong",{parentName:"li"},(0,r.kt)("icon",{icon:"fa-solid fa-rocket",size:"lg"})),"."),(0,r.kt)("li",{parentName:"ol"},"Review the ",(0,r.kt)("strong",{parentName:"li"},"Deploy generated pod to Kubernetes")," screen."),(0,r.kt)("li",{parentName:"ol"},"Click ",(0,r.kt)("strong",{parentName:"li"},(0,r.kt)("icon",{icon:"fa-solid fa-rocket",size:"lg"})),"."))),(0,r.kt)("li",{parentName:"ol"},"To stop the container:"),(0,r.kt)("li",{parentName:"ol"},"Click ",(0,r.kt)("strong",{parentName:"li"},(0,r.kt)("icon",{icon:"fa-solid fa-stop",size:"lg"})),"."),(0,r.kt)("li",{parentName:"ol"},"To delete the container:"),(0,r.kt)("li",{parentName:"ol"},"Click ",(0,r.kt)("strong",{parentName:"li"},(0,r.kt)("icon",{icon:"fa-solid fa-trash",size:"lg"})),".")))}m.isMDXComponent=!0}}]); \ No newline at end of file diff --git a/assets/js/4213e5b1.eb013531.js b/assets/js/4213e5b1.eb013531.js new file mode 100644 index 00000000000..5d450ba2f7f --- /dev/null +++ b/assets/js/4213e5b1.eb013531.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[9973],{35318:(e,t,n)=>{n.d(t,{Zo:()=>p,kt:()=>d});var a=n(27378);function o(e,t,n){return t in e?Object.defineProperty(e,t,{value:n,enumerable:!0,configurable:!0,writable:!0}):e[t]=n,e}function r(e,t){var n=Object.keys(e);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);t&&(a=a.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),n.push.apply(n,a)}return n}function i(e){for(var t=1;t=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(e);for(a=0;a=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var c=a.createContext({}),s=function(e){var t=a.useContext(c),n=t;return e&&(n="function"==typeof e?e(t):i(i({},t),e)),n},p=function(e){var t=s(e.components);return a.createElement(c.Provider,{value:t},e.children)},m={inlineCode:"code",wrapper:function(e){var t=e.children;return a.createElement(a.Fragment,{},t)}},k=a.forwardRef((function(e,t){var n=e.components,o=e.mdxType,r=e.originalType,c=e.parentName,p=l(e,["components","mdxType","originalType","parentName"]),k=s(n),d=o,u=k["".concat(c,".").concat(d)]||k[d]||m[d]||r;return n?a.createElement(u,i(i({ref:t},p),{},{components:n})):a.createElement(u,i({ref:t},p))}));function d(e,t){var n=arguments,o=t&&t.mdxType;if("string"==typeof e||o){var r=n.length,i=new Array(r);i[0]=k;var l={};for(var c in t)hasOwnProperty.call(t,c)&&(l[c]=t[c]);l.originalType=e,l.mdxType="string"==typeof e?e:o,i[1]=l;for(var s=2;s{n.r(t),n.d(t,{assets:()=>c,contentTitle:()=>i,default:()=>d,frontMatter:()=>r,metadata:()=>l,toc:()=>s});var a=n(25773),o=(n(27378),n(35318));const r={sidebar_position:30,title:"Containers",description:"Starting a container on your container engine.",keywords:["podman desktop","podman","containers","images"],tags:["images"]},i="Starting a container on your container engine",l={unversionedId:"containers/starting-a-container",id:"containers/starting-a-container",title:"Containers",description:"Starting a container on your container engine.",source:"@site/docs/containers/starting-a-container.md",sourceDirName:"containers",slug:"/containers/starting-a-container",permalink:"/docs/containers/starting-a-container",draft:!1,editUrl:"https://github.com/containers/podman-desktop/tree/main/website/docs/containers/starting-a-container.md",tags:[{label:"images",permalink:"/docs/tags/images"}],version:"current",sidebarPosition:30,frontMatter:{sidebar_position:30,title:"Containers",description:"Starting a container on your container engine.",keywords:["podman desktop","podman","containers","images"],tags:["images"]},sidebar:"mySidebar",previous:{title:"Pulling an image",permalink:"/docs/containers/images/pulling-an-image"},next:{title:"Pods",permalink:"/docs/containers/creating-a-pod"}},c={},s=[{value:"Prerequisites",id:"prerequisites",level:4},{value:"Procedure",id:"procedure",level:4},{value:"Verification",id:"verification",level:4}],p=(m="Icon",function(e){return console.warn("Component "+m+" was not imported, exported, or provided by MDXProvider as global scope"),(0,o.kt)("div",e)});var m;const k={toc:s};function d(e){let{components:t,...n}=e;return(0,o.kt)("wrapper",(0,a.Z)({},k,n,{components:t,mdxType:"MDXLayout"}),(0,o.kt)("h1",{id:"starting-a-container-on-your-container-engine"},"Starting a container on your container engine"),(0,o.kt)("p",null,"With Podman Desktop, you can start a container from an image on your container engine.\nYou can interact with the running container by using the terminal in Podman Desktop, or by opening your browser to the exposed ports."),(0,o.kt)("h4",{id:"prerequisites"},"Prerequisites"),(0,o.kt)("ul",null,(0,o.kt)("li",{parentName:"ul"},"The ",(0,o.kt)("strong",{parentName:"li"},(0,o.kt)(p,{icon:"fa-solid fa-cloud",size:"lg",mdxType:"Icon"})," Images")," list has your image, such as ",(0,o.kt)("inlineCode",{parentName:"li"},"quay.io/podman/hello"),".")),(0,o.kt)("h4",{id:"procedure"},"Procedure"),(0,o.kt)("ol",null,(0,o.kt)("li",{parentName:"ol"},"Go to ",(0,o.kt)("strong",{parentName:"li"},(0,o.kt)(p,{icon:"fa-solid fa-cloud",size:"lg",mdxType:"Icon"})," Images"),"."),(0,o.kt)("li",{parentName:"ol"},"On the line with your image name, such as ",(0,o.kt)("inlineCode",{parentName:"li"},"quay.io/podman/hello"),", click ",(0,o.kt)("strong",{parentName:"li"},(0,o.kt)(p,{icon:"fa-solid fa-play",size:"lg",mdxType:"Icon"})),"."),(0,o.kt)("li",{parentName:"ol"},"On the ",(0,o.kt)("strong",{parentName:"li"},"Create a container")," screen, review the configuration."),(0,o.kt)("li",{parentName:"ol"},"Click ",(0,o.kt)("strong",{parentName:"li"},(0,o.kt)(p,{icon:"fa-solid fa-play",size:"lg",mdxType:"Icon"})," Start Container"),".")),(0,o.kt)("h4",{id:"verification"},"Verification"),(0,o.kt)("ol",null,(0,o.kt)("li",{parentName:"ol"},"Go to ",(0,o.kt)("strong",{parentName:"li"},(0,o.kt)(p,{icon:"fa-solid fa-cubes",size:"lg",mdxType:"Icon"})," Containers"),"."),(0,o.kt)("li",{parentName:"ol"},(0,o.kt)("strong",{parentName:"li"},(0,o.kt)(p,{icon:"fa-solid fa-search",size:"lg",mdxType:"Icon"})),": Enter your image name, such as ",(0,o.kt)("inlineCode",{parentName:"li"},"quay.io/podman/hello"),", to find your running container."),(0,o.kt)("li",{parentName:"ol"},"Click your running container name."),(0,o.kt)("li",{parentName:"ol"},"To view logs:",(0,o.kt)("ol",{parentName:"li"},(0,o.kt)("li",{parentName:"ol"},"Go to ",(0,o.kt)("strong",{parentName:"li"},"Logs"),"."),(0,o.kt)("li",{parentName:"ol"},"Browse the content."))),(0,o.kt)("li",{parentName:"ol"},"To inspect the container:",(0,o.kt)("ol",{parentName:"li"},(0,o.kt)("li",{parentName:"ol"},"Go to ",(0,o.kt)("strong",{parentName:"li"},"Inspect"),"."),(0,o.kt)("li",{parentName:"ol"},"Click the content area to activate it."),(0,o.kt)("li",{parentName:"ol"},"Enter ",(0,o.kt)("kbd",null,"Ctrl")," + ",(0,o.kt)("kbd",null,"F")," on Windows and Linux, or ",(0,o.kt)("kbd",null,"\u2318")," + ",(0,o.kt)("kbd",null,"F")," on macOS to start searching in the content."))),(0,o.kt)("li",{parentName:"ol"},"To generate Kubernetes YAML, when your container engine is Podman:",(0,o.kt)("ol",{parentName:"li"},(0,o.kt)("li",{parentName:"ol"},"Go to ",(0,o.kt)("strong",{parentName:"li"},"Kube"),"."),(0,o.kt)("li",{parentName:"ol"},"Click the content area to activate it."),(0,o.kt)("li",{parentName:"ol"},"Enter ",(0,o.kt)("kbd",null,"Ctrl")," + ",(0,o.kt)("kbd",null,"F")," on Windows and Linux, or ",(0,o.kt)("kbd",null,"\u2318")," + ",(0,o.kt)("kbd",null,"F")," on macOS to start searching in the content."),(0,o.kt)("li",{parentName:"ol"},"Copy the content to a YAML file."),(0,o.kt)("li",{parentName:"ol"},"Later, you can reuse this file to start a container in Podman from Kubernetes YAML, or to start a pod in Kubernetes."))),(0,o.kt)("li",{parentName:"ol"},"To interact with the container terminal:",(0,o.kt)("ol",{parentName:"li"},(0,o.kt)("li",{parentName:"ol"},"Go to ",(0,o.kt)("strong",{parentName:"li"},"Terminal"),"."),(0,o.kt)("li",{parentName:"ol"},"Click the content area to activate the terminal."),(0,o.kt)("li",{parentName:"ol"},"Enter your commands."))),(0,o.kt)("li",{parentName:"ol"},"To interact with the exposed ports:",(0,o.kt)("ol",{parentName:"li"},(0,o.kt)("li",{parentName:"ol"},"Click ",(0,o.kt)("strong",{parentName:"li"},(0,o.kt)(p,{icon:"fa-solid fa-external-link",size:"lg",mdxType:"Icon"})),"."),(0,o.kt)("li",{parentName:"ol"},"Your browser opens a page to the first exposed port on ",(0,o.kt)("inlineCode",{parentName:"li"},"localhost"),"."))),(0,o.kt)("li",{parentName:"ol"},"To deploy to your current Kubernetes context, when you container engine is Podman:",(0,o.kt)("ol",{parentName:"li"},(0,o.kt)("li",{parentName:"ol"},"Click ",(0,o.kt)("strong",{parentName:"li"},(0,o.kt)(p,{icon:"fa-solid fa-rocket",size:"lg",mdxType:"Icon"})),"."),(0,o.kt)("li",{parentName:"ol"},"Review the ",(0,o.kt)("strong",{parentName:"li"},"Deploy generated pod to Kubernetes")," screen."),(0,o.kt)("li",{parentName:"ol"},"Click ",(0,o.kt)("strong",{parentName:"li"},(0,o.kt)(p,{icon:"fa-solid fa-rocket",size:"lg",mdxType:"Icon"})),"."))),(0,o.kt)("li",{parentName:"ol"},"To stop the container:"),(0,o.kt)("li",{parentName:"ol"},"Click ",(0,o.kt)("strong",{parentName:"li"},(0,o.kt)(p,{icon:"fa-solid fa-stop",size:"lg",mdxType:"Icon"})),"."),(0,o.kt)("li",{parentName:"ol"},"To delete the container:"),(0,o.kt)("li",{parentName:"ol"},"Click ",(0,o.kt)("strong",{parentName:"li"},(0,o.kt)(p,{icon:"fa-solid fa-trash",size:"lg",mdxType:"Icon"})),".")))}d.isMDXComponent=!0}}]); \ No newline at end of file diff --git a/assets/js/473de3ed.9ed7082a.js b/assets/js/473de3ed.9ed7082a.js deleted file mode 100644 index fa4417ec878..00000000000 --- a/assets/js/473de3ed.9ed7082a.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[9043],{35318:(e,t,n)=>{n.d(t,{Zo:()=>u,kt:()=>d});var a=n(27378);function r(e,t,n){return t in e?Object.defineProperty(e,t,{value:n,enumerable:!0,configurable:!0,writable:!0}):e[t]=n,e}function i(e,t){var n=Object.keys(e);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);t&&(a=a.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),n.push.apply(n,a)}return n}function o(e){for(var t=1;t=0||(r[n]=e[n]);return r}(e,t);if(Object.getOwnPropertySymbols){var i=Object.getOwnPropertySymbols(e);for(a=0;a=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(r[n]=e[n])}return r}var s=a.createContext({}),p=function(e){var t=a.useContext(s),n=t;return e&&(n="function"==typeof e?e(t):o(o({},t),e)),n},u=function(e){var t=p(e.components);return a.createElement(s.Provider,{value:t},e.children)},m={inlineCode:"code",wrapper:function(e){var t=e.children;return a.createElement(a.Fragment,{},t)}},c=a.forwardRef((function(e,t){var n=e.components,r=e.mdxType,i=e.originalType,s=e.parentName,u=l(e,["components","mdxType","originalType","parentName"]),c=p(n),d=r,k=c["".concat(s,".").concat(d)]||c[d]||m[d]||i;return n?a.createElement(k,o(o({ref:t},u),{},{components:n})):a.createElement(k,o({ref:t},u))}));function d(e,t){var n=arguments,r=t&&t.mdxType;if("string"==typeof e||r){var i=n.length,o=new Array(i);o[0]=c;var l={};for(var s in t)hasOwnProperty.call(t,s)&&(l[s]=t[s]);l.originalType=e,l.mdxType="string"==typeof e?e:r,o[1]=l;for(var p=2;p{n.r(t),n.d(t,{assets:()=>s,contentTitle:()=>o,default:()=>m,frontMatter:()=>i,metadata:()=>l,toc:()=>p});var a=n(25773),r=(n(27378),n(35318));const i={sidebar_position:10,title:"Push an image to Kind",description:"Pushing an image to your Kind cluster",keywords:["podman desktop","podman","containers","images","migrating","kubernetes"],tags:["migrating-to-kubernetes","images"]},o="Pushing an image to your local Kind-powered Kubernetes cluster",l={unversionedId:"kubernetes/kind/pushing-an-image-to-kind",id:"kubernetes/kind/pushing-an-image-to-kind",title:"Push an image to Kind",description:"Pushing an image to your Kind cluster",source:"@site/docs/kubernetes/kind/pushing-an-image-to-kind.md",sourceDirName:"kubernetes/kind",slug:"/kubernetes/kind/pushing-an-image-to-kind",permalink:"/docs/kubernetes/kind/pushing-an-image-to-kind",draft:!1,editUrl:"https://github.com/containers/podman-desktop/tree/main/website/docs/kubernetes/kind/pushing-an-image-to-kind.md",tags:[{label:"migrating-to-kubernetes",permalink:"/docs/tags/migrating-to-kubernetes"},{label:"images",permalink:"/docs/tags/images"}],version:"current",sidebarPosition:10,frontMatter:{sidebar_position:10,title:"Push an image to Kind",description:"Pushing an image to your Kind cluster",keywords:["podman desktop","podman","containers","images","migrating","kubernetes"],tags:["migrating-to-kubernetes","images"]},sidebar:"mySidebar",previous:{title:"Existing Kubernetes",permalink:"/docs/kubernetes/existing-kubernetes/"},next:{title:"Kind",permalink:"/docs/kind/"}},s={},p=[{value:"Prerequisites",id:"prerequisites",level:4},{value:"Procedure",id:"procedure",level:4},{value:"Verification",id:"verification",level:4}],u={toc:p};function m(e){let{components:t,...n}=e;return(0,r.kt)("wrapper",(0,a.Z)({},u,n,{components:t,mdxType:"MDXLayout"}),(0,r.kt)("h1",{id:"pushing-an-image-to-your-local-kind-powered-kubernetes-cluster"},"Pushing an image to your local Kind-powered Kubernetes cluster"),(0,r.kt)("p",null,"With Podman Desktop, you can push an image to your local Kind-powered Kubernetes cluster."),(0,r.kt)("h4",{id:"prerequisites"},"Prerequisites"),(0,r.kt)("ul",null,(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("a",{parentName:"li",href:"/docs/containers"},"You onboarded a container engine"),"."),(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("a",{parentName:"li",href:"/docs/kind"},"You onboarded a Kind cluster"),"."),(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("a",{parentName:"li",href:"/docs/kind/working-with-your-local-kind-cluster"},"You have set your Kubernetes context to your local Kind-powered Kubernetes cluster"),"."),(0,r.kt)("li",{parentName:"ul"},"Your image is available on the ",(0,r.kt)("strong",{parentName:"li"},"Images")," page: ",(0,r.kt)("inlineCode",{parentName:"li"},":"),".")),(0,r.kt)("h4",{id:"procedure"},"Procedure"),(0,r.kt)("ol",null,(0,r.kt)("li",{parentName:"ol"},"Open ",(0,r.kt)("strong",{parentName:"li"},"Podman Desktop dashboard > ",(0,r.kt)("icon",{icon:"fa-solid fa-cloud",size:"lg"})," Images"),"."),(0,r.kt)("li",{parentName:"ol"},(0,r.kt)("strong",{parentName:"li"},(0,r.kt)("icon",{icon:"fa-solid fa-search",size:"lg"})," Search images"),": ",(0,r.kt)("inlineCode",{parentName:"li"},":"),"."),(0,r.kt)("li",{parentName:"ol"},"Click ",(0,r.kt)("strong",{parentName:"li"},(0,r.kt)("icon",{icon:"fa-solid fa-ellipsis-v",size:"lg"})," > ",(0,r.kt)("icon",{icon:"fa-solid fa-ellipsis-v",size:"lg"})," Push image to Kind cluster"),"."),(0,r.kt)("li",{parentName:"ol"},"If you created many Kind clusters, select your Kind cluster from the list.")),(0,r.kt)("h4",{id:"verification"},"Verification"),(0,r.kt)("p",null,"Kind does not enable you to list loaded images.\nTherefore, create a Pod that uses the loaded image."),(0,r.kt)("ol",null,(0,r.kt)("li",{parentName:"ol"},(0,r.kt)("p",{parentName:"li"},"Create a ",(0,r.kt)("inlineCode",{parentName:"p"},"verify_my_image.yaml")," Kubernetes YAML file on your workstation.\nReplace the placeholders:"),(0,r.kt)("ul",{parentName:"li"},(0,r.kt)("li",{parentName:"ul"},"Pod ",(0,r.kt)("inlineCode",{parentName:"li"},"name")," and container ",(0,r.kt)("inlineCode",{parentName:"li"},"name")," value must consist of lower case alphanumeric characters, '-' or '.', and must start and end with an alphanumeric character."),(0,r.kt)("li",{parentName:"ul"},"Container ",(0,r.kt)("inlineCode",{parentName:"li"},"image")," value is the image you pushed.")),(0,r.kt)("pre",{parentName:"li"},(0,r.kt)("code",{parentName:"pre",className:"language-yaml"},"apiVersion: v1\nkind: Pod\nmetadata:\n name: \nspec:\n containers:\n - name: \n image: :\n imagePullPolicy: Never\n"))),(0,r.kt)("li",{parentName:"ol"},(0,r.kt)("p",{parentName:"li"},"Open ",(0,r.kt)("strong",{parentName:"p"},(0,r.kt)("icon",{icon:"fa-solid fa-cubes",size:"lg"})," Pods > Play Kubernetes YAML"),"."),(0,r.kt)("ol",{parentName:"li"},(0,r.kt)("li",{parentName:"ol"},(0,r.kt)("strong",{parentName:"li"},"Kubernetes YAML file"),": select your ",(0,r.kt)("inlineCode",{parentName:"li"},"verify_my_image.yaml")," file."),(0,r.kt)("li",{parentName:"ol"},(0,r.kt)("strong",{parentName:"li"},"Select Runtime"),": ",(0,r.kt)("strong",{parentName:"li"},"Using a Kubernetes cluster"),"."),(0,r.kt)("li",{parentName:"ol"},"Click ",(0,r.kt)("strong",{parentName:"li"},"Play"),"."),(0,r.kt)("li",{parentName:"ol"},"Click ",(0,r.kt)("strong",{parentName:"li"},"Done")))),(0,r.kt)("li",{parentName:"ol"},(0,r.kt)("p",{parentName:"li"},"Open ",(0,r.kt)("strong",{parentName:"p"},(0,r.kt)("icon",{icon:"fa-solid fa-cubes",size:"lg"})," Pods"),".")),(0,r.kt)("li",{parentName:"ol"},(0,r.kt)("p",{parentName:"li"},(0,r.kt)("strong",{parentName:"p"},(0,r.kt)("icon",{icon:"fa-solid fa-search",size:"lg"})," Search pods"),": ",(0,r.kt)("inlineCode",{parentName:"p"},""),".")),(0,r.kt)("li",{parentName:"ol"},(0,r.kt)("p",{parentName:"li"},"The pod ",(0,r.kt)("strong",{parentName:"p"},"Status")," is ",(0,r.kt)("strong",{parentName:"p"},"Running"),"."))))}m.isMDXComponent=!0}}]); \ No newline at end of file diff --git a/assets/js/473de3ed.ac1acbcd.js b/assets/js/473de3ed.ac1acbcd.js new file mode 100644 index 00000000000..5436cadc627 --- /dev/null +++ b/assets/js/473de3ed.ac1acbcd.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[9043],{35318:(e,t,n)=>{n.d(t,{Zo:()=>m,kt:()=>d});var a=n(27378);function r(e,t,n){return t in e?Object.defineProperty(e,t,{value:n,enumerable:!0,configurable:!0,writable:!0}):e[t]=n,e}function i(e,t){var n=Object.keys(e);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);t&&(a=a.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),n.push.apply(n,a)}return n}function o(e){for(var t=1;t=0||(r[n]=e[n]);return r}(e,t);if(Object.getOwnPropertySymbols){var i=Object.getOwnPropertySymbols(e);for(a=0;a=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(r[n]=e[n])}return r}var s=a.createContext({}),p=function(e){var t=a.useContext(s),n=t;return e&&(n="function"==typeof e?e(t):o(o({},t),e)),n},m=function(e){var t=p(e.components);return a.createElement(s.Provider,{value:t},e.children)},u={inlineCode:"code",wrapper:function(e){var t=e.children;return a.createElement(a.Fragment,{},t)}},c=a.forwardRef((function(e,t){var n=e.components,r=e.mdxType,i=e.originalType,s=e.parentName,m=l(e,["components","mdxType","originalType","parentName"]),c=p(n),d=r,k=c["".concat(s,".").concat(d)]||c[d]||u[d]||i;return n?a.createElement(k,o(o({ref:t},m),{},{components:n})):a.createElement(k,o({ref:t},m))}));function d(e,t){var n=arguments,r=t&&t.mdxType;if("string"==typeof e||r){var i=n.length,o=new Array(i);o[0]=c;var l={};for(var s in t)hasOwnProperty.call(t,s)&&(l[s]=t[s]);l.originalType=e,l.mdxType="string"==typeof e?e:r,o[1]=l;for(var p=2;p{n.r(t),n.d(t,{assets:()=>s,contentTitle:()=>o,default:()=>d,frontMatter:()=>i,metadata:()=>l,toc:()=>p});var a=n(25773),r=(n(27378),n(35318));const i={sidebar_position:10,title:"Push an image to Kind",description:"Pushing an image to your Kind cluster",keywords:["podman desktop","podman","containers","images","migrating","kubernetes"],tags:["migrating-to-kubernetes","images"]},o="Pushing an image to your local Kind-powered Kubernetes cluster",l={unversionedId:"kubernetes/kind/pushing-an-image-to-kind",id:"kubernetes/kind/pushing-an-image-to-kind",title:"Push an image to Kind",description:"Pushing an image to your Kind cluster",source:"@site/docs/kubernetes/kind/pushing-an-image-to-kind.md",sourceDirName:"kubernetes/kind",slug:"/kubernetes/kind/pushing-an-image-to-kind",permalink:"/docs/kubernetes/kind/pushing-an-image-to-kind",draft:!1,editUrl:"https://github.com/containers/podman-desktop/tree/main/website/docs/kubernetes/kind/pushing-an-image-to-kind.md",tags:[{label:"migrating-to-kubernetes",permalink:"/docs/tags/migrating-to-kubernetes"},{label:"images",permalink:"/docs/tags/images"}],version:"current",sidebarPosition:10,frontMatter:{sidebar_position:10,title:"Push an image to Kind",description:"Pushing an image to your Kind cluster",keywords:["podman desktop","podman","containers","images","migrating","kubernetes"],tags:["migrating-to-kubernetes","images"]},sidebar:"mySidebar",previous:{title:"Existing Kubernetes",permalink:"/docs/kubernetes/existing-kubernetes/"},next:{title:"Kind",permalink:"/docs/kind/"}},s={},p=[{value:"Prerequisites",id:"prerequisites",level:4},{value:"Procedure",id:"procedure",level:4},{value:"Verification",id:"verification",level:4}],m=(u="Icon",function(e){return console.warn("Component "+u+" was not imported, exported, or provided by MDXProvider as global scope"),(0,r.kt)("div",e)});var u;const c={toc:p};function d(e){let{components:t,...n}=e;return(0,r.kt)("wrapper",(0,a.Z)({},c,n,{components:t,mdxType:"MDXLayout"}),(0,r.kt)("h1",{id:"pushing-an-image-to-your-local-kind-powered-kubernetes-cluster"},"Pushing an image to your local Kind-powered Kubernetes cluster"),(0,r.kt)("p",null,"With Podman Desktop, you can push an image to your local Kind-powered Kubernetes cluster."),(0,r.kt)("h4",{id:"prerequisites"},"Prerequisites"),(0,r.kt)("ul",null,(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("a",{parentName:"li",href:"/docs/containers"},"You onboarded a container engine"),"."),(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("a",{parentName:"li",href:"/docs/kind"},"You onboarded a Kind cluster"),"."),(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("a",{parentName:"li",href:"/docs/kind/working-with-your-local-kind-cluster"},"You have set your Kubernetes context to your local Kind-powered Kubernetes cluster"),"."),(0,r.kt)("li",{parentName:"ul"},"Your image is available on the ",(0,r.kt)("strong",{parentName:"li"},"Images")," page: ",(0,r.kt)("inlineCode",{parentName:"li"},":"),".")),(0,r.kt)("h4",{id:"procedure"},"Procedure"),(0,r.kt)("ol",null,(0,r.kt)("li",{parentName:"ol"},"Open ",(0,r.kt)("strong",{parentName:"li"},"Podman Desktop dashboard > ",(0,r.kt)(m,{icon:"fa-solid fa-cloud",size:"lg",mdxType:"Icon"})," Images"),"."),(0,r.kt)("li",{parentName:"ol"},(0,r.kt)("strong",{parentName:"li"},(0,r.kt)(m,{icon:"fa-solid fa-search",size:"lg",mdxType:"Icon"})," Search images"),": ",(0,r.kt)("inlineCode",{parentName:"li"},":"),"."),(0,r.kt)("li",{parentName:"ol"},"Click ",(0,r.kt)("strong",{parentName:"li"},(0,r.kt)(m,{icon:"fa-solid fa-ellipsis-v",size:"lg",mdxType:"Icon"})," > ",(0,r.kt)(m,{icon:"fa-solid fa-ellipsis-v",size:"lg",mdxType:"Icon"})," Push image to Kind cluster"),"."),(0,r.kt)("li",{parentName:"ol"},"If you created many Kind clusters, select your Kind cluster from the list.")),(0,r.kt)("h4",{id:"verification"},"Verification"),(0,r.kt)("p",null,"Kind does not enable you to list loaded images.\nTherefore, create a Pod that uses the loaded image."),(0,r.kt)("ol",null,(0,r.kt)("li",{parentName:"ol"},(0,r.kt)("p",{parentName:"li"},"Create a ",(0,r.kt)("inlineCode",{parentName:"p"},"verify_my_image.yaml")," Kubernetes YAML file on your workstation.\nReplace the placeholders:"),(0,r.kt)("ul",{parentName:"li"},(0,r.kt)("li",{parentName:"ul"},"Pod ",(0,r.kt)("inlineCode",{parentName:"li"},"name")," and container ",(0,r.kt)("inlineCode",{parentName:"li"},"name")," value must consist of lower case alphanumeric characters, '-' or '.', and must start and end with an alphanumeric character."),(0,r.kt)("li",{parentName:"ul"},"Container ",(0,r.kt)("inlineCode",{parentName:"li"},"image")," value is the image you pushed.")),(0,r.kt)("pre",{parentName:"li"},(0,r.kt)("code",{parentName:"pre",className:"language-yaml"},"apiVersion: v1\nkind: Pod\nmetadata:\n name: \nspec:\n containers:\n - name: \n image: :\n imagePullPolicy: Never\n"))),(0,r.kt)("li",{parentName:"ol"},(0,r.kt)("p",{parentName:"li"},"Open ",(0,r.kt)("strong",{parentName:"p"},(0,r.kt)(m,{icon:"fa-solid fa-cubes",size:"lg",mdxType:"Icon"})," Pods > Play Kubernetes YAML"),"."),(0,r.kt)("ol",{parentName:"li"},(0,r.kt)("li",{parentName:"ol"},(0,r.kt)("strong",{parentName:"li"},"Kubernetes YAML file"),": select your ",(0,r.kt)("inlineCode",{parentName:"li"},"verify_my_image.yaml")," file."),(0,r.kt)("li",{parentName:"ol"},(0,r.kt)("strong",{parentName:"li"},"Select Runtime"),": ",(0,r.kt)("strong",{parentName:"li"},"Using a Kubernetes cluster"),"."),(0,r.kt)("li",{parentName:"ol"},"Click ",(0,r.kt)("strong",{parentName:"li"},"Play"),"."),(0,r.kt)("li",{parentName:"ol"},"Click ",(0,r.kt)("strong",{parentName:"li"},"Done")))),(0,r.kt)("li",{parentName:"ol"},(0,r.kt)("p",{parentName:"li"},"Open ",(0,r.kt)("strong",{parentName:"p"},(0,r.kt)(m,{icon:"fa-solid fa-cubes",size:"lg",mdxType:"Icon"})," Pods"),".")),(0,r.kt)("li",{parentName:"ol"},(0,r.kt)("p",{parentName:"li"},(0,r.kt)("strong",{parentName:"p"},(0,r.kt)(m,{icon:"fa-solid fa-search",size:"lg",mdxType:"Icon"})," Search pods"),": ",(0,r.kt)("inlineCode",{parentName:"p"},""),".")),(0,r.kt)("li",{parentName:"ol"},(0,r.kt)("p",{parentName:"li"},"The pod ",(0,r.kt)("strong",{parentName:"p"},"Status")," is ",(0,r.kt)("strong",{parentName:"p"},"Running"),"."))))}d.isMDXComponent=!0}}]); \ No newline at end of file diff --git a/assets/js/4816649b.13b901ec.js b/assets/js/4816649b.13b901ec.js deleted file mode 100644 index 1ee4ee80a22..00000000000 --- a/assets/js/4816649b.13b901ec.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[6690],{75150:(e,t,n)=>{n.r(t),n.d(t,{assets:()=>d,contentTitle:()=>l,default:()=>m,frontMatter:()=>i,metadata:()=>r,toc:()=>p});var a=n(25773),s=(n(27378),n(35318)),o=n(92975);const i={title:"Release Notes - Podman Desktop 0.14",description:"Podman Desktop 0.14 has been released!",slug:"podman-desktop-release-0.14",authors:["deboer"],tags:["podman-desktop","release","kubernetes","kind"],hide_table_of_contents:!1},l=void 0,r={permalink:"/blog/podman-desktop-release-0.14",source:"@site/blog/2023-04-14-release-0.14.md",title:"Release Notes - Podman Desktop 0.14",description:"Podman Desktop 0.14 has been released!",date:"2023-04-14T00:00:00.000Z",formattedDate:"April 14, 2023",tags:[{label:"podman-desktop",permalink:"/blog/tags/podman-desktop"},{label:"release",permalink:"/blog/tags/release"},{label:"kubernetes",permalink:"/blog/tags/kubernetes"},{label:"kind",permalink:"/blog/tags/kind"}],readingTime:4.025,hasTruncateMarker:!0,authors:[{name:"Tim deBoer",title:"Architect",url:"https://github.com/deboer-tim",imageURL:"https://github.com/deboer-tim.png",key:"deboer"}],frontMatter:{title:"Release Notes - Podman Desktop 0.14",description:"Podman Desktop 0.14 has been released!",slug:"podman-desktop-release-0.14",authors:["deboer"],tags:["podman-desktop","release","kubernetes","kind"],hide_table_of_contents:!1},prevItem:{title:"Setting up and running a Kubernetes cluster locally with Podman Desktop",permalink:"/blog/running-a-local-kubernetes-cluster-with-podman-desktop"},nextItem:{title:"Release Notes - Podman Desktop 0.13",permalink:"/blog/podman-desktop-release-0.13"}},d={authorsImageUrls:[void 0]},p=[{value:"Release details",id:"release-details",level:2},{value:"Kind Installation",id:"kind-installation",level:3},{value:"Manage Kind Clusters",id:"manage-kind-clusters",level:3},{value:"Using Kind",id:"using-kind",level:3},{value:"Kind Ingress",id:"kind-ingress",level:3},{value:"UI and UX improvements",id:"ui-and-ux-improvements",level:3},{value:"Updated Preferences",id:"updated-preferences",level:4},{value:"Telemetry Prompt",id:"telemetry-prompt",level:4},{value:"Other notable enhancements",id:"other-notable-enhancements",level:2},{value:"Documentation",id:"documentation",level:2},{value:"Notable bug fixes",id:"notable-bug-fixes",level:2},{value:"Final notes",id:"final-notes",level:2}],u={toc:p};function m(e){let{components:t,...i}=e;return(0,s.kt)("wrapper",(0,a.Z)({},u,i,{components:t,mdxType:"MDXLayout"}),(0,s.kt)("p",null,"Podman Desktop 0.14 - Our Kind-est release yet!"),(0,s.kt)("p",null,"We have been working on a Kind extension for a while now, and decided it is time to promote it\ninto a release just in time for KubeCon and CloudNativeCon Europe!"),(0,s.kt)("p",null,"We're especially excited about releasing Kind because it finally shows the full purpose\nof Podman Desktop: not just local container engines, but Kubernetes too. More importantly,\nproviding tools that allow you to manage both environments and seamlessly move between them."),(0,s.kt)("p",null,"Some of these features were available in development mode over the last few releases,\nbut since they are now in the release build, we will do a full roundup and talk about\nall the Kind features."),(0,s.kt)("ul",null,(0,s.kt)("li",{parentName:"ul"},(0,s.kt)("strong",{parentName:"li"},"Kind Installation"),": Install Kind from the status bar"),(0,s.kt)("li",{parentName:"ul"},(0,s.kt)("strong",{parentName:"li"},"Manage Kind Clusters"),": Create and manage Kind clusters from ",(0,s.kt)("strong",{parentName:"li"},(0,s.kt)("icon",{icon:"fa-solid fa-cog",size:"lg"})," Settings > Resources")),(0,s.kt)("li",{parentName:"ul"},(0,s.kt)("strong",{parentName:"li"},"Using Kind"),": Deploying YAML and sharing images to a cluster"),(0,s.kt)("li",{parentName:"ul"},(0,s.kt)("strong",{parentName:"li"},"Kind Ingress"),": Install a Contour ingress controller"),(0,s.kt)("li",{parentName:"ul"},(0,s.kt)("strong",{parentName:"li"},"UX and UI Improvements"),": Updated preferences and telemetry prompt")),(0,s.kt)("p",null,"Podman Desktop 0.14 is now available. ",(0,s.kt)("a",{parentName:"p",href:"/downloads"},"Click here to download it"),"!"),(0,s.kt)("p",null,(0,s.kt)("img",{alt:"Podman-desktop-0-14-hero",src:n(41767).Z,width:"1140",height:"1097"})),(0,s.kt)("hr",null),(0,s.kt)("h2",{id:"release-details"},"Release details"),(0,s.kt)("h3",{id:"kind-installation"},"Kind Installation"),(0,s.kt)("p",null,"Get Kind up and running in seconds! The Kind extension is now bundled as part of Podman Desktop\n",(0,s.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/issues/1421"},"1421"),"\nand allows you to easily ",(0,s.kt)("a",{parentName:"p",href:"/docs/kind/installing"},"install Kind directly from the status bar"),"\n",(0,s.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/issues/1257"},"1257"),"."),(0,s.kt)("p",null,"The installed ",(0,s.kt)("inlineCode",{parentName:"p"},"kind")," CLI is available from the system shell ",(0,s.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/issues/1516"},"1516"),",\nallowing you to open a terminal window to ",(0,s.kt)("inlineCode",{parentName:"p"},"kind get clusters")," or work with other tools."),(0,s.kt)("h3",{id:"manage-kind-clusters"},"Manage Kind Clusters"),(0,s.kt)("p",null,"Once Kind is installed (or if you already had it), you can manage your clusters in ",(0,s.kt)("strong",{parentName:"p"},(0,s.kt)("icon",{icon:"fa-solid fa-cog",size:"lg"})," Settings > Resources"),".\nFrom here you can ",(0,s.kt)("a",{parentName:"p",href:"/docs/kind/creating-a-kind-cluster"},"create Kind clusters"),",\nstart/stop ",(0,s.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/issues/1953"},"1953"),"\nor delete ",(0,s.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/issues/1977"},"1977")," them."),(0,s.kt)("p",null,(0,s.kt)("img",{alt:"kind-clusters",src:n(45988).Z,width:"1484",height:"364"})),(0,s.kt)("p",null,"The Kind control plane runs as a container. You will see this container\nin the ",(0,s.kt)("strong",{parentName:"p"},"Container")," list and can also start or stop it from there."),(0,s.kt)("h3",{id:"using-kind"},"Using Kind"),(0,s.kt)("p",null,"Now that you have Kind installed and running, what can you do with it?\nIf you like terminals, you can always open one up and use the Kind CLI to\n",(0,s.kt)("a",{parentName:"p",href:"https://kind.sigs.k8s.io/docs/user/quick-start/#interacting-with-your-cluster"},"interact with your cluster"),"."),(0,s.kt)("p",null,"Within Podman Desktop we have started with two ways to interact with the cluster.\nThe first is the ability to play local YAML files on your Kind (or any other Kubernetes!) cluster ",(0,s.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/issues/1261"},"1261"),". This allows you to take existing Kubernetes YAML definitions -\nyour deployments, services, or other objects - and deploy it to the cluster."),(0,s.kt)(o.Z,{playing:!0,controls:!0,url:"https://user-images.githubusercontent.com/436777/231812563-ece0a56a-b347-48f8-a3a7-400eb9449037.mp4",width:"100%",height:"100%",mdxType:"ReactPlayer"}),(0,s.kt)("p",null,"As you deploy pods, they will automatically appear in the list of ",(0,s.kt)("strong",{parentName:"p"},"Pods")," ",(0,s.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/issues/1263"},"1263"),", allowing you to start, stop, and interact them just like pods running on Podman."),(0,s.kt)("p",null,"One of the most common uses is to deploy a container that you have been running on Podman, and this will fail\nif the image is not available in Kind. To solve this we have made it easy to push images from\nPodman to Kind ",(0,s.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/issues/1448"},"1448"),"."),(0,s.kt)("p",null,(0,s.kt)("img",{alt:"push-image-kind",src:n(75281).Z,width:"1054",height:"152"})),(0,s.kt)("h3",{id:"kind-ingress"},"Kind Ingress"),(0,s.kt)("p",null,"If you deploy a pod to Kind, you are also going to want to reach it! To do this you will need to install a load balancer or\ningress controller so that the pod is accessible from outside the cluster. We made it easy to install the Contour ingress\ncontroller while creating a Kind cluster ",(0,s.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/issues/1675"},"1675"),",\nso if you created your cluster with Podman Desktop it is already there!"),(0,s.kt)("p",null,(0,s.kt)("img",{alt:"kind-ingress",src:n(61958).Z,width:"1328",height:"1238"})),(0,s.kt)("p",null,"We have several other Kind and Kubernetes features planned to expand the supported scenarios, but hopefully this\nmakes it easy to get started with Kind and shows where we're headed. As always, feedback is appreciated!"),(0,s.kt)("h3",{id:"ui-and-ux-improvements"},"UI and UX improvements"),(0,s.kt)("h4",{id:"updated-preferences"},"Updated Preferences"),(0,s.kt)("p",null,"The ",(0,s.kt)("strong",{parentName:"p"},(0,s.kt)("icon",{icon:"fa-solid fa-cog",size:"lg"})," Settings > Preferences")," page has been updated with a new design ",(0,s.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/1913"},"1913"),",\nmaking it easier to see and change preferences. Changes are live, no more Update button."),(0,s.kt)("p",null,(0,s.kt)("img",{parentName:"p",src:"https://user-images.githubusercontent.com/49404737/229498507-e754b55c-dcbd-486d-9ee3-a1fe3bed7271.gif",alt:"preferences"})),(0,s.kt)("h4",{id:"telemetry-prompt"},"Telemetry Prompt"),(0,s.kt)("p",null,"The prompt to enable or disable telemetry has been moved from its own dialog into the ",(0,s.kt)("strong",{parentName:"p"},"Welcome")," screen.\n",(0,s.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/1927"},"1927"),"\nThis is more usable, one less prompt, and solves a window-layering issue for some users!"),(0,s.kt)("p",null,(0,s.kt)("img",{parentName:"p",src:"https://user-images.githubusercontent.com/19958075/229577331-365a9a01-0426-4482-a95d-f5dfe39af90a.png",alt:"telemetry prompt"})),(0,s.kt)("hr",null),(0,s.kt)("h2",{id:"other-notable-enhancements"},"Other notable enhancements"),(0,s.kt)("ul",null,(0,s.kt)("li",{parentName:"ul"},"Extension support for opening an external URL ",(0,s.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/2028"},"2028")," and\naccessing the clipboard ",(0,s.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/2023"},"2023"))),(0,s.kt)("hr",null),(0,s.kt)("h2",{id:"documentation"},"Documentation"),(0,s.kt)("p",null,"Naturally, we have a section in the documentation just for ",(0,s.kt)("a",{parentName:"p",href:"https://podman-desktop.io/docs/kind"},"Kind"),"."),(0,s.kt)("hr",null),(0,s.kt)("h2",{id:"notable-bug-fixes"},"Notable bug fixes"),(0,s.kt)("ul",null,(0,s.kt)("li",{parentName:"ul"},"Avoid a dialog box if unable to check for updates ",(0,s.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/2062"},"2062")),(0,s.kt)("li",{parentName:"ul"},"Unable to get to the Dashboard if Kind (or Kubernetes) cluster was not running ",(0,s.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/issues/2052"},"2052"))),(0,s.kt)("hr",null),(0,s.kt)("h2",{id:"final-notes"},"Final notes"),(0,s.kt)("p",null,"The complete list of issues fixed in this release is available ",(0,s.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/issues?q=is%3Aclosed+milestone%3A0.14.0"},"here"),"."),(0,s.kt)("p",null,"Get the latest release from the ",(0,s.kt)("a",{parentName:"p",href:"/downloads"},"Downloads")," section of the website and boost your development journey with Podman Desktop. Additionally, visit the ",(0,s.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop"},"GitHub repository")," and see how you can help us make Podman Desktop better."))}m.isMDXComponent=!0},45988:(e,t,n)=>{n.d(t,{Z:()=>a});const a=n.p+"assets/images/kind-clusters-580828529dfdd23680262d7ee586823d.png"},61958:(e,t,n)=>{n.d(t,{Z:()=>a});const a=n.p+"assets/images/kind-ingress-ab2dd4054a7ce838c758ddc0d98cc5cb.png"},41767:(e,t,n)=>{n.d(t,{Z:()=>a});const a=n.p+"assets/images/podman-desktop-release-0.14-5d7adb6814b7191ab2623cdd431642f3.png"},75281:(e,t,n)=>{n.d(t,{Z:()=>a});const a=n.p+"assets/images/push-image-kind-ea3f19b80ab3ce13cdfadbbb63762780.png"}}]); \ No newline at end of file diff --git a/assets/js/4816649b.e532397c.js b/assets/js/4816649b.e532397c.js new file mode 100644 index 00000000000..173147ac1fd --- /dev/null +++ b/assets/js/4816649b.e532397c.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[6690],{75150:(e,t,n)=>{n.r(t),n.d(t,{assets:()=>d,contentTitle:()=>l,default:()=>c,frontMatter:()=>i,metadata:()=>r,toc:()=>p});var a=n(25773),s=(n(27378),n(35318)),o=n(92975);const i={title:"Release Notes - Podman Desktop 0.14",description:"Podman Desktop 0.14 has been released!",slug:"podman-desktop-release-0.14",authors:["deboer"],tags:["podman-desktop","release","kubernetes","kind"],hide_table_of_contents:!1},l=void 0,r={permalink:"/blog/podman-desktop-release-0.14",source:"@site/blog/2023-04-14-release-0.14.md",title:"Release Notes - Podman Desktop 0.14",description:"Podman Desktop 0.14 has been released!",date:"2023-04-14T00:00:00.000Z",formattedDate:"April 14, 2023",tags:[{label:"podman-desktop",permalink:"/blog/tags/podman-desktop"},{label:"release",permalink:"/blog/tags/release"},{label:"kubernetes",permalink:"/blog/tags/kubernetes"},{label:"kind",permalink:"/blog/tags/kind"}],readingTime:4.025,hasTruncateMarker:!0,authors:[{name:"Tim deBoer",title:"Architect",url:"https://github.com/deboer-tim",imageURL:"https://github.com/deboer-tim.png",key:"deboer"}],frontMatter:{title:"Release Notes - Podman Desktop 0.14",description:"Podman Desktop 0.14 has been released!",slug:"podman-desktop-release-0.14",authors:["deboer"],tags:["podman-desktop","release","kubernetes","kind"],hide_table_of_contents:!1},prevItem:{title:"Setting up and running a Kubernetes cluster locally with Podman Desktop",permalink:"/blog/running-a-local-kubernetes-cluster-with-podman-desktop"},nextItem:{title:"Release Notes - Podman Desktop 0.13",permalink:"/blog/podman-desktop-release-0.13"}},d={authorsImageUrls:[void 0]},p=[{value:"Release details",id:"release-details",level:2},{value:"Kind Installation",id:"kind-installation",level:3},{value:"Manage Kind Clusters",id:"manage-kind-clusters",level:3},{value:"Using Kind",id:"using-kind",level:3},{value:"Kind Ingress",id:"kind-ingress",level:3},{value:"UI and UX improvements",id:"ui-and-ux-improvements",level:3},{value:"Updated Preferences",id:"updated-preferences",level:4},{value:"Telemetry Prompt",id:"telemetry-prompt",level:4},{value:"Other notable enhancements",id:"other-notable-enhancements",level:2},{value:"Documentation",id:"documentation",level:2},{value:"Notable bug fixes",id:"notable-bug-fixes",level:2},{value:"Final notes",id:"final-notes",level:2}],u=(m="Icon",function(e){return console.warn("Component "+m+" was not imported, exported, or provided by MDXProvider as global scope"),(0,s.kt)("div",e)});var m;const h={toc:p};function c(e){let{components:t,...i}=e;return(0,s.kt)("wrapper",(0,a.Z)({},h,i,{components:t,mdxType:"MDXLayout"}),(0,s.kt)("p",null,"Podman Desktop 0.14 - Our Kind-est release yet!"),(0,s.kt)("p",null,"We have been working on a Kind extension for a while now, and decided it is time to promote it\ninto a release just in time for KubeCon and CloudNativeCon Europe!"),(0,s.kt)("p",null,"We're especially excited about releasing Kind because it finally shows the full purpose\nof Podman Desktop: not just local container engines, but Kubernetes too. More importantly,\nproviding tools that allow you to manage both environments and seamlessly move between them."),(0,s.kt)("p",null,"Some of these features were available in development mode over the last few releases,\nbut since they are now in the release build, we will do a full roundup and talk about\nall the Kind features."),(0,s.kt)("ul",null,(0,s.kt)("li",{parentName:"ul"},(0,s.kt)("strong",{parentName:"li"},"Kind Installation"),": Install Kind from the status bar"),(0,s.kt)("li",{parentName:"ul"},(0,s.kt)("strong",{parentName:"li"},"Manage Kind Clusters"),": Create and manage Kind clusters from ",(0,s.kt)("strong",{parentName:"li"},(0,s.kt)(u,{icon:"fa-solid fa-cog",size:"lg",mdxType:"Icon"})," Settings > Resources")),(0,s.kt)("li",{parentName:"ul"},(0,s.kt)("strong",{parentName:"li"},"Using Kind"),": Deploying YAML and sharing images to a cluster"),(0,s.kt)("li",{parentName:"ul"},(0,s.kt)("strong",{parentName:"li"},"Kind Ingress"),": Install a Contour ingress controller"),(0,s.kt)("li",{parentName:"ul"},(0,s.kt)("strong",{parentName:"li"},"UX and UI Improvements"),": Updated preferences and telemetry prompt")),(0,s.kt)("p",null,"Podman Desktop 0.14 is now available. ",(0,s.kt)("a",{parentName:"p",href:"/downloads"},"Click here to download it"),"!"),(0,s.kt)("p",null,(0,s.kt)("img",{alt:"Podman-desktop-0-14-hero",src:n(41767).Z,width:"1140",height:"1097"})),(0,s.kt)("hr",null),(0,s.kt)("h2",{id:"release-details"},"Release details"),(0,s.kt)("h3",{id:"kind-installation"},"Kind Installation"),(0,s.kt)("p",null,"Get Kind up and running in seconds! The Kind extension is now bundled as part of Podman Desktop\n",(0,s.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/issues/1421"},"1421"),"\nand allows you to easily ",(0,s.kt)("a",{parentName:"p",href:"/docs/kind/installing"},"install Kind directly from the status bar"),"\n",(0,s.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/issues/1257"},"1257"),"."),(0,s.kt)("p",null,"The installed ",(0,s.kt)("inlineCode",{parentName:"p"},"kind")," CLI is available from the system shell ",(0,s.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/issues/1516"},"1516"),",\nallowing you to open a terminal window to ",(0,s.kt)("inlineCode",{parentName:"p"},"kind get clusters")," or work with other tools."),(0,s.kt)("h3",{id:"manage-kind-clusters"},"Manage Kind Clusters"),(0,s.kt)("p",null,"Once Kind is installed (or if you already had it), you can manage your clusters in ",(0,s.kt)("strong",{parentName:"p"},(0,s.kt)(u,{icon:"fa-solid fa-cog",size:"lg",mdxType:"Icon"})," Settings > Resources"),".\nFrom here you can ",(0,s.kt)("a",{parentName:"p",href:"/docs/kind/creating-a-kind-cluster"},"create Kind clusters"),",\nstart/stop ",(0,s.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/issues/1953"},"1953"),"\nor delete ",(0,s.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/issues/1977"},"1977")," them."),(0,s.kt)("p",null,(0,s.kt)("img",{alt:"kind-clusters",src:n(45988).Z,width:"1484",height:"364"})),(0,s.kt)("p",null,"The Kind control plane runs as a container. You will see this container\nin the ",(0,s.kt)("strong",{parentName:"p"},"Container")," list and can also start or stop it from there."),(0,s.kt)("h3",{id:"using-kind"},"Using Kind"),(0,s.kt)("p",null,"Now that you have Kind installed and running, what can you do with it?\nIf you like terminals, you can always open one up and use the Kind CLI to\n",(0,s.kt)("a",{parentName:"p",href:"https://kind.sigs.k8s.io/docs/user/quick-start/#interacting-with-your-cluster"},"interact with your cluster"),"."),(0,s.kt)("p",null,"Within Podman Desktop we have started with two ways to interact with the cluster.\nThe first is the ability to play local YAML files on your Kind (or any other Kubernetes!) cluster ",(0,s.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/issues/1261"},"1261"),". This allows you to take existing Kubernetes YAML definitions -\nyour deployments, services, or other objects - and deploy it to the cluster."),(0,s.kt)(o.Z,{playing:!0,controls:!0,url:"https://user-images.githubusercontent.com/436777/231812563-ece0a56a-b347-48f8-a3a7-400eb9449037.mp4",width:"100%",height:"100%",mdxType:"ReactPlayer"}),(0,s.kt)("p",null,"As you deploy pods, they will automatically appear in the list of ",(0,s.kt)("strong",{parentName:"p"},"Pods")," ",(0,s.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/issues/1263"},"1263"),", allowing you to start, stop, and interact them just like pods running on Podman."),(0,s.kt)("p",null,"One of the most common uses is to deploy a container that you have been running on Podman, and this will fail\nif the image is not available in Kind. To solve this we have made it easy to push images from\nPodman to Kind ",(0,s.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/issues/1448"},"1448"),"."),(0,s.kt)("p",null,(0,s.kt)("img",{alt:"push-image-kind",src:n(75281).Z,width:"1054",height:"152"})),(0,s.kt)("h3",{id:"kind-ingress"},"Kind Ingress"),(0,s.kt)("p",null,"If you deploy a pod to Kind, you are also going to want to reach it! To do this you will need to install a load balancer or\ningress controller so that the pod is accessible from outside the cluster. We made it easy to install the Contour ingress\ncontroller while creating a Kind cluster ",(0,s.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/issues/1675"},"1675"),",\nso if you created your cluster with Podman Desktop it is already there!"),(0,s.kt)("p",null,(0,s.kt)("img",{alt:"kind-ingress",src:n(61958).Z,width:"1328",height:"1238"})),(0,s.kt)("p",null,"We have several other Kind and Kubernetes features planned to expand the supported scenarios, but hopefully this\nmakes it easy to get started with Kind and shows where we're headed. As always, feedback is appreciated!"),(0,s.kt)("h3",{id:"ui-and-ux-improvements"},"UI and UX improvements"),(0,s.kt)("h4",{id:"updated-preferences"},"Updated Preferences"),(0,s.kt)("p",null,"The ",(0,s.kt)("strong",{parentName:"p"},(0,s.kt)(u,{icon:"fa-solid fa-cog",size:"lg",mdxType:"Icon"})," Settings > Preferences")," page has been updated with a new design ",(0,s.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/1913"},"1913"),",\nmaking it easier to see and change preferences. Changes are live, no more Update button."),(0,s.kt)("p",null,(0,s.kt)("img",{parentName:"p",src:"https://user-images.githubusercontent.com/49404737/229498507-e754b55c-dcbd-486d-9ee3-a1fe3bed7271.gif",alt:"preferences"})),(0,s.kt)("h4",{id:"telemetry-prompt"},"Telemetry Prompt"),(0,s.kt)("p",null,"The prompt to enable or disable telemetry has been moved from its own dialog into the ",(0,s.kt)("strong",{parentName:"p"},"Welcome")," screen.\n",(0,s.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/1927"},"1927"),"\nThis is more usable, one less prompt, and solves a window-layering issue for some users!"),(0,s.kt)("p",null,(0,s.kt)("img",{parentName:"p",src:"https://user-images.githubusercontent.com/19958075/229577331-365a9a01-0426-4482-a95d-f5dfe39af90a.png",alt:"telemetry prompt"})),(0,s.kt)("hr",null),(0,s.kt)("h2",{id:"other-notable-enhancements"},"Other notable enhancements"),(0,s.kt)("ul",null,(0,s.kt)("li",{parentName:"ul"},"Extension support for opening an external URL ",(0,s.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/2028"},"2028")," and\naccessing the clipboard ",(0,s.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/2023"},"2023"))),(0,s.kt)("hr",null),(0,s.kt)("h2",{id:"documentation"},"Documentation"),(0,s.kt)("p",null,"Naturally, we have a section in the documentation just for ",(0,s.kt)("a",{parentName:"p",href:"https://podman-desktop.io/docs/kind"},"Kind"),"."),(0,s.kt)("hr",null),(0,s.kt)("h2",{id:"notable-bug-fixes"},"Notable bug fixes"),(0,s.kt)("ul",null,(0,s.kt)("li",{parentName:"ul"},"Avoid a dialog box if unable to check for updates ",(0,s.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/2062"},"2062")),(0,s.kt)("li",{parentName:"ul"},"Unable to get to the Dashboard if Kind (or Kubernetes) cluster was not running ",(0,s.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/issues/2052"},"2052"))),(0,s.kt)("hr",null),(0,s.kt)("h2",{id:"final-notes"},"Final notes"),(0,s.kt)("p",null,"The complete list of issues fixed in this release is available ",(0,s.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/issues?q=is%3Aclosed+milestone%3A0.14.0"},"here"),"."),(0,s.kt)("p",null,"Get the latest release from the ",(0,s.kt)("a",{parentName:"p",href:"/downloads"},"Downloads")," section of the website and boost your development journey with Podman Desktop. Additionally, visit the ",(0,s.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop"},"GitHub repository")," and see how you can help us make Podman Desktop better."))}c.isMDXComponent=!0},45988:(e,t,n)=>{n.d(t,{Z:()=>a});const a=n.p+"assets/images/kind-clusters-580828529dfdd23680262d7ee586823d.png"},61958:(e,t,n)=>{n.d(t,{Z:()=>a});const a=n.p+"assets/images/kind-ingress-ab2dd4054a7ce838c758ddc0d98cc5cb.png"},41767:(e,t,n)=>{n.d(t,{Z:()=>a});const a=n.p+"assets/images/podman-desktop-release-0.14-5d7adb6814b7191ab2623cdd431642f3.png"},75281:(e,t,n)=>{n.d(t,{Z:()=>a});const a=n.p+"assets/images/push-image-kind-ea3f19b80ab3ce13cdfadbbb63762780.png"}}]); \ No newline at end of file diff --git a/assets/js/4b8121dd.12bc2380.js b/assets/js/4b8121dd.12bc2380.js new file mode 100644 index 00000000000..15302d0f1b0 --- /dev/null +++ b/assets/js/4b8121dd.12bc2380.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[534],{35318:(e,t,n)=>{n.d(t,{Zo:()=>c,kt:()=>k});var r=n(27378);function i(e,t,n){return t in e?Object.defineProperty(e,t,{value:n,enumerable:!0,configurable:!0,writable:!0}):e[t]=n,e}function o(e,t){var n=Object.keys(e);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(e);t&&(r=r.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),n.push.apply(n,r)}return n}function s(e){for(var t=1;t=0||(i[n]=e[n]);return i}(e,t);if(Object.getOwnPropertySymbols){var o=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(i[n]=e[n])}return i}var u=r.createContext({}),l=function(e){var t=r.useContext(u),n=t;return e&&(n="function"==typeof e?e(t):s(s({},t),e)),n},c=function(e){var t=l(e.components);return r.createElement(u.Provider,{value:t},e.children)},p={inlineCode:"code",wrapper:function(e){var t=e.children;return r.createElement(r.Fragment,{},t)}},d=r.forwardRef((function(e,t){var n=e.components,i=e.mdxType,o=e.originalType,u=e.parentName,c=a(e,["components","mdxType","originalType","parentName"]),d=l(n),k=i,m=d["".concat(u,".").concat(k)]||d[k]||p[k]||o;return n?r.createElement(m,s(s({ref:t},c),{},{components:n})):r.createElement(m,s({ref:t},c))}));function k(e,t){var n=arguments,i=t&&t.mdxType;if("string"==typeof e||i){var o=n.length,s=new Array(o);s[0]=d;var a={};for(var u in t)hasOwnProperty.call(t,u)&&(a[u]=t[u]);a.originalType=e,a.mdxType="string"==typeof e?e:i,s[1]=a;for(var l=2;l{n.r(t),n.d(t,{assets:()=>u,contentTitle:()=>s,default:()=>k,frontMatter:()=>o,metadata:()=>a,toc:()=>l});var r=n(25773),i=(n(27378),n(35318));const o={title:"Existing Kubernetes",description:"Configuring access to a Kubernetes cluster",keywords:["podman desktop","podman","containers","pods","migrating","kubernetes"],tags:["migrating-to-kubernetes"]},s="Configuring access to a Kubernetes cluster",a={unversionedId:"kubernetes/existing-kubernetes/index",id:"kubernetes/existing-kubernetes/index",title:"Existing Kubernetes",description:"Configuring access to a Kubernetes cluster",source:"@site/docs/kubernetes/existing-kubernetes/index.md",sourceDirName:"kubernetes/existing-kubernetes",slug:"/kubernetes/existing-kubernetes/",permalink:"/docs/kubernetes/existing-kubernetes/",draft:!1,editUrl:"https://github.com/containers/podman-desktop/tree/main/website/docs/kubernetes/existing-kubernetes/index.md",tags:[{label:"migrating-to-kubernetes",permalink:"/docs/tags/migrating-to-kubernetes"}],version:"current",frontMatter:{title:"Existing Kubernetes",description:"Configuring access to a Kubernetes cluster",keywords:["podman desktop","podman","containers","pods","migrating","kubernetes"],tags:["migrating-to-kubernetes"]},sidebar:"mySidebar",previous:{title:"Deploying a pod",permalink:"/docs/kubernetes/deploying-a-pod-to-kubernetes"},next:{title:"Push an image to Kind",permalink:"/docs/kubernetes/kind/pushing-an-image-to-kind"}},u={},l=[{value:"Prerequisites",id:"prerequisites",level:4},{value:"Procedure",id:"procedure",level:4},{value:"Verification",id:"verification",level:4},{value:"Additional resopurces",id:"additional-resopurces",level:4}],c=(p="Icon",function(e){return console.warn("Component "+p+" was not imported, exported, or provided by MDXProvider as global scope"),(0,i.kt)("div",e)});var p;const d={toc:l};function k(e){let{components:t,...n}=e;return(0,i.kt)("wrapper",(0,r.Z)({},d,n,{components:t,mdxType:"MDXLayout"}),(0,i.kt)("h1",{id:"configuring-access-to-a-kubernetes-cluster"},"Configuring access to a Kubernetes cluster"),(0,i.kt)("p",null,"Podman Desktop configures the access to Kubernetes clusters automatically when:"),(0,i.kt)("ul",null,(0,i.kt)("li",{parentName:"ul"},(0,i.kt)("a",{parentName:"li",href:"/docs/kind/creating-a-kind-cluster"},"Creating a Kind-powered local Kubernetes cluster"),"."),(0,i.kt)("li",{parentName:"ul"},(0,i.kt)("a",{parentName:"li",href:"/docs/openshift/openshift-local"},"Creating an OpenShift Local cluster"),"."),(0,i.kt)("li",{parentName:"ul"},(0,i.kt)("a",{parentName:"li",href:"/docs/openshift/developer-sandbox"},"Configuring access to a Developer Sandbox"),".")),(0,i.kt)("p",null,"You can also use the Kubernetes CLI to configure access to your Kubernetes cluster:"),(0,i.kt)("h4",{id:"prerequisites"},"Prerequisites"),(0,i.kt)("ul",null,(0,i.kt)("li",{parentName:"ul"},"You have credentials for your Kubernetes cluster.")),(0,i.kt)("h4",{id:"procedure"},"Procedure"),(0,i.kt)("ol",null,(0,i.kt)("li",{parentName:"ol"},(0,i.kt)("p",{parentName:"li"},"(Optionally) Go to ",(0,i.kt)("strong",{parentName:"p"},(0,i.kt)(c,{icon:"fa-solid fa-cog",size:"lg",mdxType:"Icon"})," Settings > Preferences > Path to the kubeconfig file")," to adapt your kubeconfig file location, when different from the default ",(0,i.kt)("inlineCode",{parentName:"p"},"$HOME/.kube/config"),".")),(0,i.kt)("li",{parentName:"ol"},(0,i.kt)("p",{parentName:"li"},"Register your ",(0,i.kt)("em",{parentName:"p"},(0,i.kt)("inlineCode",{parentName:"em"},""))," Kubernetes cluster:"),(0,i.kt)("pre",{parentName:"li"},(0,i.kt)("code",{parentName:"pre",className:"language-shell-session"},"$ kubectl config set-cluster --server=\n")))),(0,i.kt)("h4",{id:"verification"},"Verification"),(0,i.kt)("ul",null,(0,i.kt)("li",{parentName:"ul"},"You can ",(0,i.kt)("a",{parentName:"li",href:"/docs/kubernetes/viewing-and-selecting-current-kubernete-context"},"view and select the Kubernetes cluster in Podman Desktop"))),(0,i.kt)("h4",{id:"additional-resopurces"},"Additional resopurces"),(0,i.kt)("ul",null,(0,i.kt)("li",{parentName:"ul"},(0,i.kt)("a",{parentName:"li",href:"https://kubernetes.io/docs/tasks/access-application-cluster/configure-access-multiple-clusters/"},"Kubernetes documentation: Configure access to multiple clusters"))))}k.isMDXComponent=!0}}]); \ No newline at end of file diff --git a/assets/js/4b8121dd.24fea72f.js b/assets/js/4b8121dd.24fea72f.js deleted file mode 100644 index bea346df588..00000000000 --- a/assets/js/4b8121dd.24fea72f.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[534],{35318:(e,t,n)=>{n.d(t,{Zo:()=>c,kt:()=>k});var r=n(27378);function i(e,t,n){return t in e?Object.defineProperty(e,t,{value:n,enumerable:!0,configurable:!0,writable:!0}):e[t]=n,e}function s(e,t){var n=Object.keys(e);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(e);t&&(r=r.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),n.push.apply(n,r)}return n}function o(e){for(var t=1;t=0||(i[n]=e[n]);return i}(e,t);if(Object.getOwnPropertySymbols){var s=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(i[n]=e[n])}return i}var u=r.createContext({}),l=function(e){var t=r.useContext(u),n=t;return e&&(n="function"==typeof e?e(t):o(o({},t),e)),n},c=function(e){var t=l(e.components);return r.createElement(u.Provider,{value:t},e.children)},p={inlineCode:"code",wrapper:function(e){var t=e.children;return r.createElement(r.Fragment,{},t)}},d=r.forwardRef((function(e,t){var n=e.components,i=e.mdxType,s=e.originalType,u=e.parentName,c=a(e,["components","mdxType","originalType","parentName"]),d=l(n),k=i,m=d["".concat(u,".").concat(k)]||d[k]||p[k]||s;return n?r.createElement(m,o(o({ref:t},c),{},{components:n})):r.createElement(m,o({ref:t},c))}));function k(e,t){var n=arguments,i=t&&t.mdxType;if("string"==typeof e||i){var s=n.length,o=new Array(s);o[0]=d;var a={};for(var u in t)hasOwnProperty.call(t,u)&&(a[u]=t[u]);a.originalType=e,a.mdxType="string"==typeof e?e:i,o[1]=a;for(var l=2;l{n.r(t),n.d(t,{assets:()=>u,contentTitle:()=>o,default:()=>p,frontMatter:()=>s,metadata:()=>a,toc:()=>l});var r=n(25773),i=(n(27378),n(35318));const s={title:"Existing Kubernetes",description:"Configuring access to a Kubernetes cluster",keywords:["podman desktop","podman","containers","pods","migrating","kubernetes"],tags:["migrating-to-kubernetes"]},o="Configuring access to a Kubernetes cluster",a={unversionedId:"kubernetes/existing-kubernetes/index",id:"kubernetes/existing-kubernetes/index",title:"Existing Kubernetes",description:"Configuring access to a Kubernetes cluster",source:"@site/docs/kubernetes/existing-kubernetes/index.md",sourceDirName:"kubernetes/existing-kubernetes",slug:"/kubernetes/existing-kubernetes/",permalink:"/docs/kubernetes/existing-kubernetes/",draft:!1,editUrl:"https://github.com/containers/podman-desktop/tree/main/website/docs/kubernetes/existing-kubernetes/index.md",tags:[{label:"migrating-to-kubernetes",permalink:"/docs/tags/migrating-to-kubernetes"}],version:"current",frontMatter:{title:"Existing Kubernetes",description:"Configuring access to a Kubernetes cluster",keywords:["podman desktop","podman","containers","pods","migrating","kubernetes"],tags:["migrating-to-kubernetes"]},sidebar:"mySidebar",previous:{title:"Deploying a pod",permalink:"/docs/kubernetes/deploying-a-pod-to-kubernetes"},next:{title:"Push an image to Kind",permalink:"/docs/kubernetes/kind/pushing-an-image-to-kind"}},u={},l=[{value:"Prerequisites",id:"prerequisites",level:4},{value:"Procedure",id:"procedure",level:4},{value:"Verification",id:"verification",level:4},{value:"Additional resopurces",id:"additional-resopurces",level:4}],c={toc:l};function p(e){let{components:t,...n}=e;return(0,i.kt)("wrapper",(0,r.Z)({},c,n,{components:t,mdxType:"MDXLayout"}),(0,i.kt)("h1",{id:"configuring-access-to-a-kubernetes-cluster"},"Configuring access to a Kubernetes cluster"),(0,i.kt)("p",null,"Podman Desktop configures the access to Kubernetes clusters automatically when:"),(0,i.kt)("ul",null,(0,i.kt)("li",{parentName:"ul"},(0,i.kt)("a",{parentName:"li",href:"/docs/kind/creating-a-kind-cluster"},"Creating a Kind-powered local Kubernetes cluster"),"."),(0,i.kt)("li",{parentName:"ul"},(0,i.kt)("a",{parentName:"li",href:"/docs/openshift/openshift-local"},"Creating an OpenShift Local cluster"),"."),(0,i.kt)("li",{parentName:"ul"},(0,i.kt)("a",{parentName:"li",href:"/docs/openshift/developer-sandbox"},"Configuring access to a Developer Sandbox"),".")),(0,i.kt)("p",null,"You can also use the Kubernetes CLI to configure access to your Kubernetes cluster:"),(0,i.kt)("h4",{id:"prerequisites"},"Prerequisites"),(0,i.kt)("ul",null,(0,i.kt)("li",{parentName:"ul"},"You have credentials for your Kubernetes cluster.")),(0,i.kt)("h4",{id:"procedure"},"Procedure"),(0,i.kt)("ol",null,(0,i.kt)("li",{parentName:"ol"},(0,i.kt)("p",{parentName:"li"},"(Optionally) Go to ",(0,i.kt)("strong",{parentName:"p"},(0,i.kt)("icon",{icon:"fa-solid fa-cog",size:"lg"})," Settings > Preferences > Path to the kubeconfig file")," to adapt your kubeconfig file location, when different from the default ",(0,i.kt)("inlineCode",{parentName:"p"},"$HOME/.kube/config"),".")),(0,i.kt)("li",{parentName:"ol"},(0,i.kt)("p",{parentName:"li"},"Register your ",(0,i.kt)("em",{parentName:"p"},(0,i.kt)("inlineCode",{parentName:"em"},""))," Kubernetes cluster:"),(0,i.kt)("pre",{parentName:"li"},(0,i.kt)("code",{parentName:"pre",className:"language-shell-session"},"$ kubectl config set-cluster --server=\n")))),(0,i.kt)("h4",{id:"verification"},"Verification"),(0,i.kt)("ul",null,(0,i.kt)("li",{parentName:"ul"},"You can ",(0,i.kt)("a",{parentName:"li",href:"/docs/kubernetes/viewing-and-selecting-current-kubernete-context"},"view and select the Kubernetes cluster in Podman Desktop"))),(0,i.kt)("h4",{id:"additional-resopurces"},"Additional resopurces"),(0,i.kt)("ul",null,(0,i.kt)("li",{parentName:"ul"},(0,i.kt)("a",{parentName:"li",href:"https://kubernetes.io/docs/tasks/access-application-cluster/configure-access-multiple-clusters/"},"Kubernetes documentation: Configure access to multiple clusters"))))}p.isMDXComponent=!0}}]); \ No newline at end of file diff --git a/assets/js/51e516cc.b48a3263.js b/assets/js/51e516cc.b48a3263.js new file mode 100644 index 00000000000..b40cc3fbd96 --- /dev/null +++ b/assets/js/51e516cc.b48a3263.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[6158],{35318:(e,t,n)=>{n.d(t,{Zo:()=>p,kt:()=>u});var o=n(27378);function r(e,t,n){return t in e?Object.defineProperty(e,t,{value:n,enumerable:!0,configurable:!0,writable:!0}):e[t]=n,e}function a(e,t){var n=Object.keys(e);if(Object.getOwnPropertySymbols){var o=Object.getOwnPropertySymbols(e);t&&(o=o.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),n.push.apply(n,o)}return n}function i(e){for(var t=1;t=0||(r[n]=e[n]);return r}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(o=0;o=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(r[n]=e[n])}return r}var s=o.createContext({}),c=function(e){var t=o.useContext(s),n=t;return e&&(n="function"==typeof e?e(t):i(i({},t),e)),n},p=function(e){var t=c(e.components);return o.createElement(s.Provider,{value:t},e.children)},d={inlineCode:"code",wrapper:function(e){var t=e.children;return o.createElement(o.Fragment,{},t)}},m=o.forwardRef((function(e,t){var n=e.components,r=e.mdxType,a=e.originalType,s=e.parentName,p=l(e,["components","mdxType","originalType","parentName"]),m=c(n),u=r,k=m["".concat(s,".").concat(u)]||m[u]||d[u]||a;return n?o.createElement(k,i(i({ref:t},p),{},{components:n})):o.createElement(k,i({ref:t},p))}));function u(e,t){var n=arguments,r=t&&t.mdxType;if("string"==typeof e||r){var a=n.length,i=new Array(a);i[0]=m;var l={};for(var s in t)hasOwnProperty.call(t,s)&&(l[s]=t[s]);l.originalType=e,l.mdxType="string"==typeof e?e:r,i[1]=l;for(var c=2;c{n.r(t),n.d(t,{assets:()=>s,contentTitle:()=>i,default:()=>u,frontMatter:()=>a,metadata:()=>l,toc:()=>c});var o=n(25773),r=(n(27378),n(35318));const a={sidebar_position:40,title:"Pods",description:"Creating a pod from selected containers.",keywords:["podman desktop","podman","containers","pods"],tags:["pods"]},i="Creating a pod from selected containers",l={unversionedId:"containers/creating-a-pod",id:"containers/creating-a-pod",title:"Pods",description:"Creating a pod from selected containers.",source:"@site/docs/containers/creating-a-pod.md",sourceDirName:"containers",slug:"/containers/creating-a-pod",permalink:"/docs/containers/creating-a-pod",draft:!1,editUrl:"https://github.com/containers/podman-desktop/tree/main/website/docs/containers/creating-a-pod.md",tags:[{label:"pods",permalink:"/docs/tags/pods"}],version:"current",sidebarPosition:40,frontMatter:{sidebar_position:40,title:"Pods",description:"Creating a pod from selected containers.",keywords:["podman desktop","podman","containers","pods"],tags:["pods"]},sidebar:"mySidebar",previous:{title:"Containers",permalink:"/docs/containers/starting-a-container"},next:{title:"Compose",permalink:"/docs/compose/"}},s={},c=[{value:"Prerequisites",id:"prerequisites",level:4},{value:"Procedure",id:"procedure",level:4},{value:"Verification",id:"verification",level:4}],p=(d="Icon",function(e){return console.warn("Component "+d+" was not imported, exported, or provided by MDXProvider as global scope"),(0,r.kt)("div",e)});var d;const m={toc:c};function u(e){let{components:t,...n}=e;return(0,r.kt)("wrapper",(0,o.Z)({},m,n,{components:t,mdxType:"MDXLayout"}),(0,r.kt)("h1",{id:"creating-a-pod-from-selected-containers"},"Creating a pod from selected containers"),(0,r.kt)("p",null,"With Podman Desktop, you can create a pod from your selected containers, and run the pod on the Podman container engine."),(0,r.kt)("p",null,"Consider running containers in a pod to:"),(0,r.kt)("ol",null,(0,r.kt)("li",{parentName:"ol"},"Expose your ",(0,r.kt)("inlineCode",{parentName:"li"},"frontend")," application to the public network."),(0,r.kt)("li",{parentName:"ol"},"Protect your ",(0,r.kt)("inlineCode",{parentName:"li"},"database")," container in a private network.")),(0,r.kt)("h4",{id:"prerequisites"},"Prerequisites"),(0,r.kt)("ul",null,(0,r.kt)("li",{parentName:"ul"},"You are using the Podman container engine."),(0,r.kt)("li",{parentName:"ul"},"Your containers, such as ",(0,r.kt)("inlineCode",{parentName:"li"},"database")," and ",(0,r.kt)("inlineCode",{parentName:"li"},"frontend"),", running or stopped, are available on the Containers page."),(0,r.kt)("li",{parentName:"ul"},"The ",(0,r.kt)("inlineCode",{parentName:"li"},"frontend")," container is configured to access the service exposed by the ",(0,r.kt)("inlineCode",{parentName:"li"},"database")," container on localhost, such as ",(0,r.kt)("inlineCode",{parentName:"li"},"localhost:6379"),".")),(0,r.kt)("h4",{id:"procedure"},"Procedure"),(0,r.kt)("ol",null,(0,r.kt)("li",{parentName:"ol"},"Go to ",(0,r.kt)("strong",{parentName:"li"},(0,r.kt)(p,{icon:"fa-solid fa-cube",size:"lg",mdxType:"Icon"})," Containers"),"."),(0,r.kt)("li",{parentName:"ol"},"Click the checkbox in the container line for your containers, such as ",(0,r.kt)("inlineCode",{parentName:"li"},"database")," and ",(0,r.kt)("inlineCode",{parentName:"li"},"frontend"),"."),(0,r.kt)("li",{parentName:"ol"},"Click ",(0,r.kt)("strong",{parentName:"li"},(0,r.kt)(p,{icon:"fa-solid fa-cubes",size:"lg",mdxType:"Icon"})),"."),(0,r.kt)("li",{parentName:"ol"},"In the ",(0,r.kt)("strong",{parentName:"li"},"Copy containers to a pod")," screen:",(0,r.kt)("ol",{parentName:"li"},(0,r.kt)("li",{parentName:"ol"},(0,r.kt)("strong",{parentName:"li"},"Name of the pod"),": enter your pod name, such as ",(0,r.kt)("inlineCode",{parentName:"li"},"my-pod"),"."),(0,r.kt)("li",{parentName:"ol"},(0,r.kt)("strong",{parentName:"li"},"All selected ports will be exposed"),":",(0,r.kt)("ol",{parentName:"li"},(0,r.kt)("li",{parentName:"ol"},"Select ",(0,r.kt)("inlineCode",{parentName:"li"},"frontend"),"."),(0,r.kt)("li",{parentName:"ol"},"Clear ",(0,r.kt)("inlineCode",{parentName:"li"},"database"),"."))))),(0,r.kt)("li",{parentName:"ol"},"Click ",(0,r.kt)("strong",{parentName:"li"},(0,r.kt)(p,{icon:"fa-solid fa-cube",size:"lg",mdxType:"Icon"})," Create Pod"),".")),(0,r.kt)("h4",{id:"verification"},"Verification"),(0,r.kt)("ol",null,(0,r.kt)("li",{parentName:"ol"},"Go to ",(0,r.kt)("strong",{parentName:"li"},(0,r.kt)(p,{icon:"fa-solid fa-cubes",size:"lg",mdxType:"Icon"})," Pods"),"."),(0,r.kt)("li",{parentName:"ol"},"Click your pod, such as ",(0,r.kt)("inlineCode",{parentName:"li"},"my-pod"),"."),(0,r.kt)("li",{parentName:"ol"},"Go to ",(0,r.kt)("strong",{parentName:"li"},"Logs"),": see the combined logs from the two containers."),(0,r.kt)("li",{parentName:"ol"},"Go to ",(0,r.kt)("strong",{parentName:"li"},"Summary"),": see the containers."),(0,r.kt)("li",{parentName:"ol"},"Click ",(0,r.kt)("inlineCode",{parentName:"li"},"frontend-podified"),"."),(0,r.kt)("li",{parentName:"ol"},"Click ",(0,r.kt)("strong",{parentName:"li"},(0,r.kt)(p,{icon:"fa-solid fa-external-link",size:"lg",mdxType:"Icon"})),"."),(0,r.kt)("li",{parentName:"ol"},"Your browser opens the service exposed by your ",(0,r.kt)("inlineCode",{parentName:"li"},"frontend-podified")," container."),(0,r.kt)("li",{parentName:"ol"},"Go to ",(0,r.kt)("strong",{parentName:"li"},(0,r.kt)(p,{icon:"fa-solid fa-cube",size:"lg",mdxType:"Icon"})," Containers"),": see the running containers.")))}u.isMDXComponent=!0}}]); \ No newline at end of file diff --git a/assets/js/51e516cc.e1bb3a48.js b/assets/js/51e516cc.e1bb3a48.js deleted file mode 100644 index c9093922ed0..00000000000 --- a/assets/js/51e516cc.e1bb3a48.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[6158],{35318:(e,t,n)=>{n.d(t,{Zo:()=>p,kt:()=>u});var o=n(27378);function r(e,t,n){return t in e?Object.defineProperty(e,t,{value:n,enumerable:!0,configurable:!0,writable:!0}):e[t]=n,e}function a(e,t){var n=Object.keys(e);if(Object.getOwnPropertySymbols){var o=Object.getOwnPropertySymbols(e);t&&(o=o.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),n.push.apply(n,o)}return n}function i(e){for(var t=1;t=0||(r[n]=e[n]);return r}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(o=0;o=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(r[n]=e[n])}return r}var s=o.createContext({}),c=function(e){var t=o.useContext(s),n=t;return e&&(n="function"==typeof e?e(t):i(i({},t),e)),n},p=function(e){var t=c(e.components);return o.createElement(s.Provider,{value:t},e.children)},d={inlineCode:"code",wrapper:function(e){var t=e.children;return o.createElement(o.Fragment,{},t)}},m=o.forwardRef((function(e,t){var n=e.components,r=e.mdxType,a=e.originalType,s=e.parentName,p=l(e,["components","mdxType","originalType","parentName"]),m=c(n),u=r,k=m["".concat(s,".").concat(u)]||m[u]||d[u]||a;return n?o.createElement(k,i(i({ref:t},p),{},{components:n})):o.createElement(k,i({ref:t},p))}));function u(e,t){var n=arguments,r=t&&t.mdxType;if("string"==typeof e||r){var a=n.length,i=new Array(a);i[0]=m;var l={};for(var s in t)hasOwnProperty.call(t,s)&&(l[s]=t[s]);l.originalType=e,l.mdxType="string"==typeof e?e:r,i[1]=l;for(var c=2;c{n.r(t),n.d(t,{assets:()=>s,contentTitle:()=>i,default:()=>d,frontMatter:()=>a,metadata:()=>l,toc:()=>c});var o=n(25773),r=(n(27378),n(35318));const a={sidebar_position:40,title:"Pods",description:"Creating a pod from selected containers.",keywords:["podman desktop","podman","containers","pods"],tags:["pods"]},i="Creating a pod from selected containers",l={unversionedId:"containers/creating-a-pod",id:"containers/creating-a-pod",title:"Pods",description:"Creating a pod from selected containers.",source:"@site/docs/containers/creating-a-pod.md",sourceDirName:"containers",slug:"/containers/creating-a-pod",permalink:"/docs/containers/creating-a-pod",draft:!1,editUrl:"https://github.com/containers/podman-desktop/tree/main/website/docs/containers/creating-a-pod.md",tags:[{label:"pods",permalink:"/docs/tags/pods"}],version:"current",sidebarPosition:40,frontMatter:{sidebar_position:40,title:"Pods",description:"Creating a pod from selected containers.",keywords:["podman desktop","podman","containers","pods"],tags:["pods"]},sidebar:"mySidebar",previous:{title:"Containers",permalink:"/docs/containers/starting-a-container"},next:{title:"Compose",permalink:"/docs/compose/"}},s={},c=[{value:"Prerequisites",id:"prerequisites",level:4},{value:"Procedure",id:"procedure",level:4},{value:"Verification",id:"verification",level:4}],p={toc:c};function d(e){let{components:t,...n}=e;return(0,r.kt)("wrapper",(0,o.Z)({},p,n,{components:t,mdxType:"MDXLayout"}),(0,r.kt)("h1",{id:"creating-a-pod-from-selected-containers"},"Creating a pod from selected containers"),(0,r.kt)("p",null,"With Podman Desktop, you can create a pod from your selected containers, and run the pod on the Podman container engine."),(0,r.kt)("p",null,"Consider running containers in a pod to:"),(0,r.kt)("ol",null,(0,r.kt)("li",{parentName:"ol"},"Expose your ",(0,r.kt)("inlineCode",{parentName:"li"},"frontend")," application to the public network."),(0,r.kt)("li",{parentName:"ol"},"Protect your ",(0,r.kt)("inlineCode",{parentName:"li"},"database")," container in a private network.")),(0,r.kt)("h4",{id:"prerequisites"},"Prerequisites"),(0,r.kt)("ul",null,(0,r.kt)("li",{parentName:"ul"},"You are using the Podman container engine."),(0,r.kt)("li",{parentName:"ul"},"Your containers, such as ",(0,r.kt)("inlineCode",{parentName:"li"},"database")," and ",(0,r.kt)("inlineCode",{parentName:"li"},"frontend"),", running or stopped, are available on the Containers page."),(0,r.kt)("li",{parentName:"ul"},"The ",(0,r.kt)("inlineCode",{parentName:"li"},"frontend")," container is configured to access the service exposed by the ",(0,r.kt)("inlineCode",{parentName:"li"},"database")," container on localhost, such as ",(0,r.kt)("inlineCode",{parentName:"li"},"localhost:6379"),".")),(0,r.kt)("h4",{id:"procedure"},"Procedure"),(0,r.kt)("ol",null,(0,r.kt)("li",{parentName:"ol"},"Go to ",(0,r.kt)("strong",{parentName:"li"},(0,r.kt)("icon",{icon:"fa-solid fa-cube",size:"lg"})," Containers"),"."),(0,r.kt)("li",{parentName:"ol"},"Click the checkbox in the container line for your containers, such as ",(0,r.kt)("inlineCode",{parentName:"li"},"database")," and ",(0,r.kt)("inlineCode",{parentName:"li"},"frontend"),"."),(0,r.kt)("li",{parentName:"ol"},"Click ",(0,r.kt)("strong",{parentName:"li"},(0,r.kt)("icon",{icon:"fa-solid fa-cubes",size:"lg"})),"."),(0,r.kt)("li",{parentName:"ol"},"In the ",(0,r.kt)("strong",{parentName:"li"},"Copy containers to a pod")," screen:",(0,r.kt)("ol",{parentName:"li"},(0,r.kt)("li",{parentName:"ol"},(0,r.kt)("strong",{parentName:"li"},"Name of the pod"),": enter your pod name, such as ",(0,r.kt)("inlineCode",{parentName:"li"},"my-pod"),"."),(0,r.kt)("li",{parentName:"ol"},(0,r.kt)("strong",{parentName:"li"},"All selected ports will be exposed"),":",(0,r.kt)("ol",{parentName:"li"},(0,r.kt)("li",{parentName:"ol"},"Select ",(0,r.kt)("inlineCode",{parentName:"li"},"frontend"),"."),(0,r.kt)("li",{parentName:"ol"},"Clear ",(0,r.kt)("inlineCode",{parentName:"li"},"database"),"."))))),(0,r.kt)("li",{parentName:"ol"},"Click ",(0,r.kt)("strong",{parentName:"li"},(0,r.kt)("icon",{icon:"fa-solid fa-cube",size:"lg"})," Create Pod"),".")),(0,r.kt)("h4",{id:"verification"},"Verification"),(0,r.kt)("ol",null,(0,r.kt)("li",{parentName:"ol"},"Go to ",(0,r.kt)("strong",{parentName:"li"},(0,r.kt)("icon",{icon:"fa-solid fa-cubes",size:"lg"})," Pods"),"."),(0,r.kt)("li",{parentName:"ol"},"Click your pod, such as ",(0,r.kt)("inlineCode",{parentName:"li"},"my-pod"),"."),(0,r.kt)("li",{parentName:"ol"},"Go to ",(0,r.kt)("strong",{parentName:"li"},"Logs"),": see the combined logs from the two containers."),(0,r.kt)("li",{parentName:"ol"},"Go to ",(0,r.kt)("strong",{parentName:"li"},"Summary"),": see the containers."),(0,r.kt)("li",{parentName:"ol"},"Click ",(0,r.kt)("inlineCode",{parentName:"li"},"frontend-podified"),"."),(0,r.kt)("li",{parentName:"ol"},"Click ",(0,r.kt)("strong",{parentName:"li"},(0,r.kt)("icon",{icon:"fa-solid fa-external-link",size:"lg"})),"."),(0,r.kt)("li",{parentName:"ol"},"Your browser opens the service exposed by your ",(0,r.kt)("inlineCode",{parentName:"li"},"frontend-podified")," container."),(0,r.kt)("li",{parentName:"ol"},"Go to ",(0,r.kt)("strong",{parentName:"li"},(0,r.kt)("icon",{icon:"fa-solid fa-cube",size:"lg"})," Containers"),": see the running containers.")))}d.isMDXComponent=!0}}]); \ No newline at end of file diff --git a/assets/js/54590fd2.05d927ca.js b/assets/js/54590fd2.05d927ca.js new file mode 100644 index 00000000000..f3522d8638b --- /dev/null +++ b/assets/js/54590fd2.05d927ca.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[138],{35318:(e,t,n)=>{n.d(t,{Zo:()=>u,kt:()=>m});var r=n(27378);function o(e,t,n){return t in e?Object.defineProperty(e,t,{value:n,enumerable:!0,configurable:!0,writable:!0}):e[t]=n,e}function a(e,t){var n=Object.keys(e);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(e);t&&(r=r.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),n.push.apply(n,r)}return n}function i(e){for(var t=1;t=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var p=r.createContext({}),l=function(e){var t=r.useContext(p),n=t;return e&&(n="function"==typeof e?e(t):i(i({},t),e)),n},u=function(e){var t=l(e.components);return r.createElement(p.Provider,{value:t},e.children)},d={inlineCode:"code",wrapper:function(e){var t=e.children;return r.createElement(r.Fragment,{},t)}},c=r.forwardRef((function(e,t){var n=e.components,o=e.mdxType,a=e.originalType,p=e.parentName,u=s(e,["components","mdxType","originalType","parentName"]),c=l(n),m=o,k=c["".concat(p,".").concat(m)]||c[m]||d[m]||a;return n?r.createElement(k,i(i({ref:t},u),{},{components:n})):r.createElement(k,i({ref:t},u))}));function m(e,t){var n=arguments,o=t&&t.mdxType;if("string"==typeof e||o){var a=n.length,i=new Array(a);i[0]=c;var s={};for(var p in t)hasOwnProperty.call(t,p)&&(s[p]=t[p]);s.originalType=e,s.mdxType="string"==typeof e?e:o,i[1]=s;for(var l=2;l{n.r(t),n.d(t,{assets:()=>p,contentTitle:()=>i,default:()=>m,frontMatter:()=>a,metadata:()=>s,toc:()=>l});var r=n(25773),o=(n(27378),n(35318));const a={sidebar_position:10,title:"Deploying a pod",description:"Deploying a pod to Kubernetes",keywords:["podman desktop","podman","containers","pods","migrating","kubernetes"],tags:["migrating-to-kubernetes"]},i="Deploying a pod to Kubernetes",s={unversionedId:"kubernetes/deploying-a-pod-to-kubernetes",id:"kubernetes/deploying-a-pod-to-kubernetes",title:"Deploying a pod",description:"Deploying a pod to Kubernetes",source:"@site/docs/kubernetes/deploying-a-pod-to-kubernetes.md",sourceDirName:"kubernetes",slug:"/kubernetes/deploying-a-pod-to-kubernetes",permalink:"/docs/kubernetes/deploying-a-pod-to-kubernetes",draft:!1,editUrl:"https://github.com/containers/podman-desktop/tree/main/website/docs/kubernetes/deploying-a-pod-to-kubernetes.md",tags:[{label:"migrating-to-kubernetes",permalink:"/docs/tags/migrating-to-kubernetes"}],version:"current",sidebarPosition:10,frontMatter:{sidebar_position:10,title:"Deploying a pod",description:"Deploying a pod to Kubernetes",keywords:["podman desktop","podman","containers","pods","migrating","kubernetes"],tags:["migrating-to-kubernetes"]},sidebar:"mySidebar",previous:{title:"Deploying a container",permalink:"/docs/kubernetes/deploying-a-container-to-kubernetes"},next:{title:"Existing Kubernetes",permalink:"/docs/kubernetes/existing-kubernetes/"}},p={},l=[{value:"Prerequisites",id:"prerequisites",level:4},{value:"Procedure",id:"procedure",level:4},{value:"Verification",id:"verification",level:4}],u=(d="Icon",function(e){return console.warn("Component "+d+" was not imported, exported, or provided by MDXProvider as global scope"),(0,o.kt)("div",e)});var d;const c={toc:l};function m(e){let{components:t,...a}=e;return(0,o.kt)("wrapper",(0,r.Z)({},c,a,{components:t,mdxType:"MDXLayout"}),(0,o.kt)("h1",{id:"deploying-a-pod-to-kubernetes"},"Deploying a pod to Kubernetes"),(0,o.kt)("p",null,"With Podman Desktop, you can deploy a pod to your Kubernetes cluster."),(0,o.kt)("h4",{id:"prerequisites"},"Prerequisites"),(0,o.kt)("ul",null,(0,o.kt)("li",{parentName:"ul"},"Your are using the Podman container engine."),(0,o.kt)("li",{parentName:"ul"},"Your pod, running or stopped, is available on the ",(0,o.kt)("strong",{parentName:"li"},"Pods")," page: ",(0,o.kt)("em",{parentName:"li"},"<","your_pod",">"),"."),(0,o.kt)("li",{parentName:"ul"},"You registered the Kubernetes cluster in your kubeconfig file: ",(0,o.kt)("em",{parentName:"li"},"<","your_kubernetes_cluster",">"),". For example, ",(0,o.kt)("a",{parentName:"li",href:"/docs/kind/creating-a-kind-cluster"},"Creating a kind cluster"),"."),(0,o.kt)("li",{parentName:"ul"},"The Kubernetes namespace to deploy to already exists.")),(0,o.kt)("h4",{id:"procedure"},"Procedure"),(0,o.kt)("ol",null,(0,o.kt)("li",{parentName:"ol"},"Click ",(0,o.kt)("strong",{parentName:"li"},"Podman Desktop tray > Kubernetes > Context > ",(0,o.kt)("em",{parentName:"strong"},"<","your_kubernetes_cluster",">"))," to set your Kubernetes context."),(0,o.kt)("li",{parentName:"ol"},"Open ",(0,o.kt)("strong",{parentName:"li"},"Podman Desktop dashboard > ",(0,o.kt)(u,{icon:"fa-solid fa-cubes",size:"lg",mdxType:"Icon"})," Pods > ",(0,o.kt)("em",{parentName:"strong"},"<","your_pod",">"))," to see the ",(0,o.kt)("strong",{parentName:"li"},"Pod Details")," page."),(0,o.kt)("li",{parentName:"ol"},"Click ",(0,o.kt)(u,{icon:"fa-solid fa-rocket",size:"lg",mdxType:"Icon"})," to generate a Kubernetes pod."),(0,o.kt)("li",{parentName:"ol"},"On the ",(0,o.kt)("strong",{parentName:"li"},"Deploy generated pod to Kubernetes")," screen, choose your options:",(0,o.kt)("ol",{parentName:"li"},(0,o.kt)("li",{parentName:"ol"},(0,o.kt)("strong",{parentName:"li"},"Pod Name"),": edit the proposed name."),(0,o.kt)("li",{parentName:"ol"},(0,o.kt)("strong",{parentName:"li"},"Use Kubernetes Services"),": enable or disable ",(0,o.kt)("strong",{parentName:"li"},"Replace ",(0,o.kt)("inlineCode",{parentName:"strong"},"hostPort")," exposure on containers by Services. It is the recommended way to expose ports, as a cluster policy might prevent to use ",(0,o.kt)("inlineCode",{parentName:"strong"},"hostPort"),".")),(0,o.kt)("li",{parentName:"ol"},(0,o.kt)("strong",{parentName:"li"},"Kubernetes namespace"),": select in the list the namespace to deploy the pod to."))),(0,o.kt)("li",{parentName:"ol"},"Click the ",(0,o.kt)("strong",{parentName:"li"},(0,o.kt)(u,{icon:"fa-solid fa-rocket",size:"lg",mdxType:"Icon"})," Deploy")," button.")),(0,o.kt)("h4",{id:"verification"},"Verification"),(0,o.kt)("ul",null,(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},"On the ",(0,o.kt)("strong",{parentName:"p"},"Deploy generated pod to Kubernetes")," screen, the created pod status is ",(0,o.kt)("em",{parentName:"p"},"Phase: Running")),(0,o.kt)("p",{parentName:"li"},(0,o.kt)("img",{alt:"Deploying a pod",src:n(2392).Z,width:"816",height:"751"}))),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},"Go to ",(0,o.kt)("strong",{parentName:"p"},"Pods"),": your pod is in the list."))))}m.isMDXComponent=!0},2392:(e,t,n)=>{n.d(t,{Z:()=>r});const r=n.p+"assets/images/deploying-a-pod-6c02e24c06e0f39452ce5bec4ab1b9e5.png"}}]); \ No newline at end of file diff --git a/assets/js/54590fd2.8a802f7b.js b/assets/js/54590fd2.8a802f7b.js deleted file mode 100644 index fc9bb29bbca..00000000000 --- a/assets/js/54590fd2.8a802f7b.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[138],{35318:(e,t,n)=>{n.d(t,{Zo:()=>u,kt:()=>m});var r=n(27378);function o(e,t,n){return t in e?Object.defineProperty(e,t,{value:n,enumerable:!0,configurable:!0,writable:!0}):e[t]=n,e}function a(e,t){var n=Object.keys(e);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(e);t&&(r=r.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),n.push.apply(n,r)}return n}function i(e){for(var t=1;t=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var p=r.createContext({}),l=function(e){var t=r.useContext(p),n=t;return e&&(n="function"==typeof e?e(t):i(i({},t),e)),n},u=function(e){var t=l(e.components);return r.createElement(p.Provider,{value:t},e.children)},c={inlineCode:"code",wrapper:function(e){var t=e.children;return r.createElement(r.Fragment,{},t)}},d=r.forwardRef((function(e,t){var n=e.components,o=e.mdxType,a=e.originalType,p=e.parentName,u=s(e,["components","mdxType","originalType","parentName"]),d=l(n),m=o,k=d["".concat(p,".").concat(m)]||d[m]||c[m]||a;return n?r.createElement(k,i(i({ref:t},u),{},{components:n})):r.createElement(k,i({ref:t},u))}));function m(e,t){var n=arguments,o=t&&t.mdxType;if("string"==typeof e||o){var a=n.length,i=new Array(a);i[0]=d;var s={};for(var p in t)hasOwnProperty.call(t,p)&&(s[p]=t[p]);s.originalType=e,s.mdxType="string"==typeof e?e:o,i[1]=s;for(var l=2;l{n.r(t),n.d(t,{assets:()=>p,contentTitle:()=>i,default:()=>c,frontMatter:()=>a,metadata:()=>s,toc:()=>l});var r=n(25773),o=(n(27378),n(35318));const a={sidebar_position:10,title:"Deploying a pod",description:"Deploying a pod to Kubernetes",keywords:["podman desktop","podman","containers","pods","migrating","kubernetes"],tags:["migrating-to-kubernetes"]},i="Deploying a pod to Kubernetes",s={unversionedId:"kubernetes/deploying-a-pod-to-kubernetes",id:"kubernetes/deploying-a-pod-to-kubernetes",title:"Deploying a pod",description:"Deploying a pod to Kubernetes",source:"@site/docs/kubernetes/deploying-a-pod-to-kubernetes.md",sourceDirName:"kubernetes",slug:"/kubernetes/deploying-a-pod-to-kubernetes",permalink:"/docs/kubernetes/deploying-a-pod-to-kubernetes",draft:!1,editUrl:"https://github.com/containers/podman-desktop/tree/main/website/docs/kubernetes/deploying-a-pod-to-kubernetes.md",tags:[{label:"migrating-to-kubernetes",permalink:"/docs/tags/migrating-to-kubernetes"}],version:"current",sidebarPosition:10,frontMatter:{sidebar_position:10,title:"Deploying a pod",description:"Deploying a pod to Kubernetes",keywords:["podman desktop","podman","containers","pods","migrating","kubernetes"],tags:["migrating-to-kubernetes"]},sidebar:"mySidebar",previous:{title:"Deploying a container",permalink:"/docs/kubernetes/deploying-a-container-to-kubernetes"},next:{title:"Existing Kubernetes",permalink:"/docs/kubernetes/existing-kubernetes/"}},p={},l=[{value:"Prerequisites",id:"prerequisites",level:4},{value:"Procedure",id:"procedure",level:4},{value:"Verification",id:"verification",level:4}],u={toc:l};function c(e){let{components:t,...a}=e;return(0,o.kt)("wrapper",(0,r.Z)({},u,a,{components:t,mdxType:"MDXLayout"}),(0,o.kt)("h1",{id:"deploying-a-pod-to-kubernetes"},"Deploying a pod to Kubernetes"),(0,o.kt)("p",null,"With Podman Desktop, you can deploy a pod to your Kubernetes cluster."),(0,o.kt)("h4",{id:"prerequisites"},"Prerequisites"),(0,o.kt)("ul",null,(0,o.kt)("li",{parentName:"ul"},"Your are using the Podman container engine."),(0,o.kt)("li",{parentName:"ul"},"Your pod, running or stopped, is available on the ",(0,o.kt)("strong",{parentName:"li"},"Pods")," page: ",(0,o.kt)("em",{parentName:"li"},"<","your_pod",">"),"."),(0,o.kt)("li",{parentName:"ul"},"You registered the Kubernetes cluster in your kubeconfig file: ",(0,o.kt)("em",{parentName:"li"},"<","your_kubernetes_cluster",">"),". For example, ",(0,o.kt)("a",{parentName:"li",href:"/docs/kind/creating-a-kind-cluster"},"Creating a kind cluster"),"."),(0,o.kt)("li",{parentName:"ul"},"The Kubernetes namespace to deploy to already exists.")),(0,o.kt)("h4",{id:"procedure"},"Procedure"),(0,o.kt)("ol",null,(0,o.kt)("li",{parentName:"ol"},"Click ",(0,o.kt)("strong",{parentName:"li"},"Podman Desktop tray > Kubernetes > Context > ",(0,o.kt)("em",{parentName:"strong"},"<","your_kubernetes_cluster",">"))," to set your Kubernetes context."),(0,o.kt)("li",{parentName:"ol"},"Open ",(0,o.kt)("strong",{parentName:"li"},"Podman Desktop dashboard > ",(0,o.kt)("icon",{icon:"fa-solid fa-cubes",size:"lg"})," Pods > ",(0,o.kt)("em",{parentName:"strong"},"<","your_pod",">"))," to see the ",(0,o.kt)("strong",{parentName:"li"},"Pod Details")," page."),(0,o.kt)("li",{parentName:"ol"},"Click ",(0,o.kt)("icon",{icon:"fa-solid fa-rocket",size:"lg"})," to generate a Kubernetes pod."),(0,o.kt)("li",{parentName:"ol"},"On the ",(0,o.kt)("strong",{parentName:"li"},"Deploy generated pod to Kubernetes")," screen, choose your options:",(0,o.kt)("ol",{parentName:"li"},(0,o.kt)("li",{parentName:"ol"},(0,o.kt)("strong",{parentName:"li"},"Pod Name"),": edit the proposed name."),(0,o.kt)("li",{parentName:"ol"},(0,o.kt)("strong",{parentName:"li"},"Use Kubernetes Services"),": enable or disable ",(0,o.kt)("strong",{parentName:"li"},"Replace ",(0,o.kt)("inlineCode",{parentName:"strong"},"hostPort")," exposure on containers by Services. It is the recommended way to expose ports, as a cluster policy might prevent to use ",(0,o.kt)("inlineCode",{parentName:"strong"},"hostPort"),".")),(0,o.kt)("li",{parentName:"ol"},(0,o.kt)("strong",{parentName:"li"},"Kubernetes namespace"),": select in the list the namespace to deploy the pod to."))),(0,o.kt)("li",{parentName:"ol"},"Click the ",(0,o.kt)("strong",{parentName:"li"},(0,o.kt)("icon",{icon:"fa-solid fa-rocket",size:"lg"})," Deploy")," button.")),(0,o.kt)("h4",{id:"verification"},"Verification"),(0,o.kt)("ul",null,(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},"On the ",(0,o.kt)("strong",{parentName:"p"},"Deploy generated pod to Kubernetes")," screen, the created pod status is ",(0,o.kt)("em",{parentName:"p"},"Phase: Running")),(0,o.kt)("p",{parentName:"li"},(0,o.kt)("img",{alt:"Deploying a pod",src:n(2392).Z,width:"816",height:"751"}))),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},"Go to ",(0,o.kt)("strong",{parentName:"p"},"Pods"),": your pod is in the list."))))}c.isMDXComponent=!0},2392:(e,t,n)=>{n.d(t,{Z:()=>r});const r=n.p+"assets/images/deploying-a-pod-6c02e24c06e0f39452ce5bec4ab1b9e5.png"}}]); \ No newline at end of file diff --git a/assets/js/562ca3e9.c43abc7d.js b/assets/js/562ca3e9.c43abc7d.js new file mode 100644 index 00000000000..074afef735c --- /dev/null +++ b/assets/js/562ca3e9.c43abc7d.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[3840],{35318:(e,t,n)=>{n.d(t,{Zo:()=>p,kt:()=>k});var r=n(27378);function i(e,t,n){return t in e?Object.defineProperty(e,t,{value:n,enumerable:!0,configurable:!0,writable:!0}):e[t]=n,e}function a(e,t){var n=Object.keys(e);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(e);t&&(r=r.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),n.push.apply(n,r)}return n}function o(e){for(var t=1;t=0||(i[n]=e[n]);return i}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(i[n]=e[n])}return i}var s=r.createContext({}),c=function(e){var t=r.useContext(s),n=t;return e&&(n="function"==typeof e?e(t):o(o({},t),e)),n},p=function(e){var t=c(e.components);return r.createElement(s.Provider,{value:t},e.children)},d={inlineCode:"code",wrapper:function(e){var t=e.children;return r.createElement(r.Fragment,{},t)}},u=r.forwardRef((function(e,t){var n=e.components,i=e.mdxType,a=e.originalType,s=e.parentName,p=l(e,["components","mdxType","originalType","parentName"]),u=c(n),k=i,m=u["".concat(s,".").concat(k)]||u[k]||d[k]||a;return n?r.createElement(m,o(o({ref:t},p),{},{components:n})):r.createElement(m,o({ref:t},p))}));function k(e,t){var n=arguments,i=t&&t.mdxType;if("string"==typeof e||i){var a=n.length,o=new Array(a);o[0]=u;var l={};for(var s in t)hasOwnProperty.call(t,s)&&(l[s]=t[s]);l.originalType=e,l.mdxType="string"==typeof e?e:i,o[1]=l;for(var c=2;c{n.r(t),n.d(t,{assets:()=>s,contentTitle:()=>o,default:()=>k,frontMatter:()=>a,metadata:()=>l,toc:()=>c});var r=n(25773),i=(n(27378),n(35318));const a={sidebar_position:4,title:"Creating a Kind cluster",description:"Creating a local Kind-powered Kubernetes cluster.",keywords:["podman desktop","podman","containers","migrating","kubernetes","kind"],tags:["migrating-to-kubernetes","kind"]},o="Creating a local Kind-powered Kubernetes cluster",l={unversionedId:"kind/creating-a-kind-cluster",id:"kind/creating-a-kind-cluster",title:"Creating a Kind cluster",description:"Creating a local Kind-powered Kubernetes cluster.",source:"@site/docs/kind/creating-a-kind-cluster.md",sourceDirName:"kind",slug:"/kind/creating-a-kind-cluster",permalink:"/docs/kind/creating-a-kind-cluster",draft:!1,editUrl:"https://github.com/containers/podman-desktop/tree/main/website/docs/kind/creating-a-kind-cluster.md",tags:[{label:"migrating-to-kubernetes",permalink:"/docs/tags/migrating-to-kubernetes"},{label:"kind",permalink:"/docs/tags/kind"}],version:"current",sidebarPosition:4,frontMatter:{sidebar_position:4,title:"Creating a Kind cluster",description:"Creating a local Kind-powered Kubernetes cluster.",keywords:["podman desktop","podman","containers","migrating","kubernetes","kind"],tags:["migrating-to-kubernetes","kind"]},sidebar:"mySidebar",previous:{title:"Configuring Podman for Kind",permalink:"/docs/kind/configuring-podman-for-kind-on-windows"},next:{title:"Restarting your Kind cluster",permalink:"/docs/kind/restarting-your-kind-cluster"}},s={},c=[{value:"Prerequisites",id:"prerequisites",level:4},{value:"Procedure",id:"procedure",level:4},{value:"Verification",id:"verification",level:4}],p=(d="Icon",function(e){return console.warn("Component "+d+" was not imported, exported, or provided by MDXProvider as global scope"),(0,i.kt)("div",e)});var d;const u={toc:c};function k(e){let{components:t,...n}=e;return(0,i.kt)("wrapper",(0,r.Z)({},u,n,{components:t,mdxType:"MDXLayout"}),(0,i.kt)("h1",{id:"creating-a-local-kind-powered-kubernetes-cluster"},"Creating a local Kind-powered Kubernetes cluster"),(0,i.kt)("p",null,"You can create multiple local Kind-powered Kubernetes clusters."),(0,i.kt)("h4",{id:"prerequisites"},"Prerequisites"),(0,i.kt)("ul",null,(0,i.kt)("li",{parentName:"ul"},(0,i.kt)("a",{parentName:"li",href:"/docs/kind/installing"},"You installed Kind"),"."),(0,i.kt)("li",{parentName:"ul"},(0,i.kt)("a",{parentName:"li",href:"/docs/kind/configuring-podman-for-kind-on-windows"},"On Windows, you configured Podman"),".")),(0,i.kt)("h4",{id:"procedure"},"Procedure"),(0,i.kt)("ol",null,(0,i.kt)("li",{parentName:"ol"},(0,i.kt)("p",{parentName:"li"},"Go to ",(0,i.kt)("strong",{parentName:"p"},(0,i.kt)(p,{icon:"fa-solid fa-cog",size:"lg",mdxType:"Icon"})," Settings > Resources"))),(0,i.kt)("li",{parentName:"ol"},(0,i.kt)("p",{parentName:"li"},"In the Kind tile, click on the ",(0,i.kt)("strong",{parentName:"p"},"Create new ...")," button.")),(0,i.kt)("li",{parentName:"ol"},(0,i.kt)("p",{parentName:"li"},"Choose your options, and click the ",(0,i.kt)("strong",{parentName:"p"},"Create")," button."),(0,i.kt)("p",{parentName:"li"},"The defaults are:"),(0,i.kt)("ul",{parentName:"li"},(0,i.kt)("li",{parentName:"ul"},(0,i.kt)("strong",{parentName:"li"},"Name"),": ",(0,i.kt)("inlineCode",{parentName:"li"},"kind-cluster")),(0,i.kt)("li",{parentName:"ul"},(0,i.kt)("strong",{parentName:"li"},"Provider Type"),": ",(0,i.kt)("inlineCode",{parentName:"li"},"podman")),(0,i.kt)("li",{parentName:"ul"},(0,i.kt)("strong",{parentName:"li"},"HTTP Port"),": ",(0,i.kt)("inlineCode",{parentName:"li"},"9090")),(0,i.kt)("li",{parentName:"ul"},(0,i.kt)("strong",{parentName:"li"},"HTTPS Port"),": ",(0,i.kt)("inlineCode",{parentName:"li"},"9443")),(0,i.kt)("li",{parentName:"ul"},(0,i.kt)("strong",{parentName:"li"},"Setup an ingress controller (Contour ",(0,i.kt)("a",{parentName:"strong",href:"https://projectcontour.io"},"https://projectcontour.io"),")"),": Enabled"),(0,i.kt)("li",{parentName:"ul"},(0,i.kt)("strong",{parentName:"li"},"Node\u2019s container image (Available image tags on ",(0,i.kt)("a",{parentName:"strong",href:"https://github.com/kubernetes-sigs/kind/releases"},"kind/releases"),")"),": Left empty to use latest."))),(0,i.kt)("li",{parentName:"ol"},(0,i.kt)("p",{parentName:"li"},"(Optionally) Click the ",(0,i.kt)("strong",{parentName:"p"},"Show logs")," button to display the logs.")),(0,i.kt)("li",{parentName:"ol"},(0,i.kt)("p",{parentName:"li"},"After successful creation, click on the ",(0,i.kt)("strong",{parentName:"p"},"Go back to resources")," button"))),(0,i.kt)("h4",{id:"verification"},"Verification"),(0,i.kt)("ol",null,(0,i.kt)("li",{parentName:"ol"},"In ",(0,i.kt)("strong",{parentName:"li"},(0,i.kt)(p,{icon:"fa-solid fa-cog",size:"lg",mdxType:"Icon"})," Settings > Resources"),", in the ",(0,i.kt)("strong",{parentName:"li"},"Kind")," tile, your ",(0,i.kt)("inlineCode",{parentName:"li"},"")," instance is running."),(0,i.kt)("li",{parentName:"ol"},"In the Podman Desktop tray, open the ",(0,i.kt)("strong",{parentName:"li"},"Kubernetes")," menu, you can set the context to your Kind cluster: ",(0,i.kt)("inlineCode",{parentName:"li"},"kind-"),".")))}k.isMDXComponent=!0}}]); \ No newline at end of file diff --git a/assets/js/562ca3e9.e6938fa9.js b/assets/js/562ca3e9.e6938fa9.js deleted file mode 100644 index fedd7bd718e..00000000000 --- a/assets/js/562ca3e9.e6938fa9.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[3840],{35318:(e,t,n)=>{n.d(t,{Zo:()=>p,kt:()=>k});var r=n(27378);function i(e,t,n){return t in e?Object.defineProperty(e,t,{value:n,enumerable:!0,configurable:!0,writable:!0}):e[t]=n,e}function a(e,t){var n=Object.keys(e);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(e);t&&(r=r.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),n.push.apply(n,r)}return n}function o(e){for(var t=1;t=0||(i[n]=e[n]);return i}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(i[n]=e[n])}return i}var s=r.createContext({}),c=function(e){var t=r.useContext(s),n=t;return e&&(n="function"==typeof e?e(t):o(o({},t),e)),n},p=function(e){var t=c(e.components);return r.createElement(s.Provider,{value:t},e.children)},u={inlineCode:"code",wrapper:function(e){var t=e.children;return r.createElement(r.Fragment,{},t)}},d=r.forwardRef((function(e,t){var n=e.components,i=e.mdxType,a=e.originalType,s=e.parentName,p=l(e,["components","mdxType","originalType","parentName"]),d=c(n),k=i,m=d["".concat(s,".").concat(k)]||d[k]||u[k]||a;return n?r.createElement(m,o(o({ref:t},p),{},{components:n})):r.createElement(m,o({ref:t},p))}));function k(e,t){var n=arguments,i=t&&t.mdxType;if("string"==typeof e||i){var a=n.length,o=new Array(a);o[0]=d;var l={};for(var s in t)hasOwnProperty.call(t,s)&&(l[s]=t[s]);l.originalType=e,l.mdxType="string"==typeof e?e:i,o[1]=l;for(var c=2;c{n.r(t),n.d(t,{assets:()=>s,contentTitle:()=>o,default:()=>u,frontMatter:()=>a,metadata:()=>l,toc:()=>c});var r=n(25773),i=(n(27378),n(35318));const a={sidebar_position:4,title:"Creating a Kind cluster",description:"Creating a local Kind-powered Kubernetes cluster.",keywords:["podman desktop","podman","containers","migrating","kubernetes","kind"],tags:["migrating-to-kubernetes","kind"]},o="Creating a local Kind-powered Kubernetes cluster",l={unversionedId:"kind/creating-a-kind-cluster",id:"kind/creating-a-kind-cluster",title:"Creating a Kind cluster",description:"Creating a local Kind-powered Kubernetes cluster.",source:"@site/docs/kind/creating-a-kind-cluster.md",sourceDirName:"kind",slug:"/kind/creating-a-kind-cluster",permalink:"/docs/kind/creating-a-kind-cluster",draft:!1,editUrl:"https://github.com/containers/podman-desktop/tree/main/website/docs/kind/creating-a-kind-cluster.md",tags:[{label:"migrating-to-kubernetes",permalink:"/docs/tags/migrating-to-kubernetes"},{label:"kind",permalink:"/docs/tags/kind"}],version:"current",sidebarPosition:4,frontMatter:{sidebar_position:4,title:"Creating a Kind cluster",description:"Creating a local Kind-powered Kubernetes cluster.",keywords:["podman desktop","podman","containers","migrating","kubernetes","kind"],tags:["migrating-to-kubernetes","kind"]},sidebar:"mySidebar",previous:{title:"Configuring Podman for Kind",permalink:"/docs/kind/configuring-podman-for-kind-on-windows"},next:{title:"Restarting your Kind cluster",permalink:"/docs/kind/restarting-your-kind-cluster"}},s={},c=[{value:"Prerequisites",id:"prerequisites",level:4},{value:"Procedure",id:"procedure",level:4},{value:"Verification",id:"verification",level:4}],p={toc:c};function u(e){let{components:t,...n}=e;return(0,i.kt)("wrapper",(0,r.Z)({},p,n,{components:t,mdxType:"MDXLayout"}),(0,i.kt)("h1",{id:"creating-a-local-kind-powered-kubernetes-cluster"},"Creating a local Kind-powered Kubernetes cluster"),(0,i.kt)("p",null,"You can create multiple local Kind-powered Kubernetes clusters."),(0,i.kt)("h4",{id:"prerequisites"},"Prerequisites"),(0,i.kt)("ul",null,(0,i.kt)("li",{parentName:"ul"},(0,i.kt)("a",{parentName:"li",href:"/docs/kind/installing"},"You installed Kind"),"."),(0,i.kt)("li",{parentName:"ul"},(0,i.kt)("a",{parentName:"li",href:"/docs/kind/configuring-podman-for-kind-on-windows"},"On Windows, you configured Podman"),".")),(0,i.kt)("h4",{id:"procedure"},"Procedure"),(0,i.kt)("ol",null,(0,i.kt)("li",{parentName:"ol"},(0,i.kt)("p",{parentName:"li"},"Go to ",(0,i.kt)("strong",{parentName:"p"},(0,i.kt)("icon",{icon:"fa-solid fa-cog",size:"lg"})," Settings > Resources"))),(0,i.kt)("li",{parentName:"ol"},(0,i.kt)("p",{parentName:"li"},"In the Kind tile, click on the ",(0,i.kt)("strong",{parentName:"p"},"Create new ...")," button.")),(0,i.kt)("li",{parentName:"ol"},(0,i.kt)("p",{parentName:"li"},"Choose your options, and click the ",(0,i.kt)("strong",{parentName:"p"},"Create")," button."),(0,i.kt)("p",{parentName:"li"},"The defaults are:"),(0,i.kt)("ul",{parentName:"li"},(0,i.kt)("li",{parentName:"ul"},(0,i.kt)("strong",{parentName:"li"},"Name"),": ",(0,i.kt)("inlineCode",{parentName:"li"},"kind-cluster")),(0,i.kt)("li",{parentName:"ul"},(0,i.kt)("strong",{parentName:"li"},"Provider Type"),": ",(0,i.kt)("inlineCode",{parentName:"li"},"podman")),(0,i.kt)("li",{parentName:"ul"},(0,i.kt)("strong",{parentName:"li"},"HTTP Port"),": ",(0,i.kt)("inlineCode",{parentName:"li"},"9090")),(0,i.kt)("li",{parentName:"ul"},(0,i.kt)("strong",{parentName:"li"},"HTTPS Port"),": ",(0,i.kt)("inlineCode",{parentName:"li"},"9443")),(0,i.kt)("li",{parentName:"ul"},(0,i.kt)("strong",{parentName:"li"},"Setup an ingress controller (Contour ",(0,i.kt)("a",{parentName:"strong",href:"https://projectcontour.io"},"https://projectcontour.io"),")"),": Enabled"),(0,i.kt)("li",{parentName:"ul"},(0,i.kt)("strong",{parentName:"li"},"Node\u2019s container image (Available image tags on ",(0,i.kt)("a",{parentName:"strong",href:"https://github.com/kubernetes-sigs/kind/releases"},"kind/releases"),")"),": Left empty to use latest."))),(0,i.kt)("li",{parentName:"ol"},(0,i.kt)("p",{parentName:"li"},"(Optionally) Click the ",(0,i.kt)("strong",{parentName:"p"},"Show logs")," button to display the logs.")),(0,i.kt)("li",{parentName:"ol"},(0,i.kt)("p",{parentName:"li"},"After successful creation, click on the ",(0,i.kt)("strong",{parentName:"p"},"Go back to resources")," button"))),(0,i.kt)("h4",{id:"verification"},"Verification"),(0,i.kt)("ol",null,(0,i.kt)("li",{parentName:"ol"},"In ",(0,i.kt)("strong",{parentName:"li"},(0,i.kt)("icon",{icon:"fa-solid fa-cog",size:"lg"})," Settings > Resources"),", in the ",(0,i.kt)("strong",{parentName:"li"},"Kind")," tile, your ",(0,i.kt)("inlineCode",{parentName:"li"},"")," instance is running."),(0,i.kt)("li",{parentName:"ol"},"In the Podman Desktop tray, open the ",(0,i.kt)("strong",{parentName:"li"},"Kubernetes")," menu, you can set the context to your Kind cluster: ",(0,i.kt)("inlineCode",{parentName:"li"},"kind-"),".")))}u.isMDXComponent=!0}}]); \ No newline at end of file diff --git a/assets/js/5660752d.3fd29c77.js b/assets/js/5660752d.7df7d400.js similarity index 50% rename from assets/js/5660752d.3fd29c77.js rename to assets/js/5660752d.7df7d400.js index 3880fee9382..eb48840bac3 100644 --- a/assets/js/5660752d.3fd29c77.js +++ b/assets/js/5660752d.7df7d400.js @@ -1 +1 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[8176],{35318:(e,t,n)=>{n.d(t,{Zo:()=>c,kt:()=>d});var a=n(27378);function r(e,t,n){return t in e?Object.defineProperty(e,t,{value:n,enumerable:!0,configurable:!0,writable:!0}):e[t]=n,e}function o(e,t){var n=Object.keys(e);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);t&&(a=a.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),n.push.apply(n,a)}return n}function i(e){for(var t=1;t=0||(r[n]=e[n]);return r}(e,t);if(Object.getOwnPropertySymbols){var o=Object.getOwnPropertySymbols(e);for(a=0;a=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(r[n]=e[n])}return r}var s=a.createContext({}),p=function(e){var t=a.useContext(s),n=t;return e&&(n="function"==typeof e?e(t):i(i({},t),e)),n},c=function(e){var t=p(e.components);return a.createElement(s.Provider,{value:t},e.children)},u={inlineCode:"code",wrapper:function(e){var t=e.children;return a.createElement(a.Fragment,{},t)}},m=a.forwardRef((function(e,t){var n=e.components,r=e.mdxType,o=e.originalType,s=e.parentName,c=l(e,["components","mdxType","originalType","parentName"]),m=p(n),d=r,f=m["".concat(s,".").concat(d)]||m[d]||u[d]||o;return n?a.createElement(f,i(i({ref:t},c),{},{components:n})):a.createElement(f,i({ref:t},c))}));function d(e,t){var n=arguments,r=t&&t.mdxType;if("string"==typeof e||r){var o=n.length,i=new Array(o);i[0]=m;var l={};for(var s in t)hasOwnProperty.call(t,s)&&(l[s]=t[s]);l.originalType=e,l.mdxType="string"==typeof e?e:r,i[1]=l;for(var p=2;p{n.d(t,{Z:()=>i});var a=n(27378),r=n(38944);const o="tabItem_wHwb";function i(e){let{children:t,hidden:n,className:i}=e;return a.createElement("div",{role:"tabpanel",className:(0,r.Z)(o,i),hidden:n},t)}},23930:(e,t,n)=>{n.d(t,{Z:()=>O});var a=n(25773),r=n(27378),o=n(38944),i=n(83457),l=n(35331),s=n(30654),p=n(70784),c=n(71819);function u(e){return function(e){return r.Children.map(e,(e=>{if(!e||(0,r.isValidElement)(e)&&function(e){const{props:t}=e;return!!t&&"object"==typeof t&&"value"in t}(e))return e;throw new Error(`Docusaurus error: Bad child <${"string"==typeof e.type?e.type:e.type.name}>: all children of the component should be , and every should have a unique "value" prop.`)}))?.filter(Boolean)??[]}(e).map((e=>{let{props:{value:t,label:n,attributes:a,default:r}}=e;return{value:t,label:n,attributes:a,default:r}}))}function m(e){const{values:t,children:n}=e;return(0,r.useMemo)((()=>{const e=t??u(n);return function(e){const t=(0,p.l)(e,((e,t)=>e.value===t.value));if(t.length>0)throw new Error(`Docusaurus error: Duplicate values "${t.map((e=>e.value)).join(", ")}" found in . Every value needs to be unique.`)}(e),e}),[t,n])}function d(e){let{value:t,tabValues:n}=e;return n.some((e=>e.value===t))}function f(e){let{queryString:t=!1,groupId:n}=e;const a=(0,l.k6)(),o=function(e){let{queryString:t=!1,groupId:n}=e;if("string"==typeof t)return t;if(!1===t)return null;if(!0===t&&!n)throw new Error('Docusaurus error: The component groupId prop is required if queryString=true, because this value is used as the search param name. You can also provide an explicit value such as queryString="my-search-param".');return n??null}({queryString:t,groupId:n});return[(0,s._X)(o),(0,r.useCallback)((e=>{if(!o)return;const t=new URLSearchParams(a.location.search);t.set(o,e),a.replace({...a.location,search:t.toString()})}),[o,a])]}function h(e){const{defaultValue:t,queryString:n=!1,groupId:a}=e,o=m(e),[i,l]=(0,r.useState)((()=>function(e){let{defaultValue:t,tabValues:n}=e;if(0===n.length)throw new Error("Docusaurus error: the component requires at least one children component");if(t){if(!d({value:t,tabValues:n}))throw new Error(`Docusaurus error: The has a defaultValue "${t}" but none of its children has the corresponding value. Available values are: ${n.map((e=>e.value)).join(", ")}. If you intend to show no default tab, use defaultValue={null} instead.`);return t}const a=n.find((e=>e.default))??n[0];if(!a)throw new Error("Unexpected error: 0 tabValues");return a.value}({defaultValue:t,tabValues:o}))),[s,p]=f({queryString:n,groupId:a}),[u,h]=function(e){let{groupId:t}=e;const n=function(e){return e?`docusaurus.tab.${e}`:null}(t),[a,o]=(0,c.Nk)(n);return[a,(0,r.useCallback)((e=>{n&&o.set(e)}),[n,o])]}({groupId:a}),k=(()=>{const e=s??u;return d({value:e,tabValues:o})?e:null})();(0,r.useLayoutEffect)((()=>{k&&l(k)}),[k]);return{selectedValue:i,selectValue:(0,r.useCallback)((e=>{if(!d({value:e,tabValues:o}))throw new Error(`Can't select invalid tab value=${e}`);l(e),p(e),h(e)}),[p,h,o]),tabValues:o}}var k=n(76457);const g="tabList_J5MA",b="tabItem_l0OV";function N(e){let{className:t,block:n,selectedValue:l,selectValue:s,tabValues:p}=e;const c=[],{blockElementScrollPositionUntilNextRender:u}=(0,i.o5)(),m=e=>{const t=e.currentTarget,n=c.indexOf(t),a=p[n].value;a!==l&&(u(t),s(a))},d=e=>{let t=null;switch(e.key){case"Enter":m(e);break;case"ArrowRight":{const n=c.indexOf(e.currentTarget)+1;t=c[n]??c[0];break}case"ArrowLeft":{const n=c.indexOf(e.currentTarget)-1;t=c[n]??c[c.length-1];break}}t?.focus()};return r.createElement("ul",{role:"tablist","aria-orientation":"horizontal",className:(0,o.Z)("tabs",{"tabs--block":n},t)},p.map((e=>{let{value:t,label:n,attributes:i}=e;return r.createElement("li",(0,a.Z)({role:"tab",tabIndex:l===t?0:-1,"aria-selected":l===t,key:t,ref:e=>c.push(e),onKeyDown:d,onClick:m},i,{className:(0,o.Z)("tabs__item",b,i?.className,{"tabs__item--active":l===t})}),n??t)})))}function y(e){let{lazy:t,children:n,selectedValue:a}=e;const o=(Array.isArray(n)?n:[n]).filter(Boolean);if(t){const e=o.find((e=>e.props.value===a));return e?(0,r.cloneElement)(e,{className:"margin-top--md"}):null}return r.createElement("div",{className:"margin-top--md"},o.map(((e,t)=>(0,r.cloneElement)(e,{key:t,hidden:e.props.value!==a}))))}function v(e){const t=h(e);return r.createElement("div",{className:(0,o.Z)("tabs-container",g)},r.createElement(N,(0,a.Z)({},e,t)),r.createElement(y,(0,a.Z)({},e,t)))}function O(e){const t=(0,k.Z)();return r.createElement(v,(0,a.Z)({key:String(t)},e))}},20797:(e,t,n)=>{n.r(t),n.d(t,{assets:()=>c,contentTitle:()=>s,default:()=>d,frontMatter:()=>l,metadata:()=>p,toc:()=>u});var a=n(25773),r=(n(27378),n(35318)),o=n(23930),i=n(39798);const l={title:"OpenShift Local",description:"Creating an OpenShift Local instance",keywords:["podman desktop","podman","containers","pods","migrating","kubernetes","openshift"],tags:["migrating-to-kubernetes","openshift"]},s="Creating an OpenShift Local instance",p={unversionedId:"openshift/openshift-local/index",id:"openshift/openshift-local/index",title:"OpenShift Local",description:"Creating an OpenShift Local instance",source:"@site/docs/openshift/openshift-local/index.md",sourceDirName:"openshift/openshift-local",slug:"/openshift/openshift-local/",permalink:"/docs/openshift/openshift-local/",draft:!1,editUrl:"https://github.com/containers/podman-desktop/tree/main/website/docs/openshift/openshift-local/index.md",tags:[{label:"migrating-to-kubernetes",permalink:"/docs/tags/migrating-to-kubernetes"},{label:"openshift",permalink:"/docs/tags/openshift"}],version:"current",frontMatter:{title:"OpenShift Local",description:"Creating an OpenShift Local instance",keywords:["podman desktop","podman","containers","pods","migrating","kubernetes","openshift"],tags:["migrating-to-kubernetes","openshift"]},sidebar:"mySidebar",previous:{title:"Developer Sandbox",permalink:"/docs/openshift/developer-sandbox/"},next:{title:"Writing extensions",permalink:"/docs/extensions/"}},c={},u=[{value:"Prerequisites",id:"prerequisites",level:4},{value:"Procedure",id:"procedure",level:4},{value:"Verification",id:"verification",level:4},{value:"Additional resources",id:"additional-resources",level:4}],m={toc:u};function d(e){let{components:t,...l}=e;return(0,r.kt)("wrapper",(0,a.Z)({},m,l,{components:t,mdxType:"MDXLayout"}),(0,r.kt)("h1",{id:"creating-an-openshift-local-instance"},"Creating an OpenShift Local instance"),(0,r.kt)("p",null,(0,r.kt)("a",{parentName:"p",href:"https://developers.redhat.com/products/openshift-local/overview"},"Red Hat OpenShift Local")," manages a minimal OpenShift or MicroShift cluster on your workstation for local development and testing."),(0,r.kt)("p",null,"With Podman Desktop and the OpenShift Local extension, you can manage your OpenShift Local instances."),(0,r.kt)("h4",{id:"prerequisites"},"Prerequisites"),(0,r.kt)("ul",null,(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("a",{parentName:"li",href:"https://developers.redhat.com/register"},"Register a Red Hat account"),".")),(0,r.kt)("h4",{id:"procedure"},"Procedure"),(0,r.kt)("ol",null,(0,r.kt)("li",{parentName:"ol"},(0,r.kt)("p",{parentName:"li"},"Install the ",(0,r.kt)("em",{parentName:"p"},"OpenShift Local")," extension: on to ",(0,r.kt)("strong",{parentName:"p"},"Dashboard"),", click ",(0,r.kt)("strong",{parentName:"p"},"OpenShift Local ",(0,r.kt)("icon",{icon:"fa-solid fa-download",size:"lg"})),".")),(0,r.kt)("li",{parentName:"ol"},(0,r.kt)("p",{parentName:"li"},"Install the OpenShift Local binaries, when on the ",(0,r.kt)("strong",{parentName:"p"},"Dashboard"),", you see ",(0,r.kt)("em",{parentName:"p"},"Podman Desktop was not able to find an installation of OpenShift Local"),"."),(0,r.kt)(o.Z,{groupId:"operating-systems",mdxType:"Tabs"},(0,r.kt)(i.Z,{value:"win",label:"Windows",mdxType:"TabItem"},(0,r.kt)("ol",{parentName:"li"},(0,r.kt)("li",{parentName:"ol"},"In the ",(0,r.kt)("strong",{parentName:"li"},"OpenShift Local")," tile, click ",(0,r.kt)("strong",{parentName:"li"},(0,r.kt)("icon",{icon:"fa-solid fa-rocket",size:"lg"})," Install"),"."),(0,r.kt)("li",{parentName:"ol"},"When prerequisites are missing, follow the instructions."),(0,r.kt)("li",{parentName:"ol"},"In the ",(0,r.kt)("strong",{parentName:"li"},"Red Hat OpenShift Local")," screen, click ",(0,r.kt)("strong",{parentName:"li"},"Yes")," to start the installation."),(0,r.kt)("li",{parentName:"ol"},"Follow the installation program instructions."),(0,r.kt)("li",{parentName:"ol"},"Reboot to finalize system changes."))),(0,r.kt)(i.Z,{value:"mac",label:"macOS",mdxType:"TabItem"},(0,r.kt)("ol",{parentName:"li"},(0,r.kt)("li",{parentName:"ol"},"In the ",(0,r.kt)("strong",{parentName:"li"},"OpenShift Local")," tile, click ",(0,r.kt)("strong",{parentName:"li"},(0,r.kt)("icon",{icon:"fa-solid fa-rocket",size:"lg"})," Install"),"."),(0,r.kt)("li",{parentName:"ol"},"When prerequisites are missing, follow the instructions."),(0,r.kt)("li",{parentName:"ol"},"In the ",(0,r.kt)("strong",{parentName:"li"},"Red Hat OpenShift Local")," screen, click ",(0,r.kt)("strong",{parentName:"li"},"Yes")," to start the installation."),(0,r.kt)("li",{parentName:"ol"},"Follow the installation program instructions."),(0,r.kt)("li",{parentName:"ol"},"Reboot to finalize system changes."))),(0,r.kt)(i.Z,{value:"linux",label:"Linux",mdxType:"TabItem"},(0,r.kt)("ol",{parentName:"li"},(0,r.kt)("li",{parentName:"ol"},(0,r.kt)("p",{parentName:"li"},"Go to the ",(0,r.kt)("a",{parentName:"p",href:"https://console.redhat.com/openshift/create/local"},"Red Hat OpenShift local download page"),".")),(0,r.kt)("li",{parentName:"ol"},(0,r.kt)("p",{parentName:"li"},"Select your platform.")),(0,r.kt)("li",{parentName:"ol"},(0,r.kt)("p",{parentName:"li"},"Click ",(0,r.kt)("strong",{parentName:"p"},"Download OpenShift Local"),".")),(0,r.kt)("li",{parentName:"ol"},(0,r.kt)("p",{parentName:"li"},"Extract the archive.")),(0,r.kt)("li",{parentName:"ol"},(0,r.kt)("p",{parentName:"li"},"Copy the ",(0,r.kt)("inlineCode",{parentName:"p"},"crc")," binary to a directory in your",(0,r.kt)("inlineCode",{parentName:"p"},"$PATH"),", such as ",(0,r.kt)("inlineCode",{parentName:"p"},"/usr/local/bin"),".")),(0,r.kt)("li",{parentName:"ol"},(0,r.kt)("p",{parentName:"li"},"To configure your system, run the command:"),(0,r.kt)("pre",{parentName:"li"},(0,r.kt)("code",{parentName:"pre",className:"language-shell-session"},"$ crc setup\n"))),(0,r.kt)("li",{parentName:"ol"},(0,r.kt)("p",{parentName:"li"},"Exit and restart Podman Desktop.")))))),(0,r.kt)("li",{parentName:"ol"},(0,r.kt)("p",{parentName:"li"},"(Optionally) Review the extension settings in ",(0,r.kt)("strong",{parentName:"p"},(0,r.kt)("icon",{icon:"fa-solid fa-cog",size:"lg"})," Settings > Preferences > Extension: Red Hat OpenShift Local"),".")),(0,r.kt)("li",{parentName:"ol"},(0,r.kt)("p",{parentName:"li"},"On the ",(0,r.kt)("strong",{parentName:"p"},"Dashboard"),", click ",(0,r.kt)("strong",{parentName:"p"},"Initialize and start"),"."),(0,r.kt)("ol",{parentName:"li"},(0,r.kt)("li",{parentName:"ol"},(0,r.kt)("p",{parentName:"li"},"Select your OpenShift Local Virtual machine preset, if not set in ",(0,r.kt)("strong",{parentName:"p"},(0,r.kt)("icon",{icon:"fa-solid fa-cog",size:"lg"})," Settings > Preferences > Extension: Red Hat OpenShift Local > Preset"),"."),(0,r.kt)("ul",{parentName:"li"},(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("em",{parentName:"li"},"MicroShift")," (experimental): provides a lightweight and optimized environment with a limited set of services."),(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("em",{parentName:"li"},"OpenShift"),": provides a single node OpenShift cluster with a fuller set of services, including a web console (requires more resources)."))),(0,r.kt)("li",{parentName:"ol"},(0,r.kt)("p",{parentName:"li"},"Provide a pull secret, required to pull container images from the registry:"),(0,r.kt)("ol",{parentName:"li"},(0,r.kt)("li",{parentName:"ol"},"Open the ",(0,r.kt)("a",{parentName:"li",href:"https://cloud.redhat.com/openshift/create/local"},"Red Hat OpenShift Local download page"),"."),(0,r.kt)("li",{parentName:"ol"},"Click ",(0,r.kt)("strong",{parentName:"li"},"Copy pull secret"),"."),(0,r.kt)("li",{parentName:"ol"},"Get back to Podman Desktop."),(0,r.kt)("li",{parentName:"ol"},"Paste the pull secret, and press ",(0,r.kt)("inlineCode",{parentName:"li"},"Enter"),".")))))),(0,r.kt)("h4",{id:"verification"},"Verification"),(0,r.kt)("ol",null,(0,r.kt)("li",{parentName:"ol"},(0,r.kt)("p",{parentName:"li"},"On the ",(0,r.kt)("strong",{parentName:"p"},"Dashboard")," screen, ",(0,r.kt)("em",{parentName:"p"},"OpenShift Local is running"),".")),(0,r.kt)("li",{parentName:"ol"},(0,r.kt)("p",{parentName:"li"},"On the ",(0,r.kt)("strong",{parentName:"p"},(0,r.kt)("icon",{icon:"fa-solid fa-cog",size:"lg"}),"Settings > Resources")," screen, your OpenShift Local instance is running."),(0,r.kt)("p",{parentName:"li"},(0,r.kt)("img",{alt:"Developer Sandbox is running",src:n(94650).Z,width:"467",height:"182"}))),(0,r.kt)("li",{parentName:"ol"},(0,r.kt)("p",{parentName:"li"},(0,r.kt)("a",{parentName:"p",href:"/docs/kubernetes/viewing-and-selecting-current-kubernete-context"},"Select your OpenShift Local instance the Podman Desktop tray"),".")),(0,r.kt)("li",{parentName:"ol"},(0,r.kt)("p",{parentName:"li"},"Run basic tasks such as:"),(0,r.kt)("ul",{parentName:"li"},(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("a",{parentName:"li",href:"/docs/kubernetes/deploying-a-container-to-kubernetes"},"Deploying a container")),(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("a",{parentName:"li",href:"/docs/kubernetes/deploying-a-pod-to-kubernetes"},"Deploying a pod"))))),(0,r.kt)("h4",{id:"additional-resources"},"Additional resources"),(0,r.kt)("ul",null,(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("a",{parentName:"li",href:"https://github.com/crc-org/crc-extension"},"Red Hat OpenShift Local extension repository"))))}d.isMDXComponent=!0},94650:(e,t,n)=>{n.d(t,{Z:()=>a});const a=n.p+"assets/images/resources-openshift-local-running-1eea98ac12a94cb97437a2e74046ee6a.png"}}]); \ No newline at end of file +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[8176],{35318:(e,t,n)=>{n.d(t,{Zo:()=>c,kt:()=>d});var a=n(27378);function r(e,t,n){return t in e?Object.defineProperty(e,t,{value:n,enumerable:!0,configurable:!0,writable:!0}):e[t]=n,e}function o(e,t){var n=Object.keys(e);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);t&&(a=a.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),n.push.apply(n,a)}return n}function i(e){for(var t=1;t=0||(r[n]=e[n]);return r}(e,t);if(Object.getOwnPropertySymbols){var o=Object.getOwnPropertySymbols(e);for(a=0;a=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(r[n]=e[n])}return r}var s=a.createContext({}),p=function(e){var t=a.useContext(s),n=t;return e&&(n="function"==typeof e?e(t):i(i({},t),e)),n},c=function(e){var t=p(e.components);return a.createElement(s.Provider,{value:t},e.children)},u={inlineCode:"code",wrapper:function(e){var t=e.children;return a.createElement(a.Fragment,{},t)}},m=a.forwardRef((function(e,t){var n=e.components,r=e.mdxType,o=e.originalType,s=e.parentName,c=l(e,["components","mdxType","originalType","parentName"]),m=p(n),d=r,f=m["".concat(s,".").concat(d)]||m[d]||u[d]||o;return n?a.createElement(f,i(i({ref:t},c),{},{components:n})):a.createElement(f,i({ref:t},c))}));function d(e,t){var n=arguments,r=t&&t.mdxType;if("string"==typeof e||r){var o=n.length,i=new Array(o);i[0]=m;var l={};for(var s in t)hasOwnProperty.call(t,s)&&(l[s]=t[s]);l.originalType=e,l.mdxType="string"==typeof e?e:r,i[1]=l;for(var p=2;p{n.d(t,{Z:()=>i});var a=n(27378),r=n(38944);const o="tabItem_wHwb";function i(e){let{children:t,hidden:n,className:i}=e;return a.createElement("div",{role:"tabpanel",className:(0,r.Z)(o,i),hidden:n},t)}},23930:(e,t,n)=>{n.d(t,{Z:()=>O});var a=n(25773),r=n(27378),o=n(38944),i=n(83457),l=n(35331),s=n(30654),p=n(70784),c=n(71819);function u(e){return function(e){return r.Children.map(e,(e=>{if(!e||(0,r.isValidElement)(e)&&function(e){const{props:t}=e;return!!t&&"object"==typeof t&&"value"in t}(e))return e;throw new Error(`Docusaurus error: Bad child <${"string"==typeof e.type?e.type:e.type.name}>: all children of the component should be , and every should have a unique "value" prop.`)}))?.filter(Boolean)??[]}(e).map((e=>{let{props:{value:t,label:n,attributes:a,default:r}}=e;return{value:t,label:n,attributes:a,default:r}}))}function m(e){const{values:t,children:n}=e;return(0,r.useMemo)((()=>{const e=t??u(n);return function(e){const t=(0,p.l)(e,((e,t)=>e.value===t.value));if(t.length>0)throw new Error(`Docusaurus error: Duplicate values "${t.map((e=>e.value)).join(", ")}" found in . Every value needs to be unique.`)}(e),e}),[t,n])}function d(e){let{value:t,tabValues:n}=e;return n.some((e=>e.value===t))}function f(e){let{queryString:t=!1,groupId:n}=e;const a=(0,l.k6)(),o=function(e){let{queryString:t=!1,groupId:n}=e;if("string"==typeof t)return t;if(!1===t)return null;if(!0===t&&!n)throw new Error('Docusaurus error: The component groupId prop is required if queryString=true, because this value is used as the search param name. You can also provide an explicit value such as queryString="my-search-param".');return n??null}({queryString:t,groupId:n});return[(0,s._X)(o),(0,r.useCallback)((e=>{if(!o)return;const t=new URLSearchParams(a.location.search);t.set(o,e),a.replace({...a.location,search:t.toString()})}),[o,a])]}function h(e){const{defaultValue:t,queryString:n=!1,groupId:a}=e,o=m(e),[i,l]=(0,r.useState)((()=>function(e){let{defaultValue:t,tabValues:n}=e;if(0===n.length)throw new Error("Docusaurus error: the component requires at least one children component");if(t){if(!d({value:t,tabValues:n}))throw new Error(`Docusaurus error: The has a defaultValue "${t}" but none of its children has the corresponding value. Available values are: ${n.map((e=>e.value)).join(", ")}. If you intend to show no default tab, use defaultValue={null} instead.`);return t}const a=n.find((e=>e.default))??n[0];if(!a)throw new Error("Unexpected error: 0 tabValues");return a.value}({defaultValue:t,tabValues:o}))),[s,p]=f({queryString:n,groupId:a}),[u,h]=function(e){let{groupId:t}=e;const n=function(e){return e?`docusaurus.tab.${e}`:null}(t),[a,o]=(0,c.Nk)(n);return[a,(0,r.useCallback)((e=>{n&&o.set(e)}),[n,o])]}({groupId:a}),k=(()=>{const e=s??u;return d({value:e,tabValues:o})?e:null})();(0,r.useLayoutEffect)((()=>{k&&l(k)}),[k]);return{selectedValue:i,selectValue:(0,r.useCallback)((e=>{if(!d({value:e,tabValues:o}))throw new Error(`Can't select invalid tab value=${e}`);l(e),p(e),h(e)}),[p,h,o]),tabValues:o}}var k=n(76457);const g="tabList_J5MA",b="tabItem_l0OV";function N(e){let{className:t,block:n,selectedValue:l,selectValue:s,tabValues:p}=e;const c=[],{blockElementScrollPositionUntilNextRender:u}=(0,i.o5)(),m=e=>{const t=e.currentTarget,n=c.indexOf(t),a=p[n].value;a!==l&&(u(t),s(a))},d=e=>{let t=null;switch(e.key){case"Enter":m(e);break;case"ArrowRight":{const n=c.indexOf(e.currentTarget)+1;t=c[n]??c[0];break}case"ArrowLeft":{const n=c.indexOf(e.currentTarget)-1;t=c[n]??c[c.length-1];break}}t?.focus()};return r.createElement("ul",{role:"tablist","aria-orientation":"horizontal",className:(0,o.Z)("tabs",{"tabs--block":n},t)},p.map((e=>{let{value:t,label:n,attributes:i}=e;return r.createElement("li",(0,a.Z)({role:"tab",tabIndex:l===t?0:-1,"aria-selected":l===t,key:t,ref:e=>c.push(e),onKeyDown:d,onClick:m},i,{className:(0,o.Z)("tabs__item",b,i?.className,{"tabs__item--active":l===t})}),n??t)})))}function y(e){let{lazy:t,children:n,selectedValue:a}=e;const o=(Array.isArray(n)?n:[n]).filter(Boolean);if(t){const e=o.find((e=>e.props.value===a));return e?(0,r.cloneElement)(e,{className:"margin-top--md"}):null}return r.createElement("div",{className:"margin-top--md"},o.map(((e,t)=>(0,r.cloneElement)(e,{key:t,hidden:e.props.value!==a}))))}function v(e){const t=h(e);return r.createElement("div",{className:(0,o.Z)("tabs-container",g)},r.createElement(N,(0,a.Z)({},e,t)),r.createElement(y,(0,a.Z)({},e,t)))}function O(e){const t=(0,k.Z)();return r.createElement(v,(0,a.Z)({key:String(t)},e))}},20797:(e,t,n)=>{n.r(t),n.d(t,{assets:()=>c,contentTitle:()=>s,default:()=>h,frontMatter:()=>l,metadata:()=>p,toc:()=>u});var a=n(25773),r=(n(27378),n(35318)),o=n(23930),i=n(39798);const l={title:"OpenShift Local",description:"Creating an OpenShift Local instance",keywords:["podman desktop","podman","containers","pods","migrating","kubernetes","openshift"],tags:["migrating-to-kubernetes","openshift"]},s="Creating an OpenShift Local instance",p={unversionedId:"openshift/openshift-local/index",id:"openshift/openshift-local/index",title:"OpenShift Local",description:"Creating an OpenShift Local instance",source:"@site/docs/openshift/openshift-local/index.md",sourceDirName:"openshift/openshift-local",slug:"/openshift/openshift-local/",permalink:"/docs/openshift/openshift-local/",draft:!1,editUrl:"https://github.com/containers/podman-desktop/tree/main/website/docs/openshift/openshift-local/index.md",tags:[{label:"migrating-to-kubernetes",permalink:"/docs/tags/migrating-to-kubernetes"},{label:"openshift",permalink:"/docs/tags/openshift"}],version:"current",frontMatter:{title:"OpenShift Local",description:"Creating an OpenShift Local instance",keywords:["podman desktop","podman","containers","pods","migrating","kubernetes","openshift"],tags:["migrating-to-kubernetes","openshift"]},sidebar:"mySidebar",previous:{title:"Developer Sandbox",permalink:"/docs/openshift/developer-sandbox/"},next:{title:"Writing extensions",permalink:"/docs/extensions/"}},c={},u=[{value:"Prerequisites",id:"prerequisites",level:4},{value:"Procedure",id:"procedure",level:4},{value:"Verification",id:"verification",level:4},{value:"Additional resources",id:"additional-resources",level:4}],m=(d="Icon",function(e){return console.warn("Component "+d+" was not imported, exported, or provided by MDXProvider as global scope"),(0,r.kt)("div",e)});var d;const f={toc:u};function h(e){let{components:t,...l}=e;return(0,r.kt)("wrapper",(0,a.Z)({},f,l,{components:t,mdxType:"MDXLayout"}),(0,r.kt)("h1",{id:"creating-an-openshift-local-instance"},"Creating an OpenShift Local instance"),(0,r.kt)("p",null,(0,r.kt)("a",{parentName:"p",href:"https://developers.redhat.com/products/openshift-local/overview"},"Red Hat OpenShift Local")," manages a minimal OpenShift or MicroShift cluster on your workstation for local development and testing."),(0,r.kt)("p",null,"With Podman Desktop and the OpenShift Local extension, you can manage your OpenShift Local instances."),(0,r.kt)("h4",{id:"prerequisites"},"Prerequisites"),(0,r.kt)("ul",null,(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("a",{parentName:"li",href:"https://developers.redhat.com/register"},"Register a Red Hat account"),".")),(0,r.kt)("h4",{id:"procedure"},"Procedure"),(0,r.kt)("ol",null,(0,r.kt)("li",{parentName:"ol"},(0,r.kt)("p",{parentName:"li"},"Install the ",(0,r.kt)("em",{parentName:"p"},"OpenShift Local")," extension: on to ",(0,r.kt)("strong",{parentName:"p"},"Dashboard"),", click ",(0,r.kt)("strong",{parentName:"p"},"OpenShift Local ",(0,r.kt)(m,{icon:"fa-solid fa-download",size:"lg",mdxType:"Icon"})),".")),(0,r.kt)("li",{parentName:"ol"},(0,r.kt)("p",{parentName:"li"},"Install the OpenShift Local binaries, when on the ",(0,r.kt)("strong",{parentName:"p"},"Dashboard"),", you see ",(0,r.kt)("em",{parentName:"p"},"Podman Desktop was not able to find an installation of OpenShift Local"),"."),(0,r.kt)(o.Z,{groupId:"operating-systems",mdxType:"Tabs"},(0,r.kt)(i.Z,{value:"win",label:"Windows",mdxType:"TabItem"},(0,r.kt)("ol",{parentName:"li"},(0,r.kt)("li",{parentName:"ol"},"In the ",(0,r.kt)("strong",{parentName:"li"},"OpenShift Local")," tile, click ",(0,r.kt)("strong",{parentName:"li"},(0,r.kt)(m,{icon:"fa-solid fa-rocket",size:"lg",mdxType:"Icon"})," Install"),"."),(0,r.kt)("li",{parentName:"ol"},"When prerequisites are missing, follow the instructions."),(0,r.kt)("li",{parentName:"ol"},"In the ",(0,r.kt)("strong",{parentName:"li"},"Red Hat OpenShift Local")," screen, click ",(0,r.kt)("strong",{parentName:"li"},"Yes")," to start the installation."),(0,r.kt)("li",{parentName:"ol"},"Follow the installation program instructions."),(0,r.kt)("li",{parentName:"ol"},"Reboot to finalize system changes."))),(0,r.kt)(i.Z,{value:"mac",label:"macOS",mdxType:"TabItem"},(0,r.kt)("ol",{parentName:"li"},(0,r.kt)("li",{parentName:"ol"},"In the ",(0,r.kt)("strong",{parentName:"li"},"OpenShift Local")," tile, click ",(0,r.kt)("strong",{parentName:"li"},(0,r.kt)(m,{icon:"fa-solid fa-rocket",size:"lg",mdxType:"Icon"})," Install"),"."),(0,r.kt)("li",{parentName:"ol"},"When prerequisites are missing, follow the instructions."),(0,r.kt)("li",{parentName:"ol"},"In the ",(0,r.kt)("strong",{parentName:"li"},"Red Hat OpenShift Local")," screen, click ",(0,r.kt)("strong",{parentName:"li"},"Yes")," to start the installation."),(0,r.kt)("li",{parentName:"ol"},"Follow the installation program instructions."),(0,r.kt)("li",{parentName:"ol"},"Reboot to finalize system changes."))),(0,r.kt)(i.Z,{value:"linux",label:"Linux",mdxType:"TabItem"},(0,r.kt)("ol",{parentName:"li"},(0,r.kt)("li",{parentName:"ol"},(0,r.kt)("p",{parentName:"li"},"Go to the ",(0,r.kt)("a",{parentName:"p",href:"https://console.redhat.com/openshift/create/local"},"Red Hat OpenShift local download page"),".")),(0,r.kt)("li",{parentName:"ol"},(0,r.kt)("p",{parentName:"li"},"Select your platform.")),(0,r.kt)("li",{parentName:"ol"},(0,r.kt)("p",{parentName:"li"},"Click ",(0,r.kt)("strong",{parentName:"p"},"Download OpenShift Local"),".")),(0,r.kt)("li",{parentName:"ol"},(0,r.kt)("p",{parentName:"li"},"Extract the archive.")),(0,r.kt)("li",{parentName:"ol"},(0,r.kt)("p",{parentName:"li"},"Copy the ",(0,r.kt)("inlineCode",{parentName:"p"},"crc")," binary to a directory in your",(0,r.kt)("inlineCode",{parentName:"p"},"$PATH"),", such as ",(0,r.kt)("inlineCode",{parentName:"p"},"/usr/local/bin"),".")),(0,r.kt)("li",{parentName:"ol"},(0,r.kt)("p",{parentName:"li"},"To configure your system, run the command:"),(0,r.kt)("pre",{parentName:"li"},(0,r.kt)("code",{parentName:"pre",className:"language-shell-session"},"$ crc setup\n"))),(0,r.kt)("li",{parentName:"ol"},(0,r.kt)("p",{parentName:"li"},"Exit and restart Podman Desktop.")))))),(0,r.kt)("li",{parentName:"ol"},(0,r.kt)("p",{parentName:"li"},"(Optionally) Review the extension settings in ",(0,r.kt)("strong",{parentName:"p"},(0,r.kt)(m,{icon:"fa-solid fa-cog",size:"lg",mdxType:"Icon"})," Settings > Preferences > Extension: Red Hat OpenShift Local"),".")),(0,r.kt)("li",{parentName:"ol"},(0,r.kt)("p",{parentName:"li"},"On the ",(0,r.kt)("strong",{parentName:"p"},"Dashboard"),", click ",(0,r.kt)("strong",{parentName:"p"},"Initialize and start"),"."),(0,r.kt)("ol",{parentName:"li"},(0,r.kt)("li",{parentName:"ol"},(0,r.kt)("p",{parentName:"li"},"Select your OpenShift Local Virtual machine preset, if not set in ",(0,r.kt)("strong",{parentName:"p"},(0,r.kt)(m,{icon:"fa-solid fa-cog",size:"lg",mdxType:"Icon"})," Settings > Preferences > Extension: Red Hat OpenShift Local > Preset"),"."),(0,r.kt)("ul",{parentName:"li"},(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("em",{parentName:"li"},"MicroShift")," (experimental): provides a lightweight and optimized environment with a limited set of services."),(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("em",{parentName:"li"},"OpenShift"),": provides a single node OpenShift cluster with a fuller set of services, including a web console (requires more resources)."))),(0,r.kt)("li",{parentName:"ol"},(0,r.kt)("p",{parentName:"li"},"Provide a pull secret, required to pull container images from the registry:"),(0,r.kt)("ol",{parentName:"li"},(0,r.kt)("li",{parentName:"ol"},"Open the ",(0,r.kt)("a",{parentName:"li",href:"https://cloud.redhat.com/openshift/create/local"},"Red Hat OpenShift Local download page"),"."),(0,r.kt)("li",{parentName:"ol"},"Click ",(0,r.kt)("strong",{parentName:"li"},"Copy pull secret"),"."),(0,r.kt)("li",{parentName:"ol"},"Get back to Podman Desktop."),(0,r.kt)("li",{parentName:"ol"},"Paste the pull secret, and press ",(0,r.kt)("inlineCode",{parentName:"li"},"Enter"),".")))))),(0,r.kt)("h4",{id:"verification"},"Verification"),(0,r.kt)("ol",null,(0,r.kt)("li",{parentName:"ol"},(0,r.kt)("p",{parentName:"li"},"On the ",(0,r.kt)("strong",{parentName:"p"},"Dashboard")," screen, ",(0,r.kt)("em",{parentName:"p"},"OpenShift Local is running"),".")),(0,r.kt)("li",{parentName:"ol"},(0,r.kt)("p",{parentName:"li"},"On the ",(0,r.kt)("strong",{parentName:"p"},(0,r.kt)(m,{icon:"fa-solid fa-cog",size:"lg",mdxType:"Icon"}),"Settings > Resources")," screen, your OpenShift Local instance is running."),(0,r.kt)("p",{parentName:"li"},(0,r.kt)("img",{alt:"Developer Sandbox is running",src:n(94650).Z,width:"467",height:"182"}))),(0,r.kt)("li",{parentName:"ol"},(0,r.kt)("p",{parentName:"li"},(0,r.kt)("a",{parentName:"p",href:"/docs/kubernetes/viewing-and-selecting-current-kubernete-context"},"Select your OpenShift Local instance the Podman Desktop tray"),".")),(0,r.kt)("li",{parentName:"ol"},(0,r.kt)("p",{parentName:"li"},"Run basic tasks such as:"),(0,r.kt)("ul",{parentName:"li"},(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("a",{parentName:"li",href:"/docs/kubernetes/deploying-a-container-to-kubernetes"},"Deploying a container")),(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("a",{parentName:"li",href:"/docs/kubernetes/deploying-a-pod-to-kubernetes"},"Deploying a pod"))))),(0,r.kt)("h4",{id:"additional-resources"},"Additional resources"),(0,r.kt)("ul",null,(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("a",{parentName:"li",href:"https://github.com/crc-org/crc-extension"},"Red Hat OpenShift Local extension repository"))))}h.isMDXComponent=!0},94650:(e,t,n)=>{n.d(t,{Z:()=>a});const a=n.p+"assets/images/resources-openshift-local-running-1eea98ac12a94cb97437a2e74046ee6a.png"}}]); \ No newline at end of file diff --git a/assets/js/5df556a2.045cc138.js b/assets/js/5df556a2.045cc138.js deleted file mode 100644 index f238a230786..00000000000 --- a/assets/js/5df556a2.045cc138.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[3870],{63976:(e,t,a)=>{a.r(t),a.d(t,{assets:()=>r,contentTitle:()=>l,default:()=>h,frontMatter:()=>i,metadata:()=>p,toc:()=>d});var n=a(25773),o=(a(27378),a(35318)),s=a(92975);const i={title:"Release Notes - Podman Desktop 0.15",description:"Podman Desktop 0.15 has been released!",slug:"podman-desktop-release-0.15",authors:["deboer"],tags:["podman-desktop","release","kubernetes","kind"],hide_table_of_contents:!1,image:"/img/blog/podman-desktop-release-0.15.webp"},l=void 0,p={permalink:"/blog/podman-desktop-release-0.15",source:"@site/blog/2023-05-02-release-0.15.md",title:"Release Notes - Podman Desktop 0.15",description:"Podman Desktop 0.15 has been released!",date:"2023-05-02T00:00:00.000Z",formattedDate:"May 2, 2023",tags:[{label:"podman-desktop",permalink:"/blog/tags/podman-desktop"},{label:"release",permalink:"/blog/tags/release"},{label:"kubernetes",permalink:"/blog/tags/kubernetes"},{label:"kind",permalink:"/blog/tags/kind"}],readingTime:3.685,hasTruncateMarker:!0,authors:[{name:"Tim deBoer",title:"Architect",url:"https://github.com/deboer-tim",imageURL:"https://github.com/deboer-tim.png",key:"deboer"}],frontMatter:{title:"Release Notes - Podman Desktop 0.15",description:"Podman Desktop 0.15 has been released!",slug:"podman-desktop-release-0.15",authors:["deboer"],tags:["podman-desktop","release","kubernetes","kind"],hide_table_of_contents:!1,image:"/img/blog/podman-desktop-release-0.15.webp"},prevItem:{title:"Release Notes - Podman Desktop 1.0",permalink:"/blog/podman-desktop-release-1.0"},nextItem:{title:"Setting up and running a Kubernetes cluster locally with Podman Desktop",permalink:"/blog/running-a-local-kubernetes-cluster-with-podman-desktop"}},r={authorsImageUrls:[void 0]},d=[{value:"Release Details",id:"release-details",level:2},{value:"Update to Podman v4.5.O",id:"update-to-podman-v45o",level:3},{value:"Kind Ingress",id:"kind-ingress",level:3},{value:"Podliness: Ability to Choose External Ports when Podifying Containers",id:"podliness-ability-to-choose-external-ports-when-podifying-containers",level:3},{value:"Cleanliness: New Navigation Bar, Dialogs, and Palette",id:"cleanliness-new-navigation-bar-dialogs-and-palette",level:3},{value:"New Navgation Bar",id:"new-navgation-bar",level:4},{value:"Updated Dialogs",id:"updated-dialogs",level:4},{value:"Colors",id:"colors",level:4},{value:"Other UI and UX Improvements",id:"other-ui-and-ux-improvements",level:3},{value:"Markdown Support for Extensions",id:"markdown-support-for-extensions",level:4},{value:"Other Notable Enhancements",id:"other-notable-enhancements",level:2},{value:"Notable Bug Fixes",id:"notable-bug-fixes",level:2},{value:"Final notes",id:"final-notes",level:2}],m={toc:d};function h(e){let{components:t,...i}=e;return(0,o.kt)("wrapper",(0,n.Z)({},m,i,{components:t,mdxType:"MDXLayout"}),(0,o.kt)("p",null,"Podman Desktop 0.15 - Cleanliness is next to Podliness!"),(0,o.kt)("p",null,"It has only been two weeks since our last release, but we really wanted to complete a few scenarios,\nfix a few bugs, and show off several design updates and UI improvements that we have been working on."),(0,o.kt)("ul",null,(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("strong",{parentName:"li"},"Podman Version"),": Podman 4.5 now included in Windows and Mac installers."),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("strong",{parentName:"li"},"Kind Ingress"),": Creating an ingress to expose services outside the Kind cluster."),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("strong",{parentName:"li"},"Podliness"),": Ability to choose external ports when podifying containers."),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("strong",{parentName:"li"},"Cleanliness"),": New navigation bar, dialog, and palette update."),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("strong",{parentName:"li"},"UX and UI Improvements"),": Markdown support for extensions.")),(0,o.kt)("p",null,"Podman Desktop 0.15 is now available. ",(0,o.kt)("a",{parentName:"p",href:"/downloads"},"Click here to download it"),"!"),(0,o.kt)("p",null,(0,o.kt)("img",{alt:"Podman-desktop-0-15-hero",src:a(61827).Z,width:"1920",height:"1432"})),(0,o.kt)("hr",null),(0,o.kt)("h2",{id:"release-details"},"Release Details"),(0,o.kt)("h3",{id:"update-to-podman-v45o"},"Update to Podman v4.5.O"),(0,o.kt)("p",null,"Podman Desktop 0.15 embeds ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman/releases/tag/v4.5.0"},"Podman 4.5.0")," in\nWindows and macOS installers ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/issues/2115"},"#2115"),"."),(0,o.kt)("h3",{id:"kind-ingress"},"Kind Ingress"),(0,o.kt)("p",null,"Wait a minute, didn't we enable this last release? Well yes, last time we did add support for installing\nthe Contour ingress controller on Kind ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/issues/1675"},"#1675"),",\nbut you still couldn't access your containers without the corresponding ingress."),(0,o.kt)("p",null,"This release adds a simple checkbox you can use when deploying to Kind to create an ingress and\nmake your service accessible ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/issues/1322"},"#1322"),"."),(0,o.kt)(s.Z,{playing:!0,controls:!0,url:"https://user-images.githubusercontent.com/6422176/232894496-cbaea036-a14c-46c6-bfa3-bacca629a161.mov",width:"100%",height:"100%",mdxType:"ReactPlayer"}),(0,o.kt)("h3",{id:"podliness-ability-to-choose-external-ports-when-podifying-containers"},"Podliness: Ability to Choose External Ports when Podifying Containers"),(0,o.kt)("p",null,"When you create a pod from of a set of containers (Podifying!), you probably don't want to expose every\nsingle port from every container to the world. With an updated panel you can now see which ports each container\nexposes, pick which should remain visible outside the pod, and which are for internal use\n",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/2232"},"#2232"),"."),(0,o.kt)("p",null,(0,o.kt)("img",{parentName:"p",src:"https://user-images.githubusercontent.com/49404737/234527674-ed14f52c-8f66-445f-8038-c8135bb61136.gif",alt:"Podify page"})),(0,o.kt)("h3",{id:"cleanliness-new-navigation-bar-dialogs-and-palette"},"Cleanliness: New Navigation Bar, Dialogs, and Palette"),(0,o.kt)("p",null,"It was time to catch up on some design ideas and do some UI cleanup!"),(0,o.kt)("h4",{id:"new-navgation-bar"},"New Navgation Bar"),(0,o.kt)("p",null,"The navigation bar is now always fixed on the left size, without labels. This opens up more space\nfor the content on each page, and is easier to jump in and out of ",(0,o.kt)("strong",{parentName:"p"},(0,o.kt)("icon",{icon:"fa-solid fa-cog",size:"lg"})," Settings"),".\n",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/issues/2167"},"#2167")),(0,o.kt)("p",null,(0,o.kt)("img",{alt:"Navigation bar",src:a(39245).Z,width:"252",height:"606"})),(0,o.kt)("h4",{id:"updated-dialogs"},"Updated Dialogs"),(0,o.kt)("p",null,"We wanted messages and dialog boxes to feel a bit more integrated, so we have a new message box\n",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/1808"},"#1808")," and use it for all dialogs opened by\nextensions, pruning containers/pods/images/volumes ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/2138"},"#2138"),",\nand updating Podman Desktop itself ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/2249"},"#2249"),"."),(0,o.kt)("p",null,(0,o.kt)("img",{alt:"Dialog",src:a(11507).Z,width:"1114",height:"454"})),(0,o.kt)("h4",{id:"colors"},"Colors"),(0,o.kt)("p",null,"We spent some time tweaking colors and closing on our final palette\n",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/2199"},"#2199"),", updating the colors in the terminal & detail page\n",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/2222"},"#2222"),", tweaking the navigation and main page colors\n",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/2223"},"#2223"),",\nand improving the look of forms ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/issues/2156"},"#2156"),"."),(0,o.kt)("p",null,"We're not done yet, but hopefully you will notice a more polished, consistent, good-looking application!"),(0,o.kt)("h3",{id:"other-ui-and-ux-improvements"},"Other UI and UX Improvements"),(0,o.kt)("h4",{id:"markdown-support-for-extensions"},"Markdown Support for Extensions"),(0,o.kt)("p",null,"We added a new component to display markdown ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/2219"},"#2219")," and\nenabled it in preferences ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/2253"},"#2253"),", and\nprovider properties/creation pages ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/issues/2152"},"#2152"),".\nWe can now embed links and other formatting in preferences, and extensions can use them in many places, for example:"),(0,o.kt)("p",null,(0,o.kt)("img",{alt:"Markdown",src:a(81313).Z,width:"1620",height:"264"})),(0,o.kt)("hr",null),(0,o.kt)("h2",{id:"other-notable-enhancements"},"Other Notable Enhancements"),(0,o.kt)("ul",null,(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},"We know which ",(0,o.kt)("strong",{parentName:"p"},"Settings")," page is used the most often, so now it's the default: ",(0,o.kt)("strong",{parentName:"p"},(0,o.kt)("icon",{icon:"fa-solid fa-cog",size:"lg"})," Settings > Resources")," ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/issues/2105"},"#2105"),".")),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},"Extensions can now use the Tasks API to let long running tasks continue in the background ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/issues/2019"},"#2019")," and the existing withProgress API also uses the task manager now\n",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/2187"},"#2187"),"."))),(0,o.kt)("p",null,(0,o.kt)("img",{parentName:"p",src:"https://user-images.githubusercontent.com/695993/233560830-85cfa685-5dcd-4efa-9fae-730a8a9eef3b.gif",alt:"Task API"})),(0,o.kt)("ul",null,(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},"Images are now sorted by age ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/2311"},"#2311"),".")),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},"When you start/stop a container or pod, the button is now animated instead of having an separate spinner\n",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/issues/2101"},"#2101"),".")),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},"The ",(0,o.kt)("strong",{parentName:"p"},(0,o.kt)("icon",{icon:"fa-solid fa-cog",size:"lg"})," Settings > Preferences")," page now has a search bar ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/2128"},"#2128"),"."))),(0,o.kt)("p",null,(0,o.kt)("img",{alt:"Search preferences",src:a(26657).Z,width:"1162",height:"394"})),(0,o.kt)("ul",null,(0,o.kt)("li",{parentName:"ul"},"The Help page has been updated ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/issues/431"},"#431"),".")),(0,o.kt)("p",null,(0,o.kt)("img",{alt:"Updated Help",src:a(11227).Z,width:"1386",height:"1222"})),(0,o.kt)("hr",null),(0,o.kt)("h2",{id:"notable-bug-fixes"},"Notable Bug Fixes"),(0,o.kt)("ul",null,(0,o.kt)("li",{parentName:"ul"},"There was no way to see log or outcome if you leave the Kind cluster creation page ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/issues/2079"},"#2079"),"."),(0,o.kt)("li",{parentName:"ul"},"Kind image load doesn't show a notification ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/issues/2225"},"#2225"),"."),(0,o.kt)("li",{parentName:"ul"},"Fix odd selection in ",(0,o.kt)("strong",{parentName:"li"},(0,o.kt)("icon",{icon:"fa-solid fa-cog",size:"lg"})," Settings > Extensions")," ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/issues/2130"},"#2130"),"."),(0,o.kt)("li",{parentName:"ul"},"Menus are now cleaned up properly when extensions are stopped ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/2188"},"#2188"),"."),(0,o.kt)("li",{parentName:"ul"},"Kind clusters are now cleaned up when Podman machine is stopped ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/2306"},"#2306"),".")),(0,o.kt)("hr",null),(0,o.kt)("h2",{id:"final-notes"},"Final notes"),(0,o.kt)("p",null,"The complete list of issues fixed in this release is available ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/issues?q=is%3Aclosed+milestone%3A0.15.0"},"here"),"."),(0,o.kt)("p",null,"Get the latest release from the ",(0,o.kt)("a",{parentName:"p",href:"/downloads"},"Downloads")," section of the website and boost your development journey with Podman Desktop. Additionally, visit the ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop"},"GitHub repository")," and see how you can help us make Podman Desktop better."))}h.isMDXComponent=!0},11507:(e,t,a)=>{a.d(t,{Z:()=>n});const n=a.p+"assets/images/dialog-a7641617566984fb155ab6060378c0e7.png"},11227:(e,t,a)=>{a.d(t,{Z:()=>n});const n=a.p+"assets/images/help-61063667146d82cf967c0905ee7fc9b3.png"},81313:(e,t,a)=>{a.d(t,{Z:()=>n});const n=a.p+"assets/images/markdown-62e7791bc0cf89938d344d6bdacfb3a0.png"},39245:(e,t,a)=>{a.d(t,{Z:()=>n});const n=a.p+"assets/images/navigation-a8912eb003f2c50ed0436cc5cb07be77.png"},61827:(e,t,a)=>{a.d(t,{Z:()=>n});const n=a.p+"assets/images/podman-desktop-release-0.15-89cd5f136ad85c15bc5b4d16a919140a.webp"},26657:(e,t,a)=>{a.d(t,{Z:()=>n});const n=a.p+"assets/images/prefs-8b7886c5b18178c010e3d4033f25fe5c.png"}}]); \ No newline at end of file diff --git a/assets/js/5df556a2.74568e5d.js b/assets/js/5df556a2.74568e5d.js new file mode 100644 index 00000000000..acea88e2aeb --- /dev/null +++ b/assets/js/5df556a2.74568e5d.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[3870],{63976:(e,t,a)=>{a.r(t),a.d(t,{assets:()=>r,contentTitle:()=>l,default:()=>c,frontMatter:()=>i,metadata:()=>p,toc:()=>d});var n=a(25773),o=(a(27378),a(35318)),s=a(92975);const i={title:"Release Notes - Podman Desktop 0.15",description:"Podman Desktop 0.15 has been released!",slug:"podman-desktop-release-0.15",authors:["deboer"],tags:["podman-desktop","release","kubernetes","kind"],hide_table_of_contents:!1,image:"/img/blog/podman-desktop-release-0.15.webp"},l=void 0,p={permalink:"/blog/podman-desktop-release-0.15",source:"@site/blog/2023-05-02-release-0.15.md",title:"Release Notes - Podman Desktop 0.15",description:"Podman Desktop 0.15 has been released!",date:"2023-05-02T00:00:00.000Z",formattedDate:"May 2, 2023",tags:[{label:"podman-desktop",permalink:"/blog/tags/podman-desktop"},{label:"release",permalink:"/blog/tags/release"},{label:"kubernetes",permalink:"/blog/tags/kubernetes"},{label:"kind",permalink:"/blog/tags/kind"}],readingTime:3.685,hasTruncateMarker:!0,authors:[{name:"Tim deBoer",title:"Architect",url:"https://github.com/deboer-tim",imageURL:"https://github.com/deboer-tim.png",key:"deboer"}],frontMatter:{title:"Release Notes - Podman Desktop 0.15",description:"Podman Desktop 0.15 has been released!",slug:"podman-desktop-release-0.15",authors:["deboer"],tags:["podman-desktop","release","kubernetes","kind"],hide_table_of_contents:!1,image:"/img/blog/podman-desktop-release-0.15.webp"},prevItem:{title:"Release Notes - Podman Desktop 1.0",permalink:"/blog/podman-desktop-release-1.0"},nextItem:{title:"Setting up and running a Kubernetes cluster locally with Podman Desktop",permalink:"/blog/running-a-local-kubernetes-cluster-with-podman-desktop"}},r={authorsImageUrls:[void 0]},d=[{value:"Release Details",id:"release-details",level:2},{value:"Update to Podman v4.5.O",id:"update-to-podman-v45o",level:3},{value:"Kind Ingress",id:"kind-ingress",level:3},{value:"Podliness: Ability to Choose External Ports when Podifying Containers",id:"podliness-ability-to-choose-external-ports-when-podifying-containers",level:3},{value:"Cleanliness: New Navigation Bar, Dialogs, and Palette",id:"cleanliness-new-navigation-bar-dialogs-and-palette",level:3},{value:"New Navgation Bar",id:"new-navgation-bar",level:4},{value:"Updated Dialogs",id:"updated-dialogs",level:4},{value:"Colors",id:"colors",level:4},{value:"Other UI and UX Improvements",id:"other-ui-and-ux-improvements",level:3},{value:"Markdown Support for Extensions",id:"markdown-support-for-extensions",level:4},{value:"Other Notable Enhancements",id:"other-notable-enhancements",level:2},{value:"Notable Bug Fixes",id:"notable-bug-fixes",level:2},{value:"Final notes",id:"final-notes",level:2}],m=(h="Icon",function(e){return console.warn("Component "+h+" was not imported, exported, or provided by MDXProvider as global scope"),(0,o.kt)("div",e)});var h;const u={toc:d};function c(e){let{components:t,...i}=e;return(0,o.kt)("wrapper",(0,n.Z)({},u,i,{components:t,mdxType:"MDXLayout"}),(0,o.kt)("p",null,"Podman Desktop 0.15 - Cleanliness is next to Podliness!"),(0,o.kt)("p",null,"It has only been two weeks since our last release, but we really wanted to complete a few scenarios,\nfix a few bugs, and show off several design updates and UI improvements that we have been working on."),(0,o.kt)("ul",null,(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("strong",{parentName:"li"},"Podman Version"),": Podman 4.5 now included in Windows and Mac installers."),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("strong",{parentName:"li"},"Kind Ingress"),": Creating an ingress to expose services outside the Kind cluster."),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("strong",{parentName:"li"},"Podliness"),": Ability to choose external ports when podifying containers."),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("strong",{parentName:"li"},"Cleanliness"),": New navigation bar, dialog, and palette update."),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("strong",{parentName:"li"},"UX and UI Improvements"),": Markdown support for extensions.")),(0,o.kt)("p",null,"Podman Desktop 0.15 is now available. ",(0,o.kt)("a",{parentName:"p",href:"/downloads"},"Click here to download it"),"!"),(0,o.kt)("p",null,(0,o.kt)("img",{alt:"Podman-desktop-0-15-hero",src:a(61827).Z,width:"1920",height:"1432"})),(0,o.kt)("hr",null),(0,o.kt)("h2",{id:"release-details"},"Release Details"),(0,o.kt)("h3",{id:"update-to-podman-v45o"},"Update to Podman v4.5.O"),(0,o.kt)("p",null,"Podman Desktop 0.15 embeds ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman/releases/tag/v4.5.0"},"Podman 4.5.0")," in\nWindows and macOS installers ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/issues/2115"},"#2115"),"."),(0,o.kt)("h3",{id:"kind-ingress"},"Kind Ingress"),(0,o.kt)("p",null,"Wait a minute, didn't we enable this last release? Well yes, last time we did add support for installing\nthe Contour ingress controller on Kind ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/issues/1675"},"#1675"),",\nbut you still couldn't access your containers without the corresponding ingress."),(0,o.kt)("p",null,"This release adds a simple checkbox you can use when deploying to Kind to create an ingress and\nmake your service accessible ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/issues/1322"},"#1322"),"."),(0,o.kt)(s.Z,{playing:!0,controls:!0,url:"https://user-images.githubusercontent.com/6422176/232894496-cbaea036-a14c-46c6-bfa3-bacca629a161.mov",width:"100%",height:"100%",mdxType:"ReactPlayer"}),(0,o.kt)("h3",{id:"podliness-ability-to-choose-external-ports-when-podifying-containers"},"Podliness: Ability to Choose External Ports when Podifying Containers"),(0,o.kt)("p",null,"When you create a pod from of a set of containers (Podifying!), you probably don't want to expose every\nsingle port from every container to the world. With an updated panel you can now see which ports each container\nexposes, pick which should remain visible outside the pod, and which are for internal use\n",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/2232"},"#2232"),"."),(0,o.kt)("p",null,(0,o.kt)("img",{parentName:"p",src:"https://user-images.githubusercontent.com/49404737/234527674-ed14f52c-8f66-445f-8038-c8135bb61136.gif",alt:"Podify page"})),(0,o.kt)("h3",{id:"cleanliness-new-navigation-bar-dialogs-and-palette"},"Cleanliness: New Navigation Bar, Dialogs, and Palette"),(0,o.kt)("p",null,"It was time to catch up on some design ideas and do some UI cleanup!"),(0,o.kt)("h4",{id:"new-navgation-bar"},"New Navgation Bar"),(0,o.kt)("p",null,"The navigation bar is now always fixed on the left size, without labels. This opens up more space\nfor the content on each page, and is easier to jump in and out of ",(0,o.kt)("strong",{parentName:"p"},(0,o.kt)(m,{icon:"fa-solid fa-cog",size:"lg",mdxType:"Icon"})," Settings"),".\n",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/issues/2167"},"#2167")),(0,o.kt)("p",null,(0,o.kt)("img",{alt:"Navigation bar",src:a(39245).Z,width:"252",height:"606"})),(0,o.kt)("h4",{id:"updated-dialogs"},"Updated Dialogs"),(0,o.kt)("p",null,"We wanted messages and dialog boxes to feel a bit more integrated, so we have a new message box\n",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/1808"},"#1808")," and use it for all dialogs opened by\nextensions, pruning containers/pods/images/volumes ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/2138"},"#2138"),",\nand updating Podman Desktop itself ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/2249"},"#2249"),"."),(0,o.kt)("p",null,(0,o.kt)("img",{alt:"Dialog",src:a(11507).Z,width:"1114",height:"454"})),(0,o.kt)("h4",{id:"colors"},"Colors"),(0,o.kt)("p",null,"We spent some time tweaking colors and closing on our final palette\n",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/2199"},"#2199"),", updating the colors in the terminal & detail page\n",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/2222"},"#2222"),", tweaking the navigation and main page colors\n",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/2223"},"#2223"),",\nand improving the look of forms ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/issues/2156"},"#2156"),"."),(0,o.kt)("p",null,"We're not done yet, but hopefully you will notice a more polished, consistent, good-looking application!"),(0,o.kt)("h3",{id:"other-ui-and-ux-improvements"},"Other UI and UX Improvements"),(0,o.kt)("h4",{id:"markdown-support-for-extensions"},"Markdown Support for Extensions"),(0,o.kt)("p",null,"We added a new component to display markdown ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/2219"},"#2219")," and\nenabled it in preferences ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/2253"},"#2253"),", and\nprovider properties/creation pages ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/issues/2152"},"#2152"),".\nWe can now embed links and other formatting in preferences, and extensions can use them in many places, for example:"),(0,o.kt)("p",null,(0,o.kt)("img",{alt:"Markdown",src:a(81313).Z,width:"1620",height:"264"})),(0,o.kt)("hr",null),(0,o.kt)("h2",{id:"other-notable-enhancements"},"Other Notable Enhancements"),(0,o.kt)("ul",null,(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},"We know which ",(0,o.kt)("strong",{parentName:"p"},"Settings")," page is used the most often, so now it's the default: ",(0,o.kt)("strong",{parentName:"p"},(0,o.kt)(m,{icon:"fa-solid fa-cog",size:"lg",mdxType:"Icon"})," Settings > Resources")," ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/issues/2105"},"#2105"),".")),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},"Extensions can now use the Tasks API to let long running tasks continue in the background ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/issues/2019"},"#2019")," and the existing withProgress API also uses the task manager now\n",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/2187"},"#2187"),"."))),(0,o.kt)("p",null,(0,o.kt)("img",{parentName:"p",src:"https://user-images.githubusercontent.com/695993/233560830-85cfa685-5dcd-4efa-9fae-730a8a9eef3b.gif",alt:"Task API"})),(0,o.kt)("ul",null,(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},"Images are now sorted by age ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/2311"},"#2311"),".")),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},"When you start/stop a container or pod, the button is now animated instead of having an separate spinner\n",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/issues/2101"},"#2101"),".")),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},"The ",(0,o.kt)("strong",{parentName:"p"},(0,o.kt)(m,{icon:"fa-solid fa-cog",size:"lg",mdxType:"Icon"})," Settings > Preferences")," page now has a search bar ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/2128"},"#2128"),"."))),(0,o.kt)("p",null,(0,o.kt)("img",{alt:"Search preferences",src:a(26657).Z,width:"1162",height:"394"})),(0,o.kt)("ul",null,(0,o.kt)("li",{parentName:"ul"},"The Help page has been updated ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/issues/431"},"#431"),".")),(0,o.kt)("p",null,(0,o.kt)("img",{alt:"Updated Help",src:a(11227).Z,width:"1386",height:"1222"})),(0,o.kt)("hr",null),(0,o.kt)("h2",{id:"notable-bug-fixes"},"Notable Bug Fixes"),(0,o.kt)("ul",null,(0,o.kt)("li",{parentName:"ul"},"There was no way to see log or outcome if you leave the Kind cluster creation page ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/issues/2079"},"#2079"),"."),(0,o.kt)("li",{parentName:"ul"},"Kind image load doesn't show a notification ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/issues/2225"},"#2225"),"."),(0,o.kt)("li",{parentName:"ul"},"Fix odd selection in ",(0,o.kt)("strong",{parentName:"li"},(0,o.kt)(m,{icon:"fa-solid fa-cog",size:"lg",mdxType:"Icon"})," Settings > Extensions")," ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/issues/2130"},"#2130"),"."),(0,o.kt)("li",{parentName:"ul"},"Menus are now cleaned up properly when extensions are stopped ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/2188"},"#2188"),"."),(0,o.kt)("li",{parentName:"ul"},"Kind clusters are now cleaned up when Podman machine is stopped ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/2306"},"#2306"),".")),(0,o.kt)("hr",null),(0,o.kt)("h2",{id:"final-notes"},"Final notes"),(0,o.kt)("p",null,"The complete list of issues fixed in this release is available ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/issues?q=is%3Aclosed+milestone%3A0.15.0"},"here"),"."),(0,o.kt)("p",null,"Get the latest release from the ",(0,o.kt)("a",{parentName:"p",href:"/downloads"},"Downloads")," section of the website and boost your development journey with Podman Desktop. Additionally, visit the ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop"},"GitHub repository")," and see how you can help us make Podman Desktop better."))}c.isMDXComponent=!0},11507:(e,t,a)=>{a.d(t,{Z:()=>n});const n=a.p+"assets/images/dialog-a7641617566984fb155ab6060378c0e7.png"},11227:(e,t,a)=>{a.d(t,{Z:()=>n});const n=a.p+"assets/images/help-61063667146d82cf967c0905ee7fc9b3.png"},81313:(e,t,a)=>{a.d(t,{Z:()=>n});const n=a.p+"assets/images/markdown-62e7791bc0cf89938d344d6bdacfb3a0.png"},39245:(e,t,a)=>{a.d(t,{Z:()=>n});const n=a.p+"assets/images/navigation-a8912eb003f2c50ed0436cc5cb07be77.png"},61827:(e,t,a)=>{a.d(t,{Z:()=>n});const n=a.p+"assets/images/podman-desktop-release-0.15-89cd5f136ad85c15bc5b4d16a919140a.webp"},26657:(e,t,a)=>{a.d(t,{Z:()=>n});const n=a.p+"assets/images/prefs-8b7886c5b18178c010e3d4033f25fe5c.png"}}]); \ No newline at end of file diff --git a/assets/js/64abd3af.769a0da2.js b/assets/js/64abd3af.769a0da2.js new file mode 100644 index 00000000000..0c85fd78f98 --- /dev/null +++ b/assets/js/64abd3af.769a0da2.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[745],{35318:(e,t,n)=>{n.d(t,{Zo:()=>m,kt:()=>c});var a=n(27378);function i(e,t,n){return t in e?Object.defineProperty(e,t,{value:n,enumerable:!0,configurable:!0,writable:!0}):e[t]=n,e}function r(e,t){var n=Object.keys(e);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);t&&(a=a.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),n.push.apply(n,a)}return n}function o(e){for(var t=1;t=0||(i[n]=e[n]);return i}(e,t);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(e);for(a=0;a=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(i[n]=e[n])}return i}var s=a.createContext({}),p=function(e){var t=a.useContext(s),n=t;return e&&(n="function"==typeof e?e(t):o(o({},t),e)),n},m=function(e){var t=p(e.components);return a.createElement(s.Provider,{value:t},e.children)},u={inlineCode:"code",wrapper:function(e){var t=e.children;return a.createElement(a.Fragment,{},t)}},d=a.forwardRef((function(e,t){var n=e.components,i=e.mdxType,r=e.originalType,s=e.parentName,m=l(e,["components","mdxType","originalType","parentName"]),d=p(n),c=i,g=d["".concat(s,".").concat(c)]||d[c]||u[c]||r;return n?a.createElement(g,o(o({ref:t},m),{},{components:n})):a.createElement(g,o({ref:t},m))}));function c(e,t){var n=arguments,i=t&&t.mdxType;if("string"==typeof e||i){var r=n.length,o=new Array(r);o[0]=d;var l={};for(var s in t)hasOwnProperty.call(t,s)&&(l[s]=t[s]);l.originalType=e,l.mdxType="string"==typeof e?e:i,o[1]=l;for(var p=2;p{n.r(t),n.d(t,{assets:()=>s,contentTitle:()=>o,default:()=>c,frontMatter:()=>r,metadata:()=>l,toc:()=>p});var a=n(25773),i=(n(27378),n(35318));const r={sidebar_position:10,title:"Push an image to Kind",description:"Pushing an image to your Kind cluster",keywords:["podman desktop","podman","containers","images","migrating","kubernetes"],tags:["migrating-to-kubernetes","images"]},o="Pushing an image to your local Kind-powered Kubernetes cluster",l={unversionedId:"kind/pushing-an-image-to-kind",id:"kind/pushing-an-image-to-kind",title:"Push an image to Kind",description:"Pushing an image to your Kind cluster",source:"@site/docs/kind/pushing-an-image-to-kind.md",sourceDirName:"kind",slug:"/kind/pushing-an-image-to-kind",permalink:"/docs/kind/pushing-an-image-to-kind",draft:!1,editUrl:"https://github.com/containers/podman-desktop/tree/main/website/docs/kind/pushing-an-image-to-kind.md",tags:[{label:"migrating-to-kubernetes",permalink:"/docs/tags/migrating-to-kubernetes"},{label:"images",permalink:"/docs/tags/images"}],version:"current",sidebarPosition:10,frontMatter:{sidebar_position:10,title:"Push an image to Kind",description:"Pushing an image to your Kind cluster",keywords:["podman desktop","podman","containers","images","migrating","kubernetes"],tags:["migrating-to-kubernetes","images"]},sidebar:"mySidebar",previous:{title:"Building and testing an image",permalink:"/docs/kind/building-an-image-and-testing-it-in-kind"},next:{title:"Minikube",permalink:"/docs/minikube/"}},s={},p=[{value:"Prerequisites",id:"prerequisites",level:4},{value:"Procedure",id:"procedure",level:4},{value:"Verification",id:"verification",level:4}],m=(u="Icon",function(e){return console.warn("Component "+u+" was not imported, exported, or provided by MDXProvider as global scope"),(0,i.kt)("div",e)});var u;const d={toc:p};function c(e){let{components:t,...n}=e;return(0,i.kt)("wrapper",(0,a.Z)({},d,n,{components:t,mdxType:"MDXLayout"}),(0,i.kt)("h1",{id:"pushing-an-image-to-your-local-kind-powered-kubernetes-cluster"},"Pushing an image to your local Kind-powered Kubernetes cluster"),(0,i.kt)("p",null,"With Podman Desktop, you can push an image to your local Kind-powered Kubernetes cluster."),(0,i.kt)("h4",{id:"prerequisites"},"Prerequisites"),(0,i.kt)("ul",null,(0,i.kt)("li",{parentName:"ul"},(0,i.kt)("a",{parentName:"li",href:"/docs/containers"},"You onboarded a container engine"),"."),(0,i.kt)("li",{parentName:"ul"},(0,i.kt)("a",{parentName:"li",href:"/docs/kind"},"You onboarded a Kind cluster"),"."),(0,i.kt)("li",{parentName:"ul"},(0,i.kt)("a",{parentName:"li",href:"/docs/kind/working-with-your-local-kind-cluster"},"You have set your Kubernetes context to your local Kind-powered Kubernetes cluster"),"."),(0,i.kt)("li",{parentName:"ul"},"Your image is available on the ",(0,i.kt)("strong",{parentName:"li"},"Images")," page: ",(0,i.kt)("inlineCode",{parentName:"li"},":"),".")),(0,i.kt)("h4",{id:"procedure"},"Procedure"),(0,i.kt)("ol",null,(0,i.kt)("li",{parentName:"ol"},"Open ",(0,i.kt)("strong",{parentName:"li"},"Podman Desktop dashboard > ",(0,i.kt)(m,{icon:"fa-solid fa-cloud",size:"lg",mdxType:"Icon"})," Images"),"."),(0,i.kt)("li",{parentName:"ol"},(0,i.kt)("strong",{parentName:"li"},(0,i.kt)(m,{icon:"fa-solid fa-search",size:"lg",mdxType:"Icon"})," Search images"),": ",(0,i.kt)("inlineCode",{parentName:"li"},":"),"."),(0,i.kt)("li",{parentName:"ol"},"Click ",(0,i.kt)("strong",{parentName:"li"},(0,i.kt)(m,{icon:"fa-solid fa-ellipsis-v",size:"lg",mdxType:"Icon"})," > ",(0,i.kt)(m,{icon:"fa-solid fa-ellipsis-v",size:"lg",mdxType:"Icon"})," Push image to Kind cluster"),"."),(0,i.kt)("li",{parentName:"ol"},"If you created many Kind clusters, select your Kind cluster from the list.")),(0,i.kt)("h4",{id:"verification"},"Verification"),(0,i.kt)("p",null,"Kind does not enable you to list loaded images.\nTherefore, create a Pod that uses the loaded image."),(0,i.kt)("ol",null,(0,i.kt)("li",{parentName:"ol"},(0,i.kt)("p",{parentName:"li"},"Create a ",(0,i.kt)("inlineCode",{parentName:"p"},"verify_my_image.yaml")," Kubernetes YAML file on your workstation.\nReplace the placeholders:"),(0,i.kt)("ul",{parentName:"li"},(0,i.kt)("li",{parentName:"ul"},"Pod ",(0,i.kt)("inlineCode",{parentName:"li"},"name")," and container ",(0,i.kt)("inlineCode",{parentName:"li"},"name")," value must consist of lower case alphanumeric characters, '-' or '.', and must start and end with an alphanumeric character."),(0,i.kt)("li",{parentName:"ul"},"Container ",(0,i.kt)("inlineCode",{parentName:"li"},"image")," value is the image you pushed.")),(0,i.kt)("pre",{parentName:"li"},(0,i.kt)("code",{parentName:"pre",className:"language-yaml"},"apiVersion: v1\nkind: Pod\nmetadata:\n name: \nspec:\n containers:\n - name: \n image: :\n imagePullPolicy: Never\n"))),(0,i.kt)("li",{parentName:"ol"},(0,i.kt)("p",{parentName:"li"},"Open ",(0,i.kt)("strong",{parentName:"p"},(0,i.kt)(m,{icon:"fa-solid fa-cubes",size:"lg",mdxType:"Icon"})," Pods > Play Kubernetes YAML"),"."),(0,i.kt)("ol",{parentName:"li"},(0,i.kt)("li",{parentName:"ol"},(0,i.kt)("strong",{parentName:"li"},"Kubernetes YAML file"),": select your ",(0,i.kt)("inlineCode",{parentName:"li"},"verify_my_image.yaml")," file."),(0,i.kt)("li",{parentName:"ol"},(0,i.kt)("strong",{parentName:"li"},"Select Runtime"),": ",(0,i.kt)("strong",{parentName:"li"},"Using a Kubernetes cluster"),"."),(0,i.kt)("li",{parentName:"ol"},"Click ",(0,i.kt)("strong",{parentName:"li"},"Play"),"."),(0,i.kt)("li",{parentName:"ol"},"Clik ",(0,i.kt)("strong",{parentName:"li"},"Done")))),(0,i.kt)("li",{parentName:"ol"},(0,i.kt)("p",{parentName:"li"},"Open ",(0,i.kt)("strong",{parentName:"p"},(0,i.kt)(m,{icon:"fa-solid fa-cubes",size:"lg",mdxType:"Icon"})," Pods"),".")),(0,i.kt)("li",{parentName:"ol"},(0,i.kt)("p",{parentName:"li"},(0,i.kt)("strong",{parentName:"p"},(0,i.kt)(m,{icon:"fa-solid fa-search",size:"lg",mdxType:"Icon"})," Search pods"),": ",(0,i.kt)("inlineCode",{parentName:"p"},""),".")),(0,i.kt)("li",{parentName:"ol"},(0,i.kt)("p",{parentName:"li"},"The pod ",(0,i.kt)("strong",{parentName:"p"},"Status")," is ",(0,i.kt)("strong",{parentName:"p"},"Running"),"."))))}c.isMDXComponent=!0}}]); \ No newline at end of file diff --git a/assets/js/64abd3af.d733c2bb.js b/assets/js/64abd3af.d733c2bb.js deleted file mode 100644 index 87cb9437d77..00000000000 --- a/assets/js/64abd3af.d733c2bb.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[745],{35318:(e,t,n)=>{n.d(t,{Zo:()=>m,kt:()=>d});var a=n(27378);function i(e,t,n){return t in e?Object.defineProperty(e,t,{value:n,enumerable:!0,configurable:!0,writable:!0}):e[t]=n,e}function r(e,t){var n=Object.keys(e);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);t&&(a=a.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),n.push.apply(n,a)}return n}function o(e){for(var t=1;t=0||(i[n]=e[n]);return i}(e,t);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(e);for(a=0;a=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(i[n]=e[n])}return i}var s=a.createContext({}),p=function(e){var t=a.useContext(s),n=t;return e&&(n="function"==typeof e?e(t):o(o({},t),e)),n},m=function(e){var t=p(e.components);return a.createElement(s.Provider,{value:t},e.children)},u={inlineCode:"code",wrapper:function(e){var t=e.children;return a.createElement(a.Fragment,{},t)}},c=a.forwardRef((function(e,t){var n=e.components,i=e.mdxType,r=e.originalType,s=e.parentName,m=l(e,["components","mdxType","originalType","parentName"]),c=p(n),d=i,g=c["".concat(s,".").concat(d)]||c[d]||u[d]||r;return n?a.createElement(g,o(o({ref:t},m),{},{components:n})):a.createElement(g,o({ref:t},m))}));function d(e,t){var n=arguments,i=t&&t.mdxType;if("string"==typeof e||i){var r=n.length,o=new Array(r);o[0]=c;var l={};for(var s in t)hasOwnProperty.call(t,s)&&(l[s]=t[s]);l.originalType=e,l.mdxType="string"==typeof e?e:i,o[1]=l;for(var p=2;p{n.r(t),n.d(t,{assets:()=>s,contentTitle:()=>o,default:()=>u,frontMatter:()=>r,metadata:()=>l,toc:()=>p});var a=n(25773),i=(n(27378),n(35318));const r={sidebar_position:10,title:"Push an image to Kind",description:"Pushing an image to your Kind cluster",keywords:["podman desktop","podman","containers","images","migrating","kubernetes"],tags:["migrating-to-kubernetes","images"]},o="Pushing an image to your local Kind-powered Kubernetes cluster",l={unversionedId:"kind/pushing-an-image-to-kind",id:"kind/pushing-an-image-to-kind",title:"Push an image to Kind",description:"Pushing an image to your Kind cluster",source:"@site/docs/kind/pushing-an-image-to-kind.md",sourceDirName:"kind",slug:"/kind/pushing-an-image-to-kind",permalink:"/docs/kind/pushing-an-image-to-kind",draft:!1,editUrl:"https://github.com/containers/podman-desktop/tree/main/website/docs/kind/pushing-an-image-to-kind.md",tags:[{label:"migrating-to-kubernetes",permalink:"/docs/tags/migrating-to-kubernetes"},{label:"images",permalink:"/docs/tags/images"}],version:"current",sidebarPosition:10,frontMatter:{sidebar_position:10,title:"Push an image to Kind",description:"Pushing an image to your Kind cluster",keywords:["podman desktop","podman","containers","images","migrating","kubernetes"],tags:["migrating-to-kubernetes","images"]},sidebar:"mySidebar",previous:{title:"Building and testing an image",permalink:"/docs/kind/building-an-image-and-testing-it-in-kind"},next:{title:"Minikube",permalink:"/docs/minikube/"}},s={},p=[{value:"Prerequisites",id:"prerequisites",level:4},{value:"Procedure",id:"procedure",level:4},{value:"Verification",id:"verification",level:4}],m={toc:p};function u(e){let{components:t,...n}=e;return(0,i.kt)("wrapper",(0,a.Z)({},m,n,{components:t,mdxType:"MDXLayout"}),(0,i.kt)("h1",{id:"pushing-an-image-to-your-local-kind-powered-kubernetes-cluster"},"Pushing an image to your local Kind-powered Kubernetes cluster"),(0,i.kt)("p",null,"With Podman Desktop, you can push an image to your local Kind-powered Kubernetes cluster."),(0,i.kt)("h4",{id:"prerequisites"},"Prerequisites"),(0,i.kt)("ul",null,(0,i.kt)("li",{parentName:"ul"},(0,i.kt)("a",{parentName:"li",href:"/docs/containers"},"You onboarded a container engine"),"."),(0,i.kt)("li",{parentName:"ul"},(0,i.kt)("a",{parentName:"li",href:"/docs/kind"},"You onboarded a Kind cluster"),"."),(0,i.kt)("li",{parentName:"ul"},(0,i.kt)("a",{parentName:"li",href:"/docs/kind/working-with-your-local-kind-cluster"},"You have set your Kubernetes context to your local Kind-powered Kubernetes cluster"),"."),(0,i.kt)("li",{parentName:"ul"},"Your image is available on the ",(0,i.kt)("strong",{parentName:"li"},"Images")," page: ",(0,i.kt)("inlineCode",{parentName:"li"},":"),".")),(0,i.kt)("h4",{id:"procedure"},"Procedure"),(0,i.kt)("ol",null,(0,i.kt)("li",{parentName:"ol"},"Open ",(0,i.kt)("strong",{parentName:"li"},"Podman Desktop dashboard > ",(0,i.kt)("icon",{icon:"fa-solid fa-cloud",size:"lg"})," Images"),"."),(0,i.kt)("li",{parentName:"ol"},(0,i.kt)("strong",{parentName:"li"},(0,i.kt)("icon",{icon:"fa-solid fa-search",size:"lg"})," Search images"),": ",(0,i.kt)("inlineCode",{parentName:"li"},":"),"."),(0,i.kt)("li",{parentName:"ol"},"Click ",(0,i.kt)("strong",{parentName:"li"},(0,i.kt)("icon",{icon:"fa-solid fa-ellipsis-v",size:"lg"})," > ",(0,i.kt)("icon",{icon:"fa-solid fa-ellipsis-v",size:"lg"})," Push image to Kind cluster"),"."),(0,i.kt)("li",{parentName:"ol"},"If you created many Kind clusters, select your Kind cluster from the list.")),(0,i.kt)("h4",{id:"verification"},"Verification"),(0,i.kt)("p",null,"Kind does not enable you to list loaded images.\nTherefore, create a Pod that uses the loaded image."),(0,i.kt)("ol",null,(0,i.kt)("li",{parentName:"ol"},(0,i.kt)("p",{parentName:"li"},"Create a ",(0,i.kt)("inlineCode",{parentName:"p"},"verify_my_image.yaml")," Kubernetes YAML file on your workstation.\nReplace the placeholders:"),(0,i.kt)("ul",{parentName:"li"},(0,i.kt)("li",{parentName:"ul"},"Pod ",(0,i.kt)("inlineCode",{parentName:"li"},"name")," and container ",(0,i.kt)("inlineCode",{parentName:"li"},"name")," value must consist of lower case alphanumeric characters, '-' or '.', and must start and end with an alphanumeric character."),(0,i.kt)("li",{parentName:"ul"},"Container ",(0,i.kt)("inlineCode",{parentName:"li"},"image")," value is the image you pushed.")),(0,i.kt)("pre",{parentName:"li"},(0,i.kt)("code",{parentName:"pre",className:"language-yaml"},"apiVersion: v1\nkind: Pod\nmetadata:\n name: \nspec:\n containers:\n - name: \n image: :\n imagePullPolicy: Never\n"))),(0,i.kt)("li",{parentName:"ol"},(0,i.kt)("p",{parentName:"li"},"Open ",(0,i.kt)("strong",{parentName:"p"},(0,i.kt)("icon",{icon:"fa-solid fa-cubes",size:"lg"})," Pods > Play Kubernetes YAML"),"."),(0,i.kt)("ol",{parentName:"li"},(0,i.kt)("li",{parentName:"ol"},(0,i.kt)("strong",{parentName:"li"},"Kubernetes YAML file"),": select your ",(0,i.kt)("inlineCode",{parentName:"li"},"verify_my_image.yaml")," file."),(0,i.kt)("li",{parentName:"ol"},(0,i.kt)("strong",{parentName:"li"},"Select Runtime"),": ",(0,i.kt)("strong",{parentName:"li"},"Using a Kubernetes cluster"),"."),(0,i.kt)("li",{parentName:"ol"},"Click ",(0,i.kt)("strong",{parentName:"li"},"Play"),"."),(0,i.kt)("li",{parentName:"ol"},"Clik ",(0,i.kt)("strong",{parentName:"li"},"Done")))),(0,i.kt)("li",{parentName:"ol"},(0,i.kt)("p",{parentName:"li"},"Open ",(0,i.kt)("strong",{parentName:"p"},(0,i.kt)("icon",{icon:"fa-solid fa-cubes",size:"lg"})," Pods"),".")),(0,i.kt)("li",{parentName:"ol"},(0,i.kt)("p",{parentName:"li"},(0,i.kt)("strong",{parentName:"p"},(0,i.kt)("icon",{icon:"fa-solid fa-search",size:"lg"})," Search pods"),": ",(0,i.kt)("inlineCode",{parentName:"p"},""),".")),(0,i.kt)("li",{parentName:"ol"},(0,i.kt)("p",{parentName:"li"},"The pod ",(0,i.kt)("strong",{parentName:"p"},"Status")," is ",(0,i.kt)("strong",{parentName:"p"},"Running"),"."))))}u.isMDXComponent=!0}}]); \ No newline at end of file diff --git a/assets/js/6875c492.51bd3ba5.js b/assets/js/6875c492.58abc53b.js similarity index 98% rename from assets/js/6875c492.51bd3ba5.js rename to assets/js/6875c492.58abc53b.js index 391406f21aa..db6faa35ae9 100644 --- a/assets/js/6875c492.51bd3ba5.js +++ b/assets/js/6875c492.58abc53b.js @@ -1 +1 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[8610],{20013:(e,t,a)=>{a.d(t,{Z:()=>s});var n=a(27378),l=a(99213),r=a(14582);function s(e){const{metadata:t}=e,{previousPage:a,nextPage:s}=t;return n.createElement("nav",{className:"pagination-nav","aria-label":(0,l.I)({id:"theme.blog.paginator.navAriaLabel",message:"Blog list page navigation",description:"The ARIA label for the blog pagination"})},a&&n.createElement(r.Z,{permalink:a,title:n.createElement(l.Z,{id:"theme.blog.paginator.newerEntries",description:"The label used to navigate to the newer blog posts page (previous page)"},"Newer Entries")}),s&&n.createElement(r.Z,{permalink:s,title:n.createElement(l.Z,{id:"theme.blog.paginator.olderEntries",description:"The label used to navigate to the older blog posts page (next page)"},"Older Entries"),isNext:!0}))}},2134:(e,t,a)=>{a.d(t,{Z:()=>s});var n=a(27378),l=a(70412),r=a(25532);function s(e){let{items:t,component:a=r.Z}=e;return n.createElement(n.Fragment,null,t.map((e=>{let{content:t}=e;return n.createElement(l.n,{key:t.metadata.permalink,content:t},n.createElement(a,null,n.createElement(t,null)))})))}},41071:(e,t,a)=>{a.r(t),a.d(t,{default:()=>E});var n=a(27378),l=a(38944),r=a(99213),s=a(40689),o=a(1123),i=a(75484),c=a(81884),g=a(55228),m=a(20013),u=a(60505),d=a(2134);function p(e){const t=function(){const{selectMessage:e}=(0,s.c)();return t=>e(t,(0,r.I)({id:"theme.blog.post.plurals",description:'Pluralized label for "{count} posts". Use as much plural forms (separated by "|") as your language support (see https://www.unicode.org/cldr/cldr-aux/charts/34/supplemental/language_plural_rules.html)',message:"One post|{count} posts"},{count:t}))}();return(0,r.I)({id:"theme.blog.tagTitle",description:"The title of the page for a blog tag",message:'{nPosts} tagged with "{tagName}"'},{nPosts:t(e.count),tagName:e.label})}function b(e){let{tag:t}=e;const a=p(t);return n.createElement(n.Fragment,null,n.createElement(o.d,{title:a}),n.createElement(u.Z,{tag:"blog_tags_posts"}))}function h(e){let{tag:t,items:a,sidebar:l,listMetadata:s}=e;const o=p(t);return n.createElement(g.Z,{sidebar:l},n.createElement("header",{className:"margin-bottom--xl"},n.createElement("h1",null,o),n.createElement(c.Z,{href:t.allTagsPath},n.createElement(r.Z,{id:"theme.tags.tagsPageLink",description:"The label of the link targeting the tag list page"},"View All Tags"))),n.createElement(d.Z,{items:a}),n.createElement(m.Z,{metadata:s}))}function E(e){return n.createElement(o.FG,{className:(0,l.Z)(i.k.wrapper.blogPages,i.k.page.blogTagPostListPage)},n.createElement(b,e),n.createElement(h,e))}},85978:(e,t,a)=>{a.d(t,{Z:()=>r});var n=a(27378),l=a(10610);function r(e){const t={...e};return t?.code?.length>2&&("$ "===t.code.substring(0,2)||"# "===t.code.substring(0,2)||"> "===t.code.substring(0,2))&&(t.code=t.code.substring(2)),n.createElement(n.Fragment,null,n.createElement(l.Z,t))}},35654:(e,t,a)=>{a.d(t,{Z:()=>i});var n=a(80256),l=a(92739),r=a(30537),s=a(9928),o=a(19374);r.vI.add(s.vnX,o.mRB);const i={...n.Z,icon:l.G}}}]); \ No newline at end of file +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[8610],{20013:(e,t,a)=>{a.d(t,{Z:()=>s});var n=a(27378),l=a(99213),r=a(14582);function s(e){const{metadata:t}=e,{previousPage:a,nextPage:s}=t;return n.createElement("nav",{className:"pagination-nav","aria-label":(0,l.I)({id:"theme.blog.paginator.navAriaLabel",message:"Blog list page navigation",description:"The ARIA label for the blog pagination"})},a&&n.createElement(r.Z,{permalink:a,title:n.createElement(l.Z,{id:"theme.blog.paginator.newerEntries",description:"The label used to navigate to the newer blog posts page (previous page)"},"Newer Entries")}),s&&n.createElement(r.Z,{permalink:s,title:n.createElement(l.Z,{id:"theme.blog.paginator.olderEntries",description:"The label used to navigate to the older blog posts page (next page)"},"Older Entries"),isNext:!0}))}},2134:(e,t,a)=>{a.d(t,{Z:()=>s});var n=a(27378),l=a(70412),r=a(25532);function s(e){let{items:t,component:a=r.Z}=e;return n.createElement(n.Fragment,null,t.map((e=>{let{content:t}=e;return n.createElement(l.n,{key:t.metadata.permalink,content:t},n.createElement(a,null,n.createElement(t,null)))})))}},41071:(e,t,a)=>{a.r(t),a.d(t,{default:()=>E});var n=a(27378),l=a(38944),r=a(99213),s=a(40689),o=a(1123),i=a(75484),c=a(81884),g=a(55228),m=a(20013),u=a(60505),d=a(2134);function p(e){const t=function(){const{selectMessage:e}=(0,s.c)();return t=>e(t,(0,r.I)({id:"theme.blog.post.plurals",description:'Pluralized label for "{count} posts". Use as much plural forms (separated by "|") as your language support (see https://www.unicode.org/cldr/cldr-aux/charts/34/supplemental/language_plural_rules.html)',message:"One post|{count} posts"},{count:t}))}();return(0,r.I)({id:"theme.blog.tagTitle",description:"The title of the page for a blog tag",message:'{nPosts} tagged with "{tagName}"'},{nPosts:t(e.count),tagName:e.label})}function b(e){let{tag:t}=e;const a=p(t);return n.createElement(n.Fragment,null,n.createElement(o.d,{title:a}),n.createElement(u.Z,{tag:"blog_tags_posts"}))}function h(e){let{tag:t,items:a,sidebar:l,listMetadata:s}=e;const o=p(t);return n.createElement(g.Z,{sidebar:l},n.createElement("header",{className:"margin-bottom--xl"},n.createElement("h1",null,o),n.createElement(c.Z,{href:t.allTagsPath},n.createElement(r.Z,{id:"theme.tags.tagsPageLink",description:"The label of the link targeting the tag list page"},"View All Tags"))),n.createElement(d.Z,{items:a}),n.createElement(m.Z,{metadata:s}))}function E(e){return n.createElement(o.FG,{className:(0,l.Z)(i.k.wrapper.blogPages,i.k.page.blogTagPostListPage)},n.createElement(b,e),n.createElement(h,e))}},85978:(e,t,a)=>{a.d(t,{Z:()=>r});var n=a(27378),l=a(10610);function r(e){const t={...e};return t?.code?.length>2&&("$ "===t.code.substring(0,2)||"# "===t.code.substring(0,2)||"> "===t.code.substring(0,2))&&(t.code=t.code.substring(2)),n.createElement(n.Fragment,null,n.createElement(l.Z,t))}},35654:(e,t,a)=>{a.d(t,{Z:()=>i});var n=a(80256),l=a(92739),r=a(30537),s=a(9928),o=a(19374);r.vI.add(s.vnX,o.mRB);const i={...n.Z,Icon:l.G}}}]); \ No newline at end of file diff --git a/assets/js/6bf124c2.2d89c3a9.js b/assets/js/6bf124c2.2d89c3a9.js new file mode 100644 index 00000000000..ef71402fc41 --- /dev/null +++ b/assets/js/6bf124c2.2d89c3a9.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[8960],{35318:(e,t,n)=>{n.d(t,{Zo:()=>c,kt:()=>m});var r=n(27378);function i(e,t,n){return t in e?Object.defineProperty(e,t,{value:n,enumerable:!0,configurable:!0,writable:!0}):e[t]=n,e}function o(e,t){var n=Object.keys(e);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(e);t&&(r=r.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),n.push.apply(n,r)}return n}function l(e){for(var t=1;t=0||(i[n]=e[n]);return i}(e,t);if(Object.getOwnPropertySymbols){var o=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(i[n]=e[n])}return i}var a=r.createContext({}),s=function(e){var t=r.useContext(a),n=t;return e&&(n="function"==typeof e?e(t):l(l({},t),e)),n},c=function(e){var t=s(e.components);return r.createElement(a.Provider,{value:t},e.children)},p={inlineCode:"code",wrapper:function(e){var t=e.children;return r.createElement(r.Fragment,{},t)}},d=r.forwardRef((function(e,t){var n=e.components,i=e.mdxType,o=e.originalType,a=e.parentName,c=u(e,["components","mdxType","originalType","parentName"]),d=s(n),m=i,b=d["".concat(a,".").concat(m)]||d[m]||p[m]||o;return n?r.createElement(b,l(l({ref:t},c),{},{components:n})):r.createElement(b,l({ref:t},c))}));function m(e,t){var n=arguments,i=t&&t.mdxType;if("string"==typeof e||i){var o=n.length,l=new Array(o);l[0]=d;var u={};for(var a in t)hasOwnProperty.call(t,a)&&(u[a]=t[a]);u.originalType=e,u.mdxType="string"==typeof e?e:i,l[1]=u;for(var s=2;s{n.r(t),n.d(t,{assets:()=>a,contentTitle:()=>l,default:()=>m,frontMatter:()=>o,metadata:()=>u,toc:()=>s});var r=n(25773),i=(n(27378),n(35318));const o={sidebar_position:7,title:"Deleting your Minikube cluster",description:"Deleting your local Minikube-powered Kubernetes cluster.",keywords:["podman desktop","podman","containers","migrating","kubernetes","minikube"],tags:["migrating-to-kubernetes","minikube"]},l="Deleting your local Minikube-powered Kubernetes cluster",u={unversionedId:"minikube/deleting-your-minikube-cluster",id:"minikube/deleting-your-minikube-cluster",title:"Deleting your Minikube cluster",description:"Deleting your local Minikube-powered Kubernetes cluster.",source:"@site/docs/minikube/deleting-your-minikube-cluster.md",sourceDirName:"minikube",slug:"/minikube/deleting-your-minikube-cluster",permalink:"/docs/minikube/deleting-your-minikube-cluster",draft:!1,editUrl:"https://github.com/containers/podman-desktop/tree/main/website/docs/minikube/deleting-your-minikube-cluster.md",tags:[{label:"migrating-to-kubernetes",permalink:"/docs/tags/migrating-to-kubernetes"},{label:"minikube",permalink:"/docs/tags/minikube"}],version:"current",sidebarPosition:7,frontMatter:{sidebar_position:7,title:"Deleting your Minikube cluster",description:"Deleting your local Minikube-powered Kubernetes cluster.",keywords:["podman desktop","podman","containers","migrating","kubernetes","minikube"],tags:["migrating-to-kubernetes","minikube"]},sidebar:"mySidebar",previous:{title:"Restarting your Minikube cluster",permalink:"/docs/minikube/restarting-your-minikube-cluster"},next:{title:"Building and testing an image",permalink:"/docs/minikube/building-an-image-and-testing-it-in-minikube"}},a={},s=[{value:"Prerequisites",id:"prerequisites",level:4},{value:"Procedure",id:"procedure",level:4},{value:"Verification",id:"verification",level:4}],c=(p="Icon",function(e){return console.warn("Component "+p+" was not imported, exported, or provided by MDXProvider as global scope"),(0,i.kt)("div",e)});var p;const d={toc:s};function m(e){let{components:t,...n}=e;return(0,i.kt)("wrapper",(0,r.Z)({},d,n,{components:t,mdxType:"MDXLayout"}),(0,i.kt)("h1",{id:"deleting-your-local-minikube-powered-kubernetes-cluster"},"Deleting your local Minikube-powered Kubernetes cluster"),(0,i.kt)("h4",{id:"prerequisites"},"Prerequisites"),(0,i.kt)("ul",null,(0,i.kt)("li",{parentName:"ul"},(0,i.kt)("a",{parentName:"li",href:"./creating-a-minikube-cluster"},"You configured Podman"),"."),(0,i.kt)("li",{parentName:"ul"},(0,i.kt)("a",{parentName:"li",href:"https://minikube.sigs.k8s.io/"},"You installed Minikube"),".")),(0,i.kt)("h4",{id:"procedure"},"Procedure"),(0,i.kt)("ol",null,(0,i.kt)("li",{parentName:"ol"},"Open ",(0,i.kt)("strong",{parentName:"li"},(0,i.kt)(c,{icon:"fa-solid fa-cog",size:"lg",mdxType:"Icon"})," Settings > Resources"),"."),(0,i.kt)("li",{parentName:"ol"},"Find the Minikube cluster to delete."),(0,i.kt)("li",{parentName:"ol"},"Click ",(0,i.kt)(c,{icon:"fa-solid fa-stop",size:"lg",mdxType:"Icon"})," to stop the cluster."),(0,i.kt)("li",{parentName:"ol"},"Once the cluster is stopped, click ",(0,i.kt)(c,{icon:"fa-solid fa-trash",size:"lg",mdxType:"Icon"})," to delete it.")),(0,i.kt)("h4",{id:"verification"},"Verification"),(0,i.kt)("ol",null,(0,i.kt)("li",{parentName:"ol"},"In ",(0,i.kt)("strong",{parentName:"li"},(0,i.kt)(c,{icon:"fa-solid fa-cog",size:"lg",mdxType:"Icon"})," Settings > Resources"),", the deleted Minikube cluster is not visible.")))}m.isMDXComponent=!0}}]); \ No newline at end of file diff --git a/assets/js/6bf124c2.5d83dfab.js b/assets/js/6bf124c2.5d83dfab.js deleted file mode 100644 index b0bff8990e2..00000000000 --- a/assets/js/6bf124c2.5d83dfab.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[8960],{35318:(e,t,i)=>{i.d(t,{Zo:()=>c,kt:()=>m});var n=i(27378);function r(e,t,i){return t in e?Object.defineProperty(e,t,{value:i,enumerable:!0,configurable:!0,writable:!0}):e[t]=i,e}function o(e,t){var i=Object.keys(e);if(Object.getOwnPropertySymbols){var n=Object.getOwnPropertySymbols(e);t&&(n=n.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),i.push.apply(i,n)}return i}function l(e){for(var t=1;t=0||(r[i]=e[i]);return r}(e,t);if(Object.getOwnPropertySymbols){var o=Object.getOwnPropertySymbols(e);for(n=0;n=0||Object.prototype.propertyIsEnumerable.call(e,i)&&(r[i]=e[i])}return r}var a=n.createContext({}),s=function(e){var t=n.useContext(a),i=t;return e&&(i="function"==typeof e?e(t):l(l({},t),e)),i},c=function(e){var t=s(e.components);return n.createElement(a.Provider,{value:t},e.children)},p={inlineCode:"code",wrapper:function(e){var t=e.children;return n.createElement(n.Fragment,{},t)}},d=n.forwardRef((function(e,t){var i=e.components,r=e.mdxType,o=e.originalType,a=e.parentName,c=u(e,["components","mdxType","originalType","parentName"]),d=s(i),m=r,b=d["".concat(a,".").concat(m)]||d[m]||p[m]||o;return i?n.createElement(b,l(l({ref:t},c),{},{components:i})):n.createElement(b,l({ref:t},c))}));function m(e,t){var i=arguments,r=t&&t.mdxType;if("string"==typeof e||r){var o=i.length,l=new Array(o);l[0]=d;var u={};for(var a in t)hasOwnProperty.call(t,a)&&(u[a]=t[a]);u.originalType=e,u.mdxType="string"==typeof e?e:r,l[1]=u;for(var s=2;s{i.r(t),i.d(t,{assets:()=>a,contentTitle:()=>l,default:()=>p,frontMatter:()=>o,metadata:()=>u,toc:()=>s});var n=i(25773),r=(i(27378),i(35318));const o={sidebar_position:7,title:"Deleting your Minikube cluster",description:"Deleting your local Minikube-powered Kubernetes cluster.",keywords:["podman desktop","podman","containers","migrating","kubernetes","minikube"],tags:["migrating-to-kubernetes","minikube"]},l="Deleting your local Minikube-powered Kubernetes cluster",u={unversionedId:"minikube/deleting-your-minikube-cluster",id:"minikube/deleting-your-minikube-cluster",title:"Deleting your Minikube cluster",description:"Deleting your local Minikube-powered Kubernetes cluster.",source:"@site/docs/minikube/deleting-your-minikube-cluster.md",sourceDirName:"minikube",slug:"/minikube/deleting-your-minikube-cluster",permalink:"/docs/minikube/deleting-your-minikube-cluster",draft:!1,editUrl:"https://github.com/containers/podman-desktop/tree/main/website/docs/minikube/deleting-your-minikube-cluster.md",tags:[{label:"migrating-to-kubernetes",permalink:"/docs/tags/migrating-to-kubernetes"},{label:"minikube",permalink:"/docs/tags/minikube"}],version:"current",sidebarPosition:7,frontMatter:{sidebar_position:7,title:"Deleting your Minikube cluster",description:"Deleting your local Minikube-powered Kubernetes cluster.",keywords:["podman desktop","podman","containers","migrating","kubernetes","minikube"],tags:["migrating-to-kubernetes","minikube"]},sidebar:"mySidebar",previous:{title:"Restarting your Minikube cluster",permalink:"/docs/minikube/restarting-your-minikube-cluster"},next:{title:"Building and testing an image",permalink:"/docs/minikube/building-an-image-and-testing-it-in-minikube"}},a={},s=[{value:"Prerequisites",id:"prerequisites",level:4},{value:"Procedure",id:"procedure",level:4},{value:"Verification",id:"verification",level:4}],c={toc:s};function p(e){let{components:t,...i}=e;return(0,r.kt)("wrapper",(0,n.Z)({},c,i,{components:t,mdxType:"MDXLayout"}),(0,r.kt)("h1",{id:"deleting-your-local-minikube-powered-kubernetes-cluster"},"Deleting your local Minikube-powered Kubernetes cluster"),(0,r.kt)("h4",{id:"prerequisites"},"Prerequisites"),(0,r.kt)("ul",null,(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("a",{parentName:"li",href:"./creating-a-minikube-cluster"},"You configured Podman"),"."),(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("a",{parentName:"li",href:"https://minikube.sigs.k8s.io/"},"You installed Minikube"),".")),(0,r.kt)("h4",{id:"procedure"},"Procedure"),(0,r.kt)("ol",null,(0,r.kt)("li",{parentName:"ol"},"Open ",(0,r.kt)("strong",{parentName:"li"},(0,r.kt)("icon",{icon:"fa-solid fa-cog",size:"lg"})," Settings > Resources"),"."),(0,r.kt)("li",{parentName:"ol"},"Find the Minikube cluster to delete."),(0,r.kt)("li",{parentName:"ol"},"Click ",(0,r.kt)("icon",{icon:"fa-solid fa-stop",size:"lg"})," to stop the cluster."),(0,r.kt)("li",{parentName:"ol"},"Once the cluster is stopped, click ",(0,r.kt)("icon",{icon:"fa-solid fa-trash",size:"lg"})," to delete it.")),(0,r.kt)("h4",{id:"verification"},"Verification"),(0,r.kt)("ol",null,(0,r.kt)("li",{parentName:"ol"},"In ",(0,r.kt)("strong",{parentName:"li"},(0,r.kt)("icon",{icon:"fa-solid fa-cog",size:"lg"})," Settings > Resources"),", the deleted Minikube cluster is not visible.")))}p.isMDXComponent=!0}}]); \ No newline at end of file diff --git a/assets/js/81e486a8.e2d287c9.js b/assets/js/81e486a8.9db760d6.js similarity index 54% rename from assets/js/81e486a8.e2d287c9.js rename to assets/js/81e486a8.9db760d6.js index 8fa70a60ff6..13c99f8af5b 100644 --- a/assets/js/81e486a8.e2d287c9.js +++ b/assets/js/81e486a8.9db760d6.js @@ -1 +1 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[9626],{35318:(e,t,r)=>{r.d(t,{Zo:()=>u,kt:()=>k});var n=r(27378);function i(e,t,r){return t in e?Object.defineProperty(e,t,{value:r,enumerable:!0,configurable:!0,writable:!0}):e[t]=r,e}function o(e,t){var r=Object.keys(e);if(Object.getOwnPropertySymbols){var n=Object.getOwnPropertySymbols(e);t&&(n=n.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),r.push.apply(r,n)}return r}function a(e){for(var t=1;t=0||(i[r]=e[r]);return i}(e,t);if(Object.getOwnPropertySymbols){var o=Object.getOwnPropertySymbols(e);for(n=0;n=0||Object.prototype.propertyIsEnumerable.call(e,r)&&(i[r]=e[r])}return i}var l=n.createContext({}),c=function(e){var t=n.useContext(l),r=t;return e&&(r="function"==typeof e?e(t):a(a({},t),e)),r},u=function(e){var t=c(e.components);return n.createElement(l.Provider,{value:t},e.children)},d={inlineCode:"code",wrapper:function(e){var t=e.children;return n.createElement(n.Fragment,{},t)}},p=n.forwardRef((function(e,t){var r=e.components,i=e.mdxType,o=e.originalType,l=e.parentName,u=s(e,["components","mdxType","originalType","parentName"]),p=c(r),k=i,m=p["".concat(l,".").concat(k)]||p[k]||d[k]||o;return r?n.createElement(m,a(a({ref:t},u),{},{components:r})):n.createElement(m,a({ref:t},u))}));function k(e,t){var r=arguments,i=t&&t.mdxType;if("string"==typeof e||i){var o=r.length,a=new Array(o);a[0]=p;var s={};for(var l in t)hasOwnProperty.call(t,l)&&(s[l]=t[l]);s.originalType=e,s.mdxType="string"==typeof e?e:i,a[1]=s;for(var c=2;c{r.r(t),r.d(t,{assets:()=>l,contentTitle:()=>a,default:()=>d,frontMatter:()=>o,metadata:()=>s,toc:()=>c});var n=r(25773),i=(r(27378),r(35318));const o={sidebar_position:5,title:"Restarting your Kind cluster",description:"Restarting your local Kind-powered Kubernetes cluster.",keywords:["podman desktop","podman","containers","migrating","kubernetes","kind"],tags:["migrating-to-kubernetes","kind"]},a="Restarting your local Kind-powered Kubernetes cluster",s={unversionedId:"kind/restarting-your-kind-cluster",id:"kind/restarting-your-kind-cluster",title:"Restarting your Kind cluster",description:"Restarting your local Kind-powered Kubernetes cluster.",source:"@site/docs/kind/restarting-your-kind-cluster.md",sourceDirName:"kind",slug:"/kind/restarting-your-kind-cluster",permalink:"/docs/kind/restarting-your-kind-cluster",draft:!1,editUrl:"https://github.com/containers/podman-desktop/tree/main/website/docs/kind/restarting-your-kind-cluster.md",tags:[{label:"migrating-to-kubernetes",permalink:"/docs/tags/migrating-to-kubernetes"},{label:"kind",permalink:"/docs/tags/kind"}],version:"current",sidebarPosition:5,frontMatter:{sidebar_position:5,title:"Restarting your Kind cluster",description:"Restarting your local Kind-powered Kubernetes cluster.",keywords:["podman desktop","podman","containers","migrating","kubernetes","kind"],tags:["migrating-to-kubernetes","kind"]},sidebar:"mySidebar",previous:{title:"Creating a Kind cluster",permalink:"/docs/kind/creating-a-kind-cluster"},next:{title:"Working with your Kind cluster",permalink:"/docs/kind/working-with-your-local-kind-cluster"}},l={},c=[{value:"Procedure",id:"procedure",level:4},{value:"Verification",id:"verification",level:4},{value:"Workaround",id:"workaround",level:4}],u={toc:c};function d(e){let{components:t,...r}=e;return(0,i.kt)("wrapper",(0,n.Z)({},u,r,{components:t,mdxType:"MDXLayout"}),(0,i.kt)("h1",{id:"restarting-your-local-kind-powered-kubernetes-cluster"},"Restarting your local Kind-powered Kubernetes cluster"),(0,i.kt)("p",null,"With Podman Desktop, you can restart your local Kind-powered Kubernetes cluster."),(0,i.kt)("h4",{id:"procedure"},"Procedure"),(0,i.kt)("ol",null,(0,i.kt)("li",{parentName:"ol"},"Open ",(0,i.kt)("strong",{parentName:"li"},(0,i.kt)("icon",{icon:"fa-solid fa-cog",size:"lg"})," Settings > Resources"),"."),(0,i.kt)("li",{parentName:"ol"},"Find the Kind cluster to restart."),(0,i.kt)("li",{parentName:"ol"},"Click ",(0,i.kt)("icon",{icon:"fa-solid fa-repeat",size:"lg"}),".")),(0,i.kt)("h4",{id:"verification"},"Verification"),(0,i.kt)("ol",null,(0,i.kt)("li",{parentName:"ol"},"Open ",(0,i.kt)("strong",{parentName:"li"},"Containers"),"."),(0,i.kt)("li",{parentName:"ol"},"Find the Kind cluster that restarted."),(0,i.kt)("li",{parentName:"ol"},"The cluster ",(0,i.kt)("strong",{parentName:"li"},"Age")," is consistent with the restart time."),(0,i.kt)("li",{parentName:"ol"},"Open ",(0,i.kt)("strong",{parentName:"li"},"Pods"),"."),(0,i.kt)("li",{parentName:"ol"},"Find the pods that are running on your Kind cluster.")),(0,i.kt)("h4",{id:"workaround"},"Workaround"),(0,i.kt)("p",null,"Kind has no command to restart a cluster.\nTherefore, Podman Desktop stops the Kind cluster, starts it again, and hopes for the best.\nThe Kind cluster might not restart successfully.\nIn that case:"),(0,i.kt)("ul",null,(0,i.kt)("li",{parentName:"ul"},"Consider replacing Kind with a local Kubernetes cluster that you can restart, such as ",(0,i.kt)("a",{parentName:"li",href:"https://developers.redhat.com/products/openshift-local/"},"OpenShift Local"),"."),(0,i.kt)("li",{parentName:"ul"},"Consider ",(0,i.kt)("a",{parentName:"li",href:"/docs/kind/deleting-your-kind-cluster"},"deleting your Kind cluster"),", and ",(0,i.kt)("a",{parentName:"li",href:"/docs/kind/creating-a-kind-cluster"},"creating a Kind cluster"),".")))}d.isMDXComponent=!0}}]); \ No newline at end of file +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[9626],{35318:(e,t,r)=>{r.d(t,{Zo:()=>d,kt:()=>k});var n=r(27378);function i(e,t,r){return t in e?Object.defineProperty(e,t,{value:r,enumerable:!0,configurable:!0,writable:!0}):e[t]=r,e}function o(e,t){var r=Object.keys(e);if(Object.getOwnPropertySymbols){var n=Object.getOwnPropertySymbols(e);t&&(n=n.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),r.push.apply(r,n)}return r}function a(e){for(var t=1;t=0||(i[r]=e[r]);return i}(e,t);if(Object.getOwnPropertySymbols){var o=Object.getOwnPropertySymbols(e);for(n=0;n=0||Object.prototype.propertyIsEnumerable.call(e,r)&&(i[r]=e[r])}return i}var l=n.createContext({}),c=function(e){var t=n.useContext(l),r=t;return e&&(r="function"==typeof e?e(t):a(a({},t),e)),r},d=function(e){var t=c(e.components);return n.createElement(l.Provider,{value:t},e.children)},u={inlineCode:"code",wrapper:function(e){var t=e.children;return n.createElement(n.Fragment,{},t)}},p=n.forwardRef((function(e,t){var r=e.components,i=e.mdxType,o=e.originalType,l=e.parentName,d=s(e,["components","mdxType","originalType","parentName"]),p=c(r),k=i,m=p["".concat(l,".").concat(k)]||p[k]||u[k]||o;return r?n.createElement(m,a(a({ref:t},d),{},{components:r})):n.createElement(m,a({ref:t},d))}));function k(e,t){var r=arguments,i=t&&t.mdxType;if("string"==typeof e||i){var o=r.length,a=new Array(o);a[0]=p;var s={};for(var l in t)hasOwnProperty.call(t,l)&&(s[l]=t[l]);s.originalType=e,s.mdxType="string"==typeof e?e:i,a[1]=s;for(var c=2;c{r.r(t),r.d(t,{assets:()=>l,contentTitle:()=>a,default:()=>k,frontMatter:()=>o,metadata:()=>s,toc:()=>c});var n=r(25773),i=(r(27378),r(35318));const o={sidebar_position:5,title:"Restarting your Kind cluster",description:"Restarting your local Kind-powered Kubernetes cluster.",keywords:["podman desktop","podman","containers","migrating","kubernetes","kind"],tags:["migrating-to-kubernetes","kind"]},a="Restarting your local Kind-powered Kubernetes cluster",s={unversionedId:"kind/restarting-your-kind-cluster",id:"kind/restarting-your-kind-cluster",title:"Restarting your Kind cluster",description:"Restarting your local Kind-powered Kubernetes cluster.",source:"@site/docs/kind/restarting-your-kind-cluster.md",sourceDirName:"kind",slug:"/kind/restarting-your-kind-cluster",permalink:"/docs/kind/restarting-your-kind-cluster",draft:!1,editUrl:"https://github.com/containers/podman-desktop/tree/main/website/docs/kind/restarting-your-kind-cluster.md",tags:[{label:"migrating-to-kubernetes",permalink:"/docs/tags/migrating-to-kubernetes"},{label:"kind",permalink:"/docs/tags/kind"}],version:"current",sidebarPosition:5,frontMatter:{sidebar_position:5,title:"Restarting your Kind cluster",description:"Restarting your local Kind-powered Kubernetes cluster.",keywords:["podman desktop","podman","containers","migrating","kubernetes","kind"],tags:["migrating-to-kubernetes","kind"]},sidebar:"mySidebar",previous:{title:"Creating a Kind cluster",permalink:"/docs/kind/creating-a-kind-cluster"},next:{title:"Working with your Kind cluster",permalink:"/docs/kind/working-with-your-local-kind-cluster"}},l={},c=[{value:"Procedure",id:"procedure",level:4},{value:"Verification",id:"verification",level:4},{value:"Workaround",id:"workaround",level:4}],d=(u="Icon",function(e){return console.warn("Component "+u+" was not imported, exported, or provided by MDXProvider as global scope"),(0,i.kt)("div",e)});var u;const p={toc:c};function k(e){let{components:t,...r}=e;return(0,i.kt)("wrapper",(0,n.Z)({},p,r,{components:t,mdxType:"MDXLayout"}),(0,i.kt)("h1",{id:"restarting-your-local-kind-powered-kubernetes-cluster"},"Restarting your local Kind-powered Kubernetes cluster"),(0,i.kt)("p",null,"With Podman Desktop, you can restart your local Kind-powered Kubernetes cluster."),(0,i.kt)("h4",{id:"procedure"},"Procedure"),(0,i.kt)("ol",null,(0,i.kt)("li",{parentName:"ol"},"Open ",(0,i.kt)("strong",{parentName:"li"},(0,i.kt)(d,{icon:"fa-solid fa-cog",size:"lg",mdxType:"Icon"})," Settings > Resources"),"."),(0,i.kt)("li",{parentName:"ol"},"Find the Kind cluster to restart."),(0,i.kt)("li",{parentName:"ol"},"Click ",(0,i.kt)(d,{icon:"fa-solid fa-repeat",size:"lg",mdxType:"Icon"}),".")),(0,i.kt)("h4",{id:"verification"},"Verification"),(0,i.kt)("ol",null,(0,i.kt)("li",{parentName:"ol"},"Open ",(0,i.kt)("strong",{parentName:"li"},"Containers"),"."),(0,i.kt)("li",{parentName:"ol"},"Find the Kind cluster that restarted."),(0,i.kt)("li",{parentName:"ol"},"The cluster ",(0,i.kt)("strong",{parentName:"li"},"Age")," is consistent with the restart time."),(0,i.kt)("li",{parentName:"ol"},"Open ",(0,i.kt)("strong",{parentName:"li"},"Pods"),"."),(0,i.kt)("li",{parentName:"ol"},"Find the pods that are running on your Kind cluster.")),(0,i.kt)("h4",{id:"workaround"},"Workaround"),(0,i.kt)("p",null,"Kind has no command to restart a cluster.\nTherefore, Podman Desktop stops the Kind cluster, starts it again, and hopes for the best.\nThe Kind cluster might not restart successfully.\nIn that case:"),(0,i.kt)("ul",null,(0,i.kt)("li",{parentName:"ul"},"Consider replacing Kind with a local Kubernetes cluster that you can restart, such as ",(0,i.kt)("a",{parentName:"li",href:"https://developers.redhat.com/products/openshift-local/"},"OpenShift Local"),"."),(0,i.kt)("li",{parentName:"ul"},"Consider ",(0,i.kt)("a",{parentName:"li",href:"/docs/kind/deleting-your-kind-cluster"},"deleting your Kind cluster"),", and ",(0,i.kt)("a",{parentName:"li",href:"/docs/kind/creating-a-kind-cluster"},"creating a Kind cluster"),".")))}k.isMDXComponent=!0}}]); \ No newline at end of file diff --git a/assets/js/94f3d131.91c40158.js b/assets/js/94f3d131.fd0510fd.js similarity index 50% rename from assets/js/94f3d131.91c40158.js rename to assets/js/94f3d131.fd0510fd.js index 6af971d95f3..79bb277b1c9 100644 --- a/assets/js/94f3d131.91c40158.js +++ b/assets/js/94f3d131.fd0510fd.js @@ -1 +1 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[4651],{35318:(e,t,r)=>{r.d(t,{Zo:()=>c,kt:()=>m});var n=r(27378);function i(e,t,r){return t in e?Object.defineProperty(e,t,{value:r,enumerable:!0,configurable:!0,writable:!0}):e[t]=r,e}function o(e,t){var r=Object.keys(e);if(Object.getOwnPropertySymbols){var n=Object.getOwnPropertySymbols(e);t&&(n=n.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),r.push.apply(r,n)}return r}function a(e){for(var t=1;t=0||(i[r]=e[r]);return i}(e,t);if(Object.getOwnPropertySymbols){var o=Object.getOwnPropertySymbols(e);for(n=0;n=0||Object.prototype.propertyIsEnumerable.call(e,r)&&(i[r]=e[r])}return i}var l=n.createContext({}),s=function(e){var t=n.useContext(l),r=t;return e&&(r="function"==typeof e?e(t):a(a({},t),e)),r},c=function(e){var t=s(e.components);return n.createElement(l.Provider,{value:t},e.children)},p={inlineCode:"code",wrapper:function(e){var t=e.children;return n.createElement(n.Fragment,{},t)}},k=n.forwardRef((function(e,t){var r=e.components,i=e.mdxType,o=e.originalType,l=e.parentName,c=u(e,["components","mdxType","originalType","parentName"]),k=s(r),m=i,d=k["".concat(l,".").concat(m)]||k[m]||p[m]||o;return r?n.createElement(d,a(a({ref:t},c),{},{components:r})):n.createElement(d,a({ref:t},c))}));function m(e,t){var r=arguments,i=t&&t.mdxType;if("string"==typeof e||i){var o=r.length,a=new Array(o);a[0]=k;var u={};for(var l in t)hasOwnProperty.call(t,l)&&(u[l]=t[l]);u.originalType=e,u.mdxType="string"==typeof e?e:i,a[1]=u;for(var s=2;s{r.r(t),r.d(t,{assets:()=>l,contentTitle:()=>a,default:()=>p,frontMatter:()=>o,metadata:()=>u,toc:()=>s});var n=r(25773),i=(r(27378),r(35318));const o={sidebar_position:6,title:"Restarting your Minikube cluster",description:"Restarting your local Minikube-powered Kubernetes cluster.",keywords:["podman desktop","podman","containers","migrating","kubernetes","minikube"],tags:["migrating-to-kubernetes","minikube"]},a="Restarting your local Minikube-powered Kubernetes cluster",u={unversionedId:"minikube/restarting-your-minikube-cluster",id:"minikube/restarting-your-minikube-cluster",title:"Restarting your Minikube cluster",description:"Restarting your local Minikube-powered Kubernetes cluster.",source:"@site/docs/minikube/restarting-your-minikube-cluster.md",sourceDirName:"minikube",slug:"/minikube/restarting-your-minikube-cluster",permalink:"/docs/minikube/restarting-your-minikube-cluster",draft:!1,editUrl:"https://github.com/containers/podman-desktop/tree/main/website/docs/minikube/restarting-your-minikube-cluster.md",tags:[{label:"migrating-to-kubernetes",permalink:"/docs/tags/migrating-to-kubernetes"},{label:"minikube",permalink:"/docs/tags/minikube"}],version:"current",sidebarPosition:6,frontMatter:{sidebar_position:6,title:"Restarting your Minikube cluster",description:"Restarting your local Minikube-powered Kubernetes cluster.",keywords:["podman desktop","podman","containers","migrating","kubernetes","minikube"],tags:["migrating-to-kubernetes","minikube"]},sidebar:"mySidebar",previous:{title:"Working with your Minikube cluster",permalink:"/docs/minikube/working-with-your-local-minikube-cluster"},next:{title:"Deleting your Minikube cluster",permalink:"/docs/minikube/deleting-your-minikube-cluster"}},l={},s=[{value:"Procedure",id:"procedure",level:4},{value:"Verification",id:"verification",level:4},{value:"Workaround",id:"workaround",level:4}],c={toc:s};function p(e){let{components:t,...r}=e;return(0,i.kt)("wrapper",(0,n.Z)({},c,r,{components:t,mdxType:"MDXLayout"}),(0,i.kt)("h1",{id:"restarting-your-local-minikube-powered-kubernetes-cluster"},"Restarting your local Minikube-powered Kubernetes cluster"),(0,i.kt)("p",null,"With Podman Desktop, you can restart your local Minikube-powered Kubernetes cluster."),(0,i.kt)("h4",{id:"procedure"},"Procedure"),(0,i.kt)("ol",null,(0,i.kt)("li",{parentName:"ol"},"Open ",(0,i.kt)("strong",{parentName:"li"},(0,i.kt)("icon",{icon:"fa-solid fa-cog",size:"lg"})," Settings > Resources"),"."),(0,i.kt)("li",{parentName:"ol"},"Find the Minikube cluster to restart."),(0,i.kt)("li",{parentName:"ol"},"Click ",(0,i.kt)("icon",{icon:"fa-solid fa-repeat",size:"lg"}),".")),(0,i.kt)("h4",{id:"verification"},"Verification"),(0,i.kt)("ol",null,(0,i.kt)("li",{parentName:"ol"},"Open ",(0,i.kt)("strong",{parentName:"li"},"Containers"),"."),(0,i.kt)("li",{parentName:"ol"},"Find the Minikube cluster that restarted."),(0,i.kt)("li",{parentName:"ol"},"The cluster ",(0,i.kt)("strong",{parentName:"li"},"Age")," is consistent with the restart time."),(0,i.kt)("li",{parentName:"ol"},"Open ",(0,i.kt)("strong",{parentName:"li"},"Pods"),"."),(0,i.kt)("li",{parentName:"ol"},"Find the pods that are running on your Minikube cluster.")),(0,i.kt)("h4",{id:"workaround"},"Workaround"),(0,i.kt)("p",null,"Minikube has no command to restart a cluster.\nTherefore, Podman Desktop stops the Minikube cluster, and starts it again.\nThe Minikube cluster might not restart successfully.\nIn that case:"),(0,i.kt)("ul",null,(0,i.kt)("li",{parentName:"ul"},"Consider replacing Minikube with a local Kubernetes cluster that you can restart, such as ",(0,i.kt)("a",{parentName:"li",href:"https://developers.redhat.com/products/openshift-local/"},"OpenShift Local"),"."),(0,i.kt)("li",{parentName:"ul"},"Consider ",(0,i.kt)("a",{parentName:"li",href:"/docs/minikube/deleting-your-minikube-cluster"},"deleting your Minikube cluster"),", and ",(0,i.kt)("a",{parentName:"li",href:"/docs/minikube/creating-a-minikube-cluster"},"creating a Minikube cluster"),".")))}p.isMDXComponent=!0}}]); \ No newline at end of file +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[4651],{35318:(e,t,r)=>{r.d(t,{Zo:()=>c,kt:()=>m});var n=r(27378);function i(e,t,r){return t in e?Object.defineProperty(e,t,{value:r,enumerable:!0,configurable:!0,writable:!0}):e[t]=r,e}function o(e,t){var r=Object.keys(e);if(Object.getOwnPropertySymbols){var n=Object.getOwnPropertySymbols(e);t&&(n=n.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),r.push.apply(r,n)}return r}function a(e){for(var t=1;t=0||(i[r]=e[r]);return i}(e,t);if(Object.getOwnPropertySymbols){var o=Object.getOwnPropertySymbols(e);for(n=0;n=0||Object.prototype.propertyIsEnumerable.call(e,r)&&(i[r]=e[r])}return i}var s=n.createContext({}),l=function(e){var t=n.useContext(s),r=t;return e&&(r="function"==typeof e?e(t):a(a({},t),e)),r},c=function(e){var t=l(e.components);return n.createElement(s.Provider,{value:t},e.children)},p={inlineCode:"code",wrapper:function(e){var t=e.children;return n.createElement(n.Fragment,{},t)}},k=n.forwardRef((function(e,t){var r=e.components,i=e.mdxType,o=e.originalType,s=e.parentName,c=u(e,["components","mdxType","originalType","parentName"]),k=l(r),m=i,d=k["".concat(s,".").concat(m)]||k[m]||p[m]||o;return r?n.createElement(d,a(a({ref:t},c),{},{components:r})):n.createElement(d,a({ref:t},c))}));function m(e,t){var r=arguments,i=t&&t.mdxType;if("string"==typeof e||i){var o=r.length,a=new Array(o);a[0]=k;var u={};for(var s in t)hasOwnProperty.call(t,s)&&(u[s]=t[s]);u.originalType=e,u.mdxType="string"==typeof e?e:i,a[1]=u;for(var l=2;l{r.r(t),r.d(t,{assets:()=>s,contentTitle:()=>a,default:()=>m,frontMatter:()=>o,metadata:()=>u,toc:()=>l});var n=r(25773),i=(r(27378),r(35318));const o={sidebar_position:6,title:"Restarting your Minikube cluster",description:"Restarting your local Minikube-powered Kubernetes cluster.",keywords:["podman desktop","podman","containers","migrating","kubernetes","minikube"],tags:["migrating-to-kubernetes","minikube"]},a="Restarting your local Minikube-powered Kubernetes cluster",u={unversionedId:"minikube/restarting-your-minikube-cluster",id:"minikube/restarting-your-minikube-cluster",title:"Restarting your Minikube cluster",description:"Restarting your local Minikube-powered Kubernetes cluster.",source:"@site/docs/minikube/restarting-your-minikube-cluster.md",sourceDirName:"minikube",slug:"/minikube/restarting-your-minikube-cluster",permalink:"/docs/minikube/restarting-your-minikube-cluster",draft:!1,editUrl:"https://github.com/containers/podman-desktop/tree/main/website/docs/minikube/restarting-your-minikube-cluster.md",tags:[{label:"migrating-to-kubernetes",permalink:"/docs/tags/migrating-to-kubernetes"},{label:"minikube",permalink:"/docs/tags/minikube"}],version:"current",sidebarPosition:6,frontMatter:{sidebar_position:6,title:"Restarting your Minikube cluster",description:"Restarting your local Minikube-powered Kubernetes cluster.",keywords:["podman desktop","podman","containers","migrating","kubernetes","minikube"],tags:["migrating-to-kubernetes","minikube"]},sidebar:"mySidebar",previous:{title:"Working with your Minikube cluster",permalink:"/docs/minikube/working-with-your-local-minikube-cluster"},next:{title:"Deleting your Minikube cluster",permalink:"/docs/minikube/deleting-your-minikube-cluster"}},s={},l=[{value:"Procedure",id:"procedure",level:4},{value:"Verification",id:"verification",level:4},{value:"Workaround",id:"workaround",level:4}],c=(p="Icon",function(e){return console.warn("Component "+p+" was not imported, exported, or provided by MDXProvider as global scope"),(0,i.kt)("div",e)});var p;const k={toc:l};function m(e){let{components:t,...r}=e;return(0,i.kt)("wrapper",(0,n.Z)({},k,r,{components:t,mdxType:"MDXLayout"}),(0,i.kt)("h1",{id:"restarting-your-local-minikube-powered-kubernetes-cluster"},"Restarting your local Minikube-powered Kubernetes cluster"),(0,i.kt)("p",null,"With Podman Desktop, you can restart your local Minikube-powered Kubernetes cluster."),(0,i.kt)("h4",{id:"procedure"},"Procedure"),(0,i.kt)("ol",null,(0,i.kt)("li",{parentName:"ol"},"Open ",(0,i.kt)("strong",{parentName:"li"},(0,i.kt)(c,{icon:"fa-solid fa-cog",size:"lg",mdxType:"Icon"})," Settings > Resources"),"."),(0,i.kt)("li",{parentName:"ol"},"Find the Minikube cluster to restart."),(0,i.kt)("li",{parentName:"ol"},"Click ",(0,i.kt)(c,{icon:"fa-solid fa-repeat",size:"lg",mdxType:"Icon"}),".")),(0,i.kt)("h4",{id:"verification"},"Verification"),(0,i.kt)("ol",null,(0,i.kt)("li",{parentName:"ol"},"Open ",(0,i.kt)("strong",{parentName:"li"},"Containers"),"."),(0,i.kt)("li",{parentName:"ol"},"Find the Minikube cluster that restarted."),(0,i.kt)("li",{parentName:"ol"},"The cluster ",(0,i.kt)("strong",{parentName:"li"},"Age")," is consistent with the restart time."),(0,i.kt)("li",{parentName:"ol"},"Open ",(0,i.kt)("strong",{parentName:"li"},"Pods"),"."),(0,i.kt)("li",{parentName:"ol"},"Find the pods that are running on your Minikube cluster.")),(0,i.kt)("h4",{id:"workaround"},"Workaround"),(0,i.kt)("p",null,"Minikube has no command to restart a cluster.\nTherefore, Podman Desktop stops the Minikube cluster, and starts it again.\nThe Minikube cluster might not restart successfully.\nIn that case:"),(0,i.kt)("ul",null,(0,i.kt)("li",{parentName:"ul"},"Consider replacing Minikube with a local Kubernetes cluster that you can restart, such as ",(0,i.kt)("a",{parentName:"li",href:"https://developers.redhat.com/products/openshift-local/"},"OpenShift Local"),"."),(0,i.kt)("li",{parentName:"ul"},"Consider ",(0,i.kt)("a",{parentName:"li",href:"/docs/minikube/deleting-your-minikube-cluster"},"deleting your Minikube cluster"),", and ",(0,i.kt)("a",{parentName:"li",href:"/docs/minikube/creating-a-minikube-cluster"},"creating a Minikube cluster"),".")))}m.isMDXComponent=!0}}]); \ No newline at end of file diff --git a/assets/js/959a8cfe.d67837c1.js b/assets/js/959a8cfe.d67837c1.js new file mode 100644 index 00000000000..2390eaa2807 --- /dev/null +++ b/assets/js/959a8cfe.d67837c1.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[6317],{35318:(e,t,r)=>{r.d(t,{Zo:()=>u,kt:()=>m});var n=r(27378);function a(e,t,r){return t in e?Object.defineProperty(e,t,{value:r,enumerable:!0,configurable:!0,writable:!0}):e[t]=r,e}function i(e,t){var r=Object.keys(e);if(Object.getOwnPropertySymbols){var n=Object.getOwnPropertySymbols(e);t&&(n=n.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),r.push.apply(r,n)}return r}function o(e){for(var t=1;t=0||(a[r]=e[r]);return a}(e,t);if(Object.getOwnPropertySymbols){var i=Object.getOwnPropertySymbols(e);for(n=0;n=0||Object.prototype.propertyIsEnumerable.call(e,r)&&(a[r]=e[r])}return a}var l=n.createContext({}),c=function(e){var t=n.useContext(l),r=t;return e&&(r="function"==typeof e?e(t):o(o({},t),e)),r},u=function(e){var t=c(e.components);return n.createElement(l.Provider,{value:t},e.children)},p={inlineCode:"code",wrapper:function(e){var t=e.children;return n.createElement(n.Fragment,{},t)}},d=n.forwardRef((function(e,t){var r=e.components,a=e.mdxType,i=e.originalType,l=e.parentName,u=s(e,["components","mdxType","originalType","parentName"]),d=c(r),m=a,g=d["".concat(l,".").concat(m)]||d[m]||p[m]||i;return r?n.createElement(g,o(o({ref:t},u),{},{components:r})):n.createElement(g,o({ref:t},u))}));function m(e,t){var r=arguments,a=t&&t.mdxType;if("string"==typeof e||a){var i=r.length,o=new Array(i);o[0]=d;var s={};for(var l in t)hasOwnProperty.call(t,l)&&(s[l]=t[l]);s.originalType=e,s.mdxType="string"==typeof e?e:a,o[1]=s;for(var c=2;c{r.d(t,{Z:()=>o});var n=r(27378),a=r(38944);const i="tabItem_wHwb";function o(e){let{children:t,hidden:r,className:o}=e;return n.createElement("div",{role:"tabpanel",className:(0,a.Z)(i,o),hidden:r},t)}},23930:(e,t,r)=>{r.d(t,{Z:()=>w});var n=r(25773),a=r(27378),i=r(38944),o=r(83457),s=r(35331),l=r(30654),c=r(70784),u=r(71819);function p(e){return function(e){return a.Children.map(e,(e=>{if(!e||(0,a.isValidElement)(e)&&function(e){const{props:t}=e;return!!t&&"object"==typeof t&&"value"in t}(e))return e;throw new Error(`Docusaurus error: Bad child <${"string"==typeof e.type?e.type:e.type.name}>: all children of the component should be , and every should have a unique "value" prop.`)}))?.filter(Boolean)??[]}(e).map((e=>{let{props:{value:t,label:r,attributes:n,default:a}}=e;return{value:t,label:r,attributes:n,default:a}}))}function d(e){const{values:t,children:r}=e;return(0,a.useMemo)((()=>{const e=t??p(r);return function(e){const t=(0,c.l)(e,((e,t)=>e.value===t.value));if(t.length>0)throw new Error(`Docusaurus error: Duplicate values "${t.map((e=>e.value)).join(", ")}" found in . Every value needs to be unique.`)}(e),e}),[t,r])}function m(e){let{value:t,tabValues:r}=e;return r.some((e=>e.value===t))}function g(e){let{queryString:t=!1,groupId:r}=e;const n=(0,s.k6)(),i=function(e){let{queryString:t=!1,groupId:r}=e;if("string"==typeof t)return t;if(!1===t)return null;if(!0===t&&!r)throw new Error('Docusaurus error: The component groupId prop is required if queryString=true, because this value is used as the search param name. You can also provide an explicit value such as queryString="my-search-param".');return r??null}({queryString:t,groupId:r});return[(0,l._X)(i),(0,a.useCallback)((e=>{if(!i)return;const t=new URLSearchParams(n.location.search);t.set(i,e),n.replace({...n.location,search:t.toString()})}),[i,n])]}function y(e){const{defaultValue:t,queryString:r=!1,groupId:n}=e,i=d(e),[o,s]=(0,a.useState)((()=>function(e){let{defaultValue:t,tabValues:r}=e;if(0===r.length)throw new Error("Docusaurus error: the component requires at least one children component");if(t){if(!m({value:t,tabValues:r}))throw new Error(`Docusaurus error: The has a defaultValue "${t}" but none of its children has the corresponding value. Available values are: ${r.map((e=>e.value)).join(", ")}. If you intend to show no default tab, use defaultValue={null} instead.`);return t}const n=r.find((e=>e.default))??r[0];if(!n)throw new Error("Unexpected error: 0 tabValues");return n.value}({defaultValue:t,tabValues:i}))),[l,c]=g({queryString:r,groupId:n}),[p,y]=function(e){let{groupId:t}=e;const r=function(e){return e?`docusaurus.tab.${e}`:null}(t),[n,i]=(0,u.Nk)(r);return[n,(0,a.useCallback)((e=>{r&&i.set(e)}),[r,i])]}({groupId:n}),f=(()=>{const e=l??p;return m({value:e,tabValues:i})?e:null})();(0,a.useLayoutEffect)((()=>{f&&s(f)}),[f]);return{selectedValue:o,selectValue:(0,a.useCallback)((e=>{if(!m({value:e,tabValues:i}))throw new Error(`Can't select invalid tab value=${e}`);s(e),c(e),y(e)}),[c,y,i]),tabValues:i}}var f=r(76457);const k="tabList_J5MA",h="tabItem_l0OV";function b(e){let{className:t,block:r,selectedValue:s,selectValue:l,tabValues:c}=e;const u=[],{blockElementScrollPositionUntilNextRender:p}=(0,o.o5)(),d=e=>{const t=e.currentTarget,r=u.indexOf(t),n=c[r].value;n!==s&&(p(t),l(n))},m=e=>{let t=null;switch(e.key){case"Enter":d(e);break;case"ArrowRight":{const r=u.indexOf(e.currentTarget)+1;t=u[r]??u[0];break}case"ArrowLeft":{const r=u.indexOf(e.currentTarget)-1;t=u[r]??u[u.length-1];break}}t?.focus()};return a.createElement("ul",{role:"tablist","aria-orientation":"horizontal",className:(0,i.Z)("tabs",{"tabs--block":r},t)},c.map((e=>{let{value:t,label:r,attributes:o}=e;return a.createElement("li",(0,n.Z)({role:"tab",tabIndex:s===t?0:-1,"aria-selected":s===t,key:t,ref:e=>u.push(e),onKeyDown:m,onClick:d},o,{className:(0,i.Z)("tabs__item",h,o?.className,{"tabs__item--active":s===t})}),r??t)})))}function v(e){let{lazy:t,children:r,selectedValue:n}=e;const i=(Array.isArray(r)?r:[r]).filter(Boolean);if(t){const e=i.find((e=>e.props.value===n));return e?(0,a.cloneElement)(e,{className:"margin-top--md"}):null}return a.createElement("div",{className:"margin-top--md"},i.map(((e,t)=>(0,a.cloneElement)(e,{key:t,hidden:e.props.value!==n}))))}function N(e){const t=y(e);return a.createElement("div",{className:(0,i.Z)("tabs-container",k)},a.createElement(b,(0,n.Z)({},e,t)),a.createElement(v,(0,n.Z)({},e,t)))}function w(e){const t=(0,f.Z)();return a.createElement(N,(0,n.Z)({key:String(t)},e))}},2696:(e,t,r)=>{r.d(t,{ZP:()=>l});var n=r(25773),a=(r(27378),r(35318));const i=(o="Icon",function(e){return console.warn("Component "+o+" was not imported, exported, or provided by MDXProvider as global scope"),(0,a.kt)("div",e)});var o;const s={toc:[{value:"Verification",id:"verification",level:4}]};function l(e){let{components:t,...r}=e;return(0,a.kt)("wrapper",(0,n.Z)({},s,r,{components:t,mdxType:"MDXLayout"}),(0,a.kt)("h4",{id:"verification"},"Verification"),(0,a.kt)("ol",null,(0,a.kt)("li",{parentName:"ol"},"Go to ",(0,a.kt)("strong",{parentName:"li"},(0,a.kt)(i,{icon:"fa-solid fa-cloud",size:"lg",mdxType:"Icon"})," Images"),"."),(0,a.kt)("li",{parentName:"ol"},"You can pull a private image from the registry."),(0,a.kt)("li",{parentName:"ol"},"You can push an image to the registry:",(0,a.kt)("ol",{parentName:"li"},(0,a.kt)("li",{parentName:"ol"},"Build an image with the fully qualified name required for your registry, such as ",(0,a.kt)("inlineCode",{parentName:"li"},"quay.io/my-repository/my-image"),", ",(0,a.kt)("inlineCode",{parentName:"li"},"ghcr.io/my-repository/my-image"),", ",(0,a.kt)("inlineCode",{parentName:"li"},"docker.io/my-repository/my-image"),", or ",(0,a.kt)("inlineCode",{parentName:"li"},"my-registry.tld/my-repository/my-image"),"."),(0,a.kt)("li",{parentName:"ol"},"On your image line, click ",(0,a.kt)("strong",{parentName:"li"},(0,a.kt)(i,{icon:"fa-solid fa-ellipsis-v",size:"lg",mdxType:"Icon"})),"."),(0,a.kt)("li",{parentName:"ol"},"The contextual menu has a ",(0,a.kt)("strong",{parentName:"li"},(0,a.kt)(i,{icon:"fa-solid fa-arrow-up",size:"lg",mdxType:"Icon"}),"Push Image")," entry.")))))}l.isMDXComponent=!0},79776:(e,t,r)=>{r.r(t),r.d(t,{assets:()=>h,contentTitle:()=>f,default:()=>N,frontMatter:()=>y,metadata:()=>k,toc:()=>b});var n=r(25773),a=(r(27378),r(35318)),i=r(23930),o=r(39798);const s=(l="Icon",function(e){return console.warn("Component "+l+" was not imported, exported, or provided by MDXProvider as global scope"),(0,a.kt)("div",e)});var l;const c={toc:[{value:"Prerequisites",id:"prerequisites",level:4},{value:"Procedure",id:"procedure",level:4}]};function u(e){let{components:t,...i}=e;return(0,a.kt)("wrapper",(0,n.Z)({},c,i,{components:t,mdxType:"MDXLayout"}),(0,a.kt)("h4",{id:"prerequisites"},"Prerequisites"),(0,a.kt)("ul",null,(0,a.kt)("li",{parentName:"ul"},(0,a.kt)("a",{parentName:"li",href:"/docs/podman/installing"},"A running Podman machine"),".")),(0,a.kt)("h4",{id:"procedure"},"Procedure"),(0,a.kt)("ol",null,(0,a.kt)("li",{parentName:"ol"},(0,a.kt)("p",{parentName:"li"},"Add your insecure registry within ",(0,a.kt)("strong",{parentName:"p"},(0,a.kt)(s,{icon:"fa-solid fa-cog",size:"lg",mdxType:"Icon"})," Settings > Registries"),"."),(0,a.kt)("p",{parentName:"li"},(0,a.kt)("img",{alt:"Adding a custom registry",src:r(27839).Z,width:"933",height:"501"}))),(0,a.kt)("li",{parentName:"ol"},(0,a.kt)("p",{parentName:"li"},'Click "Yes" to the insecure registry warning.'),(0,a.kt)("p",{parentName:"li"},(0,a.kt)("img",{alt:"Podman Desktop Registry Warning",src:r(8577).Z,width:"556",height:"206"}))),(0,a.kt)("li",{parentName:"ol"},(0,a.kt)("p",{parentName:"li"},"SSH into the Podman Machine to edit ",(0,a.kt)("inlineCode",{parentName:"p"},"registries.conf"),"."),(0,a.kt)("pre",{parentName:"li"},(0,a.kt)("code",{parentName:"pre",className:"language-shell-session"},"$ podman machine ssh [optional-machine-name]\n"))),(0,a.kt)("li",{parentName:"ol"},(0,a.kt)("p",{parentName:"li"},"Open ",(0,a.kt)("inlineCode",{parentName:"p"},"registries.conf"),"."),(0,a.kt)("pre",{parentName:"li"},(0,a.kt)("code",{parentName:"pre",className:"language-shell-session"},"$ sudo vi /etc/containers/registries.conf\n"))),(0,a.kt)("li",{parentName:"ol"},(0,a.kt)("p",{parentName:"li"},"Add the insecure registry: Add a new ",(0,a.kt)("inlineCode",{parentName:"p"},"[[registry]]")," section for the URL of the insecure registry you want to use. For example, if your insecure registry is located at ",(0,a.kt)("inlineCode",{parentName:"p"},"http://registry.example.com"),", add the following lines:"),(0,a.kt)("pre",{parentName:"li"},(0,a.kt)("code",{parentName:"pre",className:"language-toml"},'[[registry]]\nlocation = "registry.example.com"\ninsecure = true\n')),(0,a.kt)("p",{parentName:"li"},"If you have multiple registries, you can add one ",(0,a.kt)("inlineCode",{parentName:"p"},"[[registry]]")," block per registry.")),(0,a.kt)("li",{parentName:"ol"},(0,a.kt)("p",{parentName:"li"},"Save and exit the file.")),(0,a.kt)("li",{parentName:"ol"},(0,a.kt)("p",{parentName:"li"},"Restart Podman by the CLI or through Podman Desktop."),(0,a.kt)("pre",{parentName:"li"},(0,a.kt)("code",{parentName:"pre",className:"language-shell-session"},"$ podman machine stop\n$ podman machine start\n")))))}u.isMDXComponent=!0;const p=(e=>function(t){return console.warn("Component "+e+" was not imported, exported, or provided by MDXProvider as global scope"),(0,a.kt)("div",t)})("Icon"),d={toc:[{value:"Prerequisites",id:"prerequisites",level:4},{value:"Procedure",id:"procedure",level:4}]};function m(e){let{components:t,...i}=e;return(0,a.kt)("wrapper",(0,n.Z)({},d,i,{components:t,mdxType:"MDXLayout"}),(0,a.kt)("h4",{id:"prerequisites"},"Prerequisites"),(0,a.kt)("ul",null,(0,a.kt)("li",{parentName:"ul"},"Podman is installed.")),(0,a.kt)("h4",{id:"procedure"},"Procedure"),(0,a.kt)("ol",null,(0,a.kt)("li",{parentName:"ol"},(0,a.kt)("p",{parentName:"li"},"Add your insecure registry within ",(0,a.kt)("strong",{parentName:"p"},(0,a.kt)(p,{icon:"fa-solid fa-cog",size:"lg",mdxType:"Icon"})," Settings > Registries"),"."),(0,a.kt)("p",{parentName:"li"},(0,a.kt)("img",{alt:"Adding a custom registry",src:r(27839).Z,width:"933",height:"501"}))),(0,a.kt)("li",{parentName:"ol"},(0,a.kt)("p",{parentName:"li"},'Click "Yes" to the insecure registry warning.'),(0,a.kt)("p",{parentName:"li"},(0,a.kt)("img",{alt:"Podman Desktop Registry Warning",src:r(8577).Z,width:"556",height:"206"}))),(0,a.kt)("li",{parentName:"ol"},(0,a.kt)("p",{parentName:"li"},"Open ",(0,a.kt)("inlineCode",{parentName:"p"},"registries.conf"),"."),(0,a.kt)("pre",{parentName:"li"},(0,a.kt)("code",{parentName:"pre",className:"language-shell-session"},"$ sudo vi /etc/containers/registries.conf\n"))),(0,a.kt)("li",{parentName:"ol"},(0,a.kt)("p",{parentName:"li"},"Add the insecure registry: Add a new ",(0,a.kt)("inlineCode",{parentName:"p"},"[[registry]]")," section for the URL of the insecure registry you want to use. For example, if your insecure registry is located at ",(0,a.kt)("inlineCode",{parentName:"p"},"http://registry.example.com"),", add the following lines:"),(0,a.kt)("pre",{parentName:"li"},(0,a.kt)("code",{parentName:"pre",className:"language-toml"},'[[registry]]\nlocation = "registry.example.com"\ninsecure = true\n')),(0,a.kt)("p",{parentName:"li"},"If you have multiple registries, you can add one ",(0,a.kt)("inlineCode",{parentName:"p"},"[[registry]]")," block per registry:")),(0,a.kt)("li",{parentName:"ol"},(0,a.kt)("p",{parentName:"li"},"Save and exit the file.")),(0,a.kt)("li",{parentName:"ol"},(0,a.kt)("p",{parentName:"li"},"Restart Podman."),(0,a.kt)("pre",{parentName:"li"},(0,a.kt)("code",{parentName:"pre",className:"language-shell-session"},"$ sudo systemctl restart podman\n")))))}m.isMDXComponent=!0;var g=r(2696);const y={sidebar_position:10,title:"Adding an insecure registry",description:"Modifying Podman for an insecure registry",keywords:["podman desktop","podman","containers","registry","podman machine"],tags:["pods"]},f="Adding an Insecure Registry to Podman Desktop",k={unversionedId:"containers/registries/insecure-registry",id:"containers/registries/insecure-registry",title:"Adding an insecure registry",description:"Modifying Podman for an insecure registry",source:"@site/docs/containers/registries/insecure-registry.md",sourceDirName:"containers/registries",slug:"/containers/registries/insecure-registry",permalink:"/docs/containers/registries/insecure-registry",draft:!1,editUrl:"https://github.com/containers/podman-desktop/tree/main/website/docs/containers/registries/insecure-registry.md",tags:[{label:"pods",permalink:"/docs/tags/pods"}],version:"current",sidebarPosition:10,frontMatter:{sidebar_position:10,title:"Adding an insecure registry",description:"Modifying Podman for an insecure registry",keywords:["podman desktop","podman","containers","registry","podman machine"],tags:["pods"]},sidebar:"mySidebar",previous:{title:"Authenticating to a registry",permalink:"/docs/containers/registries/authenticating-to-a-preconfigured-registry"},next:{title:"Images",permalink:"/docs/containers/images/"}},h={},b=[],v={toc:b};function N(e){let{components:t,...r}=e;return(0,a.kt)("wrapper",(0,n.Z)({},v,r,{components:t,mdxType:"MDXLayout"}),(0,a.kt)("h1",{id:"adding-an-insecure-registry-to-podman-desktop"},"Adding an Insecure Registry to Podman Desktop"),(0,a.kt)("p",null,"In this guide, you will learn how to add an insecure registry to Podman Desktop. An insecure registry allows you to pull and push container images either over an unencrypted HTTP connection, or a HTTPS connection with a self-signed unverified certificate. Please note that using an insecure registry can expose your data to security risks, so it's recommended to use secure connections with a verifiable certificate whenever possible."),(0,a.kt)(i.Z,{groupId:"operating-systems",mdxType:"Tabs"},(0,a.kt)(o.Z,{value:"win",label:"Windows",mdxType:"TabItem"},(0,a.kt)(u,{mdxType:"WindowsMacosProcedure"})),(0,a.kt)(o.Z,{value:"mac",label:"macOS",mdxType:"TabItem"},(0,a.kt)(u,{mdxType:"WindowsMacosProcedure"})),(0,a.kt)(o.Z,{value:"linux",label:"Linux",mdxType:"TabItem"},(0,a.kt)(m,{mdxType:"LinuxProcedure"}))),(0,a.kt)(g.ZP,{mdxType:"Verification"}))}N.isMDXComponent=!0},27839:(e,t,r)=>{r.d(t,{Z:()=>n});const n=r.p+"assets/images/adding-a-custom-registry-df276b8cd69d722de97670c7eef8b235.png"},8577:(e,t,r)=>{r.d(t,{Z:()=>n});const n=r.p+"assets/images/registry-warning-insecure-245d7254807b5939c082f47e5d538d80.png"}}]); \ No newline at end of file diff --git a/assets/js/959a8cfe.e598f70b.js b/assets/js/959a8cfe.e598f70b.js deleted file mode 100644 index 5a78970ab94..00000000000 --- a/assets/js/959a8cfe.e598f70b.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[6317],{35318:(e,t,r)=>{r.d(t,{Zo:()=>u,kt:()=>m});var n=r(27378);function a(e,t,r){return t in e?Object.defineProperty(e,t,{value:r,enumerable:!0,configurable:!0,writable:!0}):e[t]=r,e}function i(e,t){var r=Object.keys(e);if(Object.getOwnPropertySymbols){var n=Object.getOwnPropertySymbols(e);t&&(n=n.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),r.push.apply(r,n)}return r}function o(e){for(var t=1;t=0||(a[r]=e[r]);return a}(e,t);if(Object.getOwnPropertySymbols){var i=Object.getOwnPropertySymbols(e);for(n=0;n=0||Object.prototype.propertyIsEnumerable.call(e,r)&&(a[r]=e[r])}return a}var l=n.createContext({}),c=function(e){var t=n.useContext(l),r=t;return e&&(r="function"==typeof e?e(t):o(o({},t),e)),r},u=function(e){var t=c(e.components);return n.createElement(l.Provider,{value:t},e.children)},p={inlineCode:"code",wrapper:function(e){var t=e.children;return n.createElement(n.Fragment,{},t)}},d=n.forwardRef((function(e,t){var r=e.components,a=e.mdxType,i=e.originalType,l=e.parentName,u=s(e,["components","mdxType","originalType","parentName"]),d=c(r),m=a,g=d["".concat(l,".").concat(m)]||d[m]||p[m]||i;return r?n.createElement(g,o(o({ref:t},u),{},{components:r})):n.createElement(g,o({ref:t},u))}));function m(e,t){var r=arguments,a=t&&t.mdxType;if("string"==typeof e||a){var i=r.length,o=new Array(i);o[0]=d;var s={};for(var l in t)hasOwnProperty.call(t,l)&&(s[l]=t[l]);s.originalType=e,s.mdxType="string"==typeof e?e:a,o[1]=s;for(var c=2;c{r.d(t,{Z:()=>o});var n=r(27378),a=r(38944);const i="tabItem_wHwb";function o(e){let{children:t,hidden:r,className:o}=e;return n.createElement("div",{role:"tabpanel",className:(0,a.Z)(i,o),hidden:r},t)}},23930:(e,t,r)=>{r.d(t,{Z:()=>w});var n=r(25773),a=r(27378),i=r(38944),o=r(83457),s=r(35331),l=r(30654),c=r(70784),u=r(71819);function p(e){return function(e){return a.Children.map(e,(e=>{if(!e||(0,a.isValidElement)(e)&&function(e){const{props:t}=e;return!!t&&"object"==typeof t&&"value"in t}(e))return e;throw new Error(`Docusaurus error: Bad child <${"string"==typeof e.type?e.type:e.type.name}>: all children of the component should be , and every should have a unique "value" prop.`)}))?.filter(Boolean)??[]}(e).map((e=>{let{props:{value:t,label:r,attributes:n,default:a}}=e;return{value:t,label:r,attributes:n,default:a}}))}function d(e){const{values:t,children:r}=e;return(0,a.useMemo)((()=>{const e=t??p(r);return function(e){const t=(0,c.l)(e,((e,t)=>e.value===t.value));if(t.length>0)throw new Error(`Docusaurus error: Duplicate values "${t.map((e=>e.value)).join(", ")}" found in . Every value needs to be unique.`)}(e),e}),[t,r])}function m(e){let{value:t,tabValues:r}=e;return r.some((e=>e.value===t))}function g(e){let{queryString:t=!1,groupId:r}=e;const n=(0,s.k6)(),i=function(e){let{queryString:t=!1,groupId:r}=e;if("string"==typeof t)return t;if(!1===t)return null;if(!0===t&&!r)throw new Error('Docusaurus error: The component groupId prop is required if queryString=true, because this value is used as the search param name. You can also provide an explicit value such as queryString="my-search-param".');return r??null}({queryString:t,groupId:r});return[(0,l._X)(i),(0,a.useCallback)((e=>{if(!i)return;const t=new URLSearchParams(n.location.search);t.set(i,e),n.replace({...n.location,search:t.toString()})}),[i,n])]}function y(e){const{defaultValue:t,queryString:r=!1,groupId:n}=e,i=d(e),[o,s]=(0,a.useState)((()=>function(e){let{defaultValue:t,tabValues:r}=e;if(0===r.length)throw new Error("Docusaurus error: the component requires at least one children component");if(t){if(!m({value:t,tabValues:r}))throw new Error(`Docusaurus error: The has a defaultValue "${t}" but none of its children has the corresponding value. Available values are: ${r.map((e=>e.value)).join(", ")}. If you intend to show no default tab, use defaultValue={null} instead.`);return t}const n=r.find((e=>e.default))??r[0];if(!n)throw new Error("Unexpected error: 0 tabValues");return n.value}({defaultValue:t,tabValues:i}))),[l,c]=g({queryString:r,groupId:n}),[p,y]=function(e){let{groupId:t}=e;const r=function(e){return e?`docusaurus.tab.${e}`:null}(t),[n,i]=(0,u.Nk)(r);return[n,(0,a.useCallback)((e=>{r&&i.set(e)}),[r,i])]}({groupId:n}),f=(()=>{const e=l??p;return m({value:e,tabValues:i})?e:null})();(0,a.useLayoutEffect)((()=>{f&&s(f)}),[f]);return{selectedValue:o,selectValue:(0,a.useCallback)((e=>{if(!m({value:e,tabValues:i}))throw new Error(`Can't select invalid tab value=${e}`);s(e),c(e),y(e)}),[c,y,i]),tabValues:i}}var f=r(76457);const k="tabList_J5MA",h="tabItem_l0OV";function b(e){let{className:t,block:r,selectedValue:s,selectValue:l,tabValues:c}=e;const u=[],{blockElementScrollPositionUntilNextRender:p}=(0,o.o5)(),d=e=>{const t=e.currentTarget,r=u.indexOf(t),n=c[r].value;n!==s&&(p(t),l(n))},m=e=>{let t=null;switch(e.key){case"Enter":d(e);break;case"ArrowRight":{const r=u.indexOf(e.currentTarget)+1;t=u[r]??u[0];break}case"ArrowLeft":{const r=u.indexOf(e.currentTarget)-1;t=u[r]??u[u.length-1];break}}t?.focus()};return a.createElement("ul",{role:"tablist","aria-orientation":"horizontal",className:(0,i.Z)("tabs",{"tabs--block":r},t)},c.map((e=>{let{value:t,label:r,attributes:o}=e;return a.createElement("li",(0,n.Z)({role:"tab",tabIndex:s===t?0:-1,"aria-selected":s===t,key:t,ref:e=>u.push(e),onKeyDown:m,onClick:d},o,{className:(0,i.Z)("tabs__item",h,o?.className,{"tabs__item--active":s===t})}),r??t)})))}function N(e){let{lazy:t,children:r,selectedValue:n}=e;const i=(Array.isArray(r)?r:[r]).filter(Boolean);if(t){const e=i.find((e=>e.props.value===n));return e?(0,a.cloneElement)(e,{className:"margin-top--md"}):null}return a.createElement("div",{className:"margin-top--md"},i.map(((e,t)=>(0,a.cloneElement)(e,{key:t,hidden:e.props.value!==n}))))}function v(e){const t=y(e);return a.createElement("div",{className:(0,i.Z)("tabs-container",k)},a.createElement(b,(0,n.Z)({},e,t)),a.createElement(N,(0,n.Z)({},e,t)))}function w(e){const t=(0,f.Z)();return a.createElement(v,(0,n.Z)({key:String(t)},e))}},2696:(e,t,r)=>{r.d(t,{ZP:()=>o});var n=r(25773),a=(r(27378),r(35318));const i={toc:[{value:"Verification",id:"verification",level:4}]};function o(e){let{components:t,...r}=e;return(0,a.kt)("wrapper",(0,n.Z)({},i,r,{components:t,mdxType:"MDXLayout"}),(0,a.kt)("h4",{id:"verification"},"Verification"),(0,a.kt)("ol",null,(0,a.kt)("li",{parentName:"ol"},"Go to ",(0,a.kt)("strong",{parentName:"li"},(0,a.kt)("icon",{icon:"fa-solid fa-cloud",size:"lg"})," Images"),"."),(0,a.kt)("li",{parentName:"ol"},"You can pull a private image from the registry."),(0,a.kt)("li",{parentName:"ol"},"You can push an image to the registry:",(0,a.kt)("ol",{parentName:"li"},(0,a.kt)("li",{parentName:"ol"},"Build an image with the fully qualified name required for your registry, such as ",(0,a.kt)("inlineCode",{parentName:"li"},"quay.io/my-repository/my-image"),", ",(0,a.kt)("inlineCode",{parentName:"li"},"ghcr.io/my-repository/my-image"),", ",(0,a.kt)("inlineCode",{parentName:"li"},"docker.io/my-repository/my-image"),", or ",(0,a.kt)("inlineCode",{parentName:"li"},"my-registry.tld/my-repository/my-image"),"."),(0,a.kt)("li",{parentName:"ol"},"On your image line, click ",(0,a.kt)("strong",{parentName:"li"},(0,a.kt)("icon",{icon:"fa-solid fa-ellipsis-v",size:"lg"})),"."),(0,a.kt)("li",{parentName:"ol"},"The contextual menu has a ",(0,a.kt)("strong",{parentName:"li"},(0,a.kt)("icon",{icon:"fa-solid fa-arrow-up",size:"lg"}),"Push Image")," entry.")))))}o.isMDXComponent=!0},79776:(e,t,r)=>{r.r(t),r.d(t,{assets:()=>y,contentTitle:()=>m,default:()=>h,frontMatter:()=>d,metadata:()=>g,toc:()=>f});var n=r(25773),a=(r(27378),r(35318)),i=r(23930),o=r(39798);const s={toc:[{value:"Prerequisites",id:"prerequisites",level:4},{value:"Procedure",id:"procedure",level:4}]};function l(e){let{components:t,...i}=e;return(0,a.kt)("wrapper",(0,n.Z)({},s,i,{components:t,mdxType:"MDXLayout"}),(0,a.kt)("h4",{id:"prerequisites"},"Prerequisites"),(0,a.kt)("ul",null,(0,a.kt)("li",{parentName:"ul"},(0,a.kt)("a",{parentName:"li",href:"/docs/podman/installing"},"A running Podman machine"),".")),(0,a.kt)("h4",{id:"procedure"},"Procedure"),(0,a.kt)("ol",null,(0,a.kt)("li",{parentName:"ol"},(0,a.kt)("p",{parentName:"li"},"Add your insecure registry within ",(0,a.kt)("strong",{parentName:"p"},(0,a.kt)("icon",{icon:"fa-solid fa-cog",size:"lg"})," Settings > Registries"),"."),(0,a.kt)("p",{parentName:"li"},(0,a.kt)("img",{alt:"Adding a custom registry",src:r(27839).Z,width:"933",height:"501"}))),(0,a.kt)("li",{parentName:"ol"},(0,a.kt)("p",{parentName:"li"},'Click "Yes" to the insecure registry warning.'),(0,a.kt)("p",{parentName:"li"},(0,a.kt)("img",{alt:"Podman Desktop Registry Warning",src:r(8577).Z,width:"556",height:"206"}))),(0,a.kt)("li",{parentName:"ol"},(0,a.kt)("p",{parentName:"li"},"SSH into the Podman Machine to edit ",(0,a.kt)("inlineCode",{parentName:"p"},"registries.conf"),"."),(0,a.kt)("pre",{parentName:"li"},(0,a.kt)("code",{parentName:"pre",className:"language-shell-session"},"$ podman machine ssh [optional-machine-name]\n"))),(0,a.kt)("li",{parentName:"ol"},(0,a.kt)("p",{parentName:"li"},"Open ",(0,a.kt)("inlineCode",{parentName:"p"},"registries.conf"),"."),(0,a.kt)("pre",{parentName:"li"},(0,a.kt)("code",{parentName:"pre",className:"language-shell-session"},"$ sudo vi /etc/containers/registries.conf\n"))),(0,a.kt)("li",{parentName:"ol"},(0,a.kt)("p",{parentName:"li"},"Add the insecure registry: Add a new ",(0,a.kt)("inlineCode",{parentName:"p"},"[[registry]]")," section for the URL of the insecure registry you want to use. For example, if your insecure registry is located at ",(0,a.kt)("inlineCode",{parentName:"p"},"http://registry.example.com"),", add the following lines:"),(0,a.kt)("pre",{parentName:"li"},(0,a.kt)("code",{parentName:"pre",className:"language-toml"},'[[registry]]\nlocation = "registry.example.com"\ninsecure = true\n')),(0,a.kt)("p",{parentName:"li"},"If you have multiple registries, you can add one ",(0,a.kt)("inlineCode",{parentName:"p"},"[[registry]]")," block per registry.")),(0,a.kt)("li",{parentName:"ol"},(0,a.kt)("p",{parentName:"li"},"Save and exit the file.")),(0,a.kt)("li",{parentName:"ol"},(0,a.kt)("p",{parentName:"li"},"Restart Podman by the CLI or through Podman Desktop."),(0,a.kt)("pre",{parentName:"li"},(0,a.kt)("code",{parentName:"pre",className:"language-shell-session"},"$ podman machine stop\n$ podman machine start\n")))))}l.isMDXComponent=!0;const c={toc:[{value:"Prerequisites",id:"prerequisites",level:4},{value:"Procedure",id:"procedure",level:4}]};function u(e){let{components:t,...i}=e;return(0,a.kt)("wrapper",(0,n.Z)({},c,i,{components:t,mdxType:"MDXLayout"}),(0,a.kt)("h4",{id:"prerequisites"},"Prerequisites"),(0,a.kt)("ul",null,(0,a.kt)("li",{parentName:"ul"},"Podman is installed.")),(0,a.kt)("h4",{id:"procedure"},"Procedure"),(0,a.kt)("ol",null,(0,a.kt)("li",{parentName:"ol"},(0,a.kt)("p",{parentName:"li"},"Add your insecure registry within ",(0,a.kt)("strong",{parentName:"p"},(0,a.kt)("icon",{icon:"fa-solid fa-cog",size:"lg"})," Settings > Registries"),"."),(0,a.kt)("p",{parentName:"li"},(0,a.kt)("img",{alt:"Adding a custom registry",src:r(27839).Z,width:"933",height:"501"}))),(0,a.kt)("li",{parentName:"ol"},(0,a.kt)("p",{parentName:"li"},'Click "Yes" to the insecure registry warning.'),(0,a.kt)("p",{parentName:"li"},(0,a.kt)("img",{alt:"Podman Desktop Registry Warning",src:r(8577).Z,width:"556",height:"206"}))),(0,a.kt)("li",{parentName:"ol"},(0,a.kt)("p",{parentName:"li"},"Open ",(0,a.kt)("inlineCode",{parentName:"p"},"registries.conf"),"."),(0,a.kt)("pre",{parentName:"li"},(0,a.kt)("code",{parentName:"pre",className:"language-shell-session"},"$ sudo vi /etc/containers/registries.conf\n"))),(0,a.kt)("li",{parentName:"ol"},(0,a.kt)("p",{parentName:"li"},"Add the insecure registry: Add a new ",(0,a.kt)("inlineCode",{parentName:"p"},"[[registry]]")," section for the URL of the insecure registry you want to use. For example, if your insecure registry is located at ",(0,a.kt)("inlineCode",{parentName:"p"},"http://registry.example.com"),", add the following lines:"),(0,a.kt)("pre",{parentName:"li"},(0,a.kt)("code",{parentName:"pre",className:"language-toml"},'[[registry]]\nlocation = "registry.example.com"\ninsecure = true\n')),(0,a.kt)("p",{parentName:"li"},"If you have multiple registries, you can add one ",(0,a.kt)("inlineCode",{parentName:"p"},"[[registry]]")," block per registry:")),(0,a.kt)("li",{parentName:"ol"},(0,a.kt)("p",{parentName:"li"},"Save and exit the file.")),(0,a.kt)("li",{parentName:"ol"},(0,a.kt)("p",{parentName:"li"},"Restart Podman."),(0,a.kt)("pre",{parentName:"li"},(0,a.kt)("code",{parentName:"pre",className:"language-shell-session"},"$ sudo systemctl restart podman\n")))))}u.isMDXComponent=!0;var p=r(2696);const d={sidebar_position:10,title:"Adding an insecure registry",description:"Modifying Podman for an insecure registry",keywords:["podman desktop","podman","containers","registry","podman machine"],tags:["pods"]},m="Adding an Insecure Registry to Podman Desktop",g={unversionedId:"containers/registries/insecure-registry",id:"containers/registries/insecure-registry",title:"Adding an insecure registry",description:"Modifying Podman for an insecure registry",source:"@site/docs/containers/registries/insecure-registry.md",sourceDirName:"containers/registries",slug:"/containers/registries/insecure-registry",permalink:"/docs/containers/registries/insecure-registry",draft:!1,editUrl:"https://github.com/containers/podman-desktop/tree/main/website/docs/containers/registries/insecure-registry.md",tags:[{label:"pods",permalink:"/docs/tags/pods"}],version:"current",sidebarPosition:10,frontMatter:{sidebar_position:10,title:"Adding an insecure registry",description:"Modifying Podman for an insecure registry",keywords:["podman desktop","podman","containers","registry","podman machine"],tags:["pods"]},sidebar:"mySidebar",previous:{title:"Authenticating to a registry",permalink:"/docs/containers/registries/authenticating-to-a-preconfigured-registry"},next:{title:"Images",permalink:"/docs/containers/images/"}},y={},f=[],k={toc:f};function h(e){let{components:t,...r}=e;return(0,a.kt)("wrapper",(0,n.Z)({},k,r,{components:t,mdxType:"MDXLayout"}),(0,a.kt)("h1",{id:"adding-an-insecure-registry-to-podman-desktop"},"Adding an Insecure Registry to Podman Desktop"),(0,a.kt)("p",null,"In this guide, you will learn how to add an insecure registry to Podman Desktop. An insecure registry allows you to pull and push container images either over an unencrypted HTTP connection, or a HTTPS connection with a self-signed unverified certificate. Please note that using an insecure registry can expose your data to security risks, so it's recommended to use secure connections with a verifiable certificate whenever possible."),(0,a.kt)(i.Z,{groupId:"operating-systems",mdxType:"Tabs"},(0,a.kt)(o.Z,{value:"win",label:"Windows",mdxType:"TabItem"},(0,a.kt)(l,{mdxType:"WindowsMacosProcedure"})),(0,a.kt)(o.Z,{value:"mac",label:"macOS",mdxType:"TabItem"},(0,a.kt)(l,{mdxType:"WindowsMacosProcedure"})),(0,a.kt)(o.Z,{value:"linux",label:"Linux",mdxType:"TabItem"},(0,a.kt)(u,{mdxType:"LinuxProcedure"}))),(0,a.kt)(p.ZP,{mdxType:"Verification"}))}h.isMDXComponent=!0},27839:(e,t,r)=>{r.d(t,{Z:()=>n});const n=r.p+"assets/images/adding-a-custom-registry-df276b8cd69d722de97670c7eef8b235.png"},8577:(e,t,r)=>{r.d(t,{Z:()=>n});const n=r.p+"assets/images/registry-warning-insecure-245d7254807b5939c082f47e5d538d80.png"}}]); \ No newline at end of file diff --git a/assets/js/9dce5486.1c39382d.js b/assets/js/9dce5486.1c39382d.js deleted file mode 100644 index 8481e591529..00000000000 --- a/assets/js/9dce5486.1c39382d.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[8566],{35318:(e,t,n)=>{n.d(t,{Zo:()=>d,kt:()=>u});var a=n(27378);function o(e,t,n){return t in e?Object.defineProperty(e,t,{value:n,enumerable:!0,configurable:!0,writable:!0}):e[t]=n,e}function i(e,t){var n=Object.keys(e);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);t&&(a=a.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),n.push.apply(n,a)}return n}function s(e){for(var t=1;t=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var i=Object.getOwnPropertySymbols(e);for(a=0;a=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var r=a.createContext({}),p=function(e){var t=a.useContext(r),n=t;return e&&(n="function"==typeof e?e(t):s(s({},t),e)),n},d=function(e){var t=p(e.components);return a.createElement(r.Provider,{value:t},e.children)},m={inlineCode:"code",wrapper:function(e){var t=e.children;return a.createElement(a.Fragment,{},t)}},c=a.forwardRef((function(e,t){var n=e.components,o=e.mdxType,i=e.originalType,r=e.parentName,d=l(e,["components","mdxType","originalType","parentName"]),c=p(n),u=o,h=c["".concat(r,".").concat(u)]||c[u]||m[u]||i;return n?a.createElement(h,s(s({ref:t},d),{},{components:n})):a.createElement(h,s({ref:t},d))}));function u(e,t){var n=arguments,o=t&&t.mdxType;if("string"==typeof e||o){var i=n.length,s=new Array(i);s[0]=c;var l={};for(var r in t)hasOwnProperty.call(t,r)&&(l[r]=t[r]);l.originalType=e,l.mdxType="string"==typeof e?e:o,s[1]=l;for(var p=2;p{n.r(t),n.d(t,{assets:()=>r,contentTitle:()=>s,default:()=>m,frontMatter:()=>i,metadata:()=>l,toc:()=>p});var a=n(25773),o=(n(27378),n(35318));const i={title:"Release Notes - Podman Desktop 0.12",description:"Podman Desktop 0.12 has been released!",slug:"podman-desktop-release-0.12",authors:["slemeur"],tags:["podman-desktop","release","kubernetes"],hide_table_of_contents:!1},s=void 0,l={permalink:"/blog/podman-desktop-release-0.12",source:"@site/blog/2023-02-15-release-0.12.md",title:"Release Notes - Podman Desktop 0.12",description:"Podman Desktop 0.12 has been released!",date:"2023-02-15T00:00:00.000Z",formattedDate:"February 15, 2023",tags:[{label:"podman-desktop",permalink:"/blog/tags/podman-desktop"},{label:"release",permalink:"/blog/tags/release"},{label:"kubernetes",permalink:"/blog/tags/kubernetes"}],readingTime:4.505,hasTruncateMarker:!0,authors:[{name:"Stevan Le Meur",title:"Product Manager",url:"https://github.com/slemeur",imageURL:"https://github.com/slemeur.png",key:"slemeur"}],frontMatter:{title:"Release Notes - Podman Desktop 0.12",description:"Podman Desktop 0.12 has been released!",slug:"podman-desktop-release-0.12",authors:["slemeur"],tags:["podman-desktop","release","kubernetes"],hide_table_of_contents:!1},prevItem:{title:"5 things to know about Podman Desktop for a Docker user",permalink:"/blog/5-things-to-know-for-a-docker-user"},nextItem:{title:"Release Notes - Podman Desktop 0.11",permalink:"/blog/podman-desktop-release-0.11"}},r={authorsImageUrls:[void 0]},p=[{value:"Release Details",id:"release-details",level:2},{value:"Update to Podman v4.4.1 #1456",id:"update-to-podman-v441-1456",level:3},{value:"Configuring port mappings when an image has no exported port #1265",id:"configuring-port-mappings-when-an-image-has-no-exported-port-1265",level:3},{value:"Installing Podman Desktop on Windows Home Edition #1268",id:"installing-podman-desktop-on-windows-home-edition-1268",level:3},{value:"Option to automatically minimize Podman Desktop on login #1374",id:"option-to-automatically-minimize-podman-desktop-on-login-1374",level:3},{value:"UI and UX Improvements",id:"ui-and-ux-improvements",level:3},{value:"Improved actions consistency #1225",id:"improved-actions-consistency-1225",level:4},{value:"Consistent status icons for Pods, Containers, Images and Volumes #1326, #1377, #1459 and #1245",id:"consistent-status-icons-for-pods-containers-images-and-volumes-1326-1377-1459-and-1245",level:4},{value:"Placeholder when logs for containers are being fetched #1353",id:"placeholder-when-logs-for-containers-are-being-fetched-1353",level:4},{value:"Fixed alignment in badges from the navigation sidebar #1357",id:"fixed-alignment-in-badges-from-the-navigation-sidebar-1357",level:4},{value:"Enable/disable open browser action based on container state #1395 and #1397",id:"enabledisable-open-browser-action-based-on-container-state-1395-and-1397",level:4},{value:"Other Notable Enhancements",id:"other-notable-enhancements",level:2},{value:"Documentation",id:"documentation",level:2},{value:"Notable bug fixes",id:"notable-bug-fixes",level:2},{value:"Community Thank You",id:"community-thank-you",level:2},{value:"Final Notes",id:"final-notes",level:2}],d={toc:p};function m(e){let{components:t,...i}=e;return(0,o.kt)("wrapper",(0,a.Z)({},d,i,{components:t,mdxType:"MDXLayout"}),(0,o.kt)("p",null,"This release note covers Podman Desktop 0.12 release changes."),(0,o.kt)("ul",null,(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("strong",{parentName:"li"},"Podman Version"),": Podman 4.4.1 now included in Windows and Mac installers."),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("strong",{parentName:"li"},"Containers Configuration"),": Configure port mappings for an image without exported ports."),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("strong",{parentName:"li"},"Windows Home Support"),": Podman Desktop now supports Windows Home Edition."),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("strong",{parentName:"li"},"Start minimized"),": Option to start Podman Desktop minimized to system tray."),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("strong",{parentName:"li"},"UX and UI Improvements"),": Consistent actions, placeholder for logs, unified icons and others.")),(0,o.kt)("p",null,"Podman Desktop 0.12 is now available. ",(0,o.kt)("a",{parentName:"p",href:"/downloads"},"Click here to download it"),"!"),(0,o.kt)("p",null,(0,o.kt)("img",{alt:"podman-desktop-0-12-hero",src:n(34132).Z,width:"1015",height:"580"})),(0,o.kt)("hr",null),(0,o.kt)("h2",{id:"release-details"},"Release Details"),(0,o.kt)("h3",{id:"update-to-podman-v441-1456"},"Update to Podman v4.4.1 ",(0,o.kt)("a",{parentName:"h3",href:"https://github.com/containers/podman-desktop/pull/1456"},"#1456")),(0,o.kt)("p",null,"Podman Desktop 0.12 embeds ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman/releases/tag/v4.4.1"},"Podman 4.4.1")," in Windows and macOS installers. Make sure to upgrade to benefit from the latest Podman features and bug fixes."),(0,o.kt)("h3",{id:"configuring-port-mappings-when-an-image-has-no-exported-port-1265"},"Configuring port mappings when an image has no exported port ",(0,o.kt)("a",{parentName:"h3",href:"https://github.com/containers/podman-desktop/pull/1265"},"#1265")),(0,o.kt)("p",null,"With the latest update, users can now add multiple local-to-remote port mappings when starting a container from an image that has no exported ports. This feature provides users with the flexibility to specify which ports on their local machine should map to which ports on the container, even if the container does not have any exported ports by default."),(0,o.kt)("p",null,(0,o.kt)("img",{parentName:"p",src:"https://user-images.githubusercontent.com/49404737/215112797-86dcf3f0-121a-487e-a71f-ad41e91f93da.gif",alt:"port-mapping"})),(0,o.kt)("h3",{id:"installing-podman-desktop-on-windows-home-edition-1268"},"Installing Podman Desktop on Windows Home Edition ",(0,o.kt)("a",{parentName:"h3",href:"https://github.com/containers/podman-desktop/pull/1268"},"#1268")),(0,o.kt)("p",null,"Podman Desktop 0.12 offers the ability to be installed on Windows Home Edition. The mechanism uses Virtual Machine Platform detection, instead of hyper-v. WSL2 is still requires but can be installed along with the installation process."),(0,o.kt)("p",null,(0,o.kt)("img",{parentName:"p",src:"https://user-images.githubusercontent.com/436777/215121429-7c757aaa-a838-43db-98a2-78ad368f407e.png",alt:"install-windows-home-edition-2"})),(0,o.kt)("h3",{id:"option-to-automatically-minimize-podman-desktop-on-login-1374"},"Option to automatically minimize Podman Desktop on login ",(0,o.kt)("a",{parentName:"h3",href:"https://github.com/containers/podman-desktop/pull/1374"},"#1374")),(0,o.kt)("p",null,'Podman Desktop now provides a "start minimized" option when users log in onto the laptop. This option, available from the application\'s settings, can be useful if users want to automatically launch Podman Desktop at log in, but prefer not to have the window visible on the screen. With this feature, you can ensure that Podman Desktop is up and running in the background without any interruption to your workflows.'),(0,o.kt)("ul",null,(0,o.kt)("li",{parentName:"ul"},"Go to ",(0,o.kt)("strong",{parentName:"li"},(0,o.kt)("icon",{icon:"fa-solid fa-cog",size:"lg"})," Settings > Preferences > Login: Minimize")," to activate the option.")),(0,o.kt)("p",null,(0,o.kt)("img",{parentName:"p",src:"https://user-images.githubusercontent.com/6422176/216651424-bcf756fd-7554-4b24-a838-e3e2f798fe6e.png",alt:"minimize-on-login"})),(0,o.kt)("h3",{id:"ui-and-ux-improvements"},"UI and UX Improvements"),(0,o.kt)("h4",{id:"improved-actions-consistency-1225"},"Improved actions consistency ",(0,o.kt)("a",{parentName:"h4",href:"https://github.com/containers/podman-desktop/pull/1225"},"#1225")),(0,o.kt)("p",null,"Actions displayed in the list pages for Images and Containers have been reviewed and made consistent between other pages."),(0,o.kt)("p",null,(0,o.kt)("img",{parentName:"p",src:"https://user-images.githubusercontent.com/19958075/214104678-2d4148d7-484e-41f9-9da9-aecee328ae2b.png",alt:"action-consistency-1"})),(0,o.kt)("p",null,"Actions displayed in the header of the container's details page have been improved so that the actions are always displayed in the same order."),(0,o.kt)("p",null,(0,o.kt)("img",{parentName:"p",src:"https://user-images.githubusercontent.com/19958075/214104663-64fa0601-bb79-49bf-8226-6a78a88d3622.png",alt:"action-consistency-2"})),(0,o.kt)("h4",{id:"consistent-status-icons-for-pods-containers-images-and-volumes-1326-1377-1459-and-1245"},"Consistent status icons for Pods, Containers, Images and Volumes ",(0,o.kt)("a",{parentName:"h4",href:"https://github.com/containers/podman-desktop/pull/1326"},"#1326"),", ",(0,o.kt)("a",{parentName:"h4",href:"https://github.com/containers/podman-desktop/pull/1377"},"#1377"),", ",(0,o.kt)("a",{parentName:"h4",href:"https://github.com/containers/podman-desktop/pull/1459"},"#1459")," and ",(0,o.kt)("a",{parentName:"h4",href:"https://github.com/containers/podman-desktop/pull/1245"},"#1245")),(0,o.kt)("p",null,"The status icons for Pods, Containers, Images, and Volumes have been unified and use consistent states."),(0,o.kt)("p",null,(0,o.kt)("img",{parentName:"p",src:"https://user-images.githubusercontent.com/19958075/216671859-bdd8dca4-56b7-40a8-961a-dcb6e01be61e.png",alt:"pods-status-icon"})),(0,o.kt)("p",null,"Icons in empty screens have been updated to use the same consistent SVG icon as the status icons."),(0,o.kt)("p",null,(0,o.kt)("img",{parentName:"p",src:"https://user-images.githubusercontent.com/436777/214577726-f4cfde7b-017a-499d-a2a9-e50d455ffaf0.png",alt:"empty-screen-2"})),(0,o.kt)("h4",{id:"placeholder-when-logs-for-containers-are-being-fetched-1353"},"Placeholder when logs for containers are being fetched ",(0,o.kt)("a",{parentName:"h4",href:"https://github.com/containers/podman-desktop/pull/1353"},"#1353")),(0,o.kt)("p",null,"A placeholder is now displayed when logs are being fetched.\n",(0,o.kt)("img",{parentName:"p",src:"https://user-images.githubusercontent.com/49404737/216952505-899308ae-183e-487a-b6e5-28832a0b6452.gif",alt:"placeholder-loading-logs"})),(0,o.kt)("h4",{id:"fixed-alignment-in-badges-from-the-navigation-sidebar-1357"},"Fixed alignment in badges from the navigation sidebar ",(0,o.kt)("a",{parentName:"h4",href:"https://github.com/containers/podman-desktop/pull/1357"},"#1357")),(0,o.kt)("p",null,"Badges in the sidebar are now aligned with the title of the section."),(0,o.kt)("p",null,(0,o.kt)("img",{parentName:"p",src:"https://user-images.githubusercontent.com/49404737/216336502-2a34dea3-fd41-4184-8cfe-9226d70da070.png",alt:"alignement-badges"})),(0,o.kt)("h4",{id:"enabledisable-open-browser-action-based-on-container-state-1395-and-1397"},"Enable/disable open browser action based on container state ",(0,o.kt)("a",{parentName:"h4",href:"https://github.com/containers/podman-desktop/pull/1395"},"#1395")," and ",(0,o.kt)("a",{parentName:"h4",href:"https://github.com/containers/podman-desktop/pull/1397"},"#1397")),(0,o.kt)("p",null,"The action to open the browser if a port is opened in a container, is now disabled when the container is stopped. It is also hidden in the kebab menu."),(0,o.kt)("p",null,(0,o.kt)("img",{parentName:"p",src:"https://user-images.githubusercontent.com/49404737/217284414-1bdc820b-30a8-485e-b0f9-485229026696.gif",alt:"enable-disable-container-actions"})),(0,o.kt)("hr",null),(0,o.kt)("h2",{id:"other-notable-enhancements"},"Other Notable Enhancements"),(0,o.kt)("ul",null,(0,o.kt)("li",{parentName:"ul"},"Display extension icons ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/1058"},"#1058")),(0,o.kt)("li",{parentName:"ul"},"Solid Icons ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/1276"},"#1267")),(0,o.kt)("li",{parentName:"ul"},"Differentiate icons compared to status icons ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/1298"},"#1268")),(0,o.kt)("li",{parentName:"ul"},"Refactors window initializing ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/1309"},"#1309")),(0,o.kt)("li",{parentName:"ul"},"Change window creation background color to dark ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/1310"},"#1310")),(0,o.kt)("li",{parentName:"ul"},"Use Podman ",(0,o.kt)("inlineCode",{parentName:"li"},"machine inspect")," to read the address to connect to the Podman machine ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/1364"},"#1364")),(0,o.kt)("li",{parentName:"ul"},"Update the editor content when the pod name changes, and disable the deploy button when empty ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/1403"},"#1403")),(0,o.kt)("li",{parentName:"ul"},"Ability to manually set color of tray icon for Windows and Linux ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/1243"},"#1243")),(0,o.kt)("li",{parentName:"ul"},"Better UI feedback when starting pods ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/1242"},"#1242"))),(0,o.kt)("hr",null),(0,o.kt)("h2",{id:"documentation"},"Documentation"),(0,o.kt)("p",null,"The documentation had many editorial reviews, and new content."),(0,o.kt)("ul",null,(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("a",{parentName:"li",href:"/docs/installation/windows-install"},"Link to simple WSL2 installation instructions")),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("a",{parentName:"li",href:"/docs/installation/windows-install"},"Refresh Windows Installation")),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("a",{parentName:"li",href:"/docs/installation"},"Revamped installation introduction")),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("a",{parentName:"li",href:"/docs/installation/linux-install"},"Reorganized Linux installation")),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("a",{parentName:"li",href:"/docs/podman/installing-podman-with-openshift-local-on-windows"},"Installing Podman with OpenShift Local")),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("a",{parentName:"li",href:"/docs/installation/windows-install/installing-podman-desktop-and-podman-in-a-restricted-environment"},"Installing Podman Desktop on Windows in a restricted environment")),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("a",{parentName:"li",href:"/docs/migrating-from-docker/using-podman-mac-helper"},"Fixed documentation on ",(0,o.kt)("inlineCode",{parentName:"a"},"podman-mac-helper")," setup"))),(0,o.kt)("hr",null),(0,o.kt)("h2",{id:"notable-bug-fixes"},"Notable bug fixes"),(0,o.kt)("ul",null,(0,o.kt)("li",{parentName:"ul"},"Fixed handling path with spaces on Windows when installing Podman ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/1270"},"#1270")),(0,o.kt)("li",{parentName:"ul"},"Removed padding from SVG icons ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/1253"},"#1253")),(0,o.kt)("li",{parentName:"ul"},"Website: fixed download links for Windows and macOS binaries ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/1255"},"#1255")),(0,o.kt)("li",{parentName:"ul"},"Fixed prettier commands on Windows ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/1267"},"#1266")),(0,o.kt)("li",{parentName:"ul"},"Fixed new xterm instance spawn when clicking the logs route ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/1344"},"#1344")),(0,o.kt)("li",{parentName:"ul"},"Fixed need to wait that telemetry has been initialized before proceeding ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/1373"},"#1373")),(0,o.kt)("li",{parentName:"ul"},"Fixed new xterm instance spawn when clicking the logs route in pod details",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/1393"},"#1393")),(0,o.kt)("li",{parentName:"ul"},"Fixed stop spinner if image cannot be retrieved ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/1394"},"#1394")),(0,o.kt)("li",{parentName:"ul"},"Fixed escape command with quotes only for Windows ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/1462"},"#1462")),(0,o.kt)("li",{parentName:"ul"},"Fixed random CRC status change ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/1420"},"#1420"))),(0,o.kt)("hr",null),(0,o.kt)("h2",{id:"community-thank-you"},"Community Thank You"),(0,o.kt)("p",null,"\ud83c\udf89 We\u2019d like to say a big thank you to everyone who helped to make Podman Desktop 0.12 even better:"),(0,o.kt)("ul",null,(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("a",{parentName:"li",href:"https://github.com/imphil"},"Philipp Wagner")," in ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/1274"},"#1274 - Link to simple WSL2 installation instructions")),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("a",{parentName:"li",href:"https://github.com/arixmkii"},"Arthur S")," in ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/1364"},"#1364 - Get podman machine socketPath from podman machine inspect first")),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("a",{parentName:"li",href:"https://github.com/Mitch9378"},"Mitch West")," in ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/1428"},"#1428 - Fix old documentation for 'podman-mac-helper setup'"))),(0,o.kt)("h2",{id:"final-notes"},"Final Notes"),(0,o.kt)("p",null,"The complete list of issues fixed in this release is available ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/issues?q=is%3Aclosed+milestone%3A0.12.0"},"here"),"."),(0,o.kt)("p",null,"Get the latest release from the ",(0,o.kt)("a",{parentName:"p",href:"/downloads"},"Downloads")," section of the website and boost your development journey with Podman Desktop. Additionally, visit the ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop"},"GitHub repository")," and see how you can help us make Podman Desktop better."))}m.isMDXComponent=!0},34132:(e,t,n)=>{n.d(t,{Z:()=>a});const a=n.p+"assets/images/podman-desktop-release-0.12-d5d46c8986e6e893b9ad30aac05c09f7.png"}}]); \ No newline at end of file diff --git a/assets/js/9dce5486.1e0f7d27.js b/assets/js/9dce5486.1e0f7d27.js new file mode 100644 index 00000000000..a228dcd83c4 --- /dev/null +++ b/assets/js/9dce5486.1e0f7d27.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[8566],{35318:(e,t,n)=>{n.d(t,{Zo:()=>d,kt:()=>u});var a=n(27378);function o(e,t,n){return t in e?Object.defineProperty(e,t,{value:n,enumerable:!0,configurable:!0,writable:!0}):e[t]=n,e}function i(e,t){var n=Object.keys(e);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);t&&(a=a.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),n.push.apply(n,a)}return n}function s(e){for(var t=1;t=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var i=Object.getOwnPropertySymbols(e);for(a=0;a=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var l=a.createContext({}),p=function(e){var t=a.useContext(l),n=t;return e&&(n="function"==typeof e?e(t):s(s({},t),e)),n},d=function(e){var t=p(e.components);return a.createElement(l.Provider,{value:t},e.children)},m={inlineCode:"code",wrapper:function(e){var t=e.children;return a.createElement(a.Fragment,{},t)}},c=a.forwardRef((function(e,t){var n=e.components,o=e.mdxType,i=e.originalType,l=e.parentName,d=r(e,["components","mdxType","originalType","parentName"]),c=p(n),u=o,h=c["".concat(l,".").concat(u)]||c[u]||m[u]||i;return n?a.createElement(h,s(s({ref:t},d),{},{components:n})):a.createElement(h,s({ref:t},d))}));function u(e,t){var n=arguments,o=t&&t.mdxType;if("string"==typeof e||o){var i=n.length,s=new Array(i);s[0]=c;var r={};for(var l in t)hasOwnProperty.call(t,l)&&(r[l]=t[l]);r.originalType=e,r.mdxType="string"==typeof e?e:o,s[1]=r;for(var p=2;p{n.r(t),n.d(t,{assets:()=>l,contentTitle:()=>s,default:()=>u,frontMatter:()=>i,metadata:()=>r,toc:()=>p});var a=n(25773),o=(n(27378),n(35318));const i={title:"Release Notes - Podman Desktop 0.12",description:"Podman Desktop 0.12 has been released!",slug:"podman-desktop-release-0.12",authors:["slemeur"],tags:["podman-desktop","release","kubernetes"],hide_table_of_contents:!1},s=void 0,r={permalink:"/blog/podman-desktop-release-0.12",source:"@site/blog/2023-02-15-release-0.12.md",title:"Release Notes - Podman Desktop 0.12",description:"Podman Desktop 0.12 has been released!",date:"2023-02-15T00:00:00.000Z",formattedDate:"February 15, 2023",tags:[{label:"podman-desktop",permalink:"/blog/tags/podman-desktop"},{label:"release",permalink:"/blog/tags/release"},{label:"kubernetes",permalink:"/blog/tags/kubernetes"}],readingTime:4.505,hasTruncateMarker:!0,authors:[{name:"Stevan Le Meur",title:"Product Manager",url:"https://github.com/slemeur",imageURL:"https://github.com/slemeur.png",key:"slemeur"}],frontMatter:{title:"Release Notes - Podman Desktop 0.12",description:"Podman Desktop 0.12 has been released!",slug:"podman-desktop-release-0.12",authors:["slemeur"],tags:["podman-desktop","release","kubernetes"],hide_table_of_contents:!1},prevItem:{title:"5 things to know about Podman Desktop for a Docker user",permalink:"/blog/5-things-to-know-for-a-docker-user"},nextItem:{title:"Release Notes - Podman Desktop 0.11",permalink:"/blog/podman-desktop-release-0.11"}},l={authorsImageUrls:[void 0]},p=[{value:"Release Details",id:"release-details",level:2},{value:"Update to Podman v4.4.1 #1456",id:"update-to-podman-v441-1456",level:3},{value:"Configuring port mappings when an image has no exported port #1265",id:"configuring-port-mappings-when-an-image-has-no-exported-port-1265",level:3},{value:"Installing Podman Desktop on Windows Home Edition #1268",id:"installing-podman-desktop-on-windows-home-edition-1268",level:3},{value:"Option to automatically minimize Podman Desktop on login #1374",id:"option-to-automatically-minimize-podman-desktop-on-login-1374",level:3},{value:"UI and UX Improvements",id:"ui-and-ux-improvements",level:3},{value:"Improved actions consistency #1225",id:"improved-actions-consistency-1225",level:4},{value:"Consistent status icons for Pods, Containers, Images and Volumes #1326, #1377, #1459 and #1245",id:"consistent-status-icons-for-pods-containers-images-and-volumes-1326-1377-1459-and-1245",level:4},{value:"Placeholder when logs for containers are being fetched #1353",id:"placeholder-when-logs-for-containers-are-being-fetched-1353",level:4},{value:"Fixed alignment in badges from the navigation sidebar #1357",id:"fixed-alignment-in-badges-from-the-navigation-sidebar-1357",level:4},{value:"Enable/disable open browser action based on container state #1395 and #1397",id:"enabledisable-open-browser-action-based-on-container-state-1395-and-1397",level:4},{value:"Other Notable Enhancements",id:"other-notable-enhancements",level:2},{value:"Documentation",id:"documentation",level:2},{value:"Notable bug fixes",id:"notable-bug-fixes",level:2},{value:"Community Thank You",id:"community-thank-you",level:2},{value:"Final Notes",id:"final-notes",level:2}],d=(m="Icon",function(e){return console.warn("Component "+m+" was not imported, exported, or provided by MDXProvider as global scope"),(0,o.kt)("div",e)});var m;const c={toc:p};function u(e){let{components:t,...i}=e;return(0,o.kt)("wrapper",(0,a.Z)({},c,i,{components:t,mdxType:"MDXLayout"}),(0,o.kt)("p",null,"This release note covers Podman Desktop 0.12 release changes."),(0,o.kt)("ul",null,(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("strong",{parentName:"li"},"Podman Version"),": Podman 4.4.1 now included in Windows and Mac installers."),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("strong",{parentName:"li"},"Containers Configuration"),": Configure port mappings for an image without exported ports."),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("strong",{parentName:"li"},"Windows Home Support"),": Podman Desktop now supports Windows Home Edition."),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("strong",{parentName:"li"},"Start minimized"),": Option to start Podman Desktop minimized to system tray."),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("strong",{parentName:"li"},"UX and UI Improvements"),": Consistent actions, placeholder for logs, unified icons and others.")),(0,o.kt)("p",null,"Podman Desktop 0.12 is now available. ",(0,o.kt)("a",{parentName:"p",href:"/downloads"},"Click here to download it"),"!"),(0,o.kt)("p",null,(0,o.kt)("img",{alt:"podman-desktop-0-12-hero",src:n(34132).Z,width:"1015",height:"580"})),(0,o.kt)("hr",null),(0,o.kt)("h2",{id:"release-details"},"Release Details"),(0,o.kt)("h3",{id:"update-to-podman-v441-1456"},"Update to Podman v4.4.1 ",(0,o.kt)("a",{parentName:"h3",href:"https://github.com/containers/podman-desktop/pull/1456"},"#1456")),(0,o.kt)("p",null,"Podman Desktop 0.12 embeds ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman/releases/tag/v4.4.1"},"Podman 4.4.1")," in Windows and macOS installers. Make sure to upgrade to benefit from the latest Podman features and bug fixes."),(0,o.kt)("h3",{id:"configuring-port-mappings-when-an-image-has-no-exported-port-1265"},"Configuring port mappings when an image has no exported port ",(0,o.kt)("a",{parentName:"h3",href:"https://github.com/containers/podman-desktop/pull/1265"},"#1265")),(0,o.kt)("p",null,"With the latest update, users can now add multiple local-to-remote port mappings when starting a container from an image that has no exported ports. This feature provides users with the flexibility to specify which ports on their local machine should map to which ports on the container, even if the container does not have any exported ports by default."),(0,o.kt)("p",null,(0,o.kt)("img",{parentName:"p",src:"https://user-images.githubusercontent.com/49404737/215112797-86dcf3f0-121a-487e-a71f-ad41e91f93da.gif",alt:"port-mapping"})),(0,o.kt)("h3",{id:"installing-podman-desktop-on-windows-home-edition-1268"},"Installing Podman Desktop on Windows Home Edition ",(0,o.kt)("a",{parentName:"h3",href:"https://github.com/containers/podman-desktop/pull/1268"},"#1268")),(0,o.kt)("p",null,"Podman Desktop 0.12 offers the ability to be installed on Windows Home Edition. The mechanism uses Virtual Machine Platform detection, instead of hyper-v. WSL2 is still requires but can be installed along with the installation process."),(0,o.kt)("p",null,(0,o.kt)("img",{parentName:"p",src:"https://user-images.githubusercontent.com/436777/215121429-7c757aaa-a838-43db-98a2-78ad368f407e.png",alt:"install-windows-home-edition-2"})),(0,o.kt)("h3",{id:"option-to-automatically-minimize-podman-desktop-on-login-1374"},"Option to automatically minimize Podman Desktop on login ",(0,o.kt)("a",{parentName:"h3",href:"https://github.com/containers/podman-desktop/pull/1374"},"#1374")),(0,o.kt)("p",null,'Podman Desktop now provides a "start minimized" option when users log in onto the laptop. This option, available from the application\'s settings, can be useful if users want to automatically launch Podman Desktop at log in, but prefer not to have the window visible on the screen. With this feature, you can ensure that Podman Desktop is up and running in the background without any interruption to your workflows.'),(0,o.kt)("ul",null,(0,o.kt)("li",{parentName:"ul"},"Go to ",(0,o.kt)("strong",{parentName:"li"},(0,o.kt)(d,{icon:"fa-solid fa-cog",size:"lg",mdxType:"Icon"})," Settings > Preferences > Login: Minimize")," to activate the option.")),(0,o.kt)("p",null,(0,o.kt)("img",{parentName:"p",src:"https://user-images.githubusercontent.com/6422176/216651424-bcf756fd-7554-4b24-a838-e3e2f798fe6e.png",alt:"minimize-on-login"})),(0,o.kt)("h3",{id:"ui-and-ux-improvements"},"UI and UX Improvements"),(0,o.kt)("h4",{id:"improved-actions-consistency-1225"},"Improved actions consistency ",(0,o.kt)("a",{parentName:"h4",href:"https://github.com/containers/podman-desktop/pull/1225"},"#1225")),(0,o.kt)("p",null,"Actions displayed in the list pages for Images and Containers have been reviewed and made consistent between other pages."),(0,o.kt)("p",null,(0,o.kt)("img",{parentName:"p",src:"https://user-images.githubusercontent.com/19958075/214104678-2d4148d7-484e-41f9-9da9-aecee328ae2b.png",alt:"action-consistency-1"})),(0,o.kt)("p",null,"Actions displayed in the header of the container's details page have been improved so that the actions are always displayed in the same order."),(0,o.kt)("p",null,(0,o.kt)("img",{parentName:"p",src:"https://user-images.githubusercontent.com/19958075/214104663-64fa0601-bb79-49bf-8226-6a78a88d3622.png",alt:"action-consistency-2"})),(0,o.kt)("h4",{id:"consistent-status-icons-for-pods-containers-images-and-volumes-1326-1377-1459-and-1245"},"Consistent status icons for Pods, Containers, Images and Volumes ",(0,o.kt)("a",{parentName:"h4",href:"https://github.com/containers/podman-desktop/pull/1326"},"#1326"),", ",(0,o.kt)("a",{parentName:"h4",href:"https://github.com/containers/podman-desktop/pull/1377"},"#1377"),", ",(0,o.kt)("a",{parentName:"h4",href:"https://github.com/containers/podman-desktop/pull/1459"},"#1459")," and ",(0,o.kt)("a",{parentName:"h4",href:"https://github.com/containers/podman-desktop/pull/1245"},"#1245")),(0,o.kt)("p",null,"The status icons for Pods, Containers, Images, and Volumes have been unified and use consistent states."),(0,o.kt)("p",null,(0,o.kt)("img",{parentName:"p",src:"https://user-images.githubusercontent.com/19958075/216671859-bdd8dca4-56b7-40a8-961a-dcb6e01be61e.png",alt:"pods-status-icon"})),(0,o.kt)("p",null,"Icons in empty screens have been updated to use the same consistent SVG icon as the status icons."),(0,o.kt)("p",null,(0,o.kt)("img",{parentName:"p",src:"https://user-images.githubusercontent.com/436777/214577726-f4cfde7b-017a-499d-a2a9-e50d455ffaf0.png",alt:"empty-screen-2"})),(0,o.kt)("h4",{id:"placeholder-when-logs-for-containers-are-being-fetched-1353"},"Placeholder when logs for containers are being fetched ",(0,o.kt)("a",{parentName:"h4",href:"https://github.com/containers/podman-desktop/pull/1353"},"#1353")),(0,o.kt)("p",null,"A placeholder is now displayed when logs are being fetched.\n",(0,o.kt)("img",{parentName:"p",src:"https://user-images.githubusercontent.com/49404737/216952505-899308ae-183e-487a-b6e5-28832a0b6452.gif",alt:"placeholder-loading-logs"})),(0,o.kt)("h4",{id:"fixed-alignment-in-badges-from-the-navigation-sidebar-1357"},"Fixed alignment in badges from the navigation sidebar ",(0,o.kt)("a",{parentName:"h4",href:"https://github.com/containers/podman-desktop/pull/1357"},"#1357")),(0,o.kt)("p",null,"Badges in the sidebar are now aligned with the title of the section."),(0,o.kt)("p",null,(0,o.kt)("img",{parentName:"p",src:"https://user-images.githubusercontent.com/49404737/216336502-2a34dea3-fd41-4184-8cfe-9226d70da070.png",alt:"alignement-badges"})),(0,o.kt)("h4",{id:"enabledisable-open-browser-action-based-on-container-state-1395-and-1397"},"Enable/disable open browser action based on container state ",(0,o.kt)("a",{parentName:"h4",href:"https://github.com/containers/podman-desktop/pull/1395"},"#1395")," and ",(0,o.kt)("a",{parentName:"h4",href:"https://github.com/containers/podman-desktop/pull/1397"},"#1397")),(0,o.kt)("p",null,"The action to open the browser if a port is opened in a container, is now disabled when the container is stopped. It is also hidden in the kebab menu."),(0,o.kt)("p",null,(0,o.kt)("img",{parentName:"p",src:"https://user-images.githubusercontent.com/49404737/217284414-1bdc820b-30a8-485e-b0f9-485229026696.gif",alt:"enable-disable-container-actions"})),(0,o.kt)("hr",null),(0,o.kt)("h2",{id:"other-notable-enhancements"},"Other Notable Enhancements"),(0,o.kt)("ul",null,(0,o.kt)("li",{parentName:"ul"},"Display extension icons ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/1058"},"#1058")),(0,o.kt)("li",{parentName:"ul"},"Solid Icons ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/1276"},"#1267")),(0,o.kt)("li",{parentName:"ul"},"Differentiate icons compared to status icons ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/1298"},"#1268")),(0,o.kt)("li",{parentName:"ul"},"Refactors window initializing ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/1309"},"#1309")),(0,o.kt)("li",{parentName:"ul"},"Change window creation background color to dark ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/1310"},"#1310")),(0,o.kt)("li",{parentName:"ul"},"Use Podman ",(0,o.kt)("inlineCode",{parentName:"li"},"machine inspect")," to read the address to connect to the Podman machine ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/1364"},"#1364")),(0,o.kt)("li",{parentName:"ul"},"Update the editor content when the pod name changes, and disable the deploy button when empty ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/1403"},"#1403")),(0,o.kt)("li",{parentName:"ul"},"Ability to manually set color of tray icon for Windows and Linux ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/1243"},"#1243")),(0,o.kt)("li",{parentName:"ul"},"Better UI feedback when starting pods ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/1242"},"#1242"))),(0,o.kt)("hr",null),(0,o.kt)("h2",{id:"documentation"},"Documentation"),(0,o.kt)("p",null,"The documentation had many editorial reviews, and new content."),(0,o.kt)("ul",null,(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("a",{parentName:"li",href:"/docs/installation/windows-install"},"Link to simple WSL2 installation instructions")),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("a",{parentName:"li",href:"/docs/installation/windows-install"},"Refresh Windows Installation")),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("a",{parentName:"li",href:"/docs/installation"},"Revamped installation introduction")),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("a",{parentName:"li",href:"/docs/installation/linux-install"},"Reorganized Linux installation")),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("a",{parentName:"li",href:"/docs/podman/installing-podman-with-openshift-local-on-windows"},"Installing Podman with OpenShift Local")),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("a",{parentName:"li",href:"/docs/installation/windows-install/installing-podman-desktop-and-podman-in-a-restricted-environment"},"Installing Podman Desktop on Windows in a restricted environment")),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("a",{parentName:"li",href:"/docs/migrating-from-docker/using-podman-mac-helper"},"Fixed documentation on ",(0,o.kt)("inlineCode",{parentName:"a"},"podman-mac-helper")," setup"))),(0,o.kt)("hr",null),(0,o.kt)("h2",{id:"notable-bug-fixes"},"Notable bug fixes"),(0,o.kt)("ul",null,(0,o.kt)("li",{parentName:"ul"},"Fixed handling path with spaces on Windows when installing Podman ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/1270"},"#1270")),(0,o.kt)("li",{parentName:"ul"},"Removed padding from SVG icons ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/1253"},"#1253")),(0,o.kt)("li",{parentName:"ul"},"Website: fixed download links for Windows and macOS binaries ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/1255"},"#1255")),(0,o.kt)("li",{parentName:"ul"},"Fixed prettier commands on Windows ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/1267"},"#1266")),(0,o.kt)("li",{parentName:"ul"},"Fixed new xterm instance spawn when clicking the logs route ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/1344"},"#1344")),(0,o.kt)("li",{parentName:"ul"},"Fixed need to wait that telemetry has been initialized before proceeding ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/1373"},"#1373")),(0,o.kt)("li",{parentName:"ul"},"Fixed new xterm instance spawn when clicking the logs route in pod details",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/1393"},"#1393")),(0,o.kt)("li",{parentName:"ul"},"Fixed stop spinner if image cannot be retrieved ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/1394"},"#1394")),(0,o.kt)("li",{parentName:"ul"},"Fixed escape command with quotes only for Windows ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/1462"},"#1462")),(0,o.kt)("li",{parentName:"ul"},"Fixed random CRC status change ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/1420"},"#1420"))),(0,o.kt)("hr",null),(0,o.kt)("h2",{id:"community-thank-you"},"Community Thank You"),(0,o.kt)("p",null,"\ud83c\udf89 We\u2019d like to say a big thank you to everyone who helped to make Podman Desktop 0.12 even better:"),(0,o.kt)("ul",null,(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("a",{parentName:"li",href:"https://github.com/imphil"},"Philipp Wagner")," in ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/1274"},"#1274 - Link to simple WSL2 installation instructions")),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("a",{parentName:"li",href:"https://github.com/arixmkii"},"Arthur S")," in ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/1364"},"#1364 - Get podman machine socketPath from podman machine inspect first")),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("a",{parentName:"li",href:"https://github.com/Mitch9378"},"Mitch West")," in ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/1428"},"#1428 - Fix old documentation for 'podman-mac-helper setup'"))),(0,o.kt)("h2",{id:"final-notes"},"Final Notes"),(0,o.kt)("p",null,"The complete list of issues fixed in this release is available ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/issues?q=is%3Aclosed+milestone%3A0.12.0"},"here"),"."),(0,o.kt)("p",null,"Get the latest release from the ",(0,o.kt)("a",{parentName:"p",href:"/downloads"},"Downloads")," section of the website and boost your development journey with Podman Desktop. Additionally, visit the ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop"},"GitHub repository")," and see how you can help us make Podman Desktop better."))}u.isMDXComponent=!0},34132:(e,t,n)=>{n.d(t,{Z:()=>a});const a=n.p+"assets/images/podman-desktop-release-0.12-d5d46c8986e6e893b9ad30aac05c09f7.png"}}]); \ No newline at end of file diff --git a/assets/js/9e8f4e9c.ead1b706.js b/assets/js/9e8f4e9c.d3f71dc8.js similarity index 58% rename from assets/js/9e8f4e9c.ead1b706.js rename to assets/js/9e8f4e9c.d3f71dc8.js index 5524cdaac2a..8e713462b6b 100644 --- a/assets/js/9e8f4e9c.ead1b706.js +++ b/assets/js/9e8f4e9c.d3f71dc8.js @@ -1 +1 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[1074],{35318:(e,t,n)=>{n.d(t,{Zo:()=>c,kt:()=>m});var i=n(27378);function o(e,t,n){return t in e?Object.defineProperty(e,t,{value:n,enumerable:!0,configurable:!0,writable:!0}):e[t]=n,e}function r(e,t){var n=Object.keys(e);if(Object.getOwnPropertySymbols){var i=Object.getOwnPropertySymbols(e);t&&(i=i.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),n.push.apply(n,i)}return n}function a(e){for(var t=1;t=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(e);for(i=0;i=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var l=i.createContext({}),p=function(e){var t=i.useContext(l),n=t;return e&&(n="function"==typeof e?e(t):a(a({},t),e)),n},c=function(e){var t=p(e.components);return i.createElement(l.Provider,{value:t},e.children)},u={inlineCode:"code",wrapper:function(e){var t=e.children;return i.createElement(i.Fragment,{},t)}},d=i.forwardRef((function(e,t){var n=e.components,o=e.mdxType,r=e.originalType,l=e.parentName,c=s(e,["components","mdxType","originalType","parentName"]),d=p(n),m=o,f=d["".concat(l,".").concat(m)]||d[m]||u[m]||r;return n?i.createElement(f,a(a({ref:t},c),{},{components:n})):i.createElement(f,a({ref:t},c))}));function m(e,t){var n=arguments,o=t&&t.mdxType;if("string"==typeof e||o){var r=n.length,a=new Array(r);a[0]=d;var s={};for(var l in t)hasOwnProperty.call(t,l)&&(s[l]=t[l]);s.originalType=e,s.mdxType="string"==typeof e?e:o,a[1]=s;for(var p=2;p{n.r(t),n.d(t,{assets:()=>l,contentTitle:()=>a,default:()=>u,frontMatter:()=>r,metadata:()=>s,toc:()=>p});var i=n(25773),o=(n(27378),n(35318));const r={sidebar_position:4,title:"Installing",description:"Install Podman Desktop extension",tags:["podman-desktop","extension","publishing"],keywords:["podman desktop","extension","publishing"]},a="Installing a Podman Desktop extension",s={unversionedId:"extensions/install/index",id:"extensions/install/index",title:"Installing",description:"Install Podman Desktop extension",source:"@site/docs/extensions/install/index.md",sourceDirName:"extensions/install",slug:"/extensions/install/",permalink:"/docs/extensions/install/",draft:!1,editUrl:"https://github.com/containers/podman-desktop/tree/main/website/docs/extensions/install/index.md",tags:[{label:"podman-desktop",permalink:"/docs/tags/podman-desktop"},{label:"extension",permalink:"/docs/tags/extension"},{label:"publishing",permalink:"/docs/tags/publishing"}],version:"current",sidebarPosition:4,frontMatter:{sidebar_position:4,title:"Installing",description:"Install Podman Desktop extension",tags:["podman-desktop","extension","publishing"],keywords:["podman desktop","extension","publishing"]},sidebar:"mySidebar",previous:{title:"Publishing",permalink:"/docs/extensions/publish/"},next:{title:"Troubleshooting",permalink:"/docs/troubleshooting/"}},l={},p=[{value:"Prerequisites",id:"prerequisites",level:4},{value:"Procedure",id:"procedure",level:4},{value:"Verification",id:"verification",level:4}],c={toc:p};function u(e){let{components:t,...n}=e;return(0,o.kt)("wrapper",(0,i.Z)({},c,n,{components:t,mdxType:"MDXLayout"}),(0,o.kt)("h1",{id:"installing-a-podman-desktop-extension"},"Installing a Podman Desktop extension"),(0,o.kt)("p",null,"Consider installing Podman Desktop extensions to enrich the default capabilities of Podman Desktop."),(0,o.kt)("h4",{id:"prerequisites"},"Prerequisites"),(0,o.kt)("ul",null,(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},"The extension Open Container Initiative (OCI) image name, such as: ",(0,o.kt)("inlineCode",{parentName:"p"},"quay.io/fbenoit/my-first-extension"),"."),(0,o.kt)("p",{parentName:"li"},"See ",(0,o.kt)("a",{parentName:"p",href:"/docs/extensions/publish"},"Publishing a Podman Desktop extension"),"."))),(0,o.kt)("h4",{id:"procedure"},"Procedure"),(0,o.kt)("ol",null,(0,o.kt)("li",{parentName:"ol"},(0,o.kt)("p",{parentName:"li"},"Go to the ",(0,o.kt)("strong",{parentName:"p"},(0,o.kt)("icon",{icon:"fa-solid fa-cog",size:"lg"})," Settings > Extensions"),".")),(0,o.kt)("li",{parentName:"ol"},(0,o.kt)("p",{parentName:"li"},"In the ",(0,o.kt)("strong",{parentName:"p"},"Name of the Image")," field, write the extension OCI image name.")),(0,o.kt)("li",{parentName:"ol"},(0,o.kt)("p",{parentName:"li"},"Click the ",(0,o.kt)("strong",{parentName:"p"},"Install extension from the OCI image")," button."))),(0,o.kt)("h4",{id:"verification"},"Verification"),(0,o.kt)("ul",null,(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},"If Podman Desktop satisfies the minimum required version of the extension, the extension activates.")),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},"Depending on the extension, items can appear in the status bar, tray menu, or other contributions."))))}u.isMDXComponent=!0}}]); \ No newline at end of file +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[1074],{35318:(e,t,n)=>{n.d(t,{Zo:()=>c,kt:()=>m});var i=n(27378);function o(e,t,n){return t in e?Object.defineProperty(e,t,{value:n,enumerable:!0,configurable:!0,writable:!0}):e[t]=n,e}function r(e,t){var n=Object.keys(e);if(Object.getOwnPropertySymbols){var i=Object.getOwnPropertySymbols(e);t&&(i=i.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),n.push.apply(n,i)}return n}function a(e){for(var t=1;t=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(e);for(i=0;i=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var l=i.createContext({}),p=function(e){var t=i.useContext(l),n=t;return e&&(n="function"==typeof e?e(t):a(a({},t),e)),n},c=function(e){var t=p(e.components);return i.createElement(l.Provider,{value:t},e.children)},d={inlineCode:"code",wrapper:function(e){var t=e.children;return i.createElement(i.Fragment,{},t)}},u=i.forwardRef((function(e,t){var n=e.components,o=e.mdxType,r=e.originalType,l=e.parentName,c=s(e,["components","mdxType","originalType","parentName"]),u=p(n),m=o,f=u["".concat(l,".").concat(m)]||u[m]||d[m]||r;return n?i.createElement(f,a(a({ref:t},c),{},{components:n})):i.createElement(f,a({ref:t},c))}));function m(e,t){var n=arguments,o=t&&t.mdxType;if("string"==typeof e||o){var r=n.length,a=new Array(r);a[0]=u;var s={};for(var l in t)hasOwnProperty.call(t,l)&&(s[l]=t[l]);s.originalType=e,s.mdxType="string"==typeof e?e:o,a[1]=s;for(var p=2;p{n.r(t),n.d(t,{assets:()=>l,contentTitle:()=>a,default:()=>m,frontMatter:()=>r,metadata:()=>s,toc:()=>p});var i=n(25773),o=(n(27378),n(35318));const r={sidebar_position:4,title:"Installing",description:"Install Podman Desktop extension",tags:["podman-desktop","extension","publishing"],keywords:["podman desktop","extension","publishing"]},a="Installing a Podman Desktop extension",s={unversionedId:"extensions/install/index",id:"extensions/install/index",title:"Installing",description:"Install Podman Desktop extension",source:"@site/docs/extensions/install/index.md",sourceDirName:"extensions/install",slug:"/extensions/install/",permalink:"/docs/extensions/install/",draft:!1,editUrl:"https://github.com/containers/podman-desktop/tree/main/website/docs/extensions/install/index.md",tags:[{label:"podman-desktop",permalink:"/docs/tags/podman-desktop"},{label:"extension",permalink:"/docs/tags/extension"},{label:"publishing",permalink:"/docs/tags/publishing"}],version:"current",sidebarPosition:4,frontMatter:{sidebar_position:4,title:"Installing",description:"Install Podman Desktop extension",tags:["podman-desktop","extension","publishing"],keywords:["podman desktop","extension","publishing"]},sidebar:"mySidebar",previous:{title:"Publishing",permalink:"/docs/extensions/publish/"},next:{title:"Troubleshooting",permalink:"/docs/troubleshooting/"}},l={},p=[{value:"Prerequisites",id:"prerequisites",level:4},{value:"Procedure",id:"procedure",level:4},{value:"Verification",id:"verification",level:4}],c=(d="Icon",function(e){return console.warn("Component "+d+" was not imported, exported, or provided by MDXProvider as global scope"),(0,o.kt)("div",e)});var d;const u={toc:p};function m(e){let{components:t,...n}=e;return(0,o.kt)("wrapper",(0,i.Z)({},u,n,{components:t,mdxType:"MDXLayout"}),(0,o.kt)("h1",{id:"installing-a-podman-desktop-extension"},"Installing a Podman Desktop extension"),(0,o.kt)("p",null,"Consider installing Podman Desktop extensions to enrich the default capabilities of Podman Desktop."),(0,o.kt)("h4",{id:"prerequisites"},"Prerequisites"),(0,o.kt)("ul",null,(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},"The extension Open Container Initiative (OCI) image name, such as: ",(0,o.kt)("inlineCode",{parentName:"p"},"quay.io/fbenoit/my-first-extension"),"."),(0,o.kt)("p",{parentName:"li"},"See ",(0,o.kt)("a",{parentName:"p",href:"/docs/extensions/publish"},"Publishing a Podman Desktop extension"),"."))),(0,o.kt)("h4",{id:"procedure"},"Procedure"),(0,o.kt)("ol",null,(0,o.kt)("li",{parentName:"ol"},(0,o.kt)("p",{parentName:"li"},"Go to the ",(0,o.kt)("strong",{parentName:"p"},(0,o.kt)(c,{icon:"fa-solid fa-cog",size:"lg",mdxType:"Icon"})," Settings > Extensions"),".")),(0,o.kt)("li",{parentName:"ol"},(0,o.kt)("p",{parentName:"li"},"In the ",(0,o.kt)("strong",{parentName:"p"},"Name of the Image")," field, write the extension OCI image name.")),(0,o.kt)("li",{parentName:"ol"},(0,o.kt)("p",{parentName:"li"},"Click the ",(0,o.kt)("strong",{parentName:"p"},"Install extension from the OCI image")," button."))),(0,o.kt)("h4",{id:"verification"},"Verification"),(0,o.kt)("ul",null,(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},"If Podman Desktop satisfies the minimum required version of the extension, the extension activates.")),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},"Depending on the extension, items can appear in the status bar, tray menu, or other contributions."))))}m.isMDXComponent=!0}}]); \ No newline at end of file diff --git a/assets/js/a00af9f0.76d3862d.js b/assets/js/a00af9f0.76d3862d.js deleted file mode 100644 index ef421cd1fab..00000000000 --- a/assets/js/a00af9f0.76d3862d.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[822],{4047:(e,t,a)=>{a.r(t),a.d(t,{assets:()=>l,contentTitle:()=>r,default:()=>h,frontMatter:()=>i,metadata:()=>p,toc:()=>m});var n=a(25773),o=(a(27378),a(35318)),s=a(92975);const i={title:"Release Notes - Podman Desktop 1.5",description:"Podman Desktop 1.5 has been released!",slug:"podman-desktop-release-1.5",authors:"duffy",tags:["podman-desktop","release","kubernetes","openshift","onboarding","compose","extensions","settings"],hide_table_of_contents:!1,image:"/blog/img/podman-desktop-release-1.5/onboarding-selkies.png"},r=void 0,p={permalink:"/blog/podman-desktop-release-1.5",source:"@site/blog/2023-11-03-release-1.5.md",title:"Release Notes - Podman Desktop 1.5",description:"Podman Desktop 1.5 has been released!",date:"2023-11-03T00:00:00.000Z",formattedDate:"November 3, 2023",tags:[{label:"podman-desktop",permalink:"/blog/tags/podman-desktop"},{label:"release",permalink:"/blog/tags/release"},{label:"kubernetes",permalink:"/blog/tags/kubernetes"},{label:"openshift",permalink:"/blog/tags/openshift"},{label:"onboarding",permalink:"/blog/tags/onboarding"},{label:"compose",permalink:"/blog/tags/compose"},{label:"extensions",permalink:"/blog/tags/extensions"},{label:"settings",permalink:"/blog/tags/settings"}],readingTime:8.14,hasTruncateMarker:!1,authors:[{name:"M\xe1ir\xedn Duffy",title:"User Experience Designer",url:"https://github.com/mairin",imageURL:"https://github.com/mairin.png",key:"duffy"}],frontMatter:{title:"Release Notes - Podman Desktop 1.5",description:"Podman Desktop 1.5 has been released!",slug:"podman-desktop-release-1.5",authors:"duffy",tags:["podman-desktop","release","kubernetes","openshift","onboarding","compose","extensions","settings"],hide_table_of_contents:!1,image:"/blog/img/podman-desktop-release-1.5/onboarding-selkies.png"},nextItem:{title:"Release Notes - Podman Desktop 1.4",permalink:"/blog/podman-desktop-release-1.4"}},l={authorsImageUrls:[void 0]},m=[{value:"Release Details",id:"release-details",level:2},{value:"Onboarding",id:"onboarding",level:3},{value:"Command Palette",id:"command-palette",level:3},{value:"Expanded "Summary" tab for Kubernetes pods",id:"expanded-summary-tab-for-kubernetes-pods",level:3},{value:"Environment file support",id:"environment-file-support",level:3},{value:"Enhancements to the Settings area",id:"enhancements-to-the-settings-area",level:3},{value:"Improved user experience for state changes",id:"improved-user-experience-for-state-changes",level:3},{value:"Extension API improvements",id:"extension-api-improvements",level:3},{value:"Other Notable Enhancements",id:"other-notable-enhancements",level:2},{value:"Notable Bug Fixes",id:"notable-bug-fixes",level:2},{value:"Community Thank You",id:"community-thank-you",level:2},{value:"Final notes",id:"final-notes",level:2},{value:"Known Issues",id:"known-issues",level:3},{value:"Known Issues: Podman Desktop 1.5.2",id:"known-issues-podman-desktop-152",level:4},{value:"Fixed Issues",id:"fixed-issues",level:3},{value:"Where to Download",id:"where-to-download",level:3}],d={toc:m};function h(e){let{components:t,...i}=e;return(0,o.kt)("wrapper",(0,n.Z)({},d,i,{components:t,mdxType:"MDXLayout"}),(0,o.kt)("p",null,"Podman Desktop 1.5 Release! \ud83c\udf89"),(0,o.kt)("p",null,"With this release of Podman Desktop, we're introducing ",(0,o.kt)("strong",{parentName:"p"},"a new onboarding feature")," that we hope will earn your \ud83e\uddad seal of approval! But wait... there's so much more!"),(0,o.kt)("ul",null,(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("strong",{parentName:"li"},"Onboarding"),": Guided setup and configuration of ",(0,o.kt)("strong",{parentName:"li"},"Podman")," and ",(0,o.kt)("strong",{parentName:"li"},"Compose")),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("strong",{parentName:"li"},"Podman 4.7.2"),": ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman/releases"},"Podman 4.7.2")," is now included in Windows and Mac installers"),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("strong",{parentName:"li"},"Command Palette"),": Gain easy access to various commands via a new keyboard-driven command palette"),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("strong",{parentName:"li"},'Expanded "Summary" tab for Kubernetes pods'),': Go deep with extended details on Kubernetes pods in the pod "Summary" tab'),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("strong",{parentName:"li"},"Environment file support"),": Chart out environment variables for new containers to access on creation"),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("strong",{parentName:"li"},"Enhancements to the Settings area"),": Get your bearings with improved Docker compatibility mode controls"),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("strong",{parentName:"li"},"Improved user experience for state changes"),": No more dead reckoning on container state with improved visual indication of status"),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("strong",{parentName:"li"},"Extension API improvements"),": A boatload of improvements to the extension API enabling more goodness from \ud83e\uddad Podman Desktop's extensions")),(0,o.kt)("p",null,"Podman Desktop 1.5 is now available. ",(0,o.kt)("a",{parentName:"p",href:"/downloads"},"Click here to download it"),"!"),(0,o.kt)("p",null,(0,o.kt)("img",{alt:"Podman-desktop-1-5-hero",src:a(90973).Z,width:"1920",height:"1080"})),(0,o.kt)("hr",null),(0,o.kt)("h2",{id:"release-details"},"Release Details"),(0,o.kt)("h3",{id:"onboarding"},"Onboarding"),(0,o.kt)("p",null,"We are introducing a new feature providing guided flows for the initial setup of specific \ud83e\uddad Podman Desktop extensions. Release 1.5 features two new onboarding flows: Podman and Compose."),(0,o.kt)("p",null,'To start the Podman onboarding flow, you can start from the dashboard notification by clicking the "Set up" button:\n',(0,o.kt)("img",{parentName:"p",src:"https://user-images.githubusercontent.com/799683/280362279-598cc052-5ea4-4c31-849c-da9bbbcc3e42.png",alt:"podman-onboarding-start"}),"\n",(0,o.kt)("img",{parentName:"p",src:"https://user-images.githubusercontent.com/799683/280363859-f35b85f8-1dd4-4b7f-a995-25fe5d1ccced.png",alt:"podman-onboarding"})),(0,o.kt)("p",null,"Visit ",(0,o.kt)("strong",{parentName:"p"},(0,o.kt)("icon",{icon:"fa-solid fa-cog",size:"lg"}),"Settings > Resources"),' screen and click the Compose "Setup ..." button in order to start Compose onboarding:\n',(0,o.kt)("img",{parentName:"p",src:"https://user-images.githubusercontent.com/799683/280276847-ca0558ab-70ad-48cc-8dd5-67e3eb465a62.png",alt:"compose-onboarding-start"}),"\n",(0,o.kt)("img",{parentName:"p",src:"https://user-images.githubusercontent.com/799683/280277936-77ba0fb2-5cb0-41de-a7cf-1a3d6400fd89.png",alt:"compose-onboarding"})),(0,o.kt)("h3",{id:"command-palette"},"Command Palette"),(0,o.kt)("p",null,"A new, search-driven command palette is now available to enable quick access to various commands available across \ud83e\uddad Podman Desktop. You can try this new tool out by hitting the F1 key. ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/4081"},"#4081")," ","&","&"," ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/3979"},"#3979")),(0,o.kt)(s.Z,{playing:!0,controls:!0,url:"https://user-images.githubusercontent.com/436777/270362431-5aaa6a1b-6df5-4b66-a811-cdd148d02ad6.mp4",width:"100%",height:"100%",mdxType:"ReactPlayer"}),(0,o.kt)("h3",{id:"expanded-summary-tab-for-kubernetes-pods"},'Expanded "Summary" tab for Kubernetes pods'),(0,o.kt)("p",null,'Kubernetes pods now offer a more comprehensive set of information under the "Summary" tab, including networking, volumes, environment variables, and other key metadata.'),(0,o.kt)(s.Z,{playing:!0,controls:!0,url:"https://user-images.githubusercontent.com/6422176/272972815-bed96f3a-6b13-45d3-a13b-74eacb27a4cd.mov",width:"100%",height:"100%",mdxType:"ReactPlayer"}),(0,o.kt)("h3",{id:"environment-file-support"},"Environment file support"),(0,o.kt)("p",null,"When creating a container from the Images list, there's now an option to provide an environment file to set env variables for the new container. ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/4026"},"#4026")," ","&","&"," ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/4025"},"#4025")),(0,o.kt)("h3",{id:"enhancements-to-the-settings-area"},"Enhancements to the Settings area"),(0,o.kt)("p",null,"The user experience for enabling or disabling Docker compatibility is improved, with a new entry in the ",(0,o.kt)("strong",{parentName:"p"},(0,o.kt)("icon",{icon:"fa-solid fa-cog",size:"lg"}),"Settings > Preferences")," screen that includes contextual guidance. ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/4093"},"#4093")),(0,o.kt)(s.Z,{playing:!0,controls:!0,url:"https://user-images.githubusercontent.com/6422176/270497318-902b2566-62ad-4ee6-87af-6a9a2705de99.mov",width:"100%",height:"100%",mdxType:"ReactPlayer"}),(0,o.kt)("h3",{id:"improved-user-experience-for-state-changes"},"Improved user experience for state changes"),(0,o.kt)("p",null,"The user experience around state changes for containers, pods, and other objects in the UI is improved, with clear status messages and improved animated visual indicator of state changes. ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/4056"},"#4056")),(0,o.kt)(s.Z,{playing:!0,controls:!0,url:"https://user-images.githubusercontent.com/19958075/270027524-f5176cf9-462f-4024-920a-b4a906c7d30d.mov",width:"100%",height:"100%",mdxType:"ReactPlayer"}),(0,o.kt)(s.Z,{playing:!0,controls:!0,url:"https://user-images.githubusercontent.com/19958075/270027533-70e152ec-5bbf-45ad-9f1d-563752464655.mov",width:"100%",height:"100%",mdxType:"ReactPlayer"}),(0,o.kt)("h3",{id:"extension-api-improvements"},"Extension API improvements"),(0,o.kt)("p",null,"The \ud83e\uddad Podman Desktop extension API received many improvements, including:"),(0,o.kt)("ul",null,(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},"In addition to pushing and listing image from an extension, it's now possible to pull images from a \ud83e\uddad Podman Desktop extension ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/4155"},"#4155"))),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},"The \ud83e\uddad Podman Desktop extension API has been enhanced with both the ability to list images ","&"," networks and the ability to create containers ","&"," networks. ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/4172"},"#4172"))),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},"\ud83e\uddad Podman Desktop extensions now have a consistent way to run administrative tasks. ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/4049"},"#4049"))),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},"Extensions now have the ability to register a custom Kubernetes config generator. ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/3970"},"#3970"))),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},"The ability of extensions to add commands to UI menus has been extended; previously for action menus it was only available in the Image list screen. It is now possible for extensions to add commands to the action menus of items listed on the Containers list screen as well. ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/3947"},"#3947")," ","&"," ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/3963"},"#3963"))),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},"Extensions have gained the ability to contribute menu items in the UI based on specific conditions. ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/3959"},"#3959"))),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},"Enhanced logic for displaying or hiding properties listed under the ",(0,o.kt)("strong",{parentName:"p"},(0,o.kt)("icon",{icon:"fa-solid fa-cog",size:"lg"}),"Settings > Preferences")," screens is now available. ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/4159"},"#4159")))),(0,o.kt)(s.Z,{playing:!0,controls:!0,url:"https://user-images.githubusercontent.com/6422176/271650937-3991565c-12a4-4e6c-a315-9343bfa25f65.mov",width:"100%",height:"100%",mdxType:"ReactPlayer"}),(0,o.kt)("hr",null),(0,o.kt)("h2",{id:"other-notable-enhancements"},"Other Notable Enhancements"),(0,o.kt)("ul",null,(0,o.kt)("li",{parentName:"ul"},"The progress of loading an image into Kind is now visible as a task in the task manager. ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/4061"},"#4061"))),(0,o.kt)("p",null,(0,o.kt)("img",{parentName:"p",src:"https://user-images.githubusercontent.com/42176370/270154775-eb7007b4-fd0e-4287-be9e-40ffc412de35.png",alt:"kind-progress-task"})),(0,o.kt)("ul",null,(0,o.kt)("li",{parentName:"ul"},"It's now possible to start a new Podman machine right after creation, or you can create it and wait to start it later. It's up to you! ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/4046"},"#4046"))),(0,o.kt)("p",null,(0,o.kt)("img",{parentName:"p",src:"https://user-images.githubusercontent.com/49404737/269941187-f4768833-ecfc-4d0b-8acf-d4afedb428d9.png",alt:"podman-start-now-or-later"})),(0,o.kt)("ul",null,(0,o.kt)("li",{parentName:"ul"},"The Podman machine and Kubernetes provider creation forms have an updated look & feel consisted with other forms in the user interface, along with minor bug fixes. ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/4317"},"#4317"))),(0,o.kt)("p",null,(0,o.kt)("img",{parentName:"p",src:"https://user-images.githubusercontent.com/19958075/274694157-fe89f3bc-e5b8-4735-96e9-669fe52c7a41.png",alt:"Updated provider creation forms"})),(0,o.kt)("ul",null,(0,o.kt)("li",{parentName:"ul"},"The empty screen message shown when a search filter results in no matches now provides a message specific to filter matching, including the specific filter terms and an explicit button for clearing the filter. Previously, the screen displayed a generic message about how to create new objects of the type displayed on the screen, which led to some confusion about the status of the system. ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/3988"},"#3988"))),(0,o.kt)(s.Z,{playing:!0,controls:!0,url:"https://user-images.githubusercontent.com/19958075/269291090-13e724f7-252f-4915-bb04-00665001d21d.mov",width:"100%",height:"100%",mdxType:"ReactPlayer"}),(0,o.kt)("ul",null,(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},"New support for adding spin animations to icons is now available. ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/4188"},"#4188"))),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},"There is a new indeterminate progress bar type available for the task manager; this is meant for providing limited status for actions whose APIs do not provide detailed status information. ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/4016"},"#4016"))),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},"For authenticating as admin to perform administrative tasks, \ud83e\uddad Podman Desktop now provides touchID support for macOS. ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/4050"},"#4050")))),(0,o.kt)("p",null,(0,o.kt)("img",{parentName:"p",src:"https://user-images.githubusercontent.com/436777/248588015-f08115bd-d211-43ad-bddd-286d7b3a7056.png",alt:"touchID-support"})),(0,o.kt)(s.Z,{playing:!0,controls:!0,url:"https://user-images.githubusercontent.com/436777/269859758-47581e2b-8469-4e9c-822c-f4fddf46684d.mp4",width:"100%",height:"100%",mdxType:"ReactPlayer"}),(0,o.kt)("ul",null,(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},"Support for connecting to interactive terminals for containers via tty was added. ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/3900"},"#3900"))),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},"It's now more clear which container/pod providers will autostart when \ud83e\uddad Podman Desktop starts. Previously autostart had both a global and a per-provider setting. It has been simplified by removing the global setting. ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/3840"},"#3840"))),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},'The "Working with containers" section of the documentation has been reworked and improved. ',(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/3951"},"#3951")))),(0,o.kt)("hr",null),(0,o.kt)("h2",{id:"notable-bug-fixes"},"Notable Bug Fixes"),(0,o.kt)("ul",null,(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},"The disable registry command was not blocking subsequent pulls from disabled registries. This has been corrected. ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/4183"},"#4183"))),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},"Some users behind network proxies were unable to complete workflow involving the download of online resources. The mechanism for fetching these resources has been fixed to be proxy compatible to address this issue. ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/3994"},"#3994"))),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},"The status of pods running in Kubernetes that are undergoing the deletion process is now accurately reflected in the \ud83e\uddad Podman Desktop UI. ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/3877"},"#3877"))),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},'The image details page always listed the image as being "not used" even when it was. This has been corrected. ',(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/3985"},"#3985"))),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},"Previously, deleting a specific image tag would cause all tags with the same Image ID to be deleted. This has been fixed so only the selected image tag will be deleted. ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/3837"},"#3837"))),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},"Could not view the pod details for some remote Kubernetes cluster pods due to an encoding error. ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/4371"},"#4371"))),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},"Error logs were being tracked separately from the actions they applied to. This has been addressed for kind cluster creation failure ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/4427"},"#4427")," and Compose installation failure ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/4407"},"#4407"),".")),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},'For Linux users, \ud83e\uddad Podman Desktop previously did not appear under the "Development" menu when installed via Flatpak; it appeared under "Utilities." \ud83e\uddad Podman Desktop now appears under the "Development" menu. ',(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/3911"},"#3911"))),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},'Podman Machine names are no longer prefixed with the "Podman Machine" string. ',(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/3878"},"#3878")))),(0,o.kt)("p",null,(0,o.kt)("img",{parentName:"p",src:"https://user-images.githubusercontent.com/19958075/267378447-aafdfbd7-f005-4b94-8626-9e11eec61b95.png",alt:"touchID-support"})),(0,o.kt)("ul",null,(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},'The initial action state of pods and containers was being displayed as "STARTING" regardless of actual state; this has been corrected. ',(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/3889"},"#3889"))),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},"Resizing the application window no longer makes the last lines of a container's terminal invisible. ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/3993"},"#3993"))),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},"An issue with incorrect terminal behavior in response to long lines in the terminal attached to a container has been resolved. ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/3955"},"#3955"))),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},"A spacing issue on the run image form has been corrected. ","[#4089]",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/4089"},"https://github.com/containers/podman-desktop/pull/4089"))),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},'The "podify" icon & button on the Containers list was unusually large in release 1.4. That regression has been corrected in this release. ',(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/4122"},"#4122"))),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},"An error in the instructions for Windows users on migrating from Docker has been corrected. ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/4157"},"#4157")))),(0,o.kt)("hr",null),(0,o.kt)("h2",{id:"community-thank-you"},"Community Thank You"),(0,o.kt)("p",null,"\ud83c\udf89 We\u2019d like to say a big thank you to everyone who helped to make \ud83e\uddad Podman Desktop even better. In this\nrelease we received pull requests from the following people:"),(0,o.kt)("ul",null,(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},(0,o.kt)("a",{parentName:"p",href:"https://github.com/afbjorklund"},"afbjorklund")," in ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/4373"},"#4373 - docs: fix broken links and add lima onboarding"),", ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/4372"},"#4372 - docs: clear up lima column on containers page"),", ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/4091"},"#4091 - fix: avoid errors with unexpected JSON input"),", ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/4098"},"#4098 - docs: Lima onboarding details"),", and ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/3854"},"#3854 - fix: check if machine init rootful flag supported"))),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},(0,o.kt)("a",{parentName:"p",href:"https://github.com/axel7083"},"axel7083")," in ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/4061"},"#4061 - feat: adding task progress for kind"),", ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/3970"},"#3970 - feat: extension can register custom kube generator"),", ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/3959"},"#3959 - feat: add when property to extensions menus"),", ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/4016"},"#4016 - feat: indeterminate progress bar"),", ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/3963"},"#3963 - fix: ContainerList propagating containers in ComposeActions and PodActions"),", and ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/3947"},"#3947 - feat: extend menus capabilities"))),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},(0,o.kt)("a",{parentName:"p",href:"https://github.com/ayushrakesh"},"ayushrakesh")," in ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/4415#"},"#4415 - Update README.md"))),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},(0,o.kt)("a",{parentName:"p",href:"https://github.com/eltociear"},"eltociear")," in ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/4194"},"#4194 - Update README.md"))),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},(0,o.kt)("a",{parentName:"p",href:"https://github.com/foxydevloper"},"foxydeveloper")," in ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/4157"},"#4157 - docs: Correct windows instructions for migrating from docker"))),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},(0,o.kt)("a",{parentName:"p",href:"https://github.com/harsh-solanki21"},"harsh-solanki21")," in ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/4162"},"#4162 - fix: Removed fullstop from summary"))),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},(0,o.kt)("a",{parentName:"p",href:"https://github.com/rahul0x00"},"rahul0x00")," in ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/4240"},"#4240 - fix typos in README.md"))),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},(0,o.kt)("a",{parentName:"p",href:"https://github.com/shelar1423"},"shelar1423")," in ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/4221"},"#4221 - chore: document property setting in EXTENSIONS.md")))),(0,o.kt)("hr",null),(0,o.kt)("h2",{id:"final-notes"},"Final notes"),(0,o.kt)("h3",{id:"known-issues"},"Known Issues"),(0,o.kt)("p",null,"We have a discussion board topic where we have posted known issues with this release. If you run into problems, please check this list before filing a bug - if we already have an issue open for it, it saves you the time and trouble of filing, and there may be a workaround posted in the issue."),(0,o.kt)("h4",{id:"known-issues-podman-desktop-152"},(0,o.kt)("a",{parentName:"h4",href:"https://github.com/containers/podman-desktop/discussions/4635"},"Known Issues: Podman Desktop 1.5.2")),(0,o.kt)("h3",{id:"fixed-issues"},"Fixed Issues"),(0,o.kt)("p",null,"The complete list of issues fixed in this release is available ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/issues?q=is%3Aclosed+milestone%3A1.5.0"},"here"),"."),(0,o.kt)("h3",{id:"where-to-download"},"Where to Download"),(0,o.kt)("p",null,"Get the latest release from the ",(0,o.kt)("a",{parentName:"p",href:"/downloads"},"Downloads")," section of the website and boost your development journey with Podman Desktop. Additionally, visit the ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop"},"GitHub repository")," and see how you can help us make Podman Desktop better."))}h.isMDXComponent=!0},90973:(e,t,a)=>{a.d(t,{Z:()=>n});const n=a.p+"assets/images/onboarding-selkies-3ddb7cb6ee2cf9abed002b01f63b1822.png"}}]); \ No newline at end of file diff --git a/assets/js/a00af9f0.ba62cf4a.js b/assets/js/a00af9f0.ba62cf4a.js new file mode 100644 index 00000000000..5ac3f7d31a6 --- /dev/null +++ b/assets/js/a00af9f0.ba62cf4a.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[822],{4047:(e,t,a)=>{a.r(t),a.d(t,{assets:()=>l,contentTitle:()=>r,default:()=>c,frontMatter:()=>i,metadata:()=>p,toc:()=>m});var n=a(25773),o=(a(27378),a(35318)),s=a(92975);const i={title:"Release Notes - Podman Desktop 1.5",description:"Podman Desktop 1.5 has been released!",slug:"podman-desktop-release-1.5",authors:"duffy",tags:["podman-desktop","release","kubernetes","openshift","onboarding","compose","extensions","settings"],hide_table_of_contents:!1,image:"/blog/img/podman-desktop-release-1.5/onboarding-selkies.png"},r=void 0,p={permalink:"/blog/podman-desktop-release-1.5",source:"@site/blog/2023-11-03-release-1.5.md",title:"Release Notes - Podman Desktop 1.5",description:"Podman Desktop 1.5 has been released!",date:"2023-11-03T00:00:00.000Z",formattedDate:"November 3, 2023",tags:[{label:"podman-desktop",permalink:"/blog/tags/podman-desktop"},{label:"release",permalink:"/blog/tags/release"},{label:"kubernetes",permalink:"/blog/tags/kubernetes"},{label:"openshift",permalink:"/blog/tags/openshift"},{label:"onboarding",permalink:"/blog/tags/onboarding"},{label:"compose",permalink:"/blog/tags/compose"},{label:"extensions",permalink:"/blog/tags/extensions"},{label:"settings",permalink:"/blog/tags/settings"}],readingTime:8.14,hasTruncateMarker:!1,authors:[{name:"M\xe1ir\xedn Duffy",title:"User Experience Designer",url:"https://github.com/mairin",imageURL:"https://github.com/mairin.png",key:"duffy"}],frontMatter:{title:"Release Notes - Podman Desktop 1.5",description:"Podman Desktop 1.5 has been released!",slug:"podman-desktop-release-1.5",authors:"duffy",tags:["podman-desktop","release","kubernetes","openshift","onboarding","compose","extensions","settings"],hide_table_of_contents:!1,image:"/blog/img/podman-desktop-release-1.5/onboarding-selkies.png"},nextItem:{title:"Release Notes - Podman Desktop 1.4",permalink:"/blog/podman-desktop-release-1.4"}},l={authorsImageUrls:[void 0]},m=[{value:"Release Details",id:"release-details",level:2},{value:"Onboarding",id:"onboarding",level:3},{value:"Command Palette",id:"command-palette",level:3},{value:"Expanded "Summary" tab for Kubernetes pods",id:"expanded-summary-tab-for-kubernetes-pods",level:3},{value:"Environment file support",id:"environment-file-support",level:3},{value:"Enhancements to the Settings area",id:"enhancements-to-the-settings-area",level:3},{value:"Improved user experience for state changes",id:"improved-user-experience-for-state-changes",level:3},{value:"Extension API improvements",id:"extension-api-improvements",level:3},{value:"Other Notable Enhancements",id:"other-notable-enhancements",level:2},{value:"Notable Bug Fixes",id:"notable-bug-fixes",level:2},{value:"Community Thank You",id:"community-thank-you",level:2},{value:"Final notes",id:"final-notes",level:2},{value:"Known Issues",id:"known-issues",level:3},{value:"Known Issues: Podman Desktop 1.5.2",id:"known-issues-podman-desktop-152",level:4},{value:"Fixed Issues",id:"fixed-issues",level:3},{value:"Where to Download",id:"where-to-download",level:3}],d=(h="Icon",function(e){return console.warn("Component "+h+" was not imported, exported, or provided by MDXProvider as global scope"),(0,o.kt)("div",e)});var h;const u={toc:m};function c(e){let{components:t,...i}=e;return(0,o.kt)("wrapper",(0,n.Z)({},u,i,{components:t,mdxType:"MDXLayout"}),(0,o.kt)("p",null,"Podman Desktop 1.5 Release! \ud83c\udf89"),(0,o.kt)("p",null,"With this release of Podman Desktop, we're introducing ",(0,o.kt)("strong",{parentName:"p"},"a new onboarding feature")," that we hope will earn your \ud83e\uddad seal of approval! But wait... there's so much more!"),(0,o.kt)("ul",null,(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("strong",{parentName:"li"},"Onboarding"),": Guided setup and configuration of ",(0,o.kt)("strong",{parentName:"li"},"Podman")," and ",(0,o.kt)("strong",{parentName:"li"},"Compose")),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("strong",{parentName:"li"},"Podman 4.7.2"),": ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman/releases"},"Podman 4.7.2")," is now included in Windows and Mac installers"),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("strong",{parentName:"li"},"Command Palette"),": Gain easy access to various commands via a new keyboard-driven command palette"),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("strong",{parentName:"li"},'Expanded "Summary" tab for Kubernetes pods'),': Go deep with extended details on Kubernetes pods in the pod "Summary" tab'),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("strong",{parentName:"li"},"Environment file support"),": Chart out environment variables for new containers to access on creation"),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("strong",{parentName:"li"},"Enhancements to the Settings area"),": Get your bearings with improved Docker compatibility mode controls"),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("strong",{parentName:"li"},"Improved user experience for state changes"),": No more dead reckoning on container state with improved visual indication of status"),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("strong",{parentName:"li"},"Extension API improvements"),": A boatload of improvements to the extension API enabling more goodness from \ud83e\uddad Podman Desktop's extensions")),(0,o.kt)("p",null,"Podman Desktop 1.5 is now available. ",(0,o.kt)("a",{parentName:"p",href:"/downloads"},"Click here to download it"),"!"),(0,o.kt)("p",null,(0,o.kt)("img",{alt:"Podman-desktop-1-5-hero",src:a(90973).Z,width:"1920",height:"1080"})),(0,o.kt)("hr",null),(0,o.kt)("h2",{id:"release-details"},"Release Details"),(0,o.kt)("h3",{id:"onboarding"},"Onboarding"),(0,o.kt)("p",null,"We are introducing a new feature providing guided flows for the initial setup of specific \ud83e\uddad Podman Desktop extensions. Release 1.5 features two new onboarding flows: Podman and Compose."),(0,o.kt)("p",null,'To start the Podman onboarding flow, you can start from the dashboard notification by clicking the "Set up" button:\n',(0,o.kt)("img",{parentName:"p",src:"https://user-images.githubusercontent.com/799683/280362279-598cc052-5ea4-4c31-849c-da9bbbcc3e42.png",alt:"podman-onboarding-start"}),"\n",(0,o.kt)("img",{parentName:"p",src:"https://user-images.githubusercontent.com/799683/280363859-f35b85f8-1dd4-4b7f-a995-25fe5d1ccced.png",alt:"podman-onboarding"})),(0,o.kt)("p",null,"Visit ",(0,o.kt)("strong",{parentName:"p"},(0,o.kt)(d,{icon:"fa-solid fa-cog",size:"lg",mdxType:"Icon"}),"Settings > Resources"),' screen and click the Compose "Setup ..." button in order to start Compose onboarding:\n',(0,o.kt)("img",{parentName:"p",src:"https://user-images.githubusercontent.com/799683/280276847-ca0558ab-70ad-48cc-8dd5-67e3eb465a62.png",alt:"compose-onboarding-start"}),"\n",(0,o.kt)("img",{parentName:"p",src:"https://user-images.githubusercontent.com/799683/280277936-77ba0fb2-5cb0-41de-a7cf-1a3d6400fd89.png",alt:"compose-onboarding"})),(0,o.kt)("h3",{id:"command-palette"},"Command Palette"),(0,o.kt)("p",null,"A new, search-driven command palette is now available to enable quick access to various commands available across \ud83e\uddad Podman Desktop. You can try this new tool out by hitting the F1 key. ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/4081"},"#4081")," ","&","&"," ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/3979"},"#3979")),(0,o.kt)(s.Z,{playing:!0,controls:!0,url:"https://user-images.githubusercontent.com/436777/270362431-5aaa6a1b-6df5-4b66-a811-cdd148d02ad6.mp4",width:"100%",height:"100%",mdxType:"ReactPlayer"}),(0,o.kt)("h3",{id:"expanded-summary-tab-for-kubernetes-pods"},'Expanded "Summary" tab for Kubernetes pods'),(0,o.kt)("p",null,'Kubernetes pods now offer a more comprehensive set of information under the "Summary" tab, including networking, volumes, environment variables, and other key metadata.'),(0,o.kt)(s.Z,{playing:!0,controls:!0,url:"https://user-images.githubusercontent.com/6422176/272972815-bed96f3a-6b13-45d3-a13b-74eacb27a4cd.mov",width:"100%",height:"100%",mdxType:"ReactPlayer"}),(0,o.kt)("h3",{id:"environment-file-support"},"Environment file support"),(0,o.kt)("p",null,"When creating a container from the Images list, there's now an option to provide an environment file to set env variables for the new container. ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/4026"},"#4026")," ","&","&"," ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/4025"},"#4025")),(0,o.kt)("h3",{id:"enhancements-to-the-settings-area"},"Enhancements to the Settings area"),(0,o.kt)("p",null,"The user experience for enabling or disabling Docker compatibility is improved, with a new entry in the ",(0,o.kt)("strong",{parentName:"p"},(0,o.kt)(d,{icon:"fa-solid fa-cog",size:"lg",mdxType:"Icon"}),"Settings > Preferences")," screen that includes contextual guidance. ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/4093"},"#4093")),(0,o.kt)(s.Z,{playing:!0,controls:!0,url:"https://user-images.githubusercontent.com/6422176/270497318-902b2566-62ad-4ee6-87af-6a9a2705de99.mov",width:"100%",height:"100%",mdxType:"ReactPlayer"}),(0,o.kt)("h3",{id:"improved-user-experience-for-state-changes"},"Improved user experience for state changes"),(0,o.kt)("p",null,"The user experience around state changes for containers, pods, and other objects in the UI is improved, with clear status messages and improved animated visual indicator of state changes. ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/4056"},"#4056")),(0,o.kt)(s.Z,{playing:!0,controls:!0,url:"https://user-images.githubusercontent.com/19958075/270027524-f5176cf9-462f-4024-920a-b4a906c7d30d.mov",width:"100%",height:"100%",mdxType:"ReactPlayer"}),(0,o.kt)(s.Z,{playing:!0,controls:!0,url:"https://user-images.githubusercontent.com/19958075/270027533-70e152ec-5bbf-45ad-9f1d-563752464655.mov",width:"100%",height:"100%",mdxType:"ReactPlayer"}),(0,o.kt)("h3",{id:"extension-api-improvements"},"Extension API improvements"),(0,o.kt)("p",null,"The \ud83e\uddad Podman Desktop extension API received many improvements, including:"),(0,o.kt)("ul",null,(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},"In addition to pushing and listing image from an extension, it's now possible to pull images from a \ud83e\uddad Podman Desktop extension ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/4155"},"#4155"))),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},"The \ud83e\uddad Podman Desktop extension API has been enhanced with both the ability to list images ","&"," networks and the ability to create containers ","&"," networks. ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/4172"},"#4172"))),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},"\ud83e\uddad Podman Desktop extensions now have a consistent way to run administrative tasks. ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/4049"},"#4049"))),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},"Extensions now have the ability to register a custom Kubernetes config generator. ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/3970"},"#3970"))),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},"The ability of extensions to add commands to UI menus has been extended; previously for action menus it was only available in the Image list screen. It is now possible for extensions to add commands to the action menus of items listed on the Containers list screen as well. ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/3947"},"#3947")," ","&"," ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/3963"},"#3963"))),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},"Extensions have gained the ability to contribute menu items in the UI based on specific conditions. ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/3959"},"#3959"))),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},"Enhanced logic for displaying or hiding properties listed under the ",(0,o.kt)("strong",{parentName:"p"},(0,o.kt)(d,{icon:"fa-solid fa-cog",size:"lg",mdxType:"Icon"}),"Settings > Preferences")," screens is now available. ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/4159"},"#4159")))),(0,o.kt)(s.Z,{playing:!0,controls:!0,url:"https://user-images.githubusercontent.com/6422176/271650937-3991565c-12a4-4e6c-a315-9343bfa25f65.mov",width:"100%",height:"100%",mdxType:"ReactPlayer"}),(0,o.kt)("hr",null),(0,o.kt)("h2",{id:"other-notable-enhancements"},"Other Notable Enhancements"),(0,o.kt)("ul",null,(0,o.kt)("li",{parentName:"ul"},"The progress of loading an image into Kind is now visible as a task in the task manager. ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/4061"},"#4061"))),(0,o.kt)("p",null,(0,o.kt)("img",{parentName:"p",src:"https://user-images.githubusercontent.com/42176370/270154775-eb7007b4-fd0e-4287-be9e-40ffc412de35.png",alt:"kind-progress-task"})),(0,o.kt)("ul",null,(0,o.kt)("li",{parentName:"ul"},"It's now possible to start a new Podman machine right after creation, or you can create it and wait to start it later. It's up to you! ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/4046"},"#4046"))),(0,o.kt)("p",null,(0,o.kt)("img",{parentName:"p",src:"https://user-images.githubusercontent.com/49404737/269941187-f4768833-ecfc-4d0b-8acf-d4afedb428d9.png",alt:"podman-start-now-or-later"})),(0,o.kt)("ul",null,(0,o.kt)("li",{parentName:"ul"},"The Podman machine and Kubernetes provider creation forms have an updated look & feel consisted with other forms in the user interface, along with minor bug fixes. ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/4317"},"#4317"))),(0,o.kt)("p",null,(0,o.kt)("img",{parentName:"p",src:"https://user-images.githubusercontent.com/19958075/274694157-fe89f3bc-e5b8-4735-96e9-669fe52c7a41.png",alt:"Updated provider creation forms"})),(0,o.kt)("ul",null,(0,o.kt)("li",{parentName:"ul"},"The empty screen message shown when a search filter results in no matches now provides a message specific to filter matching, including the specific filter terms and an explicit button for clearing the filter. Previously, the screen displayed a generic message about how to create new objects of the type displayed on the screen, which led to some confusion about the status of the system. ",(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-desktop/pull/3988"},"#3988"))),(0,o.kt)(s.Z,{playing:!0,controls:!0,url:"https://user-images.githubusercontent.com/19958075/269291090-13e724f7-252f-4915-bb04-00665001d21d.mov",width:"100%",height:"100%",mdxType:"ReactPlayer"}),(0,o.kt)("ul",null,(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},"New support for adding spin animations to icons is now available. ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/4188"},"#4188"))),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},"There is a new indeterminate progress bar type available for the task manager; this is meant for providing limited status for actions whose APIs do not provide detailed status information. ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/4016"},"#4016"))),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},"For authenticating as admin to perform administrative tasks, \ud83e\uddad Podman Desktop now provides touchID support for macOS. ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/4050"},"#4050")))),(0,o.kt)("p",null,(0,o.kt)("img",{parentName:"p",src:"https://user-images.githubusercontent.com/436777/248588015-f08115bd-d211-43ad-bddd-286d7b3a7056.png",alt:"touchID-support"})),(0,o.kt)(s.Z,{playing:!0,controls:!0,url:"https://user-images.githubusercontent.com/436777/269859758-47581e2b-8469-4e9c-822c-f4fddf46684d.mp4",width:"100%",height:"100%",mdxType:"ReactPlayer"}),(0,o.kt)("ul",null,(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},"Support for connecting to interactive terminals for containers via tty was added. ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/3900"},"#3900"))),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},"It's now more clear which container/pod providers will autostart when \ud83e\uddad Podman Desktop starts. Previously autostart had both a global and a per-provider setting. It has been simplified by removing the global setting. ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/3840"},"#3840"))),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},'The "Working with containers" section of the documentation has been reworked and improved. ',(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/3951"},"#3951")))),(0,o.kt)("hr",null),(0,o.kt)("h2",{id:"notable-bug-fixes"},"Notable Bug Fixes"),(0,o.kt)("ul",null,(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},"The disable registry command was not blocking subsequent pulls from disabled registries. This has been corrected. ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/4183"},"#4183"))),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},"Some users behind network proxies were unable to complete workflow involving the download of online resources. The mechanism for fetching these resources has been fixed to be proxy compatible to address this issue. ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/3994"},"#3994"))),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},"The status of pods running in Kubernetes that are undergoing the deletion process is now accurately reflected in the \ud83e\uddad Podman Desktop UI. ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/3877"},"#3877"))),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},'The image details page always listed the image as being "not used" even when it was. This has been corrected. ',(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/3985"},"#3985"))),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},"Previously, deleting a specific image tag would cause all tags with the same Image ID to be deleted. This has been fixed so only the selected image tag will be deleted. ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/3837"},"#3837"))),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},"Could not view the pod details for some remote Kubernetes cluster pods due to an encoding error. ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/4371"},"#4371"))),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},"Error logs were being tracked separately from the actions they applied to. This has been addressed for kind cluster creation failure ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/4427"},"#4427")," and Compose installation failure ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/4407"},"#4407"),".")),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},'For Linux users, \ud83e\uddad Podman Desktop previously did not appear under the "Development" menu when installed via Flatpak; it appeared under "Utilities." \ud83e\uddad Podman Desktop now appears under the "Development" menu. ',(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/3911"},"#3911"))),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},'Podman Machine names are no longer prefixed with the "Podman Machine" string. ',(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/3878"},"#3878")))),(0,o.kt)("p",null,(0,o.kt)("img",{parentName:"p",src:"https://user-images.githubusercontent.com/19958075/267378447-aafdfbd7-f005-4b94-8626-9e11eec61b95.png",alt:"touchID-support"})),(0,o.kt)("ul",null,(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},'The initial action state of pods and containers was being displayed as "STARTING" regardless of actual state; this has been corrected. ',(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/3889"},"#3889"))),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},"Resizing the application window no longer makes the last lines of a container's terminal invisible. ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/3993"},"#3993"))),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},"An issue with incorrect terminal behavior in response to long lines in the terminal attached to a container has been resolved. ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/3955"},"#3955"))),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},"A spacing issue on the run image form has been corrected. ","[#4089]",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/4089"},"https://github.com/containers/podman-desktop/pull/4089"))),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},'The "podify" icon & button on the Containers list was unusually large in release 1.4. That regression has been corrected in this release. ',(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/4122"},"#4122"))),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},"An error in the instructions for Windows users on migrating from Docker has been corrected. ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/4157"},"#4157")))),(0,o.kt)("hr",null),(0,o.kt)("h2",{id:"community-thank-you"},"Community Thank You"),(0,o.kt)("p",null,"\ud83c\udf89 We\u2019d like to say a big thank you to everyone who helped to make \ud83e\uddad Podman Desktop even better. In this\nrelease we received pull requests from the following people:"),(0,o.kt)("ul",null,(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},(0,o.kt)("a",{parentName:"p",href:"https://github.com/afbjorklund"},"afbjorklund")," in ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/4373"},"#4373 - docs: fix broken links and add lima onboarding"),", ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/4372"},"#4372 - docs: clear up lima column on containers page"),", ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/4091"},"#4091 - fix: avoid errors with unexpected JSON input"),", ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/4098"},"#4098 - docs: Lima onboarding details"),", and ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/3854"},"#3854 - fix: check if machine init rootful flag supported"))),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},(0,o.kt)("a",{parentName:"p",href:"https://github.com/axel7083"},"axel7083")," in ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/4061"},"#4061 - feat: adding task progress for kind"),", ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/3970"},"#3970 - feat: extension can register custom kube generator"),", ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/3959"},"#3959 - feat: add when property to extensions menus"),", ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/4016"},"#4016 - feat: indeterminate progress bar"),", ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/3963"},"#3963 - fix: ContainerList propagating containers in ComposeActions and PodActions"),", and ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/3947"},"#3947 - feat: extend menus capabilities"))),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},(0,o.kt)("a",{parentName:"p",href:"https://github.com/ayushrakesh"},"ayushrakesh")," in ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/4415#"},"#4415 - Update README.md"))),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},(0,o.kt)("a",{parentName:"p",href:"https://github.com/eltociear"},"eltociear")," in ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/4194"},"#4194 - Update README.md"))),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},(0,o.kt)("a",{parentName:"p",href:"https://github.com/foxydevloper"},"foxydeveloper")," in ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/4157"},"#4157 - docs: Correct windows instructions for migrating from docker"))),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},(0,o.kt)("a",{parentName:"p",href:"https://github.com/harsh-solanki21"},"harsh-solanki21")," in ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/4162"},"#4162 - fix: Removed fullstop from summary"))),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},(0,o.kt)("a",{parentName:"p",href:"https://github.com/rahul0x00"},"rahul0x00")," in ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/4240"},"#4240 - fix typos in README.md"))),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},(0,o.kt)("a",{parentName:"p",href:"https://github.com/shelar1423"},"shelar1423")," in ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/pull/4221"},"#4221 - chore: document property setting in EXTENSIONS.md")))),(0,o.kt)("hr",null),(0,o.kt)("h2",{id:"final-notes"},"Final notes"),(0,o.kt)("h3",{id:"known-issues"},"Known Issues"),(0,o.kt)("p",null,"We have a discussion board topic where we have posted known issues with this release. If you run into problems, please check this list before filing a bug - if we already have an issue open for it, it saves you the time and trouble of filing, and there may be a workaround posted in the issue."),(0,o.kt)("h4",{id:"known-issues-podman-desktop-152"},(0,o.kt)("a",{parentName:"h4",href:"https://github.com/containers/podman-desktop/discussions/4635"},"Known Issues: Podman Desktop 1.5.2")),(0,o.kt)("h3",{id:"fixed-issues"},"Fixed Issues"),(0,o.kt)("p",null,"The complete list of issues fixed in this release is available ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/issues?q=is%3Aclosed+milestone%3A1.5.0"},"here"),"."),(0,o.kt)("h3",{id:"where-to-download"},"Where to Download"),(0,o.kt)("p",null,"Get the latest release from the ",(0,o.kt)("a",{parentName:"p",href:"/downloads"},"Downloads")," section of the website and boost your development journey with Podman Desktop. Additionally, visit the ",(0,o.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop"},"GitHub repository")," and see how you can help us make Podman Desktop better."))}c.isMDXComponent=!0},90973:(e,t,a)=>{a.d(t,{Z:()=>n});const n=a.p+"assets/images/onboarding-selkies-3ddb7cb6ee2cf9abed002b01f63b1822.png"}}]); \ No newline at end of file diff --git a/assets/js/a0323d9f.2002b11a.js b/assets/js/a0323d9f.2002b11a.js deleted file mode 100644 index 15c952ac3e1..00000000000 --- a/assets/js/a0323d9f.2002b11a.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[523],{35318:(e,t,n)=>{n.d(t,{Zo:()=>m,kt:()=>k});var i=n(27378);function a(e,t,n){return t in e?Object.defineProperty(e,t,{value:n,enumerable:!0,configurable:!0,writable:!0}):e[t]=n,e}function r(e,t){var n=Object.keys(e);if(Object.getOwnPropertySymbols){var i=Object.getOwnPropertySymbols(e);t&&(i=i.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),n.push.apply(n,i)}return n}function o(e){for(var t=1;t=0||(a[n]=e[n]);return a}(e,t);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(e);for(i=0;i=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(a[n]=e[n])}return a}var s=i.createContext({}),u=function(e){var t=i.useContext(s),n=t;return e&&(n="function"==typeof e?e(t):o(o({},t),e)),n},m=function(e){var t=u(e.components);return i.createElement(s.Provider,{value:t},e.children)},p={inlineCode:"code",wrapper:function(e){var t=e.children;return i.createElement(i.Fragment,{},t)}},c=i.forwardRef((function(e,t){var n=e.components,a=e.mdxType,r=e.originalType,s=e.parentName,m=l(e,["components","mdxType","originalType","parentName"]),c=u(n),k=a,g=c["".concat(s,".").concat(k)]||c[k]||p[k]||r;return n?i.createElement(g,o(o({ref:t},m),{},{components:n})):i.createElement(g,o({ref:t},m))}));function k(e,t){var n=arguments,a=t&&t.mdxType;if("string"==typeof e||a){var r=n.length,o=new Array(r);o[0]=c;var l={};for(var s in t)hasOwnProperty.call(t,s)&&(l[s]=t[s]);l.originalType=e,l.mdxType="string"==typeof e?e:a,o[1]=l;for(var u=2;u{n.r(t),n.d(t,{assets:()=>s,contentTitle:()=>o,default:()=>p,frontMatter:()=>r,metadata:()=>l,toc:()=>u});var i=n(25773),a=(n(27378),n(35318));const r={sidebar_position:10,title:"Push an image to Minikube",description:"Pushing an image to your Minikube cluster",keywords:["podman desktop","podman","containers","images","migrating","kubernetes"],tags:["migrating-to-kubernetes","images"]},o="Pushing an image to your local Minikube-powered Kubernetes cluster",l={unversionedId:"minikube/pushing-an-image-to-minikube",id:"minikube/pushing-an-image-to-minikube",title:"Push an image to Minikube",description:"Pushing an image to your Minikube cluster",source:"@site/docs/minikube/pushing-an-image-to-minikube.md",sourceDirName:"minikube",slug:"/minikube/pushing-an-image-to-minikube",permalink:"/docs/minikube/pushing-an-image-to-minikube",draft:!1,editUrl:"https://github.com/containers/podman-desktop/tree/main/website/docs/minikube/pushing-an-image-to-minikube.md",tags:[{label:"migrating-to-kubernetes",permalink:"/docs/tags/migrating-to-kubernetes"},{label:"images",permalink:"/docs/tags/images"}],version:"current",sidebarPosition:10,frontMatter:{sidebar_position:10,title:"Push an image to Minikube",description:"Pushing an image to your Minikube cluster",keywords:["podman desktop","podman","containers","images","migrating","kubernetes"],tags:["migrating-to-kubernetes","images"]},sidebar:"mySidebar",previous:{title:"Building and testing an image",permalink:"/docs/minikube/building-an-image-and-testing-it-in-minikube"},next:{title:"Lima",permalink:"/docs/lima/"}},s={},u=[{value:"Prerequisites",id:"prerequisites",level:4},{value:"Procedure",id:"procedure",level:4},{value:"Verification",id:"verification",level:4}],m={toc:u};function p(e){let{components:t,...n}=e;return(0,a.kt)("wrapper",(0,i.Z)({},m,n,{components:t,mdxType:"MDXLayout"}),(0,a.kt)("h1",{id:"pushing-an-image-to-your-local-minikube-powered-kubernetes-cluster"},"Pushing an image to your local Minikube-powered Kubernetes cluster"),(0,a.kt)("p",null,"With Podman Desktop, you can push an image to your local Minikube-powered Kubernetes cluster."),(0,a.kt)("h4",{id:"prerequisites"},"Prerequisites"),(0,a.kt)("ul",null,(0,a.kt)("li",{parentName:"ul"},(0,a.kt)("a",{parentName:"li",href:"/docs/containers"},"You onboarded a container engine"),"."),(0,a.kt)("li",{parentName:"ul"},(0,a.kt)("a",{parentName:"li",href:"/docs/minikube"},"You onboarded a Minikube cluster"),"."),(0,a.kt)("li",{parentName:"ul"},(0,a.kt)("a",{parentName:"li",href:"/docs/minikube/working-with-your-local-minikube-cluster"},"You have set your Kubernetes context to your Minikube cluster"),"."),(0,a.kt)("li",{parentName:"ul"},"Your image is available on the ",(0,a.kt)("strong",{parentName:"li"},"Images")," page: ",(0,a.kt)("inlineCode",{parentName:"li"},":"),".")),(0,a.kt)("h4",{id:"procedure"},"Procedure"),(0,a.kt)("ol",null,(0,a.kt)("li",{parentName:"ol"},"Open ",(0,a.kt)("strong",{parentName:"li"},"Podman Desktop dashboard > ",(0,a.kt)("icon",{icon:"fa-solid fa-cloud",size:"lg"})," Images"),"."),(0,a.kt)("li",{parentName:"ol"},(0,a.kt)("strong",{parentName:"li"},(0,a.kt)("icon",{icon:"fa-solid fa-search",size:"lg"})," Search images"),": ",(0,a.kt)("inlineCode",{parentName:"li"},":"),"."),(0,a.kt)("li",{parentName:"ol"},"Click ",(0,a.kt)("strong",{parentName:"li"},(0,a.kt)("icon",{icon:"fa-solid fa-ellipsis-v",size:"lg"})," > ",(0,a.kt)("icon",{icon:"fa-solid fa-ellipsis-v",size:"lg"})," Push image to Minikube cluster"),"."),(0,a.kt)("li",{parentName:"ol"},"If you created many Minikube clusters, select your Minikube cluster from the list.")),(0,a.kt)("h4",{id:"verification"},"Verification"),(0,a.kt)("p",null,"Minikube enables you to list loaded images, using:"),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-command"},"$ minikube image list\n")),(0,a.kt)("p",null,"You can also create a Pod that uses the loaded image:"),(0,a.kt)("ol",null,(0,a.kt)("li",{parentName:"ol"},(0,a.kt)("p",{parentName:"li"},"Create a ",(0,a.kt)("inlineCode",{parentName:"p"},"verify_my_image.yaml")," Kubernetes YAML file on your workstation.\nReplace the placeholders:"),(0,a.kt)("ul",{parentName:"li"},(0,a.kt)("li",{parentName:"ul"},"Pod ",(0,a.kt)("inlineCode",{parentName:"li"},"name")," and container ",(0,a.kt)("inlineCode",{parentName:"li"},"name")," value must consist of lower case alphanumeric characters, '-' or '.', and must start and end with an alphanumeric character."),(0,a.kt)("li",{parentName:"ul"},"Container ",(0,a.kt)("inlineCode",{parentName:"li"},"image")," value is the image you pushed.")),(0,a.kt)("pre",{parentName:"li"},(0,a.kt)("code",{parentName:"pre",className:"language-yaml"},"apiVersion: v1\nkind: Pod\nmetadata:\n name: \nspec:\n containers:\n - name: \n image: :\n imagePullPolicy: Never\n"))),(0,a.kt)("li",{parentName:"ol"},(0,a.kt)("p",{parentName:"li"},"Open ",(0,a.kt)("strong",{parentName:"p"},(0,a.kt)("icon",{icon:"fa-solid fa-cubes",size:"lg"})," Pods > Play Kubernetes YAML"),"."),(0,a.kt)("ol",{parentName:"li"},(0,a.kt)("li",{parentName:"ol"},(0,a.kt)("strong",{parentName:"li"},"Kubernetes YAML file"),": select your ",(0,a.kt)("inlineCode",{parentName:"li"},"verify_my_image.yaml")," file."),(0,a.kt)("li",{parentName:"ol"},(0,a.kt)("strong",{parentName:"li"},"Select Runtime"),": ",(0,a.kt)("strong",{parentName:"li"},"Using a Kubernetes cluster"),"."),(0,a.kt)("li",{parentName:"ol"},"Click ",(0,a.kt)("strong",{parentName:"li"},"Play"),"."),(0,a.kt)("li",{parentName:"ol"},"Clik ",(0,a.kt)("strong",{parentName:"li"},"Done")))),(0,a.kt)("li",{parentName:"ol"},(0,a.kt)("p",{parentName:"li"},"Open ",(0,a.kt)("strong",{parentName:"p"},(0,a.kt)("icon",{icon:"fa-solid fa-cubes",size:"lg"})," Pods"),".")),(0,a.kt)("li",{parentName:"ol"},(0,a.kt)("p",{parentName:"li"},(0,a.kt)("strong",{parentName:"p"},(0,a.kt)("icon",{icon:"fa-solid fa-search",size:"lg"})," Search pods"),": ",(0,a.kt)("inlineCode",{parentName:"p"},""),".")),(0,a.kt)("li",{parentName:"ol"},(0,a.kt)("p",{parentName:"li"},"The pod ",(0,a.kt)("strong",{parentName:"p"},"Status")," is ",(0,a.kt)("strong",{parentName:"p"},"Running"),"."))))}p.isMDXComponent=!0}}]); \ No newline at end of file diff --git a/assets/js/a0323d9f.5edc8952.js b/assets/js/a0323d9f.5edc8952.js new file mode 100644 index 00000000000..6c27c87332b --- /dev/null +++ b/assets/js/a0323d9f.5edc8952.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[523],{35318:(e,t,n)=>{n.d(t,{Zo:()=>u,kt:()=>k});var i=n(27378);function a(e,t,n){return t in e?Object.defineProperty(e,t,{value:n,enumerable:!0,configurable:!0,writable:!0}):e[t]=n,e}function r(e,t){var n=Object.keys(e);if(Object.getOwnPropertySymbols){var i=Object.getOwnPropertySymbols(e);t&&(i=i.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),n.push.apply(n,i)}return n}function o(e){for(var t=1;t=0||(a[n]=e[n]);return a}(e,t);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(e);for(i=0;i=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(a[n]=e[n])}return a}var s=i.createContext({}),m=function(e){var t=i.useContext(s),n=t;return e&&(n="function"==typeof e?e(t):o(o({},t),e)),n},u=function(e){var t=m(e.components);return i.createElement(s.Provider,{value:t},e.children)},p={inlineCode:"code",wrapper:function(e){var t=e.children;return i.createElement(i.Fragment,{},t)}},c=i.forwardRef((function(e,t){var n=e.components,a=e.mdxType,r=e.originalType,s=e.parentName,u=l(e,["components","mdxType","originalType","parentName"]),c=m(n),k=a,d=c["".concat(s,".").concat(k)]||c[k]||p[k]||r;return n?i.createElement(d,o(o({ref:t},u),{},{components:n})):i.createElement(d,o({ref:t},u))}));function k(e,t){var n=arguments,a=t&&t.mdxType;if("string"==typeof e||a){var r=n.length,o=new Array(r);o[0]=c;var l={};for(var s in t)hasOwnProperty.call(t,s)&&(l[s]=t[s]);l.originalType=e,l.mdxType="string"==typeof e?e:a,o[1]=l;for(var m=2;m{n.r(t),n.d(t,{assets:()=>s,contentTitle:()=>o,default:()=>k,frontMatter:()=>r,metadata:()=>l,toc:()=>m});var i=n(25773),a=(n(27378),n(35318));const r={sidebar_position:10,title:"Push an image to Minikube",description:"Pushing an image to your Minikube cluster",keywords:["podman desktop","podman","containers","images","migrating","kubernetes"],tags:["migrating-to-kubernetes","images"]},o="Pushing an image to your local Minikube-powered Kubernetes cluster",l={unversionedId:"minikube/pushing-an-image-to-minikube",id:"minikube/pushing-an-image-to-minikube",title:"Push an image to Minikube",description:"Pushing an image to your Minikube cluster",source:"@site/docs/minikube/pushing-an-image-to-minikube.md",sourceDirName:"minikube",slug:"/minikube/pushing-an-image-to-minikube",permalink:"/docs/minikube/pushing-an-image-to-minikube",draft:!1,editUrl:"https://github.com/containers/podman-desktop/tree/main/website/docs/minikube/pushing-an-image-to-minikube.md",tags:[{label:"migrating-to-kubernetes",permalink:"/docs/tags/migrating-to-kubernetes"},{label:"images",permalink:"/docs/tags/images"}],version:"current",sidebarPosition:10,frontMatter:{sidebar_position:10,title:"Push an image to Minikube",description:"Pushing an image to your Minikube cluster",keywords:["podman desktop","podman","containers","images","migrating","kubernetes"],tags:["migrating-to-kubernetes","images"]},sidebar:"mySidebar",previous:{title:"Building and testing an image",permalink:"/docs/minikube/building-an-image-and-testing-it-in-minikube"},next:{title:"Lima",permalink:"/docs/lima/"}},s={},m=[{value:"Prerequisites",id:"prerequisites",level:4},{value:"Procedure",id:"procedure",level:4},{value:"Verification",id:"verification",level:4}],u=(p="Icon",function(e){return console.warn("Component "+p+" was not imported, exported, or provided by MDXProvider as global scope"),(0,a.kt)("div",e)});var p;const c={toc:m};function k(e){let{components:t,...n}=e;return(0,a.kt)("wrapper",(0,i.Z)({},c,n,{components:t,mdxType:"MDXLayout"}),(0,a.kt)("h1",{id:"pushing-an-image-to-your-local-minikube-powered-kubernetes-cluster"},"Pushing an image to your local Minikube-powered Kubernetes cluster"),(0,a.kt)("p",null,"With Podman Desktop, you can push an image to your local Minikube-powered Kubernetes cluster."),(0,a.kt)("h4",{id:"prerequisites"},"Prerequisites"),(0,a.kt)("ul",null,(0,a.kt)("li",{parentName:"ul"},(0,a.kt)("a",{parentName:"li",href:"/docs/containers"},"You onboarded a container engine"),"."),(0,a.kt)("li",{parentName:"ul"},(0,a.kt)("a",{parentName:"li",href:"/docs/minikube"},"You onboarded a Minikube cluster"),"."),(0,a.kt)("li",{parentName:"ul"},(0,a.kt)("a",{parentName:"li",href:"/docs/minikube/working-with-your-local-minikube-cluster"},"You have set your Kubernetes context to your Minikube cluster"),"."),(0,a.kt)("li",{parentName:"ul"},"Your image is available on the ",(0,a.kt)("strong",{parentName:"li"},"Images")," page: ",(0,a.kt)("inlineCode",{parentName:"li"},":"),".")),(0,a.kt)("h4",{id:"procedure"},"Procedure"),(0,a.kt)("ol",null,(0,a.kt)("li",{parentName:"ol"},"Open ",(0,a.kt)("strong",{parentName:"li"},"Podman Desktop dashboard > ",(0,a.kt)(u,{icon:"fa-solid fa-cloud",size:"lg",mdxType:"Icon"})," Images"),"."),(0,a.kt)("li",{parentName:"ol"},(0,a.kt)("strong",{parentName:"li"},(0,a.kt)(u,{icon:"fa-solid fa-search",size:"lg",mdxType:"Icon"})," Search images"),": ",(0,a.kt)("inlineCode",{parentName:"li"},":"),"."),(0,a.kt)("li",{parentName:"ol"},"Click ",(0,a.kt)("strong",{parentName:"li"},(0,a.kt)(u,{icon:"fa-solid fa-ellipsis-v",size:"lg",mdxType:"Icon"})," > ",(0,a.kt)(u,{icon:"fa-solid fa-ellipsis-v",size:"lg",mdxType:"Icon"})," Push image to Minikube cluster"),"."),(0,a.kt)("li",{parentName:"ol"},"If you created many Minikube clusters, select your Minikube cluster from the list.")),(0,a.kt)("h4",{id:"verification"},"Verification"),(0,a.kt)("p",null,"Minikube enables you to list loaded images, using:"),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-command"},"$ minikube image list\n")),(0,a.kt)("p",null,"You can also create a Pod that uses the loaded image:"),(0,a.kt)("ol",null,(0,a.kt)("li",{parentName:"ol"},(0,a.kt)("p",{parentName:"li"},"Create a ",(0,a.kt)("inlineCode",{parentName:"p"},"verify_my_image.yaml")," Kubernetes YAML file on your workstation.\nReplace the placeholders:"),(0,a.kt)("ul",{parentName:"li"},(0,a.kt)("li",{parentName:"ul"},"Pod ",(0,a.kt)("inlineCode",{parentName:"li"},"name")," and container ",(0,a.kt)("inlineCode",{parentName:"li"},"name")," value must consist of lower case alphanumeric characters, '-' or '.', and must start and end with an alphanumeric character."),(0,a.kt)("li",{parentName:"ul"},"Container ",(0,a.kt)("inlineCode",{parentName:"li"},"image")," value is the image you pushed.")),(0,a.kt)("pre",{parentName:"li"},(0,a.kt)("code",{parentName:"pre",className:"language-yaml"},"apiVersion: v1\nkind: Pod\nmetadata:\n name: \nspec:\n containers:\n - name: \n image: :\n imagePullPolicy: Never\n"))),(0,a.kt)("li",{parentName:"ol"},(0,a.kt)("p",{parentName:"li"},"Open ",(0,a.kt)("strong",{parentName:"p"},(0,a.kt)(u,{icon:"fa-solid fa-cubes",size:"lg",mdxType:"Icon"})," Pods > Play Kubernetes YAML"),"."),(0,a.kt)("ol",{parentName:"li"},(0,a.kt)("li",{parentName:"ol"},(0,a.kt)("strong",{parentName:"li"},"Kubernetes YAML file"),": select your ",(0,a.kt)("inlineCode",{parentName:"li"},"verify_my_image.yaml")," file."),(0,a.kt)("li",{parentName:"ol"},(0,a.kt)("strong",{parentName:"li"},"Select Runtime"),": ",(0,a.kt)("strong",{parentName:"li"},"Using a Kubernetes cluster"),"."),(0,a.kt)("li",{parentName:"ol"},"Click ",(0,a.kt)("strong",{parentName:"li"},"Play"),"."),(0,a.kt)("li",{parentName:"ol"},"Clik ",(0,a.kt)("strong",{parentName:"li"},"Done")))),(0,a.kt)("li",{parentName:"ol"},(0,a.kt)("p",{parentName:"li"},"Open ",(0,a.kt)("strong",{parentName:"p"},(0,a.kt)(u,{icon:"fa-solid fa-cubes",size:"lg",mdxType:"Icon"})," Pods"),".")),(0,a.kt)("li",{parentName:"ol"},(0,a.kt)("p",{parentName:"li"},(0,a.kt)("strong",{parentName:"p"},(0,a.kt)(u,{icon:"fa-solid fa-search",size:"lg",mdxType:"Icon"})," Search pods"),": ",(0,a.kt)("inlineCode",{parentName:"p"},""),".")),(0,a.kt)("li",{parentName:"ol"},(0,a.kt)("p",{parentName:"li"},"The pod ",(0,a.kt)("strong",{parentName:"p"},"Status")," is ",(0,a.kt)("strong",{parentName:"p"},"Running"),"."))))}k.isMDXComponent=!0}}]); \ No newline at end of file diff --git a/assets/js/a6aa9e1f.cf7d6632.js b/assets/js/a6aa9e1f.a7e9e028.js similarity index 97% rename from assets/js/a6aa9e1f.cf7d6632.js rename to assets/js/a6aa9e1f.a7e9e028.js index 4e2c29987ef..301c6f7b48a 100644 --- a/assets/js/a6aa9e1f.cf7d6632.js +++ b/assets/js/a6aa9e1f.a7e9e028.js @@ -1 +1 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[3089],{63462:(e,t,n)=>{n.r(t),n.d(t,{default:()=>u});var a=n(27378),r=n(38944),l=n(50353),i=n(1123),o=n(75484),s=n(55228),c=n(20013),m=n(60505),g=n(2134);function d(e){const{metadata:t}=e,{siteConfig:{title:n}}=(0,l.Z)(),{blogDescription:r,blogTitle:o,permalink:s}=t,c="/"===s?n:o;return a.createElement(a.Fragment,null,a.createElement(i.d,{title:c,description:r}),a.createElement(m.Z,{tag:"blog_posts_list"}))}function p(e){const{metadata:t,items:n,sidebar:r}=e;return a.createElement(s.Z,{sidebar:r},a.createElement(g.Z,{items:n}),a.createElement(c.Z,{metadata:t}))}function u(e){return a.createElement(i.FG,{className:(0,r.Z)(o.k.wrapper.blogPages,o.k.page.blogListPage)},a.createElement(d,e),a.createElement(p,e))}},20013:(e,t,n)=>{n.d(t,{Z:()=>i});var a=n(27378),r=n(99213),l=n(14582);function i(e){const{metadata:t}=e,{previousPage:n,nextPage:i}=t;return a.createElement("nav",{className:"pagination-nav","aria-label":(0,r.I)({id:"theme.blog.paginator.navAriaLabel",message:"Blog list page navigation",description:"The ARIA label for the blog pagination"})},n&&a.createElement(l.Z,{permalink:n,title:a.createElement(r.Z,{id:"theme.blog.paginator.newerEntries",description:"The label used to navigate to the newer blog posts page (previous page)"},"Newer Entries")}),i&&a.createElement(l.Z,{permalink:i,title:a.createElement(r.Z,{id:"theme.blog.paginator.olderEntries",description:"The label used to navigate to the older blog posts page (next page)"},"Older Entries"),isNext:!0}))}},2134:(e,t,n)=>{n.d(t,{Z:()=>i});var a=n(27378),r=n(70412),l=n(25532);function i(e){let{items:t,component:n=l.Z}=e;return a.createElement(a.Fragment,null,t.map((e=>{let{content:t}=e;return a.createElement(r.n,{key:t.metadata.permalink,content:t},a.createElement(n,null,a.createElement(t,null)))})))}},85978:(e,t,n)=>{n.d(t,{Z:()=>l});var a=n(27378),r=n(10610);function l(e){const t={...e};return t?.code?.length>2&&("$ "===t.code.substring(0,2)||"# "===t.code.substring(0,2)||"> "===t.code.substring(0,2))&&(t.code=t.code.substring(2)),a.createElement(a.Fragment,null,a.createElement(r.Z,t))}},35654:(e,t,n)=>{n.d(t,{Z:()=>s});var a=n(80256),r=n(92739),l=n(30537),i=n(9928),o=n(19374);l.vI.add(i.vnX,o.mRB);const s={...a.Z,icon:r.G}}}]); \ No newline at end of file +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[3089],{63462:(e,t,n)=>{n.r(t),n.d(t,{default:()=>u});var a=n(27378),r=n(38944),l=n(50353),i=n(1123),o=n(75484),s=n(55228),c=n(20013),m=n(60505),g=n(2134);function d(e){const{metadata:t}=e,{siteConfig:{title:n}}=(0,l.Z)(),{blogDescription:r,blogTitle:o,permalink:s}=t,c="/"===s?n:o;return a.createElement(a.Fragment,null,a.createElement(i.d,{title:c,description:r}),a.createElement(m.Z,{tag:"blog_posts_list"}))}function p(e){const{metadata:t,items:n,sidebar:r}=e;return a.createElement(s.Z,{sidebar:r},a.createElement(g.Z,{items:n}),a.createElement(c.Z,{metadata:t}))}function u(e){return a.createElement(i.FG,{className:(0,r.Z)(o.k.wrapper.blogPages,o.k.page.blogListPage)},a.createElement(d,e),a.createElement(p,e))}},20013:(e,t,n)=>{n.d(t,{Z:()=>i});var a=n(27378),r=n(99213),l=n(14582);function i(e){const{metadata:t}=e,{previousPage:n,nextPage:i}=t;return a.createElement("nav",{className:"pagination-nav","aria-label":(0,r.I)({id:"theme.blog.paginator.navAriaLabel",message:"Blog list page navigation",description:"The ARIA label for the blog pagination"})},n&&a.createElement(l.Z,{permalink:n,title:a.createElement(r.Z,{id:"theme.blog.paginator.newerEntries",description:"The label used to navigate to the newer blog posts page (previous page)"},"Newer Entries")}),i&&a.createElement(l.Z,{permalink:i,title:a.createElement(r.Z,{id:"theme.blog.paginator.olderEntries",description:"The label used to navigate to the older blog posts page (next page)"},"Older Entries"),isNext:!0}))}},2134:(e,t,n)=>{n.d(t,{Z:()=>i});var a=n(27378),r=n(70412),l=n(25532);function i(e){let{items:t,component:n=l.Z}=e;return a.createElement(a.Fragment,null,t.map((e=>{let{content:t}=e;return a.createElement(r.n,{key:t.metadata.permalink,content:t},a.createElement(n,null,a.createElement(t,null)))})))}},85978:(e,t,n)=>{n.d(t,{Z:()=>l});var a=n(27378),r=n(10610);function l(e){const t={...e};return t?.code?.length>2&&("$ "===t.code.substring(0,2)||"# "===t.code.substring(0,2)||"> "===t.code.substring(0,2))&&(t.code=t.code.substring(2)),a.createElement(a.Fragment,null,a.createElement(r.Z,t))}},35654:(e,t,n)=>{n.d(t,{Z:()=>s});var a=n(80256),r=n(92739),l=n(30537),i=n(9928),o=n(19374);l.vI.add(i.vnX,o.mRB);const s={...a.Z,Icon:r.G}}}]); \ No newline at end of file diff --git a/assets/js/a8ce95ee.3dd3ba53.js b/assets/js/a8ce95ee.3dd3ba53.js deleted file mode 100644 index 25d1f538c80..00000000000 --- a/assets/js/a8ce95ee.3dd3ba53.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[7159],{35318:(e,t,n)=>{n.d(t,{Zo:()=>m,kt:()=>g});var a=n(27378);function i(e,t,n){return t in e?Object.defineProperty(e,t,{value:n,enumerable:!0,configurable:!0,writable:!0}):e[t]=n,e}function r(e,t){var n=Object.keys(e);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);t&&(a=a.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),n.push.apply(n,a)}return n}function o(e){for(var t=1;t=0||(i[n]=e[n]);return i}(e,t);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(e);for(a=0;a=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(i[n]=e[n])}return i}var s=a.createContext({}),c=function(e){var t=a.useContext(s),n=t;return e&&(n="function"==typeof e?e(t):o(o({},t),e)),n},m=function(e){var t=c(e.components);return a.createElement(s.Provider,{value:t},e.children)},u={inlineCode:"code",wrapper:function(e){var t=e.children;return a.createElement(a.Fragment,{},t)}},p=a.forwardRef((function(e,t){var n=e.components,i=e.mdxType,r=e.originalType,s=e.parentName,m=l(e,["components","mdxType","originalType","parentName"]),p=c(n),g=i,d=p["".concat(s,".").concat(g)]||p[g]||u[g]||r;return n?a.createElement(d,o(o({ref:t},m),{},{components:n})):a.createElement(d,o({ref:t},m))}));function g(e,t){var n=arguments,i=t&&t.mdxType;if("string"==typeof e||i){var r=n.length,o=new Array(r);o[0]=p;var l={};for(var s in t)hasOwnProperty.call(t,s)&&(l[s]=t[s]);l.originalType=e,l.mdxType="string"==typeof e?e:i,o[1]=l;for(var c=2;c{n.r(t),n.d(t,{assets:()=>s,contentTitle:()=>o,default:()=>u,frontMatter:()=>r,metadata:()=>l,toc:()=>c});var a=n(25773),i=(n(27378),n(35318));const r={sidebar_position:22,title:"Pulling an image",description:"Pulling an image to your container engine.",keywords:["podman desktop","podman","containers","images"],tags:["images"]},o="Pulling an image to your container engine",l={unversionedId:"containers/images/pulling-an-image",id:"containers/images/pulling-an-image",title:"Pulling an image",description:"Pulling an image to your container engine.",source:"@site/docs/containers/images/pulling-an-image.md",sourceDirName:"containers/images",slug:"/containers/images/pulling-an-image",permalink:"/docs/containers/images/pulling-an-image",draft:!1,editUrl:"https://github.com/containers/podman-desktop/tree/main/website/docs/containers/images/pulling-an-image.md",tags:[{label:"images",permalink:"/docs/tags/images"}],version:"current",sidebarPosition:22,frontMatter:{sidebar_position:22,title:"Pulling an image",description:"Pulling an image to your container engine.",keywords:["podman desktop","podman","containers","images"],tags:["images"]},sidebar:"mySidebar",previous:{title:"Pushing an image to a registry",permalink:"/docs/containers/images/pushing-an-image-to-a-registry"},next:{title:"Containers",permalink:"/docs/containers/starting-a-container"}},s={},c=[{value:"Prerequisites",id:"prerequisites",level:4},{value:"Procedure",id:"procedure",level:4},{value:"Verification",id:"verification",level:4}],m={toc:c};function u(e){let{components:t,...n}=e;return(0,i.kt)("wrapper",(0,a.Z)({},m,n,{components:t,mdxType:"MDXLayout"}),(0,i.kt)("h1",{id:"pulling-an-image-to-your-container-engine"},"Pulling an image to your container engine"),(0,i.kt)("p",null,"With Podman Desktop, you can pull an image from a registry, to your container engine."),(0,i.kt)("h4",{id:"prerequisites"},"Prerequisites"),(0,i.kt)("ul",null,(0,i.kt)("li",{parentName:"ul"},"The image is available in a registry."),(0,i.kt)("li",{parentName:"ul"},"If the registry or the image are not publicly available, you configured access to the registry on Podman Desktop in ",(0,i.kt)("strong",{parentName:"li"},(0,i.kt)("icon",{icon:"fa-solid fa-cog",size:"lg"})," Settings > Registries"),".")),(0,i.kt)("h4",{id:"procedure"},"Procedure"),(0,i.kt)("ol",null,(0,i.kt)("li",{parentName:"ol"},"Go to ",(0,i.kt)("strong",{parentName:"li"},(0,i.kt)("icon",{icon:"fa-solid fa-cloud",size:"lg"})," Images"),"."),(0,i.kt)("li",{parentName:"ol"},"Click ",(0,i.kt)("strong",{parentName:"li"},(0,i.kt)("icon",{icon:"fa-solid fa-arrow-circle-down",size:"lg"})," Pull an image"),"."),(0,i.kt)("li",{parentName:"ol"},"On the ",(0,i.kt)("strong",{parentName:"li"},"Image to Pull")," screen:",(0,i.kt)("ol",{parentName:"li"},(0,i.kt)("li",{parentName:"ol"},(0,i.kt)("strong",{parentName:"li"},"Image to pull"),": enter the image name, such as ",(0,i.kt)("inlineCode",{parentName:"li"},"quay.io/podman/hello"),". Prefer the fully qualified image name that specifies the registry, to the short name that might lead to registry resolution mistakes."),(0,i.kt)("li",{parentName:"ol"},"Click ",(0,i.kt)("strong",{parentName:"li"},"Pull image"),"."))),(0,i.kt)("li",{parentName:"ol"},"Click ",(0,i.kt)("strong",{parentName:"li"},"Done"),".")),(0,i.kt)("h4",{id:"verification"},"Verification"),(0,i.kt)("ol",null,(0,i.kt)("li",{parentName:"ol"},"Go to ",(0,i.kt)("strong",{parentName:"li"},(0,i.kt)("icon",{icon:"fa-solid fa-cloud",size:"lg"})," Images"),"."),(0,i.kt)("li",{parentName:"ol"},"Click the image name you pulled, such as ",(0,i.kt)("inlineCode",{parentName:"li"},"quay.io/podman/hello"),". Podman Desktop always displays the fully qualified image name."),(0,i.kt)("li",{parentName:"ol"},"Go to ",(0,i.kt)("strong",{parentName:"li"},"Summary"),"."),(0,i.kt)("li",{parentName:"ol"},"Go to ",(0,i.kt)("strong",{parentName:"li"},"History"),".",(0,i.kt)("ol",{parentName:"li"},(0,i.kt)("li",{parentName:"ol"},"Click the output area."),(0,i.kt)("li",{parentName:"ol"},"Enter ",(0,i.kt)("kbd",null,"Ctrl")," + ",(0,i.kt)("kbd",null,"F")," on Windows and Linux, or ",(0,i.kt)("kbd",null,"\u2318")," + ",(0,i.kt)("kbd",null,"F")," on macOS to start searching in the content."))),(0,i.kt)("li",{parentName:"ol"},"Go to ",(0,i.kt)("strong",{parentName:"li"},"Inspect"),".",(0,i.kt)("ol",{parentName:"li"},(0,i.kt)("li",{parentName:"ol"},"Click the output area."),(0,i.kt)("li",{parentName:"ol"},"Enter ",(0,i.kt)("kbd",null,"Ctrl")," + ",(0,i.kt)("kbd",null,"F")," on Windows and Linux, or ",(0,i.kt)("kbd",null,"\u2318")," + ",(0,i.kt)("kbd",null,"F")," on macOS to start searching in the content.")))))}u.isMDXComponent=!0}}]); \ No newline at end of file diff --git a/assets/js/a8ce95ee.49c3ddcc.js b/assets/js/a8ce95ee.49c3ddcc.js new file mode 100644 index 00000000000..142cd3d667d --- /dev/null +++ b/assets/js/a8ce95ee.49c3ddcc.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[7159],{35318:(e,t,n)=>{n.d(t,{Zo:()=>m,kt:()=>g});var a=n(27378);function r(e,t,n){return t in e?Object.defineProperty(e,t,{value:n,enumerable:!0,configurable:!0,writable:!0}):e[t]=n,e}function i(e,t){var n=Object.keys(e);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);t&&(a=a.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),n.push.apply(n,a)}return n}function o(e){for(var t=1;t=0||(r[n]=e[n]);return r}(e,t);if(Object.getOwnPropertySymbols){var i=Object.getOwnPropertySymbols(e);for(a=0;a=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(r[n]=e[n])}return r}var s=a.createContext({}),c=function(e){var t=a.useContext(s),n=t;return e&&(n="function"==typeof e?e(t):o(o({},t),e)),n},m=function(e){var t=c(e.components);return a.createElement(s.Provider,{value:t},e.children)},p={inlineCode:"code",wrapper:function(e){var t=e.children;return a.createElement(a.Fragment,{},t)}},u=a.forwardRef((function(e,t){var n=e.components,r=e.mdxType,i=e.originalType,s=e.parentName,m=l(e,["components","mdxType","originalType","parentName"]),u=c(n),g=r,d=u["".concat(s,".").concat(g)]||u[g]||p[g]||i;return n?a.createElement(d,o(o({ref:t},m),{},{components:n})):a.createElement(d,o({ref:t},m))}));function g(e,t){var n=arguments,r=t&&t.mdxType;if("string"==typeof e||r){var i=n.length,o=new Array(i);o[0]=u;var l={};for(var s in t)hasOwnProperty.call(t,s)&&(l[s]=t[s]);l.originalType=e,l.mdxType="string"==typeof e?e:r,o[1]=l;for(var c=2;c{n.r(t),n.d(t,{assets:()=>s,contentTitle:()=>o,default:()=>g,frontMatter:()=>i,metadata:()=>l,toc:()=>c});var a=n(25773),r=(n(27378),n(35318));const i={sidebar_position:22,title:"Pulling an image",description:"Pulling an image to your container engine.",keywords:["podman desktop","podman","containers","images"],tags:["images"]},o="Pulling an image to your container engine",l={unversionedId:"containers/images/pulling-an-image",id:"containers/images/pulling-an-image",title:"Pulling an image",description:"Pulling an image to your container engine.",source:"@site/docs/containers/images/pulling-an-image.md",sourceDirName:"containers/images",slug:"/containers/images/pulling-an-image",permalink:"/docs/containers/images/pulling-an-image",draft:!1,editUrl:"https://github.com/containers/podman-desktop/tree/main/website/docs/containers/images/pulling-an-image.md",tags:[{label:"images",permalink:"/docs/tags/images"}],version:"current",sidebarPosition:22,frontMatter:{sidebar_position:22,title:"Pulling an image",description:"Pulling an image to your container engine.",keywords:["podman desktop","podman","containers","images"],tags:["images"]},sidebar:"mySidebar",previous:{title:"Pushing an image to a registry",permalink:"/docs/containers/images/pushing-an-image-to-a-registry"},next:{title:"Containers",permalink:"/docs/containers/starting-a-container"}},s={},c=[{value:"Prerequisites",id:"prerequisites",level:4},{value:"Procedure",id:"procedure",level:4},{value:"Verification",id:"verification",level:4}],m=(p="Icon",function(e){return console.warn("Component "+p+" was not imported, exported, or provided by MDXProvider as global scope"),(0,r.kt)("div",e)});var p;const u={toc:c};function g(e){let{components:t,...n}=e;return(0,r.kt)("wrapper",(0,a.Z)({},u,n,{components:t,mdxType:"MDXLayout"}),(0,r.kt)("h1",{id:"pulling-an-image-to-your-container-engine"},"Pulling an image to your container engine"),(0,r.kt)("p",null,"With Podman Desktop, you can pull an image from a registry, to your container engine."),(0,r.kt)("h4",{id:"prerequisites"},"Prerequisites"),(0,r.kt)("ul",null,(0,r.kt)("li",{parentName:"ul"},"The image is available in a registry."),(0,r.kt)("li",{parentName:"ul"},"If the registry or the image are not publicly available, you configured access to the registry on Podman Desktop in ",(0,r.kt)("strong",{parentName:"li"},(0,r.kt)(m,{icon:"fa-solid fa-cog",size:"lg",mdxType:"Icon"})," Settings > Registries"),".")),(0,r.kt)("h4",{id:"procedure"},"Procedure"),(0,r.kt)("ol",null,(0,r.kt)("li",{parentName:"ol"},"Go to ",(0,r.kt)("strong",{parentName:"li"},(0,r.kt)(m,{icon:"fa-solid fa-cloud",size:"lg",mdxType:"Icon"})," Images"),"."),(0,r.kt)("li",{parentName:"ol"},"Click ",(0,r.kt)("strong",{parentName:"li"},(0,r.kt)(m,{icon:"fa-solid fa-arrow-circle-down",size:"lg",mdxType:"Icon"})," Pull an image"),"."),(0,r.kt)("li",{parentName:"ol"},"On the ",(0,r.kt)("strong",{parentName:"li"},"Image to Pull")," screen:",(0,r.kt)("ol",{parentName:"li"},(0,r.kt)("li",{parentName:"ol"},(0,r.kt)("strong",{parentName:"li"},"Image to pull"),": enter the image name, such as ",(0,r.kt)("inlineCode",{parentName:"li"},"quay.io/podman/hello"),". Prefer the fully qualified image name that specifies the registry, to the short name that might lead to registry resolution mistakes."),(0,r.kt)("li",{parentName:"ol"},"Click ",(0,r.kt)("strong",{parentName:"li"},"Pull image"),"."))),(0,r.kt)("li",{parentName:"ol"},"Click ",(0,r.kt)("strong",{parentName:"li"},"Done"),".")),(0,r.kt)("h4",{id:"verification"},"Verification"),(0,r.kt)("ol",null,(0,r.kt)("li",{parentName:"ol"},"Go to ",(0,r.kt)("strong",{parentName:"li"},(0,r.kt)(m,{icon:"fa-solid fa-cloud",size:"lg",mdxType:"Icon"})," Images"),"."),(0,r.kt)("li",{parentName:"ol"},"Click the image name you pulled, such as ",(0,r.kt)("inlineCode",{parentName:"li"},"quay.io/podman/hello"),". Podman Desktop always displays the fully qualified image name."),(0,r.kt)("li",{parentName:"ol"},"Go to ",(0,r.kt)("strong",{parentName:"li"},"Summary"),"."),(0,r.kt)("li",{parentName:"ol"},"Go to ",(0,r.kt)("strong",{parentName:"li"},"History"),".",(0,r.kt)("ol",{parentName:"li"},(0,r.kt)("li",{parentName:"ol"},"Click the output area."),(0,r.kt)("li",{parentName:"ol"},"Enter ",(0,r.kt)("kbd",null,"Ctrl")," + ",(0,r.kt)("kbd",null,"F")," on Windows and Linux, or ",(0,r.kt)("kbd",null,"\u2318")," + ",(0,r.kt)("kbd",null,"F")," on macOS to start searching in the content."))),(0,r.kt)("li",{parentName:"ol"},"Go to ",(0,r.kt)("strong",{parentName:"li"},"Inspect"),".",(0,r.kt)("ol",{parentName:"li"},(0,r.kt)("li",{parentName:"ol"},"Click the output area."),(0,r.kt)("li",{parentName:"ol"},"Enter ",(0,r.kt)("kbd",null,"Ctrl")," + ",(0,r.kt)("kbd",null,"F")," on Windows and Linux, or ",(0,r.kt)("kbd",null,"\u2318")," + ",(0,r.kt)("kbd",null,"F")," on macOS to start searching in the content.")))))}g.isMDXComponent=!0}}]); \ No newline at end of file diff --git a/assets/js/aaabcfd8.1dc6e4a1.js b/assets/js/aaabcfd8.1dc6e4a1.js new file mode 100644 index 00000000000..ddbfa5952d9 --- /dev/null +++ b/assets/js/aaabcfd8.1dc6e4a1.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[6932],{35318:(e,t,n)=>{n.d(t,{Zo:()=>p,kt:()=>d});var a=n(27378);function r(e,t,n){return t in e?Object.defineProperty(e,t,{value:n,enumerable:!0,configurable:!0,writable:!0}):e[t]=n,e}function i(e,t){var n=Object.keys(e);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);t&&(a=a.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),n.push.apply(n,a)}return n}function o(e){for(var t=1;t=0||(r[n]=e[n]);return r}(e,t);if(Object.getOwnPropertySymbols){var i=Object.getOwnPropertySymbols(e);for(a=0;a=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(r[n]=e[n])}return r}var l=a.createContext({}),c=function(e){var t=a.useContext(l),n=t;return e&&(n="function"==typeof e?e(t):o(o({},t),e)),n},p=function(e){var t=c(e.components);return a.createElement(l.Provider,{value:t},e.children)},m={inlineCode:"code",wrapper:function(e){var t=e.children;return a.createElement(a.Fragment,{},t)}},u=a.forwardRef((function(e,t){var n=e.components,r=e.mdxType,i=e.originalType,l=e.parentName,p=s(e,["components","mdxType","originalType","parentName"]),u=c(n),d=r,k=u["".concat(l,".").concat(d)]||u[d]||m[d]||i;return n?a.createElement(k,o(o({ref:t},p),{},{components:n})):a.createElement(k,o({ref:t},p))}));function d(e,t){var n=arguments,r=t&&t.mdxType;if("string"==typeof e||r){var i=n.length,o=new Array(i);o[0]=u;var s={};for(var l in t)hasOwnProperty.call(t,l)&&(s[l]=t[l]);s.originalType=e,s.mdxType="string"==typeof e?e:r,o[1]=s;for(var c=2;c{n.r(t),n.d(t,{assets:()=>l,contentTitle:()=>o,default:()=>d,frontMatter:()=>i,metadata:()=>s,toc:()=>c});var a=n(25773),r=(n(27378),n(35318));const i={sidebar_position:3,title:"Lima instance for Kubernetes",description:"Podman Desktop can assist you to create a custom Lima instance on Linux and macOS.",tags:["podman-desktop","kubernetes","onboarding","linux","macOS"],keywords:["podman desktop","kubernetes","lima","onboarding","linux","macos"]},o="Creating a Lima instance for Kubernetes workloads with Podman Desktop",s={unversionedId:"lima/creating-a-kubernetes-instance",id:"lima/creating-a-kubernetes-instance",title:"Lima instance for Kubernetes",description:"Podman Desktop can assist you to create a custom Lima instance on Linux and macOS.",source:"@site/docs/lima/creating-a-kubernetes-instance.md",sourceDirName:"lima",slug:"/lima/creating-a-kubernetes-instance",permalink:"/docs/lima/creating-a-kubernetes-instance",draft:!1,editUrl:"https://github.com/containers/podman-desktop/tree/main/website/docs/lima/creating-a-kubernetes-instance.md",tags:[{label:"podman-desktop",permalink:"/docs/tags/podman-desktop"},{label:"kubernetes",permalink:"/docs/tags/kubernetes"},{label:"onboarding",permalink:"/docs/tags/onboarding"},{label:"linux",permalink:"/docs/tags/linux"},{label:"macOS",permalink:"/docs/tags/mac-os"}],version:"current",sidebarPosition:3,frontMatter:{sidebar_position:3,title:"Lima instance for Kubernetes",description:"Podman Desktop can assist you to create a custom Lima instance on Linux and macOS.",tags:["podman-desktop","kubernetes","onboarding","linux","macOS"],keywords:["podman desktop","kubernetes","lima","onboarding","linux","macos"]},sidebar:"mySidebar",previous:{title:"Lima instance for containers",permalink:"/docs/lima/creating-a-lima-instance"},next:{title:"Customizing Lima instance",permalink:"/docs/lima/customizing"}},l={},c=[{value:"Prerequisites",id:"prerequisites",level:4},{value:"Procedure",id:"procedure",level:4},{value:"Verification",id:"verification",level:4}],p=(m="Icon",function(e){return console.warn("Component "+m+" was not imported, exported, or provided by MDXProvider as global scope"),(0,r.kt)("div",e)});var m;const u={toc:c};function d(e){let{components:t,...i}=e;return(0,r.kt)("wrapper",(0,a.Z)({},u,i,{components:t,mdxType:"MDXLayout"}),(0,r.kt)("h1",{id:"creating-a-lima-instance-for-kubernetes-workloads-with-podman-desktop"},"Creating a Lima instance for Kubernetes workloads with Podman Desktop"),(0,r.kt)("p",null,"To use the Lima provider you need a Lima instance running a Linux virtual machine."),(0,r.kt)("p",null,"In the future, Podman Desktop might be able to create Lima instances."),(0,r.kt)("p",null,"Consider creating a custom Lima instance to:"),(0,r.kt)("ul",null,(0,r.kt)("li",{parentName:"ul"},"Control the assigned resources: CPUs, memory, and disk size."),(0,r.kt)("li",{parentName:"ul"},"Control which Kubernetes distribution (",(0,r.kt)("inlineCode",{parentName:"li"},"template"),") to install.")),(0,r.kt)("h4",{id:"prerequisites"},"Prerequisites"),(0,r.kt)("ol",null,(0,r.kt)("li",{parentName:"ol"},(0,r.kt)("a",{parentName:"li",href:"/docs/lima/installing"},"Install the ",(0,r.kt)("inlineCode",{parentName:"a"},"lima")," CLI"),".")),(0,r.kt)("h4",{id:"procedure"},"Procedure"),(0,r.kt)("ol",null,(0,r.kt)("li",{parentName:"ol"},(0,r.kt)("p",{parentName:"li"},"In a terminal, create the Lima instance."),(0,r.kt)("ul",{parentName:"li"},(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("p",{parentName:"li"},"To create a single-node Kubernetes cluster running ",(0,r.kt)("a",{parentName:"p",href:"https://k3s.io/"},"k3s"),":"),(0,r.kt)("pre",{parentName:"li"},(0,r.kt)("code",{parentName:"pre",className:"language-shell-session"},"$ limactl start template://k3s\n"))),(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("p",{parentName:"li"},"To create a single-node Kubernetes cluster running ",(0,r.kt)("a",{parentName:"p",href:"https://k8s.io/"},"k8s"),":"),(0,r.kt)("pre",{parentName:"li"},(0,r.kt)("code",{parentName:"pre",className:"language-shell-session"},"$ limactl start template://k8s\n"))),(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("p",{parentName:"li"},"To select the number of CPUs, the memory, and the disk size, add the options to the ",(0,r.kt)("inlineCode",{parentName:"p"},"limactl start")," command:"),(0,r.kt)("pre",{parentName:"li"},(0,r.kt)("code",{parentName:"pre",className:"language-shell-session"},"--cpus=4 --memory=4 --disk=100\n"))))),(0,r.kt)("li",{parentName:"ol"},(0,r.kt)("p",{parentName:"li"},"Wait for the instance to start, and restart the Lima extension."),(0,r.kt)("ul",{parentName:"li"},(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("p",{parentName:"li"},"Go to ",(0,r.kt)("strong",{parentName:"p"},(0,r.kt)(p,{icon:"fa-solid fa-cog",size:"lg",mdxType:"Icon"})," Settings > Preferences > Extension: Lima"),", to change the instance name and type."),(0,r.kt)("ul",{parentName:"li"},(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("p",{parentName:"li"},"k3s"),(0,r.kt)("ul",{parentName:"li"},(0,r.kt)("li",{parentName:"ul"},"Type: kubernetes"),(0,r.kt)("li",{parentName:"ul"},"Name: k3s\n",(0,r.kt)("img",{alt:"Lima preferences k3s",src:n(99421).Z,width:"633",height:"211"})))),(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("p",{parentName:"li"},"k8s"),(0,r.kt)("ul",{parentName:"li"},(0,r.kt)("li",{parentName:"ul"},"Type: kubernetes"),(0,r.kt)("li",{parentName:"ul"},"Name: k8s\n",(0,r.kt)("img",{alt:"Lima preferences k8s",src:n(73450).Z,width:"637",height:"205"})))))),(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("p",{parentName:"li"},"Go to ",(0,r.kt)("strong",{parentName:"p"},(0,r.kt)(p,{icon:"fa-solid fa-cog",size:"lg",mdxType:"Icon"})," Settings > Extensions > Lima"),", to disable and enable the extension after changes."))))),(0,r.kt)("h4",{id:"verification"},"Verification"),(0,r.kt)("ol",null,(0,r.kt)("li",{parentName:"ol"},(0,r.kt)("p",{parentName:"li"},"When the installation is done, the location of the KUBECONFIG file is printed. See ",(0,r.kt)("a",{parentName:"p",href:"/docs/kubernetes/existing-kubernetes"},"Configuring access to a Kubernetes cluster"),"."),(0,r.kt)("ul",{parentName:"li"},(0,r.kt)("li",{parentName:"ul"},"Go to ",(0,r.kt)("strong",{parentName:"li"},(0,r.kt)(p,{icon:"fa-solid fa-cog",size:"lg",mdxType:"Icon"})," Settings > Preferences > Path to the kubeconfig file"),", to set the path of the file."))),(0,r.kt)("li",{parentName:"ol"},(0,r.kt)("p",{parentName:"li"},"Use the ",(0,r.kt)("inlineCode",{parentName:"p"},"kubectl.lima")," wrapper script to connect to the cluster:"),(0,r.kt)("pre",{parentName:"li"},(0,r.kt)("code",{parentName:"pre",className:"language-shell-session"},"$ kubectl.lima version\n")))))}d.isMDXComponent=!0},99421:(e,t,n)=>{n.d(t,{Z:()=>a});const a=n.p+"assets/images/lima-preferences-k3s-f3a4e45ffed36f9745abbcb886be432e.png"},73450:(e,t,n)=>{n.d(t,{Z:()=>a});const a=n.p+"assets/images/lima-preferences-k8s-57f8cf79ea9d3cad25160eac58b78484.png"}}]); \ No newline at end of file diff --git a/assets/js/aaabcfd8.c58bf8b6.js b/assets/js/aaabcfd8.c58bf8b6.js deleted file mode 100644 index a14b2c5e33d..00000000000 --- a/assets/js/aaabcfd8.c58bf8b6.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[6932],{35318:(e,t,n)=>{n.d(t,{Zo:()=>p,kt:()=>k});var a=n(27378);function r(e,t,n){return t in e?Object.defineProperty(e,t,{value:n,enumerable:!0,configurable:!0,writable:!0}):e[t]=n,e}function i(e,t){var n=Object.keys(e);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);t&&(a=a.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),n.push.apply(n,a)}return n}function s(e){for(var t=1;t=0||(r[n]=e[n]);return r}(e,t);if(Object.getOwnPropertySymbols){var i=Object.getOwnPropertySymbols(e);for(a=0;a=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(r[n]=e[n])}return r}var l=a.createContext({}),c=function(e){var t=a.useContext(l),n=t;return e&&(n="function"==typeof e?e(t):s(s({},t),e)),n},p=function(e){var t=c(e.components);return a.createElement(l.Provider,{value:t},e.children)},m={inlineCode:"code",wrapper:function(e){var t=e.children;return a.createElement(a.Fragment,{},t)}},u=a.forwardRef((function(e,t){var n=e.components,r=e.mdxType,i=e.originalType,l=e.parentName,p=o(e,["components","mdxType","originalType","parentName"]),u=c(n),k=r,d=u["".concat(l,".").concat(k)]||u[k]||m[k]||i;return n?a.createElement(d,s(s({ref:t},p),{},{components:n})):a.createElement(d,s({ref:t},p))}));function k(e,t){var n=arguments,r=t&&t.mdxType;if("string"==typeof e||r){var i=n.length,s=new Array(i);s[0]=u;var o={};for(var l in t)hasOwnProperty.call(t,l)&&(o[l]=t[l]);o.originalType=e,o.mdxType="string"==typeof e?e:r,s[1]=o;for(var c=2;c{n.r(t),n.d(t,{assets:()=>l,contentTitle:()=>s,default:()=>m,frontMatter:()=>i,metadata:()=>o,toc:()=>c});var a=n(25773),r=(n(27378),n(35318));const i={sidebar_position:3,title:"Lima instance for Kubernetes",description:"Podman Desktop can assist you to create a custom Lima instance on Linux and macOS.",tags:["podman-desktop","kubernetes","onboarding","linux","macOS"],keywords:["podman desktop","kubernetes","lima","onboarding","linux","macos"]},s="Creating a Lima instance for Kubernetes workloads with Podman Desktop",o={unversionedId:"lima/creating-a-kubernetes-instance",id:"lima/creating-a-kubernetes-instance",title:"Lima instance for Kubernetes",description:"Podman Desktop can assist you to create a custom Lima instance on Linux and macOS.",source:"@site/docs/lima/creating-a-kubernetes-instance.md",sourceDirName:"lima",slug:"/lima/creating-a-kubernetes-instance",permalink:"/docs/lima/creating-a-kubernetes-instance",draft:!1,editUrl:"https://github.com/containers/podman-desktop/tree/main/website/docs/lima/creating-a-kubernetes-instance.md",tags:[{label:"podman-desktop",permalink:"/docs/tags/podman-desktop"},{label:"kubernetes",permalink:"/docs/tags/kubernetes"},{label:"onboarding",permalink:"/docs/tags/onboarding"},{label:"linux",permalink:"/docs/tags/linux"},{label:"macOS",permalink:"/docs/tags/mac-os"}],version:"current",sidebarPosition:3,frontMatter:{sidebar_position:3,title:"Lima instance for Kubernetes",description:"Podman Desktop can assist you to create a custom Lima instance on Linux and macOS.",tags:["podman-desktop","kubernetes","onboarding","linux","macOS"],keywords:["podman desktop","kubernetes","lima","onboarding","linux","macos"]},sidebar:"mySidebar",previous:{title:"Lima instance for containers",permalink:"/docs/lima/creating-a-lima-instance"},next:{title:"Customizing Lima instance",permalink:"/docs/lima/customizing"}},l={},c=[{value:"Prerequisites",id:"prerequisites",level:4},{value:"Procedure",id:"procedure",level:4},{value:"Verification",id:"verification",level:4}],p={toc:c};function m(e){let{components:t,...i}=e;return(0,r.kt)("wrapper",(0,a.Z)({},p,i,{components:t,mdxType:"MDXLayout"}),(0,r.kt)("h1",{id:"creating-a-lima-instance-for-kubernetes-workloads-with-podman-desktop"},"Creating a Lima instance for Kubernetes workloads with Podman Desktop"),(0,r.kt)("p",null,"To use the Lima provider you need a Lima instance running a Linux virtual machine."),(0,r.kt)("p",null,"In the future, Podman Desktop might be able to create Lima instances."),(0,r.kt)("p",null,"Consider creating a custom Lima instance to:"),(0,r.kt)("ul",null,(0,r.kt)("li",{parentName:"ul"},"Control the assigned resources: CPUs, memory, and disk size."),(0,r.kt)("li",{parentName:"ul"},"Control which Kubernetes distribution (",(0,r.kt)("inlineCode",{parentName:"li"},"template"),") to install.")),(0,r.kt)("h4",{id:"prerequisites"},"Prerequisites"),(0,r.kt)("ol",null,(0,r.kt)("li",{parentName:"ol"},(0,r.kt)("a",{parentName:"li",href:"/docs/lima/installing"},"Install the ",(0,r.kt)("inlineCode",{parentName:"a"},"lima")," CLI"),".")),(0,r.kt)("h4",{id:"procedure"},"Procedure"),(0,r.kt)("ol",null,(0,r.kt)("li",{parentName:"ol"},(0,r.kt)("p",{parentName:"li"},"In a terminal, create the Lima instance."),(0,r.kt)("ul",{parentName:"li"},(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("p",{parentName:"li"},"To create a single-node Kubernetes cluster running ",(0,r.kt)("a",{parentName:"p",href:"https://k3s.io/"},"k3s"),":"),(0,r.kt)("pre",{parentName:"li"},(0,r.kt)("code",{parentName:"pre",className:"language-shell-session"},"$ limactl start template://k3s\n"))),(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("p",{parentName:"li"},"To create a single-node Kubernetes cluster running ",(0,r.kt)("a",{parentName:"p",href:"https://k8s.io/"},"k8s"),":"),(0,r.kt)("pre",{parentName:"li"},(0,r.kt)("code",{parentName:"pre",className:"language-shell-session"},"$ limactl start template://k8s\n"))),(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("p",{parentName:"li"},"To select the number of CPUs, the memory, and the disk size, add the options to the ",(0,r.kt)("inlineCode",{parentName:"p"},"limactl start")," command:"),(0,r.kt)("pre",{parentName:"li"},(0,r.kt)("code",{parentName:"pre",className:"language-shell-session"},"--cpus=4 --memory=4 --disk=100\n"))))),(0,r.kt)("li",{parentName:"ol"},(0,r.kt)("p",{parentName:"li"},"Wait for the instance to start, and restart the Lima extension."),(0,r.kt)("ul",{parentName:"li"},(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("p",{parentName:"li"},"Go to ",(0,r.kt)("strong",{parentName:"p"},(0,r.kt)("icon",{icon:"fa-solid fa-cog",size:"lg"})," Settings > Preferences > Extension: Lima"),", to change the instance name and type."),(0,r.kt)("ul",{parentName:"li"},(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("p",{parentName:"li"},"k3s"),(0,r.kt)("ul",{parentName:"li"},(0,r.kt)("li",{parentName:"ul"},"Type: kubernetes"),(0,r.kt)("li",{parentName:"ul"},"Name: k3s\n",(0,r.kt)("img",{alt:"Lima preferences k3s",src:n(99421).Z,width:"633",height:"211"})))),(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("p",{parentName:"li"},"k8s"),(0,r.kt)("ul",{parentName:"li"},(0,r.kt)("li",{parentName:"ul"},"Type: kubernetes"),(0,r.kt)("li",{parentName:"ul"},"Name: k8s\n",(0,r.kt)("img",{alt:"Lima preferences k8s",src:n(73450).Z,width:"637",height:"205"})))))),(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("p",{parentName:"li"},"Go to ",(0,r.kt)("strong",{parentName:"p"},(0,r.kt)("icon",{icon:"fa-solid fa-cog",size:"lg"})," Settings > Extensions > Lima"),", to disable and enable the extension after changes."))))),(0,r.kt)("h4",{id:"verification"},"Verification"),(0,r.kt)("ol",null,(0,r.kt)("li",{parentName:"ol"},(0,r.kt)("p",{parentName:"li"},"When the installation is done, the location of the KUBECONFIG file is printed. See ",(0,r.kt)("a",{parentName:"p",href:"/docs/kubernetes/existing-kubernetes"},"Configuring access to a Kubernetes cluster"),"."),(0,r.kt)("ul",{parentName:"li"},(0,r.kt)("li",{parentName:"ul"},"Go to ",(0,r.kt)("strong",{parentName:"li"},(0,r.kt)("icon",{icon:"fa-solid fa-cog",size:"lg"})," Settings > Preferences > Path to the kubeconfig file"),", to set the path of the file."))),(0,r.kt)("li",{parentName:"ol"},(0,r.kt)("p",{parentName:"li"},"Use the ",(0,r.kt)("inlineCode",{parentName:"p"},"kubectl.lima")," wrapper script to connect to the cluster:"),(0,r.kt)("pre",{parentName:"li"},(0,r.kt)("code",{parentName:"pre",className:"language-shell-session"},"$ kubectl.lima version\n")))))}m.isMDXComponent=!0},99421:(e,t,n)=>{n.d(t,{Z:()=>a});const a=n.p+"assets/images/lima-preferences-k3s-f3a4e45ffed36f9745abbcb886be432e.png"},73450:(e,t,n)=>{n.d(t,{Z:()=>a});const a=n.p+"assets/images/lima-preferences-k8s-57f8cf79ea9d3cad25160eac58b78484.png"}}]); \ No newline at end of file diff --git a/assets/js/abc85917.d2b27867.js b/assets/js/abc85917.a2923a83.js similarity index 59% rename from assets/js/abc85917.d2b27867.js rename to assets/js/abc85917.a2923a83.js index fd8d70bedbd..b544d37bac4 100644 --- a/assets/js/abc85917.d2b27867.js +++ b/assets/js/abc85917.a2923a83.js @@ -1 +1 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[2896],{35318:(e,t,o)=>{o.d(t,{Zo:()=>c,kt:()=>d});var n=o(27378);function r(e,t,o){return t in e?Object.defineProperty(e,t,{value:o,enumerable:!0,configurable:!0,writable:!0}):e[t]=o,e}function i(e,t){var o=Object.keys(e);if(Object.getOwnPropertySymbols){var n=Object.getOwnPropertySymbols(e);t&&(n=n.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),o.push.apply(o,n)}return o}function a(e){for(var t=1;t=0||(r[o]=e[o]);return r}(e,t);if(Object.getOwnPropertySymbols){var i=Object.getOwnPropertySymbols(e);for(n=0;n=0||Object.prototype.propertyIsEnumerable.call(e,o)&&(r[o]=e[o])}return r}var p=n.createContext({}),l=function(e){var t=n.useContext(p),o=t;return e&&(o="function"==typeof e?e(t):a(a({},t),e)),o},c=function(e){var t=l(e.components);return n.createElement(p.Provider,{value:t},e.children)},m={inlineCode:"code",wrapper:function(e){var t=e.children;return n.createElement(n.Fragment,{},t)}},u=n.forwardRef((function(e,t){var o=e.components,r=e.mdxType,i=e.originalType,p=e.parentName,c=s(e,["components","mdxType","originalType","parentName"]),u=l(o),d=r,f=u["".concat(p,".").concat(d)]||u[d]||m[d]||i;return o?n.createElement(f,a(a({ref:t},c),{},{components:o})):n.createElement(f,a({ref:t},c))}));function d(e,t){var o=arguments,r=t&&t.mdxType;if("string"==typeof e||r){var i=o.length,a=new Array(i);a[0]=u;var s={};for(var p in t)hasOwnProperty.call(t,p)&&(s[p]=t[p]);s.originalType=e,s.mdxType="string"==typeof e?e:r,a[1]=s;for(var l=2;l{o.r(t),o.d(t,{assets:()=>p,contentTitle:()=>a,default:()=>m,frontMatter:()=>i,metadata:()=>s,toc:()=>l});var n=o(25773),r=(o(27378),o(35318));const i={title:"Setting up Compose",description:"Podman Desktop can install the Compose engine.",sidebar_position:2,keywords:["compose"],tags:["compose"]},a="Setting up Compose",s={unversionedId:"compose/setting-up-compose",id:"compose/setting-up-compose",title:"Setting up Compose",description:"Podman Desktop can install the Compose engine.",source:"@site/docs/compose/setting-up-compose.md",sourceDirName:"compose",slug:"/compose/setting-up-compose",permalink:"/docs/compose/setting-up-compose",draft:!1,editUrl:"https://github.com/containers/podman-desktop/tree/main/website/docs/compose/setting-up-compose.md",tags:[{label:"compose",permalink:"/docs/tags/compose"}],version:"current",sidebarPosition:2,frontMatter:{title:"Setting up Compose",description:"Podman Desktop can install the Compose engine.",sidebar_position:2,keywords:["compose"],tags:["compose"]},sidebar:"mySidebar",previous:{title:"Compose",permalink:"/docs/compose/"},next:{title:"Running Compose files",permalink:"/docs/compose/running-compose"}},p={},l=[{value:"Procedure",id:"procedure",level:4},{value:"Verification",id:"verification",level:4},{value:"Next steps",id:"next-steps",level:4},{value:"Additional resources",id:"additional-resources",level:4}],c={toc:l};function m(e){let{components:t,...o}=e;return(0,r.kt)("wrapper",(0,n.Z)({},c,o,{components:t,mdxType:"MDXLayout"}),(0,r.kt)("h1",{id:"setting-up-compose"},"Setting up Compose"),(0,r.kt)("p",null,"Podman Desktop can install the Compose engine."),(0,r.kt)("h4",{id:"procedure"},"Procedure"),(0,r.kt)("ol",null,(0,r.kt)("li",{parentName:"ol"},"Go to ",(0,r.kt)("strong",{parentName:"li"},(0,r.kt)("icon",{icon:"fa-solid fa-cog",size:"lg"})," Settings > Resources"),"."),(0,r.kt)("li",{parentName:"ol"},"In the ",(0,r.kt)("strong",{parentName:"li"},"Compose")," tile, click ",(0,r.kt)("strong",{parentName:"li"},"Setup"),", and follow the prompts.")),(0,r.kt)("h4",{id:"verification"},"Verification"),(0,r.kt)("ol",null,(0,r.kt)("li",{parentName:"ol"},(0,r.kt)("p",{parentName:"li"},"The Compose reference implementation is in your ",(0,r.kt)("inlineCode",{parentName:"p"},"PATH"),", therefore, you can display the Compose engine version in a terminal:"),(0,r.kt)("pre",{parentName:"li"},(0,r.kt)("code",{parentName:"pre",className:"language-shell-session"},"$ docker-compose version\n"))),(0,r.kt)("li",{parentName:"ol"},(0,r.kt)("p",{parentName:"li"},"Podman detects the same Compose version:"),(0,r.kt)("pre",{parentName:"li"},(0,r.kt)("code",{parentName:"pre",className:"language-shell-session"},"$ podman compose version\n")))),(0,r.kt)("h4",{id:"next-steps"},"Next steps"),(0,r.kt)("ul",null,(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("a",{parentName:"li",href:"/docs/compose/running-compose"},"Run Compose"),".")),(0,r.kt)("h4",{id:"additional-resources"},"Additional resources"),(0,r.kt)("ul",null,(0,r.kt)("li",{parentName:"ul"},"(Alternatively) Use an alternative Compose implementation in Python with Podman integration: ",(0,r.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-compose#installation"},"install Podman Compose"),"."),(0,r.kt)("li",{parentName:"ul"},"(Alternatively) ",(0,r.kt)("a",{parentName:"li",href:"https://github.com/docker/compose/relases"},"Download and install Compose yourself"),".")))}m.isMDXComponent=!0}}]); \ No newline at end of file +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[2896],{35318:(e,t,o)=>{o.d(t,{Zo:()=>c,kt:()=>d});var n=o(27378);function r(e,t,o){return t in e?Object.defineProperty(e,t,{value:o,enumerable:!0,configurable:!0,writable:!0}):e[t]=o,e}function i(e,t){var o=Object.keys(e);if(Object.getOwnPropertySymbols){var n=Object.getOwnPropertySymbols(e);t&&(n=n.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),o.push.apply(o,n)}return o}function a(e){for(var t=1;t=0||(r[o]=e[o]);return r}(e,t);if(Object.getOwnPropertySymbols){var i=Object.getOwnPropertySymbols(e);for(n=0;n=0||Object.prototype.propertyIsEnumerable.call(e,o)&&(r[o]=e[o])}return r}var p=n.createContext({}),l=function(e){var t=n.useContext(p),o=t;return e&&(o="function"==typeof e?e(t):a(a({},t),e)),o},c=function(e){var t=l(e.components);return n.createElement(p.Provider,{value:t},e.children)},m={inlineCode:"code",wrapper:function(e){var t=e.children;return n.createElement(n.Fragment,{},t)}},u=n.forwardRef((function(e,t){var o=e.components,r=e.mdxType,i=e.originalType,p=e.parentName,c=s(e,["components","mdxType","originalType","parentName"]),u=l(o),d=r,f=u["".concat(p,".").concat(d)]||u[d]||m[d]||i;return o?n.createElement(f,a(a({ref:t},c),{},{components:o})):n.createElement(f,a({ref:t},c))}));function d(e,t){var o=arguments,r=t&&t.mdxType;if("string"==typeof e||r){var i=o.length,a=new Array(i);a[0]=u;var s={};for(var p in t)hasOwnProperty.call(t,p)&&(s[p]=t[p]);s.originalType=e,s.mdxType="string"==typeof e?e:r,a[1]=s;for(var l=2;l{o.r(t),o.d(t,{assets:()=>p,contentTitle:()=>a,default:()=>d,frontMatter:()=>i,metadata:()=>s,toc:()=>l});var n=o(25773),r=(o(27378),o(35318));const i={title:"Setting up Compose",description:"Podman Desktop can install the Compose engine.",sidebar_position:2,keywords:["compose"],tags:["compose"]},a="Setting up Compose",s={unversionedId:"compose/setting-up-compose",id:"compose/setting-up-compose",title:"Setting up Compose",description:"Podman Desktop can install the Compose engine.",source:"@site/docs/compose/setting-up-compose.md",sourceDirName:"compose",slug:"/compose/setting-up-compose",permalink:"/docs/compose/setting-up-compose",draft:!1,editUrl:"https://github.com/containers/podman-desktop/tree/main/website/docs/compose/setting-up-compose.md",tags:[{label:"compose",permalink:"/docs/tags/compose"}],version:"current",sidebarPosition:2,frontMatter:{title:"Setting up Compose",description:"Podman Desktop can install the Compose engine.",sidebar_position:2,keywords:["compose"],tags:["compose"]},sidebar:"mySidebar",previous:{title:"Compose",permalink:"/docs/compose/"},next:{title:"Running Compose files",permalink:"/docs/compose/running-compose"}},p={},l=[{value:"Procedure",id:"procedure",level:4},{value:"Verification",id:"verification",level:4},{value:"Next steps",id:"next-steps",level:4},{value:"Additional resources",id:"additional-resources",level:4}],c=(m="Icon",function(e){return console.warn("Component "+m+" was not imported, exported, or provided by MDXProvider as global scope"),(0,r.kt)("div",e)});var m;const u={toc:l};function d(e){let{components:t,...o}=e;return(0,r.kt)("wrapper",(0,n.Z)({},u,o,{components:t,mdxType:"MDXLayout"}),(0,r.kt)("h1",{id:"setting-up-compose"},"Setting up Compose"),(0,r.kt)("p",null,"Podman Desktop can install the Compose engine."),(0,r.kt)("h4",{id:"procedure"},"Procedure"),(0,r.kt)("ol",null,(0,r.kt)("li",{parentName:"ol"},"Go to ",(0,r.kt)("strong",{parentName:"li"},(0,r.kt)(c,{icon:"fa-solid fa-cog",size:"lg",mdxType:"Icon"})," Settings > Resources"),"."),(0,r.kt)("li",{parentName:"ol"},"In the ",(0,r.kt)("strong",{parentName:"li"},"Compose")," tile, click ",(0,r.kt)("strong",{parentName:"li"},"Setup"),", and follow the prompts.")),(0,r.kt)("h4",{id:"verification"},"Verification"),(0,r.kt)("ol",null,(0,r.kt)("li",{parentName:"ol"},(0,r.kt)("p",{parentName:"li"},"The Compose reference implementation is in your ",(0,r.kt)("inlineCode",{parentName:"p"},"PATH"),", therefore, you can display the Compose engine version in a terminal:"),(0,r.kt)("pre",{parentName:"li"},(0,r.kt)("code",{parentName:"pre",className:"language-shell-session"},"$ docker-compose version\n"))),(0,r.kt)("li",{parentName:"ol"},(0,r.kt)("p",{parentName:"li"},"Podman detects the same Compose version:"),(0,r.kt)("pre",{parentName:"li"},(0,r.kt)("code",{parentName:"pre",className:"language-shell-session"},"$ podman compose version\n")))),(0,r.kt)("h4",{id:"next-steps"},"Next steps"),(0,r.kt)("ul",null,(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("a",{parentName:"li",href:"/docs/compose/running-compose"},"Run Compose"),".")),(0,r.kt)("h4",{id:"additional-resources"},"Additional resources"),(0,r.kt)("ul",null,(0,r.kt)("li",{parentName:"ul"},"(Alternatively) Use an alternative Compose implementation in Python with Podman integration: ",(0,r.kt)("a",{parentName:"li",href:"https://github.com/containers/podman-compose#installation"},"install Podman Compose"),"."),(0,r.kt)("li",{parentName:"ul"},"(Alternatively) ",(0,r.kt)("a",{parentName:"li",href:"https://github.com/docker/compose/relases"},"Download and install Compose yourself"),".")))}d.isMDXComponent=!0}}]); \ No newline at end of file diff --git a/assets/js/af231220.6661ae24.js b/assets/js/af231220.6661ae24.js new file mode 100644 index 00000000000..fb699257094 --- /dev/null +++ b/assets/js/af231220.6661ae24.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[5326],{35318:(e,t,n)=>{n.d(t,{Zo:()=>d,kt:()=>p});var i=n(27378);function r(e,t,n){return t in e?Object.defineProperty(e,t,{value:n,enumerable:!0,configurable:!0,writable:!0}):e[t]=n,e}function a(e,t){var n=Object.keys(e);if(Object.getOwnPropertySymbols){var i=Object.getOwnPropertySymbols(e);t&&(i=i.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),n.push.apply(n,i)}return n}function o(e){for(var t=1;t=0||(r[n]=e[n]);return r}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(i=0;i=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(r[n]=e[n])}return r}var s=i.createContext({}),l=function(e){var t=i.useContext(s),n=t;return e&&(n="function"==typeof e?e(t):o(o({},t),e)),n},d=function(e){var t=l(e.components);return i.createElement(s.Provider,{value:t},e.children)},m={inlineCode:"code",wrapper:function(e){var t=e.children;return i.createElement(i.Fragment,{},t)}},A=i.forwardRef((function(e,t){var n=e.components,r=e.mdxType,a=e.originalType,s=e.parentName,d=c(e,["components","mdxType","originalType","parentName"]),A=l(n),p=r,u=A["".concat(s,".").concat(p)]||A[p]||m[p]||a;return n?i.createElement(u,o(o({ref:t},d),{},{components:n})):i.createElement(u,o({ref:t},d))}));function p(e,t){var n=arguments,r=t&&t.mdxType;if("string"==typeof e||r){var a=n.length,o=new Array(a);o[0]=A;var c={};for(var s in t)hasOwnProperty.call(t,s)&&(c[s]=t[s]);c.originalType=e,c.mdxType="string"==typeof e?e:r,o[1]=c;for(var l=2;l{n.r(t),n.d(t,{assets:()=>s,contentTitle:()=>o,default:()=>p,frontMatter:()=>a,metadata:()=>c,toc:()=>l});var i=n(25773),r=(n(27378),n(35318));const a={sidebar_position:2,title:"Installing the `kind` CLI",description:"Kind is one way to get Kubernetes running on your workstation.",keywords:["podman desktop","podman","containers","migrating","kubernetes","kind"],tags:["migrating-to-kubernetes","kind"]},o="Installing the kind CLI",c={unversionedId:"kind/installing",id:"kind/installing",title:"Installing the `kind` CLI",description:"Kind is one way to get Kubernetes running on your workstation.",source:"@site/docs/kind/installing.md",sourceDirName:"kind",slug:"/kind/installing",permalink:"/docs/kind/installing",draft:!1,editUrl:"https://github.com/containers/podman-desktop/tree/main/website/docs/kind/installing.md",tags:[{label:"migrating-to-kubernetes",permalink:"/docs/tags/migrating-to-kubernetes"},{label:"kind",permalink:"/docs/tags/kind"}],version:"current",sidebarPosition:2,frontMatter:{sidebar_position:2,title:"Installing the `kind` CLI",description:"Kind is one way to get Kubernetes running on your workstation.",keywords:["podman desktop","podman","containers","migrating","kubernetes","kind"],tags:["migrating-to-kubernetes","kind"]},sidebar:"mySidebar",previous:{title:"Kind",permalink:"/docs/kind/"},next:{title:"Configuring Podman for Kind",permalink:"/docs/kind/configuring-podman-for-kind-on-windows"}},s={},l=[{value:"Procedure",id:"procedure",level:4},{value:"Verification",id:"verification",level:4}],d=(m="Icon",function(e){return console.warn("Component "+m+" was not imported, exported, or provided by MDXProvider as global scope"),(0,r.kt)("div",e)});var m;const A={toc:l};function p(e){let{components:t,...a}=e;return(0,r.kt)("wrapper",(0,i.Z)({},A,a,{components:t,mdxType:"MDXLayout"}),(0,r.kt)("h1",{id:"installing-the-kind-cli"},"Installing the ",(0,r.kt)("inlineCode",{parentName:"h1"},"kind")," CLI"),(0,r.kt)("h4",{id:"procedure"},"Procedure"),(0,r.kt)("ul",null,(0,r.kt)("li",{parentName:"ul"},"In the status bar, click on ",(0,r.kt)("strong",{parentName:"li"},"Kind"),", and follow the prompts.\n",(0,r.kt)("img",{alt:"Kind in the status bar",src:n(88069).Z,width:"85",height:"24"}))),(0,r.kt)("h4",{id:"verification"},"Verification"),(0,r.kt)("ol",null,(0,r.kt)("li",{parentName:"ol"},(0,r.kt)("p",{parentName:"li"},"The status bar does not display ",(0,r.kt)("strong",{parentName:"p"},"Kind"),".")),(0,r.kt)("li",{parentName:"ol"},(0,r.kt)("p",{parentName:"li"},(0,r.kt)("strong",{parentName:"p"},(0,r.kt)(d,{icon:"fa-solid fa-cog",size:"lg",mdxType:"Icon"})," Settings > Resources")," contain a ",(0,r.kt)("strong",{parentName:"p"},"Kind")," tile.\n",(0,r.kt)("img",{alt:"Kind resource tile",src:n(64121).Z,width:"200",height:"131"}))),(0,r.kt)("li",{parentName:"ol"},(0,r.kt)("p",{parentName:"li"},"You can run the ",(0,r.kt)("inlineCode",{parentName:"p"},"kind")," CLI:"),(0,r.kt)("pre",{parentName:"li"},(0,r.kt)("code",{parentName:"pre",className:"language-shell-session"},"$ kind get clusters\n")))))}p.isMDXComponent=!0},64121:(e,t,n)=>{n.d(t,{Z:()=>i});const i="data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAMgAAACDCAYAAADIx1QxAAAABHNCSVQICAgIfAhkiAAAABl0RVh0U29mdHdhcmUAZ25vbWUtc2NyZWVuc2hvdO8Dvz4AAAAmdEVYdENyZWF0aW9uIFRpbWUAbWFyIDExIGF2ciAyMDIzIDEyOjI4OjU2rKtDNQAAFLpJREFUeJzt3Xt4VPWdx/H3uc01mQwJSTAXCEgSDWBAxVuhLnQRW7yvbotttVVbta1b7VO7K7aPWC/tbp/drm3tsz7V2rXt9r7rtdW2ihe03hAQGCERopiEJEMmk8tcz8w5+8eEkEA4ZCCYGL+vP2RyZuZ3vmee+Zzf73fOmaMya9bxtmFoKIqKqqoIIfbTPR73RNcgxKQlXYYQDiQgQjiQgAjhQAIihAMJiBAOJCBCOJCACOFAAiKEAwmIEA4kIEI4kIAI4UACIoQDPa8Xe7w0XPYVqs78OLqhYaOgKKAoKijjkzXbtsC2wbaxAQWwsQAV24ZsKkHnmy+y/eEHiIfbAXtc1ivEaPIKiG96JbOWrmK6302RW0UZ/qSijPw7T/a+/9raActy/2ayEM/a9Lt0qs48l0D1XLb88vt0N23KBUqIYyCvgBQeNwuv28WcIp1pHu3wbxhHlm1jWpDMWLQNZGmtPJ7GK/+ZV394CwN7Wt7XWsSHR17jIs+0Mjyaglff31dkMxmy2ey4F3YgVVFwawpFbo2GEhezAhoFM2bSeOXNoBxN3yXEoeUXkGAJuqqgqfu/kDvefIN3mt4a98IOp6pAp9BQKKlbSNn809/39YsPh7wC4i+rQldBG7bDNk0TM5Ue77oOy6crlHpz86Djz/00urfgfa9BTH159iDTMVQFdRIMaRRFYWaBhkuDYE09MxrPmuiSxBSU1yTd8PlH9B75+FPLTh7Ytpmkw3zF1iE9Uxl1TnFL1WKWB2eOWObSVWYXauzIFjDzoxfQ0/IWsc73jqzAwzFmc9Z5S/Fv+wN/aYod/HzpIj6xcgE0Pc1fXu2i4pzruaxuB/9z31O0m+NXRuO193JjzZN845bHCI9fs+IQ8upBDI8fdfjwKp1CI0MqFmH3js207dxGOhk/okJmFfr5XOV8zvfNpkAbe26rC3Uq/RoldQuZ98kbMPyF+9v86AXMWfFJXAWBI6ppBGM2Kz77D6yYFzz4qcrlfP27a7l8kZ+2pjZMyli48mOctuRjLDz45UdTBP5gGX6XMZ6NCgf5nSj0+kYEJJWIYSb7sbIZwm0DKIpKoGQGLo9vzG1Oc7u4eEY9ndum8+YmBZdhc83JM3l7zk4e72477PsVRaFumo6q2KiNH6Ho9odoffFPdG15mRMvvZ5MKsnAnnfo2vpKPps6ZkblSm7+9peojT7K3d96gFAcoI1H7riR5mAPIdnNf6DlFRBVN0bOP2wbe9hJutzjsZ20K3G7WRqooTBcyZvrIJEGnxtMU+H59QrBTXV88aRZbCrbyQazy3kjVIX6aQZzinTi5VUolavQj49QsvVmrGyWFVW7iXhT/Otr43uLI6NmJTd/60vUdv2Bu+94iObhnWe0hVB0XFcnJkBeAQEOOluuayrW4EJFUbDSKcxkbOjVmstNwrbYme0l7bfJZnONnFc5m+anKwijkM7YLJ3nomGmQTxl8/SmFB09WXZtcXPmSfW0eKLs6NxLrRakunD04ZKiKLg0BZcGrkQKJfIWFXtfoilVSo3RT3XZ+B5YMGrOZ823rqGm7X7W3vEY7x4wzyiat5zTgq28+GITcYDSRaxY5KJp3SuEK0/n75bMp9Toof3V9Ty7rYtRpym+2SxesojasgKibW/w2vod47oN4vDyDsg+tm2RDL/H9KKiEcuTe1tJdbcP/a25PSQqa3jJ7CBRkru6SkVhz14XsQQcf5zGbZ8uYP3WFP0Ji0QKvnxeAT0xi//64wDdrS6Kig2e6XyXaiNwyIAcqMLVx65UCR4lw+ZEBaf5dgOuI93cEXw1l3DzHVdS2fRj1n73qYPCAVC57Aq+MP8F3nmxiWbAqDuXK68r46Wyc6ldEiTcFsUoXc6q81fziafuZu19G+kd9v7Sj/wTa677GJV08k5rFJas5PJPNhEa5fiAOHaOOCBWJsNAtJtNmzbR05MbS1RXVzNvXsOIW5hm4pnctVRY7JvA+FSdd9rAyOaGRy5N4cRqHRQF27YZSFo0zjGIJWy2785QXOKjwxoga1uHrcu2bWwb3ojPZIF7Bx1mAVVGD/ro++i8GXWrWXPJ6QS33sPa/3gmzyNUVdQGf83a614ZDIOfhmv/jTUrr+ey9V/k/m371nEFa25YirHxHm4cWodB6WlX8NUbTgbnEacYR3lfgjt8zqHrOuXl5VRVVlJVWUlRIDDi+UM5wVtEnTvX83jcCt39FtWlOnOP0zmx2sWeHosZ03R8bgXLhmVl1YepCTKWTW8qS9tAlh0JH+Hp89h8whfZNfsCNkQ8PPSWJ99NHVVw/iJq/DHaN+4gnHfmWnj2N68M6ylihH7+KM3pcurqygaX+Vl88Uoqu57knhEBNAm/+hB/3Pr+n5T9MMurB8kkE2QsN309EVKJGLGBGH6fH4879+XTNI3+vn6U4RN5RcEMd+GKDuDOpgAoMkvxpjw0VCssW+DGYyj8fn2cmy4O8NZuk65oFpcOK05288LWFGWZ6fiTCVI9ESJdHQAEiqej67nyU1mLt6MZIskMu197lt0v/5VEpJNF13yLjCfOhpbXiIWP7PDzgcJPfYffBa/nq9fdxRrX7dz9eEtefdNBrzW7iJoQ9PsHF8xmYV0BbeufoXkcz5+II5NfQOL9xGI6Tz75S97auCH3240xmjv8ccPJZMrq2fieTkc0xkVnejm11sXPnx7A41JYUGNwzyP9PPy3JJoKfjtC/fNPE1r3Z0KAt6CQq792K9NnVGDbNqGISVfMpOnRn9H02E+H1vPMrZejqBq2NY4XU8Z6eO0Xt3IPd/HVq+5kDd/MOySODD8+P8SiMtmYDPIaYmXSKbz+Qi67+iucuPDUoeWaqlJaUgxAybSDz4wpioLL5RrqWULbN0H3U0zz20T6LV7ensLvUUlnwG0o9MUs/vfFBJoK82eEeeLhH4y4Ynj1dTcOhaN1IEs4YRHe+grvvvDoQese13AMifLaj27le09Fqb3qTm67uI5xO3VndhHugrLZlePXpjhieQYkiWnl5hiNp39kaPm0YBGXrFqJ1+PmuPJSDF1nevE0Cgv86LrO7JlVnDB3Dm537iiSZVm07HieJTO3YGgwkLD5wSP9rN+W4vfrEzy/NTcUKyuIYXU/SU/P/rNtbo+HshmVACQyNu/2ZzBjvbzz3GMko3uP7tPIS5TN932D7z3VRc1nb+O2z9Qx9tOjTlp4aWMrwdNWs6LywOdcDI3ExPsir4DEw+1k7dypwJraE4aWG7rOKSfN51MXn8+nLjqPuXNquPHaz/Opi87jrlu+xom1cznz1EVow45updJp/vrkg3x5ZYLd4SxdvRadUYu9fRbbdmdQFLhgfjNvN70xYuK/5Jzz8fh82LZNWyxLIgMDHa2Et7x0VL9oPDIxNt/3Te5+rIuaS25j7Wfmj0tImn9zP89G6/nct+/kymXzqSgto6LudC782p1cXjc+h6rF2OQ1B4lHOslakLXA7fUy8/g6du9swgbchkEymcLlcmHbNpu2vIXPk5u8JxIJ2vZ0jNrmo//3Q1afdT7hqD3iHPyJVSo/++UvRrzWXxigpv7EXC0Zm70JC8uyCP32B1jZTD6bMo5ihB78JndzJzdfchtrjdtZ++DWo2syvpEf/8taojdcw4ob7mIVQLqTTY8/wO+2fZ3Pjev1XcKJUl/fMOYfdM/9+OWc+ekbOKnEwGuoPPfHR1j3+B/weNzUz5lNpLeX6orj2La9iWAggKZppDMmc2fX0Nq+h5bdrUf168MFi8/k/Ms/j8vtYWt3mj0xi9aXn2LDT+6APA4YfKAYQUqDEA1Hx+9AgBiz/HqQvZ0kMzaprI3XgMrZx6OoKslkis2h7QC817YHgN7+gaH3tbaP3nvkw+X2cELjKSTQeaUtSSIL6Vgf2x++f+qGA8CMEpYLHidMXgHpa91JLB5n414fQXcWJVDFiauuoGdPK+l4P9lUHMtMY1sWuTuUDL8vyeCiwSVD8wVl2F9D508UVF1D1d3oXj+GrxBPcDrt006grTM3lEpEugj97l5i4T1HtOFCjEVeQyzN5aFm2SUUz12AJxDEHrwXlleDcl/usW3vC4Y97DFD/x4UEGDw5lqAkjsUrCjDTjYqRFIW/WmLbCZDqi9CLNxOeNtrRJo2HaPDuELk5BUQAEXV0FxuFE3PfadtOGe2n7Mrjt3Rlba4zb0bo2DbWNkMViaN/T7cSUWIvC9WtK0smWG/GvTpCgu8KlY8RTyTJTumm7iN7YCsooBH1ThOA585QG96Cs81xKR0xFfz7uPVNbriBt0JhRfaY3TF9x9rOWQMxnjTB7emcFp5gKoCFwG3m9504mjLFSIvRx0QUDAtlSwKfWmF7uT47eXdmko8q5DIKOjqxN9JRXz45D0HEeLDRP73B0I4kIAI4UACIoQDCYgQDiQgQjiQgAjhQAIihAMJiBAOJCBCOJCACOFAAiKEAwmIEA4kIEI4kIAI4UACIoQDCYgQDiQgQjiQgAjhQAIihAMJiBAOJCBCOJCACOFAAiKEAwmIEA4kIEI4kIAI4UACIoQDCYgQDiQgQjiQgAjhQAIihAMJiBAOJCBCOJCACOFAAiKEAwmIEA4kIEI4kIAI4UACIoQDCYgQDiQgQjiQgAjhQAIihAMJiBAOJCBCOJCACOFAAiKEA32iCzjQ/KLPUB+4hGJX7USXIiZAJN3M9r7fsq331xNdCjDJAtJYdDWnTb9xossQE6jYVctZ028FW2db3y8mupzJNcSqC1w40SWISaKh6B8nugRgEgVEQSVgzJzoMsQkETBmokyCr+fEVzDIxkJVtIkuQ0wSqqJhY010GZMnIEJMRhIQIRxIQIRwIAERwsGHLiBqIIvba090GeIDYlKdKDxmvCnmXNTH3FOSBHy5Rdleg46XA2x9wkd/ZmLLE5PX1A9IcZzTb+qmPO4j9FA574VcmEaGkoYB5q7qZlldhue+H6D3GIbEfcZezm708Nx9BaSO3WrEMTDFA2JSf3U35d1B1v2ocH9PkdEJbwgSDnmpqNKOaTgAXIEs/oAM6z6IpnRA1JN6qa1yEbq7cPRhVMJNe/Pg40Cc+ZemiTzhpnBVPxVeD5vvDRDBpvCkXuqXpik0FPpb/OwYPizTsxQ3xpjVmCZQkoW4Tse6IppDOpaepP7qAUqLTbRAjMXXpsjGPYR+XkAvYNTEaFgeJ1hik+7wsuuJAjojyujbUtvH4kad7a/bzFkZI+hViLf4CR0wRDxkm3qSuasTJJ+YRmsEwKZ4WYQ5ZiGvr3fl3lweY9Fym12/ytUnpvQk3aZkXhqj1cd7nWN4uZ6htDFOw6UD+JoK2PGCmxg2xRd2sWx1mmyogOYXPFDXw7Kb+ijet2vxpZh1honZ5KP5iQA7m23mXNtFY4MNGZ3I6146OlWyCZ32zV7e22yQBIyGCMu+0kthn5edz/iJGDFOv3kvc8oPUV9Jioozelm43CTyt0J2vKzjOaObJasTGIMvcWwzo6HNiFFTN3h2Wk8xa3mcmuUxivdtSsMA1cUK8SP8xKeiKd2DuAMW2T4NM4/3RNeVsDE0uN8o7+espTa7/rOMra25PXvrZoNFa/bScIaf9es16POx8V7f/gZCbpjdzoLGFGrIQ3iDTrJkgAUlbtpe9g/OQVI0Xhon9UQ569cNfr03eOm/qoOTV8V576e+0WtOuAk9FCScAfASNrN8fHWM0l95ac+kaDhMmx0tGrUNSdSXfVCVoDTupc1IUVEFkVaL0gaT3pA7r89rqpvSAUn1qWjlFgaMcXKsEe3Y36katQmCpka4doC5w36eYvUpFM9Loa73YQFqeYLqBhMPKrFOF8RVNK/DdUTlKUpLNGJGkrnLkvuXmypGXZKg7hsMwQFMhfSw5WanRtLI5HqQMbTZvdlN9ookJbqPdGMKq3kau7zdNDSY0GEyo0qn+5Ep/ZXI2xT+NBSi21xkT4lTWVzArkj+LaiGDRkFLZDFM2x5tqWQHa06FuA+qZuzV6fpf9NPuMMieEovFY1ZCDk0bFi5sa03i8c7bHmfh9AzLpJjPmgwbL4yhjatFg8RvY/yGWnMOpvuh12EvS48y5P4WkyKEi6aO8a67g+HKRwQMEMBdnV30nBZjI77/AePrXWT4hkakdbRp2Jmq0FSt+heF6S1b7RXWFQuj2Otm8Hf/rxvJmATZg+LjdFeP6jbRb8Zx2wuYmto9El53sbSZsZDR2uEOWfEIOAi1KJgGT6iqweoPdVCaykiKueERpjCk3Qg4yL002lEayIsv7GHWTWZwQ22KGwY4NSbuliyeoCiQ7zdai6kuTPJwquilBfnDtOqxUnmLIuTm3UoJPtUPLNNhmYhgSQzqkYOr7Im4DXx79sdJbzseEGlYnU3c2v2TZpNKpb1Ux44wm0dU5sqHSEXhUsH8Ld4c8O4hIf21jRzzsgQDbkPcYG5TdEZPcw/JTc7MWr7aTwnMbjNJlUX9jCramoexp7SPQiA1VnA+u9p1F/Ux4Kb9rAYyBqgxXU6NgR57mG/wyFNg7fvmw5X9HD6bf1ggmaoRF8vIuqFeEKh/eFpVFwb4e+/00u8D9SMQSQxcg8eD/kJn9PD2f8eJ9vn5ZXbS+h8pJRXiHDyTW0sMBUwbJItfraEbOg7kl5FITKGNlMhD/HL0sQ2ewbDoNKx2QV10Nl8qP1lhhnLBqjtM2jeoBM4tZ/aU1yEn/ES96WoWT6AJ1HAu61O3eYHk1Jf3zBpov+F47cc2xXoFr6SDAYa/Z1afj/H8WYpDNgku3XMUYYhRrGJB43+yCG+ZLqFryRLts8glTh4OX068cQ4DbeOUZsG6uC2WxheBXOwbdVrQUId9583/WTngnFuMX9TvgcZIaMS73Qd2XsTGv2JQz9tRgznw6MZlXjnKOE51PKjcYza3L99Kuawz8JKTN2R+tTdMiHGgQRECAcSECEcSECEcCABEcKBBEQIB5MqIP1m+0SXICaJaLploksAJllAmvofmegSxCSxc+DJiS4BmGQB2dL737QM/HmiyxATrKnvUd6MPjjRZQCT7FITISabSdWDCDHZSECEcCABEcKBBEQIBxIQIRxIQIRwIAERwsH/A60Qm/M/DwubAAAAAElFTkSuQmCC"},88069:(e,t,n)=>{n.d(t,{Z:()=>i});const i="data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAFUAAAAYCAYAAACLM7HoAAAABHNCSVQICAgIfAhkiAAAABl0RVh0U29mdHdhcmUAZ25vbWUtc2NyZWVuc2hvdO8Dvz4AAAAmdEVYdENyZWF0aW9uIFRpbWUAbWFyIDExIGF2ciAyMDIzIDEyOjU3OjA3TJhLoAAABItJREFUWIXtmX9IG2cYxz8dyx1oEywxgjv/iBYS0nYjweJBLcWM6Q1qB7UOmdWNywYeLESQ2nVUB5rJgl0LbTdQOuofq2HQH4PVQWWDbkOhg46WMQUDzv5RO1gqFWMLufyx/aGdtpqql4uzxe9/9z7v+z5fvvfc8zzve1u8JQf/YROm4qX/m8CLCOOiChJK+CPOnQ9S67WYSOn5x8tGF7rUIB31bkRgd1GKiepeftNNZPYcw1ikSn5C2pygAGz3E1KdJlFab+RQ6HFiN3FHA6LmUNHcQLlt8ZjAa1ojB6TMyAhyA+euBlGsT1vy2NPWyTf9TVRIUFjTzg+3PkP1ZOZvzmcjX10O4F/i0zjWLKrgrSN0aNtSg81HqLmMrZmwsRXg3l6AXVw8mEdFuJNThywMnvianyYhcX+CsdE73JvJxFn2sEZRJWrbFIrTWPMPNaCZWrQcVHR3Eqmc5oz6CX23HwEw+8sFgod7GZw00ZWJWJOo9v0NaD5h7mF8kA/kAG/IAeq6x+ZnFFHbpuA0hZoD5XSYyL44n6thordTCyarRKm8kAcFyUWpx4GAhUJvGcr+ckpLctLsm4NTLkOp9OLKz07Xsvrqb/USOiqzkHp09PvTTAFCcmGa6KsjVDNEy5Vp46xECeV0Ox3eCbrqT3H1z9QTZsF3kEjPNs54w1zVwa0G+VKO0R8vxm/TSdgKcG8XGOuJ8OGJEWYfr/NUEekJ4Lc9ZCL+EKtD4M6NBwiklnLIAKuMVAsurRGlaNGQLRfrfNBaHcIiQy7+5gb2GE38Yh7+7nY6vDG61KWCpl1WJMGZdmpqP+a9Ko13u+9SrAZ4u2R+grWM4z0B3KO91MnvU1MVolKO8J2+Dav4zK3XjNWJKvlprS/mCd9i7nzUWrDacp+cX7SXkOZCwAhysTtyIamTSK4+gpLjw1yaz7mQItY3wE0kXvXMfeL26moUcYiu5uvEHvfT+h0Go7eYSi67pWGsQtQclKN17LY9NSwK/4kmik/nJgF3fQO1JawdyUkuaRH6Z2Qi0RYUw23aQxIzIIgAFtw+CUZHuLkOB5QVRRXkRpqql2mhxJ1o0Xa+ON/OkcrlWqxdqK3lxprqmRHOqhH64z46oi0cKDGvoBj7etaGFUR1crjVv3wLNTPBpU9PEtR66bvxYNnV+VWNNMkGBUmMcFYN0xv3cbwvU2FT/H4jhu7by5sZHlBWg2eKWljTiOpL827Hh7l2+xHokwwOxFg+LRXwVlsdLqPsEjH61DC9d3dxPHqMWo9xYWcHvuXi3Z2EeppQPHPt1lZPOaHWvbyyboXKWoZ21EfaIr6jCm2/C6enjCZ1F+l4iTsUQu84jDN8LOy4kyN9x6g3Kqwe46wW4WLcR8fABW6NX+HHHgV+/YN7JheqLekuqQU5yPfR18k3wUny55PsCwyzUS6xBGsedpvO1OSjrHBKG6n66BDXx01wmfyb65dHNoygAHpimr+yJCg8I1LnYMEu5WEVDdbMpE5iZpqphLknlo2OFY6pKaYm40ytD5cXBpv/qLKATVGzgE1Rs4B/Aei/SnFKSWx/AAAAAElFTkSuQmCC"}}]); \ No newline at end of file diff --git a/assets/js/af231220.de109415.js b/assets/js/af231220.de109415.js deleted file mode 100644 index 0df308370c4..00000000000 --- a/assets/js/af231220.de109415.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[5326],{35318:(e,t,n)=>{n.d(t,{Zo:()=>A,kt:()=>u});var i=n(27378);function r(e,t,n){return t in e?Object.defineProperty(e,t,{value:n,enumerable:!0,configurable:!0,writable:!0}):e[t]=n,e}function a(e,t){var n=Object.keys(e);if(Object.getOwnPropertySymbols){var i=Object.getOwnPropertySymbols(e);t&&(i=i.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),n.push.apply(n,i)}return n}function o(e){for(var t=1;t=0||(r[n]=e[n]);return r}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(i=0;i=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(r[n]=e[n])}return r}var l=i.createContext({}),s=function(e){var t=i.useContext(l),n=t;return e&&(n="function"==typeof e?e(t):o(o({},t),e)),n},A=function(e){var t=s(e.components);return i.createElement(l.Provider,{value:t},e.children)},m={inlineCode:"code",wrapper:function(e){var t=e.children;return i.createElement(i.Fragment,{},t)}},d=i.forwardRef((function(e,t){var n=e.components,r=e.mdxType,a=e.originalType,l=e.parentName,A=c(e,["components","mdxType","originalType","parentName"]),d=s(n),u=r,p=d["".concat(l,".").concat(u)]||d[u]||m[u]||a;return n?i.createElement(p,o(o({ref:t},A),{},{components:n})):i.createElement(p,o({ref:t},A))}));function u(e,t){var n=arguments,r=t&&t.mdxType;if("string"==typeof e||r){var a=n.length,o=new Array(a);o[0]=d;var c={};for(var l in t)hasOwnProperty.call(t,l)&&(c[l]=t[l]);c.originalType=e,c.mdxType="string"==typeof e?e:r,o[1]=c;for(var s=2;s{n.r(t),n.d(t,{assets:()=>l,contentTitle:()=>o,default:()=>m,frontMatter:()=>a,metadata:()=>c,toc:()=>s});var i=n(25773),r=(n(27378),n(35318));const a={sidebar_position:2,title:"Installing the `kind` CLI",description:"Kind is one way to get Kubernetes running on your workstation.",keywords:["podman desktop","podman","containers","migrating","kubernetes","kind"],tags:["migrating-to-kubernetes","kind"]},o="Installing the kind CLI",c={unversionedId:"kind/installing",id:"kind/installing",title:"Installing the `kind` CLI",description:"Kind is one way to get Kubernetes running on your workstation.",source:"@site/docs/kind/installing.md",sourceDirName:"kind",slug:"/kind/installing",permalink:"/docs/kind/installing",draft:!1,editUrl:"https://github.com/containers/podman-desktop/tree/main/website/docs/kind/installing.md",tags:[{label:"migrating-to-kubernetes",permalink:"/docs/tags/migrating-to-kubernetes"},{label:"kind",permalink:"/docs/tags/kind"}],version:"current",sidebarPosition:2,frontMatter:{sidebar_position:2,title:"Installing the `kind` CLI",description:"Kind is one way to get Kubernetes running on your workstation.",keywords:["podman desktop","podman","containers","migrating","kubernetes","kind"],tags:["migrating-to-kubernetes","kind"]},sidebar:"mySidebar",previous:{title:"Kind",permalink:"/docs/kind/"},next:{title:"Configuring Podman for Kind",permalink:"/docs/kind/configuring-podman-for-kind-on-windows"}},l={},s=[{value:"Procedure",id:"procedure",level:4},{value:"Verification",id:"verification",level:4}],A={toc:s};function m(e){let{components:t,...a}=e;return(0,r.kt)("wrapper",(0,i.Z)({},A,a,{components:t,mdxType:"MDXLayout"}),(0,r.kt)("h1",{id:"installing-the-kind-cli"},"Installing the ",(0,r.kt)("inlineCode",{parentName:"h1"},"kind")," CLI"),(0,r.kt)("h4",{id:"procedure"},"Procedure"),(0,r.kt)("ul",null,(0,r.kt)("li",{parentName:"ul"},"In the status bar, click on ",(0,r.kt)("strong",{parentName:"li"},"Kind"),", and follow the prompts.\n",(0,r.kt)("img",{alt:"Kind in the status bar",src:n(88069).Z,width:"85",height:"24"}))),(0,r.kt)("h4",{id:"verification"},"Verification"),(0,r.kt)("ol",null,(0,r.kt)("li",{parentName:"ol"},(0,r.kt)("p",{parentName:"li"},"The status bar does not display ",(0,r.kt)("strong",{parentName:"p"},"Kind"),".")),(0,r.kt)("li",{parentName:"ol"},(0,r.kt)("p",{parentName:"li"},(0,r.kt)("strong",{parentName:"p"},(0,r.kt)("icon",{icon:"fa-solid fa-cog",size:"lg"})," Settings > Resources")," contain a ",(0,r.kt)("strong",{parentName:"p"},"Kind")," tile.\n",(0,r.kt)("img",{alt:"Kind resource tile",src:n(64121).Z,width:"200",height:"131"}))),(0,r.kt)("li",{parentName:"ol"},(0,r.kt)("p",{parentName:"li"},"You can run the ",(0,r.kt)("inlineCode",{parentName:"p"},"kind")," CLI:"),(0,r.kt)("pre",{parentName:"li"},(0,r.kt)("code",{parentName:"pre",className:"language-shell-session"},"$ kind get clusters\n")))))}m.isMDXComponent=!0},64121:(e,t,n)=>{n.d(t,{Z:()=>i});const i="data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAMgAAACDCAYAAADIx1QxAAAABHNCSVQICAgIfAhkiAAAABl0RVh0U29mdHdhcmUAZ25vbWUtc2NyZWVuc2hvdO8Dvz4AAAAmdEVYdENyZWF0aW9uIFRpbWUAbWFyIDExIGF2ciAyMDIzIDEyOjI4OjU2rKtDNQAAFLpJREFUeJzt3Xt4VPWdx/H3uc01mQwJSTAXCEgSDWBAxVuhLnQRW7yvbotttVVbta1b7VO7K7aPWC/tbp/drm3tsz7V2rXt9r7rtdW2ihe03hAQGCERopiEJEMmk8tcz8w5+8eEkEA4ZCCYGL+vP2RyZuZ3vmee+Zzf73fOmaMya9bxtmFoKIqKqqoIIfbTPR73RNcgxKQlXYYQDiQgQjiQgAjhQAIihAMJiBAOJCBCOJCACOFAAiKEAwmIEA4kIEI4kIAI4UACIoQDPa8Xe7w0XPYVqs78OLqhYaOgKKAoKijjkzXbtsC2wbaxAQWwsQAV24ZsKkHnmy+y/eEHiIfbAXtc1ivEaPIKiG96JbOWrmK6302RW0UZ/qSijPw7T/a+/9raActy/2ayEM/a9Lt0qs48l0D1XLb88vt0N23KBUqIYyCvgBQeNwuv28WcIp1pHu3wbxhHlm1jWpDMWLQNZGmtPJ7GK/+ZV394CwN7Wt7XWsSHR17jIs+0Mjyaglff31dkMxmy2ey4F3YgVVFwawpFbo2GEhezAhoFM2bSeOXNoBxN3yXEoeUXkGAJuqqgqfu/kDvefIN3mt4a98IOp6pAp9BQKKlbSNn809/39YsPh7wC4i+rQldBG7bDNk0TM5Ue77oOy6crlHpz86Djz/00urfgfa9BTH159iDTMVQFdRIMaRRFYWaBhkuDYE09MxrPmuiSxBSU1yTd8PlH9B75+FPLTh7Ytpmkw3zF1iE9Uxl1TnFL1WKWB2eOWObSVWYXauzIFjDzoxfQ0/IWsc73jqzAwzFmc9Z5S/Fv+wN/aYod/HzpIj6xcgE0Pc1fXu2i4pzruaxuB/9z31O0m+NXRuO193JjzZN845bHCI9fs+IQ8upBDI8fdfjwKp1CI0MqFmH3js207dxGOhk/okJmFfr5XOV8zvfNpkAbe26rC3Uq/RoldQuZ98kbMPyF+9v86AXMWfFJXAWBI6ppBGM2Kz77D6yYFzz4qcrlfP27a7l8kZ+2pjZMyli48mOctuRjLDz45UdTBP5gGX6XMZ6NCgf5nSj0+kYEJJWIYSb7sbIZwm0DKIpKoGQGLo9vzG1Oc7u4eEY9ndum8+YmBZdhc83JM3l7zk4e72477PsVRaFumo6q2KiNH6Ho9odoffFPdG15mRMvvZ5MKsnAnnfo2vpKPps6ZkblSm7+9peojT7K3d96gFAcoI1H7riR5mAPIdnNf6DlFRBVN0bOP2wbe9hJutzjsZ20K3G7WRqooTBcyZvrIJEGnxtMU+H59QrBTXV88aRZbCrbyQazy3kjVIX6aQZzinTi5VUolavQj49QsvVmrGyWFVW7iXhT/Otr43uLI6NmJTd/60vUdv2Bu+94iObhnWe0hVB0XFcnJkBeAQEOOluuayrW4EJFUbDSKcxkbOjVmstNwrbYme0l7bfJZnONnFc5m+anKwijkM7YLJ3nomGmQTxl8/SmFB09WXZtcXPmSfW0eKLs6NxLrRakunD04ZKiKLg0BZcGrkQKJfIWFXtfoilVSo3RT3XZ+B5YMGrOZ823rqGm7X7W3vEY7x4wzyiat5zTgq28+GITcYDSRaxY5KJp3SuEK0/n75bMp9Toof3V9Ty7rYtRpym+2SxesojasgKibW/w2vod47oN4vDyDsg+tm2RDL/H9KKiEcuTe1tJdbcP/a25PSQqa3jJ7CBRkru6SkVhz14XsQQcf5zGbZ8uYP3WFP0Ji0QKvnxeAT0xi//64wDdrS6Kig2e6XyXaiNwyIAcqMLVx65UCR4lw+ZEBaf5dgOuI93cEXw1l3DzHVdS2fRj1n73qYPCAVC57Aq+MP8F3nmxiWbAqDuXK68r46Wyc6ldEiTcFsUoXc6q81fziafuZu19G+kd9v7Sj/wTa677GJV08k5rFJas5PJPNhEa5fiAOHaOOCBWJsNAtJtNmzbR05MbS1RXVzNvXsOIW5hm4pnctVRY7JvA+FSdd9rAyOaGRy5N4cRqHRQF27YZSFo0zjGIJWy2785QXOKjwxoga1uHrcu2bWwb3ojPZIF7Bx1mAVVGD/ro++i8GXWrWXPJ6QS33sPa/3gmzyNUVdQGf83a614ZDIOfhmv/jTUrr+ey9V/k/m371nEFa25YirHxHm4cWodB6WlX8NUbTgbnEacYR3lfgjt8zqHrOuXl5VRVVlJVWUlRIDDi+UM5wVtEnTvX83jcCt39FtWlOnOP0zmx2sWeHosZ03R8bgXLhmVl1YepCTKWTW8qS9tAlh0JH+Hp89h8whfZNfsCNkQ8PPSWJ99NHVVw/iJq/DHaN+4gnHfmWnj2N68M6ylihH7+KM3pcurqygaX+Vl88Uoqu57knhEBNAm/+hB/3Pr+n5T9MMurB8kkE2QsN309EVKJGLGBGH6fH4879+XTNI3+vn6U4RN5RcEMd+GKDuDOpgAoMkvxpjw0VCssW+DGYyj8fn2cmy4O8NZuk65oFpcOK05288LWFGWZ6fiTCVI9ESJdHQAEiqej67nyU1mLt6MZIskMu197lt0v/5VEpJNF13yLjCfOhpbXiIWP7PDzgcJPfYffBa/nq9fdxRrX7dz9eEtefdNBrzW7iJoQ9PsHF8xmYV0BbeufoXkcz5+II5NfQOL9xGI6Tz75S97auCH3240xmjv8ccPJZMrq2fieTkc0xkVnejm11sXPnx7A41JYUGNwzyP9PPy3JJoKfjtC/fNPE1r3Z0KAt6CQq792K9NnVGDbNqGISVfMpOnRn9H02E+H1vPMrZejqBq2NY4XU8Z6eO0Xt3IPd/HVq+5kDd/MOySODD8+P8SiMtmYDPIaYmXSKbz+Qi67+iucuPDUoeWaqlJaUgxAybSDz4wpioLL5RrqWULbN0H3U0zz20T6LV7ensLvUUlnwG0o9MUs/vfFBJoK82eEeeLhH4y4Ynj1dTcOhaN1IEs4YRHe+grvvvDoQese13AMifLaj27le09Fqb3qTm67uI5xO3VndhHugrLZlePXpjhieQYkiWnl5hiNp39kaPm0YBGXrFqJ1+PmuPJSDF1nevE0Cgv86LrO7JlVnDB3Dm537iiSZVm07HieJTO3YGgwkLD5wSP9rN+W4vfrEzy/NTcUKyuIYXU/SU/P/rNtbo+HshmVACQyNu/2ZzBjvbzz3GMko3uP7tPIS5TN932D7z3VRc1nb+O2z9Qx9tOjTlp4aWMrwdNWs6LywOdcDI3ExPsir4DEw+1k7dypwJraE4aWG7rOKSfN51MXn8+nLjqPuXNquPHaz/Opi87jrlu+xom1cznz1EVow45updJp/vrkg3x5ZYLd4SxdvRadUYu9fRbbdmdQFLhgfjNvN70xYuK/5Jzz8fh82LZNWyxLIgMDHa2Et7x0VL9oPDIxNt/3Te5+rIuaS25j7Wfmj0tImn9zP89G6/nct+/kymXzqSgto6LudC782p1cXjc+h6rF2OQ1B4lHOslakLXA7fUy8/g6du9swgbchkEymcLlcmHbNpu2vIXPk5u8JxIJ2vZ0jNrmo//3Q1afdT7hqD3iHPyJVSo/++UvRrzWXxigpv7EXC0Zm70JC8uyCP32B1jZTD6bMo5ihB78JndzJzdfchtrjdtZ++DWo2syvpEf/8taojdcw4ob7mIVQLqTTY8/wO+2fZ3Pjev1XcKJUl/fMOYfdM/9+OWc+ekbOKnEwGuoPPfHR1j3+B/weNzUz5lNpLeX6orj2La9iWAggKZppDMmc2fX0Nq+h5bdrUf168MFi8/k/Ms/j8vtYWt3mj0xi9aXn2LDT+6APA4YfKAYQUqDEA1Hx+9AgBiz/HqQvZ0kMzaprI3XgMrZx6OoKslkis2h7QC817YHgN7+gaH3tbaP3nvkw+X2cELjKSTQeaUtSSIL6Vgf2x++f+qGA8CMEpYLHidMXgHpa91JLB5n414fQXcWJVDFiauuoGdPK+l4P9lUHMtMY1sWuTuUDL8vyeCiwSVD8wVl2F9D508UVF1D1d3oXj+GrxBPcDrt006grTM3lEpEugj97l5i4T1HtOFCjEVeQyzN5aFm2SUUz12AJxDEHrwXlleDcl/usW3vC4Y97DFD/x4UEGDw5lqAkjsUrCjDTjYqRFIW/WmLbCZDqi9CLNxOeNtrRJo2HaPDuELk5BUQAEXV0FxuFE3PfadtOGe2n7Mrjt3Rlba4zb0bo2DbWNkMViaN/T7cSUWIvC9WtK0smWG/GvTpCgu8KlY8RTyTJTumm7iN7YCsooBH1ThOA585QG96Cs81xKR0xFfz7uPVNbriBt0JhRfaY3TF9x9rOWQMxnjTB7emcFp5gKoCFwG3m9504mjLFSIvRx0QUDAtlSwKfWmF7uT47eXdmko8q5DIKOjqxN9JRXz45D0HEeLDRP73B0I4kIAI4UACIoQDCYgQDiQgQjiQgAjhQAIihAMJiBAOJCBCOJCACOFAAiKEAwmIEA4kIEI4kIAI4UACIoQDCYgQDiQgQjiQgAjhQAIihAMJiBAOJCBCOJCACOFAAiKEAwmIEA4kIEI4kIAI4UACIoQDCYgQDiQgQjiQgAjhQAIihAMJiBAOJCBCOJCACOFAAiKEAwmIEA4kIEI4kIAI4UACIoQDCYgQDiQgQjiQgAjhQAIihAMJiBAOJCBCOJCACOFAAiKEA32iCzjQ/KLPUB+4hGJX7USXIiZAJN3M9r7fsq331xNdCjDJAtJYdDWnTb9xossQE6jYVctZ028FW2db3y8mupzJNcSqC1w40SWISaKh6B8nugRgEgVEQSVgzJzoMsQkETBmokyCr+fEVzDIxkJVtIkuQ0wSqqJhY010GZMnIEJMRhIQIRxIQIRwIAERwsGHLiBqIIvba090GeIDYlKdKDxmvCnmXNTH3FOSBHy5Rdleg46XA2x9wkd/ZmLLE5PX1A9IcZzTb+qmPO4j9FA574VcmEaGkoYB5q7qZlldhue+H6D3GIbEfcZezm708Nx9BaSO3WrEMTDFA2JSf3U35d1B1v2ocH9PkdEJbwgSDnmpqNKOaTgAXIEs/oAM6z6IpnRA1JN6qa1yEbq7cPRhVMJNe/Pg40Cc+ZemiTzhpnBVPxVeD5vvDRDBpvCkXuqXpik0FPpb/OwYPizTsxQ3xpjVmCZQkoW4Tse6IppDOpaepP7qAUqLTbRAjMXXpsjGPYR+XkAvYNTEaFgeJ1hik+7wsuuJAjojyujbUtvH4kad7a/bzFkZI+hViLf4CR0wRDxkm3qSuasTJJ+YRmsEwKZ4WYQ5ZiGvr3fl3lweY9Fym12/ytUnpvQk3aZkXhqj1cd7nWN4uZ6htDFOw6UD+JoK2PGCmxg2xRd2sWx1mmyogOYXPFDXw7Kb+ijet2vxpZh1honZ5KP5iQA7m23mXNtFY4MNGZ3I6146OlWyCZ32zV7e22yQBIyGCMu+0kthn5edz/iJGDFOv3kvc8oPUV9Jioozelm43CTyt0J2vKzjOaObJasTGIMvcWwzo6HNiFFTN3h2Wk8xa3mcmuUxivdtSsMA1cUK8SP8xKeiKd2DuAMW2T4NM4/3RNeVsDE0uN8o7+espTa7/rOMra25PXvrZoNFa/bScIaf9es16POx8V7f/gZCbpjdzoLGFGrIQ3iDTrJkgAUlbtpe9g/OQVI0Xhon9UQ569cNfr03eOm/qoOTV8V576e+0WtOuAk9FCScAfASNrN8fHWM0l95ac+kaDhMmx0tGrUNSdSXfVCVoDTupc1IUVEFkVaL0gaT3pA7r89rqpvSAUn1qWjlFgaMcXKsEe3Y36katQmCpka4doC5w36eYvUpFM9Loa73YQFqeYLqBhMPKrFOF8RVNK/DdUTlKUpLNGJGkrnLkvuXmypGXZKg7hsMwQFMhfSw5WanRtLI5HqQMbTZvdlN9ookJbqPdGMKq3kau7zdNDSY0GEyo0qn+5Ep/ZXI2xT+NBSi21xkT4lTWVzArkj+LaiGDRkFLZDFM2x5tqWQHa06FuA+qZuzV6fpf9NPuMMieEovFY1ZCDk0bFi5sa03i8c7bHmfh9AzLpJjPmgwbL4yhjatFg8RvY/yGWnMOpvuh12EvS48y5P4WkyKEi6aO8a67g+HKRwQMEMBdnV30nBZjI77/AePrXWT4hkakdbRp2Jmq0FSt+heF6S1b7RXWFQuj2Otm8Hf/rxvJmATZg+LjdFeP6jbRb8Zx2wuYmto9El53sbSZsZDR2uEOWfEIOAi1KJgGT6iqweoPdVCaykiKueERpjCk3Qg4yL002lEayIsv7GHWTWZwQ22KGwY4NSbuliyeoCiQ7zdai6kuTPJwquilBfnDtOqxUnmLIuTm3UoJPtUPLNNhmYhgSQzqkYOr7Im4DXx79sdJbzseEGlYnU3c2v2TZpNKpb1Ux44wm0dU5sqHSEXhUsH8Ld4c8O4hIf21jRzzsgQDbkPcYG5TdEZPcw/JTc7MWr7aTwnMbjNJlUX9jCramoexp7SPQiA1VnA+u9p1F/Ux4Kb9rAYyBqgxXU6NgR57mG/wyFNg7fvmw5X9HD6bf1ggmaoRF8vIuqFeEKh/eFpVFwb4e+/00u8D9SMQSQxcg8eD/kJn9PD2f8eJ9vn5ZXbS+h8pJRXiHDyTW0sMBUwbJItfraEbOg7kl5FITKGNlMhD/HL0sQ2ewbDoNKx2QV10Nl8qP1lhhnLBqjtM2jeoBM4tZ/aU1yEn/ES96WoWT6AJ1HAu61O3eYHk1Jf3zBpov+F47cc2xXoFr6SDAYa/Z1afj/H8WYpDNgku3XMUYYhRrGJB43+yCG+ZLqFryRLts8glTh4OX068cQ4DbeOUZsG6uC2WxheBXOwbdVrQUId9583/WTngnFuMX9TvgcZIaMS73Qd2XsTGv2JQz9tRgznw6MZlXjnKOE51PKjcYza3L99Kuawz8JKTN2R+tTdMiHGgQRECAcSECEcSECEcCABEcKBBEQIB5MqIP1m+0SXICaJaLploksAJllAmvofmegSxCSxc+DJiS4BmGQB2dL737QM/HmiyxATrKnvUd6MPjjRZQCT7FITISabSdWDCDHZSECEcCABEcKBBEQIBxIQIRxIQIRwIAERwsH/A60Qm/M/DwubAAAAAElFTkSuQmCC"},88069:(e,t,n)=>{n.d(t,{Z:()=>i});const i="data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAFUAAAAYCAYAAACLM7HoAAAABHNCSVQICAgIfAhkiAAAABl0RVh0U29mdHdhcmUAZ25vbWUtc2NyZWVuc2hvdO8Dvz4AAAAmdEVYdENyZWF0aW9uIFRpbWUAbWFyIDExIGF2ciAyMDIzIDEyOjU3OjA3TJhLoAAABItJREFUWIXtmX9IG2cYxz8dyx1oEywxgjv/iBYS0nYjweJBLcWM6Q1qB7UOmdWNywYeLESQ2nVUB5rJgl0LbTdQOuofq2HQH4PVQWWDbkOhg46WMQUDzv5RO1gqFWMLufyx/aGdtpqql4uzxe9/9z7v+z5fvvfc8zzve1u8JQf/YROm4qX/m8CLCOOiChJK+CPOnQ9S67WYSOn5x8tGF7rUIB31bkRgd1GKiepeftNNZPYcw1ikSn5C2pygAGz3E1KdJlFab+RQ6HFiN3FHA6LmUNHcQLlt8ZjAa1ojB6TMyAhyA+euBlGsT1vy2NPWyTf9TVRIUFjTzg+3PkP1ZOZvzmcjX10O4F/i0zjWLKrgrSN0aNtSg81HqLmMrZmwsRXg3l6AXVw8mEdFuJNThywMnvianyYhcX+CsdE73JvJxFn2sEZRJWrbFIrTWPMPNaCZWrQcVHR3Eqmc5oz6CX23HwEw+8sFgod7GZw00ZWJWJOo9v0NaD5h7mF8kA/kAG/IAeq6x+ZnFFHbpuA0hZoD5XSYyL44n6thordTCyarRKm8kAcFyUWpx4GAhUJvGcr+ckpLctLsm4NTLkOp9OLKz07Xsvrqb/USOiqzkHp09PvTTAFCcmGa6KsjVDNEy5Vp46xECeV0Ox3eCbrqT3H1z9QTZsF3kEjPNs54w1zVwa0G+VKO0R8vxm/TSdgKcG8XGOuJ8OGJEWYfr/NUEekJ4Lc9ZCL+EKtD4M6NBwiklnLIAKuMVAsurRGlaNGQLRfrfNBaHcIiQy7+5gb2GE38Yh7+7nY6vDG61KWCpl1WJMGZdmpqP+a9Ko13u+9SrAZ4u2R+grWM4z0B3KO91MnvU1MVolKO8J2+Dav4zK3XjNWJKvlprS/mCd9i7nzUWrDacp+cX7SXkOZCwAhysTtyIamTSK4+gpLjw1yaz7mQItY3wE0kXvXMfeL26moUcYiu5uvEHvfT+h0Go7eYSi67pWGsQtQclKN17LY9NSwK/4kmik/nJgF3fQO1JawdyUkuaRH6Z2Qi0RYUw23aQxIzIIgAFtw+CUZHuLkOB5QVRRXkRpqql2mhxJ1o0Xa+ON/OkcrlWqxdqK3lxprqmRHOqhH64z46oi0cKDGvoBj7etaGFUR1crjVv3wLNTPBpU9PEtR66bvxYNnV+VWNNMkGBUmMcFYN0xv3cbwvU2FT/H4jhu7by5sZHlBWg2eKWljTiOpL827Hh7l2+xHokwwOxFg+LRXwVlsdLqPsEjH61DC9d3dxPHqMWo9xYWcHvuXi3Z2EeppQPHPt1lZPOaHWvbyyboXKWoZ21EfaIr6jCm2/C6enjCZ1F+l4iTsUQu84jDN8LOy4kyN9x6g3Kqwe46wW4WLcR8fABW6NX+HHHgV+/YN7JheqLekuqQU5yPfR18k3wUny55PsCwyzUS6xBGsedpvO1OSjrHBKG6n66BDXx01wmfyb65dHNoygAHpimr+yJCg8I1LnYMEu5WEVDdbMpE5iZpqphLknlo2OFY6pKaYm40ytD5cXBpv/qLKATVGzgE1Rs4B/Aei/SnFKSWx/AAAAAElFTkSuQmCC"}}]); \ No newline at end of file diff --git a/assets/js/b104dd1e.7db7c3e0.js b/assets/js/b104dd1e.7db7c3e0.js deleted file mode 100644 index 2f8be739a5c..00000000000 --- a/assets/js/b104dd1e.7db7c3e0.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[6623],{35318:(e,t,n)=>{n.d(t,{Zo:()=>c,kt:()=>d});var o=n(27378);function a(e,t,n){return t in e?Object.defineProperty(e,t,{value:n,enumerable:!0,configurable:!0,writable:!0}):e[t]=n,e}function r(e,t){var n=Object.keys(e);if(Object.getOwnPropertySymbols){var o=Object.getOwnPropertySymbols(e);t&&(o=o.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),n.push.apply(n,o)}return n}function i(e){for(var t=1;t=0||(a[n]=e[n]);return a}(e,t);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(e);for(o=0;o=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(a[n]=e[n])}return a}var s=o.createContext({}),l=function(e){var t=o.useContext(s),n=t;return e&&(n="function"==typeof e?e(t):i(i({},t),e)),n},c=function(e){var t=l(e.components);return o.createElement(s.Provider,{value:t},e.children)},m={inlineCode:"code",wrapper:function(e){var t=e.children;return o.createElement(o.Fragment,{},t)}},u=o.forwardRef((function(e,t){var n=e.components,a=e.mdxType,r=e.originalType,s=e.parentName,c=p(e,["components","mdxType","originalType","parentName"]),u=l(n),d=a,k=u["".concat(s,".").concat(d)]||u[d]||m[d]||r;return n?o.createElement(k,i(i({ref:t},c),{},{components:n})):o.createElement(k,i({ref:t},c))}));function d(e,t){var n=arguments,a=t&&t.mdxType;if("string"==typeof e||a){var r=n.length,i=new Array(r);i[0]=u;var p={};for(var s in t)hasOwnProperty.call(t,s)&&(p[s]=t[s]);p.originalType=e,p.mdxType="string"==typeof e?e:a,i[1]=p;for(var l=2;l{n.r(t),n.d(t,{assets:()=>s,contentTitle:()=>i,default:()=>m,frontMatter:()=>r,metadata:()=>p,toc:()=>l});var o=n(25773),a=(n(27378),n(35318));const r={title:"Running Compose files",description:"With Podman Desktop, you can manage multi-container applications defined in Compose files.",sidebar_position:3,keywords:["compose"],tags:["compose"]},i=void 0,p={unversionedId:"compose/running-compose",id:"compose/running-compose",title:"Running Compose files",description:"With Podman Desktop, you can manage multi-container applications defined in Compose files.",source:"@site/docs/compose/running-compose.md",sourceDirName:"compose",slug:"/compose/running-compose",permalink:"/docs/compose/running-compose",draft:!1,editUrl:"https://github.com/containers/podman-desktop/tree/main/website/docs/compose/running-compose.md",tags:[{label:"compose",permalink:"/docs/tags/compose"}],version:"current",sidebarPosition:3,frontMatter:{title:"Running Compose files",description:"With Podman Desktop, you can manage multi-container applications defined in Compose files.",sidebar_position:3,keywords:["compose"],tags:["compose"]},sidebar:"mySidebar",previous:{title:"Setting up Compose",permalink:"/docs/compose/setting-up-compose"},next:{title:"Kubernetes",permalink:"/docs/kubernetes/"}},s={},l=[{value:"Prerequisites",id:"prerequisites",level:4},{value:"Procedure",id:"procedure",level:4},{value:"Verification",id:"verification",level:4}],c={toc:l};function m(e){let{components:t,...r}=e;return(0,a.kt)("wrapper",(0,o.Z)({},c,r,{components:t,mdxType:"MDXLayout"}),(0,a.kt)("p",null,"With Podman Desktop, you can manage multi-container applications defined in a Compose file."),(0,a.kt)("h4",{id:"prerequisites"},"Prerequisites"),(0,a.kt)("ul",null,(0,a.kt)("li",{parentName:"ul"},(0,a.kt)("a",{parentName:"li",href:"/docs/onboarding-for-containers/installing-podman"},"Podman")," 4.7.0 or greater."),(0,a.kt)("li",{parentName:"ul"},(0,a.kt)("a",{parentName:"li",href:"/docs/compose/setting-up-compose"},"You have set up Compose"),"."),(0,a.kt)("li",{parentName:"ul"},(0,a.kt)("a",{parentName:"li",href:"https://github.com/compose-spec/compose-spec/blob/master/spec.md#compose-file"},"You have a Compose file"),", such as ",(0,a.kt)("inlineCode",{parentName:"li"},"compose.yaml"),".")),(0,a.kt)("h4",{id:"procedure"},"Procedure"),(0,a.kt)("ul",null,(0,a.kt)("li",{parentName:"ul"},(0,a.kt)("p",{parentName:"li"},"Run the command in a terminal:"),(0,a.kt)("pre",{parentName:"li"},(0,a.kt)("code",{parentName:"pre",className:"language-shell-session"},"$ podman compose --file compose.yaml up --detach\n")),(0,a.kt)("details",null,(0,a.kt)("summary",null,(0,a.kt)("p",{parentName:"li"},"(Alternatively) With an older Podman version, run ",(0,a.kt)("inlineCode",{parentName:"p"},"docker-compose"),":")),(0,a.kt)("ol",{parentName:"li"},(0,a.kt)("li",{parentName:"ol"},(0,a.kt)("p",{parentName:"li"},(0,a.kt)("a",{parentName:"p",href:"/docs/migrating-from-docker/using-the-docker_host-environment-variable"},"Set the DOCKER_HOST variable"),".")),(0,a.kt)("li",{parentName:"ol"},(0,a.kt)("p",{parentName:"li"},"Run ",(0,a.kt)("inlineCode",{parentName:"p"},"docker-compose")," rather than ",(0,a.kt)("inlineCode",{parentName:"p"},"podman compose"),":"),(0,a.kt)("pre",{parentName:"li"},(0,a.kt)("code",{parentName:"pre",className:"language-shell-session"},"$ docker-compose --file compose.yaml up --detach\n"))))),(0,a.kt)("details",null,(0,a.kt)("summary",null,(0,a.kt)("p",{parentName:"li"},"(Optionally) Learn about Compose commands:")),(0,a.kt)("pre",{parentName:"li"},(0,a.kt)("code",{parentName:"pre",className:"language-shell-session"},"$ podman compose --help\n"))))),(0,a.kt)("h4",{id:"verification"},"Verification"),(0,a.kt)("ol",null,(0,a.kt)("li",{parentName:"ol"},(0,a.kt)("p",{parentName:"li"},"The Compose engine starts the containers and services, and adds a label to each resource:"),(0,a.kt)("ul",{parentName:"li"},(0,a.kt)("li",{parentName:"ul"},"Container label: ",(0,a.kt)("inlineCode",{parentName:"li"},"com.docker.compose.project")),(0,a.kt)("li",{parentName:"ul"},"Service label: ",(0,a.kt)("inlineCode",{parentName:"li"},"com.docker.compose.service")))),(0,a.kt)("li",{parentName:"ol"},(0,a.kt)("p",{parentName:"li"},"Podman Desktop detects the Compose labels, and displays the container group as a group of containers."),(0,a.kt)("p",{parentName:"li"},"The Podman Desktop ",(0,a.kt)("strong",{parentName:"p"},(0,a.kt)("icon",{icon:"fa-solid fa-cube",size:"lg"})," Containers")," list displays the containers created by Compose grouped in a container group with a ",(0,a.kt)("inlineCode",{parentName:"p"},"(compose)")," suffix, such as ",(0,a.kt)("inlineCode",{parentName:"p"},"flask-redis (compose)"),"."))),(0,a.kt)("p",null,(0,a.kt)("img",{alt:"img2",src:n(64228).Z,width:"1017",height:"742"})))}m.isMDXComponent=!0},64228:(e,t,n)=>{n.d(t,{Z:()=>o});const o=n.p+"assets/images/compose-in-containers-view-b93a1a1667842a10985bf3203a035f3b.png"}}]); \ No newline at end of file diff --git a/assets/js/b104dd1e.e06e9c08.js b/assets/js/b104dd1e.e06e9c08.js new file mode 100644 index 00000000000..cc19e38e1ea --- /dev/null +++ b/assets/js/b104dd1e.e06e9c08.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[6623],{35318:(e,t,n)=>{n.d(t,{Zo:()=>c,kt:()=>d});var o=n(27378);function r(e,t,n){return t in e?Object.defineProperty(e,t,{value:n,enumerable:!0,configurable:!0,writable:!0}):e[t]=n,e}function a(e,t){var n=Object.keys(e);if(Object.getOwnPropertySymbols){var o=Object.getOwnPropertySymbols(e);t&&(o=o.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),n.push.apply(n,o)}return n}function i(e){for(var t=1;t=0||(r[n]=e[n]);return r}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(o=0;o=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(r[n]=e[n])}return r}var s=o.createContext({}),l=function(e){var t=o.useContext(s),n=t;return e&&(n="function"==typeof e?e(t):i(i({},t),e)),n},c=function(e){var t=l(e.components);return o.createElement(s.Provider,{value:t},e.children)},m={inlineCode:"code",wrapper:function(e){var t=e.children;return o.createElement(o.Fragment,{},t)}},u=o.forwardRef((function(e,t){var n=e.components,r=e.mdxType,a=e.originalType,s=e.parentName,c=p(e,["components","mdxType","originalType","parentName"]),u=l(n),d=r,k=u["".concat(s,".").concat(d)]||u[d]||m[d]||a;return n?o.createElement(k,i(i({ref:t},c),{},{components:n})):o.createElement(k,i({ref:t},c))}));function d(e,t){var n=arguments,r=t&&t.mdxType;if("string"==typeof e||r){var a=n.length,i=new Array(a);i[0]=u;var p={};for(var s in t)hasOwnProperty.call(t,s)&&(p[s]=t[s]);p.originalType=e,p.mdxType="string"==typeof e?e:r,i[1]=p;for(var l=2;l{n.r(t),n.d(t,{assets:()=>s,contentTitle:()=>i,default:()=>d,frontMatter:()=>a,metadata:()=>p,toc:()=>l});var o=n(25773),r=(n(27378),n(35318));const a={title:"Running Compose files",description:"With Podman Desktop, you can manage multi-container applications defined in Compose files.",sidebar_position:3,keywords:["compose"],tags:["compose"]},i=void 0,p={unversionedId:"compose/running-compose",id:"compose/running-compose",title:"Running Compose files",description:"With Podman Desktop, you can manage multi-container applications defined in Compose files.",source:"@site/docs/compose/running-compose.md",sourceDirName:"compose",slug:"/compose/running-compose",permalink:"/docs/compose/running-compose",draft:!1,editUrl:"https://github.com/containers/podman-desktop/tree/main/website/docs/compose/running-compose.md",tags:[{label:"compose",permalink:"/docs/tags/compose"}],version:"current",sidebarPosition:3,frontMatter:{title:"Running Compose files",description:"With Podman Desktop, you can manage multi-container applications defined in Compose files.",sidebar_position:3,keywords:["compose"],tags:["compose"]},sidebar:"mySidebar",previous:{title:"Setting up Compose",permalink:"/docs/compose/setting-up-compose"},next:{title:"Kubernetes",permalink:"/docs/kubernetes/"}},s={},l=[{value:"Prerequisites",id:"prerequisites",level:4},{value:"Procedure",id:"procedure",level:4},{value:"Verification",id:"verification",level:4}],c=(m="Icon",function(e){return console.warn("Component "+m+" was not imported, exported, or provided by MDXProvider as global scope"),(0,r.kt)("div",e)});var m;const u={toc:l};function d(e){let{components:t,...a}=e;return(0,r.kt)("wrapper",(0,o.Z)({},u,a,{components:t,mdxType:"MDXLayout"}),(0,r.kt)("p",null,"With Podman Desktop, you can manage multi-container applications defined in a Compose file."),(0,r.kt)("h4",{id:"prerequisites"},"Prerequisites"),(0,r.kt)("ul",null,(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("a",{parentName:"li",href:"/docs/onboarding-for-containers/installing-podman"},"Podman")," 4.7.0 or greater."),(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("a",{parentName:"li",href:"/docs/compose/setting-up-compose"},"You have set up Compose"),"."),(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("a",{parentName:"li",href:"https://github.com/compose-spec/compose-spec/blob/master/spec.md#compose-file"},"You have a Compose file"),", such as ",(0,r.kt)("inlineCode",{parentName:"li"},"compose.yaml"),".")),(0,r.kt)("h4",{id:"procedure"},"Procedure"),(0,r.kt)("ul",null,(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("p",{parentName:"li"},"Run the command in a terminal:"),(0,r.kt)("pre",{parentName:"li"},(0,r.kt)("code",{parentName:"pre",className:"language-shell-session"},"$ podman compose --file compose.yaml up --detach\n")),(0,r.kt)("details",null,(0,r.kt)("summary",null,(0,r.kt)("p",{parentName:"li"},"(Alternatively) With an older Podman version, run ",(0,r.kt)("inlineCode",{parentName:"p"},"docker-compose"),":")),(0,r.kt)("ol",{parentName:"li"},(0,r.kt)("li",{parentName:"ol"},(0,r.kt)("p",{parentName:"li"},(0,r.kt)("a",{parentName:"p",href:"/docs/migrating-from-docker/using-the-docker_host-environment-variable"},"Set the DOCKER_HOST variable"),".")),(0,r.kt)("li",{parentName:"ol"},(0,r.kt)("p",{parentName:"li"},"Run ",(0,r.kt)("inlineCode",{parentName:"p"},"docker-compose")," rather than ",(0,r.kt)("inlineCode",{parentName:"p"},"podman compose"),":"),(0,r.kt)("pre",{parentName:"li"},(0,r.kt)("code",{parentName:"pre",className:"language-shell-session"},"$ docker-compose --file compose.yaml up --detach\n"))))),(0,r.kt)("details",null,(0,r.kt)("summary",null,(0,r.kt)("p",{parentName:"li"},"(Optionally) Learn about Compose commands:")),(0,r.kt)("pre",{parentName:"li"},(0,r.kt)("code",{parentName:"pre",className:"language-shell-session"},"$ podman compose --help\n"))))),(0,r.kt)("h4",{id:"verification"},"Verification"),(0,r.kt)("ol",null,(0,r.kt)("li",{parentName:"ol"},(0,r.kt)("p",{parentName:"li"},"The Compose engine starts the containers and services, and adds a label to each resource:"),(0,r.kt)("ul",{parentName:"li"},(0,r.kt)("li",{parentName:"ul"},"Container label: ",(0,r.kt)("inlineCode",{parentName:"li"},"com.docker.compose.project")),(0,r.kt)("li",{parentName:"ul"},"Service label: ",(0,r.kt)("inlineCode",{parentName:"li"},"com.docker.compose.service")))),(0,r.kt)("li",{parentName:"ol"},(0,r.kt)("p",{parentName:"li"},"Podman Desktop detects the Compose labels, and displays the container group as a group of containers."),(0,r.kt)("p",{parentName:"li"},"The Podman Desktop ",(0,r.kt)("strong",{parentName:"p"},(0,r.kt)(c,{icon:"fa-solid fa-cube",size:"lg",mdxType:"Icon"})," Containers")," list displays the containers created by Compose grouped in a container group with a ",(0,r.kt)("inlineCode",{parentName:"p"},"(compose)")," suffix, such as ",(0,r.kt)("inlineCode",{parentName:"p"},"flask-redis (compose)"),"."))),(0,r.kt)("p",null,(0,r.kt)("img",{alt:"img2",src:n(64228).Z,width:"1017",height:"742"})))}d.isMDXComponent=!0},64228:(e,t,n)=>{n.d(t,{Z:()=>o});const o=n.p+"assets/images/compose-in-containers-view-b93a1a1667842a10985bf3203a035f3b.png"}}]); \ No newline at end of file diff --git a/assets/js/b2f554cd.7afd319e.js b/assets/js/b2f554cd.12630173.js similarity index 98% rename from assets/js/b2f554cd.7afd319e.js rename to assets/js/b2f554cd.12630173.js index 610c53a3aab..bd7055e89ee 100644 --- a/assets/js/b2f554cd.7afd319e.js +++ b/assets/js/b2f554cd.12630173.js @@ -1 +1 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[1477],{30010:e=>{e.exports=JSON.parse('{"blogPosts":[{"id":"podman-desktop-release-1.5","metadata":{"permalink":"/blog/podman-desktop-release-1.5","source":"@site/blog/2023-11-03-release-1.5.md","title":"Release Notes - Podman Desktop 1.5","description":"Podman Desktop 1.5 has been released!","date":"2023-11-03T00:00:00.000Z","formattedDate":"November 3, 2023","tags":[{"label":"podman-desktop","permalink":"/blog/tags/podman-desktop"},{"label":"release","permalink":"/blog/tags/release"},{"label":"kubernetes","permalink":"/blog/tags/kubernetes"},{"label":"openshift","permalink":"/blog/tags/openshift"},{"label":"onboarding","permalink":"/blog/tags/onboarding"},{"label":"compose","permalink":"/blog/tags/compose"},{"label":"extensions","permalink":"/blog/tags/extensions"},{"label":"settings","permalink":"/blog/tags/settings"}],"readingTime":8.14,"hasTruncateMarker":false,"authors":[{"name":"M\xe1ir\xedn Duffy","title":"User Experience Designer","url":"https://github.com/mairin","imageURL":"https://github.com/mairin.png","key":"duffy"}],"frontMatter":{"title":"Release Notes - Podman Desktop 1.5","description":"Podman Desktop 1.5 has been released!","slug":"podman-desktop-release-1.5","authors":"duffy","tags":["podman-desktop","release","kubernetes","openshift","onboarding","compose","extensions","settings"],"hide_table_of_contents":false,"image":"/blog/img/podman-desktop-release-1.5/onboarding-selkies.png"},"nextItem":{"title":"Release Notes - Podman Desktop 1.4","permalink":"/blog/podman-desktop-release-1.4"}},"content":"import ReactPlayer from \'react-player\'\\n\\nPodman Desktop 1.5 Release! \ud83c\udf89\\n\\nWith this release of Podman Desktop, we\'re introducing **a new onboarding feature** that we hope will earn your \ud83e\uddad seal of approval! But wait... there\'s so much more!\\n\\n- **Onboarding**: Guided setup and configuration of **Podman** and **Compose**\\n- **Podman 4.7.2**: [Podman 4.7.2](https://github.com/containers/podman/releases) is now included in Windows and Mac installers\\n- **Command Palette**: Gain easy access to various commands via a new keyboard-driven command palette\\n- **Expanded \\"Summary\\" tab for Kubernetes pods**: Go deep with extended details on Kubernetes pods in the pod \\"Summary\\" tab\\n- **Environment file support**: Chart out environment variables for new containers to access on creation\\n- **Enhancements to the Settings area**: Get your bearings with improved Docker compatibility mode controls\\n- **Improved user experience for state changes**: No more dead reckoning on container state with improved visual indication of status\\n- **Extension API improvements**: A boatload of improvements to the extension API enabling more goodness from \ud83e\uddad Podman Desktop\'s extensions\\n\\nPodman Desktop 1.5 is now available. [Click here to download it](/downloads)!\\n\\n![Podman-desktop-1-5-hero](img/podman-desktop-release-1.5/onboarding-selkies.png)\\n\\n---\\n\\n## Release Details\\n\\n### Onboarding\\n\\nWe are introducing a new feature providing guided flows for the initial setup of specific \ud83e\uddad Podman Desktop extensions. Release 1.5 features two new onboarding flows: Podman and Compose.\\n\\nTo start the Podman onboarding flow, you can start from the dashboard notification by clicking the \\"Set up\\" button:\\n![podman-onboarding-start](https://user-images.githubusercontent.com/799683/280362279-598cc052-5ea4-4c31-849c-da9bbbcc3e42.png)\\n![podman-onboarding](https://user-images.githubusercontent.com/799683/280363859-f35b85f8-1dd4-4b7f-a995-25fe5d1ccced.png)\\n\\nVisit **Settings > Resources** screen and click the Compose \\"Setup ...\\" button in order to start Compose onboarding:\\n![compose-onboarding-start](https://user-images.githubusercontent.com/799683/280276847-ca0558ab-70ad-48cc-8dd5-67e3eb465a62.png)\\n![compose-onboarding](https://user-images.githubusercontent.com/799683/280277936-77ba0fb2-5cb0-41de-a7cf-1a3d6400fd89.png)\\n\\n### Command Palette\\n\\nA new, search-driven command palette is now available to enable quick access to various commands available across \ud83e\uddad Podman Desktop. You can try this new tool out by hitting the F1 key. [#4081](https://github.com/containers/podman-desktop/pull/4081) && [#3979](https://github.com/containers/podman-desktop/pull/3979)\\n\\n\\n\\n### Expanded \\"Summary\\" tab for Kubernetes pods\\n\\nKubernetes pods now offer a more comprehensive set of information under the \\"Summary\\" tab, including networking, volumes, environment variables, and other key metadata.\\n\\n\\n\\n### Environment file support\\n\\nWhen creating a container from the Images list, there\'s now an option to provide an environment file to set env variables for the new container. [#4026](https://github.com/containers/podman-desktop/pull/4026) && [#4025](https://github.com/containers/podman-desktop/pull/4025)\\n\\n### Enhancements to the Settings area\\n\\nThe user experience for enabling or disabling Docker compatibility is improved, with a new entry in the **Settings > Preferences** screen that includes contextual guidance. [#4093](https://github.com/containers/podman-desktop/pull/4093)\\n\\n\\n\\n### Improved user experience for state changes\\n\\nThe user experience around state changes for containers, pods, and other objects in the UI is improved, with clear status messages and improved animated visual indicator of state changes. [#4056](https://github.com/containers/podman-desktop/pull/4056)\\n\\n\\n\\n\\n\\n### Extension API improvements\\n\\nThe \ud83e\uddad Podman Desktop extension API received many improvements, including:\\n\\n- In addition to pushing and listing image from an extension, it\'s now possible to pull images from a \ud83e\uddad Podman Desktop extension [#4155](https://github.com/containers/podman-desktop/pull/4155)\\n\\n- The \ud83e\uddad Podman Desktop extension API has been enhanced with both the ability to list images & networks and the ability to create containers & networks. [#4172](https://github.com/containers/podman-desktop/pull/4172)\\n\\n- \ud83e\uddad Podman Desktop extensions now have a consistent way to run administrative tasks. [#4049](https://github.com/containers/podman-desktop/pull/4049)\\n\\n- Extensions now have the ability to register a custom Kubernetes config generator. [#3970](https://github.com/containers/podman-desktop/pull/3970)\\n\\n- The ability of extensions to add commands to UI menus has been extended; previously for action menus it was only available in the Image list screen. It is now possible for extensions to add commands to the action menus of items listed on the Containers list screen as well. [#3947](https://github.com/containers/podman-desktop/pull/3947) & [#3963](https://github.com/containers/podman-desktop/pull/3963)\\n\\n- Extensions have gained the ability to contribute menu items in the UI based on specific conditions. [#3959](https://github.com/containers/podman-desktop/pull/3959)\\n\\n- Enhanced logic for displaying or hiding properties listed under the **Settings > Preferences** screens is now available. [#4159](https://github.com/containers/podman-desktop/pull/4159)\\n\\n\\n\\n---\\n\\n## Other Notable Enhancements\\n\\n- The progress of loading an image into Kind is now visible as a task in the task manager. [#4061](https://github.com/containers/podman-desktop/pull/4061)\\n\\n![kind-progress-task](https://user-images.githubusercontent.com/42176370/270154775-eb7007b4-fd0e-4287-be9e-40ffc412de35.png)\\n\\n- It\'s now possible to start a new Podman machine right after creation, or you can create it and wait to start it later. It\'s up to you! [#4046](https://github.com/containers/podman-desktop/pull/4046)\\n\\n![podman-start-now-or-later](https://user-images.githubusercontent.com/49404737/269941187-f4768833-ecfc-4d0b-8acf-d4afedb428d9.png)\\n\\n- The Podman machine and Kubernetes provider creation forms have an updated look & feel consisted with other forms in the user interface, along with minor bug fixes. [#4317](https://github.com/containers/podman-desktop/pull/4317)\\n\\n![Updated provider creation forms](https://user-images.githubusercontent.com/19958075/274694157-fe89f3bc-e5b8-4735-96e9-669fe52c7a41.png)\\n\\n- The empty screen message shown when a search filter results in no matches now provides a message specific to filter matching, including the specific filter terms and an explicit button for clearing the filter. Previously, the screen displayed a generic message about how to create new objects of the type displayed on the screen, which led to some confusion about the status of the system. [#3988](https://github.com/containers/podman-desktop/pull/3988)\\n\\n\\n\\n- New support for adding spin animations to icons is now available. [#4188](https://github.com/containers/podman-desktop/pull/4188)\\n\\n- There is a new indeterminate progress bar type available for the task manager; this is meant for providing limited status for actions whose APIs do not provide detailed status information. [#4016](https://github.com/containers/podman-desktop/pull/4016)\\n\\n- For authenticating as admin to perform administrative tasks, \ud83e\uddad Podman Desktop now provides touchID support for macOS. [#4050](https://github.com/containers/podman-desktop/pull/4050)\\n\\n![touchID-support](https://user-images.githubusercontent.com/436777/248588015-f08115bd-d211-43ad-bddd-286d7b3a7056.png)\\n\\n\\n\\n- Support for connecting to interactive terminals for containers via tty was added. [#3900](https://github.com/containers/podman-desktop/pull/3900)\\n\\n- It\'s now more clear which container/pod providers will autostart when \ud83e\uddad Podman Desktop starts. Previously autostart had both a global and a per-provider setting. It has been simplified by removing the global setting. [#3840](https://github.com/containers/podman-desktop/pull/3840)\\n\\n- The \\"Working with containers\\" section of the documentation has been reworked and improved. [#3951](https://github.com/containers/podman-desktop/pull/3951)\\n\\n---\\n\\n## Notable Bug Fixes\\n\\n- The disable registry command was not blocking subsequent pulls from disabled registries. This has been corrected. [#4183](https://github.com/containers/podman-desktop/pull/4183)\\n\\n- Some users behind network proxies were unable to complete workflow involving the download of online resources. The mechanism for fetching these resources has been fixed to be proxy compatible to address this issue. [#3994](https://github.com/containers/podman-desktop/pull/3994)\\n\\n- The status of pods running in Kubernetes that are undergoing the deletion process is now accurately reflected in the \ud83e\uddad Podman Desktop UI. [#3877](https://github.com/containers/podman-desktop/pull/3877)\\n\\n- The image details page always listed the image as being \\"not used\\" even when it was. This has been corrected. [#3985](https://github.com/containers/podman-desktop/pull/3985)\\n\\n- Previously, deleting a specific image tag would cause all tags with the same Image ID to be deleted. This has been fixed so only the selected image tag will be deleted. [#3837](https://github.com/containers/podman-desktop/pull/3837)\\n\\n- Could not view the pod details for some remote Kubernetes cluster pods due to an encoding error. [#4371](https://github.com/containers/podman-desktop/pull/4371)\\n\\n- Error logs were being tracked separately from the actions they applied to. This has been addressed for kind cluster creation failure [#4427](https://github.com/containers/podman-desktop/pull/4427) and Compose installation failure [#4407](https://github.com/containers/podman-desktop/pull/4407).\\n\\n- For Linux users, \ud83e\uddad Podman Desktop previously did not appear under the \\"Development\\" menu when installed via Flatpak; it appeared under \\"Utilities.\\" \ud83e\uddad Podman Desktop now appears under the \\"Development\\" menu. [#3911](https://github.com/containers/podman-desktop/pull/3911)\\n\\n- Podman Machine names are no longer prefixed with the \\"Podman Machine\\" string. [#3878](https://github.com/containers/podman-desktop/pull/3878)\\n\\n![touchID-support](https://user-images.githubusercontent.com/19958075/267378447-aafdfbd7-f005-4b94-8626-9e11eec61b95.png)\\n\\n- The initial action state of pods and containers was being displayed as \\"STARTING\\" regardless of actual state; this has been corrected. [#3889](https://github.com/containers/podman-desktop/pull/3889)\\n\\n- Resizing the application window no longer makes the last lines of a container\'s terminal invisible. [#3993](https://github.com/containers/podman-desktop/pull/3993)\\n\\n- An issue with incorrect terminal behavior in response to long lines in the terminal attached to a container has been resolved. [#3955](https://github.com/containers/podman-desktop/pull/3955)\\n\\n- A spacing issue on the run image form has been corrected. [#4089]https://github.com/containers/podman-desktop/pull/4089\\n\\n- The \\"podify\\" icon & button on the Containers list was unusually large in release 1.4. That regression has been corrected in this release. [#4122](https://github.com/containers/podman-desktop/pull/4122)\\n\\n- An error in the instructions for Windows users on migrating from Docker has been corrected. [#4157](https://github.com/containers/podman-desktop/pull/4157)\\n\\n---\\n\\n## Community Thank You\\n\\n\ud83c\udf89 We\u2019d like to say a big thank you to everyone who helped to make \ud83e\uddad Podman Desktop even better. In this\\nrelease we received pull requests from the following people:\\n\\n- [afbjorklund](https://github.com/afbjorklund) in [#4373 - docs: fix broken links and add lima onboarding](https://github.com/containers/podman-desktop/pull/4373), [#4372 - docs: clear up lima column on containers page](https://github.com/containers/podman-desktop/pull/4372), [#4091 - fix: avoid errors with unexpected JSON input](https://github.com/containers/podman-desktop/pull/4091), [#4098 - docs: Lima onboarding details](https://github.com/containers/podman-desktop/pull/4098), and [#3854 - fix: check if machine init rootful flag supported](https://github.com/containers/podman-desktop/pull/3854)\\n\\n- [axel7083](https://github.com/axel7083) in [#4061 - feat: adding task progress for kind](https://github.com/containers/podman-desktop/pull/4061), [#3970 - feat: extension can register custom kube generator](https://github.com/containers/podman-desktop/pull/3970), [#3959 - feat: add when property to extensions menus](https://github.com/containers/podman-desktop/pull/3959), [#4016 - feat: indeterminate progress bar](https://github.com/containers/podman-desktop/pull/4016), [#3963 - fix: ContainerList propagating containers in ComposeActions and PodActions](https://github.com/containers/podman-desktop/pull/3963), and [#3947 - feat: extend menus capabilities](https://github.com/containers/podman-desktop/pull/3947)\\n\\n- [ayushrakesh](https://github.com/ayushrakesh) in [#4415 - Update README.md](https://github.com/containers/podman-desktop/pull/4415#)\\n\\n- [eltociear](https://github.com/eltociear) in [#4194 - Update README.md](https://github.com/containers/podman-desktop/pull/4194)\\n\\n- [foxydeveloper](https://github.com/foxydevloper) in [#4157 - docs: Correct windows instructions for migrating from docker](https://github.com/containers/podman-desktop/pull/4157)\\n\\n- [harsh-solanki21](https://github.com/harsh-solanki21) in [#4162 - fix: Removed fullstop from summary](https://github.com/containers/podman-desktop/pull/4162)\\n\\n- [rahul0x00](https://github.com/rahul0x00) in [#4240 - fix typos in README.md](https://github.com/containers/podman-desktop/pull/4240)\\n\\n- [shelar1423](https://github.com/shelar1423) in [#4221 - chore: document property setting in EXTENSIONS.md](https://github.com/containers/podman-desktop/pull/4221)\\n\\n---\\n\\n## Final notes\\n\\n### Known Issues\\n\\nWe have a discussion board topic where we have posted known issues with this release. If you run into problems, please check this list before filing a bug - if we already have an issue open for it, it saves you the time and trouble of filing, and there may be a workaround posted in the issue.\\n\\n#### [Known Issues: Podman Desktop 1.5.2](https://github.com/containers/podman-desktop/discussions/4635)\\n\\n### Fixed Issues\\n\\nThe complete list of issues fixed in this release is available [here](https://github.com/containers/podman-desktop/issues?q=is%3Aclosed+milestone%3A1.5.0).\\n\\n### Where to Download\\n\\nGet the latest release from the [Downloads](/downloads) section of the website and boost your development journey with Podman Desktop. Additionally, visit the [GitHub repository](https://github.com/containers/podman-desktop) and see how you can help us make Podman Desktop better."},{"id":"podman-desktop-release-1.4","metadata":{"permalink":"/blog/podman-desktop-release-1.4","source":"@site/blog/2023-09-18-release-1.4.md","title":"Release Notes - Podman Desktop 1.4","description":"Podman Desktop 1.4 has been released!","date":"2023-09-18T00:00:00.000Z","formattedDate":"September 18, 2023","tags":[{"label":"podman-desktop","permalink":"/blog/tags/podman-desktop"},{"label":"release","permalink":"/blog/tags/release"},{"label":"kubernetes","permalink":"/blog/tags/kubernetes"},{"label":"openshift","permalink":"/blog/tags/openshift"}],"readingTime":3.415,"hasTruncateMarker":false,"authors":[{"name":"Jeff Maury","title":"Engineering Manager","url":"https://github.com/jeffmaury","imageURL":"https://github.com/jeffmaury.png","key":"jeffmaury"}],"frontMatter":{"title":"Release Notes - Podman Desktop 1.4","description":"Podman Desktop 1.4 has been released!","slug":"podman-desktop-release-1.4","authors":["jeffmaury"],"tags":["podman-desktop","release","kubernetes","openshift"],"hide_table_of_contents":false,"image":"/blog/img/podman-desktop-release-1.4/juggling.png"},"prevItem":{"title":"Release Notes - Podman Desktop 1.5","permalink":"/blog/podman-desktop-release-1.5"},"nextItem":{"title":"Release Notes - Podman Desktop 1.3","permalink":"/blog/podman-desktop-release-1.3"}},"content":"import ReactPlayer from \'react-player\'\\n\\nPodman Desktop 1.4 Release! \ud83c\udf89\\n\\nThis is essentially a bug-fix release to fix various issues in UI, but as usual we also added a few new features.\\n\\n- **Podman 4.6.2**: Podman 4.6.2 included with Podman Desktop 1.4\\n- **Windows Arm64**: Native Windows on Arm64 installers and binaries\\n- **Port range mapping**: Start containers and map a range of ports\\n- **Terminal UX Improvement**: Persistent terminal sessions when SSH\'ing in a container\\n- **Volume Creation**: Create volume from the `Volumes` page\\n- **Bash support**: Terminals are now using `bash` if available.\\n\\nPodman Desktop 1.4 is now available. [Click here to download it](/downloads)!\\n\\n![Podman-desktop-1-4-juggling](img/podman-desktop-release-1.4/juggling.png)\\n\\n---\\n\\n## Release Details\\n\\n### Port range mapping [#3654](https://github.com/containers/podman-desktop/pull/3654)\\n\\nWhen starting a new container, you can now map a port range between host and container. If the range is not valid between host and container, an error is raised.\\n\\n![Range mapping](https://user-images.githubusercontent.com/49404737/262927546-da66b67a-0884-40b1-85bd-a9c3ea2f3f9e.gif)\\n\\n### Terminal lifetime [#3725](https://github.com/containers/podman-desktop/pull/3725)\\n\\nWhen a terminal is opened for a container, it can now be reused after you switched to another part of the Podman Desktop UI.\\n\\n![terminal lifetime](img/podman-desktop-release-1.4/terminal.gif)\\n\\n### Create volume [#3742](https://github.com/containers/podman-desktop/pull/3742)\\n\\nThe Volumes tab now has a Create volume button. The Create volume UI has a single field for the volume name.\\n\\n![create volume](img/podman-desktop-release-1.4/create-volume.gif)\\n\\n### bash support [#3750](https://github.com/containers/podman-desktop/pull/3750)\\n\\nWhen a terminal is opened for a container, if bash is available within the container, it will be used. Otherwise, sh will be used.\\n\\n![bash sh](img/podman-desktop-release-1.4/bash-sh.gif)\\n\\n### Notable Bug Fixes\\n\\n- Reduce API calls when listing containers by @benoitf [#3489](https://github.com/containers/podman-desktop/pull/3489)\\n- Removing a connection(podman machine) should redirect to previous page by @benoitf [#3576](https://github.com/containers/podman-desktop/pull/3576)\\n- Enhance error message when image is not there by @benoitf [#3587](https://github.com/containers/podman-desktop/pull/3587)\\n- Dispose kind install button when extension is deactivated (#3586) by @lstocchi [#3610](https://github.com/containers/podman-desktop/pull/3610)\\n- Replace backslash/slash on windows when building image (#3465) by @lstocchi [#3618](https://github.com/containers/podman-desktop/pull/3618)\\n- Handle null value in container command (#3620) by @lstocchi [#3625](https://github.com/containers/podman-desktop/pull/3625)\\n- Add maximum activation time for extensions by @benoitf [#3446](https://github.com/containers/podman-desktop/pull/3446)\\n- Handle single non-spread arguments by @benoitf [#3641](https://github.com/containers/podman-desktop/pull/3641)\\n- Grab usage data of volumes only on-demand by @benoitf [#3635](https://github.com/containers/podman-desktop/pull/3635)\\n- Add arm64 binaries for Windows by @benoitf [#3643](https://github.com/containers/podman-desktop/pull/3643)\\n- Include right airgap file for Windows and arm64 by @benoitf [#3651](https://github.com/containers/podman-desktop/pull/3651)\\n- Redirect to previous page when removing a kubernetes connection by @benoitf [#3650](https://github.com/containers/podman-desktop/pull/3650)\\n- Support port ranges when starting a container (#3204) by @lstocchi [#3654](https://github.com/containers/podman-desktop/pull/3654)\\n- Add a strict undefined check to messagebox result (#3692) by @lstocchi [#3699](https://github.com/containers/podman-desktop/pull/3699)\\n- Only restart if a machine is running by @cdrage [#3491](https://github.com/containers/podman-desktop/pull/3491)\\n- Session to the terminal is reused by @benoitf [#3725](https://github.com/containers/podman-desktop/pull/3725)\\n- Disable next button and show try again when onboarding failed (#3616) by @lstocchi [#3711](https://github.com/containers/podman-desktop/pull/3711)\\n- Add podman in PATH after updating process environment PATH (#3729) by @lstocchi [#3730](https://github.com/containers/podman-desktop/pull/3730)\\n- Allow to create a volume by @benoitf [#3742](https://github.com/containers/podman-desktop/pull/3742)\\n- Using bash if available otherwise sh in terminal by @axel7083 [#3750](https://github.com/containers/podman-desktop/pull/3750)\\n- Allow to embed existing component to onboarding (#3755) by @lstocchi [#3763](https://github.com/containers/podman-desktop/pull/3763)\\n- Some containers never return logs, do not wait for them by @dgolovin [#3784](https://github.com/containers/podman-desktop/pull/3784)\\n- Remove cancel button when on final onboarding step (#3771) by @lstocchi [#3802](https://github.com/containers/podman-desktop/pull/3802)\\n- Onboarding add link micromark for commands by @cdrage [#3747](https://github.com/containers/podman-desktop/pull/3747)\\n- Mounts can be null when using older podman by @afbjorklund [#3806](https://github.com/containers/podman-desktop/pull/3806)\\n- Remove redundant step completion check when onboarding gets started by @lstocchi [#3798](https://github.com/containers/podman-desktop/pull/3798)\\n- Ability to click enter in pull image name input by @deboer-tim [#3850](https://github.com/containers/podman-desktop/pull/3850)\\n- Set proxy environment variable when launching process by @jeffmaury [#3838](https://github.com/containers/podman-desktop/pull/3838)\\n- The socket location was moved for new podman by @afbjorklund [#3853](https://github.com/containers/podman-desktop/pull/3853)\\n- Don\'t log console errors when activating lima extension by @afbjorklund [#3852](https://github.com/containers/podman-desktop/pull/3852)\\n\\n### Community Thank You\\n\\n\ud83c\udf89 We\u2019d like to say a big thank you to everyone who helped to make Podman Desktop even better.\\n\\nA warm welcome to [@tomgoren](https://github.com/tomgoren), [@Julian](https://github.com/Julian), [@Gelob](https://github.com/Gelob) and [@cedricclyburn](https://github.com/cedricclyburn) who made their first contribution to the project in this release.\\n\\n### Final Notes\\n\\nThe complete list of issues fixed in this release is available [here](https://github.com/containers/podman-desktop/issues?q=is%3Aclosed+milestone%3A1.4.0).\\n\\nGet the latest release from the [Downloads](/downloads) section of the website and boost your development journey with Podman Desktop. Additionally, visit the [GitHub repository](https://github.com/containers/podman-desktop) and see how you can help us make Podman Desktop better."},{"id":"podman-desktop-release-1.3","metadata":{"permalink":"/blog/podman-desktop-release-1.3","source":"@site/blog/2023-08-16-release-1.3.md","title":"Release Notes - Podman Desktop 1.3","description":"Podman Desktop 1.3 has been released!","date":"2023-08-16T00:00:00.000Z","formattedDate":"August 16, 2023","tags":[{"label":"podman-desktop","permalink":"/blog/tags/podman-desktop"},{"label":"release","permalink":"/blog/tags/release"},{"label":"kubernetes","permalink":"/blog/tags/kubernetes"},{"label":"openshift","permalink":"/blog/tags/openshift"}],"readingTime":5.195,"hasTruncateMarker":false,"authors":[{"name":"Denis Golovin","title":"Principal Software Engineer","url":"https://github.com/cdrage","imageURL":"https://github.com/dgolovin.png","key":"dgolovin"}],"frontMatter":{"title":"Release Notes - Podman Desktop 1.3","description":"Podman Desktop 1.3 has been released!","slug":"podman-desktop-release-1.3","authors":["dgolovin"],"tags":["podman-desktop","release","kubernetes","openshift"],"hide_table_of_contents":false,"image":"/img/blog/podman-desktop-release-1.3.webp"},"prevItem":{"title":"Release Notes - Podman Desktop 1.4","permalink":"/blog/podman-desktop-release-1.4"},"nextItem":{"title":"Release Notes - Podman Desktop 1.2","permalink":"/blog/podman-desktop-release-1.2"}},"content":"import ReactPlayer from \'react-player\'\\n\\nPodman Desktop 1.3 Release! \ud83c\udf89\\n\\nThis is essentially a bug-fix release to fix various issues in UI, extension engine and featured extensions, but as usual we also added a few new features.\\n\\n- **Podman 4.6.1**: Podman 4.6.1 included in Windows and Mac installers\\n- **Podman user-mode networking support to Windows/WSL**: A new switch `User mode networking\' is available when creating Podman machine on Windows for Podman 4.6.0+ to configure podman to work in certain VPN setups and other specialized networking configurations\\n- **Compose group new UI elements**: You can now see summary, inspect, deploy to kubernetes, generate kube yaml and view logs\\n- **Extension packs and extension dependencies**: Install group of extensions in one click\\n- **Resource details page update**: See summary and log for resource\\n- **Create Kind cluster form update**: A new `Node\'s container image` field can be used to specify the Kubernetes version used for the control-planed\\n- **Support Docker Desktop extensions using a backend**: When loading Docker Desktop extension the containers are created in the backend as described in the vm section of extension\'s descriptor\\n- **Podman Initial Onboarding (preview)**: Install and configure podman using included installer\\n\\nPodman Desktop 1.3 is now available. [Click here to download it](/downloads)!\\n\\n![Podman-desktop-1-3-bug-swatting](img/podman-desktop-release-1.3/title-bug-swatting.png)\\n\\n---\\n\\n## Release Details\\n\\n### Compose group Logs tab [#3176](https://github.com/containers/podman-desktop/pull/3176)\\n\\nWhen clicking on the group of containers, you can now view the logs of the entire group of compose containers and don\'t need to open\\nlog for every component individually.\\n\\n![Screenshot 2023-07-11 at 12 48 47 PM](https://github.com/containers/podman-desktop/assets/6422176/743a4ffc-e291-4697-8ac5-8052cc921946)\\n\\n### Podman user-mode networking support to Windows/WSL [#3251](https://github.com/containers/podman-desktop/pull/3251)\\n\\nCertain VPN setups or other specialized networking configs will block traffic from the virtual WSL networking device, resulting in the podman WSL backend from being unable to contact systems on the VPN, and potentially losing internet access altogether. The new switch allows you to create a podman VM machine configured to work correctly in mentioned above networking environments.\\n\\n![user](https://github.com/containers/podman-desktop/assets/620330/2f521576-b6a6-42b5-b24d-08df5b432608)\\n\\n### Compose group Summary tab [#3317](https://github.com/containers/podman-desktop/pull/3317),\\n\\nCompose group Summary tab shows all containers in the group and let you navigate to Details page for specific container.\\n\\n\\n\\n### Compose group Inspect tab [#3316](https://github.com/containers/podman-desktop/pull/3316)\\n\\nCompose group Inspect tab shows an array of \\"container inspect\\" from docker / podman.\\n\\n\\n\\n### `Deploy to kubernetes` in compose actions [#3299](https://github.com/containers/podman-desktop/pull/3295)\\n\\nA button to deploy to kubernetes added to Compose group.\\n\\n\\n\\n### `Generate Kube` in Compose actions and `Kube` tab in compose details [#3253](https://github.com/containers/podman-desktop/pull/3253)\\n\\n`Generate Kube` item added to Compose actions and \\"Kube\\" tab is now available in Compose details view.\\n\\n\\n\\n### Install multiple extensions using extension pack [#3150](https://github.com/containers/podman-desktop/pull/3150)\\n\\nAn Extension pack introduced in Extension engine is a way to declare set of extensions to install them all at once.\\n\\n\\n\\n### Customize icons from extension [#3131](https://github.com/containers/podman-desktop/pull/3131)\\n\\nExtensions now can customize icons for list elements using `when` clause.\\n\\n![image](https://github.com/containers/podman-desktop/assets/49404737/7aae5347-4f07-4854-ba11-1f629b5ccf22)\\n\\n### Resource details page update [#1923](https://github.com/containers/podman-desktop/pull/1923)\\n\\nIf you click on the arrow icon next to a resource name it will open up a details page (similarly to how clicking on a container in the container list opens up a details page).\\n\\n![image](https://user-images.githubusercontent.com/49404737/229542404-bae44f89-5cd3-4baf-8b08-e934e4462697.gif)\\n\\n### `Node\'s container image` field added to `Create a Kind cluster` form [#3508](https://github.com/containers/podman-desktop/pull/3508)\\n\\nThe new `Node\'s container image` field can be used to specify the Kubernetes version used for the control-planed.\\n\\n![image](https://github.com/containers/podman-desktop/assets/42176370/b2a63faf-629f-436d-8496-7c0cd8158679)\\n\\n### Support Docker Desktop extensions using a backend [#3435](https://github.com/containers/podman-desktop/pull/3435)\\n\\nPodman Desktop now loads the containers in the backend as described in the vm section of extension descriptor the same way as Docker Desktop does.\\n\\n### Initial onboarding implementation for podman (experimental) [#3308](https://github.com/containers/podman-desktop/pull/3308)\\n\\nThis is the initial implementation for the onboarding feature. It only covers a simple onboarding for podman. Check system requirements -> install podman -> yay! Done!\\n\\n### Notable Bug Fixes\\n\\n- Updating videos to be adaptive for mobile by @mairin [#3229](https://github.com/containers/podman-desktop/pull/3229)\\n- Consistent max width and padding in settings by @deboer-tim [#3232](https://github.com/containers/podman-desktop/pull/3232)\\n- Settings navigation bar resizing by @deboer-tim in [#3231](https://github.com/containers/podman-desktop/pull/3231)\\n- Move new registry button to header by @deboer-tim [#3245](https://github.com/containers/podman-desktop/pull/3245)\\n- Bigger lima logo by @afbjorklund [#3248](https://github.com/containers/podman-desktop/pull/3248)\\n- Horizontal docker logo by @afbjorklund [#3236](https://github.com/containers/podman-desktop/pull/3236)\\n- Respect LIMA_HOME environment variable by @afbjorklund [#3254](https://github.com/containers/podman-desktop/pull/3254)\\n- Add check before writing to terminal by @lstocchi [#3263](https://github.com/containers/podman-desktop/pull/3263)\\n- Wait until remote side has fully initialized the extensions by @benoitf [#3257](https://github.com/containers/podman-desktop/pull/3257)\\n- Fix loader not centered horizontally by @benoitf [#3270](https://github.com/containers/podman-desktop/pull/3270)\\n- Troubleshooting still waiting after failure by @deboer-tim [#3354](https://github.com/containers/podman-desktop/pull/3354)\\n- Store error for build by @cdrage [#3365](https://github.com/containers/podman-desktop/pull/3365)\\n- Missing checkbox tooltips by @deboer-tim [#3380](https://github.com/containers/podman-desktop/pull/3380)\\n- Load compose logs async not await by @cdrage [#3377](https://github.com/containers/podman-desktop/pull/3377)\\n- Set rootful connection when starting rootful machine by @lstocchi [#3364](https://github.com/containers/podman-desktop/pull/3364)\\n- Default last page by @deboer-tim [#3388](https://github.com/containers/podman-desktop/pull/3388)\\n- Avoid dashboard displaying providers starting while they don\'t by @benoitf [#3451](https://github.com/containers/podman-desktop/pull/3451)\\n- Do not use extensionInfo until it is defined by @benoitf [#V](https://github.com/containers/podman-desktop/pull/3450)\\n- Allow BASIC authentication (all caps) by @cdrage [#3471](https://github.com/containers/podman-desktop/pull/3471)\\n- Allow single domain registry such as localhost:5000 by @cdrage [#3468](https://github.com/containers/podman-desktop/pull/3468)\\n- Create /usr/local/bin directory if it does not exist on binary install by @cdrage [#3425](https://github.com/containers/podman-desktop/pull/3425)\\n- Only delete selected pods by @deboer-tim [#](https://github.com/containers/podman-desktop/pull/3378)\\n- Add back \'Done\' text on the button by @benoitf [#3487](https://github.com/containers/podman-desktop/pull/3487)\\n- Do not wait for more than 5s when checking for podman ping by @benoitf [#3497](https://github.com/containers/podman-desktop/pull/3497)\\n- Add proxy support for extension using patching get and request approach by @dgolovin [#2825](https://github.com/containers/podman-desktop/pull/2825)\\n- Refresh component when field is updated by @benoitf [#3525](https://github.com/containers/podman-desktop/pull/3525)\\n- Higher-res icons for featured extensions list by @mairin [#3511](https://github.com/containers/podman-desktop/pull/3511)\\n- Main nav selection by @deboer-tim [#3510](https://github.com/containers/podman-desktop/pull/3510)\\n- kube event error when switching context by @jeffmaury [#3494](https://github.com/containers/podman-desktop/pull/3494)\\n- Reset error message each time we pull image by @benoitf [#3550](https://github.com/containers/podman-desktop/pull/3550)\\n\\n### Community Thank You\\n\\n\ud83c\udf89 We\u2019d like to say a big thank you to everyone who helped to make Podman Desktop even better.\\n\\nA warm welcome to [@rostalan](https://github.com/rostalan) and [@axel7083](https://github.com/axel7083) who made their first contribution to the project in this release.\\n\\n### Final Notes\\n\\nThe complete list of issues fixed in this release is available [here](https://github.com/containers/podman-desktop/issues?q=is%3Aclosed+milestone%3A1.3.0).\\n\\nGet the latest release from the [Downloads](/downloads) section of the website and boost your development journey with Podman Desktop. Additionally, visit the [GitHub repository](https://github.com/containers/podman-desktop) and see how you can help us make Podman Desktop better."},{"id":"podman-desktop-release-1.2","metadata":{"permalink":"/blog/podman-desktop-release-1.2","source":"@site/blog/2023-07-12-release-1.2.md","title":"Release Notes - Podman Desktop 1.2","description":"Podman Desktop 1.2 has been released!","date":"2023-07-12T00:00:00.000Z","formattedDate":"July 12, 2023","tags":[{"label":"podman-desktop","permalink":"/blog/tags/podman-desktop"},{"label":"release","permalink":"/blog/tags/release"},{"label":"kubernetes","permalink":"/blog/tags/kubernetes"},{"label":"openshift","permalink":"/blog/tags/openshift"}],"readingTime":6.05,"hasTruncateMarker":false,"authors":[{"name":"Charlie Drage","title":"Software Engineer","url":"https://github.com/cdrage","imageURL":"https://github.com/cdrage.png","key":"cdrage"}],"frontMatter":{"title":"Release Notes - Podman Desktop 1.2","description":"Podman Desktop 1.2 has been released!","slug":"podman-desktop-release-1.2","authors":["cdrage"],"tags":["podman-desktop","release","kubernetes","openshift"],"hide_table_of_contents":false,"image":"/img/blog/podman-desktop-release-1.2.webp"},"prevItem":{"title":"Release Notes - Podman Desktop 1.3","permalink":"/blog/podman-desktop-release-1.3"},"nextItem":{"title":"Release Notes - Podman Desktop 1.1","permalink":"/blog/podman-desktop-release-1.1"}},"content":"import ReactPlayer from \'react-player\'\\n\\nPodman Desktop 1.2 Release! \ud83c\udf89\\n\\nWe\'re excited to announce the release of Podman Desktop version 1.2.0! This release includes many new features (Kubernetes, Compose and extension support!), bug fixes, and improvements to enhance your container management experience. Here\'s a summary of the key changes in this release:\\n\\n- **Added start/stop/delete/restart buttons for Compose**: You can now make changes to an entire Compose group of containers\\n- **Kubernetes context on the status bar**: Choose from multiple Kubernetes contexts more easily all from the status bar\\n- **Rename images**: Rename an image with a click of a button\\n- **Protocol handler support**: Added support for protocol handlers such as `open podman-desktop:extension/redhat.openshift-local`\\n- **Troubleshooting page**: A troubleshooting page for helping diagnose Podman Desktop related development issues\\n\\nPodman Desktop 1.2 is now available. [Click here to download it](/downloads)!\\n\\n![Podman-desktop-1-2-hero](img/podman-desktop-release-1.2/podman-desktop-release-1.2.png)\\n\\n---\\n\\n## Release Details\\n\\n### Added start/stop/delete/restart buttons for Compose\\n\\nIn the last month we\'ve been addind support for more Compose features. Before you were only able to control a group of containers if they were in a Pod. Now we have added the ability to control a group of Compose containers. You can now start, stop, delete and restart a group of containers launched by either `docker-compose` or `podman-compose`.\\n\\nStay tuned as we add even more features to Compose! If you have any feedback or feature requests, feel free to open an issue or start a discussion on GitHub.\\n\\n\\n\\n### Kubernetes context on the status bar\\n\\nWith Kubernetes context on the status bar, you can switch from one context to another in just a couple of clicks. Easily switch to a different cluster all together. If there are multiple contexts available, you can now click and pick which one to use.\\n\\n\\n\\n### Rename images\\n\\nDeployed an image but now you need to rename it / add a new tag? Podman Desktop allows you to edit an image now. Thanks to an awesome contributor [@tuckerrc](https://github.com/tuckerrc) who added the new feature.\\n\\n\\n\\n### Troubleshooting page\\n\\nDeveloping an extension for Podman Desktop? Want to view the logs of Podman Desktop as well as ping your container connection? We now have a troubleshooting page!\\n\\nClick on the lightbulb button on the bottom right to access the page.\\n\\n\\n\\n### Protocol handler support\\n\\nPodman Desktop now supports protocol handling when using the terminal! Want to access your favourite extension directly from a script or the terminal? If you type in `open podman-desktop:extension/redhat.openshift-local` in the terminal, Podman Desktop will automatically load up to the correct extension.\\n\\n\\n\\n---\\n\\n## Other Notable Features\\n\\n- Background colors and FormPage ([PR #2977](https://github.com/containers/podman-desktop/pull/2977))\\n- Add ability to add insecure registry / skipping cert verify ([PR #2896](https://github.com/containers/podman-desktop/pull/2896))\\n- Add support for icon contribution ([PR #2984](https://github.com/containers/podman-desktop/pull/2984))\\n- Add warning dialog message that virtual machine has low memory limit ([PR #2822](https://github.com/containers/podman-desktop/pull/2822))\\n- Propose indexed name for new pod ([PR #3028](https://github.com/containers/podman-desktop/pull/3028))\\n- Add restart button after enabling / disabling mac os compatibility ([PR #2841](https://github.com/containers/podman-desktop/pull/2841))\\n- Add environment related helper constants ([PR #3079](https://github.com/containers/podman-desktop/pull/3079))\\n- Allow entrypoint and cmd when starting container ([PR #3031](https://github.com/containers/podman-desktop/pull/3031))\\n- Add a way to debug stores in troubleshooting page ([PR #3121](https://github.com/containers/podman-desktop/pull/3121))\\n- Add custompick component (#2855) ([PR #3012](https://github.com/containers/podman-desktop/pull/3012))\\n- Dynamic breadcrumbs ([PR #3119](https://github.com/containers/podman-desktop/pull/3119))\\n- Icons on form pages ([PR #3155](https://github.com/containers/podman-desktop/pull/3155))\\n- Switch more pages to formpage ([PR #3162](https://github.com/containers/podman-desktop/pull/3162))\\n- Add rename image button ([PR #2588](https://github.com/containers/podman-desktop/pull/2588))\\n- Fixed headers, improved scrollbars ([PR #2863](https://github.com/containers/podman-desktop/pull/2863))\\n- Reports warnings on failed kube deploy, fixes error out ([PR #3050](https://github.com/containers/podman-desktop/pull/3050))\\n- Kube context on statusbar ([PR #2755](https://github.com/containers/podman-desktop/pull/2755))\\n- Install provider if not installed when clicking on create new button (#2706) ([PR #2817](https://github.com/containers/podman-desktop/pull/2817))\\n- Add tag and authenticated push capacity to the extension API ([PR #2876](https://github.com/containers/podman-desktop/pull/2876))\\n- Add navigation bar e2e tests ([PR #2950](https://github.com/containers/podman-desktop/pull/2950))\\n\\n---\\n\\n## Documentation Updates\\n\\n- Fix documentation for building image of extensions ([PR #2873](https://github.com/containers/podman-desktop/pull/2873))\\n- Add Minikube install docs ([PR #2824](https://github.com/containers/podman-desktop/pull/2824))\\n- Add Minikube documentation ([PR #2694](https://github.com/containers/podman-desktop/pull/2694))\\n- Updated Building an image procedure ([PR #2964](https://github.com/containers/podman-desktop/pull/2964))\\n- Starting a container ([PR #2958](https://github.com/containers/podman-desktop/pull/2958))\\n- Pulling an image ([PR #2956](https://github.com/containers/podman-desktop/pull/2956))\\n- Updated selecting containers to run in a pod ([PR #2970](https://github.com/containers/podman-desktop/pull/2970))\\n- Pushing an image to a registry ([PR #2969](https://github.com/containers/podman-desktop/pull/2969))\\n- How to add an insecure registry ([PR #2953](https://github.com/containers/podman-desktop/pull/2953))\\n- Add documentation for lima ([PR #2995](https://github.com/containers/podman-desktop/pull/2995))\\n- Replace broken link to podman.io ([PR #2994](https://github.com/containers/podman-desktop/pull/2994))\\n- Authenticating to a pre-configured registry ([PR #2965](https://github.com/containers/podman-desktop/pull/2965))\\n- Lima is not a container engine ([PR #3051](https://github.com/containers/podman-desktop/pull/3051))\\n- Using the Troubleshooting page ([PR #3083](https://github.com/containers/podman-desktop/pull/3083))\\n- View and select your current Kubernetes context in the status bar ([PR #3090](https://github.com/containers/podman-desktop/pull/3090))\\n\\n---\\n\\n## Notable Bug Fixes\\n\\n- Deleting a running pod generates an error ([PR #2827](https://github.com/containers/podman-desktop/pull/2827))\\n- If kubeconfig is empty, does not try to do things, cancel ([PR #2874](https://github.com/containers/podman-desktop/pull/2874))\\n- Async telemetry startup ([PR #2885](https://github.com/containers/podman-desktop/pull/2885))\\n- Do not block startup while waiting for kube resource refresh ([PR #2884](https://github.com/containers/podman-desktop/pull/2884))\\n- Images list too wide ([PR #2918](https://github.com/containers/podman-desktop/pull/2918))\\n- Compose deactivate function never called ([PR #2922](https://github.com/containers/podman-desktop/pull/2922))\\n- Auto-scrolling on form pages, layout issues ([PR #2927](https://github.com/containers/podman-desktop/pull/2927))\\n- Show current context in quick pick ([PR #2920](https://github.com/containers/podman-desktop/pull/2920))\\n- Remove sticky position of loader in dashboard UI (#2535) ([PR #2959](https://github.com/containers/podman-desktop/pull/2959))\\n- Undo change that broke the website ([PR #2992](https://github.com/containers/podman-desktop/pull/2992))\\n- Detailspage, resizing & consistency ([PR #2987](https://github.com/containers/podman-desktop/pull/2987))\\n- Quick pick click to close and over nav bar ([PR #2758](https://github.com/containers/podman-desktop/pull/2758))\\n- Only show empty screen when no pods ([PR #2929](https://github.com/containers/podman-desktop/pull/2929))\\n- Do not redirect to /pods when deleting pod in containerlist ([PR #2963](https://github.com/containers/podman-desktop/pull/2963))\\n- Bulk delete on pods should call the pod deletion ([PR #2979](https://github.com/containers/podman-desktop/pull/2979))\\n- Update nodejs version to 18 in .nvmrc to fix yarn install failure ([PR #2989](https://github.com/containers/podman-desktop/pull/2989))\\n- Website check targets ([PR #2996](https://github.com/containers/podman-desktop/pull/2996))\\n- Don\'t show exception to user ([PR #3034](https://github.com/containers/podman-desktop/pull/3034))\\n- Interpret arguments given to info command for example ([PR #3015](https://github.com/containers/podman-desktop/pull/3015))\\n- Change defaults for Podman machine ([PR #3061](https://github.com/containers/podman-desktop/pull/3061))\\n- Normalize development/production folders path ([PR #3113](https://github.com/containers/podman-desktop/pull/3113))\\n- Calculate machine socket path for linux ([PR #3070](https://github.com/containers/podman-desktop/pull/3070))\\n- Replace backslash with slash so to support rendering on Windows (#3120) ([PR #3122](https://github.com/containers/podman-desktop/pull/3122))\\n- Keep stdout and stderr in the error object for Docker Desktop extensions ([PR #3014](https://github.com/containers/podman-desktop/pull/3014))\\n- Mark task completed if there\'s a failure ([PR #3016](https://github.com/containers/podman-desktop/pull/3016))\\n- Handle invalid kubeconfig file ([PR #3129](https://github.com/containers/podman-desktop/pull/3129))\\n- Do not remove registries when podman extension is stopping ([PR #3136](https://github.com/containers/podman-desktop/pull/3136))\\n- Warning should be amber ([PR #3153](https://github.com/containers/podman-desktop/pull/3153))\\n- Load user extensions from plugins as removable ([PR #3152](https://github.com/containers/podman-desktop/pull/3152))\\n- Images with spaces in entrypoints or commands fail to start ([PR #3161](https://github.com/containers/podman-desktop/pull/3161))\\n- Scrolling offscreen when clicking checkbox ([PR #3178](https://github.com/containers/podman-desktop/pull/3178))\\n- Avoid messagebox expanding offscreen ([PR #2778](https://github.com/containers/podman-desktop/pull/2778))\\n- Release-notes-generator run failure ([PR #2752](https://github.com/containers/podman-desktop/pull/2752))\\n- Unable to do a new build if the previous one failed ([PR #2721](https://github.com/containers/podman-desktop/pull/2721))\\n\\n---\\n\\n## Community Thank You\\n\\n\ud83c\udf89 We\u2019d like to say a big thank you to everyone who helped to make Podman Desktop even better.\\n\\nA big shoutout to [@afbjorklund](https://github.com/afbjorklund), [@tuckerrc](https://github.com/tuckerrc) and [@evanshortiss](https://github.com/evanshortiss) who contributed to this release!\\n\\n---\\n\\n## Final notes\\n\\nThe complete list of issues fixed in this release is available [here](https://github.com/containers/podman-desktop/issues?q=is%3Aclosed+milestone%3A1.2.0) and [here](https://github.com/containers/podman-desktop/issues?q=is%3Aclosed+milestone%3A1.2.0).\\n\\nGet the latest release from the [Downloads](/downloads) section of the website and boost your development journey with Podman Desktop. Additionally, visit the [GitHub repository](https://github.com/containers/podman-desktop) and see how you can help us make Podman Desktop better."},{"id":"podman-desktop-release-1.1","metadata":{"permalink":"/blog/podman-desktop-release-1.1","source":"@site/blog/2023-06-08-release-1.1.md","title":"Release Notes - Podman Desktop 1.1","description":"Podman Desktop 1.1 has been released!","date":"2023-06-08T00:00:00.000Z","formattedDate":"June 8, 2023","tags":[{"label":"podman-desktop","permalink":"/blog/tags/podman-desktop"},{"label":"release","permalink":"/blog/tags/release"},{"label":"kubernetes","permalink":"/blog/tags/kubernetes"},{"label":"openshift","permalink":"/blog/tags/openshift"}],"readingTime":2.465,"hasTruncateMarker":true,"authors":[{"name":"Tim deBoer","title":"Architect","url":"https://github.com/deboer-tim","imageURL":"https://github.com/deboer-tim.png","key":"deboer"}],"frontMatter":{"title":"Release Notes - Podman Desktop 1.1","description":"Podman Desktop 1.1 has been released!","slug":"podman-desktop-release-1.1","authors":["deboer"],"tags":["podman-desktop","release","kubernetes","openshift"],"hide_table_of_contents":false,"image":"/img/blog/podman-desktop-release-1.1.webp"},"prevItem":{"title":"Release Notes - Podman Desktop 1.2","permalink":"/blog/podman-desktop-release-1.2"},"nextItem":{"title":"Release Notes - Podman Desktop 1.0","permalink":"/blog/podman-desktop-release-1.0"}},"content":"import ReactPlayer from \'react-player\'\\n\\nPodman Desktop 1.1 Release! \ud83c\udf89\\n\\nThis is primarily a bug-fix release to fix a few important issues, but we\'ve managed to squeeze in a few enhancements\\nalong the way.\\n\\n\x3c!--Main Features--\x3e\\n\\n- **Podman 4.5.1**: Podman 4.5.1 now included in Windows and Mac installers.\\n- **Extensions**: Update extensions from within Podman Desktop.\\n- **Lima Support**: Choose engine type and override its name from the settings.\\n- **UX and UI Improvements**: New loading screen.\\n\\nPodman Desktop 1.1 is now available. [Click here to download it](/downloads)!\\n\\n![Podman-desktop-1-1-hero](img/podman-desktop-release-1.1/podman-desktop-release-1.1.png)\\n\\n\x3c!--truncate--\x3e\\n\\n---\\n\\n## Release Details\\n\\n### Podman v4.5.1\\n\\nPodman Desktop 1.1 moves up to [Podman 4.5.1](https://github.com/containers/podman/releases/tag/v4.5.1).\\n\\n### Extensions\\n\\nOptional extensions will follow their own lifecycle and update independently from Podman Desktop. As of\\nthis release you\'ll be able to see when there is an update available and install from within\\nPodman Desktop [#2655](https://github.com/containers/podman-desktop/pull/2655).\\n\\nWe\'ve also added options in **Settings > Preferences** to\\nautomatically check for and install extension updates.\\n\\n\\n\\n![Update extensions](img/podman-desktop-release-1.1/update-extensions.png)\\n\\n### Lima Support\\n\\nThanks to contributor [Anders Bj\xf6rklund](https://github.com/afbjorklund), we have some improvements to the\\nLima extension! In **Settings > Preferences** you can select which\\nengine type Lima runs on and override the instance name [#2674](https://github.com/containers/podman-desktop/pull/2674).\\n\\n![Lima preferences](https://user-images.githubusercontent.com/10364051/241755966-0a6a293b-b18e-4222-9c40-abd6c114d464.png)\\n\\n### Other UI and UX Improvements\\n\\n#### New Loading Screen\\n\\nWe have a new loading screen, Podman Desktop style! [#2743](https://github.com/containers/podman-desktop/pull/2743).\\n\\n\\n\\n---\\n\\n## Other Notable Enhancements\\n\\n- Docker-compose can be installed system-wide [#2718](https://github.com/containers/podman-desktop/pull/2718).\\n- Show warning when creating a pod with two containers that use the same port [#2671](https://github.com/containers/podman-desktop/pull/2671).\\n- Display Kubernetes context name in pod label [#2634](https://github.com/containers/podman-desktop/pull/2634).\\n- Add Docker compatibility button using flatpak-spawn [#1925](https://github.com/containers/podman-desktop/pull/1925).\\n- Improve UI consistency of Pull Image page [#2604](https://github.com/containers/podman-desktop/pull/2604).\\n\\n---\\n\\n## Notable Bug Fixes\\n\\n- Could not install extensions on Windows 10 [#2762](https://github.com/containers/podman-desktop/pull/2762).\\n- Could not use locally built images on Kubernetes [#2710](https://github.com/containers/podman-desktop/pull/2710).\\n- Dashboard still suggests update after installation [#2648](https://github.com/containers/podman-desktop/pull/2648).\\n- Could not Play Kubernetes YAML to Podman on Windows [#2594](https://github.com/containers/podman-desktop/pull/2594).\\n- Pod label wasn\'t always shown in list [#2614](https://github.com/containers/podman-desktop/pull/2614).\\n- Dashboard button state was resetting [#2584](https://github.com/containers/podman-desktop/pull/2584).\\n- Change checkbox style so they don\'t look like stop buttons [#2723](https://github.com/containers/podman-desktop/pull/2723).\\n\\n---\\n\\n## Community Thank You\\n\\n\ud83c\udf89 We\u2019d like to say a big thank you to everyone who helped to make Podman Desktop even better. In this\\nsprint we received pull requests from the following people:\\n\\n- [wangxiaolei](https://github.com/fatelei) in [#2602 - Add meaningful tooltips to build, pull, prune buttons](https://github.com/containers/podman-desktop/pull/2602)\\n- [AsciiWolf](https://github.com/AsciiWolf) in [#2607 - fix typing error in Flathub name](https://github.com/containers/podman-desktop/pull/2607) and [#2609 - fix Flatpak install instructions](https://github.com/containers/podman-desktop/pull/2609)\\n- [Anders Bj\xf6rklund](https://github.com/afbjorklund) in [#2674 - Select engine for Lima provider](https://github.com/containers/podman-desktop/pull/2674)\\n\\n---\\n\\n## Final notes\\n\\nThe complete list of issues fixed in this release is available [here](https://github.com/containers/podman-desktop/issues?q=is%3Aclosed+milestone%3A1.1.0) and [here](https://github.com/containers/podman-desktop/issues?q=is%3Aclosed+milestone%3A1.1.0).\\n\\nGet the latest release from the [Downloads](/downloads) section of the website and boost your development journey with Podman Desktop. Additionally, visit the [GitHub repository](https://github.com/containers/podman-desktop) and see how you can help us make Podman Desktop better."},{"id":"podman-desktop-release-1.0","metadata":{"permalink":"/blog/podman-desktop-release-1.0","source":"@site/blog/2023-05-17-release-1.0.md","title":"Release Notes - Podman Desktop 1.0","description":"Podman Desktop 1.0 has been released!","date":"2023-05-17T00:00:00.000Z","formattedDate":"May 17, 2023","tags":[{"label":"podman-desktop","permalink":"/blog/tags/podman-desktop"},{"label":"release","permalink":"/blog/tags/release"},{"label":"kubernetes","permalink":"/blog/tags/kubernetes"},{"label":"kind","permalink":"/blog/tags/kind"},{"label":"openshift","permalink":"/blog/tags/openshift"}],"readingTime":5,"hasTruncateMarker":true,"authors":[{"name":"Tim deBoer","title":"Architect","url":"https://github.com/deboer-tim","imageURL":"https://github.com/deboer-tim.png","key":"deboer"}],"frontMatter":{"title":"Release Notes - Podman Desktop 1.0","description":"Podman Desktop 1.0 has been released!","slug":"podman-desktop-release-1.0","authors":["deboer"],"tags":["podman-desktop","release","kubernetes","kind","openshift"],"hide_table_of_contents":false,"image":"/img/blog/podman-desktop-release-1.0.jpg"},"prevItem":{"title":"Release Notes - Podman Desktop 1.1","permalink":"/blog/podman-desktop-release-1.1"},"nextItem":{"title":"Release Notes - Podman Desktop 0.15","permalink":"/blog/podman-desktop-release-0.15"}},"content":"import ReactPlayer from \'react-player\'\\n\\nPodman Desktop 1.0 Release! \ud83c\udf89\\n\\nWe still have many things planned, but with a little polish and a few more bug fixes we\\nfelt we\'ve reached a level of maturity and it is now time to declare our 1.0 release.\\n\\nThank you to everyone who has been with us on this journey so far! Please keep the\\nfeedback coming!\\n\\n\x3c!--Main Features--\x3e\\n\\n- **Highlighting Featured Extensions**: Easily find and install new extensions.\\n- **Featured Extensions**: Two new extensions supporting OpenShift.\\n- **Podman Machine as Root**: Ability to run a Podman machine as root.\\n- **UX and UI Improvements**: Opening external websites, editing numbers, and tooltips.\\n\\nPodman Desktop 1.0 is now available. [Click here to download it](/downloads)!\\n\\n![Podman-desktop-1-0-hero](img/podman-desktop-release-1.0/podman-desktop-release-1.0.jpg)\\n\\n\x3c!--truncate--\x3e\\n\\n---\\n\\n## Release Details\\n\\n### Highlighting Featured Extensions\\n\\nA critical part of our vision for Podman Desktop is the ability to install extensions to\\nsupport additional container engines, Kubernetes providers, or other tools. However, it\\nhas not been easy to discover new extensions.\\n\\nWith 1.0 we show a list of featured extensions in the **Welcome**\\n[#2354](https://github.com/containers/podman-desktop/pull/2354), the **Dashboard** and in\\n** Settings > Extensions**\\n[#2355](https://github.com/containers/podman-desktop/pull/2355). Check out the new\\nextensions for **Red Hat OpenShift Local** and the **Developer Sandbox for Red Hat OpenShift**!\\n\\n![Featured extensions](img/podman-desktop-release-1.0/featured-extensions.png)\\n\\n### Featured Extensions\\n\\nSpeaking of extensions, let\'s take a minute to turn the spotlight on these two!\\n\\nHave another idea for extending Podman Desktop? We would love to hear from you or see\\nwhat you can create with the [Extension documentation](/docs/extensions),\\nand feature your extension here.\\n\\n#### Red Hat OpenShift Local\\n\\nOpenShift Local is a fully-featured single-node OpenShift cluster designed to run on your local computer.\\nWith this extension you can install, start/stop, and deploy pods or YAML to OpenShift Local,\\nallowing you to test your applications on a full OpenShift environment, ensuring a consistent\\nexperience between development, test, and production.\\n\\nThe recent addition of the MicroShift preset provides a lighter, optimized option that\\nstarts faster and uses less resources for deployments that still want OpenShift compatibility\\nwithout the full set of OpenShift services.\\n\\n![OpenShift Local](img/podman-desktop-release-1.0/openshift-local.png)\\n\\n#### Developer Sandbox for Red Hat OpenShift\\n\\nThe OpenShift Developer Sandbox is a free, cloud-based OpenShift environment that allows developers to\\ncreate, build, and deploy applications to OpenShift for 30 days. With this extension you can sign up\\nand easily deploy pods or YAML to a hosted OpenShift environment without a local installation or\\nleaving Podman Desktop.\\n\\n![Developer Sandbox](img/podman-desktop-release-1.0/sandbox.png)\\n\\n### Podman Machine as Root\\n\\nWhen creating a Podman machine you can now decide to run as root [#2427](https://github.com/containers/podman-desktop/pull/2427). This is a prerequisite for some scenarios, such as running Kind on Windows.\\n\\n![Podman machine as root](img/podman-desktop-release-1.0/podman-root.png)\\n\\n### Other UI and UX Improvements\\n\\n#### Prompt to Open External Website\\n\\nIn the previous release links to external websites were blocked due to the security risk.\\nIn 1.0 you can click to see the URL and have the option of opening or copying it\\n[#2414](https://github.com/containers/podman-desktop/pull/2414).\\n\\n![External link dialog](img/podman-desktop-release-1.0/external-link.png)\\n\\n#### Editable Numeric Preferences\\n\\nTired of clicking +, +, +? Us too. Numeric preferences are now editable so\\nyou can directly enter the value you want\\n[#2368](https://github.com/containers/podman-desktop/pull/2368).\\n\\n![Editing numbers](img/podman-desktop-release-1.0/edit-number.png)\\n\\n#### Navigation tooltips\\n\\nWe like our new navigation bar, but the tooltips were slow to appear. This made it harder for new\\nusers to discover the pages and for power users to see the container/pod/image counts. The\\ntooltips are now a little nicer and appear immediately\\n[#2286](https://github.com/containers/podman-desktop/pull/2286).\\n\\n![Navigation tooltips](img/podman-desktop-release-1.0/nav-tooltips.png)\\n\\n---\\n\\n## Other Notable Enhancements\\n\\n- If you use a non-default Podman machine you are now prompted to make it the default, so\\n that command line tools will use the same machine [#2205](https://github.com/containers/podman-desktop/pull/2205).\\n\\n- Extensions can now be installed without requiring a running local container engine\\n [#2273](https://github.com/containers/podman-desktop/pull/2273).\\n\\n- When extensions fail to load there is a new state (failed!) and an error message\\n to help you fix or report the problem [#2424](https://github.com/containers/podman-desktop/pull/2424).\\n\\n- The showInputBox API has support for Markdown [#2418](https://github.com/containers/podman-desktop/pull/2418).\\n\\n---\\n\\n## Notable Bug Fixes\\n\\n- Fixed shared status when using multiple Podman 4.5 machines [#2441](https://github.com/containers/podman-desktop/pull/2441).\\n- Fixed hang on exit when telemetry is unreachable [#2431](https://github.com/containers/podman-desktop/pull/2431).\\n- Reduced initial Podman REST API calls to improve performance [#2419](https://github.com/containers/podman-desktop/pull/2419).\\n- **Play Kubernetes YAML** now honors the namespace [#2509](https://github.com/containers/podman-desktop/pull/2509).\\n- **Container** list was not remembering expand/collapsed status [#2491](https://github.com/containers/podman-desktop/pull/2491).\\n- Clear previous error when installing Docker extension [#2469](https://github.com/containers/podman-desktop/pull/2469).\\n- Ensure correct path with running Kind CLI [#2455](https://github.com/containers/podman-desktop/pull/2455).\\n- Use IPv4 over IPv6 by default [#2398](https://github.com/containers/podman-desktop/pull/2398).\\n- When changing the Kubernetes pod name, change the app name to match [#2389](https://github.com/containers/podman-desktop/pull/2389).\\n- Fixed incorrect pod status in **Containers** view [#2387](https://github.com/containers/podman-desktop/pull/2387).\\n- **Dashboard** wasn\'t correctly refreshing Podman status [#2359](https://github.com/containers/podman-desktop/pull/2359).\\n\\n---\\n\\n## Community Thank You\\n\\n\ud83c\udf89 We\u2019d like to say a big thank you to everyone who helped to make Podman Desktop even better. In this final\\nsprint we received pull requests from the following people:\\n\\n- [Taha Attari](https://github.com/TahaAttari) in [#2470 - Update docker command in importing-saved-containers.md](https://github.com/containers/podman-desktop/pull/2470)\\n- [Jason Greene](https://github.com/n1hility) in [#2431 - Fix hang on exit when telemetry endpoint is unreachable](https://github.com/containers/podman-desktop/pull/2431)\\n- [Anders Bj\xf6rklund](https://github.com/afbjorklund) in [#2571 - Fix the location of the lima podman socket](https://github.com/containers/podman-desktop/pull/2571) and [#2572 - Fix the state of the lima container provider](https://github.com/containers/podman-desktop/pull/2572)\\n- [Tucker Chapman](https://github.com/tuckerrc) in [#2567 - Add example image name in placeholder](https://github.com/containers/podman-desktop/pull/2567)\\n\\nThere are now a total of 54 people (and two bots!) who have contributed PRs to Podman Desktop, and we\'d\\nlike to extend an extra thanks to all of those outside of the immediate development team who contributed\\nto get us here:\\n\\n[afbjorklund](https://github.com/afbjorklund),\\n[alv67](https://github.com/alv67),\\n[anjannath](https://github.com/anjannath),\\n[ankanroy-code](https://github.com/ankanroy-code),\\n[arixmkii](https://github.com/arixmkii),\\n[cblecker](https://github.com/cblecker),\\n[cfergeau](https://github.com/cfergeau),\\n[chevdor](https://github.com/chevdor),\\n[chrisjsimpson](https://github.com/chrisjsimpson),\\n[cu8code](https://github.com/cu8code),\\n[doehyunbaek](https://github.com/doehyunbaek),\\n[dylanmtaylor](https://github.com/dylanmtaylor),\\n[eidottermihi](https://github.com/eidottermihi),\\n[elervik](https://github.com/elervik),\\n[emmanuelbernard](https://github.com/emmanuelbernard),\\n[evanfpearson](https://github.com/evanfpearson),\\n[gorkem](https://github.com/gorkem),\\n[idjohnson](https://github.com/idjohnson),\\n[imphil](https://github.com/imphil),\\n[iongion](https://github.com/iongion),\\n[jlosito](https://github.com/jlosito),\\n[KevinAtSesam](https://github.com/KevinAtSesam),\\n[lsm5](https://github.com/lsm5),\\n[Mitch9378](https://github.com/Mitch9378),\\n[n1hility](https://github.com/n1hility),\\n[osslate](https://github.com/osslate),\\n[PatentLobster](https://github.com/PatentLobster),\\n[pwright](https://github.com/pwright),\\n[rdwz](https://github.com/rdwz),\\n[redhatrises](https://github.com/redhatrises),\\n[rhatdan](https://github.com/rhatdan),\\n[RobotSail](https://github.com/RobotSail),\\n[rohit-rambade](https://github.com/rohit-rambade),\\n[rsvoboda](https://github.com/rsvoboda),\\n[sfrunza13](https://github.com/sfrunza13),\\n[shemanaev](https://github.com/shemanaev),\\n[sstosh](https://github.com/sstosh),\\n[stickster](https://github.com/stickster),\\n[TahaAttari](https://github.com/TahaAttari),\\n[ths83](https://github.com/ths83),\\n[Tony-Sol](https://github.com/Tony-Sol),\\n[tuckerrc](https://github.com/tuckerrc),\\n[ucomesdag](https://github.com/ucomesdag),\\n[xbabalov](https://github.com/xbabalov),\\nzezo2019.\\n\\n---\\n\\n## Final notes\\n\\nThe complete list of issues fixed in this release is available [here](https://github.com/containers/podman-desktop/issues?q=is%3Aclosed+milestone%3A1.0.0) and [here](https://github.com/containers/podman-desktop/issues?q=is%3Aclosed+milestone%3A1.0.1).\\n\\nGet the latest release from the [Downloads](/downloads) section of the website and boost your development journey with Podman Desktop. Additionally, visit the [GitHub repository](https://github.com/containers/podman-desktop) and see how you can help us make Podman Desktop better."},{"id":"podman-desktop-release-0.15","metadata":{"permalink":"/blog/podman-desktop-release-0.15","source":"@site/blog/2023-05-02-release-0.15.md","title":"Release Notes - Podman Desktop 0.15","description":"Podman Desktop 0.15 has been released!","date":"2023-05-02T00:00:00.000Z","formattedDate":"May 2, 2023","tags":[{"label":"podman-desktop","permalink":"/blog/tags/podman-desktop"},{"label":"release","permalink":"/blog/tags/release"},{"label":"kubernetes","permalink":"/blog/tags/kubernetes"},{"label":"kind","permalink":"/blog/tags/kind"}],"readingTime":3.685,"hasTruncateMarker":true,"authors":[{"name":"Tim deBoer","title":"Architect","url":"https://github.com/deboer-tim","imageURL":"https://github.com/deboer-tim.png","key":"deboer"}],"frontMatter":{"title":"Release Notes - Podman Desktop 0.15","description":"Podman Desktop 0.15 has been released!","slug":"podman-desktop-release-0.15","authors":["deboer"],"tags":["podman-desktop","release","kubernetes","kind"],"hide_table_of_contents":false,"image":"/img/blog/podman-desktop-release-0.15.webp"},"prevItem":{"title":"Release Notes - Podman Desktop 1.0","permalink":"/blog/podman-desktop-release-1.0"},"nextItem":{"title":"Setting up and running a Kubernetes cluster locally with Podman Desktop","permalink":"/blog/running-a-local-kubernetes-cluster-with-podman-desktop"}},"content":"import ReactPlayer from \'react-player\'\\n\\nPodman Desktop 0.15 - Cleanliness is next to Podliness!\\n\\nIt has only been two weeks since our last release, but we really wanted to complete a few scenarios,\\nfix a few bugs, and show off several design updates and UI improvements that we have been working on.\\n\\n\x3c!--Main Features--\x3e\\n\\n- **Podman Version**: Podman 4.5 now included in Windows and Mac installers.\\n- **Kind Ingress**: Creating an ingress to expose services outside the Kind cluster.\\n- **Podliness**: Ability to choose external ports when podifying containers.\\n- **Cleanliness**: New navigation bar, dialog, and palette update.\\n- **UX and UI Improvements**: Markdown support for extensions.\\n\\nPodman Desktop 0.15 is now available. [Click here to download it](/downloads)!\\n\\n![Podman-desktop-0-15-hero](img/podman-desktop-release-0.15/podman-desktop-release-0.15.webp)\\n\\n\x3c!--truncate--\x3e\\n\\n---\\n\\n## Release Details\\n\\n### Update to Podman v4.5.O\\n\\nPodman Desktop 0.15 embeds [Podman 4.5.0](https://github.com/containers/podman/releases/tag/v4.5.0) in\\nWindows and macOS installers [#2115](https://github.com/containers/podman-desktop/issues/2115).\\n\\n### Kind Ingress\\n\\nWait a minute, didn\'t we enable this last release? Well yes, last time we did add support for installing\\nthe Contour ingress controller on Kind [#1675](https://github.com/containers/podman-desktop/issues/1675),\\nbut you still couldn\'t access your containers without the corresponding ingress.\\n\\nThis release adds a simple checkbox you can use when deploying to Kind to create an ingress and\\nmake your service accessible [#1322](https://github.com/containers/podman-desktop/issues/1322).\\n\\n\\n\\n### Podliness: Ability to Choose External Ports when Podifying Containers\\n\\nWhen you create a pod from of a set of containers (Podifying!), you probably don\'t want to expose every\\nsingle port from every container to the world. With an updated panel you can now see which ports each container\\nexposes, pick which should remain visible outside the pod, and which are for internal use\\n[#2232](https://github.com/containers/podman-desktop/pull/2232).\\n\\n![Podify page](https://user-images.githubusercontent.com/49404737/234527674-ed14f52c-8f66-445f-8038-c8135bb61136.gif)\\n\\n### Cleanliness: New Navigation Bar, Dialogs, and Palette\\n\\nIt was time to catch up on some design ideas and do some UI cleanup!\\n\\n#### New Navgation Bar\\n\\nThe navigation bar is now always fixed on the left size, without labels. This opens up more space\\nfor the content on each page, and is easier to jump in and out of ** Settings**.\\n[#2167](https://github.com/containers/podman-desktop/issues/2167)\\n\\n![Navigation bar](img/podman-desktop-release-0.15/navigation.png)\\n\\n#### Updated Dialogs\\n\\nWe wanted messages and dialog boxes to feel a bit more integrated, so we have a new message box\\n[#1808](https://github.com/containers/podman-desktop/pull/1808) and use it for all dialogs opened by\\nextensions, pruning containers/pods/images/volumes [#2138](https://github.com/containers/podman-desktop/pull/2138),\\nand updating Podman Desktop itself [#2249](https://github.com/containers/podman-desktop/pull/2249).\\n\\n![Dialog](img/podman-desktop-release-0.15/dialog.png)\\n\\n#### Colors\\n\\nWe spent some time tweaking colors and closing on our final palette\\n[#2199](https://github.com/containers/podman-desktop/pull/2199), updating the colors in the terminal & detail page\\n[#2222](https://github.com/containers/podman-desktop/pull/2222), tweaking the navigation and main page colors\\n[#2223](https://github.com/containers/podman-desktop/pull/2223),\\nand improving the look of forms [#2156](https://github.com/containers/podman-desktop/issues/2156).\\n\\nWe\'re not done yet, but hopefully you will notice a more polished, consistent, good-looking application!\\n\\n### Other UI and UX Improvements\\n\\n#### Markdown Support for Extensions\\n\\nWe added a new component to display markdown [#2219](https://github.com/containers/podman-desktop/pull/2219) and\\nenabled it in preferences [#2253](https://github.com/containers/podman-desktop/pull/2253), and\\nprovider properties/creation pages [#2152](https://github.com/containers/podman-desktop/issues/2152).\\nWe can now embed links and other formatting in preferences, and extensions can use them in many places, for example:\\n\\n![Markdown](img/podman-desktop-release-0.15/markdown.png)\\n\\n---\\n\\n## Other Notable Enhancements\\n\\n- We know which **Settings** page is used the most often, so now it\'s the default: ** Settings > Resources** [#2105](https://github.com/containers/podman-desktop/issues/2105).\\n\\n- Extensions can now use the Tasks API to let long running tasks continue in the background [#2019](https://github.com/containers/podman-desktop/issues/2019) and the existing withProgress API also uses the task manager now\\n [#2187](https://github.com/containers/podman-desktop/pull/2187).\\n\\n![Task API](https://user-images.githubusercontent.com/695993/233560830-85cfa685-5dcd-4efa-9fae-730a8a9eef3b.gif)\\n\\n- Images are now sorted by age [#2311](https://github.com/containers/podman-desktop/pull/2311).\\n\\n- When you start/stop a container or pod, the button is now animated instead of having an separate spinner\\n [#2101](https://github.com/containers/podman-desktop/issues/2101).\\n\\n- The ** Settings > Preferences** page now has a search bar [#2128](https://github.com/containers/podman-desktop/pull/2128).\\n\\n![Search preferences](img/podman-desktop-release-0.15/prefs.png)\\n\\n- The Help page has been updated [#431](https://github.com/containers/podman-desktop/issues/431).\\n\\n![Updated Help](img/podman-desktop-release-0.15/help.png)\\n\\n---\\n\\n## Notable Bug Fixes\\n\\n- There was no way to see log or outcome if you leave the Kind cluster creation page [#2079](https://github.com/containers/podman-desktop/issues/2079).\\n- Kind image load doesn\'t show a notification [#2225](https://github.com/containers/podman-desktop/issues/2225).\\n- Fix odd selection in ** Settings > Extensions** [#2130](https://github.com/containers/podman-desktop/issues/2130).\\n- Menus are now cleaned up properly when extensions are stopped [#2188](https://github.com/containers/podman-desktop/pull/2188).\\n- Kind clusters are now cleaned up when Podman machine is stopped [#2306](https://github.com/containers/podman-desktop/pull/2306).\\n\\n---\\n\\n## Final notes\\n\\nThe complete list of issues fixed in this release is available [here](https://github.com/containers/podman-desktop/issues?q=is%3Aclosed+milestone%3A0.15.0).\\n\\nGet the latest release from the [Downloads](/downloads) section of the website and boost your development journey with Podman Desktop. Additionally, visit the [GitHub repository](https://github.com/containers/podman-desktop) and see how you can help us make Podman Desktop better."},{"id":"running-a-local-kubernetes-cluster-with-podman-desktop","metadata":{"permalink":"/blog/running-a-local-kubernetes-cluster-with-podman-desktop","source":"@site/blog/2023-04-19-running-a-local-kubernetes-cluster-with-podman-desktop.md","title":"Setting up and running a Kubernetes cluster locally with Podman Desktop","description":"Setting up and running a Kubernetes cluster locally with Podman Desktop","date":"2023-04-19T00:00:00.000Z","formattedDate":"April 19, 2023","tags":[{"label":"podman-desktop","permalink":"/blog/tags/podman-desktop"},{"label":"story","permalink":"/blog/tags/story"},{"label":"kubernetes","permalink":"/blog/tags/kubernetes"},{"label":"kind","permalink":"/blog/tags/kind"}],"readingTime":8.86,"hasTruncateMarker":true,"authors":[{"name":"Fabrice Flore-Thebault","title":"Technical writer","url":"https://github.com/themr0c","imageURL":"https://github.com/themr0c.png","key":"themr0c"}],"frontMatter":{"title":"Setting up and running a Kubernetes cluster locally with Podman Desktop","description":"Setting up and running a Kubernetes cluster locally with Podman Desktop","slug":"running-a-local-kubernetes-cluster-with-podman-desktop","authors":["themr0c"],"tags":["podman-desktop","story","kubernetes","kind"],"hide_table_of_contents":false},"prevItem":{"title":"Release Notes - Podman Desktop 0.15","permalink":"/blog/podman-desktop-release-0.15"},"nextItem":{"title":"Release Notes - Podman Desktop 0.14","permalink":"/blog/podman-desktop-release-0.14"}},"content":"In this blog post you will learn to use Podman Desktop to run the [Kubernetes documentation example: Deploying PHP Guestbook application with Redis](https://kubernetes.io/docs/tutorials/stateless-application/guestbook/).\\n\\nOn the agenda:\\n\\n1. Installing Podman Desktop.\\n1. Installing and initializing your container engine: Podman.\\n1. Installing and starting your local Kubernetes provider: Kind.\\n1. Starting the Redis leader.\\n1. Starting and scaling the Redis followers.\\n1. Starting and exposing the Guestbook frontend.\\n\\n\x3c!--truncate--\x3e\\n\\n## Installing Podman Desktop\\n\\nYou need Podman Desktop.\\n\\n1. Go to [Podman Desktop installation documentation](/docs/installation).\\n1. Click on your platform name: [Windows](/docs/installation/windows-install), [macOS](/docs/installation/macos-install), or [Linux](/docs/installation/linux-install).\\n1. Follow the instructions. Stick to the default installation method.\\n1. Start **Podman Desktop**.\\n\\nAt this point, you have a graphical user interface to:\\n\\n- Install Podman and Kind.\\n- Control and work with your container engines and Kubernetes clusters.\\n- Run your application on your container engine and migrate it to Kubernetes.\\n\\n## Installing and initializing your container engine: Podman\\n\\nPodman Desktop can control various container engines, such as:\\n\\n- Docker\\n- Lima\\n- Podman\\n\\nConsider installing the Podman container engine for:\\n\\n- Added security\\n- No daemon\\n- Open source\\n\\nContainers are a Linux technology.\\n\\n- On Linux, you can install Podman natively.\\n See: [Installing Podman on Linux](https://podman.io/docs/installation#installing-on-linux).\\n- On macOS and Windows, Podman requires to run in a Linux virtual machine: the Podman machine.\\n Use Podman Desktop to install Podman and initialize your Podman machine:\\n\\n#### Procedure\\n\\n1. Open Podman Desktop **Dashboard**\\n1. The **Dashboard** displays _Podman Desktop was not able to find an installation of Podman_.\\n1. Click on **Install**.\\n1. Podman Desktop checks the prerequisites to install Podman Engine. When necessary, follow the instructions to install prerequisites.\\n1. Podman displays the dialog: _Podman is not installed on this system, would you like to install Podman?_. Click on **Yes** to install Podman.\\n1. Click on **Initialize and start**.\\n\\n#### Verification\\n\\n- The **Dashboard** displays _Podman is running_.\\n\\n ![Podman is running](img/running-a-local-kubernetes-cluster-with-podman-desktop/podman-is-running.png)\\n\\nAt this point, you can start working with containers.\\n\\n## Installing and starting your local Kubernetes provider: Kind\\n\\nYou want to deploy your application to a local Kubernetes cluster.\\n\\nPodman Desktop can help you run Kind-powered local Kubernetes clusters on a container engine, such as Podman.\\n\\nPodman Desktop helps you [installing the `kind` CLI](/docs/kind/installing):\\n\\n1. In the status bar, click on **Kind**, and follow the prompts.\\n1. When the `kind` CLI is available, the status bar does not display **Kind**.\\n1. On Windows, [configure Podman in rootful mode](/docs/kind/configuring-podman-for-kind-on-windows)\\n\\n ```shell-session\\n $ podman system connection default podman-machine-default-root\\n ```\\n\\n1. Go to ** Settings > Resources**\\n1. In the **\\"Podman Podman** tile, click on the **** icon to restart the Podman container engine.\\n1. In the **\\"Kind Kind** tile, click on the **Create new** button.\\n 1. **Name**: enter `kind-cluster`.\\n 1. **Provider Type**: select `podman`.\\n 1. **HTTP Port**: select `9090`.\\n 1. **HTTPS Port**: select `9443`.\\n 1. **Setup an ingress controller**: `Enabled`\\n 1. Click the **Create** button.\\n ![Create a Kind cluster screen](img/running-a-local-kubernetes-cluster-with-podman-desktop/create-a-kind-cluster.png)\\n1. After successful creation, click on the **Go back to resources** button\\n\\n#### Verification\\n\\n1. In ** Settings > Resources** your Kind cluster is running/\\n\\n ![Kind cluster is running](img/running-a-local-kubernetes-cluster-with-podman-desktop/kind-cluster-is-running.png)\\n\\n1. In the **Podman Desktop** tray, open the **Kubernetes** menu: you can set the context to your Kind cluster: `kind-kind-cluster`.\\n\\n ![Kind cluster Kubernetes context in the tray](img/running-a-local-kubernetes-cluster-with-podman-desktop/kind-cluster-context-in-the-tray.png)\\n\\n At this point, you can start working with containers, and your local Kubernetes cluster.\\n\\n#### Additional resources\\n\\n- [Creating a local Kind-powered Kubernetes cluster](/docs/kind/creating-a-kind-cluster)\\n\\n## Starting the Redis leader\\n\\nThe Guestbook application uses Redis to store its data.\\n\\nWith Podman Desktop, you can prepare the Redis leader image and container on your local container engine, and deploy the results to a Kubernetes pod and service.\\nThis is functionally equal to the `redis-leader` deployment that the Kubernetes example propose.\\n\\n#### Procedure\\n\\n1. Open ** Images > Pull an image**.\\n 1. **Image to Pull**: enter `docker.io/redis:6.0.5`\\n 1. Click **Pull image** to pull the image to your container engine local image registry.\\n 1. Click **Done** to get back to the images list.\\n1. ** Search images**: enter `redis:6.0.5` to find the image.\\n1. Click **** to open the **Create a container from image** dialog.\\n 1. **Container name**: enter `leader`,\\n 1. **Local port for `6379/tcp`**: `6379`.\\n 1. Click ** Start Container** to start the container in your container engine.\\n1. ** Search containers**: enter `leader` to find the running container.\\n1. Click **** to stop the container, and leave the `6379` port available for the Redis follower container.\\n\\n1. Click ** > Deploy to Kubernetes** to open the **Deploy generated pod to Kubernetes** screen.\\n\\n 1. **Pod Name**: enter `redis-leader`.\\n 1. **Use Kubernetes Services**: select **Replace `hostPort` exposure on containers by Services. It is the recommended way to expose ports, as a cluster policy might prevent to use `hostPort`.**\\n 1. **Expose service locally using Kubernetes Ingress**: deselect **Create a Kubernetes ingress to get access to the ports that this pod exposes, at the default ingress controller location. Example: on a default Kind cluster created with Podman Desktop: `http://localhost:9090`. Requirements: your cluster has an ingress controller`**.\\n 1. **Kubernetes namespaces**: select `default`.\\n 1. Click ** Deploy**.\\n ![Deploy generated leader pod to Kubernetes screen](img/running-a-local-kubernetes-cluster-with-podman-desktop/deploy-generated-leader-pod-to-kubernetes.png)\\n 1. Wait for the pod to reach the state: **Phase: Running**.\\n 1. Click **Done**.\\n\\n#### Verification\\n\\n- The ** Pods** screen lists the running `redis-leader` pod.\\n\\n ![leader pod is running](img/running-a-local-kubernetes-cluster-with-podman-desktop/leader-pod-is-running.png)\\n\\n## Starting the Redis followers\\n\\nAlthough the Redis leader is a single Pod, you can make it highly available and meet traffic demands by adding a few Redis followers, or replicas.\\n\\n**With Podman Desktop, you can prepare the Redis follower image and container on your local container engine, and deploy the results to Kubernetes pods and services.**\\nThis is functionally equal to the `redis-follower` deployment that the Kubernetes example propose.\\n\\n#### Procedure\\n\\n1. Open ** Images > Pull an image**.\\n 1. **Image to Pull**: enter `gcr.io/google_samples/gb-redis-follower:v2`\\n 1. Click **Pull image** to pull the image to your container engine local image registry.\\n 1. Click **Done** to get back to the images list.\\n1. ** Search images**: enter `gb-redis-follower:v2` to find the image.\\n1. Click **** to open the **Create a container from image** dialog.\\n 1. **Container name**: enter `follower`,\\n 1. **Local port for `6379/tcp`**: `6379`.\\n 1. Click ** Start Container** to start the container in your container engine.\\n1. ** Search containers**: enter `follower` to find the running container.\\n1. Click **** to stop the container: you do not need it to run in the container engine.\\n1. Click ** > Deploy to Kubernetes** to open the **Deploy generated pod to Kubernetes** screen.\\n 1. **Pod Name**: enter `redis-follower`.\\n 1. **Use Kubernetes Services**: select **Replace `hostPort` exposure on containers by Services. It is the recommended way to expose ports, as a cluster policy might prevent to use `hostPort`.**\\n 1. **Expose service locally using Kubernetes Ingress**: deselect **Create a Kubernetes ingress to get access to the ports that this pod exposes, at the default ingress controller location. Example: on a default Kind cluster created with Podman Desktop: `http://localhost:9090`. Requirements: your cluster has an ingress controller`**.\\n 1. **Kubernetes namespaces**: select `default`.\\n 1. Click ** Deploy**.\\n ![Deploy generated follower pod to Kubernetes screen](img/running-a-local-kubernetes-cluster-with-podman-desktop/deploy-generated-follower-pod-to-kubernetes.png)\\n 1. Wait for the pod to reach the state: **Phase: Running**.\\n 1. Click **Done**.\\n1. To add replicas, repeat the last step with another **Pod Name** value.\\n\\n#### Verification\\n\\n- The ** Pods** screen lists the running `redis-follower` pods.\\n\\n ![follower pods are running](img/running-a-local-kubernetes-cluster-with-podman-desktop/follower-pods-are-running.png)\\n\\n## Starting the default frontend\\n\\nNow that you have the Redis storage of your Guestbook up and running, start the Guestbook web servers.\\nLike the Redis followers, deploy the frontend using Kubernetes pods and services.\\n\\nThe Guestbook app uses a PHP frontend.\\nIt is configured to communicate with either the Redis follower or leader Services, depending on whether the request is a read or a write.\\nThe frontend exposes a JSON interface, and serves a jQuery-Ajax-based UX.\\n\\nWith Podman Desktop, you can prepare the Guestbook frontend image and container on your local container engine, and deploy the results to Kubernetes pods and services.\\nThis is functionally equal to the `frontend` deployment that the Kubernetes example propose.\\n\\n#### Procedure\\n\\n1. Open ** Images > Pull an image**.\\n 1. **Image to Pull**: enter `gcr.io/google_samples/gb-frontend:v5`\\n 1. Click **Pull image** to pull the image to your container engine local image registry.\\n 1. Wait for the pull to complete.\\n 1. Click **Done** to get back to the images list.\\n1. ** Search images**: enter `gb-frontend:v5` to find the image.\\n1. Click **** to open the **Create a container from image** dialog.\\n 1. **Container name**: enter `frontend`,\\n 1. **Local port for `80/tcp`**: `9000`.\\n 1. Click ** Start Container** to start the container in your container engine.\\n1. ** Search containers**: enter `frontend` to find the running container.\\n1. Click **** to stop the container: you do not need it to run in the container engine.\\n1. Click ** > Deploy to Kubernetes** to open the **Deploy generated pod to Kubernetes** screen.\\n 1. **Pod Name**: enter `frontend`.\\n 1. **Use Kubernetes Services**: select **Replace `hostPort` exposure on containers by Services. It is the recommended way to expose ports, as a cluster policy might prevent to use `hostPort`.**\\n 1. **Expose service locally using Kubernetes Ingress**: select **Create a Kubernetes ingress to get access to the ports that this pod exposes, at the default ingress controller location. Example: on a default Kind cluster created with Podman Desktop: `http://localhost:9090`. Requirements: your cluster has an ingress controller`**.\\n 1. **Kubernetes namespaces**: select `default`.\\n 1. Click ** Deploy**.\\n ![Deploy generated frontend pod to Kubernetes screen](img/running-a-local-kubernetes-cluster-with-podman-desktop/deploy-generated-frontend-pod-to-kubernetes.png)\\n 1. Wait for the pod to reach the state: **Phase: Running**.\\n 1. Click **Done**.\\n\\n#### Verification\\n\\n1. The ** Pods** screen lists the running `frontend` pod.\\n\\n ![`frontend` pod is running](img/running-a-local-kubernetes-cluster-with-podman-desktop/frontend-pod-is-running.png)\\n\\n1. Go to `http://localhost:9090`: the Guestbook application is running."},{"id":"podman-desktop-release-0.14","metadata":{"permalink":"/blog/podman-desktop-release-0.14","source":"@site/blog/2023-04-14-release-0.14.md","title":"Release Notes - Podman Desktop 0.14","description":"Podman Desktop 0.14 has been released!","date":"2023-04-14T00:00:00.000Z","formattedDate":"April 14, 2023","tags":[{"label":"podman-desktop","permalink":"/blog/tags/podman-desktop"},{"label":"release","permalink":"/blog/tags/release"},{"label":"kubernetes","permalink":"/blog/tags/kubernetes"},{"label":"kind","permalink":"/blog/tags/kind"}],"readingTime":4.025,"hasTruncateMarker":true,"authors":[{"name":"Tim deBoer","title":"Architect","url":"https://github.com/deboer-tim","imageURL":"https://github.com/deboer-tim.png","key":"deboer"}],"frontMatter":{"title":"Release Notes - Podman Desktop 0.14","description":"Podman Desktop 0.14 has been released!","slug":"podman-desktop-release-0.14","authors":["deboer"],"tags":["podman-desktop","release","kubernetes","kind"],"hide_table_of_contents":false},"prevItem":{"title":"Setting up and running a Kubernetes cluster locally with Podman Desktop","permalink":"/blog/running-a-local-kubernetes-cluster-with-podman-desktop"},"nextItem":{"title":"Release Notes - Podman Desktop 0.13","permalink":"/blog/podman-desktop-release-0.13"}},"content":"import ReactPlayer from \'react-player\'\\n\\nPodman Desktop 0.14 - Our Kind-est release yet!\\n\\nWe have been working on a Kind extension for a while now, and decided it is time to promote it\\ninto a release just in time for KubeCon and CloudNativeCon Europe!\\n\\nWe\'re especially excited about releasing Kind because it finally shows the full purpose\\nof Podman Desktop: not just local container engines, but Kubernetes too. More importantly,\\nproviding tools that allow you to manage both environments and seamlessly move between them.\\n\\nSome of these features were available in development mode over the last few releases,\\nbut since they are now in the release build, we will do a full roundup and talk about\\nall the Kind features.\\n\\n\x3c!--Main Features--\x3e\\n\\n- **Kind Installation**: Install Kind from the status bar\\n- **Manage Kind Clusters**: Create and manage Kind clusters from ** Settings > Resources**\\n- **Using Kind**: Deploying YAML and sharing images to a cluster\\n- **Kind Ingress**: Install a Contour ingress controller\\n- **UX and UI Improvements**: Updated preferences and telemetry prompt\\n\\nPodman Desktop 0.14 is now available. [Click here to download it](/downloads)!\\n\\n![Podman-desktop-0-14-hero](img/podman-desktop-release-0.14/podman-desktop-release-0.14.png)\\n\\n\x3c!--truncate--\x3e\\n\\n---\\n\\n## Release details\\n\\n### Kind Installation\\n\\nGet Kind up and running in seconds! The Kind extension is now bundled as part of Podman Desktop\\n[1421](https://github.com/containers/podman-desktop/issues/1421)\\nand allows you to easily [install Kind directly from the status bar](/docs/kind/installing)\\n[1257](https://github.com/containers/podman-desktop/issues/1257).\\n\\nThe installed `kind` CLI is available from the system shell [1516](https://github.com/containers/podman-desktop/issues/1516),\\nallowing you to open a terminal window to `kind get clusters` or work with other tools.\\n\\n### Manage Kind Clusters\\n\\nOnce Kind is installed (or if you already had it), you can manage your clusters in ** Settings > Resources**.\\nFrom here you can [create Kind clusters](/docs/kind/creating-a-kind-cluster),\\nstart/stop [1953](https://github.com/containers/podman-desktop/issues/1953)\\nor delete [1977](https://github.com/containers/podman-desktop/issues/1977) them.\\n\\n![kind-clusters](img/podman-desktop-release-0.14/kind-clusters.png)\\n\\nThe Kind control plane runs as a container. You will see this container\\nin the **Container** list and can also start or stop it from there.\\n\\n### Using Kind\\n\\nNow that you have Kind installed and running, what can you do with it?\\nIf you like terminals, you can always open one up and use the Kind CLI to\\n[interact with your cluster](https://kind.sigs.k8s.io/docs/user/quick-start/#interacting-with-your-cluster).\\n\\nWithin Podman Desktop we have started with two ways to interact with the cluster.\\nThe first is the ability to play local YAML files on your Kind (or any other Kubernetes!) cluster [1261](https://github.com/containers/podman-desktop/issues/1261). This allows you to take existing Kubernetes YAML definitions -\\nyour deployments, services, or other objects - and deploy it to the cluster.\\n\\n\\n\\nAs you deploy pods, they will automatically appear in the list of **Pods** [1263](https://github.com/containers/podman-desktop/issues/1263), allowing you to start, stop, and interact them just like pods running on Podman.\\n\\nOne of the most common uses is to deploy a container that you have been running on Podman, and this will fail\\nif the image is not available in Kind. To solve this we have made it easy to push images from\\nPodman to Kind [1448](https://github.com/containers/podman-desktop/issues/1448).\\n\\n![push-image-kind](img/podman-desktop-release-0.14/push-image-kind.png)\\n\\n### Kind Ingress\\n\\nIf you deploy a pod to Kind, you are also going to want to reach it! To do this you will need to install a load balancer or\\ningress controller so that the pod is accessible from outside the cluster. We made it easy to install the Contour ingress\\ncontroller while creating a Kind cluster [1675](https://github.com/containers/podman-desktop/issues/1675),\\nso if you created your cluster with Podman Desktop it is already there!\\n\\n![kind-ingress](img/podman-desktop-release-0.14/kind-ingress.png)\\n\\nWe have several other Kind and Kubernetes features planned to expand the supported scenarios, but hopefully this\\nmakes it easy to get started with Kind and shows where we\'re headed. As always, feedback is appreciated!\\n\\n### UI and UX improvements\\n\\n#### Updated Preferences\\n\\nThe ** Settings > Preferences** page has been updated with a new design [1913](https://github.com/containers/podman-desktop/pull/1913),\\nmaking it easier to see and change preferences. Changes are live, no more Update button.\\n\\n![preferences](https://user-images.githubusercontent.com/49404737/229498507-e754b55c-dcbd-486d-9ee3-a1fe3bed7271.gif)\\n\\n#### Telemetry Prompt\\n\\nThe prompt to enable or disable telemetry has been moved from its own dialog into the **Welcome** screen.\\n[1927](https://github.com/containers/podman-desktop/pull/1927)\\nThis is more usable, one less prompt, and solves a window-layering issue for some users!\\n\\n![telemetry prompt](https://user-images.githubusercontent.com/19958075/229577331-365a9a01-0426-4482-a95d-f5dfe39af90a.png)\\n\\n---\\n\\n## Other notable enhancements\\n\\n- Extension support for opening an external URL [2028](https://github.com/containers/podman-desktop/pull/2028) and\\n accessing the clipboard [2023](https://github.com/containers/podman-desktop/pull/2023)\\n\\n---\\n\\n## Documentation\\n\\nNaturally, we have a section in the documentation just for [Kind](https://podman-desktop.io/docs/kind).\\n\\n---\\n\\n## Notable bug fixes\\n\\n- Avoid a dialog box if unable to check for updates [2062](https://github.com/containers/podman-desktop/pull/2062)\\n- Unable to get to the Dashboard if Kind (or Kubernetes) cluster was not running [2052](https://github.com/containers/podman-desktop/issues/2052)\\n\\n---\\n\\n## Final notes\\n\\nThe complete list of issues fixed in this release is available [here](https://github.com/containers/podman-desktop/issues?q=is%3Aclosed+milestone%3A0.14.0).\\n\\nGet the latest release from the [Downloads](/downloads) section of the website and boost your development journey with Podman Desktop. Additionally, visit the [GitHub repository](https://github.com/containers/podman-desktop) and see how you can help us make Podman Desktop better."},{"id":"podman-desktop-release-0.13","metadata":{"permalink":"/blog/podman-desktop-release-0.13","source":"@site/blog/2023-03-29-release-0.13.md","title":"Release Notes - Podman Desktop 0.13","description":"Podman Desktop 0.13 has been released!","date":"2023-03-29T00:00:00.000Z","formattedDate":"March 29, 2023","tags":[{"label":"podman-desktop","permalink":"/blog/tags/podman-desktop"},{"label":"release","permalink":"/blog/tags/release"},{"label":"kubernetes","permalink":"/blog/tags/kubernetes"},{"label":"compose","permalink":"/blog/tags/compose"}],"readingTime":3.155,"hasTruncateMarker":true,"authors":[{"name":"Tim deBoer","title":"Architect","url":"https://github.com/deboer-tim","imageURL":"https://github.com/deboer-tim.png","key":"deboer"}],"frontMatter":{"title":"Release Notes - Podman Desktop 0.13","description":"Podman Desktop 0.13 has been released!","slug":"podman-desktop-release-0.13","authors":["deboer"],"tags":["podman-desktop","release","kubernetes","compose"],"hide_table_of_contents":false},"prevItem":{"title":"Release Notes - Podman Desktop 0.14","permalink":"/blog/podman-desktop-release-0.14"},"nextItem":{"title":"5 things to know about Podman Desktop for a Docker user","permalink":"/blog/5-things-to-know-for-a-docker-user"}},"content":"import ReactPlayer from \'react-player\'\\n\\nThis release note covers Podman Desktop 0.13 release changes.\\n\\n\x3c!--Main Features--\x3e\\n\\n- **Podman Version**: Podman 4.4.4 now included in Windows and Mac installers.\\n- **Compose**: Support for installing Docker Compose.\\n- **Extensions**: Improved extension support for Podman Desktop with additional capabilities.\\n- **UX and UI Improvements**: Welcome page, task manager, resources, and update alerts.\\n\\nPodman Desktop 0.13 is now available. [Click here to download it](/downloads)!\\n\\n![Podman-desktop-0-13-hero](img/podman-desktop-release-0.13/podman-desktop-release-0.13.png)\\n\\n\x3c!--truncate--\x3e\\n\\n---\\n\\n## Release details\\n\\n### Update to Podman v4.4.4\\n\\nPodman Desktop 0.13 embeds [Podman 4.4.4](https://github.com/containers/podman/releases/tag/v4.4.4) in\\nWindows and macOS installers [#1456](https://github.com/containers/podman-desktop/pull/1456).\\n\\n### Compose support\\n\\nYou can install Docker Compose from the Podman Desktop UI [#1578](https://github.com/containers/podman-desktop/pull/1578). This will allow you use Compose workflows using Podman.\\n\\n### Extensions\\n\\nTo make it easier to extend Podman Desktop we have:\\n\\n- Published the [Podman Desktop Extension API](https://www.npmjs.com/package/@podman-desktop/api) to npmjs [#1727](https://github.com/containers/podman-desktop/pull/1727)\\n- Documented [how to create, publish, and install your own extensions](https://podman-desktop.io/docs/extensions)\\n- Expanded the API for `QuickPickInput` [#1839](https://github.com/containers/podman-desktop/pull/1839)\\n\\n### UI and UX improvements\\n\\n#### Welcome page [#1726](https://github.com/containers/podman-desktop/pull/1726)\\n\\nThe first time every user starts Podman Desktop, they will see a welcome page:\\n\\n![welcome-page](https://user-images.githubusercontent.com/19958075/225682776-e016ba31-5bb9-41d5-87ed-f93caeb3fb84.png)\\n\\nNote that the Welcome page will only appear the first time you run Podman Desktop 0.13.0, and none of your settings or assets in Podman Desktop will be affected by it.\\nOver time, this page will be expanded to help with initial setup and configuration.\\n\\n#### New Task Manager [#1724](https://github.com/containers/podman-desktop/pull/1724)\\n\\nA new Task Manager has been added to the status bar to see the progress (or return to) long running tasks. To start with, building images [#1725](https://github.com/containers/podman-desktop/pull/1725) and Podman machine [#1742](https://github.com/containers/podman-desktop/pull/1742) are using the task manager.\\n\\n![task-manager](img/podman-desktop-release-0.13/task-manager.png)\\n\\n#### Updated Resources Settings [#1582](https://github.com/containers/podman-desktop/pull/1582)\\n\\nThe ** Settings > Resources** page has been updated with a new design, making it easier to see and control your providers from a single place.\\n\\n![resources](https://user-images.githubusercontent.com/49404737/221908815-595715fe-4c95-4087-89e0-45e5544ed5c9.gif)\\n\\nThe other settings pages have been updated for consistency with this new design.\\n\\n#### Update Alerts [#1827](https://github.com/containers/podman-desktop/pull/1827)\\n\\nA new alert button will appear in the status bar when future updates are available.\\n\\n\\n\\n#### Prune buttons [#1481](https://github.com/containers/podman-desktop/pull/1481), [#1482](https://github.com/containers/podman-desktop/pull/1482), [#1484](https://github.com/containers/podman-desktop/pull/1484)\\n\\nWe\'ve added buttons to prune unused volumes [#1481](https://github.com/containers/podman-desktop/pull/1481), images [#1482](https://github.com/containers/podman-desktop/pull/1482) and pods [#1484](https://github.com/containers/podman-desktop/pull/1484).\\n\\n![prune-image](img/podman-desktop-release-0.13/prune-image.png)\\n\\n---\\n\\n## Other notable enhancements\\n\\n- Kubernetes pods are now shown in the Pods view [#1312](https://github.com/containers/podman-desktop/pull/1312)\\n- Easy button to fix Docker compatibility mode on macOS [#1697](https://github.com/containers/podman-desktop/pull/1697)\\n- Display extension icons [#1058](https://github.com/containers/podman-desktop/pull/1058)\\n- API to cancel long running tasks [#1777](https://github.com/containers/podman-desktop/pull/1777)\\n\\n---\\n\\n## Documentation\\n\\nThe documentation has new content:\\n\\n- [How to create, publish, and install your own Podman Desktop extensions](https://podman-desktop.io/docs/extensions)\\n- [Using Compose](https://podman-desktop.io/docs/compose/podman-compose)\\n- [Restarting Kind](https://podman-desktop.io/docs/kind)\\n\\n---\\n\\n## Notable bug fixes\\n\\n- Periodically check and refresh Podman connection on Windows and Mac [#1662](https://github.com/containers/podman-desktop/pull/1662)\\n- Fix inconsistent Log view behaviour [#1710](https://github.com/containers/podman-desktop/pull/1710)\\n- Don\'t create route for regular Kubernetes clusters [#1707](https://github.com/containers/podman-desktop/pull/1707)\\n- Fix copy button on empty screen [#1804](https://github.com/containers/podman-desktop/pull/1804)\\n- Register extension tray items correctly [#1778](https://github.com/containers/podman-desktop/pull/1778) and handle updates [#1800](https://github.com/containers/podman-desktop/pull/1800)\\n\\n---\\n\\n## Community thank you\\n\\n\ud83c\udf89 We\u2019d like to say a big thank you to everyone who helped to make Podman Desktop 0.13 even better:\\n\\n- [`Tony Soloveyv`](https://github.com/Tony-Sol) in [#1605 - Fix directories inconsistency in `~/.local/share/`](https://github.com/containers/podman-desktop/pull/1605)\\n- [`Oleg`](https://github.com/RobotSail) in [#1567 - Check for Flatpak when calling command from exec](https://github.com/containers/podman-desktop/pull/1567)\\n- [`Christoph Blecker`](https://github.com/cblecker) in [#1556 - Fix: Hide dock icon on macOS if starting minimized](https://github.com/containers/podman-desktop/pull/1556)\\n- [`Paul Wright`](https://github.com/pwright) in [#1604 - Docs: correct syntax of kind doc](https://github.com/containers/podman-desktop/pull/1604)\\n- [`Denis Golovin`](https://github.com/dgolovin) in [#1790 - Feat: add EventEmitter class to extension API](https://github.com/containers/podman-desktop/pull/1790)\\n- [`Christophe Fergeau`](https://github.com/cfergeau) in [#1642 - Fix: Pod list \\"an pod\\" typing error](https://github.com/containers/podman-desktop/pull/1642)\\n\\n## Final notes\\n\\nThe complete list of issues fixed in this release is available [here](https://github.com/containers/podman-desktop/issues?q=is%3Aclosed+milestone%3A0.13.0).\\n\\nGet the latest release from the [Downloads](/downloads) section of the website and boost your development journey with Podman Desktop. Additionally, visit the [GitHub repository](https://github.com/containers/podman-desktop) and see how you can help us make Podman Desktop better."},{"id":"5-things-to-know-for-a-docker-user","metadata":{"permalink":"/blog/5-things-to-know-for-a-docker-user","source":"@site/blog/2023-03-24-5-things-to-know-for-a-docker-user.md","title":"5 things to know about Podman Desktop for a Docker user","description":"Important things to know when switching from Docker Desktop to Podman Desktop","date":"2023-03-24T00:00:00.000Z","formattedDate":"March 24, 2023","tags":[{"label":"podman-desktop","permalink":"/blog/tags/podman-desktop"},{"label":"docker","permalink":"/blog/tags/docker"},{"label":"migrating","permalink":"/blog/tags/migrating"}],"readingTime":4.285,"hasTruncateMarker":true,"authors":[{"name":"Florent Benoit","title":"Maintainer of Podman Desktop","url":"https://github.com/benoitf","imageURL":"https://github.com/benoitf.png","key":"benoitf"}],"frontMatter":{"title":"5 things to know about Podman Desktop for a Docker user","description":"Important things to know when switching from Docker Desktop to Podman Desktop","slug":"5-things-to-know-for-a-docker-user","authors":["benoitf"],"tags":["podman-desktop","docker","migrating"],"hide_table_of_contents":false},"prevItem":{"title":"Release Notes - Podman Desktop 0.13","permalink":"/blog/podman-desktop-release-0.13"},"nextItem":{"title":"Release Notes - Podman Desktop 0.12","permalink":"/blog/podman-desktop-release-0.12"}},"content":"The 5 things to know being a Docker user by using Podman Desktop:\\n\\n- **Use a single UI**: Podman Desktop works with several container engines, including Docker.\\n- The **compatibility mode**: How to ensure tools are working with Podman instead of Docker.\\n- **Compose** support: How to work with Compose files and Podman.\\n- **Kubernetes** support: How to use Kubernetes with Podman.\\n- **Security**: Use `rootless` mode or containers without root privileges.\\n\\n![5-things-to-know-for-a-docker-user-hero](img/5-things-to-know-for-a-docker-user/5-things-to-know-for-a-docker-user-hero.png)\\n\\n\x3c!--truncate--\x3e\\n\\n---\\n\\n## Use Podman Desktop to interact with containers running in Docker\\n\\nDocker Desktop provides a UI to interact with containers and images. But the UI depends on Docker API and it is not possible to use the UI with Docker and Podman at the same time.\\n\\nPodman Desktop is a multi-engine UI tool. The UI is compatible with the API of Docker and Podman. It means all containers and images from all the engines at the same time are visible in the UI.\\n\\nWhen migrating from Docker to Podman, you can use Podman Desktop to interact with containers running in Docker. Explore all commands and features of Podman Desktop and see all the resources from Docker.\\n\\n![Many container engines at the same time](img/5-things-to-know-for-a-docker-user/multiple-container-engines.png)\\n\\n## Docker compatibility mode\\n\\nUsing Podman with Podman Desktop or with the Podman CLI is straightforward. But some tools expect to find `docker` CLI or `docker.sock` socket. In this case, you have to use the compatibility mode of Podman.\\n\\n### Socket file compatibility\\n\\nThe socket compatibility mode is a feature of Podman that allows to bind the Podman socket under the Docker socket path.\\n\\nOn Windows the socket compatibility mode is always enabled by default. On macOS, by using the `.pkg installer` it is active by default. But when installing with `brew`, it will not be there because it requires some admin permissions.\\n\\nThat is not an issue because you can enable it by [invoking a CLI tool](https://podman-desktop.io/docs/migrating-from-docker/using-podman-mac-helper) that will setup the compatibility mode.\\n\\nFor example if you use [`TestContainers`](https://www.testcontainers.org/) in your Java project, you can use the compatibility mode to ensure that the tool will use Podman instead of Docker.\\n\\n### CLI compatibility\\n\\nIf you have scripts relying on `docker` CLI, you can use the compatibility mode to ensure that the tool is working with Podman instead of Docker.\\n\\nIf you have the `docker` CLI installed on your computer, you can use the socket file compatibility of docker to ensure that the tool is working with Podman engine instead of Docker.\\n\\nIf you do not have the `docker` CLI installed on your computer, you can [Create a script](https://podman-desktop.io/docs/migrating-from-docker/emulating-docker-cli-with-podman) called `docker` that will call the `podman` CLI\\n\\n**_NOTE:_** creating a shell prompt alias, for example `alias docker=podman`, will not work inside scripts that you call.\\n\\n## Compose\\n\\nAs a user of Docker, you might use `docker compose` (or `docker-compose`) to run some of your applications.\\n\\nFor now Podman does not include a `Compose` support directly in the CLI with a command `podman compose`.\\n\\n`Compose` can work with the Podman socket.\\n\\nBased on the compatibility mode (see [section about Docker compatibility mode](#docker-compatibility-mode)):\\n\\n- Enabled: you can use the `compose` binary to run your applications.\\n- Disabled: you need to [export the environment variable DOCKER_HOST](https://podman-desktop.io/docs/migrating-from-docker/using-the-docker_host-environment-variable) before running compose.\\n\\nYou can now use the `compose` binary to run your applications and it will use Podman engine.\\n\\nPodman Desktop has a `compose` extension that can fetch `compose` binary if not already available on the filesystem.\\n\\nPodman Desktop UI displays the containers created by `Compose` are in the same group.\\n\\n![Compose support in the UI](img/5-things-to-know-for-a-docker-user/compose-containers-in-ui.png)\\n\\n## Kubernetes\\n\\nIt is possible to start a Kubernetes cluster with Docker.\\n\\nPodman supports directly a subset of Kubernetes resources that you can use with `.yaml` files.\\n\\nFor example if you only want to create a `Pod` resource, you can use the `Play Kubernetes YAML` button from the `Containers` list screen with your `.yaml` file. No need to install or start a Kubernetes cluster.\\n\\n![Play Kubernetes YAML](img/5-things-to-know-for-a-docker-user/play-kubernetes-yaml.png)\\n\\nIt is possible to do the counter-part. Export the definition of a container or pod to a Kubernetes resource. You can use the `Generate kube` button from the kebab menu of a given container or pod.\\n\\n![Kubernetes generate](img/5-things-to-know-for-a-docker-user/kube-generate.png)\\n\\nPodman handles pods and in the Podman Desktop UI, you can see all the pods inside a Pod section. All containers inside the pod are in the same group.\\n\\n![Pods in the UI](img/5-things-to-know-for-a-docker-user/pods-in-ui.png)\\n\\n![Containers from pod](img/5-things-to-know-for-a-docker-user/containers-from-pod.png)\\n\\nAn experimental `kind` extension is bringing the creation of full-blown Kubernetes cluster with Podman.\\n\\n## Rootless mode\\n\\nOne of the difference of Docker and Podman is the way they handle containers. Docker requires root privileges to run containers by default. Podman can run containers without root privileges by default.\\n\\nIt means that for example, starting a container with a port < 1024 will not work. You need to use a port > 1024.\\n\\nIf you still need to create containers with a port < 1024, you can change the Podman machine configuration of the Podman Machine if you are on Windows or macOS.\\n\\nThe command is `podman machine set --rootful` to enable the execution with root privileges or `podman machine set --rootful=false` to switch back to rootless mode."},{"id":"podman-desktop-release-0.12","metadata":{"permalink":"/blog/podman-desktop-release-0.12","source":"@site/blog/2023-02-15-release-0.12.md","title":"Release Notes - Podman Desktop 0.12","description":"Podman Desktop 0.12 has been released!","date":"2023-02-15T00:00:00.000Z","formattedDate":"February 15, 2023","tags":[{"label":"podman-desktop","permalink":"/blog/tags/podman-desktop"},{"label":"release","permalink":"/blog/tags/release"},{"label":"kubernetes","permalink":"/blog/tags/kubernetes"}],"readingTime":4.505,"hasTruncateMarker":true,"authors":[{"name":"Stevan Le Meur","title":"Product Manager","url":"https://github.com/slemeur","imageURL":"https://github.com/slemeur.png","key":"slemeur"}],"frontMatter":{"title":"Release Notes - Podman Desktop 0.12","description":"Podman Desktop 0.12 has been released!","slug":"podman-desktop-release-0.12","authors":["slemeur"],"tags":["podman-desktop","release","kubernetes"],"hide_table_of_contents":false},"prevItem":{"title":"5 things to know about Podman Desktop for a Docker user","permalink":"/blog/5-things-to-know-for-a-docker-user"},"nextItem":{"title":"Release Notes - Podman Desktop 0.11","permalink":"/blog/podman-desktop-release-0.11"}},"content":"import ReactPlayer from \'react-player\'\\n\\nThis release note covers Podman Desktop 0.12 release changes.\\n\\n\x3c!--Main Features--\x3e\\n\\n- **Podman Version**: Podman 4.4.1 now included in Windows and Mac installers.\\n- **Containers Configuration**: Configure port mappings for an image without exported ports.\\n- **Windows Home Support**: Podman Desktop now supports Windows Home Edition.\\n- **Start minimized**: Option to start Podman Desktop minimized to system tray.\\n- **UX and UI Improvements**: Consistent actions, placeholder for logs, unified icons and others.\\n\\nPodman Desktop 0.12 is now available. [Click here to download it](/downloads)!\\n\\n![podman-desktop-0-12-hero](img/podman-desktop-release-0.12/podman-desktop-release-0.12.png)\\n\\n\x3c!--truncate--\x3e\\n\\n---\\n\\n## Release Details\\n\\n### Update to Podman v4.4.1 [#1456](https://github.com/containers/podman-desktop/pull/1456)\\n\\nPodman Desktop 0.12 embeds [Podman 4.4.1](https://github.com/containers/podman/releases/tag/v4.4.1) in Windows and macOS installers. Make sure to upgrade to benefit from the latest Podman features and bug fixes.\\n\\n### Configuring port mappings when an image has no exported port [#1265](https://github.com/containers/podman-desktop/pull/1265)\\n\\nWith the latest update, users can now add multiple local-to-remote port mappings when starting a container from an image that has no exported ports. This feature provides users with the flexibility to specify which ports on their local machine should map to which ports on the container, even if the container does not have any exported ports by default.\\n\\n![port-mapping](https://user-images.githubusercontent.com/49404737/215112797-86dcf3f0-121a-487e-a71f-ad41e91f93da.gif)\\n\\n### Installing Podman Desktop on Windows Home Edition [#1268](https://github.com/containers/podman-desktop/pull/1268)\\n\\nPodman Desktop 0.12 offers the ability to be installed on Windows Home Edition. The mechanism uses Virtual Machine Platform detection, instead of hyper-v. WSL2 is still requires but can be installed along with the installation process.\\n\\n![install-windows-home-edition-2](https://user-images.githubusercontent.com/436777/215121429-7c757aaa-a838-43db-98a2-78ad368f407e.png)\\n\\n### Option to automatically minimize Podman Desktop on login [#1374](https://github.com/containers/podman-desktop/pull/1374)\\n\\nPodman Desktop now provides a \\"start minimized\\" option when users log in onto the laptop. This option, available from the application\'s settings, can be useful if users want to automatically launch Podman Desktop at log in, but prefer not to have the window visible on the screen. With this feature, you can ensure that Podman Desktop is up and running in the background without any interruption to your workflows.\\n\\n- Go to ** Settings > Preferences > Login: Minimize** to activate the option.\\n\\n![minimize-on-login](https://user-images.githubusercontent.com/6422176/216651424-bcf756fd-7554-4b24-a838-e3e2f798fe6e.png)\\n\\n### UI and UX Improvements\\n\\n#### Improved actions consistency [#1225](https://github.com/containers/podman-desktop/pull/1225)\\n\\nActions displayed in the list pages for Images and Containers have been reviewed and made consistent between other pages.\\n\\n![action-consistency-1](https://user-images.githubusercontent.com/19958075/214104678-2d4148d7-484e-41f9-9da9-aecee328ae2b.png)\\n\\nActions displayed in the header of the container\'s details page have been improved so that the actions are always displayed in the same order.\\n\\n![action-consistency-2](https://user-images.githubusercontent.com/19958075/214104663-64fa0601-bb79-49bf-8226-6a78a88d3622.png)\\n\\n#### Consistent status icons for Pods, Containers, Images and Volumes [#1326](https://github.com/containers/podman-desktop/pull/1326), [#1377](https://github.com/containers/podman-desktop/pull/1377), [#1459](https://github.com/containers/podman-desktop/pull/1459) and [#1245](https://github.com/containers/podman-desktop/pull/1245)\\n\\nThe status icons for Pods, Containers, Images, and Volumes have been unified and use consistent states.\\n\\n![pods-status-icon](https://user-images.githubusercontent.com/19958075/216671859-bdd8dca4-56b7-40a8-961a-dcb6e01be61e.png)\\n\\nIcons in empty screens have been updated to use the same consistent SVG icon as the status icons.\\n\\n![empty-screen-2](https://user-images.githubusercontent.com/436777/214577726-f4cfde7b-017a-499d-a2a9-e50d455ffaf0.png)\\n\\n#### Placeholder when logs for containers are being fetched [#1353](https://github.com/containers/podman-desktop/pull/1353)\\n\\nA placeholder is now displayed when logs are being fetched.\\n![placeholder-loading-logs](https://user-images.githubusercontent.com/49404737/216952505-899308ae-183e-487a-b6e5-28832a0b6452.gif)\\n\\n#### Fixed alignment in badges from the navigation sidebar [#1357](https://github.com/containers/podman-desktop/pull/1357)\\n\\nBadges in the sidebar are now aligned with the title of the section.\\n\\n![alignement-badges](https://user-images.githubusercontent.com/49404737/216336502-2a34dea3-fd41-4184-8cfe-9226d70da070.png)\\n\\n#### Enable/disable open browser action based on container state [#1395](https://github.com/containers/podman-desktop/pull/1395) and [#1397](https://github.com/containers/podman-desktop/pull/1397)\\n\\nThe action to open the browser if a port is opened in a container, is now disabled when the container is stopped. It is also hidden in the kebab menu.\\n\\n![enable-disable-container-actions](https://user-images.githubusercontent.com/49404737/217284414-1bdc820b-30a8-485e-b0f9-485229026696.gif)\\n\\n---\\n\\n## Other Notable Enhancements\\n\\n- Display extension icons [#1058](https://github.com/containers/podman-desktop/pull/1058)\\n- Solid Icons [#1267](https://github.com/containers/podman-desktop/pull/1276)\\n- Differentiate icons compared to status icons [#1268](https://github.com/containers/podman-desktop/pull/1298)\\n- Refactors window initializing [#1309](https://github.com/containers/podman-desktop/pull/1309)\\n- Change window creation background color to dark [#1310](https://github.com/containers/podman-desktop/pull/1310)\\n- Use Podman `machine inspect` to read the address to connect to the Podman machine [#1364](https://github.com/containers/podman-desktop/pull/1364)\\n- Update the editor content when the pod name changes, and disable the deploy button when empty [#1403](https://github.com/containers/podman-desktop/pull/1403)\\n- Ability to manually set color of tray icon for Windows and Linux [#1243](https://github.com/containers/podman-desktop/pull/1243)\\n- Better UI feedback when starting pods [#1242](https://github.com/containers/podman-desktop/pull/1242)\\n\\n---\\n\\n## Documentation\\n\\nThe documentation had many editorial reviews, and new content.\\n\\n- [Link to simple WSL2 installation instructions](/docs/installation/windows-install)\\n- [Refresh Windows Installation](/docs/installation/windows-install)\\n- [Revamped installation introduction](/docs/installation)\\n- [Reorganized Linux installation](/docs/installation/linux-install)\\n- [Installing Podman with OpenShift Local](/docs/podman/installing-podman-with-openshift-local-on-windows)\\n- [Installing Podman Desktop on Windows in a restricted environment](/docs/installation/windows-install/installing-podman-desktop-and-podman-in-a-restricted-environment)\\n- [Fixed documentation on `podman-mac-helper` setup](/docs/migrating-from-docker/using-podman-mac-helper)\\n\\n---\\n\\n## Notable bug fixes\\n\\n- Fixed handling path with spaces on Windows when installing Podman [#1270](https://github.com/containers/podman-desktop/pull/1270)\\n- Removed padding from SVG icons [#1253](https://github.com/containers/podman-desktop/pull/1253)\\n- Website: fixed download links for Windows and macOS binaries [#1255](https://github.com/containers/podman-desktop/pull/1255)\\n- Fixed prettier commands on Windows [#1266](https://github.com/containers/podman-desktop/pull/1267)\\n- Fixed new xterm instance spawn when clicking the logs route [#1344](https://github.com/containers/podman-desktop/pull/1344)\\n- Fixed need to wait that telemetry has been initialized before proceeding [#1373](https://github.com/containers/podman-desktop/pull/1373)\\n- Fixed new xterm instance spawn when clicking the logs route in pod details[#1393](https://github.com/containers/podman-desktop/pull/1393)\\n- Fixed stop spinner if image cannot be retrieved [#1394](https://github.com/containers/podman-desktop/pull/1394)\\n- Fixed escape command with quotes only for Windows [#1462](https://github.com/containers/podman-desktop/pull/1462)\\n- Fixed random CRC status change [#1420](https://github.com/containers/podman-desktop/pull/1420)\\n\\n---\\n\\n## Community Thank You\\n\\n\ud83c\udf89 We\u2019d like to say a big thank you to everyone who helped to make Podman Desktop 0.12 even better:\\n\\n- [Philipp Wagner](https://github.com/imphil) in [#1274 - Link to simple WSL2 installation instructions](https://github.com/containers/podman-desktop/pull/1274)\\n- [Arthur S](https://github.com/arixmkii) in [#1364 - Get podman machine socketPath from podman machine inspect first](https://github.com/containers/podman-desktop/pull/1364)\\n- [Mitch West](https://github.com/Mitch9378) in [#1428 - Fix old documentation for \'podman-mac-helper setup\'](https://github.com/containers/podman-desktop/pull/1428)\\n\\n## Final Notes\\n\\nThe complete list of issues fixed in this release is available [here](https://github.com/containers/podman-desktop/issues?q=is%3Aclosed+milestone%3A0.12.0).\\n\\nGet the latest release from the [Downloads](/downloads) section of the website and boost your development journey with Podman Desktop. Additionally, visit the [GitHub repository](https://github.com/containers/podman-desktop) and see how you can help us make Podman Desktop better."},{"id":"podman-desktop-release-0.11","metadata":{"permalink":"/blog/podman-desktop-release-0.11","source":"@site/blog/2023-01-18-release-0.11.md","title":"Release Notes - Podman Desktop 0.11","description":"Podman Desktop 0.11 has been released!","date":"2023-01-18T00:00:00.000Z","formattedDate":"January 18, 2023","tags":[{"label":"podman-desktop","permalink":"/blog/tags/podman-desktop"},{"label":"release","permalink":"/blog/tags/release"},{"label":"kubernetes","permalink":"/blog/tags/kubernetes"}],"readingTime":9.43,"hasTruncateMarker":true,"authors":[{"name":"Stevan Le Meur","title":"Product Manager","url":"https://github.com/slemeur","imageURL":"https://github.com/slemeur.png","key":"slemeur"}],"frontMatter":{"title":"Release Notes - Podman Desktop 0.11","description":"Podman Desktop 0.11 has been released!","slug":"podman-desktop-release-0.11","authors":["slemeur"],"tags":["podman-desktop","release","kubernetes"],"hide_table_of_contents":false},"prevItem":{"title":"Release Notes - Podman Desktop 0.12","permalink":"/blog/podman-desktop-release-0.12"},"nextItem":{"title":"Release Notes - Podman Desktop 0.10","permalink":"/blog/podman-desktop-release-0.10"}},"content":"import ReactPlayer from \'react-player\'\\n\\nThis release note covers Podman Desktop 0.11 release changes.\\n\\n- **Air-Gapped Installation**: New all-in-one binaries for air-gapped installation.\\n- **Feedback**: Submit feedback directly from Podman Desktop.\\n- **Docker Compatibility Mode**: Information about the Docker compatibility mode.\\n- **Proxy Setting**: Toggle on/off the proxy setting.\\n- **Deploy to Kubernetes**: Select the namespace to deploy to Kubernetes.\\n- **Registry Configuration**: Simplified registry configuration for well known registries.\\n- **UX/UI Improvements**: View pod\'s container logs, better visual feedback, configurable editor font size, and more.\\n\\nPodman Desktop 0.11 is now available. [Click here to download it](/downloads)!\\n\\n\x3c!--truncate--\x3e\\n\\n---\\n\\n## Release Details\\n\\n### Air-Gapped installation [#1104](https://github.com/containers/podman-desktop/pull/1104) [#1120](https://github.com/containers/podman-desktop/pull/1120)\\n\\nFor users who are not able to connect to the internet, a new all-in-one (airgap) binary that includes the Podman Desktop application and the Podman binaries is now available for both Mac and Windows. When initializing a new Podman machine using all-in-one binaries, it\'ll use the embedded files and not grab them from internet:\\n\\n- on Mac, it embeds the qemu FCOS binaries.\\n- on Windows, it embeds the WSL binary.\\n\\nTo differentiate the air-gapped binaries from the regular ones, you can check the artifactname, they\'re containing \'airgap\' and are bigger.\\nPlease note, that those binaries are available only on releases and not the pre-releases.\\n\\nThere is also an optional way to provide a custom Podman machine image in the create machine form. By providing the path to the image you want, Podman Desktop will create a machine with that image. Leaving the field empty will use the default image (the one included in the binary).\\n\\n\\n\\n### Feedback within Podman Desktop [#1078](https://github.com/containers/podman-desktop/pull/1078)\\n\\nSubmitting feedback on Podman Desktop is getting easier as it is possible directly within the tool. This will help to get more information about the issues you are facing and will help us to improve the tool.\\n\\n\\n\\nPlease feel free to submit any feedback you have, we are looking forward to hearing from you!\\n\\n### Docker compatibility mode [#1047](https://github.com/containers/podman-desktop/pull/1047)\\n\\nThe Docker compatibility mode is a feature that allows to use Podman as a drop-in replacement for Docker. It relies on the Docker socket helper provided with Podman and automatically handle the local setup of Podman path to the Docker socket. Tools like [Testcontainers](https://www.testcontainers.org/) or others are relying on this to communicate to the container engine.\\n\\nIn this new version of Podman Desktop, we are now providing information to the user about the status of this compatibility mode directly on the dashboard page. The way it works is the following:\\n\\n- When Docker is running: the socket is pointing to Docker.\\n- When Podman is starting and Docker is not running: the docker API socket will use Podman.\\n\\nIn case the compatibility mode is not activated, new documentation on how to activate it and how to easily switch between Docker and Podman is available here: [https://podman-desktop.io/docs/migrating-from-docker](https://podman-desktop.io/docs/migrating-from-docker).\\n\\nThis is a warning displayed for Windows users:\\n![windows-docker-compatibility](https://user-images.githubusercontent.com/436777/209305744-9056addd-f122-4f75-9e03-ad27a0109375.png)\\n\\nThis is the warning for Mac users:\\n![mac-docker-compatibility](https://user-images.githubusercontent.com/6422176/207964861-a9c1f72c-89d6-4816-beab-397af4125620.png)\\n\\n### Allow to toggle on/off the proxy setting [#983](https://github.com/containers/podman-desktop/pull/983)\\n\\nIn some context, users need the ability to disable and re-enable the proxy configuration very quickly, without having to entirely reconfigure it. This is now possible from the Podman Desktop settings page, where a toggle to enable/disable the proxy configuration has been added.\\n\\n\\n\\nNote: extensions can read this information and then update the proxy configuration.\\n\\n### Namespace selection for deploy to Kubernetes [#1008](https://github.com/containers/podman-desktop/pull/1008)\\n\\nA new dropdown menu has been added to the deploy to Kubernetes screen to allow selecting the namespace to deploy to. Defaults to defaultnamespace, if unable to get any from kube_client module.\\n\\nIf the user have set `kubectl config set-context --current --namespace=NAMESPACE` it honors that as the chosen value.\\n\\n![deploy-kubernetes-namespace](https://user-images.githubusercontent.com/7339809/206688886-095e4f15-42ae-4a0a-b1c6-ae4b547fcdfb.gif)\\n\\n### Configure Podman binary path [#941](https://github.com/containers/podman-desktop/pull/941)\\n\\nUsers might use a custom path to the podman binary. An option within settings (Settings -> Preferences) to allow providing an additional path to Podman binary has been added.\\nThis is useful for users who have installed Podman using a package manager and want to use the binary provided by the package manager.\\nSee: [Unable to set custom binary path for Podman on macOS](/docs/troubleshooting/troubleshooting-podman-on-macos#unable-to-set-custom-binary-path-for-podman-on-macos)\\n![custom-path](https://user-images.githubusercontent.com/6422176/204832063-5858065a-2fc3-49de-8d23-3b99b7d10dbf.png)\\n\\n### Provide pre-defined registries [#1201](https://github.com/containers/podman-desktop/pull/1201)\\n\\nThe experience of configuring a registry is getting simplified for the most popular ones. The user will be able to select a registry from a pre-defined list and will only have to provide the username and password. The following registries will be pre-defined:\\n\\n- Dockerhub\\n- Red Hat Quay\\n- GitHub\\n- IBM Container Registry\\n- Google Container Registry\\n\\n\\n\\n### UI/UX Improvements\\n\\n#### View Pods logs [#1122](https://github.com/containers/podman-desktop/pull/1122)\\n\\nThe pods details view provides the ability to view the logs of each containers that might be running in a pod. Moreover, as it can also be hard to scan and identify which container is producing which output, we appended the container name at the beginning of each output and differentiate each container with a different color.\\n\\n![pods-logs](https://user-images.githubusercontent.com/6422176/211024673-eee9bad8-1b0c-4446-b8d1-97a226282c4d.png)\\n\\n#### Improved feedback when clicking on container list action icons [#1150](https://github.com/containers/podman-desktop/pull/1150) [#1161](https://github.com/containers/podman-desktop/pull/1161)\\n\\nWhen starting/stopping or deleting a container, a spinner is now displayed. In case of error, a message indicating that the action failed will also be better indicated.\\n\\n\\n\\nFor containers that exit immediately or short-lived containers, the feedback is also improved and include report of error now provide a better feedback to the user [#1161](https://github.com/containers/podman-desktop/pull/1161).\\n\\n\\n\\n#### Allows to change the default font size for the editor [#1160](https://github.com/containers/podman-desktop/pull/1160)\\n\\nAn editor is used in several screens of Podman Desktop, from the inspect screen to container\'s outputs and Kubernetes YAML. The default font size is 10 pixels. It\'s now possible to adjust the font size to the one the one you prefer. This setting is persisted and will be used for all the editors of Podman Desktop and available from the preferences page (Settings -> Preferences).\\n\\n\\n\\n#### Keep expanded state of pods when refreshing containers [#1042](https://github.com/containers/podman-desktop/pull/1042)\\n\\nWhen switching from different screens of the application or simply refreshing the list of containers, the expanded state of each item in the list is now persisted and will be properly restored.\\n\\n\\n\\n#### Click on the Pod name redirects to the Pod details page [#1159](https://github.com/containers/podman-desktop/pull/1159)\\n\\nThe list of containers also displays pods, now clicking on the pod name directly redirects to the Pod details page.\\n\\n\\n\\n#### Improved styles of buttons for actions [#984](https://github.com/containers/podman-desktop/pull/984)\\n\\nThe style of the buttons for actions on item in the list of in details pages have been improved. The background has been removed, but to make the hover state more visible, the \\"hover\\" circle is visible and the icon\'s color is also changing.\\n\\nOn lists:\\n![list-actions](https://user-images.githubusercontent.com/6422176/205979121-b49a0ddf-03bb-4a4d-8d12-bc8d0bd52387.png)\\n\\nOn details pages:\\n![details-actions](https://user-images.githubusercontent.com/6422176/205979123-ea420b17-e834-4029-82eb-22949889eee9.png)\\n\\n#### Improved alignments in pages with lists [#1182](https://github.com/containers/podman-desktop/pull/1182)\\n\\nThe alignment of the items in the list of containers and pods have been improved. The header of each columns are now aligned with the text. and the actions icons are now aligned with the top of the text.\\n\\n![list-actions](https://user-images.githubusercontent.com/19958075/212712580-096fd090-0beb-40a4-8dc6-b3fdc5e81e35.png)\\n\\n---\\n\\n## Other Notable Enhancements\\n\\n- Statistics area in container details are always shown. ([#1131](https://github.com/containers/podman-desktop/pull/1131))\\n- Add more descriptive wording and more information to extensions. ([#985](https://github.com/containers/podman-desktop/pull/985))\\n- Allow to install on-the fly Podman Desktop extensions using an OCI image. ([#1187](https://github.com/containers/podman-desktop/pull/1187))\\n- Display correctly non-multiplexed stream in logs (when using non interactive mode). ([#1197](https://github.com/containers/podman-desktop/pull/1197))\\n- Font changed from white to gray for non-name sections (creation date, size). ([#1206](https://github.com/containers/podman-desktop/pull/1206))\\n- Add Help/about menu for macOS/Windows/Linux. ([#1207](https://github.com/containers/podman-desktop/pull/1207))\\n\\n---\\n\\n## Documentation\\n\\nComing with this new version of Podman Desktop, the documentation has been getting attention (with number of editorial reviews) and new content have been added.\\n\\nContent for helping users to migrate from Docker to Podman has been added:\\n\\n- [Using the `podman-mac-helper` tool to migrate from Docker to Podman on macOS](https://github.com/containers/podman-desktop/pull/1088)\\n- [better identify podman-mac-helper verification steps](https://github.com/containers/podman-desktop/pull/1129)\\n- [Emulating Docker CLI using Podman to migrate from Docker to Podman](https://github.com/containers/podman-desktop/pull/1143)\\n- [Migrating from Docker section](https://github.com/containers/podman-desktop/pull/1146)\\n- [Verifying that your tools are using Podman](https://github.com/containers/podman-desktop/pull/1152)\\n- [Importing saved containers](https://github.com/containers/podman-desktop/pull/1144)\\n\\nSeveral of other improvements have been made to the documentation and the website:\\n\\n- [Troubleshooting for Apple Silicon and brew x86_64 installs](https://github.com/containers/podman-desktop/pull/962)\\n- [Change text of custom binary location, add docs](https://github.com/containers/podman-desktop/pull/972)\\n- [Silent install option for windows](https://github.com/containers/podman-desktop/pull/974)\\n- [Upgrade to vite v4 and rollup v3](https://github.com/containers/podman-desktop/pull/1079)\\n- [Refreshing documentation on installing on Linux](https://github.com/containers/podman-desktop/pull/1118)\\n- [Identify the shell sessions in Installing on Linux](https://github.com/containers/podman-desktop/pull/1130)\\n- [Website: the linux binary is not a source, it should be promoted as a binary](https://github.com/containers/podman-desktop/pull/1133)\\n- [Introducing tabs for operatings systems and container engines](https://github.com/containers/podman-desktop/pull/1162)\\n- [website: In the landing page, update plugins and container engines lists](https://github.com/containers/podman-desktop/pull/1165)\\n- [Document where code is located within Podman Desktop](https://github.com/containers/podman-desktop/pull/1163)\\n- [(extension-api): Documentation on how to write an extension and use the api](https://github.com/containers/podman-desktop/pull/1172)\\n\\n---\\n\\n## Notable bug fixes\\n\\n- Update to v0.3.2 Docker Desktop API for extensions - [#1070](https://github.com/containers/podman-desktop/pull/1070)\\n- Updated link to the Matrix room - [#1076](https://github.com/containers/podman-desktop/pull/1076)\\n- Report error when container name already exists - [#1142](https://github.com/containers/podman-desktop/pull/1142)\\n- Fixed connectivity to the Podman machine when the generated socket length is greater than 104 characters in MacOS - [#1145](https://github.com/containers/podman-desktop/pull/1145)\\n- Do not use long calls for external clients - [#1151](https://github.com/containers/podman-desktop/pull/1151)\\n- Invalid name/tag for images with registries using a different port - [#1127](https://github.com/containers/podman-desktop/pull/1127)\\n- Invalid badge count for images when two images have the same tag - [#1124](https://github.com/containers/podman-desktop/pull/1124)\\n- Fixed detection of WSL2 - [#981](https://github.com/containers/podman-desktop/pull/981)\\n- Handle invalid kubeconfig files instead of crashing - [#953](https://github.com/containers/podman-desktop/pull/953)\\n- Removed redundant actions from details pages - [#1200](https://github.com/containers/podman-desktop/pull/1200)\\n- Fixed registry URL not aligned with header - [#1205](https://github.com/containers/podman-desktop/pull/1205)\\n- Moved SVGs to reusable components - [#1211](https://github.com/containers/podman-desktop/pull/1211)\\n\\n**Extensions API has also been improved in this new release:**\\n\\n- (extension-api): Allows to register a factory for kubernetes connection objects (like for container connections) - [#1040](https://github.com/containers/podman-desktop/pull/1040)\\n- (extension-api): List or inspect containers, be notified on events - [#1041](https://github.com/containers/podman-desktop/pull/1041)\\n- (extension-api): Allows to get provider notification - [#1045](https://github.com/containers/podman-desktop/pull/1045)\\n- (dd-extension-api): Implement toast API - [#1154](https://github.com/containers/podman-desktop/pull/1154)\\n- (extension-api): Moved extension properties to preferences - [#948](https://github.com/containers/podman-desktop/pull/948)\\n- (dd-extension-api): Added open dev console on dd webview in development mode - [#1071](https://github.com/containers/podman-desktop/pull/1071)\\n- (extension-api): Added notes on extension and frameworks/tooling of Podman Desktop - [#1166](https://github.com/containers/podman-desktop/pull/1166)\\n- (extension-api): Documentation on how to write an extension and use the api - [#1172](https://github.com/containers/podman-desktop/pull/1172)\\n- (dd-extension-api): DD extensions should see only minimal information on containers - [#1191](https://github.com/containers/podman-desktop/pull/1191)\\n\\n---\\n\\n## Community Thank You\\n\\n\ud83c\udf89 We\u2019d like to say a big thank you to everyone who helped to make Podman Desktop 0.11 even better:\\n\\n- [Emmanuel Bernard](https://github.com/emmanuelbernard) in [#962 - Troubleshooting for Apple Silicon](https://github.com/containers/podman-desktop/pull/962)\\n- [Michael Prankl](https://github.com/eidottermihi) in [#974 - Silent install option for windows](https://github.com/containers/podman-desktop/pull/974)\\n- [Endre Lervik](https://github.com/elervik) in [#1008 - Namespace selection for deploy to kubernetes](https://github.com/containers/podman-desktop/pull/1008)\\n- [Evan FP](https://github.com/evanfpearson) in [#1145 - fixed socket path length error](https://github.com/containers/podman-desktop/pull/1145)\\n- [Lokesh Mandvekar](https://github.com/lsm5) in [#956 - add repository key to package.json](https://github.com/containers/podman-desktop/pull/956)\\n- [Jean Fran\xe7ois Maury](https://github.com/jeffmaury) in [#1194 - Cannot create Kind cluster on Windows](https://github.com/containers/podman-desktop/pull/1194)\\n\\n## Final Notes\\n\\nThe complete list of issues fixed in this release is available [here](https://github.com/containers/podman-desktop/issues?q=is%3Aclosed+milestone%3A0.11.0).\\n\\nGet the latest release from the [Downloads](/downloads) section of the website and boost your development journey with Podman Desktop. Additionally, visit the [GitHub repository](https://github.com/containers/podman-desktop) and see how you can help us make Podman Desktop better."},{"id":"podman-desktop-release-0.10","metadata":{"permalink":"/blog/podman-desktop-release-0.10","source":"@site/blog/2022-12-01-release-0.10-blog.md","title":"Release Notes - Podman Desktop 0.10","description":"Podman Desktop 0.10 has been released! New Create Container Wizard, improved Kubernetes workflows, revamped registries configuration, and more!","date":"2022-12-01T00:00:00.000Z","formattedDate":"December 1, 2022","tags":[{"label":"podman-desktop","permalink":"/blog/tags/podman-desktop"},{"label":"release","permalink":"/blog/tags/release"},{"label":"kubernetes","permalink":"/blog/tags/kubernetes"}],"readingTime":4.115,"hasTruncateMarker":true,"authors":[{"name":"Dev Kumar","title":"Technical PMM Intern","url":"https://github.com/deekay2310","imageURL":"https://github.com/deekay2310.png","key":"deekay2310"}],"frontMatter":{"title":"Release Notes - Podman Desktop 0.10","description":"Podman Desktop 0.10 has been released! New Create Container Wizard, improved Kubernetes workflows, revamped registries configuration, and more!","slug":"podman-desktop-release-0.10","authors":["deekay2310"],"tags":["podman-desktop","release","kubernetes"],"hide_table_of_contents":false},"prevItem":{"title":"Release Notes - Podman Desktop 0.11","permalink":"/blog/podman-desktop-release-0.11"},"nextItem":{"title":"Build & run Podman Desktop in a DevContainer","permalink":"/blog/develop-using-devcontainer"}},"content":"This release note covers Podman Desktop 0.10 release changes.\\n\\n- **Containers Configuration**: Container creation wizzard allowing to define environment variables, networking and more configuration options.\\n- **Kubernetes Improvements**: Play Kubernetes YAML, custom Kubeconfig path support, reload of kube context.\\n- **Registries Configuration**: Revamped registries configuration UI.\\n- **Podman Version**: Podman 4.3.1 now included in Windows and Mac installers.\\n- **UX/UI Improvements**: Improved lists, better contrast, and more.\\n\\nPodman Desktop 0.10 is now available. [Click here to download it](/downloads)!\\n\\n\x3c!--truncate--\x3e\\n\\n---\\n\\n## Release Details\\n\\n### New configuration wizzard to create containers ([#773](https://github.com/containers/podman-desktop/pull/773))\\n\\nUntil now, we could only specify port binding when building images to start containers. The create container wizzard now includes several options enabling configuring volumes, environment variables, restart policy and settings on networking and security. It is also possible to reuse an existing (and already configured) a network when creating containers.\\n\\n![new container creation wizard](img/podman-desktop-release-0.10/new_container_creation_wizard.gif)\\n\\n### Kubernetes Capabilities Improvements\\n\\n**Custom Kubeconfig file path ([#780](https://github.com/containers/podman-desktop/pull/780))**\\n\\nKubeconfig path location is now configurable from ** Settings > Preferences > Kubernetes: Kubeconfig** and can be set to a custom path. By default, Podman Desktop use the path `$HOME/.kube/config` for the Kubeconfig file.\\n\\n![custom kubeconfig file path](img/podman-desktop-release-0.10/custom-kubeconfig.png)\\n\\n**Play Kubernetes YAML from the Pods list ([#739](https://github.com/containers/podman-desktop/pull/739))**\\n\\nPodman Desktop enables to play existing Kubernetes YAML files. This is now available from `Play Kubernetes YAML` button added to the Pods list, in addition to the Containers list.\\n\\n![play k8s yaml](img/podman-desktop-release-0.10/play_k8s_yaml.gif)\\n\\n**Kube context automatically reloaded when updated ([#813](https://github.com/containers/podman-desktop/pull/813))**\\n\\nAny change to the kube context will now be detected by Podman Desktop in its running state. The system tray, allowing to select which Kubernetes environment to work with, will now reload the kube context without restarting Podman Desktop.\\n\\n### Revamped Container Registries UI ([#446](https://github.com/containers/podman-desktop/issues/446))\\n\\nThe registries configuration UI has been revamped. Instead of using tiles for displaying the registries, now it uses a list where each registry can be added or edited directly in the list. The kebab menu provides options to edit or remove a registry from the list.\\n\\n![registries](img/podman-desktop-release-0.10/registries.png)\\n\\n### Update to Podman 4.3.1 ([#913](https://github.com/containers/podman-desktop/issues/913))\\n\\nPodman Desktop 0.10 is now embedding [Podman 4.3.1](https://github.com/containers/podman/releases/tag/v4.3.1) in Windows and macOS installers.\\n\\n### UI/UX Improvements\\n\\n**Improved lists UX ([#877](https://github.com/containers/podman-desktop/pull/877))**\\n\\nTo reduce the width used in the lists when displaying all the icons, main actions icons are now always displayed (before it was on hover) and the secondary actions are displayed in a kebab menu. For example Start/Stop and delete are primary actions while open the browser, inspect, generate kube yaml, etc. are secondary options.\\n\\n![kebab menu](img/podman-desktop-release-0.10/kebab-menu.png)\\n\\n**Delay appearance of text in navbar ([#767](https://github.com/containers/podman-desktop/pull/767))**\\n\\nWhen minimizing or expanding the navbar, the text was overlapping for a few second the page. Now it\'s displayed with a fading animation.\\n\\n**Selected state: better text color contrast ([#802](https://github.com/containers/podman-desktop/pull/802))**\\n\\nIn the `Images` page, on hover for both the image and the name column, the text contrast has been increased for better visibility: violet indicates that you have selected it.\\n\\n![text color when hover](img/podman-desktop-release-0.10/text-color.gif)\\n\\n**On Linux and Windows, the menu bar is now hidden by default ([#668](https://github.com/containers/podman-desktop/pull/668))**\\n\\nWith this change, the menu bar looks more integrated to the Operating System. The menu can appear if you hit the `Alt` key. Thanks to [Dylan M. Taylor](https://github.com/dylanmtaylor) for contributing to fix this.\\n\\n**Exit when clicking on the close icon of the dashboard on Linux ([#671](https://github.com/containers/podman-desktop/pull/671))**\\n\\nFor most users on Linux, there is no tray icon support. In this situation, when closed, Podman Desktop continues to run in background. [Dylan M. Taylor](https://github.com/dylanmtaylor) added a property to exit the app by default when clicking on the close icon. For people having tray icon support or with the desire of a different behavior, it is possible to disable it from the Settings.\\n\\n---\\n\\n## Other Notable Enhancements\\n\\n- Rename `Started` into `Age` in Containers list.([#878](https://github.com/containers/podman-desktop/pull/878))\\n- Added domain validation when adding a registry. ([#838](https://github.com/containers/podman-desktop/pull/838))\\n- Provided a consistent behavior with Podman CLI, `podman-machine-default` is now the default name when creating a Podman machine from Podman Desktop. ([#775](https://github.com/containers/podman-desktop/pull/775))\\n\\n---\\n\\n## Notable bug fixes\\n\\n- Fixed error handling when pulling images of Desktop Extensions. ([#782](https://github.com/containers/podman-desktop/pull/782))\\n- Fixed use of the full height of the screen when displaying log in the details of a container. ([#946](https://github.com/containers/podman-desktop/discussions/946))\\n- Fixed First start of Podman Desktop on flatpak was not seeing the podman engine ([#860](https://github.com/containers/podman-desktop/pull/860))\\n\\n## Community Thank You\\n\\n\ud83c\udf89 We\u2019d like to say a big thank you to everyone who helped to make Podman Desktop 0.10 even better:\\n\\n- [Dylan M. Taylor](https://github.com/dylanmtaylor) in [#671](https://github.com/containers/podman-desktop/pull/671)\\n- [Fionn Kelleher](https://github.com/osslate) in [#713](https://github.com/containers/podman-desktop/pull/713)\\n- [Rostislav Svoboda](https://github.com/rsvoboda) in [#737](https://github.com/containers/podman-desktop/pull/737)\\n- [Denis Shemanaev](https://github.com/shemanaev) in [#783](https://github.com/containers/podman-desktop/pull/783)\\n- [Fabrice Flore-Th\xe9bault](https://github.com/themr0c) in [#856](https://github.com/containers/podman-desktop/pull/856)\\n- [Kevin](https://github.com/KevinAtSesam) in [#864](https://github.com/containers/podman-desktop/pull/864)\\n- [@sfrunza13](https://github.com/sfrunza13) in [#872](https://github.com/containers/podman-desktop/pull/872)\\n- [Anjan Nath](https://github.com/anjannath) in [#918](https://github.com/containers/podman-desktop/pull/918)\\n\\n## Final Notes\\n\\nThe complete list of issues fixed in this release is available [here](https://github.com/containers/podman-desktop/issues?q=is%3Aclosed+milestone%3A0.10.0).\\n\\nGet the latest release from the [Downloads](/downloads) section of the website and boost your development journey with Podman Desktop. Additionally, visit the [GitHub repository](https://github.com/containers/podman-desktop) and see how you can help us make Podman Desktop better."},{"id":"develop-using-devcontainer","metadata":{"permalink":"/blog/develop-using-devcontainer","source":"@site/blog/2022-11-17-develop-podman-using-codespaces.md","title":"Build & run Podman Desktop in a DevContainer","description":"Develop Podman Desktop using a DevContainer locally or using GitHub Codespaces.","date":"2022-11-17T00:00:00.000Z","formattedDate":"November 17, 2022","tags":[{"label":"podman-desktop","permalink":"/blog/tags/podman-desktop"},{"label":"devcontainer","permalink":"/blog/tags/devcontainer"},{"label":"codespaces","permalink":"/blog/tags/codespaces"}],"readingTime":6.985,"hasTruncateMarker":true,"authors":[{"name":"Florent Benoit","title":"Maintainer of Podman Desktop","url":"https://github.com/benoitf","imageURL":"https://github.com/benoitf.png","key":"benoitf"}],"frontMatter":{"title":"Build & run Podman Desktop in a DevContainer","description":"Develop Podman Desktop using a DevContainer locally or using GitHub Codespaces.","slug":"develop-using-devcontainer","authors":["benoitf"],"tags":["podman-desktop","devcontainer","codespaces"],"hide_table_of_contents":false},"prevItem":{"title":"Release Notes - Podman Desktop 0.10","permalink":"/blog/podman-desktop-release-0.10"}},"content":"GitHub [announced last week](https://github.blog/changelog/2022-11-09-codespaces-for-free-and-pro-accounts/) that Codespaces is available for everyone and it includes free minutes.\\n\\nLet see how we can use a [Development Container](https://containers.dev/) having all the tools to build and run Podman Desktop. The Development Container works locally using Visual Studio Code but in this blog post we will see how it works directly with a simple click from GitHub.\\n\\nThe challenges are to run a desktop tool (Podman Desktop) and running a container engine (Podman) inside this Development Container without using too many memory !\\n\\n\x3c!--truncate--\x3e\\n\\n## Defining image of the container\\n\\nThe first thing is in the choice of the image for the container. It is possible to pick-up a default image and add some features but there is no existing feature for Podman at https://github.com/devcontainers/features/tree/main/src and most of the features are expecting to run on top of Debian/Ubuntu\\n\\nIf you are not interested in how to setup the image, jump to the [next section](#configure-the-devcontainer-using-devcontainerjson).\\n\\nPodman binaries are available quickly after the releases for Fedora. I decided then to use `Fedora 37` as the base image.\\n\\nLet start the Containerfile using:\\n\\n```docker\\nFROM quay.io/fedora/fedora:37\\n```\\n\\nThen I install Node.js 16 from official nodejs.org repository. It\'s easier to switch to the version that we need.\\n\\n```docker\\n# install Node.js + yarn\\nENV NODE_VERSION 16.18.1\\nRUN curl -SLO \\"https://nodejs.org/dist/v$NODE_VERSION/node-v$NODE_VERSION-linux-x64.tar.gz\\" && \\\\\\n tar -xzf \\"node-v$NODE_VERSION-linux-x64.tar.gz\\" -C /usr/local --strip-components=1 && \\\\\\n rm \\"node-v$NODE_VERSION-linux-x64.tar.gz\\" && \\\\\\n npm install -g yarn\\n```\\n\\nNow, all system dependencies used to run an Electron application needs to be installed.\\n\\nPodman is also installed so we can run some containers inside this container.\\n\\nAnd of course, we need to install VNC (I choose [tigervnc](https://tigervnc.org/)) with a light Window Manager ([fluxbox](http://fluxbox.org/)).\\n\\nTo connect to the display of the container, we need to expose VNC over HTML/websocket using [noVNC](https://novnc.com/)\\n\\nxterm is installed to start a terminal from the VNC side.\\n\\n```docker\\nRUN dnf -y update && \\\\\\n yum -y reinstall shadow-utils && \\\\\\n yum install -y git \\\\\\n # dependencies for Podman Desktop\\n nss \\\\\\n atk \\\\\\n at-spi2-atk \\\\\\n cups-libs \\\\\\n gtk3 \\\\\\n # for remote Display\\n fluxbox \\\\\\n tigervnc-server \\\\\\n xorg-x11-fonts-Type1 \\\\\\n novnc \\\\\\n supervisor \\\\\\n xdpyinfo \\\\\\n # for podman\\n podman \\\\\\n fuse-overlayfs --exclude container-selinux \\\\\\n xterm && \\\\\\n rm -rf /var/cache /var/log/dnf* /var/log/yum.*\\n```\\n\\nSupervisord setup the launch of the VNC server and the Window manager\\n\\n```docker\\nCOPY supervisord.conf /etc/supervisord.conf\\n```\\n\\nA custom theme for fluxbox:\\n\\n```docker\\nCOPY fluxbox /usr/share/fluxbox/init\\n```\\n\\nThen we need a special configuration to allow to have Podman working inside the container\\n\\nWe add the `podman-desktop` user with correct range on subuid and subgid when running containers. I used the [tutorial](https://github.com/containers/podman/blob/main/docs/tutorials/rootless_tutorial.md#etcsubuid-and-etcsubgid-configuration).\\n\\n```docker\\nRUN useradd -u 1000 podman-desktop && echo podman-desktop:10000:5000 > /etc/subuid && echo podman-desktop:10000:5000 > /etc/subgid\\n```\\n\\nThen use some default configuration files\\n\\n```docker\\n# initialize conf files\\nADD https://raw.githubusercontent.com/containers/libpod/master/contrib/podmanimage/stable/containers.conf /etc/containers/containers.conf\\nADD https://raw.githubusercontent.com/containers/libpod/master/contrib/podmanimage/stable/podman-containers.conf /home/podman-desktop/.config/containers/containers.conf\\n```\\n\\nand make sure that all permissions are correct following the guide [https://www.redhat.com/sysadmin/podman-inside-container](https://www.redhat.com/sysadmin/podman-inside-container)\\n\\n```docker\\n# set permissions\\nRUN chown podman-desktop:podman-desktop -R /home/podman-desktop && chmod 644 /etc/containers/containers.conf && \\\\\\n mkdir -p /var/lib/shared/overlay-images /var/lib/shared/overlay-layers /var/lib/shared/vfs-images /var/lib/shared/vfs-layers; touch /var/lib/shared/overlay-images/images.lock; touch /var/lib/shared/overlay-layers/layers.lock; touch /var/lib/shared/vfs-images/images.lock; touch /var/lib/shared/vfs-layers/layers.lock && \\\\\\n mkdir -p /run/user/1000 && chown podman-desktop:podman-desktop /run/user/1000\\n```\\n\\nplus define an empty user namespace.\\n\\n```docker\\nENV _CONTAINERS_USERNS_CONFIGURED=\\"\\"\\n```\\n\\nMake sure Podman will create the socket in an expected directory:\\n\\n```docker\\n# socket path for podman\\nENV XDG_RUNTIME_DIR=/run/user/1000\\n```\\n\\nOK ! we have a custom Containerfile providing all the tools to build and run Podman Desktop (using VNC for the display), run Podman and run Electron.\\n\\nThe current file is available at https://github.com/containers/podman-desktop/blob/main/.devcontainer/.parent/Containerfile\\n\\nLet\'s configure the DevContainer.\\n\\n## Configure the DevContainer using devcontainer.json\\n\\nDevContainer definition is stored at `.devcontainer/devcontainer.json` file.\\n\\nWe need to reuse the image of the previous step. For that let\'s use the build section of the `devcontainer.json` file.\\n\\n```json\\n\\"build\\": {\\n \\"dockerfile\\": \\"Containerfile\\"\\n},\\n```\\n\\nIn order to avoid to redo all the build steps each time we open a workspace using this dev container, we published the image to quay.io at [quay.io/podman-desktop/devcontainer-parent:next\\n](https://quay.io/repository/podman-desktop/devcontainer-parent?tab=tags&tag=next). This parent image is not changing much so it\'s better to use is as a parent one.\\n\\nInside `.devcontainer` directory there is a `.parent` directory with everything related to the parent image.\\n\\nAnd in the `.devcontainer/Containerfile` file we reference this image\\n\\n```docker\\nFROM quay.io/podman-desktop/devcontainer-parent:next\\n```\\n\\nBy default, we will be `root` in the container and this is probably not what we expect. Let\'s change that.\\n\\n```json\\n\\"containerUser\\": \\"podman-desktop\\"\\n```\\n\\nSome Visual Studio Code extensions are nice to use and we can add them\\n\\n```json\\n \\"extensions\\": [\\"svelte.svelte-vscode\\", \\"bradlc.vscode-tailwindcss\\"]\\n```\\n\\nThen here is the tricky part, how to run our container allowing to run again inside the container some containers with podman.\\n\\nWe specify the arguments to make it possible. It\'s possible to use `--privileged` flag but I prefer to list the subset of permissions.\\nUsing `--privileged` we don\'t really know what are the privilege that are required while specifying all of them, people are aware of what is granted/denied.\\n\\n```json\\n\\"runArgs\\": [\\n \\"--cap-add=sys_admin\\",\\n \\"--security-opt\\",\\n \\"seccomp=unconfined\\",\\n \\"--device\\",\\n \\"/dev/fuse\\",\\n \\"--security-opt\\",\\n \\"label=disable\\",\\n \\"--security-opt\\",\\n \\"apparmor=unconfined\\"\\n ],\\n```\\n\\nSource code of Podman Desktop needs to be editable within the DevContainer so it needs to be mounted.\\n\\n```json\\n\\"workspaceMount\\": \\"source=${localWorkspaceFolder},target=/workspace,type=bind\\",\\n\\"workspaceFolder\\": \\"/workspace\\",\\n```\\n\\nThen we need a command to build Podman Desktop.\\n\\nFor that, we use `onCreateCommand` hook with a custom command\\n\\n```json\\n\\"onCreateCommand\\": \\"${containerWorkspaceFolder}/.devcontainer/onCreateCommand.sh\\",\\n```\\n\\nand in the `.devcontainer` folder the `onCreateCommand.sh` script is the following\\n\\n```shell\\n#!/bin/sh\\nyarn\\n\\nMODE=production yarn run build && yarn run electron-builder build --linux --dir --config .electron-builder.config.cjs\\n```\\n\\nTwo instructions:\\n\\n1. Fetch all Node.js dependencies.\\n2. build Podman Desktop in the `dist` folder using `Linux` as target Operating System.\\n\\nAfter the start of the container, how to launch Podman Desktop, the website and VNC, etc ?\\n\\nJust use `postStartCommand` hook.\\n\\n```json\\n\\"postStartCommand\\": \\"${containerWorkspaceFolder}/.devcontainer/postStartCommand.sh\\",\\n```\\n\\nand in the `.devcontainer` folder the `postStartCommand.sh` script is the following:\\n\\n```shell\\n#!/bin/sh\\n\\n# Start all services\\n/usr/bin/supervisord -c /etc/supervisord.conf &\\n\\n# wait X server to be ready or after 2mn exit\\necho \\"Waiting for X server to be ready\\"\\ntimeout 120 bash -c \'until xdpyinfo -display :0 &> /dev/null; do printf \\".\\"; sleep 1; done\'\\n\\n# launch podman desktop\\necho \\"Launching Podman Desktop\\"\\ncd dist/linux-unpacked/&& ./podman-desktop &\\n\\n# Launch the 9000 redirect after 20 seconds\\nsleep 20\\nwebsockify --web=/usr/share/novnc localhost:9000 localhost:5900 &\\n\\n# launch the website rendering\\necho \\"Launching Website\\"\\ncd website && yarn start\\n```\\n\\nIt starts VNC and noVNC, start precompiled Podman Desktop and start the documentation rendering.\\n\\nIt is not launching the Watch mode/development mode of Podman Desktop as it requires a container having more than 8GB of memory.\\n\\nPicking up a larger instance with for example 16GB, it\'s possible to use development mode.\\n\\nOf course, to make VNC happy, we need to specify the `DISPLAY` environment variable.\\n\\n```json\\n\\"remoteEnv\\": {\\n \\"DISPLAY\\": \\":0\\"\\n}\\n```\\n\\nWhen the DevContainer is fully available, we want to have a way to quickly open the `Website rendering URL` and `noVNC`\\n\\nLet\'s tweak the `devcontainer.json` file by adding the `portsAttributes` section\\n\\n```json\\n\\"portsAttributes\\": {\\n \\"9000\\": {\\n \\"label\\": \\"vnc\\",\\n \\"onAutoForward\\": \\"openPreview\\"\\n },\\n \\"3000\\": {\\n \\"label\\": \\"website\\"\\n }\\n}\\n```\\n\\nAfter all post-creation steps, the `Preview` browser inside the VS Code editor will open a window to VNC. And another port (`3000`) is flagged for the website.\\n\\n## Using the DevContainer.json on Github Codespace\\n\\nAs a user, opening a workspace with all what we configured is done using a single click.\\n\\nGo to https://github.com/containers/podman-desktop then click on the `< > Code` dropdown and click on `Create codespace on main` button.\\n\\n![Open Codespace](img/develop-podman-using-codespaces/codespaces-click-repository.png)\\n\\nOnce you click on the button, the codespace is setting up:\\n\\n![Preparing Codespace](img/develop-podman-using-codespaces/codespaces-preparing-codespace.png)\\n\\nAfter few minutes, as there is not yet [prebuilt codespaces](https://docs.github.com/en/codespaces/prebuilding-your-codespaces/about-github-codespaces-prebuilds), the codespace is opening.\\n\\nThe simple Browser displays the noVNC window:\\n![Opening Codespace](img/develop-podman-using-codespaces/codespaces-open-novnc.png)\\n\\nClick on the connect button. Then on the terminal you can enter `podman run quay.io/podman/hello` and the container is detected in Podman Desktop.\\n![Testing Codespace](img/develop-podman-using-codespaces/codespaces-testing-podman-desktop.png)\\n\\nIt\'s also possible using the port widget to get on `3000` port by clicking on the world icon a preview of the website in another tab. Changing source code of the website will refresh the content of the window.\\n\\nDepending on the usecase, it\'s also possible to open documentation in the preview browser.\\n\\n![Edit website Codespace](img/develop-podman-using-codespaces/codespaces-edit-website.png)\\n\\n## Conclusion\\n\\nThe DevContainer image for Podman Desktop is recent so it\'ll probably evolve over time by adding new capabilities but it allows you to easily build/run/experiment and **contribute** to the tool or the website."}]}')}}]); \ No newline at end of file +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[1477],{30010:e=>{e.exports=JSON.parse('{"blogPosts":[{"id":"podman-desktop-release-1.5","metadata":{"permalink":"/blog/podman-desktop-release-1.5","source":"@site/blog/2023-11-03-release-1.5.md","title":"Release Notes - Podman Desktop 1.5","description":"Podman Desktop 1.5 has been released!","date":"2023-11-03T00:00:00.000Z","formattedDate":"November 3, 2023","tags":[{"label":"podman-desktop","permalink":"/blog/tags/podman-desktop"},{"label":"release","permalink":"/blog/tags/release"},{"label":"kubernetes","permalink":"/blog/tags/kubernetes"},{"label":"openshift","permalink":"/blog/tags/openshift"},{"label":"onboarding","permalink":"/blog/tags/onboarding"},{"label":"compose","permalink":"/blog/tags/compose"},{"label":"extensions","permalink":"/blog/tags/extensions"},{"label":"settings","permalink":"/blog/tags/settings"}],"readingTime":8.14,"hasTruncateMarker":false,"authors":[{"name":"M\xe1ir\xedn Duffy","title":"User Experience Designer","url":"https://github.com/mairin","imageURL":"https://github.com/mairin.png","key":"duffy"}],"frontMatter":{"title":"Release Notes - Podman Desktop 1.5","description":"Podman Desktop 1.5 has been released!","slug":"podman-desktop-release-1.5","authors":"duffy","tags":["podman-desktop","release","kubernetes","openshift","onboarding","compose","extensions","settings"],"hide_table_of_contents":false,"image":"/blog/img/podman-desktop-release-1.5/onboarding-selkies.png"},"nextItem":{"title":"Release Notes - Podman Desktop 1.4","permalink":"/blog/podman-desktop-release-1.4"}},"content":"import ReactPlayer from \'react-player\'\\n\\nPodman Desktop 1.5 Release! \ud83c\udf89\\n\\nWith this release of Podman Desktop, we\'re introducing **a new onboarding feature** that we hope will earn your \ud83e\uddad seal of approval! But wait... there\'s so much more!\\n\\n- **Onboarding**: Guided setup and configuration of **Podman** and **Compose**\\n- **Podman 4.7.2**: [Podman 4.7.2](https://github.com/containers/podman/releases) is now included in Windows and Mac installers\\n- **Command Palette**: Gain easy access to various commands via a new keyboard-driven command palette\\n- **Expanded \\"Summary\\" tab for Kubernetes pods**: Go deep with extended details on Kubernetes pods in the pod \\"Summary\\" tab\\n- **Environment file support**: Chart out environment variables for new containers to access on creation\\n- **Enhancements to the Settings area**: Get your bearings with improved Docker compatibility mode controls\\n- **Improved user experience for state changes**: No more dead reckoning on container state with improved visual indication of status\\n- **Extension API improvements**: A boatload of improvements to the extension API enabling more goodness from \ud83e\uddad Podman Desktop\'s extensions\\n\\nPodman Desktop 1.5 is now available. [Click here to download it](/downloads)!\\n\\n![Podman-desktop-1-5-hero](img/podman-desktop-release-1.5/onboarding-selkies.png)\\n\\n---\\n\\n## Release Details\\n\\n### Onboarding\\n\\nWe are introducing a new feature providing guided flows for the initial setup of specific \ud83e\uddad Podman Desktop extensions. Release 1.5 features two new onboarding flows: Podman and Compose.\\n\\nTo start the Podman onboarding flow, you can start from the dashboard notification by clicking the \\"Set up\\" button:\\n![podman-onboarding-start](https://user-images.githubusercontent.com/799683/280362279-598cc052-5ea4-4c31-849c-da9bbbcc3e42.png)\\n![podman-onboarding](https://user-images.githubusercontent.com/799683/280363859-f35b85f8-1dd4-4b7f-a995-25fe5d1ccced.png)\\n\\nVisit **Settings > Resources** screen and click the Compose \\"Setup ...\\" button in order to start Compose onboarding:\\n![compose-onboarding-start](https://user-images.githubusercontent.com/799683/280276847-ca0558ab-70ad-48cc-8dd5-67e3eb465a62.png)\\n![compose-onboarding](https://user-images.githubusercontent.com/799683/280277936-77ba0fb2-5cb0-41de-a7cf-1a3d6400fd89.png)\\n\\n### Command Palette\\n\\nA new, search-driven command palette is now available to enable quick access to various commands available across \ud83e\uddad Podman Desktop. You can try this new tool out by hitting the F1 key. [#4081](https://github.com/containers/podman-desktop/pull/4081) && [#3979](https://github.com/containers/podman-desktop/pull/3979)\\n\\n\\n\\n### Expanded \\"Summary\\" tab for Kubernetes pods\\n\\nKubernetes pods now offer a more comprehensive set of information under the \\"Summary\\" tab, including networking, volumes, environment variables, and other key metadata.\\n\\n\\n\\n### Environment file support\\n\\nWhen creating a container from the Images list, there\'s now an option to provide an environment file to set env variables for the new container. [#4026](https://github.com/containers/podman-desktop/pull/4026) && [#4025](https://github.com/containers/podman-desktop/pull/4025)\\n\\n### Enhancements to the Settings area\\n\\nThe user experience for enabling or disabling Docker compatibility is improved, with a new entry in the **Settings > Preferences** screen that includes contextual guidance. [#4093](https://github.com/containers/podman-desktop/pull/4093)\\n\\n\\n\\n### Improved user experience for state changes\\n\\nThe user experience around state changes for containers, pods, and other objects in the UI is improved, with clear status messages and improved animated visual indicator of state changes. [#4056](https://github.com/containers/podman-desktop/pull/4056)\\n\\n\\n\\n\\n\\n### Extension API improvements\\n\\nThe \ud83e\uddad Podman Desktop extension API received many improvements, including:\\n\\n- In addition to pushing and listing image from an extension, it\'s now possible to pull images from a \ud83e\uddad Podman Desktop extension [#4155](https://github.com/containers/podman-desktop/pull/4155)\\n\\n- The \ud83e\uddad Podman Desktop extension API has been enhanced with both the ability to list images & networks and the ability to create containers & networks. [#4172](https://github.com/containers/podman-desktop/pull/4172)\\n\\n- \ud83e\uddad Podman Desktop extensions now have a consistent way to run administrative tasks. [#4049](https://github.com/containers/podman-desktop/pull/4049)\\n\\n- Extensions now have the ability to register a custom Kubernetes config generator. [#3970](https://github.com/containers/podman-desktop/pull/3970)\\n\\n- The ability of extensions to add commands to UI menus has been extended; previously for action menus it was only available in the Image list screen. It is now possible for extensions to add commands to the action menus of items listed on the Containers list screen as well. [#3947](https://github.com/containers/podman-desktop/pull/3947) & [#3963](https://github.com/containers/podman-desktop/pull/3963)\\n\\n- Extensions have gained the ability to contribute menu items in the UI based on specific conditions. [#3959](https://github.com/containers/podman-desktop/pull/3959)\\n\\n- Enhanced logic for displaying or hiding properties listed under the **Settings > Preferences** screens is now available. [#4159](https://github.com/containers/podman-desktop/pull/4159)\\n\\n\\n\\n---\\n\\n## Other Notable Enhancements\\n\\n- The progress of loading an image into Kind is now visible as a task in the task manager. [#4061](https://github.com/containers/podman-desktop/pull/4061)\\n\\n![kind-progress-task](https://user-images.githubusercontent.com/42176370/270154775-eb7007b4-fd0e-4287-be9e-40ffc412de35.png)\\n\\n- It\'s now possible to start a new Podman machine right after creation, or you can create it and wait to start it later. It\'s up to you! [#4046](https://github.com/containers/podman-desktop/pull/4046)\\n\\n![podman-start-now-or-later](https://user-images.githubusercontent.com/49404737/269941187-f4768833-ecfc-4d0b-8acf-d4afedb428d9.png)\\n\\n- The Podman machine and Kubernetes provider creation forms have an updated look & feel consisted with other forms in the user interface, along with minor bug fixes. [#4317](https://github.com/containers/podman-desktop/pull/4317)\\n\\n![Updated provider creation forms](https://user-images.githubusercontent.com/19958075/274694157-fe89f3bc-e5b8-4735-96e9-669fe52c7a41.png)\\n\\n- The empty screen message shown when a search filter results in no matches now provides a message specific to filter matching, including the specific filter terms and an explicit button for clearing the filter. Previously, the screen displayed a generic message about how to create new objects of the type displayed on the screen, which led to some confusion about the status of the system. [#3988](https://github.com/containers/podman-desktop/pull/3988)\\n\\n\\n\\n- New support for adding spin animations to icons is now available. [#4188](https://github.com/containers/podman-desktop/pull/4188)\\n\\n- There is a new indeterminate progress bar type available for the task manager; this is meant for providing limited status for actions whose APIs do not provide detailed status information. [#4016](https://github.com/containers/podman-desktop/pull/4016)\\n\\n- For authenticating as admin to perform administrative tasks, \ud83e\uddad Podman Desktop now provides touchID support for macOS. [#4050](https://github.com/containers/podman-desktop/pull/4050)\\n\\n![touchID-support](https://user-images.githubusercontent.com/436777/248588015-f08115bd-d211-43ad-bddd-286d7b3a7056.png)\\n\\n\\n\\n- Support for connecting to interactive terminals for containers via tty was added. [#3900](https://github.com/containers/podman-desktop/pull/3900)\\n\\n- It\'s now more clear which container/pod providers will autostart when \ud83e\uddad Podman Desktop starts. Previously autostart had both a global and a per-provider setting. It has been simplified by removing the global setting. [#3840](https://github.com/containers/podman-desktop/pull/3840)\\n\\n- The \\"Working with containers\\" section of the documentation has been reworked and improved. [#3951](https://github.com/containers/podman-desktop/pull/3951)\\n\\n---\\n\\n## Notable Bug Fixes\\n\\n- The disable registry command was not blocking subsequent pulls from disabled registries. This has been corrected. [#4183](https://github.com/containers/podman-desktop/pull/4183)\\n\\n- Some users behind network proxies were unable to complete workflow involving the download of online resources. The mechanism for fetching these resources has been fixed to be proxy compatible to address this issue. [#3994](https://github.com/containers/podman-desktop/pull/3994)\\n\\n- The status of pods running in Kubernetes that are undergoing the deletion process is now accurately reflected in the \ud83e\uddad Podman Desktop UI. [#3877](https://github.com/containers/podman-desktop/pull/3877)\\n\\n- The image details page always listed the image as being \\"not used\\" even when it was. This has been corrected. [#3985](https://github.com/containers/podman-desktop/pull/3985)\\n\\n- Previously, deleting a specific image tag would cause all tags with the same Image ID to be deleted. This has been fixed so only the selected image tag will be deleted. [#3837](https://github.com/containers/podman-desktop/pull/3837)\\n\\n- Could not view the pod details for some remote Kubernetes cluster pods due to an encoding error. [#4371](https://github.com/containers/podman-desktop/pull/4371)\\n\\n- Error logs were being tracked separately from the actions they applied to. This has been addressed for kind cluster creation failure [#4427](https://github.com/containers/podman-desktop/pull/4427) and Compose installation failure [#4407](https://github.com/containers/podman-desktop/pull/4407).\\n\\n- For Linux users, \ud83e\uddad Podman Desktop previously did not appear under the \\"Development\\" menu when installed via Flatpak; it appeared under \\"Utilities.\\" \ud83e\uddad Podman Desktop now appears under the \\"Development\\" menu. [#3911](https://github.com/containers/podman-desktop/pull/3911)\\n\\n- Podman Machine names are no longer prefixed with the \\"Podman Machine\\" string. [#3878](https://github.com/containers/podman-desktop/pull/3878)\\n\\n![touchID-support](https://user-images.githubusercontent.com/19958075/267378447-aafdfbd7-f005-4b94-8626-9e11eec61b95.png)\\n\\n- The initial action state of pods and containers was being displayed as \\"STARTING\\" regardless of actual state; this has been corrected. [#3889](https://github.com/containers/podman-desktop/pull/3889)\\n\\n- Resizing the application window no longer makes the last lines of a container\'s terminal invisible. [#3993](https://github.com/containers/podman-desktop/pull/3993)\\n\\n- An issue with incorrect terminal behavior in response to long lines in the terminal attached to a container has been resolved. [#3955](https://github.com/containers/podman-desktop/pull/3955)\\n\\n- A spacing issue on the run image form has been corrected. [#4089]https://github.com/containers/podman-desktop/pull/4089\\n\\n- The \\"podify\\" icon & button on the Containers list was unusually large in release 1.4. That regression has been corrected in this release. [#4122](https://github.com/containers/podman-desktop/pull/4122)\\n\\n- An error in the instructions for Windows users on migrating from Docker has been corrected. [#4157](https://github.com/containers/podman-desktop/pull/4157)\\n\\n---\\n\\n## Community Thank You\\n\\n\ud83c\udf89 We\u2019d like to say a big thank you to everyone who helped to make \ud83e\uddad Podman Desktop even better. In this\\nrelease we received pull requests from the following people:\\n\\n- [afbjorklund](https://github.com/afbjorklund) in [#4373 - docs: fix broken links and add lima onboarding](https://github.com/containers/podman-desktop/pull/4373), [#4372 - docs: clear up lima column on containers page](https://github.com/containers/podman-desktop/pull/4372), [#4091 - fix: avoid errors with unexpected JSON input](https://github.com/containers/podman-desktop/pull/4091), [#4098 - docs: Lima onboarding details](https://github.com/containers/podman-desktop/pull/4098), and [#3854 - fix: check if machine init rootful flag supported](https://github.com/containers/podman-desktop/pull/3854)\\n\\n- [axel7083](https://github.com/axel7083) in [#4061 - feat: adding task progress for kind](https://github.com/containers/podman-desktop/pull/4061), [#3970 - feat: extension can register custom kube generator](https://github.com/containers/podman-desktop/pull/3970), [#3959 - feat: add when property to extensions menus](https://github.com/containers/podman-desktop/pull/3959), [#4016 - feat: indeterminate progress bar](https://github.com/containers/podman-desktop/pull/4016), [#3963 - fix: ContainerList propagating containers in ComposeActions and PodActions](https://github.com/containers/podman-desktop/pull/3963), and [#3947 - feat: extend menus capabilities](https://github.com/containers/podman-desktop/pull/3947)\\n\\n- [ayushrakesh](https://github.com/ayushrakesh) in [#4415 - Update README.md](https://github.com/containers/podman-desktop/pull/4415#)\\n\\n- [eltociear](https://github.com/eltociear) in [#4194 - Update README.md](https://github.com/containers/podman-desktop/pull/4194)\\n\\n- [foxydeveloper](https://github.com/foxydevloper) in [#4157 - docs: Correct windows instructions for migrating from docker](https://github.com/containers/podman-desktop/pull/4157)\\n\\n- [harsh-solanki21](https://github.com/harsh-solanki21) in [#4162 - fix: Removed fullstop from summary](https://github.com/containers/podman-desktop/pull/4162)\\n\\n- [rahul0x00](https://github.com/rahul0x00) in [#4240 - fix typos in README.md](https://github.com/containers/podman-desktop/pull/4240)\\n\\n- [shelar1423](https://github.com/shelar1423) in [#4221 - chore: document property setting in EXTENSIONS.md](https://github.com/containers/podman-desktop/pull/4221)\\n\\n---\\n\\n## Final notes\\n\\n### Known Issues\\n\\nWe have a discussion board topic where we have posted known issues with this release. If you run into problems, please check this list before filing a bug - if we already have an issue open for it, it saves you the time and trouble of filing, and there may be a workaround posted in the issue.\\n\\n#### [Known Issues: Podman Desktop 1.5.2](https://github.com/containers/podman-desktop/discussions/4635)\\n\\n### Fixed Issues\\n\\nThe complete list of issues fixed in this release is available [here](https://github.com/containers/podman-desktop/issues?q=is%3Aclosed+milestone%3A1.5.0).\\n\\n### Where to Download\\n\\nGet the latest release from the [Downloads](/downloads) section of the website and boost your development journey with Podman Desktop. Additionally, visit the [GitHub repository](https://github.com/containers/podman-desktop) and see how you can help us make Podman Desktop better."},{"id":"podman-desktop-release-1.4","metadata":{"permalink":"/blog/podman-desktop-release-1.4","source":"@site/blog/2023-09-18-release-1.4.md","title":"Release Notes - Podman Desktop 1.4","description":"Podman Desktop 1.4 has been released!","date":"2023-09-18T00:00:00.000Z","formattedDate":"September 18, 2023","tags":[{"label":"podman-desktop","permalink":"/blog/tags/podman-desktop"},{"label":"release","permalink":"/blog/tags/release"},{"label":"kubernetes","permalink":"/blog/tags/kubernetes"},{"label":"openshift","permalink":"/blog/tags/openshift"}],"readingTime":3.415,"hasTruncateMarker":false,"authors":[{"name":"Jeff Maury","title":"Engineering Manager","url":"https://github.com/jeffmaury","imageURL":"https://github.com/jeffmaury.png","key":"jeffmaury"}],"frontMatter":{"title":"Release Notes - Podman Desktop 1.4","description":"Podman Desktop 1.4 has been released!","slug":"podman-desktop-release-1.4","authors":["jeffmaury"],"tags":["podman-desktop","release","kubernetes","openshift"],"hide_table_of_contents":false,"image":"/blog/img/podman-desktop-release-1.4/juggling.png"},"prevItem":{"title":"Release Notes - Podman Desktop 1.5","permalink":"/blog/podman-desktop-release-1.5"},"nextItem":{"title":"Release Notes - Podman Desktop 1.3","permalink":"/blog/podman-desktop-release-1.3"}},"content":"import ReactPlayer from \'react-player\'\\n\\nPodman Desktop 1.4 Release! \ud83c\udf89\\n\\nThis is essentially a bug-fix release to fix various issues in UI, but as usual we also added a few new features.\\n\\n- **Podman 4.6.2**: Podman 4.6.2 included with Podman Desktop 1.4\\n- **Windows Arm64**: Native Windows on Arm64 installers and binaries\\n- **Port range mapping**: Start containers and map a range of ports\\n- **Terminal UX Improvement**: Persistent terminal sessions when SSH\'ing in a container\\n- **Volume Creation**: Create volume from the `Volumes` page\\n- **Bash support**: Terminals are now using `bash` if available.\\n\\nPodman Desktop 1.4 is now available. [Click here to download it](/downloads)!\\n\\n![Podman-desktop-1-4-juggling](img/podman-desktop-release-1.4/juggling.png)\\n\\n---\\n\\n## Release Details\\n\\n### Port range mapping [#3654](https://github.com/containers/podman-desktop/pull/3654)\\n\\nWhen starting a new container, you can now map a port range between host and container. If the range is not valid between host and container, an error is raised.\\n\\n![Range mapping](https://user-images.githubusercontent.com/49404737/262927546-da66b67a-0884-40b1-85bd-a9c3ea2f3f9e.gif)\\n\\n### Terminal lifetime [#3725](https://github.com/containers/podman-desktop/pull/3725)\\n\\nWhen a terminal is opened for a container, it can now be reused after you switched to another part of the Podman Desktop UI.\\n\\n![terminal lifetime](img/podman-desktop-release-1.4/terminal.gif)\\n\\n### Create volume [#3742](https://github.com/containers/podman-desktop/pull/3742)\\n\\nThe Volumes tab now has a Create volume button. The Create volume UI has a single field for the volume name.\\n\\n![create volume](img/podman-desktop-release-1.4/create-volume.gif)\\n\\n### bash support [#3750](https://github.com/containers/podman-desktop/pull/3750)\\n\\nWhen a terminal is opened for a container, if bash is available within the container, it will be used. Otherwise, sh will be used.\\n\\n![bash sh](img/podman-desktop-release-1.4/bash-sh.gif)\\n\\n### Notable Bug Fixes\\n\\n- Reduce API calls when listing containers by @benoitf [#3489](https://github.com/containers/podman-desktop/pull/3489)\\n- Removing a connection(podman machine) should redirect to previous page by @benoitf [#3576](https://github.com/containers/podman-desktop/pull/3576)\\n- Enhance error message when image is not there by @benoitf [#3587](https://github.com/containers/podman-desktop/pull/3587)\\n- Dispose kind install button when extension is deactivated (#3586) by @lstocchi [#3610](https://github.com/containers/podman-desktop/pull/3610)\\n- Replace backslash/slash on windows when building image (#3465) by @lstocchi [#3618](https://github.com/containers/podman-desktop/pull/3618)\\n- Handle null value in container command (#3620) by @lstocchi [#3625](https://github.com/containers/podman-desktop/pull/3625)\\n- Add maximum activation time for extensions by @benoitf [#3446](https://github.com/containers/podman-desktop/pull/3446)\\n- Handle single non-spread arguments by @benoitf [#3641](https://github.com/containers/podman-desktop/pull/3641)\\n- Grab usage data of volumes only on-demand by @benoitf [#3635](https://github.com/containers/podman-desktop/pull/3635)\\n- Add arm64 binaries for Windows by @benoitf [#3643](https://github.com/containers/podman-desktop/pull/3643)\\n- Include right airgap file for Windows and arm64 by @benoitf [#3651](https://github.com/containers/podman-desktop/pull/3651)\\n- Redirect to previous page when removing a kubernetes connection by @benoitf [#3650](https://github.com/containers/podman-desktop/pull/3650)\\n- Support port ranges when starting a container (#3204) by @lstocchi [#3654](https://github.com/containers/podman-desktop/pull/3654)\\n- Add a strict undefined check to messagebox result (#3692) by @lstocchi [#3699](https://github.com/containers/podman-desktop/pull/3699)\\n- Only restart if a machine is running by @cdrage [#3491](https://github.com/containers/podman-desktop/pull/3491)\\n- Session to the terminal is reused by @benoitf [#3725](https://github.com/containers/podman-desktop/pull/3725)\\n- Disable next button and show try again when onboarding failed (#3616) by @lstocchi [#3711](https://github.com/containers/podman-desktop/pull/3711)\\n- Add podman in PATH after updating process environment PATH (#3729) by @lstocchi [#3730](https://github.com/containers/podman-desktop/pull/3730)\\n- Allow to create a volume by @benoitf [#3742](https://github.com/containers/podman-desktop/pull/3742)\\n- Using bash if available otherwise sh in terminal by @axel7083 [#3750](https://github.com/containers/podman-desktop/pull/3750)\\n- Allow to embed existing component to onboarding (#3755) by @lstocchi [#3763](https://github.com/containers/podman-desktop/pull/3763)\\n- Some containers never return logs, do not wait for them by @dgolovin [#3784](https://github.com/containers/podman-desktop/pull/3784)\\n- Remove cancel button when on final onboarding step (#3771) by @lstocchi [#3802](https://github.com/containers/podman-desktop/pull/3802)\\n- Onboarding add link micromark for commands by @cdrage [#3747](https://github.com/containers/podman-desktop/pull/3747)\\n- Mounts can be null when using older podman by @afbjorklund [#3806](https://github.com/containers/podman-desktop/pull/3806)\\n- Remove redundant step completion check when onboarding gets started by @lstocchi [#3798](https://github.com/containers/podman-desktop/pull/3798)\\n- Ability to click enter in pull image name input by @deboer-tim [#3850](https://github.com/containers/podman-desktop/pull/3850)\\n- Set proxy environment variable when launching process by @jeffmaury [#3838](https://github.com/containers/podman-desktop/pull/3838)\\n- The socket location was moved for new podman by @afbjorklund [#3853](https://github.com/containers/podman-desktop/pull/3853)\\n- Don\'t log console errors when activating lima extension by @afbjorklund [#3852](https://github.com/containers/podman-desktop/pull/3852)\\n\\n### Community Thank You\\n\\n\ud83c\udf89 We\u2019d like to say a big thank you to everyone who helped to make Podman Desktop even better.\\n\\nA warm welcome to [@tomgoren](https://github.com/tomgoren), [@Julian](https://github.com/Julian), [@Gelob](https://github.com/Gelob) and [@cedricclyburn](https://github.com/cedricclyburn) who made their first contribution to the project in this release.\\n\\n### Final Notes\\n\\nThe complete list of issues fixed in this release is available [here](https://github.com/containers/podman-desktop/issues?q=is%3Aclosed+milestone%3A1.4.0).\\n\\nGet the latest release from the [Downloads](/downloads) section of the website and boost your development journey with Podman Desktop. Additionally, visit the [GitHub repository](https://github.com/containers/podman-desktop) and see how you can help us make Podman Desktop better."},{"id":"podman-desktop-release-1.3","metadata":{"permalink":"/blog/podman-desktop-release-1.3","source":"@site/blog/2023-08-16-release-1.3.md","title":"Release Notes - Podman Desktop 1.3","description":"Podman Desktop 1.3 has been released!","date":"2023-08-16T00:00:00.000Z","formattedDate":"August 16, 2023","tags":[{"label":"podman-desktop","permalink":"/blog/tags/podman-desktop"},{"label":"release","permalink":"/blog/tags/release"},{"label":"kubernetes","permalink":"/blog/tags/kubernetes"},{"label":"openshift","permalink":"/blog/tags/openshift"}],"readingTime":5.195,"hasTruncateMarker":false,"authors":[{"name":"Denis Golovin","title":"Principal Software Engineer","url":"https://github.com/cdrage","imageURL":"https://github.com/dgolovin.png","key":"dgolovin"}],"frontMatter":{"title":"Release Notes - Podman Desktop 1.3","description":"Podman Desktop 1.3 has been released!","slug":"podman-desktop-release-1.3","authors":["dgolovin"],"tags":["podman-desktop","release","kubernetes","openshift"],"hide_table_of_contents":false,"image":"/img/blog/podman-desktop-release-1.3.webp"},"prevItem":{"title":"Release Notes - Podman Desktop 1.4","permalink":"/blog/podman-desktop-release-1.4"},"nextItem":{"title":"Release Notes - Podman Desktop 1.2","permalink":"/blog/podman-desktop-release-1.2"}},"content":"import ReactPlayer from \'react-player\'\\n\\nPodman Desktop 1.3 Release! \ud83c\udf89\\n\\nThis is essentially a bug-fix release to fix various issues in UI, extension engine and featured extensions, but as usual we also added a few new features.\\n\\n- **Podman 4.6.1**: Podman 4.6.1 included in Windows and Mac installers\\n- **Podman user-mode networking support to Windows/WSL**: A new switch `User mode networking\' is available when creating Podman machine on Windows for Podman 4.6.0+ to configure podman to work in certain VPN setups and other specialized networking configurations\\n- **Compose group new UI elements**: You can now see summary, inspect, deploy to kubernetes, generate kube yaml and view logs\\n- **Extension packs and extension dependencies**: Install group of extensions in one click\\n- **Resource details page update**: See summary and log for resource\\n- **Create Kind cluster form update**: A new `Node\'s container image` field can be used to specify the Kubernetes version used for the control-planed\\n- **Support Docker Desktop extensions using a backend**: When loading Docker Desktop extension the containers are created in the backend as described in the vm section of extension\'s descriptor\\n- **Podman Initial Onboarding (preview)**: Install and configure podman using included installer\\n\\nPodman Desktop 1.3 is now available. [Click here to download it](/downloads)!\\n\\n![Podman-desktop-1-3-bug-swatting](img/podman-desktop-release-1.3/title-bug-swatting.png)\\n\\n---\\n\\n## Release Details\\n\\n### Compose group Logs tab [#3176](https://github.com/containers/podman-desktop/pull/3176)\\n\\nWhen clicking on the group of containers, you can now view the logs of the entire group of compose containers and don\'t need to open\\nlog for every component individually.\\n\\n![Screenshot 2023-07-11 at 12 48 47 PM](https://github.com/containers/podman-desktop/assets/6422176/743a4ffc-e291-4697-8ac5-8052cc921946)\\n\\n### Podman user-mode networking support to Windows/WSL [#3251](https://github.com/containers/podman-desktop/pull/3251)\\n\\nCertain VPN setups or other specialized networking configs will block traffic from the virtual WSL networking device, resulting in the podman WSL backend from being unable to contact systems on the VPN, and potentially losing internet access altogether. The new switch allows you to create a podman VM machine configured to work correctly in mentioned above networking environments.\\n\\n![user](https://github.com/containers/podman-desktop/assets/620330/2f521576-b6a6-42b5-b24d-08df5b432608)\\n\\n### Compose group Summary tab [#3317](https://github.com/containers/podman-desktop/pull/3317),\\n\\nCompose group Summary tab shows all containers in the group and let you navigate to Details page for specific container.\\n\\n\\n\\n### Compose group Inspect tab [#3316](https://github.com/containers/podman-desktop/pull/3316)\\n\\nCompose group Inspect tab shows an array of \\"container inspect\\" from docker / podman.\\n\\n\\n\\n### `Deploy to kubernetes` in compose actions [#3299](https://github.com/containers/podman-desktop/pull/3295)\\n\\nA button to deploy to kubernetes added to Compose group.\\n\\n\\n\\n### `Generate Kube` in Compose actions and `Kube` tab in compose details [#3253](https://github.com/containers/podman-desktop/pull/3253)\\n\\n`Generate Kube` item added to Compose actions and \\"Kube\\" tab is now available in Compose details view.\\n\\n\\n\\n### Install multiple extensions using extension pack [#3150](https://github.com/containers/podman-desktop/pull/3150)\\n\\nAn Extension pack introduced in Extension engine is a way to declare set of extensions to install them all at once.\\n\\n\\n\\n### Customize icons from extension [#3131](https://github.com/containers/podman-desktop/pull/3131)\\n\\nExtensions now can customize icons for list elements using `when` clause.\\n\\n![image](https://github.com/containers/podman-desktop/assets/49404737/7aae5347-4f07-4854-ba11-1f629b5ccf22)\\n\\n### Resource details page update [#1923](https://github.com/containers/podman-desktop/pull/1923)\\n\\nIf you click on the arrow icon next to a resource name it will open up a details page (similarly to how clicking on a container in the container list opens up a details page).\\n\\n![image](https://user-images.githubusercontent.com/49404737/229542404-bae44f89-5cd3-4baf-8b08-e934e4462697.gif)\\n\\n### `Node\'s container image` field added to `Create a Kind cluster` form [#3508](https://github.com/containers/podman-desktop/pull/3508)\\n\\nThe new `Node\'s container image` field can be used to specify the Kubernetes version used for the control-planed.\\n\\n![image](https://github.com/containers/podman-desktop/assets/42176370/b2a63faf-629f-436d-8496-7c0cd8158679)\\n\\n### Support Docker Desktop extensions using a backend [#3435](https://github.com/containers/podman-desktop/pull/3435)\\n\\nPodman Desktop now loads the containers in the backend as described in the vm section of extension descriptor the same way as Docker Desktop does.\\n\\n### Initial onboarding implementation for podman (experimental) [#3308](https://github.com/containers/podman-desktop/pull/3308)\\n\\nThis is the initial implementation for the onboarding feature. It only covers a simple onboarding for podman. Check system requirements -> install podman -> yay! Done!\\n\\n### Notable Bug Fixes\\n\\n- Updating videos to be adaptive for mobile by @mairin [#3229](https://github.com/containers/podman-desktop/pull/3229)\\n- Consistent max width and padding in settings by @deboer-tim [#3232](https://github.com/containers/podman-desktop/pull/3232)\\n- Settings navigation bar resizing by @deboer-tim in [#3231](https://github.com/containers/podman-desktop/pull/3231)\\n- Move new registry button to header by @deboer-tim [#3245](https://github.com/containers/podman-desktop/pull/3245)\\n- Bigger lima logo by @afbjorklund [#3248](https://github.com/containers/podman-desktop/pull/3248)\\n- Horizontal docker logo by @afbjorklund [#3236](https://github.com/containers/podman-desktop/pull/3236)\\n- Respect LIMA_HOME environment variable by @afbjorklund [#3254](https://github.com/containers/podman-desktop/pull/3254)\\n- Add check before writing to terminal by @lstocchi [#3263](https://github.com/containers/podman-desktop/pull/3263)\\n- Wait until remote side has fully initialized the extensions by @benoitf [#3257](https://github.com/containers/podman-desktop/pull/3257)\\n- Fix loader not centered horizontally by @benoitf [#3270](https://github.com/containers/podman-desktop/pull/3270)\\n- Troubleshooting still waiting after failure by @deboer-tim [#3354](https://github.com/containers/podman-desktop/pull/3354)\\n- Store error for build by @cdrage [#3365](https://github.com/containers/podman-desktop/pull/3365)\\n- Missing checkbox tooltips by @deboer-tim [#3380](https://github.com/containers/podman-desktop/pull/3380)\\n- Load compose logs async not await by @cdrage [#3377](https://github.com/containers/podman-desktop/pull/3377)\\n- Set rootful connection when starting rootful machine by @lstocchi [#3364](https://github.com/containers/podman-desktop/pull/3364)\\n- Default last page by @deboer-tim [#3388](https://github.com/containers/podman-desktop/pull/3388)\\n- Avoid dashboard displaying providers starting while they don\'t by @benoitf [#3451](https://github.com/containers/podman-desktop/pull/3451)\\n- Do not use extensionInfo until it is defined by @benoitf [#V](https://github.com/containers/podman-desktop/pull/3450)\\n- Allow BASIC authentication (all caps) by @cdrage [#3471](https://github.com/containers/podman-desktop/pull/3471)\\n- Allow single domain registry such as localhost:5000 by @cdrage [#3468](https://github.com/containers/podman-desktop/pull/3468)\\n- Create /usr/local/bin directory if it does not exist on binary install by @cdrage [#3425](https://github.com/containers/podman-desktop/pull/3425)\\n- Only delete selected pods by @deboer-tim [#](https://github.com/containers/podman-desktop/pull/3378)\\n- Add back \'Done\' text on the button by @benoitf [#3487](https://github.com/containers/podman-desktop/pull/3487)\\n- Do not wait for more than 5s when checking for podman ping by @benoitf [#3497](https://github.com/containers/podman-desktop/pull/3497)\\n- Add proxy support for extension using patching get and request approach by @dgolovin [#2825](https://github.com/containers/podman-desktop/pull/2825)\\n- Refresh component when field is updated by @benoitf [#3525](https://github.com/containers/podman-desktop/pull/3525)\\n- Higher-res icons for featured extensions list by @mairin [#3511](https://github.com/containers/podman-desktop/pull/3511)\\n- Main nav selection by @deboer-tim [#3510](https://github.com/containers/podman-desktop/pull/3510)\\n- kube event error when switching context by @jeffmaury [#3494](https://github.com/containers/podman-desktop/pull/3494)\\n- Reset error message each time we pull image by @benoitf [#3550](https://github.com/containers/podman-desktop/pull/3550)\\n\\n### Community Thank You\\n\\n\ud83c\udf89 We\u2019d like to say a big thank you to everyone who helped to make Podman Desktop even better.\\n\\nA warm welcome to [@rostalan](https://github.com/rostalan) and [@axel7083](https://github.com/axel7083) who made their first contribution to the project in this release.\\n\\n### Final Notes\\n\\nThe complete list of issues fixed in this release is available [here](https://github.com/containers/podman-desktop/issues?q=is%3Aclosed+milestone%3A1.3.0).\\n\\nGet the latest release from the [Downloads](/downloads) section of the website and boost your development journey with Podman Desktop. Additionally, visit the [GitHub repository](https://github.com/containers/podman-desktop) and see how you can help us make Podman Desktop better."},{"id":"podman-desktop-release-1.2","metadata":{"permalink":"/blog/podman-desktop-release-1.2","source":"@site/blog/2023-07-12-release-1.2.md","title":"Release Notes - Podman Desktop 1.2","description":"Podman Desktop 1.2 has been released!","date":"2023-07-12T00:00:00.000Z","formattedDate":"July 12, 2023","tags":[{"label":"podman-desktop","permalink":"/blog/tags/podman-desktop"},{"label":"release","permalink":"/blog/tags/release"},{"label":"kubernetes","permalink":"/blog/tags/kubernetes"},{"label":"openshift","permalink":"/blog/tags/openshift"}],"readingTime":6.05,"hasTruncateMarker":false,"authors":[{"name":"Charlie Drage","title":"Software Engineer","url":"https://github.com/cdrage","imageURL":"https://github.com/cdrage.png","key":"cdrage"}],"frontMatter":{"title":"Release Notes - Podman Desktop 1.2","description":"Podman Desktop 1.2 has been released!","slug":"podman-desktop-release-1.2","authors":["cdrage"],"tags":["podman-desktop","release","kubernetes","openshift"],"hide_table_of_contents":false,"image":"/img/blog/podman-desktop-release-1.2.webp"},"prevItem":{"title":"Release Notes - Podman Desktop 1.3","permalink":"/blog/podman-desktop-release-1.3"},"nextItem":{"title":"Release Notes - Podman Desktop 1.1","permalink":"/blog/podman-desktop-release-1.1"}},"content":"import ReactPlayer from \'react-player\'\\n\\nPodman Desktop 1.2 Release! \ud83c\udf89\\n\\nWe\'re excited to announce the release of Podman Desktop version 1.2.0! This release includes many new features (Kubernetes, Compose and extension support!), bug fixes, and improvements to enhance your container management experience. Here\'s a summary of the key changes in this release:\\n\\n- **Added start/stop/delete/restart buttons for Compose**: You can now make changes to an entire Compose group of containers\\n- **Kubernetes context on the status bar**: Choose from multiple Kubernetes contexts more easily all from the status bar\\n- **Rename images**: Rename an image with a click of a button\\n- **Protocol handler support**: Added support for protocol handlers such as `open podman-desktop:extension/redhat.openshift-local`\\n- **Troubleshooting page**: A troubleshooting page for helping diagnose Podman Desktop related development issues\\n\\nPodman Desktop 1.2 is now available. [Click here to download it](/downloads)!\\n\\n![Podman-desktop-1-2-hero](img/podman-desktop-release-1.2/podman-desktop-release-1.2.png)\\n\\n---\\n\\n## Release Details\\n\\n### Added start/stop/delete/restart buttons for Compose\\n\\nIn the last month we\'ve been addind support for more Compose features. Before you were only able to control a group of containers if they were in a Pod. Now we have added the ability to control a group of Compose containers. You can now start, stop, delete and restart a group of containers launched by either `docker-compose` or `podman-compose`.\\n\\nStay tuned as we add even more features to Compose! If you have any feedback or feature requests, feel free to open an issue or start a discussion on GitHub.\\n\\n\\n\\n### Kubernetes context on the status bar\\n\\nWith Kubernetes context on the status bar, you can switch from one context to another in just a couple of clicks. Easily switch to a different cluster all together. If there are multiple contexts available, you can now click and pick which one to use.\\n\\n\\n\\n### Rename images\\n\\nDeployed an image but now you need to rename it / add a new tag? Podman Desktop allows you to edit an image now. Thanks to an awesome contributor [@tuckerrc](https://github.com/tuckerrc) who added the new feature.\\n\\n\\n\\n### Troubleshooting page\\n\\nDeveloping an extension for Podman Desktop? Want to view the logs of Podman Desktop as well as ping your container connection? We now have a troubleshooting page!\\n\\nClick on the lightbulb button on the bottom right to access the page.\\n\\n\\n\\n### Protocol handler support\\n\\nPodman Desktop now supports protocol handling when using the terminal! Want to access your favourite extension directly from a script or the terminal? If you type in `open podman-desktop:extension/redhat.openshift-local` in the terminal, Podman Desktop will automatically load up to the correct extension.\\n\\n\\n\\n---\\n\\n## Other Notable Features\\n\\n- Background colors and FormPage ([PR #2977](https://github.com/containers/podman-desktop/pull/2977))\\n- Add ability to add insecure registry / skipping cert verify ([PR #2896](https://github.com/containers/podman-desktop/pull/2896))\\n- Add support for icon contribution ([PR #2984](https://github.com/containers/podman-desktop/pull/2984))\\n- Add warning dialog message that virtual machine has low memory limit ([PR #2822](https://github.com/containers/podman-desktop/pull/2822))\\n- Propose indexed name for new pod ([PR #3028](https://github.com/containers/podman-desktop/pull/3028))\\n- Add restart button after enabling / disabling mac os compatibility ([PR #2841](https://github.com/containers/podman-desktop/pull/2841))\\n- Add environment related helper constants ([PR #3079](https://github.com/containers/podman-desktop/pull/3079))\\n- Allow entrypoint and cmd when starting container ([PR #3031](https://github.com/containers/podman-desktop/pull/3031))\\n- Add a way to debug stores in troubleshooting page ([PR #3121](https://github.com/containers/podman-desktop/pull/3121))\\n- Add custompick component (#2855) ([PR #3012](https://github.com/containers/podman-desktop/pull/3012))\\n- Dynamic breadcrumbs ([PR #3119](https://github.com/containers/podman-desktop/pull/3119))\\n- Icons on form pages ([PR #3155](https://github.com/containers/podman-desktop/pull/3155))\\n- Switch more pages to formpage ([PR #3162](https://github.com/containers/podman-desktop/pull/3162))\\n- Add rename image button ([PR #2588](https://github.com/containers/podman-desktop/pull/2588))\\n- Fixed headers, improved scrollbars ([PR #2863](https://github.com/containers/podman-desktop/pull/2863))\\n- Reports warnings on failed kube deploy, fixes error out ([PR #3050](https://github.com/containers/podman-desktop/pull/3050))\\n- Kube context on statusbar ([PR #2755](https://github.com/containers/podman-desktop/pull/2755))\\n- Install provider if not installed when clicking on create new button (#2706) ([PR #2817](https://github.com/containers/podman-desktop/pull/2817))\\n- Add tag and authenticated push capacity to the extension API ([PR #2876](https://github.com/containers/podman-desktop/pull/2876))\\n- Add navigation bar e2e tests ([PR #2950](https://github.com/containers/podman-desktop/pull/2950))\\n\\n---\\n\\n## Documentation Updates\\n\\n- Fix documentation for building image of extensions ([PR #2873](https://github.com/containers/podman-desktop/pull/2873))\\n- Add Minikube install docs ([PR #2824](https://github.com/containers/podman-desktop/pull/2824))\\n- Add Minikube documentation ([PR #2694](https://github.com/containers/podman-desktop/pull/2694))\\n- Updated Building an image procedure ([PR #2964](https://github.com/containers/podman-desktop/pull/2964))\\n- Starting a container ([PR #2958](https://github.com/containers/podman-desktop/pull/2958))\\n- Pulling an image ([PR #2956](https://github.com/containers/podman-desktop/pull/2956))\\n- Updated selecting containers to run in a pod ([PR #2970](https://github.com/containers/podman-desktop/pull/2970))\\n- Pushing an image to a registry ([PR #2969](https://github.com/containers/podman-desktop/pull/2969))\\n- How to add an insecure registry ([PR #2953](https://github.com/containers/podman-desktop/pull/2953))\\n- Add documentation for lima ([PR #2995](https://github.com/containers/podman-desktop/pull/2995))\\n- Replace broken link to podman.io ([PR #2994](https://github.com/containers/podman-desktop/pull/2994))\\n- Authenticating to a pre-configured registry ([PR #2965](https://github.com/containers/podman-desktop/pull/2965))\\n- Lima is not a container engine ([PR #3051](https://github.com/containers/podman-desktop/pull/3051))\\n- Using the Troubleshooting page ([PR #3083](https://github.com/containers/podman-desktop/pull/3083))\\n- View and select your current Kubernetes context in the status bar ([PR #3090](https://github.com/containers/podman-desktop/pull/3090))\\n\\n---\\n\\n## Notable Bug Fixes\\n\\n- Deleting a running pod generates an error ([PR #2827](https://github.com/containers/podman-desktop/pull/2827))\\n- If kubeconfig is empty, does not try to do things, cancel ([PR #2874](https://github.com/containers/podman-desktop/pull/2874))\\n- Async telemetry startup ([PR #2885](https://github.com/containers/podman-desktop/pull/2885))\\n- Do not block startup while waiting for kube resource refresh ([PR #2884](https://github.com/containers/podman-desktop/pull/2884))\\n- Images list too wide ([PR #2918](https://github.com/containers/podman-desktop/pull/2918))\\n- Compose deactivate function never called ([PR #2922](https://github.com/containers/podman-desktop/pull/2922))\\n- Auto-scrolling on form pages, layout issues ([PR #2927](https://github.com/containers/podman-desktop/pull/2927))\\n- Show current context in quick pick ([PR #2920](https://github.com/containers/podman-desktop/pull/2920))\\n- Remove sticky position of loader in dashboard UI (#2535) ([PR #2959](https://github.com/containers/podman-desktop/pull/2959))\\n- Undo change that broke the website ([PR #2992](https://github.com/containers/podman-desktop/pull/2992))\\n- Detailspage, resizing & consistency ([PR #2987](https://github.com/containers/podman-desktop/pull/2987))\\n- Quick pick click to close and over nav bar ([PR #2758](https://github.com/containers/podman-desktop/pull/2758))\\n- Only show empty screen when no pods ([PR #2929](https://github.com/containers/podman-desktop/pull/2929))\\n- Do not redirect to /pods when deleting pod in containerlist ([PR #2963](https://github.com/containers/podman-desktop/pull/2963))\\n- Bulk delete on pods should call the pod deletion ([PR #2979](https://github.com/containers/podman-desktop/pull/2979))\\n- Update nodejs version to 18 in .nvmrc to fix yarn install failure ([PR #2989](https://github.com/containers/podman-desktop/pull/2989))\\n- Website check targets ([PR #2996](https://github.com/containers/podman-desktop/pull/2996))\\n- Don\'t show exception to user ([PR #3034](https://github.com/containers/podman-desktop/pull/3034))\\n- Interpret arguments given to info command for example ([PR #3015](https://github.com/containers/podman-desktop/pull/3015))\\n- Change defaults for Podman machine ([PR #3061](https://github.com/containers/podman-desktop/pull/3061))\\n- Normalize development/production folders path ([PR #3113](https://github.com/containers/podman-desktop/pull/3113))\\n- Calculate machine socket path for linux ([PR #3070](https://github.com/containers/podman-desktop/pull/3070))\\n- Replace backslash with slash so to support rendering on Windows (#3120) ([PR #3122](https://github.com/containers/podman-desktop/pull/3122))\\n- Keep stdout and stderr in the error object for Docker Desktop extensions ([PR #3014](https://github.com/containers/podman-desktop/pull/3014))\\n- Mark task completed if there\'s a failure ([PR #3016](https://github.com/containers/podman-desktop/pull/3016))\\n- Handle invalid kubeconfig file ([PR #3129](https://github.com/containers/podman-desktop/pull/3129))\\n- Do not remove registries when podman extension is stopping ([PR #3136](https://github.com/containers/podman-desktop/pull/3136))\\n- Warning should be amber ([PR #3153](https://github.com/containers/podman-desktop/pull/3153))\\n- Load user extensions from plugins as removable ([PR #3152](https://github.com/containers/podman-desktop/pull/3152))\\n- Images with spaces in entrypoints or commands fail to start ([PR #3161](https://github.com/containers/podman-desktop/pull/3161))\\n- Scrolling offscreen when clicking checkbox ([PR #3178](https://github.com/containers/podman-desktop/pull/3178))\\n- Avoid messagebox expanding offscreen ([PR #2778](https://github.com/containers/podman-desktop/pull/2778))\\n- Release-notes-generator run failure ([PR #2752](https://github.com/containers/podman-desktop/pull/2752))\\n- Unable to do a new build if the previous one failed ([PR #2721](https://github.com/containers/podman-desktop/pull/2721))\\n\\n---\\n\\n## Community Thank You\\n\\n\ud83c\udf89 We\u2019d like to say a big thank you to everyone who helped to make Podman Desktop even better.\\n\\nA big shoutout to [@afbjorklund](https://github.com/afbjorklund), [@tuckerrc](https://github.com/tuckerrc) and [@evanshortiss](https://github.com/evanshortiss) who contributed to this release!\\n\\n---\\n\\n## Final notes\\n\\nThe complete list of issues fixed in this release is available [here](https://github.com/containers/podman-desktop/issues?q=is%3Aclosed+milestone%3A1.2.0) and [here](https://github.com/containers/podman-desktop/issues?q=is%3Aclosed+milestone%3A1.2.0).\\n\\nGet the latest release from the [Downloads](/downloads) section of the website and boost your development journey with Podman Desktop. Additionally, visit the [GitHub repository](https://github.com/containers/podman-desktop) and see how you can help us make Podman Desktop better."},{"id":"podman-desktop-release-1.1","metadata":{"permalink":"/blog/podman-desktop-release-1.1","source":"@site/blog/2023-06-08-release-1.1.md","title":"Release Notes - Podman Desktop 1.1","description":"Podman Desktop 1.1 has been released!","date":"2023-06-08T00:00:00.000Z","formattedDate":"June 8, 2023","tags":[{"label":"podman-desktop","permalink":"/blog/tags/podman-desktop"},{"label":"release","permalink":"/blog/tags/release"},{"label":"kubernetes","permalink":"/blog/tags/kubernetes"},{"label":"openshift","permalink":"/blog/tags/openshift"}],"readingTime":2.465,"hasTruncateMarker":true,"authors":[{"name":"Tim deBoer","title":"Architect","url":"https://github.com/deboer-tim","imageURL":"https://github.com/deboer-tim.png","key":"deboer"}],"frontMatter":{"title":"Release Notes - Podman Desktop 1.1","description":"Podman Desktop 1.1 has been released!","slug":"podman-desktop-release-1.1","authors":["deboer"],"tags":["podman-desktop","release","kubernetes","openshift"],"hide_table_of_contents":false,"image":"/img/blog/podman-desktop-release-1.1.webp"},"prevItem":{"title":"Release Notes - Podman Desktop 1.2","permalink":"/blog/podman-desktop-release-1.2"},"nextItem":{"title":"Release Notes - Podman Desktop 1.0","permalink":"/blog/podman-desktop-release-1.0"}},"content":"import ReactPlayer from \'react-player\'\\n\\nPodman Desktop 1.1 Release! \ud83c\udf89\\n\\nThis is primarily a bug-fix release to fix a few important issues, but we\'ve managed to squeeze in a few enhancements\\nalong the way.\\n\\n\x3c!--Main Features--\x3e\\n\\n- **Podman 4.5.1**: Podman 4.5.1 now included in Windows and Mac installers.\\n- **Extensions**: Update extensions from within Podman Desktop.\\n- **Lima Support**: Choose engine type and override its name from the settings.\\n- **UX and UI Improvements**: New loading screen.\\n\\nPodman Desktop 1.1 is now available. [Click here to download it](/downloads)!\\n\\n![Podman-desktop-1-1-hero](img/podman-desktop-release-1.1/podman-desktop-release-1.1.png)\\n\\n\x3c!--truncate--\x3e\\n\\n---\\n\\n## Release Details\\n\\n### Podman v4.5.1\\n\\nPodman Desktop 1.1 moves up to [Podman 4.5.1](https://github.com/containers/podman/releases/tag/v4.5.1).\\n\\n### Extensions\\n\\nOptional extensions will follow their own lifecycle and update independently from Podman Desktop. As of\\nthis release you\'ll be able to see when there is an update available and install from within\\nPodman Desktop [#2655](https://github.com/containers/podman-desktop/pull/2655).\\n\\nWe\'ve also added options in **Settings > Preferences** to\\nautomatically check for and install extension updates.\\n\\n\\n\\n![Update extensions](img/podman-desktop-release-1.1/update-extensions.png)\\n\\n### Lima Support\\n\\nThanks to contributor [Anders Bj\xf6rklund](https://github.com/afbjorklund), we have some improvements to the\\nLima extension! In **Settings > Preferences** you can select which\\nengine type Lima runs on and override the instance name [#2674](https://github.com/containers/podman-desktop/pull/2674).\\n\\n![Lima preferences](https://user-images.githubusercontent.com/10364051/241755966-0a6a293b-b18e-4222-9c40-abd6c114d464.png)\\n\\n### Other UI and UX Improvements\\n\\n#### New Loading Screen\\n\\nWe have a new loading screen, Podman Desktop style! [#2743](https://github.com/containers/podman-desktop/pull/2743).\\n\\n\\n\\n---\\n\\n## Other Notable Enhancements\\n\\n- Docker-compose can be installed system-wide [#2718](https://github.com/containers/podman-desktop/pull/2718).\\n- Show warning when creating a pod with two containers that use the same port [#2671](https://github.com/containers/podman-desktop/pull/2671).\\n- Display Kubernetes context name in pod label [#2634](https://github.com/containers/podman-desktop/pull/2634).\\n- Add Docker compatibility button using flatpak-spawn [#1925](https://github.com/containers/podman-desktop/pull/1925).\\n- Improve UI consistency of Pull Image page [#2604](https://github.com/containers/podman-desktop/pull/2604).\\n\\n---\\n\\n## Notable Bug Fixes\\n\\n- Could not install extensions on Windows 10 [#2762](https://github.com/containers/podman-desktop/pull/2762).\\n- Could not use locally built images on Kubernetes [#2710](https://github.com/containers/podman-desktop/pull/2710).\\n- Dashboard still suggests update after installation [#2648](https://github.com/containers/podman-desktop/pull/2648).\\n- Could not Play Kubernetes YAML to Podman on Windows [#2594](https://github.com/containers/podman-desktop/pull/2594).\\n- Pod label wasn\'t always shown in list [#2614](https://github.com/containers/podman-desktop/pull/2614).\\n- Dashboard button state was resetting [#2584](https://github.com/containers/podman-desktop/pull/2584).\\n- Change checkbox style so they don\'t look like stop buttons [#2723](https://github.com/containers/podman-desktop/pull/2723).\\n\\n---\\n\\n## Community Thank You\\n\\n\ud83c\udf89 We\u2019d like to say a big thank you to everyone who helped to make Podman Desktop even better. In this\\nsprint we received pull requests from the following people:\\n\\n- [wangxiaolei](https://github.com/fatelei) in [#2602 - Add meaningful tooltips to build, pull, prune buttons](https://github.com/containers/podman-desktop/pull/2602)\\n- [AsciiWolf](https://github.com/AsciiWolf) in [#2607 - fix typing error in Flathub name](https://github.com/containers/podman-desktop/pull/2607) and [#2609 - fix Flatpak install instructions](https://github.com/containers/podman-desktop/pull/2609)\\n- [Anders Bj\xf6rklund](https://github.com/afbjorklund) in [#2674 - Select engine for Lima provider](https://github.com/containers/podman-desktop/pull/2674)\\n\\n---\\n\\n## Final notes\\n\\nThe complete list of issues fixed in this release is available [here](https://github.com/containers/podman-desktop/issues?q=is%3Aclosed+milestone%3A1.1.0) and [here](https://github.com/containers/podman-desktop/issues?q=is%3Aclosed+milestone%3A1.1.0).\\n\\nGet the latest release from the [Downloads](/downloads) section of the website and boost your development journey with Podman Desktop. Additionally, visit the [GitHub repository](https://github.com/containers/podman-desktop) and see how you can help us make Podman Desktop better."},{"id":"podman-desktop-release-1.0","metadata":{"permalink":"/blog/podman-desktop-release-1.0","source":"@site/blog/2023-05-17-release-1.0.md","title":"Release Notes - Podman Desktop 1.0","description":"Podman Desktop 1.0 has been released!","date":"2023-05-17T00:00:00.000Z","formattedDate":"May 17, 2023","tags":[{"label":"podman-desktop","permalink":"/blog/tags/podman-desktop"},{"label":"release","permalink":"/blog/tags/release"},{"label":"kubernetes","permalink":"/blog/tags/kubernetes"},{"label":"kind","permalink":"/blog/tags/kind"},{"label":"openshift","permalink":"/blog/tags/openshift"}],"readingTime":5,"hasTruncateMarker":true,"authors":[{"name":"Tim deBoer","title":"Architect","url":"https://github.com/deboer-tim","imageURL":"https://github.com/deboer-tim.png","key":"deboer"}],"frontMatter":{"title":"Release Notes - Podman Desktop 1.0","description":"Podman Desktop 1.0 has been released!","slug":"podman-desktop-release-1.0","authors":["deboer"],"tags":["podman-desktop","release","kubernetes","kind","openshift"],"hide_table_of_contents":false,"image":"/img/blog/podman-desktop-release-1.0.jpg"},"prevItem":{"title":"Release Notes - Podman Desktop 1.1","permalink":"/blog/podman-desktop-release-1.1"},"nextItem":{"title":"Release Notes - Podman Desktop 0.15","permalink":"/blog/podman-desktop-release-0.15"}},"content":"import ReactPlayer from \'react-player\'\\n\\nPodman Desktop 1.0 Release! \ud83c\udf89\\n\\nWe still have many things planned, but with a little polish and a few more bug fixes we\\nfelt we\'ve reached a level of maturity and it is now time to declare our 1.0 release.\\n\\nThank you to everyone who has been with us on this journey so far! Please keep the\\nfeedback coming!\\n\\n\x3c!--Main Features--\x3e\\n\\n- **Highlighting Featured Extensions**: Easily find and install new extensions.\\n- **Featured Extensions**: Two new extensions supporting OpenShift.\\n- **Podman Machine as Root**: Ability to run a Podman machine as root.\\n- **UX and UI Improvements**: Opening external websites, editing numbers, and tooltips.\\n\\nPodman Desktop 1.0 is now available. [Click here to download it](/downloads)!\\n\\n![Podman-desktop-1-0-hero](img/podman-desktop-release-1.0/podman-desktop-release-1.0.jpg)\\n\\n\x3c!--truncate--\x3e\\n\\n---\\n\\n## Release Details\\n\\n### Highlighting Featured Extensions\\n\\nA critical part of our vision for Podman Desktop is the ability to install extensions to\\nsupport additional container engines, Kubernetes providers, or other tools. However, it\\nhas not been easy to discover new extensions.\\n\\nWith 1.0 we show a list of featured extensions in the **Welcome**\\n[#2354](https://github.com/containers/podman-desktop/pull/2354), the **Dashboard** and in\\n** Settings > Extensions**\\n[#2355](https://github.com/containers/podman-desktop/pull/2355). Check out the new\\nextensions for **Red Hat OpenShift Local** and the **Developer Sandbox for Red Hat OpenShift**!\\n\\n![Featured extensions](img/podman-desktop-release-1.0/featured-extensions.png)\\n\\n### Featured Extensions\\n\\nSpeaking of extensions, let\'s take a minute to turn the spotlight on these two!\\n\\nHave another idea for extending Podman Desktop? We would love to hear from you or see\\nwhat you can create with the [Extension documentation](/docs/extensions),\\nand feature your extension here.\\n\\n#### Red Hat OpenShift Local\\n\\nOpenShift Local is a fully-featured single-node OpenShift cluster designed to run on your local computer.\\nWith this extension you can install, start/stop, and deploy pods or YAML to OpenShift Local,\\nallowing you to test your applications on a full OpenShift environment, ensuring a consistent\\nexperience between development, test, and production.\\n\\nThe recent addition of the MicroShift preset provides a lighter, optimized option that\\nstarts faster and uses less resources for deployments that still want OpenShift compatibility\\nwithout the full set of OpenShift services.\\n\\n![OpenShift Local](img/podman-desktop-release-1.0/openshift-local.png)\\n\\n#### Developer Sandbox for Red Hat OpenShift\\n\\nThe OpenShift Developer Sandbox is a free, cloud-based OpenShift environment that allows developers to\\ncreate, build, and deploy applications to OpenShift for 30 days. With this extension you can sign up\\nand easily deploy pods or YAML to a hosted OpenShift environment without a local installation or\\nleaving Podman Desktop.\\n\\n![Developer Sandbox](img/podman-desktop-release-1.0/sandbox.png)\\n\\n### Podman Machine as Root\\n\\nWhen creating a Podman machine you can now decide to run as root [#2427](https://github.com/containers/podman-desktop/pull/2427). This is a prerequisite for some scenarios, such as running Kind on Windows.\\n\\n![Podman machine as root](img/podman-desktop-release-1.0/podman-root.png)\\n\\n### Other UI and UX Improvements\\n\\n#### Prompt to Open External Website\\n\\nIn the previous release links to external websites were blocked due to the security risk.\\nIn 1.0 you can click to see the URL and have the option of opening or copying it\\n[#2414](https://github.com/containers/podman-desktop/pull/2414).\\n\\n![External link dialog](img/podman-desktop-release-1.0/external-link.png)\\n\\n#### Editable Numeric Preferences\\n\\nTired of clicking +, +, +? Us too. Numeric preferences are now editable so\\nyou can directly enter the value you want\\n[#2368](https://github.com/containers/podman-desktop/pull/2368).\\n\\n![Editing numbers](img/podman-desktop-release-1.0/edit-number.png)\\n\\n#### Navigation tooltips\\n\\nWe like our new navigation bar, but the tooltips were slow to appear. This made it harder for new\\nusers to discover the pages and for power users to see the container/pod/image counts. The\\ntooltips are now a little nicer and appear immediately\\n[#2286](https://github.com/containers/podman-desktop/pull/2286).\\n\\n![Navigation tooltips](img/podman-desktop-release-1.0/nav-tooltips.png)\\n\\n---\\n\\n## Other Notable Enhancements\\n\\n- If you use a non-default Podman machine you are now prompted to make it the default, so\\n that command line tools will use the same machine [#2205](https://github.com/containers/podman-desktop/pull/2205).\\n\\n- Extensions can now be installed without requiring a running local container engine\\n [#2273](https://github.com/containers/podman-desktop/pull/2273).\\n\\n- When extensions fail to load there is a new state (failed!) and an error message\\n to help you fix or report the problem [#2424](https://github.com/containers/podman-desktop/pull/2424).\\n\\n- The showInputBox API has support for Markdown [#2418](https://github.com/containers/podman-desktop/pull/2418).\\n\\n---\\n\\n## Notable Bug Fixes\\n\\n- Fixed shared status when using multiple Podman 4.5 machines [#2441](https://github.com/containers/podman-desktop/pull/2441).\\n- Fixed hang on exit when telemetry is unreachable [#2431](https://github.com/containers/podman-desktop/pull/2431).\\n- Reduced initial Podman REST API calls to improve performance [#2419](https://github.com/containers/podman-desktop/pull/2419).\\n- **Play Kubernetes YAML** now honors the namespace [#2509](https://github.com/containers/podman-desktop/pull/2509).\\n- **Container** list was not remembering expand/collapsed status [#2491](https://github.com/containers/podman-desktop/pull/2491).\\n- Clear previous error when installing Docker extension [#2469](https://github.com/containers/podman-desktop/pull/2469).\\n- Ensure correct path with running Kind CLI [#2455](https://github.com/containers/podman-desktop/pull/2455).\\n- Use IPv4 over IPv6 by default [#2398](https://github.com/containers/podman-desktop/pull/2398).\\n- When changing the Kubernetes pod name, change the app name to match [#2389](https://github.com/containers/podman-desktop/pull/2389).\\n- Fixed incorrect pod status in **Containers** view [#2387](https://github.com/containers/podman-desktop/pull/2387).\\n- **Dashboard** wasn\'t correctly refreshing Podman status [#2359](https://github.com/containers/podman-desktop/pull/2359).\\n\\n---\\n\\n## Community Thank You\\n\\n\ud83c\udf89 We\u2019d like to say a big thank you to everyone who helped to make Podman Desktop even better. In this final\\nsprint we received pull requests from the following people:\\n\\n- [Taha Attari](https://github.com/TahaAttari) in [#2470 - Update docker command in importing-saved-containers.md](https://github.com/containers/podman-desktop/pull/2470)\\n- [Jason Greene](https://github.com/n1hility) in [#2431 - Fix hang on exit when telemetry endpoint is unreachable](https://github.com/containers/podman-desktop/pull/2431)\\n- [Anders Bj\xf6rklund](https://github.com/afbjorklund) in [#2571 - Fix the location of the lima podman socket](https://github.com/containers/podman-desktop/pull/2571) and [#2572 - Fix the state of the lima container provider](https://github.com/containers/podman-desktop/pull/2572)\\n- [Tucker Chapman](https://github.com/tuckerrc) in [#2567 - Add example image name in placeholder](https://github.com/containers/podman-desktop/pull/2567)\\n\\nThere are now a total of 54 people (and two bots!) who have contributed PRs to Podman Desktop, and we\'d\\nlike to extend an extra thanks to all of those outside of the immediate development team who contributed\\nto get us here:\\n\\n[afbjorklund](https://github.com/afbjorklund),\\n[alv67](https://github.com/alv67),\\n[anjannath](https://github.com/anjannath),\\n[ankanroy-code](https://github.com/ankanroy-code),\\n[arixmkii](https://github.com/arixmkii),\\n[cblecker](https://github.com/cblecker),\\n[cfergeau](https://github.com/cfergeau),\\n[chevdor](https://github.com/chevdor),\\n[chrisjsimpson](https://github.com/chrisjsimpson),\\n[cu8code](https://github.com/cu8code),\\n[doehyunbaek](https://github.com/doehyunbaek),\\n[dylanmtaylor](https://github.com/dylanmtaylor),\\n[eidottermihi](https://github.com/eidottermihi),\\n[elervik](https://github.com/elervik),\\n[emmanuelbernard](https://github.com/emmanuelbernard),\\n[evanfpearson](https://github.com/evanfpearson),\\n[gorkem](https://github.com/gorkem),\\n[idjohnson](https://github.com/idjohnson),\\n[imphil](https://github.com/imphil),\\n[iongion](https://github.com/iongion),\\n[jlosito](https://github.com/jlosito),\\n[KevinAtSesam](https://github.com/KevinAtSesam),\\n[lsm5](https://github.com/lsm5),\\n[Mitch9378](https://github.com/Mitch9378),\\n[n1hility](https://github.com/n1hility),\\n[osslate](https://github.com/osslate),\\n[PatentLobster](https://github.com/PatentLobster),\\n[pwright](https://github.com/pwright),\\n[rdwz](https://github.com/rdwz),\\n[redhatrises](https://github.com/redhatrises),\\n[rhatdan](https://github.com/rhatdan),\\n[RobotSail](https://github.com/RobotSail),\\n[rohit-rambade](https://github.com/rohit-rambade),\\n[rsvoboda](https://github.com/rsvoboda),\\n[sfrunza13](https://github.com/sfrunza13),\\n[shemanaev](https://github.com/shemanaev),\\n[sstosh](https://github.com/sstosh),\\n[stickster](https://github.com/stickster),\\n[TahaAttari](https://github.com/TahaAttari),\\n[ths83](https://github.com/ths83),\\n[Tony-Sol](https://github.com/Tony-Sol),\\n[tuckerrc](https://github.com/tuckerrc),\\n[ucomesdag](https://github.com/ucomesdag),\\n[xbabalov](https://github.com/xbabalov),\\nzezo2019.\\n\\n---\\n\\n## Final notes\\n\\nThe complete list of issues fixed in this release is available [here](https://github.com/containers/podman-desktop/issues?q=is%3Aclosed+milestone%3A1.0.0) and [here](https://github.com/containers/podman-desktop/issues?q=is%3Aclosed+milestone%3A1.0.1).\\n\\nGet the latest release from the [Downloads](/downloads) section of the website and boost your development journey with Podman Desktop. Additionally, visit the [GitHub repository](https://github.com/containers/podman-desktop) and see how you can help us make Podman Desktop better."},{"id":"podman-desktop-release-0.15","metadata":{"permalink":"/blog/podman-desktop-release-0.15","source":"@site/blog/2023-05-02-release-0.15.md","title":"Release Notes - Podman Desktop 0.15","description":"Podman Desktop 0.15 has been released!","date":"2023-05-02T00:00:00.000Z","formattedDate":"May 2, 2023","tags":[{"label":"podman-desktop","permalink":"/blog/tags/podman-desktop"},{"label":"release","permalink":"/blog/tags/release"},{"label":"kubernetes","permalink":"/blog/tags/kubernetes"},{"label":"kind","permalink":"/blog/tags/kind"}],"readingTime":3.685,"hasTruncateMarker":true,"authors":[{"name":"Tim deBoer","title":"Architect","url":"https://github.com/deboer-tim","imageURL":"https://github.com/deboer-tim.png","key":"deboer"}],"frontMatter":{"title":"Release Notes - Podman Desktop 0.15","description":"Podman Desktop 0.15 has been released!","slug":"podman-desktop-release-0.15","authors":["deboer"],"tags":["podman-desktop","release","kubernetes","kind"],"hide_table_of_contents":false,"image":"/img/blog/podman-desktop-release-0.15.webp"},"prevItem":{"title":"Release Notes - Podman Desktop 1.0","permalink":"/blog/podman-desktop-release-1.0"},"nextItem":{"title":"Setting up and running a Kubernetes cluster locally with Podman Desktop","permalink":"/blog/running-a-local-kubernetes-cluster-with-podman-desktop"}},"content":"import ReactPlayer from \'react-player\'\\n\\nPodman Desktop 0.15 - Cleanliness is next to Podliness!\\n\\nIt has only been two weeks since our last release, but we really wanted to complete a few scenarios,\\nfix a few bugs, and show off several design updates and UI improvements that we have been working on.\\n\\n\x3c!--Main Features--\x3e\\n\\n- **Podman Version**: Podman 4.5 now included in Windows and Mac installers.\\n- **Kind Ingress**: Creating an ingress to expose services outside the Kind cluster.\\n- **Podliness**: Ability to choose external ports when podifying containers.\\n- **Cleanliness**: New navigation bar, dialog, and palette update.\\n- **UX and UI Improvements**: Markdown support for extensions.\\n\\nPodman Desktop 0.15 is now available. [Click here to download it](/downloads)!\\n\\n![Podman-desktop-0-15-hero](img/podman-desktop-release-0.15/podman-desktop-release-0.15.webp)\\n\\n\x3c!--truncate--\x3e\\n\\n---\\n\\n## Release Details\\n\\n### Update to Podman v4.5.O\\n\\nPodman Desktop 0.15 embeds [Podman 4.5.0](https://github.com/containers/podman/releases/tag/v4.5.0) in\\nWindows and macOS installers [#2115](https://github.com/containers/podman-desktop/issues/2115).\\n\\n### Kind Ingress\\n\\nWait a minute, didn\'t we enable this last release? Well yes, last time we did add support for installing\\nthe Contour ingress controller on Kind [#1675](https://github.com/containers/podman-desktop/issues/1675),\\nbut you still couldn\'t access your containers without the corresponding ingress.\\n\\nThis release adds a simple checkbox you can use when deploying to Kind to create an ingress and\\nmake your service accessible [#1322](https://github.com/containers/podman-desktop/issues/1322).\\n\\n\\n\\n### Podliness: Ability to Choose External Ports when Podifying Containers\\n\\nWhen you create a pod from of a set of containers (Podifying!), you probably don\'t want to expose every\\nsingle port from every container to the world. With an updated panel you can now see which ports each container\\nexposes, pick which should remain visible outside the pod, and which are for internal use\\n[#2232](https://github.com/containers/podman-desktop/pull/2232).\\n\\n![Podify page](https://user-images.githubusercontent.com/49404737/234527674-ed14f52c-8f66-445f-8038-c8135bb61136.gif)\\n\\n### Cleanliness: New Navigation Bar, Dialogs, and Palette\\n\\nIt was time to catch up on some design ideas and do some UI cleanup!\\n\\n#### New Navgation Bar\\n\\nThe navigation bar is now always fixed on the left size, without labels. This opens up more space\\nfor the content on each page, and is easier to jump in and out of ** Settings**.\\n[#2167](https://github.com/containers/podman-desktop/issues/2167)\\n\\n![Navigation bar](img/podman-desktop-release-0.15/navigation.png)\\n\\n#### Updated Dialogs\\n\\nWe wanted messages and dialog boxes to feel a bit more integrated, so we have a new message box\\n[#1808](https://github.com/containers/podman-desktop/pull/1808) and use it for all dialogs opened by\\nextensions, pruning containers/pods/images/volumes [#2138](https://github.com/containers/podman-desktop/pull/2138),\\nand updating Podman Desktop itself [#2249](https://github.com/containers/podman-desktop/pull/2249).\\n\\n![Dialog](img/podman-desktop-release-0.15/dialog.png)\\n\\n#### Colors\\n\\nWe spent some time tweaking colors and closing on our final palette\\n[#2199](https://github.com/containers/podman-desktop/pull/2199), updating the colors in the terminal & detail page\\n[#2222](https://github.com/containers/podman-desktop/pull/2222), tweaking the navigation and main page colors\\n[#2223](https://github.com/containers/podman-desktop/pull/2223),\\nand improving the look of forms [#2156](https://github.com/containers/podman-desktop/issues/2156).\\n\\nWe\'re not done yet, but hopefully you will notice a more polished, consistent, good-looking application!\\n\\n### Other UI and UX Improvements\\n\\n#### Markdown Support for Extensions\\n\\nWe added a new component to display markdown [#2219](https://github.com/containers/podman-desktop/pull/2219) and\\nenabled it in preferences [#2253](https://github.com/containers/podman-desktop/pull/2253), and\\nprovider properties/creation pages [#2152](https://github.com/containers/podman-desktop/issues/2152).\\nWe can now embed links and other formatting in preferences, and extensions can use them in many places, for example:\\n\\n![Markdown](img/podman-desktop-release-0.15/markdown.png)\\n\\n---\\n\\n## Other Notable Enhancements\\n\\n- We know which **Settings** page is used the most often, so now it\'s the default: ** Settings > Resources** [#2105](https://github.com/containers/podman-desktop/issues/2105).\\n\\n- Extensions can now use the Tasks API to let long running tasks continue in the background [#2019](https://github.com/containers/podman-desktop/issues/2019) and the existing withProgress API also uses the task manager now\\n [#2187](https://github.com/containers/podman-desktop/pull/2187).\\n\\n![Task API](https://user-images.githubusercontent.com/695993/233560830-85cfa685-5dcd-4efa-9fae-730a8a9eef3b.gif)\\n\\n- Images are now sorted by age [#2311](https://github.com/containers/podman-desktop/pull/2311).\\n\\n- When you start/stop a container or pod, the button is now animated instead of having an separate spinner\\n [#2101](https://github.com/containers/podman-desktop/issues/2101).\\n\\n- The ** Settings > Preferences** page now has a search bar [#2128](https://github.com/containers/podman-desktop/pull/2128).\\n\\n![Search preferences](img/podman-desktop-release-0.15/prefs.png)\\n\\n- The Help page has been updated [#431](https://github.com/containers/podman-desktop/issues/431).\\n\\n![Updated Help](img/podman-desktop-release-0.15/help.png)\\n\\n---\\n\\n## Notable Bug Fixes\\n\\n- There was no way to see log or outcome if you leave the Kind cluster creation page [#2079](https://github.com/containers/podman-desktop/issues/2079).\\n- Kind image load doesn\'t show a notification [#2225](https://github.com/containers/podman-desktop/issues/2225).\\n- Fix odd selection in ** Settings > Extensions** [#2130](https://github.com/containers/podman-desktop/issues/2130).\\n- Menus are now cleaned up properly when extensions are stopped [#2188](https://github.com/containers/podman-desktop/pull/2188).\\n- Kind clusters are now cleaned up when Podman machine is stopped [#2306](https://github.com/containers/podman-desktop/pull/2306).\\n\\n---\\n\\n## Final notes\\n\\nThe complete list of issues fixed in this release is available [here](https://github.com/containers/podman-desktop/issues?q=is%3Aclosed+milestone%3A0.15.0).\\n\\nGet the latest release from the [Downloads](/downloads) section of the website and boost your development journey with Podman Desktop. Additionally, visit the [GitHub repository](https://github.com/containers/podman-desktop) and see how you can help us make Podman Desktop better."},{"id":"running-a-local-kubernetes-cluster-with-podman-desktop","metadata":{"permalink":"/blog/running-a-local-kubernetes-cluster-with-podman-desktop","source":"@site/blog/2023-04-19-running-a-local-kubernetes-cluster-with-podman-desktop.md","title":"Setting up and running a Kubernetes cluster locally with Podman Desktop","description":"Setting up and running a Kubernetes cluster locally with Podman Desktop","date":"2023-04-19T00:00:00.000Z","formattedDate":"April 19, 2023","tags":[{"label":"podman-desktop","permalink":"/blog/tags/podman-desktop"},{"label":"story","permalink":"/blog/tags/story"},{"label":"kubernetes","permalink":"/blog/tags/kubernetes"},{"label":"kind","permalink":"/blog/tags/kind"}],"readingTime":8.86,"hasTruncateMarker":true,"authors":[{"name":"Fabrice Flore-Thebault","title":"Technical writer","url":"https://github.com/themr0c","imageURL":"https://github.com/themr0c.png","key":"themr0c"}],"frontMatter":{"title":"Setting up and running a Kubernetes cluster locally with Podman Desktop","description":"Setting up and running a Kubernetes cluster locally with Podman Desktop","slug":"running-a-local-kubernetes-cluster-with-podman-desktop","authors":["themr0c"],"tags":["podman-desktop","story","kubernetes","kind"],"hide_table_of_contents":false},"prevItem":{"title":"Release Notes - Podman Desktop 0.15","permalink":"/blog/podman-desktop-release-0.15"},"nextItem":{"title":"Release Notes - Podman Desktop 0.14","permalink":"/blog/podman-desktop-release-0.14"}},"content":"In this blog post you will learn to use Podman Desktop to run the [Kubernetes documentation example: Deploying PHP Guestbook application with Redis](https://kubernetes.io/docs/tutorials/stateless-application/guestbook/).\\n\\nOn the agenda:\\n\\n1. Installing Podman Desktop.\\n1. Installing and initializing your container engine: Podman.\\n1. Installing and starting your local Kubernetes provider: Kind.\\n1. Starting the Redis leader.\\n1. Starting and scaling the Redis followers.\\n1. Starting and exposing the Guestbook frontend.\\n\\n\x3c!--truncate--\x3e\\n\\n## Installing Podman Desktop\\n\\nYou need Podman Desktop.\\n\\n1. Go to [Podman Desktop installation documentation](/docs/installation).\\n1. Click on your platform name: [Windows](/docs/installation/windows-install), [macOS](/docs/installation/macos-install), or [Linux](/docs/installation/linux-install).\\n1. Follow the instructions. Stick to the default installation method.\\n1. Start **Podman Desktop**.\\n\\nAt this point, you have a graphical user interface to:\\n\\n- Install Podman and Kind.\\n- Control and work with your container engines and Kubernetes clusters.\\n- Run your application on your container engine and migrate it to Kubernetes.\\n\\n## Installing and initializing your container engine: Podman\\n\\nPodman Desktop can control various container engines, such as:\\n\\n- Docker\\n- Lima\\n- Podman\\n\\nConsider installing the Podman container engine for:\\n\\n- Added security\\n- No daemon\\n- Open source\\n\\nContainers are a Linux technology.\\n\\n- On Linux, you can install Podman natively.\\n See: [Installing Podman on Linux](https://podman.io/docs/installation#installing-on-linux).\\n- On macOS and Windows, Podman requires to run in a Linux virtual machine: the Podman machine.\\n Use Podman Desktop to install Podman and initialize your Podman machine:\\n\\n#### Procedure\\n\\n1. Open Podman Desktop **Dashboard**\\n1. The **Dashboard** displays _Podman Desktop was not able to find an installation of Podman_.\\n1. Click on **Install**.\\n1. Podman Desktop checks the prerequisites to install Podman Engine. When necessary, follow the instructions to install prerequisites.\\n1. Podman displays the dialog: _Podman is not installed on this system, would you like to install Podman?_. Click on **Yes** to install Podman.\\n1. Click on **Initialize and start**.\\n\\n#### Verification\\n\\n- The **Dashboard** displays _Podman is running_.\\n\\n ![Podman is running](img/running-a-local-kubernetes-cluster-with-podman-desktop/podman-is-running.png)\\n\\nAt this point, you can start working with containers.\\n\\n## Installing and starting your local Kubernetes provider: Kind\\n\\nYou want to deploy your application to a local Kubernetes cluster.\\n\\nPodman Desktop can help you run Kind-powered local Kubernetes clusters on a container engine, such as Podman.\\n\\nPodman Desktop helps you [installing the `kind` CLI](/docs/kind/installing):\\n\\n1. In the status bar, click on **Kind**, and follow the prompts.\\n1. When the `kind` CLI is available, the status bar does not display **Kind**.\\n1. On Windows, [configure Podman in rootful mode](/docs/kind/configuring-podman-for-kind-on-windows)\\n\\n ```shell-session\\n $ podman system connection default podman-machine-default-root\\n ```\\n\\n1. Go to ** Settings > Resources**\\n1. In the **\\"Podman Podman** tile, click on the **** icon to restart the Podman container engine.\\n1. In the **\\"Kind Kind** tile, click on the **Create new** button.\\n 1. **Name**: enter `kind-cluster`.\\n 1. **Provider Type**: select `podman`.\\n 1. **HTTP Port**: select `9090`.\\n 1. **HTTPS Port**: select `9443`.\\n 1. **Setup an ingress controller**: `Enabled`\\n 1. Click the **Create** button.\\n ![Create a Kind cluster screen](img/running-a-local-kubernetes-cluster-with-podman-desktop/create-a-kind-cluster.png)\\n1. After successful creation, click on the **Go back to resources** button\\n\\n#### Verification\\n\\n1. In ** Settings > Resources** your Kind cluster is running/\\n\\n ![Kind cluster is running](img/running-a-local-kubernetes-cluster-with-podman-desktop/kind-cluster-is-running.png)\\n\\n1. In the **Podman Desktop** tray, open the **Kubernetes** menu: you can set the context to your Kind cluster: `kind-kind-cluster`.\\n\\n ![Kind cluster Kubernetes context in the tray](img/running-a-local-kubernetes-cluster-with-podman-desktop/kind-cluster-context-in-the-tray.png)\\n\\n At this point, you can start working with containers, and your local Kubernetes cluster.\\n\\n#### Additional resources\\n\\n- [Creating a local Kind-powered Kubernetes cluster](/docs/kind/creating-a-kind-cluster)\\n\\n## Starting the Redis leader\\n\\nThe Guestbook application uses Redis to store its data.\\n\\nWith Podman Desktop, you can prepare the Redis leader image and container on your local container engine, and deploy the results to a Kubernetes pod and service.\\nThis is functionally equal to the `redis-leader` deployment that the Kubernetes example propose.\\n\\n#### Procedure\\n\\n1. Open ** Images > Pull an image**.\\n 1. **Image to Pull**: enter `docker.io/redis:6.0.5`\\n 1. Click **Pull image** to pull the image to your container engine local image registry.\\n 1. Click **Done** to get back to the images list.\\n1. ** Search images**: enter `redis:6.0.5` to find the image.\\n1. Click **** to open the **Create a container from image** dialog.\\n 1. **Container name**: enter `leader`,\\n 1. **Local port for `6379/tcp`**: `6379`.\\n 1. Click ** Start Container** to start the container in your container engine.\\n1. ** Search containers**: enter `leader` to find the running container.\\n1. Click **** to stop the container, and leave the `6379` port available for the Redis follower container.\\n\\n1. Click ** > Deploy to Kubernetes** to open the **Deploy generated pod to Kubernetes** screen.\\n\\n 1. **Pod Name**: enter `redis-leader`.\\n 1. **Use Kubernetes Services**: select **Replace `hostPort` exposure on containers by Services. It is the recommended way to expose ports, as a cluster policy might prevent to use `hostPort`.**\\n 1. **Expose service locally using Kubernetes Ingress**: deselect **Create a Kubernetes ingress to get access to the ports that this pod exposes, at the default ingress controller location. Example: on a default Kind cluster created with Podman Desktop: `http://localhost:9090`. Requirements: your cluster has an ingress controller`**.\\n 1. **Kubernetes namespaces**: select `default`.\\n 1. Click ** Deploy**.\\n ![Deploy generated leader pod to Kubernetes screen](img/running-a-local-kubernetes-cluster-with-podman-desktop/deploy-generated-leader-pod-to-kubernetes.png)\\n 1. Wait for the pod to reach the state: **Phase: Running**.\\n 1. Click **Done**.\\n\\n#### Verification\\n\\n- The ** Pods** screen lists the running `redis-leader` pod.\\n\\n ![leader pod is running](img/running-a-local-kubernetes-cluster-with-podman-desktop/leader-pod-is-running.png)\\n\\n## Starting the Redis followers\\n\\nAlthough the Redis leader is a single Pod, you can make it highly available and meet traffic demands by adding a few Redis followers, or replicas.\\n\\n**With Podman Desktop, you can prepare the Redis follower image and container on your local container engine, and deploy the results to Kubernetes pods and services.**\\nThis is functionally equal to the `redis-follower` deployment that the Kubernetes example propose.\\n\\n#### Procedure\\n\\n1. Open ** Images > Pull an image**.\\n 1. **Image to Pull**: enter `gcr.io/google_samples/gb-redis-follower:v2`\\n 1. Click **Pull image** to pull the image to your container engine local image registry.\\n 1. Click **Done** to get back to the images list.\\n1. ** Search images**: enter `gb-redis-follower:v2` to find the image.\\n1. Click **** to open the **Create a container from image** dialog.\\n 1. **Container name**: enter `follower`,\\n 1. **Local port for `6379/tcp`**: `6379`.\\n 1. Click ** Start Container** to start the container in your container engine.\\n1. ** Search containers**: enter `follower` to find the running container.\\n1. Click **** to stop the container: you do not need it to run in the container engine.\\n1. Click ** > Deploy to Kubernetes** to open the **Deploy generated pod to Kubernetes** screen.\\n 1. **Pod Name**: enter `redis-follower`.\\n 1. **Use Kubernetes Services**: select **Replace `hostPort` exposure on containers by Services. It is the recommended way to expose ports, as a cluster policy might prevent to use `hostPort`.**\\n 1. **Expose service locally using Kubernetes Ingress**: deselect **Create a Kubernetes ingress to get access to the ports that this pod exposes, at the default ingress controller location. Example: on a default Kind cluster created with Podman Desktop: `http://localhost:9090`. Requirements: your cluster has an ingress controller`**.\\n 1. **Kubernetes namespaces**: select `default`.\\n 1. Click ** Deploy**.\\n ![Deploy generated follower pod to Kubernetes screen](img/running-a-local-kubernetes-cluster-with-podman-desktop/deploy-generated-follower-pod-to-kubernetes.png)\\n 1. Wait for the pod to reach the state: **Phase: Running**.\\n 1. Click **Done**.\\n1. To add replicas, repeat the last step with another **Pod Name** value.\\n\\n#### Verification\\n\\n- The ** Pods** screen lists the running `redis-follower` pods.\\n\\n ![follower pods are running](img/running-a-local-kubernetes-cluster-with-podman-desktop/follower-pods-are-running.png)\\n\\n## Starting the default frontend\\n\\nNow that you have the Redis storage of your Guestbook up and running, start the Guestbook web servers.\\nLike the Redis followers, deploy the frontend using Kubernetes pods and services.\\n\\nThe Guestbook app uses a PHP frontend.\\nIt is configured to communicate with either the Redis follower or leader Services, depending on whether the request is a read or a write.\\nThe frontend exposes a JSON interface, and serves a jQuery-Ajax-based UX.\\n\\nWith Podman Desktop, you can prepare the Guestbook frontend image and container on your local container engine, and deploy the results to Kubernetes pods and services.\\nThis is functionally equal to the `frontend` deployment that the Kubernetes example propose.\\n\\n#### Procedure\\n\\n1. Open ** Images > Pull an image**.\\n 1. **Image to Pull**: enter `gcr.io/google_samples/gb-frontend:v5`\\n 1. Click **Pull image** to pull the image to your container engine local image registry.\\n 1. Wait for the pull to complete.\\n 1. Click **Done** to get back to the images list.\\n1. ** Search images**: enter `gb-frontend:v5` to find the image.\\n1. Click **** to open the **Create a container from image** dialog.\\n 1. **Container name**: enter `frontend`,\\n 1. **Local port for `80/tcp`**: `9000`.\\n 1. Click ** Start Container** to start the container in your container engine.\\n1. ** Search containers**: enter `frontend` to find the running container.\\n1. Click **** to stop the container: you do not need it to run in the container engine.\\n1. Click ** > Deploy to Kubernetes** to open the **Deploy generated pod to Kubernetes** screen.\\n 1. **Pod Name**: enter `frontend`.\\n 1. **Use Kubernetes Services**: select **Replace `hostPort` exposure on containers by Services. It is the recommended way to expose ports, as a cluster policy might prevent to use `hostPort`.**\\n 1. **Expose service locally using Kubernetes Ingress**: select **Create a Kubernetes ingress to get access to the ports that this pod exposes, at the default ingress controller location. Example: on a default Kind cluster created with Podman Desktop: `http://localhost:9090`. Requirements: your cluster has an ingress controller`**.\\n 1. **Kubernetes namespaces**: select `default`.\\n 1. Click ** Deploy**.\\n ![Deploy generated frontend pod to Kubernetes screen](img/running-a-local-kubernetes-cluster-with-podman-desktop/deploy-generated-frontend-pod-to-kubernetes.png)\\n 1. Wait for the pod to reach the state: **Phase: Running**.\\n 1. Click **Done**.\\n\\n#### Verification\\n\\n1. The ** Pods** screen lists the running `frontend` pod.\\n\\n ![`frontend` pod is running](img/running-a-local-kubernetes-cluster-with-podman-desktop/frontend-pod-is-running.png)\\n\\n1. Go to `http://localhost:9090`: the Guestbook application is running."},{"id":"podman-desktop-release-0.14","metadata":{"permalink":"/blog/podman-desktop-release-0.14","source":"@site/blog/2023-04-14-release-0.14.md","title":"Release Notes - Podman Desktop 0.14","description":"Podman Desktop 0.14 has been released!","date":"2023-04-14T00:00:00.000Z","formattedDate":"April 14, 2023","tags":[{"label":"podman-desktop","permalink":"/blog/tags/podman-desktop"},{"label":"release","permalink":"/blog/tags/release"},{"label":"kubernetes","permalink":"/blog/tags/kubernetes"},{"label":"kind","permalink":"/blog/tags/kind"}],"readingTime":4.025,"hasTruncateMarker":true,"authors":[{"name":"Tim deBoer","title":"Architect","url":"https://github.com/deboer-tim","imageURL":"https://github.com/deboer-tim.png","key":"deboer"}],"frontMatter":{"title":"Release Notes - Podman Desktop 0.14","description":"Podman Desktop 0.14 has been released!","slug":"podman-desktop-release-0.14","authors":["deboer"],"tags":["podman-desktop","release","kubernetes","kind"],"hide_table_of_contents":false},"prevItem":{"title":"Setting up and running a Kubernetes cluster locally with Podman Desktop","permalink":"/blog/running-a-local-kubernetes-cluster-with-podman-desktop"},"nextItem":{"title":"Release Notes - Podman Desktop 0.13","permalink":"/blog/podman-desktop-release-0.13"}},"content":"import ReactPlayer from \'react-player\'\\n\\nPodman Desktop 0.14 - Our Kind-est release yet!\\n\\nWe have been working on a Kind extension for a while now, and decided it is time to promote it\\ninto a release just in time for KubeCon and CloudNativeCon Europe!\\n\\nWe\'re especially excited about releasing Kind because it finally shows the full purpose\\nof Podman Desktop: not just local container engines, but Kubernetes too. More importantly,\\nproviding tools that allow you to manage both environments and seamlessly move between them.\\n\\nSome of these features were available in development mode over the last few releases,\\nbut since they are now in the release build, we will do a full roundup and talk about\\nall the Kind features.\\n\\n\x3c!--Main Features--\x3e\\n\\n- **Kind Installation**: Install Kind from the status bar\\n- **Manage Kind Clusters**: Create and manage Kind clusters from ** Settings > Resources**\\n- **Using Kind**: Deploying YAML and sharing images to a cluster\\n- **Kind Ingress**: Install a Contour ingress controller\\n- **UX and UI Improvements**: Updated preferences and telemetry prompt\\n\\nPodman Desktop 0.14 is now available. [Click here to download it](/downloads)!\\n\\n![Podman-desktop-0-14-hero](img/podman-desktop-release-0.14/podman-desktop-release-0.14.png)\\n\\n\x3c!--truncate--\x3e\\n\\n---\\n\\n## Release details\\n\\n### Kind Installation\\n\\nGet Kind up and running in seconds! The Kind extension is now bundled as part of Podman Desktop\\n[1421](https://github.com/containers/podman-desktop/issues/1421)\\nand allows you to easily [install Kind directly from the status bar](/docs/kind/installing)\\n[1257](https://github.com/containers/podman-desktop/issues/1257).\\n\\nThe installed `kind` CLI is available from the system shell [1516](https://github.com/containers/podman-desktop/issues/1516),\\nallowing you to open a terminal window to `kind get clusters` or work with other tools.\\n\\n### Manage Kind Clusters\\n\\nOnce Kind is installed (or if you already had it), you can manage your clusters in ** Settings > Resources**.\\nFrom here you can [create Kind clusters](/docs/kind/creating-a-kind-cluster),\\nstart/stop [1953](https://github.com/containers/podman-desktop/issues/1953)\\nor delete [1977](https://github.com/containers/podman-desktop/issues/1977) them.\\n\\n![kind-clusters](img/podman-desktop-release-0.14/kind-clusters.png)\\n\\nThe Kind control plane runs as a container. You will see this container\\nin the **Container** list and can also start or stop it from there.\\n\\n### Using Kind\\n\\nNow that you have Kind installed and running, what can you do with it?\\nIf you like terminals, you can always open one up and use the Kind CLI to\\n[interact with your cluster](https://kind.sigs.k8s.io/docs/user/quick-start/#interacting-with-your-cluster).\\n\\nWithin Podman Desktop we have started with two ways to interact with the cluster.\\nThe first is the ability to play local YAML files on your Kind (or any other Kubernetes!) cluster [1261](https://github.com/containers/podman-desktop/issues/1261). This allows you to take existing Kubernetes YAML definitions -\\nyour deployments, services, or other objects - and deploy it to the cluster.\\n\\n\\n\\nAs you deploy pods, they will automatically appear in the list of **Pods** [1263](https://github.com/containers/podman-desktop/issues/1263), allowing you to start, stop, and interact them just like pods running on Podman.\\n\\nOne of the most common uses is to deploy a container that you have been running on Podman, and this will fail\\nif the image is not available in Kind. To solve this we have made it easy to push images from\\nPodman to Kind [1448](https://github.com/containers/podman-desktop/issues/1448).\\n\\n![push-image-kind](img/podman-desktop-release-0.14/push-image-kind.png)\\n\\n### Kind Ingress\\n\\nIf you deploy a pod to Kind, you are also going to want to reach it! To do this you will need to install a load balancer or\\ningress controller so that the pod is accessible from outside the cluster. We made it easy to install the Contour ingress\\ncontroller while creating a Kind cluster [1675](https://github.com/containers/podman-desktop/issues/1675),\\nso if you created your cluster with Podman Desktop it is already there!\\n\\n![kind-ingress](img/podman-desktop-release-0.14/kind-ingress.png)\\n\\nWe have several other Kind and Kubernetes features planned to expand the supported scenarios, but hopefully this\\nmakes it easy to get started with Kind and shows where we\'re headed. As always, feedback is appreciated!\\n\\n### UI and UX improvements\\n\\n#### Updated Preferences\\n\\nThe ** Settings > Preferences** page has been updated with a new design [1913](https://github.com/containers/podman-desktop/pull/1913),\\nmaking it easier to see and change preferences. Changes are live, no more Update button.\\n\\n![preferences](https://user-images.githubusercontent.com/49404737/229498507-e754b55c-dcbd-486d-9ee3-a1fe3bed7271.gif)\\n\\n#### Telemetry Prompt\\n\\nThe prompt to enable or disable telemetry has been moved from its own dialog into the **Welcome** screen.\\n[1927](https://github.com/containers/podman-desktop/pull/1927)\\nThis is more usable, one less prompt, and solves a window-layering issue for some users!\\n\\n![telemetry prompt](https://user-images.githubusercontent.com/19958075/229577331-365a9a01-0426-4482-a95d-f5dfe39af90a.png)\\n\\n---\\n\\n## Other notable enhancements\\n\\n- Extension support for opening an external URL [2028](https://github.com/containers/podman-desktop/pull/2028) and\\n accessing the clipboard [2023](https://github.com/containers/podman-desktop/pull/2023)\\n\\n---\\n\\n## Documentation\\n\\nNaturally, we have a section in the documentation just for [Kind](https://podman-desktop.io/docs/kind).\\n\\n---\\n\\n## Notable bug fixes\\n\\n- Avoid a dialog box if unable to check for updates [2062](https://github.com/containers/podman-desktop/pull/2062)\\n- Unable to get to the Dashboard if Kind (or Kubernetes) cluster was not running [2052](https://github.com/containers/podman-desktop/issues/2052)\\n\\n---\\n\\n## Final notes\\n\\nThe complete list of issues fixed in this release is available [here](https://github.com/containers/podman-desktop/issues?q=is%3Aclosed+milestone%3A0.14.0).\\n\\nGet the latest release from the [Downloads](/downloads) section of the website and boost your development journey with Podman Desktop. Additionally, visit the [GitHub repository](https://github.com/containers/podman-desktop) and see how you can help us make Podman Desktop better."},{"id":"podman-desktop-release-0.13","metadata":{"permalink":"/blog/podman-desktop-release-0.13","source":"@site/blog/2023-03-29-release-0.13.md","title":"Release Notes - Podman Desktop 0.13","description":"Podman Desktop 0.13 has been released!","date":"2023-03-29T00:00:00.000Z","formattedDate":"March 29, 2023","tags":[{"label":"podman-desktop","permalink":"/blog/tags/podman-desktop"},{"label":"release","permalink":"/blog/tags/release"},{"label":"kubernetes","permalink":"/blog/tags/kubernetes"},{"label":"compose","permalink":"/blog/tags/compose"}],"readingTime":3.155,"hasTruncateMarker":true,"authors":[{"name":"Tim deBoer","title":"Architect","url":"https://github.com/deboer-tim","imageURL":"https://github.com/deboer-tim.png","key":"deboer"}],"frontMatter":{"title":"Release Notes - Podman Desktop 0.13","description":"Podman Desktop 0.13 has been released!","slug":"podman-desktop-release-0.13","authors":["deboer"],"tags":["podman-desktop","release","kubernetes","compose"],"hide_table_of_contents":false},"prevItem":{"title":"Release Notes - Podman Desktop 0.14","permalink":"/blog/podman-desktop-release-0.14"},"nextItem":{"title":"5 things to know about Podman Desktop for a Docker user","permalink":"/blog/5-things-to-know-for-a-docker-user"}},"content":"import ReactPlayer from \'react-player\'\\n\\nThis release note covers Podman Desktop 0.13 release changes.\\n\\n\x3c!--Main Features--\x3e\\n\\n- **Podman Version**: Podman 4.4.4 now included in Windows and Mac installers.\\n- **Compose**: Support for installing Docker Compose.\\n- **Extensions**: Improved extension support for Podman Desktop with additional capabilities.\\n- **UX and UI Improvements**: Welcome page, task manager, resources, and update alerts.\\n\\nPodman Desktop 0.13 is now available. [Click here to download it](/downloads)!\\n\\n![Podman-desktop-0-13-hero](img/podman-desktop-release-0.13/podman-desktop-release-0.13.png)\\n\\n\x3c!--truncate--\x3e\\n\\n---\\n\\n## Release details\\n\\n### Update to Podman v4.4.4\\n\\nPodman Desktop 0.13 embeds [Podman 4.4.4](https://github.com/containers/podman/releases/tag/v4.4.4) in\\nWindows and macOS installers [#1456](https://github.com/containers/podman-desktop/pull/1456).\\n\\n### Compose support\\n\\nYou can install Docker Compose from the Podman Desktop UI [#1578](https://github.com/containers/podman-desktop/pull/1578). This will allow you use Compose workflows using Podman.\\n\\n### Extensions\\n\\nTo make it easier to extend Podman Desktop we have:\\n\\n- Published the [Podman Desktop Extension API](https://www.npmjs.com/package/@podman-desktop/api) to npmjs [#1727](https://github.com/containers/podman-desktop/pull/1727)\\n- Documented [how to create, publish, and install your own extensions](https://podman-desktop.io/docs/extensions)\\n- Expanded the API for `QuickPickInput` [#1839](https://github.com/containers/podman-desktop/pull/1839)\\n\\n### UI and UX improvements\\n\\n#### Welcome page [#1726](https://github.com/containers/podman-desktop/pull/1726)\\n\\nThe first time every user starts Podman Desktop, they will see a welcome page:\\n\\n![welcome-page](https://user-images.githubusercontent.com/19958075/225682776-e016ba31-5bb9-41d5-87ed-f93caeb3fb84.png)\\n\\nNote that the Welcome page will only appear the first time you run Podman Desktop 0.13.0, and none of your settings or assets in Podman Desktop will be affected by it.\\nOver time, this page will be expanded to help with initial setup and configuration.\\n\\n#### New Task Manager [#1724](https://github.com/containers/podman-desktop/pull/1724)\\n\\nA new Task Manager has been added to the status bar to see the progress (or return to) long running tasks. To start with, building images [#1725](https://github.com/containers/podman-desktop/pull/1725) and Podman machine [#1742](https://github.com/containers/podman-desktop/pull/1742) are using the task manager.\\n\\n![task-manager](img/podman-desktop-release-0.13/task-manager.png)\\n\\n#### Updated Resources Settings [#1582](https://github.com/containers/podman-desktop/pull/1582)\\n\\nThe ** Settings > Resources** page has been updated with a new design, making it easier to see and control your providers from a single place.\\n\\n![resources](https://user-images.githubusercontent.com/49404737/221908815-595715fe-4c95-4087-89e0-45e5544ed5c9.gif)\\n\\nThe other settings pages have been updated for consistency with this new design.\\n\\n#### Update Alerts [#1827](https://github.com/containers/podman-desktop/pull/1827)\\n\\nA new alert button will appear in the status bar when future updates are available.\\n\\n\\n\\n#### Prune buttons [#1481](https://github.com/containers/podman-desktop/pull/1481), [#1482](https://github.com/containers/podman-desktop/pull/1482), [#1484](https://github.com/containers/podman-desktop/pull/1484)\\n\\nWe\'ve added buttons to prune unused volumes [#1481](https://github.com/containers/podman-desktop/pull/1481), images [#1482](https://github.com/containers/podman-desktop/pull/1482) and pods [#1484](https://github.com/containers/podman-desktop/pull/1484).\\n\\n![prune-image](img/podman-desktop-release-0.13/prune-image.png)\\n\\n---\\n\\n## Other notable enhancements\\n\\n- Kubernetes pods are now shown in the Pods view [#1312](https://github.com/containers/podman-desktop/pull/1312)\\n- Easy button to fix Docker compatibility mode on macOS [#1697](https://github.com/containers/podman-desktop/pull/1697)\\n- Display extension icons [#1058](https://github.com/containers/podman-desktop/pull/1058)\\n- API to cancel long running tasks [#1777](https://github.com/containers/podman-desktop/pull/1777)\\n\\n---\\n\\n## Documentation\\n\\nThe documentation has new content:\\n\\n- [How to create, publish, and install your own Podman Desktop extensions](https://podman-desktop.io/docs/extensions)\\n- [Using Compose](https://podman-desktop.io/docs/compose/podman-compose)\\n- [Restarting Kind](https://podman-desktop.io/docs/kind)\\n\\n---\\n\\n## Notable bug fixes\\n\\n- Periodically check and refresh Podman connection on Windows and Mac [#1662](https://github.com/containers/podman-desktop/pull/1662)\\n- Fix inconsistent Log view behaviour [#1710](https://github.com/containers/podman-desktop/pull/1710)\\n- Don\'t create route for regular Kubernetes clusters [#1707](https://github.com/containers/podman-desktop/pull/1707)\\n- Fix copy button on empty screen [#1804](https://github.com/containers/podman-desktop/pull/1804)\\n- Register extension tray items correctly [#1778](https://github.com/containers/podman-desktop/pull/1778) and handle updates [#1800](https://github.com/containers/podman-desktop/pull/1800)\\n\\n---\\n\\n## Community thank you\\n\\n\ud83c\udf89 We\u2019d like to say a big thank you to everyone who helped to make Podman Desktop 0.13 even better:\\n\\n- [`Tony Soloveyv`](https://github.com/Tony-Sol) in [#1605 - Fix directories inconsistency in `~/.local/share/`](https://github.com/containers/podman-desktop/pull/1605)\\n- [`Oleg`](https://github.com/RobotSail) in [#1567 - Check for Flatpak when calling command from exec](https://github.com/containers/podman-desktop/pull/1567)\\n- [`Christoph Blecker`](https://github.com/cblecker) in [#1556 - Fix: Hide dock icon on macOS if starting minimized](https://github.com/containers/podman-desktop/pull/1556)\\n- [`Paul Wright`](https://github.com/pwright) in [#1604 - Docs: correct syntax of kind doc](https://github.com/containers/podman-desktop/pull/1604)\\n- [`Denis Golovin`](https://github.com/dgolovin) in [#1790 - Feat: add EventEmitter class to extension API](https://github.com/containers/podman-desktop/pull/1790)\\n- [`Christophe Fergeau`](https://github.com/cfergeau) in [#1642 - Fix: Pod list \\"an pod\\" typing error](https://github.com/containers/podman-desktop/pull/1642)\\n\\n## Final notes\\n\\nThe complete list of issues fixed in this release is available [here](https://github.com/containers/podman-desktop/issues?q=is%3Aclosed+milestone%3A0.13.0).\\n\\nGet the latest release from the [Downloads](/downloads) section of the website and boost your development journey with Podman Desktop. Additionally, visit the [GitHub repository](https://github.com/containers/podman-desktop) and see how you can help us make Podman Desktop better."},{"id":"5-things-to-know-for-a-docker-user","metadata":{"permalink":"/blog/5-things-to-know-for-a-docker-user","source":"@site/blog/2023-03-24-5-things-to-know-for-a-docker-user.md","title":"5 things to know about Podman Desktop for a Docker user","description":"Important things to know when switching from Docker Desktop to Podman Desktop","date":"2023-03-24T00:00:00.000Z","formattedDate":"March 24, 2023","tags":[{"label":"podman-desktop","permalink":"/blog/tags/podman-desktop"},{"label":"docker","permalink":"/blog/tags/docker"},{"label":"migrating","permalink":"/blog/tags/migrating"}],"readingTime":4.285,"hasTruncateMarker":true,"authors":[{"name":"Florent Benoit","title":"Maintainer of Podman Desktop","url":"https://github.com/benoitf","imageURL":"https://github.com/benoitf.png","key":"benoitf"}],"frontMatter":{"title":"5 things to know about Podman Desktop for a Docker user","description":"Important things to know when switching from Docker Desktop to Podman Desktop","slug":"5-things-to-know-for-a-docker-user","authors":["benoitf"],"tags":["podman-desktop","docker","migrating"],"hide_table_of_contents":false},"prevItem":{"title":"Release Notes - Podman Desktop 0.13","permalink":"/blog/podman-desktop-release-0.13"},"nextItem":{"title":"Release Notes - Podman Desktop 0.12","permalink":"/blog/podman-desktop-release-0.12"}},"content":"The 5 things to know being a Docker user by using Podman Desktop:\\n\\n- **Use a single UI**: Podman Desktop works with several container engines, including Docker.\\n- The **compatibility mode**: How to ensure tools are working with Podman instead of Docker.\\n- **Compose** support: How to work with Compose files and Podman.\\n- **Kubernetes** support: How to use Kubernetes with Podman.\\n- **Security**: Use `rootless` mode or containers without root privileges.\\n\\n![5-things-to-know-for-a-docker-user-hero](img/5-things-to-know-for-a-docker-user/5-things-to-know-for-a-docker-user-hero.png)\\n\\n\x3c!--truncate--\x3e\\n\\n---\\n\\n## Use Podman Desktop to interact with containers running in Docker\\n\\nDocker Desktop provides a UI to interact with containers and images. But the UI depends on Docker API and it is not possible to use the UI with Docker and Podman at the same time.\\n\\nPodman Desktop is a multi-engine UI tool. The UI is compatible with the API of Docker and Podman. It means all containers and images from all the engines at the same time are visible in the UI.\\n\\nWhen migrating from Docker to Podman, you can use Podman Desktop to interact with containers running in Docker. Explore all commands and features of Podman Desktop and see all the resources from Docker.\\n\\n![Many container engines at the same time](img/5-things-to-know-for-a-docker-user/multiple-container-engines.png)\\n\\n## Docker compatibility mode\\n\\nUsing Podman with Podman Desktop or with the Podman CLI is straightforward. But some tools expect to find `docker` CLI or `docker.sock` socket. In this case, you have to use the compatibility mode of Podman.\\n\\n### Socket file compatibility\\n\\nThe socket compatibility mode is a feature of Podman that allows to bind the Podman socket under the Docker socket path.\\n\\nOn Windows the socket compatibility mode is always enabled by default. On macOS, by using the `.pkg installer` it is active by default. But when installing with `brew`, it will not be there because it requires some admin permissions.\\n\\nThat is not an issue because you can enable it by [invoking a CLI tool](https://podman-desktop.io/docs/migrating-from-docker/using-podman-mac-helper) that will setup the compatibility mode.\\n\\nFor example if you use [`TestContainers`](https://www.testcontainers.org/) in your Java project, you can use the compatibility mode to ensure that the tool will use Podman instead of Docker.\\n\\n### CLI compatibility\\n\\nIf you have scripts relying on `docker` CLI, you can use the compatibility mode to ensure that the tool is working with Podman instead of Docker.\\n\\nIf you have the `docker` CLI installed on your computer, you can use the socket file compatibility of docker to ensure that the tool is working with Podman engine instead of Docker.\\n\\nIf you do not have the `docker` CLI installed on your computer, you can [Create a script](https://podman-desktop.io/docs/migrating-from-docker/emulating-docker-cli-with-podman) called `docker` that will call the `podman` CLI\\n\\n**_NOTE:_** creating a shell prompt alias, for example `alias docker=podman`, will not work inside scripts that you call.\\n\\n## Compose\\n\\nAs a user of Docker, you might use `docker compose` (or `docker-compose`) to run some of your applications.\\n\\nFor now Podman does not include a `Compose` support directly in the CLI with a command `podman compose`.\\n\\n`Compose` can work with the Podman socket.\\n\\nBased on the compatibility mode (see [section about Docker compatibility mode](#docker-compatibility-mode)):\\n\\n- Enabled: you can use the `compose` binary to run your applications.\\n- Disabled: you need to [export the environment variable DOCKER_HOST](https://podman-desktop.io/docs/migrating-from-docker/using-the-docker_host-environment-variable) before running compose.\\n\\nYou can now use the `compose` binary to run your applications and it will use Podman engine.\\n\\nPodman Desktop has a `compose` extension that can fetch `compose` binary if not already available on the filesystem.\\n\\nPodman Desktop UI displays the containers created by `Compose` are in the same group.\\n\\n![Compose support in the UI](img/5-things-to-know-for-a-docker-user/compose-containers-in-ui.png)\\n\\n## Kubernetes\\n\\nIt is possible to start a Kubernetes cluster with Docker.\\n\\nPodman supports directly a subset of Kubernetes resources that you can use with `.yaml` files.\\n\\nFor example if you only want to create a `Pod` resource, you can use the `Play Kubernetes YAML` button from the `Containers` list screen with your `.yaml` file. No need to install or start a Kubernetes cluster.\\n\\n![Play Kubernetes YAML](img/5-things-to-know-for-a-docker-user/play-kubernetes-yaml.png)\\n\\nIt is possible to do the counter-part. Export the definition of a container or pod to a Kubernetes resource. You can use the `Generate kube` button from the kebab menu of a given container or pod.\\n\\n![Kubernetes generate](img/5-things-to-know-for-a-docker-user/kube-generate.png)\\n\\nPodman handles pods and in the Podman Desktop UI, you can see all the pods inside a Pod section. All containers inside the pod are in the same group.\\n\\n![Pods in the UI](img/5-things-to-know-for-a-docker-user/pods-in-ui.png)\\n\\n![Containers from pod](img/5-things-to-know-for-a-docker-user/containers-from-pod.png)\\n\\nAn experimental `kind` extension is bringing the creation of full-blown Kubernetes cluster with Podman.\\n\\n## Rootless mode\\n\\nOne of the difference of Docker and Podman is the way they handle containers. Docker requires root privileges to run containers by default. Podman can run containers without root privileges by default.\\n\\nIt means that for example, starting a container with a port < 1024 will not work. You need to use a port > 1024.\\n\\nIf you still need to create containers with a port < 1024, you can change the Podman machine configuration of the Podman Machine if you are on Windows or macOS.\\n\\nThe command is `podman machine set --rootful` to enable the execution with root privileges or `podman machine set --rootful=false` to switch back to rootless mode."},{"id":"podman-desktop-release-0.12","metadata":{"permalink":"/blog/podman-desktop-release-0.12","source":"@site/blog/2023-02-15-release-0.12.md","title":"Release Notes - Podman Desktop 0.12","description":"Podman Desktop 0.12 has been released!","date":"2023-02-15T00:00:00.000Z","formattedDate":"February 15, 2023","tags":[{"label":"podman-desktop","permalink":"/blog/tags/podman-desktop"},{"label":"release","permalink":"/blog/tags/release"},{"label":"kubernetes","permalink":"/blog/tags/kubernetes"}],"readingTime":4.505,"hasTruncateMarker":true,"authors":[{"name":"Stevan Le Meur","title":"Product Manager","url":"https://github.com/slemeur","imageURL":"https://github.com/slemeur.png","key":"slemeur"}],"frontMatter":{"title":"Release Notes - Podman Desktop 0.12","description":"Podman Desktop 0.12 has been released!","slug":"podman-desktop-release-0.12","authors":["slemeur"],"tags":["podman-desktop","release","kubernetes"],"hide_table_of_contents":false},"prevItem":{"title":"5 things to know about Podman Desktop for a Docker user","permalink":"/blog/5-things-to-know-for-a-docker-user"},"nextItem":{"title":"Release Notes - Podman Desktop 0.11","permalink":"/blog/podman-desktop-release-0.11"}},"content":"import ReactPlayer from \'react-player\'\\n\\nThis release note covers Podman Desktop 0.12 release changes.\\n\\n\x3c!--Main Features--\x3e\\n\\n- **Podman Version**: Podman 4.4.1 now included in Windows and Mac installers.\\n- **Containers Configuration**: Configure port mappings for an image without exported ports.\\n- **Windows Home Support**: Podman Desktop now supports Windows Home Edition.\\n- **Start minimized**: Option to start Podman Desktop minimized to system tray.\\n- **UX and UI Improvements**: Consistent actions, placeholder for logs, unified icons and others.\\n\\nPodman Desktop 0.12 is now available. [Click here to download it](/downloads)!\\n\\n![podman-desktop-0-12-hero](img/podman-desktop-release-0.12/podman-desktop-release-0.12.png)\\n\\n\x3c!--truncate--\x3e\\n\\n---\\n\\n## Release Details\\n\\n### Update to Podman v4.4.1 [#1456](https://github.com/containers/podman-desktop/pull/1456)\\n\\nPodman Desktop 0.12 embeds [Podman 4.4.1](https://github.com/containers/podman/releases/tag/v4.4.1) in Windows and macOS installers. Make sure to upgrade to benefit from the latest Podman features and bug fixes.\\n\\n### Configuring port mappings when an image has no exported port [#1265](https://github.com/containers/podman-desktop/pull/1265)\\n\\nWith the latest update, users can now add multiple local-to-remote port mappings when starting a container from an image that has no exported ports. This feature provides users with the flexibility to specify which ports on their local machine should map to which ports on the container, even if the container does not have any exported ports by default.\\n\\n![port-mapping](https://user-images.githubusercontent.com/49404737/215112797-86dcf3f0-121a-487e-a71f-ad41e91f93da.gif)\\n\\n### Installing Podman Desktop on Windows Home Edition [#1268](https://github.com/containers/podman-desktop/pull/1268)\\n\\nPodman Desktop 0.12 offers the ability to be installed on Windows Home Edition. The mechanism uses Virtual Machine Platform detection, instead of hyper-v. WSL2 is still requires but can be installed along with the installation process.\\n\\n![install-windows-home-edition-2](https://user-images.githubusercontent.com/436777/215121429-7c757aaa-a838-43db-98a2-78ad368f407e.png)\\n\\n### Option to automatically minimize Podman Desktop on login [#1374](https://github.com/containers/podman-desktop/pull/1374)\\n\\nPodman Desktop now provides a \\"start minimized\\" option when users log in onto the laptop. This option, available from the application\'s settings, can be useful if users want to automatically launch Podman Desktop at log in, but prefer not to have the window visible on the screen. With this feature, you can ensure that Podman Desktop is up and running in the background without any interruption to your workflows.\\n\\n- Go to ** Settings > Preferences > Login: Minimize** to activate the option.\\n\\n![minimize-on-login](https://user-images.githubusercontent.com/6422176/216651424-bcf756fd-7554-4b24-a838-e3e2f798fe6e.png)\\n\\n### UI and UX Improvements\\n\\n#### Improved actions consistency [#1225](https://github.com/containers/podman-desktop/pull/1225)\\n\\nActions displayed in the list pages for Images and Containers have been reviewed and made consistent between other pages.\\n\\n![action-consistency-1](https://user-images.githubusercontent.com/19958075/214104678-2d4148d7-484e-41f9-9da9-aecee328ae2b.png)\\n\\nActions displayed in the header of the container\'s details page have been improved so that the actions are always displayed in the same order.\\n\\n![action-consistency-2](https://user-images.githubusercontent.com/19958075/214104663-64fa0601-bb79-49bf-8226-6a78a88d3622.png)\\n\\n#### Consistent status icons for Pods, Containers, Images and Volumes [#1326](https://github.com/containers/podman-desktop/pull/1326), [#1377](https://github.com/containers/podman-desktop/pull/1377), [#1459](https://github.com/containers/podman-desktop/pull/1459) and [#1245](https://github.com/containers/podman-desktop/pull/1245)\\n\\nThe status icons for Pods, Containers, Images, and Volumes have been unified and use consistent states.\\n\\n![pods-status-icon](https://user-images.githubusercontent.com/19958075/216671859-bdd8dca4-56b7-40a8-961a-dcb6e01be61e.png)\\n\\nIcons in empty screens have been updated to use the same consistent SVG icon as the status icons.\\n\\n![empty-screen-2](https://user-images.githubusercontent.com/436777/214577726-f4cfde7b-017a-499d-a2a9-e50d455ffaf0.png)\\n\\n#### Placeholder when logs for containers are being fetched [#1353](https://github.com/containers/podman-desktop/pull/1353)\\n\\nA placeholder is now displayed when logs are being fetched.\\n![placeholder-loading-logs](https://user-images.githubusercontent.com/49404737/216952505-899308ae-183e-487a-b6e5-28832a0b6452.gif)\\n\\n#### Fixed alignment in badges from the navigation sidebar [#1357](https://github.com/containers/podman-desktop/pull/1357)\\n\\nBadges in the sidebar are now aligned with the title of the section.\\n\\n![alignement-badges](https://user-images.githubusercontent.com/49404737/216336502-2a34dea3-fd41-4184-8cfe-9226d70da070.png)\\n\\n#### Enable/disable open browser action based on container state [#1395](https://github.com/containers/podman-desktop/pull/1395) and [#1397](https://github.com/containers/podman-desktop/pull/1397)\\n\\nThe action to open the browser if a port is opened in a container, is now disabled when the container is stopped. It is also hidden in the kebab menu.\\n\\n![enable-disable-container-actions](https://user-images.githubusercontent.com/49404737/217284414-1bdc820b-30a8-485e-b0f9-485229026696.gif)\\n\\n---\\n\\n## Other Notable Enhancements\\n\\n- Display extension icons [#1058](https://github.com/containers/podman-desktop/pull/1058)\\n- Solid Icons [#1267](https://github.com/containers/podman-desktop/pull/1276)\\n- Differentiate icons compared to status icons [#1268](https://github.com/containers/podman-desktop/pull/1298)\\n- Refactors window initializing [#1309](https://github.com/containers/podman-desktop/pull/1309)\\n- Change window creation background color to dark [#1310](https://github.com/containers/podman-desktop/pull/1310)\\n- Use Podman `machine inspect` to read the address to connect to the Podman machine [#1364](https://github.com/containers/podman-desktop/pull/1364)\\n- Update the editor content when the pod name changes, and disable the deploy button when empty [#1403](https://github.com/containers/podman-desktop/pull/1403)\\n- Ability to manually set color of tray icon for Windows and Linux [#1243](https://github.com/containers/podman-desktop/pull/1243)\\n- Better UI feedback when starting pods [#1242](https://github.com/containers/podman-desktop/pull/1242)\\n\\n---\\n\\n## Documentation\\n\\nThe documentation had many editorial reviews, and new content.\\n\\n- [Link to simple WSL2 installation instructions](/docs/installation/windows-install)\\n- [Refresh Windows Installation](/docs/installation/windows-install)\\n- [Revamped installation introduction](/docs/installation)\\n- [Reorganized Linux installation](/docs/installation/linux-install)\\n- [Installing Podman with OpenShift Local](/docs/podman/installing-podman-with-openshift-local-on-windows)\\n- [Installing Podman Desktop on Windows in a restricted environment](/docs/installation/windows-install/installing-podman-desktop-and-podman-in-a-restricted-environment)\\n- [Fixed documentation on `podman-mac-helper` setup](/docs/migrating-from-docker/using-podman-mac-helper)\\n\\n---\\n\\n## Notable bug fixes\\n\\n- Fixed handling path with spaces on Windows when installing Podman [#1270](https://github.com/containers/podman-desktop/pull/1270)\\n- Removed padding from SVG icons [#1253](https://github.com/containers/podman-desktop/pull/1253)\\n- Website: fixed download links for Windows and macOS binaries [#1255](https://github.com/containers/podman-desktop/pull/1255)\\n- Fixed prettier commands on Windows [#1266](https://github.com/containers/podman-desktop/pull/1267)\\n- Fixed new xterm instance spawn when clicking the logs route [#1344](https://github.com/containers/podman-desktop/pull/1344)\\n- Fixed need to wait that telemetry has been initialized before proceeding [#1373](https://github.com/containers/podman-desktop/pull/1373)\\n- Fixed new xterm instance spawn when clicking the logs route in pod details[#1393](https://github.com/containers/podman-desktop/pull/1393)\\n- Fixed stop spinner if image cannot be retrieved [#1394](https://github.com/containers/podman-desktop/pull/1394)\\n- Fixed escape command with quotes only for Windows [#1462](https://github.com/containers/podman-desktop/pull/1462)\\n- Fixed random CRC status change [#1420](https://github.com/containers/podman-desktop/pull/1420)\\n\\n---\\n\\n## Community Thank You\\n\\n\ud83c\udf89 We\u2019d like to say a big thank you to everyone who helped to make Podman Desktop 0.12 even better:\\n\\n- [Philipp Wagner](https://github.com/imphil) in [#1274 - Link to simple WSL2 installation instructions](https://github.com/containers/podman-desktop/pull/1274)\\n- [Arthur S](https://github.com/arixmkii) in [#1364 - Get podman machine socketPath from podman machine inspect first](https://github.com/containers/podman-desktop/pull/1364)\\n- [Mitch West](https://github.com/Mitch9378) in [#1428 - Fix old documentation for \'podman-mac-helper setup\'](https://github.com/containers/podman-desktop/pull/1428)\\n\\n## Final Notes\\n\\nThe complete list of issues fixed in this release is available [here](https://github.com/containers/podman-desktop/issues?q=is%3Aclosed+milestone%3A0.12.0).\\n\\nGet the latest release from the [Downloads](/downloads) section of the website and boost your development journey with Podman Desktop. Additionally, visit the [GitHub repository](https://github.com/containers/podman-desktop) and see how you can help us make Podman Desktop better."},{"id":"podman-desktop-release-0.11","metadata":{"permalink":"/blog/podman-desktop-release-0.11","source":"@site/blog/2023-01-18-release-0.11.md","title":"Release Notes - Podman Desktop 0.11","description":"Podman Desktop 0.11 has been released!","date":"2023-01-18T00:00:00.000Z","formattedDate":"January 18, 2023","tags":[{"label":"podman-desktop","permalink":"/blog/tags/podman-desktop"},{"label":"release","permalink":"/blog/tags/release"},{"label":"kubernetes","permalink":"/blog/tags/kubernetes"}],"readingTime":9.43,"hasTruncateMarker":true,"authors":[{"name":"Stevan Le Meur","title":"Product Manager","url":"https://github.com/slemeur","imageURL":"https://github.com/slemeur.png","key":"slemeur"}],"frontMatter":{"title":"Release Notes - Podman Desktop 0.11","description":"Podman Desktop 0.11 has been released!","slug":"podman-desktop-release-0.11","authors":["slemeur"],"tags":["podman-desktop","release","kubernetes"],"hide_table_of_contents":false},"prevItem":{"title":"Release Notes - Podman Desktop 0.12","permalink":"/blog/podman-desktop-release-0.12"},"nextItem":{"title":"Release Notes - Podman Desktop 0.10","permalink":"/blog/podman-desktop-release-0.10"}},"content":"import ReactPlayer from \'react-player\'\\n\\nThis release note covers Podman Desktop 0.11 release changes.\\n\\n- **Air-Gapped Installation**: New all-in-one binaries for air-gapped installation.\\n- **Feedback**: Submit feedback directly from Podman Desktop.\\n- **Docker Compatibility Mode**: Information about the Docker compatibility mode.\\n- **Proxy Setting**: Toggle on/off the proxy setting.\\n- **Deploy to Kubernetes**: Select the namespace to deploy to Kubernetes.\\n- **Registry Configuration**: Simplified registry configuration for well known registries.\\n- **UX/UI Improvements**: View pod\'s container logs, better visual feedback, configurable editor font size, and more.\\n\\nPodman Desktop 0.11 is now available. [Click here to download it](/downloads)!\\n\\n\x3c!--truncate--\x3e\\n\\n---\\n\\n## Release Details\\n\\n### Air-Gapped installation [#1104](https://github.com/containers/podman-desktop/pull/1104) [#1120](https://github.com/containers/podman-desktop/pull/1120)\\n\\nFor users who are not able to connect to the internet, a new all-in-one (airgap) binary that includes the Podman Desktop application and the Podman binaries is now available for both Mac and Windows. When initializing a new Podman machine using all-in-one binaries, it\'ll use the embedded files and not grab them from internet:\\n\\n- on Mac, it embeds the qemu FCOS binaries.\\n- on Windows, it embeds the WSL binary.\\n\\nTo differentiate the air-gapped binaries from the regular ones, you can check the artifactname, they\'re containing \'airgap\' and are bigger.\\nPlease note, that those binaries are available only on releases and not the pre-releases.\\n\\nThere is also an optional way to provide a custom Podman machine image in the create machine form. By providing the path to the image you want, Podman Desktop will create a machine with that image. Leaving the field empty will use the default image (the one included in the binary).\\n\\n\\n\\n### Feedback within Podman Desktop [#1078](https://github.com/containers/podman-desktop/pull/1078)\\n\\nSubmitting feedback on Podman Desktop is getting easier as it is possible directly within the tool. This will help to get more information about the issues you are facing and will help us to improve the tool.\\n\\n\\n\\nPlease feel free to submit any feedback you have, we are looking forward to hearing from you!\\n\\n### Docker compatibility mode [#1047](https://github.com/containers/podman-desktop/pull/1047)\\n\\nThe Docker compatibility mode is a feature that allows to use Podman as a drop-in replacement for Docker. It relies on the Docker socket helper provided with Podman and automatically handle the local setup of Podman path to the Docker socket. Tools like [Testcontainers](https://www.testcontainers.org/) or others are relying on this to communicate to the container engine.\\n\\nIn this new version of Podman Desktop, we are now providing information to the user about the status of this compatibility mode directly on the dashboard page. The way it works is the following:\\n\\n- When Docker is running: the socket is pointing to Docker.\\n- When Podman is starting and Docker is not running: the docker API socket will use Podman.\\n\\nIn case the compatibility mode is not activated, new documentation on how to activate it and how to easily switch between Docker and Podman is available here: [https://podman-desktop.io/docs/migrating-from-docker](https://podman-desktop.io/docs/migrating-from-docker).\\n\\nThis is a warning displayed for Windows users:\\n![windows-docker-compatibility](https://user-images.githubusercontent.com/436777/209305744-9056addd-f122-4f75-9e03-ad27a0109375.png)\\n\\nThis is the warning for Mac users:\\n![mac-docker-compatibility](https://user-images.githubusercontent.com/6422176/207964861-a9c1f72c-89d6-4816-beab-397af4125620.png)\\n\\n### Allow to toggle on/off the proxy setting [#983](https://github.com/containers/podman-desktop/pull/983)\\n\\nIn some context, users need the ability to disable and re-enable the proxy configuration very quickly, without having to entirely reconfigure it. This is now possible from the Podman Desktop settings page, where a toggle to enable/disable the proxy configuration has been added.\\n\\n\\n\\nNote: extensions can read this information and then update the proxy configuration.\\n\\n### Namespace selection for deploy to Kubernetes [#1008](https://github.com/containers/podman-desktop/pull/1008)\\n\\nA new dropdown menu has been added to the deploy to Kubernetes screen to allow selecting the namespace to deploy to. Defaults to defaultnamespace, if unable to get any from kube_client module.\\n\\nIf the user have set `kubectl config set-context --current --namespace=NAMESPACE` it honors that as the chosen value.\\n\\n![deploy-kubernetes-namespace](https://user-images.githubusercontent.com/7339809/206688886-095e4f15-42ae-4a0a-b1c6-ae4b547fcdfb.gif)\\n\\n### Configure Podman binary path [#941](https://github.com/containers/podman-desktop/pull/941)\\n\\nUsers might use a custom path to the podman binary. An option within settings (Settings -> Preferences) to allow providing an additional path to Podman binary has been added.\\nThis is useful for users who have installed Podman using a package manager and want to use the binary provided by the package manager.\\nSee: [Unable to set custom binary path for Podman on macOS](/docs/troubleshooting/troubleshooting-podman-on-macos#unable-to-set-custom-binary-path-for-podman-on-macos)\\n![custom-path](https://user-images.githubusercontent.com/6422176/204832063-5858065a-2fc3-49de-8d23-3b99b7d10dbf.png)\\n\\n### Provide pre-defined registries [#1201](https://github.com/containers/podman-desktop/pull/1201)\\n\\nThe experience of configuring a registry is getting simplified for the most popular ones. The user will be able to select a registry from a pre-defined list and will only have to provide the username and password. The following registries will be pre-defined:\\n\\n- Dockerhub\\n- Red Hat Quay\\n- GitHub\\n- IBM Container Registry\\n- Google Container Registry\\n\\n\\n\\n### UI/UX Improvements\\n\\n#### View Pods logs [#1122](https://github.com/containers/podman-desktop/pull/1122)\\n\\nThe pods details view provides the ability to view the logs of each containers that might be running in a pod. Moreover, as it can also be hard to scan and identify which container is producing which output, we appended the container name at the beginning of each output and differentiate each container with a different color.\\n\\n![pods-logs](https://user-images.githubusercontent.com/6422176/211024673-eee9bad8-1b0c-4446-b8d1-97a226282c4d.png)\\n\\n#### Improved feedback when clicking on container list action icons [#1150](https://github.com/containers/podman-desktop/pull/1150) [#1161](https://github.com/containers/podman-desktop/pull/1161)\\n\\nWhen starting/stopping or deleting a container, a spinner is now displayed. In case of error, a message indicating that the action failed will also be better indicated.\\n\\n\\n\\nFor containers that exit immediately or short-lived containers, the feedback is also improved and include report of error now provide a better feedback to the user [#1161](https://github.com/containers/podman-desktop/pull/1161).\\n\\n\\n\\n#### Allows to change the default font size for the editor [#1160](https://github.com/containers/podman-desktop/pull/1160)\\n\\nAn editor is used in several screens of Podman Desktop, from the inspect screen to container\'s outputs and Kubernetes YAML. The default font size is 10 pixels. It\'s now possible to adjust the font size to the one the one you prefer. This setting is persisted and will be used for all the editors of Podman Desktop and available from the preferences page (Settings -> Preferences).\\n\\n\\n\\n#### Keep expanded state of pods when refreshing containers [#1042](https://github.com/containers/podman-desktop/pull/1042)\\n\\nWhen switching from different screens of the application or simply refreshing the list of containers, the expanded state of each item in the list is now persisted and will be properly restored.\\n\\n\\n\\n#### Click on the Pod name redirects to the Pod details page [#1159](https://github.com/containers/podman-desktop/pull/1159)\\n\\nThe list of containers also displays pods, now clicking on the pod name directly redirects to the Pod details page.\\n\\n\\n\\n#### Improved styles of buttons for actions [#984](https://github.com/containers/podman-desktop/pull/984)\\n\\nThe style of the buttons for actions on item in the list of in details pages have been improved. The background has been removed, but to make the hover state more visible, the \\"hover\\" circle is visible and the icon\'s color is also changing.\\n\\nOn lists:\\n![list-actions](https://user-images.githubusercontent.com/6422176/205979121-b49a0ddf-03bb-4a4d-8d12-bc8d0bd52387.png)\\n\\nOn details pages:\\n![details-actions](https://user-images.githubusercontent.com/6422176/205979123-ea420b17-e834-4029-82eb-22949889eee9.png)\\n\\n#### Improved alignments in pages with lists [#1182](https://github.com/containers/podman-desktop/pull/1182)\\n\\nThe alignment of the items in the list of containers and pods have been improved. The header of each columns are now aligned with the text. and the actions icons are now aligned with the top of the text.\\n\\n![list-actions](https://user-images.githubusercontent.com/19958075/212712580-096fd090-0beb-40a4-8dc6-b3fdc5e81e35.png)\\n\\n---\\n\\n## Other Notable Enhancements\\n\\n- Statistics area in container details are always shown. ([#1131](https://github.com/containers/podman-desktop/pull/1131))\\n- Add more descriptive wording and more information to extensions. ([#985](https://github.com/containers/podman-desktop/pull/985))\\n- Allow to install on-the fly Podman Desktop extensions using an OCI image. ([#1187](https://github.com/containers/podman-desktop/pull/1187))\\n- Display correctly non-multiplexed stream in logs (when using non interactive mode). ([#1197](https://github.com/containers/podman-desktop/pull/1197))\\n- Font changed from white to gray for non-name sections (creation date, size). ([#1206](https://github.com/containers/podman-desktop/pull/1206))\\n- Add Help/about menu for macOS/Windows/Linux. ([#1207](https://github.com/containers/podman-desktop/pull/1207))\\n\\n---\\n\\n## Documentation\\n\\nComing with this new version of Podman Desktop, the documentation has been getting attention (with number of editorial reviews) and new content have been added.\\n\\nContent for helping users to migrate from Docker to Podman has been added:\\n\\n- [Using the `podman-mac-helper` tool to migrate from Docker to Podman on macOS](https://github.com/containers/podman-desktop/pull/1088)\\n- [better identify podman-mac-helper verification steps](https://github.com/containers/podman-desktop/pull/1129)\\n- [Emulating Docker CLI using Podman to migrate from Docker to Podman](https://github.com/containers/podman-desktop/pull/1143)\\n- [Migrating from Docker section](https://github.com/containers/podman-desktop/pull/1146)\\n- [Verifying that your tools are using Podman](https://github.com/containers/podman-desktop/pull/1152)\\n- [Importing saved containers](https://github.com/containers/podman-desktop/pull/1144)\\n\\nSeveral of other improvements have been made to the documentation and the website:\\n\\n- [Troubleshooting for Apple Silicon and brew x86_64 installs](https://github.com/containers/podman-desktop/pull/962)\\n- [Change text of custom binary location, add docs](https://github.com/containers/podman-desktop/pull/972)\\n- [Silent install option for windows](https://github.com/containers/podman-desktop/pull/974)\\n- [Upgrade to vite v4 and rollup v3](https://github.com/containers/podman-desktop/pull/1079)\\n- [Refreshing documentation on installing on Linux](https://github.com/containers/podman-desktop/pull/1118)\\n- [Identify the shell sessions in Installing on Linux](https://github.com/containers/podman-desktop/pull/1130)\\n- [Website: the linux binary is not a source, it should be promoted as a binary](https://github.com/containers/podman-desktop/pull/1133)\\n- [Introducing tabs for operatings systems and container engines](https://github.com/containers/podman-desktop/pull/1162)\\n- [website: In the landing page, update plugins and container engines lists](https://github.com/containers/podman-desktop/pull/1165)\\n- [Document where code is located within Podman Desktop](https://github.com/containers/podman-desktop/pull/1163)\\n- [(extension-api): Documentation on how to write an extension and use the api](https://github.com/containers/podman-desktop/pull/1172)\\n\\n---\\n\\n## Notable bug fixes\\n\\n- Update to v0.3.2 Docker Desktop API for extensions - [#1070](https://github.com/containers/podman-desktop/pull/1070)\\n- Updated link to the Matrix room - [#1076](https://github.com/containers/podman-desktop/pull/1076)\\n- Report error when container name already exists - [#1142](https://github.com/containers/podman-desktop/pull/1142)\\n- Fixed connectivity to the Podman machine when the generated socket length is greater than 104 characters in MacOS - [#1145](https://github.com/containers/podman-desktop/pull/1145)\\n- Do not use long calls for external clients - [#1151](https://github.com/containers/podman-desktop/pull/1151)\\n- Invalid name/tag for images with registries using a different port - [#1127](https://github.com/containers/podman-desktop/pull/1127)\\n- Invalid badge count for images when two images have the same tag - [#1124](https://github.com/containers/podman-desktop/pull/1124)\\n- Fixed detection of WSL2 - [#981](https://github.com/containers/podman-desktop/pull/981)\\n- Handle invalid kubeconfig files instead of crashing - [#953](https://github.com/containers/podman-desktop/pull/953)\\n- Removed redundant actions from details pages - [#1200](https://github.com/containers/podman-desktop/pull/1200)\\n- Fixed registry URL not aligned with header - [#1205](https://github.com/containers/podman-desktop/pull/1205)\\n- Moved SVGs to reusable components - [#1211](https://github.com/containers/podman-desktop/pull/1211)\\n\\n**Extensions API has also been improved in this new release:**\\n\\n- (extension-api): Allows to register a factory for kubernetes connection objects (like for container connections) - [#1040](https://github.com/containers/podman-desktop/pull/1040)\\n- (extension-api): List or inspect containers, be notified on events - [#1041](https://github.com/containers/podman-desktop/pull/1041)\\n- (extension-api): Allows to get provider notification - [#1045](https://github.com/containers/podman-desktop/pull/1045)\\n- (dd-extension-api): Implement toast API - [#1154](https://github.com/containers/podman-desktop/pull/1154)\\n- (extension-api): Moved extension properties to preferences - [#948](https://github.com/containers/podman-desktop/pull/948)\\n- (dd-extension-api): Added open dev console on dd webview in development mode - [#1071](https://github.com/containers/podman-desktop/pull/1071)\\n- (extension-api): Added notes on extension and frameworks/tooling of Podman Desktop - [#1166](https://github.com/containers/podman-desktop/pull/1166)\\n- (extension-api): Documentation on how to write an extension and use the api - [#1172](https://github.com/containers/podman-desktop/pull/1172)\\n- (dd-extension-api): DD extensions should see only minimal information on containers - [#1191](https://github.com/containers/podman-desktop/pull/1191)\\n\\n---\\n\\n## Community Thank You\\n\\n\ud83c\udf89 We\u2019d like to say a big thank you to everyone who helped to make Podman Desktop 0.11 even better:\\n\\n- [Emmanuel Bernard](https://github.com/emmanuelbernard) in [#962 - Troubleshooting for Apple Silicon](https://github.com/containers/podman-desktop/pull/962)\\n- [Michael Prankl](https://github.com/eidottermihi) in [#974 - Silent install option for windows](https://github.com/containers/podman-desktop/pull/974)\\n- [Endre Lervik](https://github.com/elervik) in [#1008 - Namespace selection for deploy to kubernetes](https://github.com/containers/podman-desktop/pull/1008)\\n- [Evan FP](https://github.com/evanfpearson) in [#1145 - fixed socket path length error](https://github.com/containers/podman-desktop/pull/1145)\\n- [Lokesh Mandvekar](https://github.com/lsm5) in [#956 - add repository key to package.json](https://github.com/containers/podman-desktop/pull/956)\\n- [Jean Fran\xe7ois Maury](https://github.com/jeffmaury) in [#1194 - Cannot create Kind cluster on Windows](https://github.com/containers/podman-desktop/pull/1194)\\n\\n## Final Notes\\n\\nThe complete list of issues fixed in this release is available [here](https://github.com/containers/podman-desktop/issues?q=is%3Aclosed+milestone%3A0.11.0).\\n\\nGet the latest release from the [Downloads](/downloads) section of the website and boost your development journey with Podman Desktop. Additionally, visit the [GitHub repository](https://github.com/containers/podman-desktop) and see how you can help us make Podman Desktop better."},{"id":"podman-desktop-release-0.10","metadata":{"permalink":"/blog/podman-desktop-release-0.10","source":"@site/blog/2022-12-01-release-0.10-blog.md","title":"Release Notes - Podman Desktop 0.10","description":"Podman Desktop 0.10 has been released! New Create Container Wizard, improved Kubernetes workflows, revamped registries configuration, and more!","date":"2022-12-01T00:00:00.000Z","formattedDate":"December 1, 2022","tags":[{"label":"podman-desktop","permalink":"/blog/tags/podman-desktop"},{"label":"release","permalink":"/blog/tags/release"},{"label":"kubernetes","permalink":"/blog/tags/kubernetes"}],"readingTime":4.115,"hasTruncateMarker":true,"authors":[{"name":"Dev Kumar","title":"Technical PMM Intern","url":"https://github.com/deekay2310","imageURL":"https://github.com/deekay2310.png","key":"deekay2310"}],"frontMatter":{"title":"Release Notes - Podman Desktop 0.10","description":"Podman Desktop 0.10 has been released! New Create Container Wizard, improved Kubernetes workflows, revamped registries configuration, and more!","slug":"podman-desktop-release-0.10","authors":["deekay2310"],"tags":["podman-desktop","release","kubernetes"],"hide_table_of_contents":false},"prevItem":{"title":"Release Notes - Podman Desktop 0.11","permalink":"/blog/podman-desktop-release-0.11"},"nextItem":{"title":"Build & run Podman Desktop in a DevContainer","permalink":"/blog/develop-using-devcontainer"}},"content":"This release note covers Podman Desktop 0.10 release changes.\\n\\n- **Containers Configuration**: Container creation wizzard allowing to define environment variables, networking and more configuration options.\\n- **Kubernetes Improvements**: Play Kubernetes YAML, custom Kubeconfig path support, reload of kube context.\\n- **Registries Configuration**: Revamped registries configuration UI.\\n- **Podman Version**: Podman 4.3.1 now included in Windows and Mac installers.\\n- **UX/UI Improvements**: Improved lists, better contrast, and more.\\n\\nPodman Desktop 0.10 is now available. [Click here to download it](/downloads)!\\n\\n\x3c!--truncate--\x3e\\n\\n---\\n\\n## Release Details\\n\\n### New configuration wizzard to create containers ([#773](https://github.com/containers/podman-desktop/pull/773))\\n\\nUntil now, we could only specify port binding when building images to start containers. The create container wizzard now includes several options enabling configuring volumes, environment variables, restart policy and settings on networking and security. It is also possible to reuse an existing (and already configured) a network when creating containers.\\n\\n![new container creation wizard](img/podman-desktop-release-0.10/new_container_creation_wizard.gif)\\n\\n### Kubernetes Capabilities Improvements\\n\\n**Custom Kubeconfig file path ([#780](https://github.com/containers/podman-desktop/pull/780))**\\n\\nKubeconfig path location is now configurable from ** Settings > Preferences > Kubernetes: Kubeconfig** and can be set to a custom path. By default, Podman Desktop use the path `$HOME/.kube/config` for the Kubeconfig file.\\n\\n![custom kubeconfig file path](img/podman-desktop-release-0.10/custom-kubeconfig.png)\\n\\n**Play Kubernetes YAML from the Pods list ([#739](https://github.com/containers/podman-desktop/pull/739))**\\n\\nPodman Desktop enables to play existing Kubernetes YAML files. This is now available from `Play Kubernetes YAML` button added to the Pods list, in addition to the Containers list.\\n\\n![play k8s yaml](img/podman-desktop-release-0.10/play_k8s_yaml.gif)\\n\\n**Kube context automatically reloaded when updated ([#813](https://github.com/containers/podman-desktop/pull/813))**\\n\\nAny change to the kube context will now be detected by Podman Desktop in its running state. The system tray, allowing to select which Kubernetes environment to work with, will now reload the kube context without restarting Podman Desktop.\\n\\n### Revamped Container Registries UI ([#446](https://github.com/containers/podman-desktop/issues/446))\\n\\nThe registries configuration UI has been revamped. Instead of using tiles for displaying the registries, now it uses a list where each registry can be added or edited directly in the list. The kebab menu provides options to edit or remove a registry from the list.\\n\\n![registries](img/podman-desktop-release-0.10/registries.png)\\n\\n### Update to Podman 4.3.1 ([#913](https://github.com/containers/podman-desktop/issues/913))\\n\\nPodman Desktop 0.10 is now embedding [Podman 4.3.1](https://github.com/containers/podman/releases/tag/v4.3.1) in Windows and macOS installers.\\n\\n### UI/UX Improvements\\n\\n**Improved lists UX ([#877](https://github.com/containers/podman-desktop/pull/877))**\\n\\nTo reduce the width used in the lists when displaying all the icons, main actions icons are now always displayed (before it was on hover) and the secondary actions are displayed in a kebab menu. For example Start/Stop and delete are primary actions while open the browser, inspect, generate kube yaml, etc. are secondary options.\\n\\n![kebab menu](img/podman-desktop-release-0.10/kebab-menu.png)\\n\\n**Delay appearance of text in navbar ([#767](https://github.com/containers/podman-desktop/pull/767))**\\n\\nWhen minimizing or expanding the navbar, the text was overlapping for a few second the page. Now it\'s displayed with a fading animation.\\n\\n**Selected state: better text color contrast ([#802](https://github.com/containers/podman-desktop/pull/802))**\\n\\nIn the `Images` page, on hover for both the image and the name column, the text contrast has been increased for better visibility: violet indicates that you have selected it.\\n\\n![text color when hover](img/podman-desktop-release-0.10/text-color.gif)\\n\\n**On Linux and Windows, the menu bar is now hidden by default ([#668](https://github.com/containers/podman-desktop/pull/668))**\\n\\nWith this change, the menu bar looks more integrated to the Operating System. The menu can appear if you hit the `Alt` key. Thanks to [Dylan M. Taylor](https://github.com/dylanmtaylor) for contributing to fix this.\\n\\n**Exit when clicking on the close icon of the dashboard on Linux ([#671](https://github.com/containers/podman-desktop/pull/671))**\\n\\nFor most users on Linux, there is no tray icon support. In this situation, when closed, Podman Desktop continues to run in background. [Dylan M. Taylor](https://github.com/dylanmtaylor) added a property to exit the app by default when clicking on the close icon. For people having tray icon support or with the desire of a different behavior, it is possible to disable it from the Settings.\\n\\n---\\n\\n## Other Notable Enhancements\\n\\n- Rename `Started` into `Age` in Containers list.([#878](https://github.com/containers/podman-desktop/pull/878))\\n- Added domain validation when adding a registry. ([#838](https://github.com/containers/podman-desktop/pull/838))\\n- Provided a consistent behavior with Podman CLI, `podman-machine-default` is now the default name when creating a Podman machine from Podman Desktop. ([#775](https://github.com/containers/podman-desktop/pull/775))\\n\\n---\\n\\n## Notable bug fixes\\n\\n- Fixed error handling when pulling images of Desktop Extensions. ([#782](https://github.com/containers/podman-desktop/pull/782))\\n- Fixed use of the full height of the screen when displaying log in the details of a container. ([#946](https://github.com/containers/podman-desktop/discussions/946))\\n- Fixed First start of Podman Desktop on flatpak was not seeing the podman engine ([#860](https://github.com/containers/podman-desktop/pull/860))\\n\\n## Community Thank You\\n\\n\ud83c\udf89 We\u2019d like to say a big thank you to everyone who helped to make Podman Desktop 0.10 even better:\\n\\n- [Dylan M. Taylor](https://github.com/dylanmtaylor) in [#671](https://github.com/containers/podman-desktop/pull/671)\\n- [Fionn Kelleher](https://github.com/osslate) in [#713](https://github.com/containers/podman-desktop/pull/713)\\n- [Rostislav Svoboda](https://github.com/rsvoboda) in [#737](https://github.com/containers/podman-desktop/pull/737)\\n- [Denis Shemanaev](https://github.com/shemanaev) in [#783](https://github.com/containers/podman-desktop/pull/783)\\n- [Fabrice Flore-Th\xe9bault](https://github.com/themr0c) in [#856](https://github.com/containers/podman-desktop/pull/856)\\n- [Kevin](https://github.com/KevinAtSesam) in [#864](https://github.com/containers/podman-desktop/pull/864)\\n- [@sfrunza13](https://github.com/sfrunza13) in [#872](https://github.com/containers/podman-desktop/pull/872)\\n- [Anjan Nath](https://github.com/anjannath) in [#918](https://github.com/containers/podman-desktop/pull/918)\\n\\n## Final Notes\\n\\nThe complete list of issues fixed in this release is available [here](https://github.com/containers/podman-desktop/issues?q=is%3Aclosed+milestone%3A0.10.0).\\n\\nGet the latest release from the [Downloads](/downloads) section of the website and boost your development journey with Podman Desktop. Additionally, visit the [GitHub repository](https://github.com/containers/podman-desktop) and see how you can help us make Podman Desktop better."},{"id":"develop-using-devcontainer","metadata":{"permalink":"/blog/develop-using-devcontainer","source":"@site/blog/2022-11-17-develop-podman-using-codespaces.md","title":"Build & run Podman Desktop in a DevContainer","description":"Develop Podman Desktop using a DevContainer locally or using GitHub Codespaces.","date":"2022-11-17T00:00:00.000Z","formattedDate":"November 17, 2022","tags":[{"label":"podman-desktop","permalink":"/blog/tags/podman-desktop"},{"label":"devcontainer","permalink":"/blog/tags/devcontainer"},{"label":"codespaces","permalink":"/blog/tags/codespaces"}],"readingTime":6.985,"hasTruncateMarker":true,"authors":[{"name":"Florent Benoit","title":"Maintainer of Podman Desktop","url":"https://github.com/benoitf","imageURL":"https://github.com/benoitf.png","key":"benoitf"}],"frontMatter":{"title":"Build & run Podman Desktop in a DevContainer","description":"Develop Podman Desktop using a DevContainer locally or using GitHub Codespaces.","slug":"develop-using-devcontainer","authors":["benoitf"],"tags":["podman-desktop","devcontainer","codespaces"],"hide_table_of_contents":false},"prevItem":{"title":"Release Notes - Podman Desktop 0.10","permalink":"/blog/podman-desktop-release-0.10"}},"content":"GitHub [announced last week](https://github.blog/changelog/2022-11-09-codespaces-for-free-and-pro-accounts/) that Codespaces is available for everyone and it includes free minutes.\\n\\nLet see how we can use a [Development Container](https://containers.dev/) having all the tools to build and run Podman Desktop. The Development Container works locally using Visual Studio Code but in this blog post we will see how it works directly with a simple click from GitHub.\\n\\nThe challenges are to run a desktop tool (Podman Desktop) and running a container engine (Podman) inside this Development Container without using too many memory !\\n\\n\x3c!--truncate--\x3e\\n\\n## Defining image of the container\\n\\nThe first thing is in the choice of the image for the container. It is possible to pick-up a default image and add some features but there is no existing feature for Podman at https://github.com/devcontainers/features/tree/main/src and most of the features are expecting to run on top of Debian/Ubuntu\\n\\nIf you are not interested in how to setup the image, jump to the [next section](#configure-the-devcontainer-using-devcontainerjson).\\n\\nPodman binaries are available quickly after the releases for Fedora. I decided then to use `Fedora 37` as the base image.\\n\\nLet start the Containerfile using:\\n\\n```docker\\nFROM quay.io/fedora/fedora:37\\n```\\n\\nThen I install Node.js 16 from official nodejs.org repository. It\'s easier to switch to the version that we need.\\n\\n```docker\\n# install Node.js + yarn\\nENV NODE_VERSION 16.18.1\\nRUN curl -SLO \\"https://nodejs.org/dist/v$NODE_VERSION/node-v$NODE_VERSION-linux-x64.tar.gz\\" && \\\\\\n tar -xzf \\"node-v$NODE_VERSION-linux-x64.tar.gz\\" -C /usr/local --strip-components=1 && \\\\\\n rm \\"node-v$NODE_VERSION-linux-x64.tar.gz\\" && \\\\\\n npm install -g yarn\\n```\\n\\nNow, all system dependencies used to run an Electron application needs to be installed.\\n\\nPodman is also installed so we can run some containers inside this container.\\n\\nAnd of course, we need to install VNC (I choose [tigervnc](https://tigervnc.org/)) with a light Window Manager ([fluxbox](http://fluxbox.org/)).\\n\\nTo connect to the display of the container, we need to expose VNC over HTML/websocket using [noVNC](https://novnc.com/)\\n\\nxterm is installed to start a terminal from the VNC side.\\n\\n```docker\\nRUN dnf -y update && \\\\\\n yum -y reinstall shadow-utils && \\\\\\n yum install -y git \\\\\\n # dependencies for Podman Desktop\\n nss \\\\\\n atk \\\\\\n at-spi2-atk \\\\\\n cups-libs \\\\\\n gtk3 \\\\\\n # for remote Display\\n fluxbox \\\\\\n tigervnc-server \\\\\\n xorg-x11-fonts-Type1 \\\\\\n novnc \\\\\\n supervisor \\\\\\n xdpyinfo \\\\\\n # for podman\\n podman \\\\\\n fuse-overlayfs --exclude container-selinux \\\\\\n xterm && \\\\\\n rm -rf /var/cache /var/log/dnf* /var/log/yum.*\\n```\\n\\nSupervisord setup the launch of the VNC server and the Window manager\\n\\n```docker\\nCOPY supervisord.conf /etc/supervisord.conf\\n```\\n\\nA custom theme for fluxbox:\\n\\n```docker\\nCOPY fluxbox /usr/share/fluxbox/init\\n```\\n\\nThen we need a special configuration to allow to have Podman working inside the container\\n\\nWe add the `podman-desktop` user with correct range on subuid and subgid when running containers. I used the [tutorial](https://github.com/containers/podman/blob/main/docs/tutorials/rootless_tutorial.md#etcsubuid-and-etcsubgid-configuration).\\n\\n```docker\\nRUN useradd -u 1000 podman-desktop && echo podman-desktop:10000:5000 > /etc/subuid && echo podman-desktop:10000:5000 > /etc/subgid\\n```\\n\\nThen use some default configuration files\\n\\n```docker\\n# initialize conf files\\nADD https://raw.githubusercontent.com/containers/libpod/master/contrib/podmanimage/stable/containers.conf /etc/containers/containers.conf\\nADD https://raw.githubusercontent.com/containers/libpod/master/contrib/podmanimage/stable/podman-containers.conf /home/podman-desktop/.config/containers/containers.conf\\n```\\n\\nand make sure that all permissions are correct following the guide [https://www.redhat.com/sysadmin/podman-inside-container](https://www.redhat.com/sysadmin/podman-inside-container)\\n\\n```docker\\n# set permissions\\nRUN chown podman-desktop:podman-desktop -R /home/podman-desktop && chmod 644 /etc/containers/containers.conf && \\\\\\n mkdir -p /var/lib/shared/overlay-images /var/lib/shared/overlay-layers /var/lib/shared/vfs-images /var/lib/shared/vfs-layers; touch /var/lib/shared/overlay-images/images.lock; touch /var/lib/shared/overlay-layers/layers.lock; touch /var/lib/shared/vfs-images/images.lock; touch /var/lib/shared/vfs-layers/layers.lock && \\\\\\n mkdir -p /run/user/1000 && chown podman-desktop:podman-desktop /run/user/1000\\n```\\n\\nplus define an empty user namespace.\\n\\n```docker\\nENV _CONTAINERS_USERNS_CONFIGURED=\\"\\"\\n```\\n\\nMake sure Podman will create the socket in an expected directory:\\n\\n```docker\\n# socket path for podman\\nENV XDG_RUNTIME_DIR=/run/user/1000\\n```\\n\\nOK ! we have a custom Containerfile providing all the tools to build and run Podman Desktop (using VNC for the display), run Podman and run Electron.\\n\\nThe current file is available at https://github.com/containers/podman-desktop/blob/main/.devcontainer/.parent/Containerfile\\n\\nLet\'s configure the DevContainer.\\n\\n## Configure the DevContainer using devcontainer.json\\n\\nDevContainer definition is stored at `.devcontainer/devcontainer.json` file.\\n\\nWe need to reuse the image of the previous step. For that let\'s use the build section of the `devcontainer.json` file.\\n\\n```json\\n\\"build\\": {\\n \\"dockerfile\\": \\"Containerfile\\"\\n},\\n```\\n\\nIn order to avoid to redo all the build steps each time we open a workspace using this dev container, we published the image to quay.io at [quay.io/podman-desktop/devcontainer-parent:next\\n](https://quay.io/repository/podman-desktop/devcontainer-parent?tab=tags&tag=next). This parent image is not changing much so it\'s better to use is as a parent one.\\n\\nInside `.devcontainer` directory there is a `.parent` directory with everything related to the parent image.\\n\\nAnd in the `.devcontainer/Containerfile` file we reference this image\\n\\n```docker\\nFROM quay.io/podman-desktop/devcontainer-parent:next\\n```\\n\\nBy default, we will be `root` in the container and this is probably not what we expect. Let\'s change that.\\n\\n```json\\n\\"containerUser\\": \\"podman-desktop\\"\\n```\\n\\nSome Visual Studio Code extensions are nice to use and we can add them\\n\\n```json\\n \\"extensions\\": [\\"svelte.svelte-vscode\\", \\"bradlc.vscode-tailwindcss\\"]\\n```\\n\\nThen here is the tricky part, how to run our container allowing to run again inside the container some containers with podman.\\n\\nWe specify the arguments to make it possible. It\'s possible to use `--privileged` flag but I prefer to list the subset of permissions.\\nUsing `--privileged` we don\'t really know what are the privilege that are required while specifying all of them, people are aware of what is granted/denied.\\n\\n```json\\n\\"runArgs\\": [\\n \\"--cap-add=sys_admin\\",\\n \\"--security-opt\\",\\n \\"seccomp=unconfined\\",\\n \\"--device\\",\\n \\"/dev/fuse\\",\\n \\"--security-opt\\",\\n \\"label=disable\\",\\n \\"--security-opt\\",\\n \\"apparmor=unconfined\\"\\n ],\\n```\\n\\nSource code of Podman Desktop needs to be editable within the DevContainer so it needs to be mounted.\\n\\n```json\\n\\"workspaceMount\\": \\"source=${localWorkspaceFolder},target=/workspace,type=bind\\",\\n\\"workspaceFolder\\": \\"/workspace\\",\\n```\\n\\nThen we need a command to build Podman Desktop.\\n\\nFor that, we use `onCreateCommand` hook with a custom command\\n\\n```json\\n\\"onCreateCommand\\": \\"${containerWorkspaceFolder}/.devcontainer/onCreateCommand.sh\\",\\n```\\n\\nand in the `.devcontainer` folder the `onCreateCommand.sh` script is the following\\n\\n```shell\\n#!/bin/sh\\nyarn\\n\\nMODE=production yarn run build && yarn run electron-builder build --linux --dir --config .electron-builder.config.cjs\\n```\\n\\nTwo instructions:\\n\\n1. Fetch all Node.js dependencies.\\n2. build Podman Desktop in the `dist` folder using `Linux` as target Operating System.\\n\\nAfter the start of the container, how to launch Podman Desktop, the website and VNC, etc ?\\n\\nJust use `postStartCommand` hook.\\n\\n```json\\n\\"postStartCommand\\": \\"${containerWorkspaceFolder}/.devcontainer/postStartCommand.sh\\",\\n```\\n\\nand in the `.devcontainer` folder the `postStartCommand.sh` script is the following:\\n\\n```shell\\n#!/bin/sh\\n\\n# Start all services\\n/usr/bin/supervisord -c /etc/supervisord.conf &\\n\\n# wait X server to be ready or after 2mn exit\\necho \\"Waiting for X server to be ready\\"\\ntimeout 120 bash -c \'until xdpyinfo -display :0 &> /dev/null; do printf \\".\\"; sleep 1; done\'\\n\\n# launch podman desktop\\necho \\"Launching Podman Desktop\\"\\ncd dist/linux-unpacked/&& ./podman-desktop &\\n\\n# Launch the 9000 redirect after 20 seconds\\nsleep 20\\nwebsockify --web=/usr/share/novnc localhost:9000 localhost:5900 &\\n\\n# launch the website rendering\\necho \\"Launching Website\\"\\ncd website && yarn start\\n```\\n\\nIt starts VNC and noVNC, start precompiled Podman Desktop and start the documentation rendering.\\n\\nIt is not launching the Watch mode/development mode of Podman Desktop as it requires a container having more than 8GB of memory.\\n\\nPicking up a larger instance with for example 16GB, it\'s possible to use development mode.\\n\\nOf course, to make VNC happy, we need to specify the `DISPLAY` environment variable.\\n\\n```json\\n\\"remoteEnv\\": {\\n \\"DISPLAY\\": \\":0\\"\\n}\\n```\\n\\nWhen the DevContainer is fully available, we want to have a way to quickly open the `Website rendering URL` and `noVNC`\\n\\nLet\'s tweak the `devcontainer.json` file by adding the `portsAttributes` section\\n\\n```json\\n\\"portsAttributes\\": {\\n \\"9000\\": {\\n \\"label\\": \\"vnc\\",\\n \\"onAutoForward\\": \\"openPreview\\"\\n },\\n \\"3000\\": {\\n \\"label\\": \\"website\\"\\n }\\n}\\n```\\n\\nAfter all post-creation steps, the `Preview` browser inside the VS Code editor will open a window to VNC. And another port (`3000`) is flagged for the website.\\n\\n## Using the DevContainer.json on Github Codespace\\n\\nAs a user, opening a workspace with all what we configured is done using a single click.\\n\\nGo to https://github.com/containers/podman-desktop then click on the `< > Code` dropdown and click on `Create codespace on main` button.\\n\\n![Open Codespace](img/develop-podman-using-codespaces/codespaces-click-repository.png)\\n\\nOnce you click on the button, the codespace is setting up:\\n\\n![Preparing Codespace](img/develop-podman-using-codespaces/codespaces-preparing-codespace.png)\\n\\nAfter few minutes, as there is not yet [prebuilt codespaces](https://docs.github.com/en/codespaces/prebuilding-your-codespaces/about-github-codespaces-prebuilds), the codespace is opening.\\n\\nThe simple Browser displays the noVNC window:\\n![Opening Codespace](img/develop-podman-using-codespaces/codespaces-open-novnc.png)\\n\\nClick on the connect button. Then on the terminal you can enter `podman run quay.io/podman/hello` and the container is detected in Podman Desktop.\\n![Testing Codespace](img/develop-podman-using-codespaces/codespaces-testing-podman-desktop.png)\\n\\nIt\'s also possible using the port widget to get on `3000` port by clicking on the world icon a preview of the website in another tab. Changing source code of the website will refresh the content of the window.\\n\\nDepending on the usecase, it\'s also possible to open documentation in the preview browser.\\n\\n![Edit website Codespace](img/develop-podman-using-codespaces/codespaces-edit-website.png)\\n\\n## Conclusion\\n\\nThe DevContainer image for Podman Desktop is recent so it\'ll probably evolve over time by adding new capabilities but it allows you to easily build/run/experiment and **contribute** to the tool or the website."}]}')}}]); \ No newline at end of file diff --git a/assets/js/bd80aa65.f0f8caf8.js b/assets/js/bd80aa65.07ae56ee.js similarity index 68% rename from assets/js/bd80aa65.f0f8caf8.js rename to assets/js/bd80aa65.07ae56ee.js index fdb259b4387..f8292232d4d 100644 --- a/assets/js/bd80aa65.f0f8caf8.js +++ b/assets/js/bd80aa65.07ae56ee.js @@ -1 +1 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[3427],{35318:(e,t,n)=>{n.d(t,{Zo:()=>d,kt:()=>k});var r=n(27378);function i(e,t,n){return t in e?Object.defineProperty(e,t,{value:n,enumerable:!0,configurable:!0,writable:!0}):e[t]=n,e}function o(e,t){var n=Object.keys(e);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(e);t&&(r=r.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),n.push.apply(n,r)}return n}function l(e){for(var t=1;t=0||(i[n]=e[n]);return i}(e,t);if(Object.getOwnPropertySymbols){var o=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(i[n]=e[n])}return i}var s=r.createContext({}),c=function(e){var t=r.useContext(s),n=t;return e&&(n="function"==typeof e?e(t):l(l({},t),e)),n},d=function(e){var t=c(e.components);return r.createElement(s.Provider,{value:t},e.children)},u={inlineCode:"code",wrapper:function(e){var t=e.children;return r.createElement(r.Fragment,{},t)}},p=r.forwardRef((function(e,t){var n=e.components,i=e.mdxType,o=e.originalType,s=e.parentName,d=a(e,["components","mdxType","originalType","parentName"]),p=c(n),k=i,g=p["".concat(s,".").concat(k)]||p[k]||u[k]||o;return n?r.createElement(g,l(l({ref:t},d),{},{components:n})):r.createElement(g,l({ref:t},d))}));function k(e,t){var n=arguments,i=t&&t.mdxType;if("string"==typeof e||i){var o=n.length,l=new Array(o);l[0]=p;var a={};for(var s in t)hasOwnProperty.call(t,s)&&(a[s]=t[s]);a.originalType=e,a.mdxType="string"==typeof e?e:i,l[1]=a;for(var c=2;c{n.r(t),n.d(t,{assets:()=>s,contentTitle:()=>l,default:()=>u,frontMatter:()=>o,metadata:()=>a,toc:()=>c});var r=n(25773),i=(n(27378),n(35318));const o={sidebar_position:6,title:"Deleting your Kind cluster",description:"Deleting your local Kind-powered Kubernetes cluster.",keywords:["podman desktop","podman","containers","migrating","kubernetes","kind"],tags:["migrating-to-kubernetes","kind"]},l="Deleting your local Kind-powered Kubernetes cluster",a={unversionedId:"kind/deleting-your-kind-cluster",id:"kind/deleting-your-kind-cluster",title:"Deleting your Kind cluster",description:"Deleting your local Kind-powered Kubernetes cluster.",source:"@site/docs/kind/deleting-your-kind-cluster.md",sourceDirName:"kind",slug:"/kind/deleting-your-kind-cluster",permalink:"/docs/kind/deleting-your-kind-cluster",draft:!1,editUrl:"https://github.com/containers/podman-desktop/tree/main/website/docs/kind/deleting-your-kind-cluster.md",tags:[{label:"migrating-to-kubernetes",permalink:"/docs/tags/migrating-to-kubernetes"},{label:"kind",permalink:"/docs/tags/kind"}],version:"current",sidebarPosition:6,frontMatter:{sidebar_position:6,title:"Deleting your Kind cluster",description:"Deleting your local Kind-powered Kubernetes cluster.",keywords:["podman desktop","podman","containers","migrating","kubernetes","kind"],tags:["migrating-to-kubernetes","kind"]},sidebar:"mySidebar",previous:{title:"Working with your Kind cluster",permalink:"/docs/kind/working-with-your-local-kind-cluster"},next:{title:"Building and testing an image",permalink:"/docs/kind/building-an-image-and-testing-it-in-kind"}},s={},c=[{value:"Prerequisites",id:"prerequisites",level:4},{value:"Procedure",id:"procedure",level:4},{value:"Verification",id:"verification",level:4}],d={toc:c};function u(e){let{components:t,...n}=e;return(0,i.kt)("wrapper",(0,r.Z)({},d,n,{components:t,mdxType:"MDXLayout"}),(0,i.kt)("h1",{id:"deleting-your-local-kind-powered-kubernetes-cluster"},"Deleting your local Kind-powered Kubernetes cluster"),(0,i.kt)("h4",{id:"prerequisites"},"Prerequisites"),(0,i.kt)("ul",null,(0,i.kt)("li",{parentName:"ul"},(0,i.kt)("a",{parentName:"li",href:"/docs/kind/creating-a-kind-cluster"},"You configured Podman"),"."),(0,i.kt)("li",{parentName:"ul"},(0,i.kt)("a",{parentName:"li",href:"https://kind.sigs.k8s.io/"},"You installed Kind"),".")),(0,i.kt)("h4",{id:"procedure"},"Procedure"),(0,i.kt)("ol",null,(0,i.kt)("li",{parentName:"ol"},"Open ",(0,i.kt)("strong",{parentName:"li"},(0,i.kt)("icon",{icon:"fa-solid fa-cog",size:"lg"})," Settings > Resources"),"."),(0,i.kt)("li",{parentName:"ol"},"Find the Kind cluster to delete."),(0,i.kt)("li",{parentName:"ol"},"Click ",(0,i.kt)("icon",{icon:"fa-solid fa-stop",size:"lg"})," to stop the cluster."),(0,i.kt)("li",{parentName:"ol"},"Once the cluster is stopped, click ",(0,i.kt)("icon",{icon:"fa-solid fa-trash",size:"lg"})," to delete it.")),(0,i.kt)("h4",{id:"verification"},"Verification"),(0,i.kt)("ol",null,(0,i.kt)("li",{parentName:"ol"},"In ",(0,i.kt)("strong",{parentName:"li"},(0,i.kt)("icon",{icon:"fa-solid fa-cog",size:"lg"})," Settings > Resources"),", the deleted Kind cluster is not visible.")))}u.isMDXComponent=!0}}]); \ No newline at end of file +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[3427],{35318:(e,t,n)=>{n.d(t,{Zo:()=>d,kt:()=>k});var r=n(27378);function i(e,t,n){return t in e?Object.defineProperty(e,t,{value:n,enumerable:!0,configurable:!0,writable:!0}):e[t]=n,e}function o(e,t){var n=Object.keys(e);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(e);t&&(r=r.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),n.push.apply(n,r)}return n}function l(e){for(var t=1;t=0||(i[n]=e[n]);return i}(e,t);if(Object.getOwnPropertySymbols){var o=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(i[n]=e[n])}return i}var s=r.createContext({}),c=function(e){var t=r.useContext(s),n=t;return e&&(n="function"==typeof e?e(t):l(l({},t),e)),n},d=function(e){var t=c(e.components);return r.createElement(s.Provider,{value:t},e.children)},u={inlineCode:"code",wrapper:function(e){var t=e.children;return r.createElement(r.Fragment,{},t)}},p=r.forwardRef((function(e,t){var n=e.components,i=e.mdxType,o=e.originalType,s=e.parentName,d=a(e,["components","mdxType","originalType","parentName"]),p=c(n),k=i,g=p["".concat(s,".").concat(k)]||p[k]||u[k]||o;return n?r.createElement(g,l(l({ref:t},d),{},{components:n})):r.createElement(g,l({ref:t},d))}));function k(e,t){var n=arguments,i=t&&t.mdxType;if("string"==typeof e||i){var o=n.length,l=new Array(o);l[0]=p;var a={};for(var s in t)hasOwnProperty.call(t,s)&&(a[s]=t[s]);a.originalType=e,a.mdxType="string"==typeof e?e:i,l[1]=a;for(var c=2;c{n.r(t),n.d(t,{assets:()=>s,contentTitle:()=>l,default:()=>k,frontMatter:()=>o,metadata:()=>a,toc:()=>c});var r=n(25773),i=(n(27378),n(35318));const o={sidebar_position:6,title:"Deleting your Kind cluster",description:"Deleting your local Kind-powered Kubernetes cluster.",keywords:["podman desktop","podman","containers","migrating","kubernetes","kind"],tags:["migrating-to-kubernetes","kind"]},l="Deleting your local Kind-powered Kubernetes cluster",a={unversionedId:"kind/deleting-your-kind-cluster",id:"kind/deleting-your-kind-cluster",title:"Deleting your Kind cluster",description:"Deleting your local Kind-powered Kubernetes cluster.",source:"@site/docs/kind/deleting-your-kind-cluster.md",sourceDirName:"kind",slug:"/kind/deleting-your-kind-cluster",permalink:"/docs/kind/deleting-your-kind-cluster",draft:!1,editUrl:"https://github.com/containers/podman-desktop/tree/main/website/docs/kind/deleting-your-kind-cluster.md",tags:[{label:"migrating-to-kubernetes",permalink:"/docs/tags/migrating-to-kubernetes"},{label:"kind",permalink:"/docs/tags/kind"}],version:"current",sidebarPosition:6,frontMatter:{sidebar_position:6,title:"Deleting your Kind cluster",description:"Deleting your local Kind-powered Kubernetes cluster.",keywords:["podman desktop","podman","containers","migrating","kubernetes","kind"],tags:["migrating-to-kubernetes","kind"]},sidebar:"mySidebar",previous:{title:"Working with your Kind cluster",permalink:"/docs/kind/working-with-your-local-kind-cluster"},next:{title:"Building and testing an image",permalink:"/docs/kind/building-an-image-and-testing-it-in-kind"}},s={},c=[{value:"Prerequisites",id:"prerequisites",level:4},{value:"Procedure",id:"procedure",level:4},{value:"Verification",id:"verification",level:4}],d=(u="Icon",function(e){return console.warn("Component "+u+" was not imported, exported, or provided by MDXProvider as global scope"),(0,i.kt)("div",e)});var u;const p={toc:c};function k(e){let{components:t,...n}=e;return(0,i.kt)("wrapper",(0,r.Z)({},p,n,{components:t,mdxType:"MDXLayout"}),(0,i.kt)("h1",{id:"deleting-your-local-kind-powered-kubernetes-cluster"},"Deleting your local Kind-powered Kubernetes cluster"),(0,i.kt)("h4",{id:"prerequisites"},"Prerequisites"),(0,i.kt)("ul",null,(0,i.kt)("li",{parentName:"ul"},(0,i.kt)("a",{parentName:"li",href:"/docs/kind/creating-a-kind-cluster"},"You configured Podman"),"."),(0,i.kt)("li",{parentName:"ul"},(0,i.kt)("a",{parentName:"li",href:"https://kind.sigs.k8s.io/"},"You installed Kind"),".")),(0,i.kt)("h4",{id:"procedure"},"Procedure"),(0,i.kt)("ol",null,(0,i.kt)("li",{parentName:"ol"},"Open ",(0,i.kt)("strong",{parentName:"li"},(0,i.kt)(d,{icon:"fa-solid fa-cog",size:"lg",mdxType:"Icon"})," Settings > Resources"),"."),(0,i.kt)("li",{parentName:"ol"},"Find the Kind cluster to delete."),(0,i.kt)("li",{parentName:"ol"},"Click ",(0,i.kt)(d,{icon:"fa-solid fa-stop",size:"lg",mdxType:"Icon"})," to stop the cluster."),(0,i.kt)("li",{parentName:"ol"},"Once the cluster is stopped, click ",(0,i.kt)(d,{icon:"fa-solid fa-trash",size:"lg",mdxType:"Icon"})," to delete it.")),(0,i.kt)("h4",{id:"verification"},"Verification"),(0,i.kt)("ol",null,(0,i.kt)("li",{parentName:"ol"},"In ",(0,i.kt)("strong",{parentName:"li"},(0,i.kt)(d,{icon:"fa-solid fa-cog",size:"lg",mdxType:"Icon"})," Settings > Resources"),", the deleted Kind cluster is not visible.")))}k.isMDXComponent=!0}}]); \ No newline at end of file diff --git a/assets/js/c5b2f0f9.c0c9ba07.js b/assets/js/c5b2f0f9.4d4620c9.js similarity index 52% rename from assets/js/c5b2f0f9.c0c9ba07.js rename to assets/js/c5b2f0f9.4d4620c9.js index 8d2073f7360..cf0660c928d 100644 --- a/assets/js/c5b2f0f9.c0c9ba07.js +++ b/assets/js/c5b2f0f9.4d4620c9.js @@ -1 +1 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[2193],{35318:(e,t,i)=>{i.d(t,{Zo:()=>m,kt:()=>p});var r=i(27378);function n(e,t,i){return t in e?Object.defineProperty(e,t,{value:i,enumerable:!0,configurable:!0,writable:!0}):e[t]=i,e}function a(e,t){var i=Object.keys(e);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(e);t&&(r=r.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),i.push.apply(i,r)}return i}function o(e){for(var t=1;t=0||(n[i]=e[i]);return n}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,i)&&(n[i]=e[i])}return n}var l=r.createContext({}),g=function(e){var t=r.useContext(l),i=t;return e&&(i="function"==typeof e?e(t):o(o({},t),e)),i},m=function(e){var t=g(e.components);return r.createElement(l.Provider,{value:t},e.children)},c={inlineCode:"code",wrapper:function(e){var t=e.children;return r.createElement(r.Fragment,{},t)}},u=r.forwardRef((function(e,t){var i=e.components,n=e.mdxType,a=e.originalType,l=e.parentName,m=s(e,["components","mdxType","originalType","parentName"]),u=g(i),p=n,d=u["".concat(l,".").concat(p)]||u[p]||c[p]||a;return i?r.createElement(d,o(o({ref:t},m),{},{components:i})):r.createElement(d,o({ref:t},m))}));function p(e,t){var i=arguments,n=t&&t.mdxType;if("string"==typeof e||n){var a=i.length,o=new Array(a);o[0]=u;var s={};for(var l in t)hasOwnProperty.call(t,l)&&(s[l]=t[l]);s.originalType=e,s.mdxType="string"==typeof e?e:n,o[1]=s;for(var g=2;g{i.r(t),i.d(t,{assets:()=>l,contentTitle:()=>o,default:()=>c,frontMatter:()=>a,metadata:()=>s,toc:()=>g});var r=i(25773),n=(i(27378),i(35318));const a={sidebar_position:21,title:"Pushing an image to a registry",description:"Pushing an image to a registry.",keywords:["podman desktop","podman","containers","image","registry","registries"],tags:["images"]},o="Pushing an image to a registry",s={unversionedId:"containers/images/pushing-an-image-to-a-registry",id:"containers/images/pushing-an-image-to-a-registry",title:"Pushing an image to a registry",description:"Pushing an image to a registry.",source:"@site/docs/containers/images/pushing-an-image-to-a-registry.md",sourceDirName:"containers/images",slug:"/containers/images/pushing-an-image-to-a-registry",permalink:"/docs/containers/images/pushing-an-image-to-a-registry",draft:!1,editUrl:"https://github.com/containers/podman-desktop/tree/main/website/docs/containers/images/pushing-an-image-to-a-registry.md",tags:[{label:"images",permalink:"/docs/tags/images"}],version:"current",sidebarPosition:21,frontMatter:{sidebar_position:21,title:"Pushing an image to a registry",description:"Pushing an image to a registry.",keywords:["podman desktop","podman","containers","image","registry","registries"],tags:["images"]},sidebar:"mySidebar",previous:{title:"Building an image",permalink:"/docs/containers/images/building-an-image"},next:{title:"Pulling an image",permalink:"/docs/containers/images/pulling-an-image"}},l={},g=[{value:"Prerequisites",id:"prerequisites",level:4},{value:"Procedure",id:"procedure",level:4},{value:"Verification",id:"verification",level:4}],m={toc:g};function c(e){let{components:t,...i}=e;return(0,n.kt)("wrapper",(0,r.Z)({},m,i,{components:t,mdxType:"MDXLayout"}),(0,n.kt)("h1",{id:"pushing-an-image-to-a-registry"},"Pushing an image to a registry"),(0,n.kt)("p",null,"With Podman Desktop, you can push an image to registries."),(0,n.kt)("h4",{id:"prerequisites"},"Prerequisites"),(0,n.kt)("ul",null,(0,n.kt)("li",{parentName:"ul"},"You have configured your registry ",(0,n.kt)("strong",{parentName:"li"},(0,n.kt)("icon",{icon:"fa-solid fa-cog",size:"lg"})," Settings > Registries"),"."),(0,n.kt)("li",{parentName:"ul"},"You have built an image, which name is the fully qualified name required for your registry, such as ",(0,n.kt)("inlineCode",{parentName:"li"},"quay.io/my-repository/my-image"),", ",(0,n.kt)("inlineCode",{parentName:"li"},"ghcr.io/my-repository/my-image"),", or ",(0,n.kt)("inlineCode",{parentName:"li"},"docker.io/my-repository/my-image"),".\nEnsure that the image name includes the registry where to publish the image. To publish on ",(0,n.kt)("inlineCode",{parentName:"li"},"quay.io/repository")," the image ",(0,n.kt)("inlineCode",{parentName:"li"},"my-image"),", the FQN image name should be ",(0,n.kt)("inlineCode",{parentName:"li"},"quay.io/repository/my-image"),".")),(0,n.kt)("h4",{id:"procedure"},"Procedure"),(0,n.kt)("ol",null,(0,n.kt)("li",{parentName:"ol"},"Go to ",(0,n.kt)("strong",{parentName:"li"},(0,n.kt)("icon",{icon:"fa-solid fa-cloud",size:"lg"})," Images"),"."),(0,n.kt)("li",{parentName:"ol"},"On your image line, click ",(0,n.kt)("strong",{parentName:"li"},(0,n.kt)("icon",{icon:"fa-solid fa-ellipsis-v",size:"lg"})," > ",(0,n.kt)("icon",{icon:"fa-solid fa-arrow-up",size:"lg"}),"Push Image"),"."),(0,n.kt)("li",{parentName:"ol"},"Select the Image tag for your registry."),(0,n.kt)("li",{parentName:"ol"},"Click ",(0,n.kt)("strong",{parentName:"li"},(0,n.kt)("icon",{icon:"fa-solid fa-arrow-up",size:"lg"}),"Push Image"),"."),(0,n.kt)("li",{parentName:"ol"},"Click ",(0,n.kt)("strong",{parentName:"li"},"Done"),".")),(0,n.kt)("h4",{id:"verification"},"Verification"),(0,n.kt)("ol",null,(0,n.kt)("li",{parentName:"ol"},"Go to your container registry."),(0,n.kt)("li",{parentName:"ol"},"Find your image.")))}c.isMDXComponent=!0}}]); \ No newline at end of file +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[2193],{35318:(e,t,i)=>{i.d(t,{Zo:()=>m,kt:()=>u});var r=i(27378);function n(e,t,i){return t in e?Object.defineProperty(e,t,{value:i,enumerable:!0,configurable:!0,writable:!0}):e[t]=i,e}function a(e,t){var i=Object.keys(e);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(e);t&&(r=r.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),i.push.apply(i,r)}return i}function o(e){for(var t=1;t=0||(n[i]=e[i]);return n}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,i)&&(n[i]=e[i])}return n}var l=r.createContext({}),g=function(e){var t=r.useContext(l),i=t;return e&&(i="function"==typeof e?e(t):o(o({},t),e)),i},m=function(e){var t=g(e.components);return r.createElement(l.Provider,{value:t},e.children)},c={inlineCode:"code",wrapper:function(e){var t=e.children;return r.createElement(r.Fragment,{},t)}},p=r.forwardRef((function(e,t){var i=e.components,n=e.mdxType,a=e.originalType,l=e.parentName,m=s(e,["components","mdxType","originalType","parentName"]),p=g(i),u=n,d=p["".concat(l,".").concat(u)]||p[u]||c[u]||a;return i?r.createElement(d,o(o({ref:t},m),{},{components:i})):r.createElement(d,o({ref:t},m))}));function u(e,t){var i=arguments,n=t&&t.mdxType;if("string"==typeof e||n){var a=i.length,o=new Array(a);o[0]=p;var s={};for(var l in t)hasOwnProperty.call(t,l)&&(s[l]=t[l]);s.originalType=e,s.mdxType="string"==typeof e?e:n,o[1]=s;for(var g=2;g{i.r(t),i.d(t,{assets:()=>l,contentTitle:()=>o,default:()=>u,frontMatter:()=>a,metadata:()=>s,toc:()=>g});var r=i(25773),n=(i(27378),i(35318));const a={sidebar_position:21,title:"Pushing an image to a registry",description:"Pushing an image to a registry.",keywords:["podman desktop","podman","containers","image","registry","registries"],tags:["images"]},o="Pushing an image to a registry",s={unversionedId:"containers/images/pushing-an-image-to-a-registry",id:"containers/images/pushing-an-image-to-a-registry",title:"Pushing an image to a registry",description:"Pushing an image to a registry.",source:"@site/docs/containers/images/pushing-an-image-to-a-registry.md",sourceDirName:"containers/images",slug:"/containers/images/pushing-an-image-to-a-registry",permalink:"/docs/containers/images/pushing-an-image-to-a-registry",draft:!1,editUrl:"https://github.com/containers/podman-desktop/tree/main/website/docs/containers/images/pushing-an-image-to-a-registry.md",tags:[{label:"images",permalink:"/docs/tags/images"}],version:"current",sidebarPosition:21,frontMatter:{sidebar_position:21,title:"Pushing an image to a registry",description:"Pushing an image to a registry.",keywords:["podman desktop","podman","containers","image","registry","registries"],tags:["images"]},sidebar:"mySidebar",previous:{title:"Building an image",permalink:"/docs/containers/images/building-an-image"},next:{title:"Pulling an image",permalink:"/docs/containers/images/pulling-an-image"}},l={},g=[{value:"Prerequisites",id:"prerequisites",level:4},{value:"Procedure",id:"procedure",level:4},{value:"Verification",id:"verification",level:4}],m=(c="Icon",function(e){return console.warn("Component "+c+" was not imported, exported, or provided by MDXProvider as global scope"),(0,n.kt)("div",e)});var c;const p={toc:g};function u(e){let{components:t,...i}=e;return(0,n.kt)("wrapper",(0,r.Z)({},p,i,{components:t,mdxType:"MDXLayout"}),(0,n.kt)("h1",{id:"pushing-an-image-to-a-registry"},"Pushing an image to a registry"),(0,n.kt)("p",null,"With Podman Desktop, you can push an image to registries."),(0,n.kt)("h4",{id:"prerequisites"},"Prerequisites"),(0,n.kt)("ul",null,(0,n.kt)("li",{parentName:"ul"},"You have configured your registry ",(0,n.kt)("strong",{parentName:"li"},(0,n.kt)(m,{icon:"fa-solid fa-cog",size:"lg",mdxType:"Icon"})," Settings > Registries"),"."),(0,n.kt)("li",{parentName:"ul"},"You have built an image, which name is the fully qualified name required for your registry, such as ",(0,n.kt)("inlineCode",{parentName:"li"},"quay.io/my-repository/my-image"),", ",(0,n.kt)("inlineCode",{parentName:"li"},"ghcr.io/my-repository/my-image"),", or ",(0,n.kt)("inlineCode",{parentName:"li"},"docker.io/my-repository/my-image"),".\nEnsure that the image name includes the registry where to publish the image. To publish on ",(0,n.kt)("inlineCode",{parentName:"li"},"quay.io/repository")," the image ",(0,n.kt)("inlineCode",{parentName:"li"},"my-image"),", the FQN image name should be ",(0,n.kt)("inlineCode",{parentName:"li"},"quay.io/repository/my-image"),".")),(0,n.kt)("h4",{id:"procedure"},"Procedure"),(0,n.kt)("ol",null,(0,n.kt)("li",{parentName:"ol"},"Go to ",(0,n.kt)("strong",{parentName:"li"},(0,n.kt)(m,{icon:"fa-solid fa-cloud",size:"lg",mdxType:"Icon"})," Images"),"."),(0,n.kt)("li",{parentName:"ol"},"On your image line, click ",(0,n.kt)("strong",{parentName:"li"},(0,n.kt)(m,{icon:"fa-solid fa-ellipsis-v",size:"lg",mdxType:"Icon"})," > ",(0,n.kt)(m,{icon:"fa-solid fa-arrow-up",size:"lg",mdxType:"Icon"}),"Push Image"),"."),(0,n.kt)("li",{parentName:"ol"},"Select the Image tag for your registry."),(0,n.kt)("li",{parentName:"ol"},"Click ",(0,n.kt)("strong",{parentName:"li"},(0,n.kt)(m,{icon:"fa-solid fa-arrow-up",size:"lg",mdxType:"Icon"}),"Push Image"),"."),(0,n.kt)("li",{parentName:"ol"},"Click ",(0,n.kt)("strong",{parentName:"li"},"Done"),".")),(0,n.kt)("h4",{id:"verification"},"Verification"),(0,n.kt)("ol",null,(0,n.kt)("li",{parentName:"ol"},"Go to your container registry."),(0,n.kt)("li",{parentName:"ol"},"Find your image.")))}u.isMDXComponent=!0}}]); \ No newline at end of file diff --git a/assets/js/ccc49370.0a9a510b.js b/assets/js/ccc49370.1191af98.js similarity index 99% rename from assets/js/ccc49370.0a9a510b.js rename to assets/js/ccc49370.1191af98.js index f9110750a12..5f5be634685 100644 --- a/assets/js/ccc49370.0a9a510b.js +++ b/assets/js/ccc49370.1191af98.js @@ -1 +1 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[6103],{83227:(e,t,n)=>{n.r(t),n.d(t,{default:()=>h});var a=n(27378),l=n(38944),r=n(1123),o=n(75484),i=n(70412),c=n(55228),s=n(25532),m=n(25773),d=n(99213),u=n(14582);function g(e){const{nextItem:t,prevItem:n}=e;return a.createElement("nav",{className:"pagination-nav docusaurus-mt-lg","aria-label":(0,d.I)({id:"theme.blog.post.paginator.navAriaLabel",message:"Blog post page navigation",description:"The ARIA label for the blog posts pagination"})},n&&a.createElement(u.Z,(0,m.Z)({},n,{subLabel:a.createElement(d.Z,{id:"theme.blog.post.paginator.newerPost",description:"The blog post button label to navigate to the newer/previous post"},"Newer Post")})),t&&a.createElement(u.Z,(0,m.Z)({},t,{subLabel:a.createElement(d.Z,{id:"theme.blog.post.paginator.olderPost",description:"The blog post button label to navigate to the older/next post"},"Older Post"),isNext:!0})))}function v(){const{assets:e,metadata:t}=(0,i.C)(),{title:n,description:l,date:o,tags:c,authors:s,frontMatter:m}=t,{keywords:d}=m,u=e.image??m.image;return a.createElement(r.d,{title:n,description:l,keywords:d,image:u},a.createElement("meta",{property:"og:type",content:"article"}),a.createElement("meta",{property:"article:published_time",content:o}),s.some((e=>e.url))&&a.createElement("meta",{property:"article:author",content:s.map((e=>e.url)).filter(Boolean).join(",")}),c.length>0&&a.createElement("meta",{property:"article:tag",content:c.map((e=>e.label)).join(",")}))}var f=n(17061);function p(e){let{sidebar:t,children:n}=e;const{metadata:l,toc:r}=(0,i.C)(),{nextItem:o,prevItem:m,frontMatter:d}=l,{hide_table_of_contents:u,toc_min_heading_level:v,toc_max_heading_level:p}=d;return a.createElement(c.Z,{sidebar:t,toc:!u&&r.length>0?a.createElement(f.Z,{toc:r,minHeadingLevel:v,maxHeadingLevel:p}):void 0},a.createElement(s.Z,null,n),(o||m)&&a.createElement(g,{nextItem:o,prevItem:m}))}function h(e){const t=e.content;return a.createElement(i.n,{content:e.content,isBlogPostPage:!0},a.createElement(r.FG,{className:(0,l.Z)(o.k.wrapper.blogPages,o.k.page.blogPostPage)},a.createElement(v,null),a.createElement(p,{sidebar:e.sidebar},a.createElement(t,null))))}},17061:(e,t,n)=>{n.d(t,{Z:()=>c});var a=n(25773),l=n(27378),r=n(38944),o=n(36033);const i="tableOfContents_XG6w";function c(e){let{className:t,...n}=e;return l.createElement("div",{className:(0,r.Z)(i,"thin-scrollbar",t)},l.createElement(o.Z,(0,a.Z)({},n,{linkClassName:"table-of-contents__link toc-highlight",linkActiveClassName:"table-of-contents__link--active"})))}},36033:(e,t,n)=>{n.d(t,{Z:()=>v});var a=n(25773),l=n(27378),r=n(20624);function o(e){const t=e.map((e=>({...e,parentIndex:-1,children:[]}))),n=Array(7).fill(-1);t.forEach(((e,t)=>{const a=n.slice(2,e.level);e.parentIndex=Math.max(...a),n[e.level]=t}));const a=[];return t.forEach((e=>{const{parentIndex:n,...l}=e;n>=0?t[n].children.push(l):a.push(l)})),a}function i(e){let{toc:t,minHeadingLevel:n,maxHeadingLevel:a}=e;return t.flatMap((e=>{const t=i({toc:e.children,minHeadingLevel:n,maxHeadingLevel:a});return function(e){return e.level>=n&&e.level<=a}(e)?[{...e,children:t}]:t}))}function c(e){const t=e.getBoundingClientRect();return t.top===t.bottom?c(e.parentNode):t}function s(e,t){let{anchorTopOffset:n}=t;const a=e.find((e=>c(e).top>=n));if(a){return function(e){return e.top>0&&e.bottom{e.current=t?0:document.querySelector(".navbar").clientHeight}),[t]),e}function d(e){const t=(0,l.useRef)(void 0),n=m();(0,l.useEffect)((()=>{if(!e)return()=>{};const{linkClassName:a,linkActiveClassName:l,minHeadingLevel:r,maxHeadingLevel:o}=e;function i(){const e=function(e){return Array.from(document.getElementsByClassName(e))}(a),i=function(e){let{minHeadingLevel:t,maxHeadingLevel:n}=e;const a=[];for(let l=t;l<=n;l+=1)a.push(`h${l}.anchor`);return Array.from(document.querySelectorAll(a.join()))}({minHeadingLevel:r,maxHeadingLevel:o}),c=s(i,{anchorTopOffset:n.current}),m=e.find((e=>c&&c.id===function(e){return decodeURIComponent(e.href.substring(e.href.indexOf("#")+1))}(e)));e.forEach((e=>{!function(e,n){n?(t.current&&t.current!==e&&t.current.classList.remove(l),e.classList.add(l),t.current=e):e.classList.remove(l)}(e,e===m)}))}return document.addEventListener("scroll",i),document.addEventListener("resize",i),i(),()=>{document.removeEventListener("scroll",i),document.removeEventListener("resize",i)}}),[e,n])}function u(e){let{toc:t,className:n,linkClassName:a,isChild:r}=e;return t.length?l.createElement("ul",{className:r?void 0:n},t.map((e=>l.createElement("li",{key:e.id},l.createElement("a",{href:`#${e.id}`,className:a??void 0,dangerouslySetInnerHTML:{__html:e.value}}),l.createElement(u,{isChild:!0,toc:e.children,className:n,linkClassName:a}))))):null}const g=l.memo(u);function v(e){let{toc:t,className:n="table-of-contents table-of-contents__left-border",linkClassName:c="table-of-contents__link",linkActiveClassName:s,minHeadingLevel:m,maxHeadingLevel:u,...v}=e;const f=(0,r.L)(),p=m??f.tableOfContents.minHeadingLevel,h=u??f.tableOfContents.maxHeadingLevel,b=function(e){let{toc:t,minHeadingLevel:n,maxHeadingLevel:a}=e;return(0,l.useMemo)((()=>i({toc:o(t),minHeadingLevel:n,maxHeadingLevel:a})),[t,n,a])}({toc:t,minHeadingLevel:p,maxHeadingLevel:h});return d((0,l.useMemo)((()=>{if(c&&s)return{linkClassName:c,linkActiveClassName:s,minHeadingLevel:p,maxHeadingLevel:h}}),[c,s,p,h])),l.createElement(g,(0,a.Z)({toc:b,className:n,linkClassName:c},v))}},85978:(e,t,n)=>{n.d(t,{Z:()=>r});var a=n(27378),l=n(10610);function r(e){const t={...e};return t?.code?.length>2&&("$ "===t.code.substring(0,2)||"# "===t.code.substring(0,2)||"> "===t.code.substring(0,2))&&(t.code=t.code.substring(2)),a.createElement(a.Fragment,null,a.createElement(l.Z,t))}},35654:(e,t,n)=>{n.d(t,{Z:()=>c});var a=n(80256),l=n(92739),r=n(30537),o=n(9928),i=n(19374);r.vI.add(o.vnX,i.mRB);const c={...a.Z,icon:l.G}}}]); \ No newline at end of file +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[6103],{83227:(e,t,n)=>{n.r(t),n.d(t,{default:()=>h});var a=n(27378),l=n(38944),r=n(1123),o=n(75484),i=n(70412),c=n(55228),s=n(25532),m=n(25773),d=n(99213),u=n(14582);function g(e){const{nextItem:t,prevItem:n}=e;return a.createElement("nav",{className:"pagination-nav docusaurus-mt-lg","aria-label":(0,d.I)({id:"theme.blog.post.paginator.navAriaLabel",message:"Blog post page navigation",description:"The ARIA label for the blog posts pagination"})},n&&a.createElement(u.Z,(0,m.Z)({},n,{subLabel:a.createElement(d.Z,{id:"theme.blog.post.paginator.newerPost",description:"The blog post button label to navigate to the newer/previous post"},"Newer Post")})),t&&a.createElement(u.Z,(0,m.Z)({},t,{subLabel:a.createElement(d.Z,{id:"theme.blog.post.paginator.olderPost",description:"The blog post button label to navigate to the older/next post"},"Older Post"),isNext:!0})))}function v(){const{assets:e,metadata:t}=(0,i.C)(),{title:n,description:l,date:o,tags:c,authors:s,frontMatter:m}=t,{keywords:d}=m,u=e.image??m.image;return a.createElement(r.d,{title:n,description:l,keywords:d,image:u},a.createElement("meta",{property:"og:type",content:"article"}),a.createElement("meta",{property:"article:published_time",content:o}),s.some((e=>e.url))&&a.createElement("meta",{property:"article:author",content:s.map((e=>e.url)).filter(Boolean).join(",")}),c.length>0&&a.createElement("meta",{property:"article:tag",content:c.map((e=>e.label)).join(",")}))}var f=n(17061);function p(e){let{sidebar:t,children:n}=e;const{metadata:l,toc:r}=(0,i.C)(),{nextItem:o,prevItem:m,frontMatter:d}=l,{hide_table_of_contents:u,toc_min_heading_level:v,toc_max_heading_level:p}=d;return a.createElement(c.Z,{sidebar:t,toc:!u&&r.length>0?a.createElement(f.Z,{toc:r,minHeadingLevel:v,maxHeadingLevel:p}):void 0},a.createElement(s.Z,null,n),(o||m)&&a.createElement(g,{nextItem:o,prevItem:m}))}function h(e){const t=e.content;return a.createElement(i.n,{content:e.content,isBlogPostPage:!0},a.createElement(r.FG,{className:(0,l.Z)(o.k.wrapper.blogPages,o.k.page.blogPostPage)},a.createElement(v,null),a.createElement(p,{sidebar:e.sidebar},a.createElement(t,null))))}},17061:(e,t,n)=>{n.d(t,{Z:()=>c});var a=n(25773),l=n(27378),r=n(38944),o=n(36033);const i="tableOfContents_XG6w";function c(e){let{className:t,...n}=e;return l.createElement("div",{className:(0,r.Z)(i,"thin-scrollbar",t)},l.createElement(o.Z,(0,a.Z)({},n,{linkClassName:"table-of-contents__link toc-highlight",linkActiveClassName:"table-of-contents__link--active"})))}},36033:(e,t,n)=>{n.d(t,{Z:()=>v});var a=n(25773),l=n(27378),r=n(20624);function o(e){const t=e.map((e=>({...e,parentIndex:-1,children:[]}))),n=Array(7).fill(-1);t.forEach(((e,t)=>{const a=n.slice(2,e.level);e.parentIndex=Math.max(...a),n[e.level]=t}));const a=[];return t.forEach((e=>{const{parentIndex:n,...l}=e;n>=0?t[n].children.push(l):a.push(l)})),a}function i(e){let{toc:t,minHeadingLevel:n,maxHeadingLevel:a}=e;return t.flatMap((e=>{const t=i({toc:e.children,minHeadingLevel:n,maxHeadingLevel:a});return function(e){return e.level>=n&&e.level<=a}(e)?[{...e,children:t}]:t}))}function c(e){const t=e.getBoundingClientRect();return t.top===t.bottom?c(e.parentNode):t}function s(e,t){let{anchorTopOffset:n}=t;const a=e.find((e=>c(e).top>=n));if(a){return function(e){return e.top>0&&e.bottom{e.current=t?0:document.querySelector(".navbar").clientHeight}),[t]),e}function d(e){const t=(0,l.useRef)(void 0),n=m();(0,l.useEffect)((()=>{if(!e)return()=>{};const{linkClassName:a,linkActiveClassName:l,minHeadingLevel:r,maxHeadingLevel:o}=e;function i(){const e=function(e){return Array.from(document.getElementsByClassName(e))}(a),i=function(e){let{minHeadingLevel:t,maxHeadingLevel:n}=e;const a=[];for(let l=t;l<=n;l+=1)a.push(`h${l}.anchor`);return Array.from(document.querySelectorAll(a.join()))}({minHeadingLevel:r,maxHeadingLevel:o}),c=s(i,{anchorTopOffset:n.current}),m=e.find((e=>c&&c.id===function(e){return decodeURIComponent(e.href.substring(e.href.indexOf("#")+1))}(e)));e.forEach((e=>{!function(e,n){n?(t.current&&t.current!==e&&t.current.classList.remove(l),e.classList.add(l),t.current=e):e.classList.remove(l)}(e,e===m)}))}return document.addEventListener("scroll",i),document.addEventListener("resize",i),i(),()=>{document.removeEventListener("scroll",i),document.removeEventListener("resize",i)}}),[e,n])}function u(e){let{toc:t,className:n,linkClassName:a,isChild:r}=e;return t.length?l.createElement("ul",{className:r?void 0:n},t.map((e=>l.createElement("li",{key:e.id},l.createElement("a",{href:`#${e.id}`,className:a??void 0,dangerouslySetInnerHTML:{__html:e.value}}),l.createElement(u,{isChild:!0,toc:e.children,className:n,linkClassName:a}))))):null}const g=l.memo(u);function v(e){let{toc:t,className:n="table-of-contents table-of-contents__left-border",linkClassName:c="table-of-contents__link",linkActiveClassName:s,minHeadingLevel:m,maxHeadingLevel:u,...v}=e;const f=(0,r.L)(),p=m??f.tableOfContents.minHeadingLevel,h=u??f.tableOfContents.maxHeadingLevel,b=function(e){let{toc:t,minHeadingLevel:n,maxHeadingLevel:a}=e;return(0,l.useMemo)((()=>i({toc:o(t),minHeadingLevel:n,maxHeadingLevel:a})),[t,n,a])}({toc:t,minHeadingLevel:p,maxHeadingLevel:h});return d((0,l.useMemo)((()=>{if(c&&s)return{linkClassName:c,linkActiveClassName:s,minHeadingLevel:p,maxHeadingLevel:h}}),[c,s,p,h])),l.createElement(g,(0,a.Z)({toc:b,className:n,linkClassName:c},v))}},85978:(e,t,n)=>{n.d(t,{Z:()=>r});var a=n(27378),l=n(10610);function r(e){const t={...e};return t?.code?.length>2&&("$ "===t.code.substring(0,2)||"# "===t.code.substring(0,2)||"> "===t.code.substring(0,2))&&(t.code=t.code.substring(2)),a.createElement(a.Fragment,null,a.createElement(l.Z,t))}},35654:(e,t,n)=>{n.d(t,{Z:()=>c});var a=n(80256),l=n(92739),r=n(30537),o=n(9928),i=n(19374);r.vI.add(o.vnX,i.mRB);const c={...a.Z,Icon:l.G}}}]); \ No newline at end of file diff --git a/assets/js/d1b15a6d.51e398af.js b/assets/js/d1b15a6d.51e398af.js new file mode 100644 index 00000000000..7497cb35ffd --- /dev/null +++ b/assets/js/d1b15a6d.51e398af.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[8532],{35318:(e,t,n)=>{n.d(t,{Zo:()=>p,kt:()=>d});var i=n(27378);function a(e,t,n){return t in e?Object.defineProperty(e,t,{value:n,enumerable:!0,configurable:!0,writable:!0}):e[t]=n,e}function r(e,t){var n=Object.keys(e);if(Object.getOwnPropertySymbols){var i=Object.getOwnPropertySymbols(e);t&&(i=i.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),n.push.apply(n,i)}return n}function o(e){for(var t=1;t=0||(a[n]=e[n]);return a}(e,t);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(e);for(i=0;i=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(a[n]=e[n])}return a}var s=i.createContext({}),m=function(e){var t=i.useContext(s),n=t;return e&&(n="function"==typeof e?e(t):o(o({},t),e)),n},p=function(e){var t=m(e.components);return i.createElement(s.Provider,{value:t},e.children)},c={inlineCode:"code",wrapper:function(e){var t=e.children;return i.createElement(i.Fragment,{},t)}},u=i.forwardRef((function(e,t){var n=e.components,a=e.mdxType,r=e.originalType,s=e.parentName,p=l(e,["components","mdxType","originalType","parentName"]),u=m(n),d=a,k=u["".concat(s,".").concat(d)]||u[d]||c[d]||r;return n?i.createElement(k,o(o({ref:t},p),{},{components:n})):i.createElement(k,o({ref:t},p))}));function d(e,t){var n=arguments,a=t&&t.mdxType;if("string"==typeof e||a){var r=n.length,o=new Array(r);o[0]=u;var l={};for(var s in t)hasOwnProperty.call(t,s)&&(l[s]=t[s]);l.originalType=e,l.mdxType="string"==typeof e?e:a,o[1]=l;for(var m=2;m{n.r(t),n.d(t,{assets:()=>s,contentTitle:()=>o,default:()=>d,frontMatter:()=>r,metadata:()=>l,toc:()=>m});var i=n(25773),a=(n(27378),n(35318));const r={sidebar_position:10,title:"Building and testing an image",description:"Building an image and testing it in Minikube",keywords:["podman desktop","podman","containers","pods","migrating","kubernetes","minikube"],tags:["migrating-to-kubernetes"]},o="Building an image and testing it in Minikube",l={unversionedId:"minikube/building-an-image-and-testing-it-in-minikube",id:"minikube/building-an-image-and-testing-it-in-minikube",title:"Building and testing an image",description:"Building an image and testing it in Minikube",source:"@site/docs/minikube/building-an-image-and-testing-it-in-minikube.md",sourceDirName:"minikube",slug:"/minikube/building-an-image-and-testing-it-in-minikube",permalink:"/docs/minikube/building-an-image-and-testing-it-in-minikube",draft:!1,editUrl:"https://github.com/containers/podman-desktop/tree/main/website/docs/minikube/building-an-image-and-testing-it-in-minikube.md",tags:[{label:"migrating-to-kubernetes",permalink:"/docs/tags/migrating-to-kubernetes"}],version:"current",sidebarPosition:10,frontMatter:{sidebar_position:10,title:"Building and testing an image",description:"Building an image and testing it in Minikube",keywords:["podman desktop","podman","containers","pods","migrating","kubernetes","minikube"],tags:["migrating-to-kubernetes"]},sidebar:"mySidebar",previous:{title:"Deleting your Minikube cluster",permalink:"/docs/minikube/deleting-your-minikube-cluster"},next:{title:"Push an image to Minikube",permalink:"/docs/minikube/pushing-an-image-to-minikube"}},s={},m=[{value:"Prerequisites",id:"prerequisites",level:4},{value:"Procedure",id:"procedure",level:4},{value:"Verification",id:"verification",level:4}],p=(c="Icon",function(e){return console.warn("Component "+c+" was not imported, exported, or provided by MDXProvider as global scope"),(0,a.kt)("div",e)});var c;const u={toc:m};function d(e){let{components:t,...n}=e;return(0,a.kt)("wrapper",(0,i.Z)({},u,n,{components:t,mdxType:"MDXLayout"}),(0,a.kt)("h1",{id:"building-an-image-and-testing-it-in-minikube"},"Building an image and testing it in Minikube"),(0,a.kt)("p",null,"With Podman Desktop, you can build an image with your container engine, and test it in your local Minikube-powered Kubernetes cluster."),(0,a.kt)("h4",{id:"prerequisites"},"Prerequisites"),(0,a.kt)("ul",null,(0,a.kt)("li",{parentName:"ul"},(0,a.kt)("a",{parentName:"li",href:"/docs/containers"},"You onboarded a container engine"),"."),(0,a.kt)("li",{parentName:"ul"},(0,a.kt)("a",{parentName:"li",href:"/docs/minikube"},"You onboarded a Minikube cluster"),"."),(0,a.kt)("li",{parentName:"ul"},(0,a.kt)("a",{parentName:"li",href:"/docs/minikube/working-with-your-local-minikube-cluster"},"You have set your Kubernetes context to your Minikube cluster"),"."),(0,a.kt)("li",{parentName:"ul"},"A container definition file: ",(0,a.kt)("inlineCode",{parentName:"li"},"Containerfile")," or ",(0,a.kt)("inlineCode",{parentName:"li"},"Dockerfile"),".")),(0,a.kt)("h4",{id:"procedure"},"Procedure"),(0,a.kt)("ol",null,(0,a.kt)("li",{parentName:"ol"},(0,a.kt)("p",{parentName:"li"},"Build your image:"),(0,a.kt)("ol",{parentName:"li"},(0,a.kt)("li",{parentName:"ol"},"Open ",(0,a.kt)("strong",{parentName:"li"},(0,a.kt)(p,{icon:"fa-solid fa-cloud",size:"lg",mdxType:"Icon"})," Images > ",(0,a.kt)(p,{icon:"fa-solid fa-cube",size:"lg",mdxType:"Icon"})," Build an image"),"."),(0,a.kt)("li",{parentName:"ol"},(0,a.kt)("strong",{parentName:"li"},"Containerfile path"),": select your ",(0,a.kt)("inlineCode",{parentName:"li"},"Containerfile")," or ",(0,a.kt)("inlineCode",{parentName:"li"},"Dockerfile"),"."),(0,a.kt)("li",{parentName:"ol"},(0,a.kt)("strong",{parentName:"li"},"Build context directory"),": optionally, select a directory different from the directory containing your ",(0,a.kt)("inlineCode",{parentName:"li"},"Containerfile")," or ",(0,a.kt)("inlineCode",{parentName:"li"},"Dockerfile"),"."),(0,a.kt)("li",{parentName:"ol"},(0,a.kt)("strong",{parentName:"li"},"Image Name"),": enter your image name ",(0,a.kt)("inlineCode",{parentName:"li"},"my-custom-image"),"."),(0,a.kt)("li",{parentName:"ol"},"Click ",(0,a.kt)("strong",{parentName:"li"},(0,a.kt)(p,{icon:"fa-solid fa-cube",size:"lg",mdxType:"Icon"})," Build"),"."),(0,a.kt)("li",{parentName:"ol"},"Wait for the image build to finish."),(0,a.kt)("li",{parentName:"ol"},"Click ",(0,a.kt)("strong",{parentName:"li"},"Done")," to get back to the images list."))),(0,a.kt)("li",{parentName:"ol"},(0,a.kt)("p",{parentName:"li"},"Push your image to your Minikube cluster:"),(0,a.kt)("ol",{parentName:"li"},(0,a.kt)("li",{parentName:"ol"},(0,a.kt)("strong",{parentName:"li"},(0,a.kt)(p,{icon:"fa-solid fa-cloud",size:"lg",mdxType:"Icon"})," Search images"),": enter your image name ",(0,a.kt)("inlineCode",{parentName:"li"},"my-custom-image")," to find the image."),(0,a.kt)("li",{parentName:"ol"},"Click ",(0,a.kt)("strong",{parentName:"li"},(0,a.kt)(p,{icon:"fa-solid fa-ellipsis-v",size:"lg",mdxType:"Icon"})," > ",(0,a.kt)(p,{icon:"fa-solid fa-ellipsis-v",size:"lg",mdxType:"Icon"})," Push image to Minikube cluster"),"."))),(0,a.kt)("li",{parentName:"ol"},(0,a.kt)("p",{parentName:"li"},"Test your image by creating a container:"),(0,a.kt)("ol",{parentName:"li"},(0,a.kt)("li",{parentName:"ol"},"Click ",(0,a.kt)("strong",{parentName:"li"},(0,a.kt)(p,{icon:"fa-solid fa-play",size:"lg",mdxType:"Icon"}))," to open the ",(0,a.kt)("strong",{parentName:"li"},"Create a container from image")," dialog."),(0,a.kt)("li",{parentName:"ol"},(0,a.kt)("strong",{parentName:"li"},"Container name"),": enter ",(0,a.kt)("inlineCode",{parentName:"li"},"my-custom-image-container"),"."),(0,a.kt)("li",{parentName:"ol"},"Review the parameters that Podman Desktop has detected from your image definition."),(0,a.kt)("li",{parentName:"ol"},"Click ",(0,a.kt)("strong",{parentName:"li"},(0,a.kt)(p,{icon:"fa-solid fa-play",size:"lg",mdxType:"Icon"})," Start Container")," to start the container in your container engine."))),(0,a.kt)("li",{parentName:"ol"},(0,a.kt)("p",{parentName:"li"},"Test your image and container on your Minikube cluster:"),(0,a.kt)("ol",{parentName:"li"},(0,a.kt)("li",{parentName:"ol"},(0,a.kt)("strong",{parentName:"li"},(0,a.kt)(p,{icon:"fa-solid fa-cloud",size:"lg",mdxType:"Icon"})," Search containers"),": enter ",(0,a.kt)("inlineCode",{parentName:"li"},"my-custom-image-container")," to find the running container."),(0,a.kt)("li",{parentName:"ol"},"Click ",(0,a.kt)("strong",{parentName:"li"},(0,a.kt)(p,{icon:"fa-solid fa-ellipsis-v",size:"lg",mdxType:"Icon"})," > ",(0,a.kt)(p,{icon:"fa-solid fa-rocket",size:"lg",mdxType:"Icon"})," Deploy to Kubernetes")," to open the ",(0,a.kt)("strong",{parentName:"li"},"Deploy generated pod to Kubernetes")," screen."),(0,a.kt)("li",{parentName:"ol"},(0,a.kt)("strong",{parentName:"li"},"Pod Name"),": keep the proposed value ",(0,a.kt)("inlineCode",{parentName:"li"},"my-custom-image-container-pod"),"."),(0,a.kt)("li",{parentName:"ol"},(0,a.kt)("strong",{parentName:"li"},"Use Kubernetes Services"),": select ",(0,a.kt)("strong",{parentName:"li"},"Replace ",(0,a.kt)("inlineCode",{parentName:"strong"},"hostPort")," exposure on containers by Services. It is the recommended way to expose ports, as a cluster policy might prevent to use ",(0,a.kt)("inlineCode",{parentName:"strong"},"hostPort"),".")),(0,a.kt)("li",{parentName:"ol"},(0,a.kt)("strong",{parentName:"li"},"Expose service locally using Kubernetes LoadBalancer"),": if your container is exposing a service, you can use ",(0,a.kt)("inlineCode",{parentName:"li"},"minikube service")," to get a web browser or an URL to use."),(0,a.kt)("li",{parentName:"ol"},"Optionally, if your container is exposing more than one port, select the port to expose."),(0,a.kt)("li",{parentName:"ol"},(0,a.kt)("strong",{parentName:"li"},"Kubernetes namespaces"),": select ",(0,a.kt)("inlineCode",{parentName:"li"},"default"),"."),(0,a.kt)("li",{parentName:"ol"},"Click ",(0,a.kt)("strong",{parentName:"li"},(0,a.kt)(p,{icon:"fa-solid fa-rocket",size:"lg",mdxType:"Icon"})," Deploy"),"."),(0,a.kt)("li",{parentName:"ol"},"Wait for the pod to reach the state: ",(0,a.kt)("strong",{parentName:"li"},"Phase: Running"),"."),(0,a.kt)("li",{parentName:"ol"},"Click ",(0,a.kt)("strong",{parentName:"li"},"Done"),".")))),(0,a.kt)("h4",{id:"verification"},"Verification"),(0,a.kt)("ol",null,(0,a.kt)("li",{parentName:"ol"},"The ",(0,a.kt)("strong",{parentName:"li"},(0,a.kt)(p,{icon:"fa-solid fa-cubes",size:"lg",mdxType:"Icon"})," Pods")," screen lists the running ",(0,a.kt)("inlineCode",{parentName:"li"},"my-image-container-pod")," pod."),(0,a.kt)("li",{parentName:"ol"},"Click on the pod name to view details and logs."),(0,a.kt)("li",{parentName:"ol"},"Optionally, if your container is exposing a service, go to the server URL: your application is running.")))}d.isMDXComponent=!0}}]); \ No newline at end of file diff --git a/assets/js/d1b15a6d.58a24c58.js b/assets/js/d1b15a6d.58a24c58.js deleted file mode 100644 index 94cdf488627..00000000000 --- a/assets/js/d1b15a6d.58a24c58.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[8532],{35318:(e,t,i)=>{i.d(t,{Zo:()=>p,kt:()=>k});var n=i(27378);function a(e,t,i){return t in e?Object.defineProperty(e,t,{value:i,enumerable:!0,configurable:!0,writable:!0}):e[t]=i,e}function r(e,t){var i=Object.keys(e);if(Object.getOwnPropertySymbols){var n=Object.getOwnPropertySymbols(e);t&&(n=n.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),i.push.apply(i,n)}return i}function o(e){for(var t=1;t=0||(a[i]=e[i]);return a}(e,t);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(e);for(n=0;n=0||Object.prototype.propertyIsEnumerable.call(e,i)&&(a[i]=e[i])}return a}var s=n.createContext({}),m=function(e){var t=n.useContext(s),i=t;return e&&(i="function"==typeof e?e(t):o(o({},t),e)),i},p=function(e){var t=m(e.components);return n.createElement(s.Provider,{value:t},e.children)},c={inlineCode:"code",wrapper:function(e){var t=e.children;return n.createElement(n.Fragment,{},t)}},u=n.forwardRef((function(e,t){var i=e.components,a=e.mdxType,r=e.originalType,s=e.parentName,p=l(e,["components","mdxType","originalType","parentName"]),u=m(i),k=a,d=u["".concat(s,".").concat(k)]||u[k]||c[k]||r;return i?n.createElement(d,o(o({ref:t},p),{},{components:i})):n.createElement(d,o({ref:t},p))}));function k(e,t){var i=arguments,a=t&&t.mdxType;if("string"==typeof e||a){var r=i.length,o=new Array(r);o[0]=u;var l={};for(var s in t)hasOwnProperty.call(t,s)&&(l[s]=t[s]);l.originalType=e,l.mdxType="string"==typeof e?e:a,o[1]=l;for(var m=2;m{i.r(t),i.d(t,{assets:()=>s,contentTitle:()=>o,default:()=>c,frontMatter:()=>r,metadata:()=>l,toc:()=>m});var n=i(25773),a=(i(27378),i(35318));const r={sidebar_position:10,title:"Building and testing an image",description:"Building an image and testing it in Minikube",keywords:["podman desktop","podman","containers","pods","migrating","kubernetes","minikube"],tags:["migrating-to-kubernetes"]},o="Building an image and testing it in Minikube",l={unversionedId:"minikube/building-an-image-and-testing-it-in-minikube",id:"minikube/building-an-image-and-testing-it-in-minikube",title:"Building and testing an image",description:"Building an image and testing it in Minikube",source:"@site/docs/minikube/building-an-image-and-testing-it-in-minikube.md",sourceDirName:"minikube",slug:"/minikube/building-an-image-and-testing-it-in-minikube",permalink:"/docs/minikube/building-an-image-and-testing-it-in-minikube",draft:!1,editUrl:"https://github.com/containers/podman-desktop/tree/main/website/docs/minikube/building-an-image-and-testing-it-in-minikube.md",tags:[{label:"migrating-to-kubernetes",permalink:"/docs/tags/migrating-to-kubernetes"}],version:"current",sidebarPosition:10,frontMatter:{sidebar_position:10,title:"Building and testing an image",description:"Building an image and testing it in Minikube",keywords:["podman desktop","podman","containers","pods","migrating","kubernetes","minikube"],tags:["migrating-to-kubernetes"]},sidebar:"mySidebar",previous:{title:"Deleting your Minikube cluster",permalink:"/docs/minikube/deleting-your-minikube-cluster"},next:{title:"Push an image to Minikube",permalink:"/docs/minikube/pushing-an-image-to-minikube"}},s={},m=[{value:"Prerequisites",id:"prerequisites",level:4},{value:"Procedure",id:"procedure",level:4},{value:"Verification",id:"verification",level:4}],p={toc:m};function c(e){let{components:t,...i}=e;return(0,a.kt)("wrapper",(0,n.Z)({},p,i,{components:t,mdxType:"MDXLayout"}),(0,a.kt)("h1",{id:"building-an-image-and-testing-it-in-minikube"},"Building an image and testing it in Minikube"),(0,a.kt)("p",null,"With Podman Desktop, you can build an image with your container engine, and test it in your local Minikube-powered Kubernetes cluster."),(0,a.kt)("h4",{id:"prerequisites"},"Prerequisites"),(0,a.kt)("ul",null,(0,a.kt)("li",{parentName:"ul"},(0,a.kt)("a",{parentName:"li",href:"/docs/containers"},"You onboarded a container engine"),"."),(0,a.kt)("li",{parentName:"ul"},(0,a.kt)("a",{parentName:"li",href:"/docs/minikube"},"You onboarded a Minikube cluster"),"."),(0,a.kt)("li",{parentName:"ul"},(0,a.kt)("a",{parentName:"li",href:"/docs/minikube/working-with-your-local-minikube-cluster"},"You have set your Kubernetes context to your Minikube cluster"),"."),(0,a.kt)("li",{parentName:"ul"},"A container definition file: ",(0,a.kt)("inlineCode",{parentName:"li"},"Containerfile")," or ",(0,a.kt)("inlineCode",{parentName:"li"},"Dockerfile"),".")),(0,a.kt)("h4",{id:"procedure"},"Procedure"),(0,a.kt)("ol",null,(0,a.kt)("li",{parentName:"ol"},(0,a.kt)("p",{parentName:"li"},"Build your image:"),(0,a.kt)("ol",{parentName:"li"},(0,a.kt)("li",{parentName:"ol"},"Open ",(0,a.kt)("strong",{parentName:"li"},(0,a.kt)("icon",{icon:"fa-solid fa-cloud",size:"lg"})," Images > ",(0,a.kt)("icon",{icon:"fa-solid fa-cube",size:"lg"})," Build an image"),"."),(0,a.kt)("li",{parentName:"ol"},(0,a.kt)("strong",{parentName:"li"},"Containerfile path"),": select your ",(0,a.kt)("inlineCode",{parentName:"li"},"Containerfile")," or ",(0,a.kt)("inlineCode",{parentName:"li"},"Dockerfile"),"."),(0,a.kt)("li",{parentName:"ol"},(0,a.kt)("strong",{parentName:"li"},"Build context directory"),": optionally, select a directory different from the directory containing your ",(0,a.kt)("inlineCode",{parentName:"li"},"Containerfile")," or ",(0,a.kt)("inlineCode",{parentName:"li"},"Dockerfile"),"."),(0,a.kt)("li",{parentName:"ol"},(0,a.kt)("strong",{parentName:"li"},"Image Name"),": enter your image name ",(0,a.kt)("inlineCode",{parentName:"li"},"my-custom-image"),"."),(0,a.kt)("li",{parentName:"ol"},"Click ",(0,a.kt)("strong",{parentName:"li"},(0,a.kt)("icon",{icon:"fa-solid fa-cube",size:"lg"})," Build"),"."),(0,a.kt)("li",{parentName:"ol"},"Wait for the image build to finish."),(0,a.kt)("li",{parentName:"ol"},"Click ",(0,a.kt)("strong",{parentName:"li"},"Done")," to get back to the images list."))),(0,a.kt)("li",{parentName:"ol"},(0,a.kt)("p",{parentName:"li"},"Push your image to your Minikube cluster:"),(0,a.kt)("ol",{parentName:"li"},(0,a.kt)("li",{parentName:"ol"},(0,a.kt)("strong",{parentName:"li"},(0,a.kt)("icon",{icon:"fa-solid fa-cloud",size:"lg"})," Search images"),": enter your image name ",(0,a.kt)("inlineCode",{parentName:"li"},"my-custom-image")," to find the image."),(0,a.kt)("li",{parentName:"ol"},"Click ",(0,a.kt)("strong",{parentName:"li"},(0,a.kt)("icon",{icon:"fa-solid fa-ellipsis-v",size:"lg"})," > ",(0,a.kt)("icon",{icon:"fa-solid fa-ellipsis-v",size:"lg"})," Push image to Minikube cluster"),"."))),(0,a.kt)("li",{parentName:"ol"},(0,a.kt)("p",{parentName:"li"},"Test your image by creating a container:"),(0,a.kt)("ol",{parentName:"li"},(0,a.kt)("li",{parentName:"ol"},"Click ",(0,a.kt)("strong",{parentName:"li"},(0,a.kt)("icon",{icon:"fa-solid fa-play",size:"lg"}))," to open the ",(0,a.kt)("strong",{parentName:"li"},"Create a container from image")," dialog."),(0,a.kt)("li",{parentName:"ol"},(0,a.kt)("strong",{parentName:"li"},"Container name"),": enter ",(0,a.kt)("inlineCode",{parentName:"li"},"my-custom-image-container"),"."),(0,a.kt)("li",{parentName:"ol"},"Review the parameters that Podman Desktop has detected from your image definition."),(0,a.kt)("li",{parentName:"ol"},"Click ",(0,a.kt)("strong",{parentName:"li"},(0,a.kt)("icon",{icon:"fa-solid fa-play",size:"lg"})," Start Container")," to start the container in your container engine."))),(0,a.kt)("li",{parentName:"ol"},(0,a.kt)("p",{parentName:"li"},"Test your image and container on your Minikube cluster:"),(0,a.kt)("ol",{parentName:"li"},(0,a.kt)("li",{parentName:"ol"},(0,a.kt)("strong",{parentName:"li"},(0,a.kt)("icon",{icon:"fa-solid fa-cloud",size:"lg"})," Search containers"),": enter ",(0,a.kt)("inlineCode",{parentName:"li"},"my-custom-image-container")," to find the running container."),(0,a.kt)("li",{parentName:"ol"},"Click ",(0,a.kt)("strong",{parentName:"li"},(0,a.kt)("icon",{icon:"fa-solid fa-ellipsis-v",size:"lg"})," > ",(0,a.kt)("icon",{icon:"fa-solid fa-rocket",size:"lg"})," Deploy to Kubernetes")," to open the ",(0,a.kt)("strong",{parentName:"li"},"Deploy generated pod to Kubernetes")," screen."),(0,a.kt)("li",{parentName:"ol"},(0,a.kt)("strong",{parentName:"li"},"Pod Name"),": keep the proposed value ",(0,a.kt)("inlineCode",{parentName:"li"},"my-custom-image-container-pod"),"."),(0,a.kt)("li",{parentName:"ol"},(0,a.kt)("strong",{parentName:"li"},"Use Kubernetes Services"),": select ",(0,a.kt)("strong",{parentName:"li"},"Replace ",(0,a.kt)("inlineCode",{parentName:"strong"},"hostPort")," exposure on containers by Services. It is the recommended way to expose ports, as a cluster policy might prevent to use ",(0,a.kt)("inlineCode",{parentName:"strong"},"hostPort"),".")),(0,a.kt)("li",{parentName:"ol"},(0,a.kt)("strong",{parentName:"li"},"Expose service locally using Kubernetes LoadBalancer"),": if your container is exposing a service, you can use ",(0,a.kt)("inlineCode",{parentName:"li"},"minikube service")," to get a web browser or an URL to use."),(0,a.kt)("li",{parentName:"ol"},"Optionally, if your container is exposing more than one port, select the port to expose."),(0,a.kt)("li",{parentName:"ol"},(0,a.kt)("strong",{parentName:"li"},"Kubernetes namespaces"),": select ",(0,a.kt)("inlineCode",{parentName:"li"},"default"),"."),(0,a.kt)("li",{parentName:"ol"},"Click ",(0,a.kt)("strong",{parentName:"li"},(0,a.kt)("icon",{icon:"fa-solid fa-rocket",size:"lg"})," Deploy"),"."),(0,a.kt)("li",{parentName:"ol"},"Wait for the pod to reach the state: ",(0,a.kt)("strong",{parentName:"li"},"Phase: Running"),"."),(0,a.kt)("li",{parentName:"ol"},"Click ",(0,a.kt)("strong",{parentName:"li"},"Done"),".")))),(0,a.kt)("h4",{id:"verification"},"Verification"),(0,a.kt)("ol",null,(0,a.kt)("li",{parentName:"ol"},"The ",(0,a.kt)("strong",{parentName:"li"},(0,a.kt)("icon",{icon:"fa-solid fa-cubes",size:"lg"})," Pods")," screen lists the running ",(0,a.kt)("inlineCode",{parentName:"li"},"my-image-container-pod")," pod."),(0,a.kt)("li",{parentName:"ol"},"Click on the pod name to view details and logs."),(0,a.kt)("li",{parentName:"ol"},"Optionally, if your container is exposing a service, go to the server URL: your application is running.")))}c.isMDXComponent=!0}}]); \ No newline at end of file diff --git a/assets/js/d651e2ee.43a52878.js b/assets/js/d651e2ee.43a52878.js new file mode 100644 index 00000000000..68b5c7ae9fe --- /dev/null +++ b/assets/js/d651e2ee.43a52878.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[8514],{35318:(e,t,o)=>{o.d(t,{Zo:()=>c,kt:()=>m});var n=o(27378);function r(e,t,o){return t in e?Object.defineProperty(e,t,{value:o,enumerable:!0,configurable:!0,writable:!0}):e[t]=o,e}function a(e,t){var o=Object.keys(e);if(Object.getOwnPropertySymbols){var n=Object.getOwnPropertySymbols(e);t&&(n=n.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),o.push.apply(o,n)}return o}function i(e){for(var t=1;t=0||(r[o]=e[o]);return r}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(n=0;n=0||Object.prototype.propertyIsEnumerable.call(e,o)&&(r[o]=e[o])}return r}var l=n.createContext({}),p=function(e){var t=n.useContext(l),o=t;return e&&(o="function"==typeof e?e(t):i(i({},t),e)),o},c=function(e){var t=p(e.components);return n.createElement(l.Provider,{value:t},e.children)},u={inlineCode:"code",wrapper:function(e){var t=e.children;return n.createElement(n.Fragment,{},t)}},d=n.forwardRef((function(e,t){var o=e.components,r=e.mdxType,a=e.originalType,l=e.parentName,c=s(e,["components","mdxType","originalType","parentName"]),d=p(o),m=r,h=d["".concat(l,".").concat(m)]||d[m]||u[m]||a;return o?n.createElement(h,i(i({ref:t},c),{},{components:o})):n.createElement(h,i({ref:t},c))}));function m(e,t){var o=arguments,r=t&&t.mdxType;if("string"==typeof e||r){var a=o.length,i=new Array(a);i[0]=d;var s={};for(var l in t)hasOwnProperty.call(t,l)&&(s[l]=t[l]);s.originalType=e,s.mdxType="string"==typeof e?e:r,i[1]=s;for(var p=2;p{o.r(t),o.d(t,{assets:()=>l,contentTitle:()=>i,default:()=>m,frontMatter:()=>a,metadata:()=>s,toc:()=>p});var n=o(25773),r=(o(27378),o(35318));const a={sidebar_position:120},i="Troubleshooting",s={unversionedId:"troubleshooting/index",id:"troubleshooting/index",title:"Troubleshooting",description:"If you cannot find your issue here or in the documentation, please fill an issue on our repository. You can also explore the discussions and do a search on similar issues on the repository.",source:"@site/docs/troubleshooting/index.md",sourceDirName:"troubleshooting",slug:"/troubleshooting/",permalink:"/docs/troubleshooting/",draft:!1,editUrl:"https://github.com/containers/podman-desktop/tree/main/website/docs/troubleshooting/index.md",tags:[],version:"current",sidebarPosition:120,frontMatter:{sidebar_position:120},sidebar:"mySidebar",previous:{title:"Installing",permalink:"/docs/extensions/install/"},next:{title:"Troubleshooting Podman",permalink:"/docs/troubleshooting/troubleshooting-podman"}},l={},p=[{value:"Using the Troubleshooting page",id:"using-the-troubleshooting-page",level:2},{value:"Procedure",id:"procedure",level:4},{value:"Additional resources",id:"additional-resources",level:4}],c=(u="Icon",function(e){return console.warn("Component "+u+" was not imported, exported, or provided by MDXProvider as global scope"),(0,r.kt)("div",e)});var u;const d={toc:p};function m(e){let{components:t,...o}=e;return(0,r.kt)("wrapper",(0,n.Z)({},d,o,{components:t,mdxType:"MDXLayout"}),(0,r.kt)("h1",{id:"troubleshooting"},"Troubleshooting"),(0,r.kt)("p",null,"If you cannot find your issue here or in the documentation, please fill an issue on our ",(0,r.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/issues"},"repository"),". You can also explore the ",(0,r.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/discussions"},"discussions")," and do a search on similar issues on the ",(0,r.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/issues"},"repository"),"."),(0,r.kt)("h2",{id:"using-the-troubleshooting-page"},"Using the ",(0,r.kt)("strong",{parentName:"h2"},"Troubleshooting")," page"),(0,r.kt)("p",null,"Podman Desktop has a ",(0,r.kt)("strong",{parentName:"p"},"Troubleshooting")," page to help identify and fix most common errors."),(0,r.kt)("h4",{id:"procedure"},"Procedure"),(0,r.kt)("ol",null,(0,r.kt)("li",{parentName:"ol"},(0,r.kt)("p",{parentName:"li"},"To open the ",(0,r.kt)("strong",{parentName:"p"},"Troubleshooting")," page, click the ",(0,r.kt)("strong",{parentName:"p"},(0,r.kt)(c,{icon:"fa-solid fa-lightbulb",size:"lg",mdxType:"Icon"}))," icon.")),(0,r.kt)("li",{parentName:"ol"},(0,r.kt)("p",{parentName:"li"},"To test the connection to the container engine, click the ",(0,r.kt)("strong",{parentName:"p"},"Ping")," button."),(0,r.kt)("p",{parentName:"li"},"Expect a reply such as: ",(0,r.kt)("em",{parentName:"p"},"Responded: 79,75 (9.10ms)"),".")),(0,r.kt)("li",{parentName:"ol"},(0,r.kt)("p",{parentName:"li"},"To test Click the ",(0,r.kt)("strong",{parentName:"p"},"Check containers")," button."),(0,r.kt)("p",{parentName:"li"},"Expect a reply such as: ",(0,r.kt)("em",{parentName:"p"},"Responded: 16 containers (108.70ms)"),".")),(0,r.kt)("li",{parentName:"ol"},(0,r.kt)("p",{parentName:"li"},"When connection to the container engine failed, to recreate connections to the sockets, click the ",(0,r.kt)("strong",{parentName:"p"},"Reconnect providers")," button."),(0,r.kt)("p",{parentName:"li"},"Expect a reply such as: ",(0,r.kt)("em",{parentName:"p"},"Done in (5.00ms)"),".")),(0,r.kt)("li",{parentName:"ol"},(0,r.kt)("p",{parentName:"li"},"Search for errors in the ",(0,r.kt)("strong",{parentName:"p"},"Logs")," section."))),(0,r.kt)("h4",{id:"additional-resources"},"Additional resources"),(0,r.kt)("ul",null,(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("a",{parentName:"li",href:"/docs/troubleshooting/troubleshooting-podman"},"Troubleshooting Podman")),(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("a",{parentName:"li",href:"/docs/troubleshooting/troubleshooting-podman-on-windows"},"Troubleshooting Podman on Windows")),(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("a",{parentName:"li",href:"/docs/troubleshooting/troubleshooting-podman-on-macos"},"Troubleshooting Podman on macOS")),(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("a",{parentName:"li",href:"/docs/troubleshooting/troubleshooting-podman-on-linux"},"Troubleshooting Podman on Linux")),(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("a",{parentName:"li",href:"/docs/troubleshooting/troubleshooting-openshift-local"},"Troubleshooting OpenShift Local"))))}m.isMDXComponent=!0}}]); \ No newline at end of file diff --git a/assets/js/d651e2ee.ae1174d6.js b/assets/js/d651e2ee.ae1174d6.js deleted file mode 100644 index c0ad05122c4..00000000000 --- a/assets/js/d651e2ee.ae1174d6.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[8514],{35318:(e,t,o)=>{o.d(t,{Zo:()=>c,kt:()=>m});var n=o(27378);function r(e,t,o){return t in e?Object.defineProperty(e,t,{value:o,enumerable:!0,configurable:!0,writable:!0}):e[t]=o,e}function a(e,t){var o=Object.keys(e);if(Object.getOwnPropertySymbols){var n=Object.getOwnPropertySymbols(e);t&&(n=n.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),o.push.apply(o,n)}return o}function i(e){for(var t=1;t=0||(r[o]=e[o]);return r}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(n=0;n=0||Object.prototype.propertyIsEnumerable.call(e,o)&&(r[o]=e[o])}return r}var l=n.createContext({}),p=function(e){var t=n.useContext(l),o=t;return e&&(o="function"==typeof e?e(t):i(i({},t),e)),o},c=function(e){var t=p(e.components);return n.createElement(l.Provider,{value:t},e.children)},u={inlineCode:"code",wrapper:function(e){var t=e.children;return n.createElement(n.Fragment,{},t)}},d=n.forwardRef((function(e,t){var o=e.components,r=e.mdxType,a=e.originalType,l=e.parentName,c=s(e,["components","mdxType","originalType","parentName"]),d=p(o),m=r,h=d["".concat(l,".").concat(m)]||d[m]||u[m]||a;return o?n.createElement(h,i(i({ref:t},c),{},{components:o})):n.createElement(h,i({ref:t},c))}));function m(e,t){var o=arguments,r=t&&t.mdxType;if("string"==typeof e||r){var a=o.length,i=new Array(a);i[0]=d;var s={};for(var l in t)hasOwnProperty.call(t,l)&&(s[l]=t[l]);s.originalType=e,s.mdxType="string"==typeof e?e:r,i[1]=s;for(var p=2;p{o.r(t),o.d(t,{assets:()=>l,contentTitle:()=>i,default:()=>u,frontMatter:()=>a,metadata:()=>s,toc:()=>p});var n=o(25773),r=(o(27378),o(35318));const a={sidebar_position:120},i="Troubleshooting",s={unversionedId:"troubleshooting/index",id:"troubleshooting/index",title:"Troubleshooting",description:"If you cannot find your issue here or in the documentation, please fill an issue on our repository. You can also explore the discussions and do a search on similar issues on the repository.",source:"@site/docs/troubleshooting/index.md",sourceDirName:"troubleshooting",slug:"/troubleshooting/",permalink:"/docs/troubleshooting/",draft:!1,editUrl:"https://github.com/containers/podman-desktop/tree/main/website/docs/troubleshooting/index.md",tags:[],version:"current",sidebarPosition:120,frontMatter:{sidebar_position:120},sidebar:"mySidebar",previous:{title:"Installing",permalink:"/docs/extensions/install/"},next:{title:"Troubleshooting Podman",permalink:"/docs/troubleshooting/troubleshooting-podman"}},l={},p=[{value:"Using the Troubleshooting page",id:"using-the-troubleshooting-page",level:2},{value:"Procedure",id:"procedure",level:4},{value:"Additional resources",id:"additional-resources",level:4}],c={toc:p};function u(e){let{components:t,...o}=e;return(0,r.kt)("wrapper",(0,n.Z)({},c,o,{components:t,mdxType:"MDXLayout"}),(0,r.kt)("h1",{id:"troubleshooting"},"Troubleshooting"),(0,r.kt)("p",null,"If you cannot find your issue here or in the documentation, please fill an issue on our ",(0,r.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/issues"},"repository"),". You can also explore the ",(0,r.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/discussions"},"discussions")," and do a search on similar issues on the ",(0,r.kt)("a",{parentName:"p",href:"https://github.com/containers/podman-desktop/issues"},"repository"),"."),(0,r.kt)("h2",{id:"using-the-troubleshooting-page"},"Using the ",(0,r.kt)("strong",{parentName:"h2"},"Troubleshooting")," page"),(0,r.kt)("p",null,"Podman Desktop has a ",(0,r.kt)("strong",{parentName:"p"},"Troubleshooting")," page to help identify and fix most common errors."),(0,r.kt)("h4",{id:"procedure"},"Procedure"),(0,r.kt)("ol",null,(0,r.kt)("li",{parentName:"ol"},(0,r.kt)("p",{parentName:"li"},"To open the ",(0,r.kt)("strong",{parentName:"p"},"Troubleshooting")," page, click the ",(0,r.kt)("strong",{parentName:"p"},(0,r.kt)("icon",{icon:"fa-solid fa-lightbulb",size:"lg"}))," icon.")),(0,r.kt)("li",{parentName:"ol"},(0,r.kt)("p",{parentName:"li"},"To test the connection to the container engine, click the ",(0,r.kt)("strong",{parentName:"p"},"Ping")," button."),(0,r.kt)("p",{parentName:"li"},"Expect a reply such as: ",(0,r.kt)("em",{parentName:"p"},"Responded: 79,75 (9.10ms)"),".")),(0,r.kt)("li",{parentName:"ol"},(0,r.kt)("p",{parentName:"li"},"To test Click the ",(0,r.kt)("strong",{parentName:"p"},"Check containers")," button."),(0,r.kt)("p",{parentName:"li"},"Expect a reply such as: ",(0,r.kt)("em",{parentName:"p"},"Responded: 16 containers (108.70ms)"),".")),(0,r.kt)("li",{parentName:"ol"},(0,r.kt)("p",{parentName:"li"},"When connection to the container engine failed, to recreate connections to the sockets, click the ",(0,r.kt)("strong",{parentName:"p"},"Reconnect providers")," button."),(0,r.kt)("p",{parentName:"li"},"Expect a reply such as: ",(0,r.kt)("em",{parentName:"p"},"Done in (5.00ms)"),".")),(0,r.kt)("li",{parentName:"ol"},(0,r.kt)("p",{parentName:"li"},"Search for errors in the ",(0,r.kt)("strong",{parentName:"p"},"Logs")," section."))),(0,r.kt)("h4",{id:"additional-resources"},"Additional resources"),(0,r.kt)("ul",null,(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("a",{parentName:"li",href:"/docs/troubleshooting/troubleshooting-podman"},"Troubleshooting Podman")),(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("a",{parentName:"li",href:"/docs/troubleshooting/troubleshooting-podman-on-windows"},"Troubleshooting Podman on Windows")),(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("a",{parentName:"li",href:"/docs/troubleshooting/troubleshooting-podman-on-macos"},"Troubleshooting Podman on macOS")),(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("a",{parentName:"li",href:"/docs/troubleshooting/troubleshooting-podman-on-linux"},"Troubleshooting Podman on Linux")),(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("a",{parentName:"li",href:"/docs/troubleshooting/troubleshooting-openshift-local"},"Troubleshooting OpenShift Local"))))}u.isMDXComponent=!0}}]); \ No newline at end of file diff --git a/assets/js/de311ed4.0d61b40e.js b/assets/js/de311ed4.0d61b40e.js new file mode 100644 index 00000000000..4912cff9048 --- /dev/null +++ b/assets/js/de311ed4.0d61b40e.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[1625],{35318:(e,t,n)=>{n.d(t,{Zo:()=>d,kt:()=>k});var a=n(27378);function o(e,t,n){return t in e?Object.defineProperty(e,t,{value:n,enumerable:!0,configurable:!0,writable:!0}):e[t]=n,e}function i(e,t){var n=Object.keys(e);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);t&&(a=a.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),n.push.apply(n,a)}return n}function r(e){for(var t=1;t=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var i=Object.getOwnPropertySymbols(e);for(a=0;a=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var s=a.createContext({}),p=function(e){var t=a.useContext(s),n=t;return e&&(n="function"==typeof e?e(t):r(r({},t),e)),n},d=function(e){var t=p(e.components);return a.createElement(s.Provider,{value:t},e.children)},m={inlineCode:"code",wrapper:function(e){var t=e.children;return a.createElement(a.Fragment,{},t)}},c=a.forwardRef((function(e,t){var n=e.components,o=e.mdxType,i=e.originalType,s=e.parentName,d=l(e,["components","mdxType","originalType","parentName"]),c=p(n),k=o,u=c["".concat(s,".").concat(k)]||c[k]||m[k]||i;return n?a.createElement(u,r(r({ref:t},d),{},{components:n})):a.createElement(u,r({ref:t},d))}));function k(e,t){var n=arguments,o=t&&t.mdxType;if("string"==typeof e||o){var i=n.length,r=new Array(i);r[0]=c;var l={};for(var s in t)hasOwnProperty.call(t,s)&&(l[s]=t[s]);l.originalType=e,l.mdxType="string"==typeof e?e:o,r[1]=l;for(var p=2;p{n.r(t),n.d(t,{assets:()=>s,contentTitle:()=>r,default:()=>k,frontMatter:()=>i,metadata:()=>l,toc:()=>p});var a=n(25773),o=(n(27378),n(35318));const i={title:"Setting up and running a Kubernetes cluster locally with Podman Desktop",description:"Setting up and running a Kubernetes cluster locally with Podman Desktop",slug:"running-a-local-kubernetes-cluster-with-podman-desktop",authors:["themr0c"],tags:["podman-desktop","story","kubernetes","kind"],hide_table_of_contents:!1},r="Setting up and running a Kubernetes cluster locally with Podman Desktop",l={permalink:"/blog/running-a-local-kubernetes-cluster-with-podman-desktop",source:"@site/blog/2023-04-19-running-a-local-kubernetes-cluster-with-podman-desktop.md",title:"Setting up and running a Kubernetes cluster locally with Podman Desktop",description:"Setting up and running a Kubernetes cluster locally with Podman Desktop",date:"2023-04-19T00:00:00.000Z",formattedDate:"April 19, 2023",tags:[{label:"podman-desktop",permalink:"/blog/tags/podman-desktop"},{label:"story",permalink:"/blog/tags/story"},{label:"kubernetes",permalink:"/blog/tags/kubernetes"},{label:"kind",permalink:"/blog/tags/kind"}],readingTime:8.86,hasTruncateMarker:!0,authors:[{name:"Fabrice Flore-Thebault",title:"Technical writer",url:"https://github.com/themr0c",imageURL:"https://github.com/themr0c.png",key:"themr0c"}],frontMatter:{title:"Setting up and running a Kubernetes cluster locally with Podman Desktop",description:"Setting up and running a Kubernetes cluster locally with Podman Desktop",slug:"running-a-local-kubernetes-cluster-with-podman-desktop",authors:["themr0c"],tags:["podman-desktop","story","kubernetes","kind"],hide_table_of_contents:!1},prevItem:{title:"Release Notes - Podman Desktop 0.15",permalink:"/blog/podman-desktop-release-0.15"},nextItem:{title:"Release Notes - Podman Desktop 0.14",permalink:"/blog/podman-desktop-release-0.14"}},s={authorsImageUrls:[void 0]},p=[{value:"Installing Podman Desktop",id:"installing-podman-desktop",level:2},{value:"Installing and initializing your container engine: Podman",id:"installing-and-initializing-your-container-engine-podman",level:2},{value:"Procedure",id:"procedure",level:4},{value:"Verification",id:"verification",level:4},{value:"Installing and starting your local Kubernetes provider: Kind",id:"installing-and-starting-your-local-kubernetes-provider-kind",level:2},{value:"Verification",id:"verification-1",level:4},{value:"Additional resources",id:"additional-resources",level:4},{value:"Starting the Redis leader",id:"starting-the-redis-leader",level:2},{value:"Procedure",id:"procedure-1",level:4},{value:"Verification",id:"verification-2",level:4},{value:"Starting the Redis followers",id:"starting-the-redis-followers",level:2},{value:"Procedure",id:"procedure-2",level:4},{value:"Verification",id:"verification-3",level:4},{value:"Starting the default frontend",id:"starting-the-default-frontend",level:2},{value:"Procedure",id:"procedure-3",level:4},{value:"Verification",id:"verification-4",level:4}],d=(m="Icon",function(e){return console.warn("Component "+m+" was not imported, exported, or provided by MDXProvider as global scope"),(0,o.kt)("div",e)});var m;const c={toc:p};function k(e){let{components:t,...i}=e;return(0,o.kt)("wrapper",(0,a.Z)({},c,i,{components:t,mdxType:"MDXLayout"}),(0,o.kt)("p",null,"In this blog post you will learn to use Podman Desktop to run the ",(0,o.kt)("a",{parentName:"p",href:"https://kubernetes.io/docs/tutorials/stateless-application/guestbook/"},"Kubernetes documentation example: Deploying PHP Guestbook application with Redis"),"."),(0,o.kt)("p",null,"On the agenda:"),(0,o.kt)("ol",null,(0,o.kt)("li",{parentName:"ol"},"Installing Podman Desktop."),(0,o.kt)("li",{parentName:"ol"},"Installing and initializing your container engine: Podman."),(0,o.kt)("li",{parentName:"ol"},"Installing and starting your local Kubernetes provider: Kind."),(0,o.kt)("li",{parentName:"ol"},"Starting the Redis leader."),(0,o.kt)("li",{parentName:"ol"},"Starting and scaling the Redis followers."),(0,o.kt)("li",{parentName:"ol"},"Starting and exposing the Guestbook frontend.")),(0,o.kt)("h2",{id:"installing-podman-desktop"},"Installing Podman Desktop"),(0,o.kt)("p",null,"You need Podman Desktop."),(0,o.kt)("ol",null,(0,o.kt)("li",{parentName:"ol"},"Go to ",(0,o.kt)("a",{parentName:"li",href:"/docs/installation"},"Podman Desktop installation documentation"),"."),(0,o.kt)("li",{parentName:"ol"},"Click on your platform name: ",(0,o.kt)("a",{parentName:"li",href:"/docs/installation/windows-install"},"Windows"),", ",(0,o.kt)("a",{parentName:"li",href:"/docs/installation/macos-install"},"macOS"),", or ",(0,o.kt)("a",{parentName:"li",href:"/docs/installation/linux-install"},"Linux"),"."),(0,o.kt)("li",{parentName:"ol"},"Follow the instructions. Stick to the default installation method."),(0,o.kt)("li",{parentName:"ol"},"Start ",(0,o.kt)("strong",{parentName:"li"},"Podman Desktop"),".")),(0,o.kt)("p",null,"At this point, you have a graphical user interface to:"),(0,o.kt)("ul",null,(0,o.kt)("li",{parentName:"ul"},"Install Podman and Kind."),(0,o.kt)("li",{parentName:"ul"},"Control and work with your container engines and Kubernetes clusters."),(0,o.kt)("li",{parentName:"ul"},"Run your application on your container engine and migrate it to Kubernetes.")),(0,o.kt)("h2",{id:"installing-and-initializing-your-container-engine-podman"},"Installing and initializing your container engine: Podman"),(0,o.kt)("p",null,"Podman Desktop can control various container engines, such as:"),(0,o.kt)("ul",null,(0,o.kt)("li",{parentName:"ul"},"Docker"),(0,o.kt)("li",{parentName:"ul"},"Lima"),(0,o.kt)("li",{parentName:"ul"},"Podman")),(0,o.kt)("p",null,"Consider installing the Podman container engine for:"),(0,o.kt)("ul",null,(0,o.kt)("li",{parentName:"ul"},"Added security"),(0,o.kt)("li",{parentName:"ul"},"No daemon"),(0,o.kt)("li",{parentName:"ul"},"Open source")),(0,o.kt)("p",null,"Containers are a Linux technology."),(0,o.kt)("ul",null,(0,o.kt)("li",{parentName:"ul"},"On Linux, you can install Podman natively.\nSee: ",(0,o.kt)("a",{parentName:"li",href:"https://podman.io/docs/installation#installing-on-linux"},"Installing Podman on Linux"),"."),(0,o.kt)("li",{parentName:"ul"},"On macOS and Windows, Podman requires to run in a Linux virtual machine: the Podman machine.\nUse Podman Desktop to install Podman and initialize your Podman machine:")),(0,o.kt)("h4",{id:"procedure"},"Procedure"),(0,o.kt)("ol",null,(0,o.kt)("li",{parentName:"ol"},"Open Podman Desktop ",(0,o.kt)("strong",{parentName:"li"},"Dashboard")),(0,o.kt)("li",{parentName:"ol"},"The ",(0,o.kt)("strong",{parentName:"li"},"Dashboard")," displays ",(0,o.kt)("em",{parentName:"li"},"Podman Desktop was not able to find an installation of Podman"),"."),(0,o.kt)("li",{parentName:"ol"},"Click on ",(0,o.kt)("strong",{parentName:"li"},"Install"),"."),(0,o.kt)("li",{parentName:"ol"},"Podman Desktop checks the prerequisites to install Podman Engine. When necessary, follow the instructions to install prerequisites."),(0,o.kt)("li",{parentName:"ol"},"Podman displays the dialog: ",(0,o.kt)("em",{parentName:"li"},"Podman is not installed on this system, would you like to install Podman?"),". Click on ",(0,o.kt)("strong",{parentName:"li"},"Yes")," to install Podman."),(0,o.kt)("li",{parentName:"ol"},"Click on ",(0,o.kt)("strong",{parentName:"li"},"Initialize and start"),".")),(0,o.kt)("h4",{id:"verification"},"Verification"),(0,o.kt)("ul",null,(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},"The ",(0,o.kt)("strong",{parentName:"p"},"Dashboard")," displays ",(0,o.kt)("em",{parentName:"p"},"Podman is running"),"."),(0,o.kt)("p",{parentName:"li"},(0,o.kt)("img",{alt:"Podman is running",src:n(65986).Z,width:"611",height:"219"})))),(0,o.kt)("p",null,"At this point, you can start working with containers."),(0,o.kt)("h2",{id:"installing-and-starting-your-local-kubernetes-provider-kind"},"Installing and starting your local Kubernetes provider: Kind"),(0,o.kt)("p",null,"You want to deploy your application to a local Kubernetes cluster."),(0,o.kt)("p",null,"Podman Desktop can help you run Kind-powered local Kubernetes clusters on a container engine, such as Podman."),(0,o.kt)("p",null,"Podman Desktop helps you ",(0,o.kt)("a",{parentName:"p",href:"/docs/kind/installing"},"installing the ",(0,o.kt)("inlineCode",{parentName:"a"},"kind")," CLI"),":"),(0,o.kt)("ol",null,(0,o.kt)("li",{parentName:"ol"},(0,o.kt)("p",{parentName:"li"},"In the status bar, click on ",(0,o.kt)("strong",{parentName:"p"},"Kind"),", and follow the prompts.")),(0,o.kt)("li",{parentName:"ol"},(0,o.kt)("p",{parentName:"li"},"When the ",(0,o.kt)("inlineCode",{parentName:"p"},"kind")," CLI is available, the status bar does not display ",(0,o.kt)("strong",{parentName:"p"},"Kind"),".")),(0,o.kt)("li",{parentName:"ol"},(0,o.kt)("p",{parentName:"li"},"On Windows, ",(0,o.kt)("a",{parentName:"p",href:"/docs/kind/configuring-podman-for-kind-on-windows"},"configure Podman in rootful mode")),(0,o.kt)("pre",{parentName:"li"},(0,o.kt)("code",{parentName:"pre",className:"language-shell-session"},"$ podman system connection default podman-machine-default-root\n"))),(0,o.kt)("li",{parentName:"ol"},(0,o.kt)("p",{parentName:"li"},"Go to ",(0,o.kt)("strong",{parentName:"p"},(0,o.kt)(d,{icon:"fa-solid fa-cog",size:"lg",mdxType:"Icon"})," Settings > Resources"))),(0,o.kt)("li",{parentName:"ol"},(0,o.kt)("p",{parentName:"li"},"In the ",(0,o.kt)("strong",{parentName:"p"},(0,o.kt)("img",{src:"/img/podman-icon.png",alt:"Podman icon",style:{height:"1.5em",display:"inline"}})," Podman")," tile, click on the ",(0,o.kt)("strong",{parentName:"p"},(0,o.kt)(d,{icon:"fa-solid fa-repeat",size:"lg",mdxType:"Icon"}))," icon to restart the Podman container engine.")),(0,o.kt)("li",{parentName:"ol"},(0,o.kt)("p",{parentName:"li"},"In the ",(0,o.kt)("strong",{parentName:"p"},(0,o.kt)("img",{src:"/img/kind-icon.png",alt:"Kind icon",style:{height:"1.5em",display:"inline"}})," Kind")," tile, click on the ",(0,o.kt)("strong",{parentName:"p"},"Create new")," button."),(0,o.kt)("ol",{parentName:"li"},(0,o.kt)("li",{parentName:"ol"},(0,o.kt)("strong",{parentName:"li"},"Name"),": enter ",(0,o.kt)("inlineCode",{parentName:"li"},"kind-cluster"),"."),(0,o.kt)("li",{parentName:"ol"},(0,o.kt)("strong",{parentName:"li"},"Provider Type"),": select ",(0,o.kt)("inlineCode",{parentName:"li"},"podman"),"."),(0,o.kt)("li",{parentName:"ol"},(0,o.kt)("strong",{parentName:"li"},"HTTP Port"),": select ",(0,o.kt)("inlineCode",{parentName:"li"},"9090"),"."),(0,o.kt)("li",{parentName:"ol"},(0,o.kt)("strong",{parentName:"li"},"HTTPS Port"),": select ",(0,o.kt)("inlineCode",{parentName:"li"},"9443"),"."),(0,o.kt)("li",{parentName:"ol"},(0,o.kt)("strong",{parentName:"li"},"Setup an ingress controller"),": ",(0,o.kt)("inlineCode",{parentName:"li"},"Enabled")),(0,o.kt)("li",{parentName:"ol"},"Click the ",(0,o.kt)("strong",{parentName:"li"},"Create")," button.\n",(0,o.kt)("img",{alt:"Create a Kind cluster screen",src:n(76893).Z,width:"793",height:"711"})))),(0,o.kt)("li",{parentName:"ol"},(0,o.kt)("p",{parentName:"li"},"After successful creation, click on the ",(0,o.kt)("strong",{parentName:"p"},"Go back to resources")," button"))),(0,o.kt)("h4",{id:"verification-1"},"Verification"),(0,o.kt)("ol",null,(0,o.kt)("li",{parentName:"ol"},(0,o.kt)("p",{parentName:"li"},"In ",(0,o.kt)("strong",{parentName:"p"},(0,o.kt)(d,{icon:"fa-solid fa-cog",size:"lg",mdxType:"Icon"})," Settings > Resources")," your Kind cluster is running/"),(0,o.kt)("p",{parentName:"li"},(0,o.kt)("img",{alt:"Kind cluster is running",src:n(30712).Z,width:"452",height:"189"}))),(0,o.kt)("li",{parentName:"ol"},(0,o.kt)("p",{parentName:"li"},"In the ",(0,o.kt)("strong",{parentName:"p"},"Podman Desktop")," tray, open the ",(0,o.kt)("strong",{parentName:"p"},"Kubernetes")," menu: you can set the context to your Kind cluster: ",(0,o.kt)("inlineCode",{parentName:"p"},"kind-kind-cluster"),"."),(0,o.kt)("p",{parentName:"li"},(0,o.kt)("img",{alt:"Kind cluster Kubernetes context in the tray",src:n(10141).Z,width:"273",height:"309"})),(0,o.kt)("p",{parentName:"li"},"At this point, you can start working with containers, and your local Kubernetes cluster."))),(0,o.kt)("h4",{id:"additional-resources"},"Additional resources"),(0,o.kt)("ul",null,(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("a",{parentName:"li",href:"/docs/kind/creating-a-kind-cluster"},"Creating a local Kind-powered Kubernetes cluster"))),(0,o.kt)("h2",{id:"starting-the-redis-leader"},"Starting the Redis leader"),(0,o.kt)("p",null,"The Guestbook application uses Redis to store its data."),(0,o.kt)("p",null,"With Podman Desktop, you can prepare the Redis leader image and container on your local container engine, and deploy the results to a Kubernetes pod and service.\nThis is functionally equal to the ",(0,o.kt)("inlineCode",{parentName:"p"},"redis-leader")," deployment that the Kubernetes example propose."),(0,o.kt)("h4",{id:"procedure-1"},"Procedure"),(0,o.kt)("ol",null,(0,o.kt)("li",{parentName:"ol"},(0,o.kt)("p",{parentName:"li"},"Open ",(0,o.kt)("strong",{parentName:"p"},(0,o.kt)(d,{icon:"fa-solid fa-cloud",size:"lg",mdxType:"Icon"})," Images > ",(0,o.kt)(d,{icon:"fa-solid fa-arrow-circle-down",size:"lg",mdxType:"Icon"})," Pull an image"),"."),(0,o.kt)("ol",{parentName:"li"},(0,o.kt)("li",{parentName:"ol"},(0,o.kt)("strong",{parentName:"li"},"Image to Pull"),": enter ",(0,o.kt)("inlineCode",{parentName:"li"},"docker.io/redis:6.0.5")),(0,o.kt)("li",{parentName:"ol"},"Click ",(0,o.kt)("strong",{parentName:"li"},"Pull image")," to pull the image to your container engine local image registry."),(0,o.kt)("li",{parentName:"ol"},"Click ",(0,o.kt)("strong",{parentName:"li"},"Done")," to get back to the images list."))),(0,o.kt)("li",{parentName:"ol"},(0,o.kt)("p",{parentName:"li"},(0,o.kt)("strong",{parentName:"p"},(0,o.kt)(d,{icon:"fa-solid fa-cloud",size:"lg",mdxType:"Icon"})," Search images"),": enter ",(0,o.kt)("inlineCode",{parentName:"p"},"redis:6.0.5")," to find the image.")),(0,o.kt)("li",{parentName:"ol"},(0,o.kt)("p",{parentName:"li"},"Click ",(0,o.kt)("strong",{parentName:"p"},(0,o.kt)(d,{icon:"fa-solid fa-play",size:"lg",mdxType:"Icon"}))," to open the ",(0,o.kt)("strong",{parentName:"p"},"Create a container from image")," dialog."),(0,o.kt)("ol",{parentName:"li"},(0,o.kt)("li",{parentName:"ol"},(0,o.kt)("strong",{parentName:"li"},"Container name"),": enter ",(0,o.kt)("inlineCode",{parentName:"li"},"leader"),","),(0,o.kt)("li",{parentName:"ol"},(0,o.kt)("strong",{parentName:"li"},"Local port for ",(0,o.kt)("inlineCode",{parentName:"strong"},"6379/tcp")),": ",(0,o.kt)("inlineCode",{parentName:"li"},"6379"),"."),(0,o.kt)("li",{parentName:"ol"},"Click ",(0,o.kt)("strong",{parentName:"li"},(0,o.kt)(d,{icon:"fa-solid fa-play",size:"lg",mdxType:"Icon"})," Start Container")," to start the container in your container engine."))),(0,o.kt)("li",{parentName:"ol"},(0,o.kt)("p",{parentName:"li"},(0,o.kt)("strong",{parentName:"p"},(0,o.kt)(d,{icon:"fa-solid fa-cloud",size:"lg",mdxType:"Icon"})," Search containers"),": enter ",(0,o.kt)("inlineCode",{parentName:"p"},"leader")," to find the running container.")),(0,o.kt)("li",{parentName:"ol"},(0,o.kt)("p",{parentName:"li"},"Click ",(0,o.kt)("strong",{parentName:"p"},(0,o.kt)(d,{icon:"fa-solid fa-stop",size:"lg",mdxType:"Icon"}))," to stop the container, and leave the ",(0,o.kt)("inlineCode",{parentName:"p"},"6379")," port available for the Redis follower container.")),(0,o.kt)("li",{parentName:"ol"},(0,o.kt)("p",{parentName:"li"},"Click ",(0,o.kt)("strong",{parentName:"p"},(0,o.kt)(d,{icon:"fa-solid fa-ellipsis-v",size:"lg",mdxType:"Icon"})," > ",(0,o.kt)(d,{icon:"fa-solid fa-rocket",size:"lg",mdxType:"Icon"})," Deploy to Kubernetes")," to open the ",(0,o.kt)("strong",{parentName:"p"},"Deploy generated pod to Kubernetes")," screen."),(0,o.kt)("ol",{parentName:"li"},(0,o.kt)("li",{parentName:"ol"},(0,o.kt)("strong",{parentName:"li"},"Pod Name"),": enter ",(0,o.kt)("inlineCode",{parentName:"li"},"redis-leader"),"."),(0,o.kt)("li",{parentName:"ol"},(0,o.kt)("strong",{parentName:"li"},"Use Kubernetes Services"),": select ",(0,o.kt)("strong",{parentName:"li"},"Replace ",(0,o.kt)("inlineCode",{parentName:"strong"},"hostPort")," exposure on containers by Services. It is the recommended way to expose ports, as a cluster policy might prevent to use ",(0,o.kt)("inlineCode",{parentName:"strong"},"hostPort"),".")),(0,o.kt)("li",{parentName:"ol"},(0,o.kt)("strong",{parentName:"li"},"Expose service locally using Kubernetes Ingress"),": deselect ",(0,o.kt)("strong",{parentName:"li"},"Create a Kubernetes ingress to get access to the ports that this pod exposes, at the default ingress controller location. Example: on a default Kind cluster created with Podman Desktop: ",(0,o.kt)("inlineCode",{parentName:"strong"},"http://localhost:9090"),". Requirements: your cluster has an ingress controller`"),"."),(0,o.kt)("li",{parentName:"ol"},(0,o.kt)("strong",{parentName:"li"},"Kubernetes namespaces"),": select ",(0,o.kt)("inlineCode",{parentName:"li"},"default"),"."),(0,o.kt)("li",{parentName:"ol"},"Click ",(0,o.kt)("strong",{parentName:"li"},(0,o.kt)(d,{icon:"fa-solid fa-rocket",size:"lg",mdxType:"Icon"})," Deploy"),".\n",(0,o.kt)("img",{alt:"Deploy generated leader pod to Kubernetes screen",src:n(61781).Z,width:"1292",height:"968"})),(0,o.kt)("li",{parentName:"ol"},"Wait for the pod to reach the state: ",(0,o.kt)("strong",{parentName:"li"},"Phase: Running"),"."),(0,o.kt)("li",{parentName:"ol"},"Click ",(0,o.kt)("strong",{parentName:"li"},"Done"),".")))),(0,o.kt)("h4",{id:"verification-2"},"Verification"),(0,o.kt)("ul",null,(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},"The ",(0,o.kt)("strong",{parentName:"p"},(0,o.kt)(d,{icon:"fa-solid fa-cubes",size:"lg",mdxType:"Icon"})," Pods")," screen lists the running ",(0,o.kt)("inlineCode",{parentName:"p"},"redis-leader")," pod."),(0,o.kt)("p",{parentName:"li"},(0,o.kt)("img",{alt:"leader pod is running",src:n(39272).Z,width:"684",height:"231"})))),(0,o.kt)("h2",{id:"starting-the-redis-followers"},"Starting the Redis followers"),(0,o.kt)("p",null,"Although the Redis leader is a single Pod, you can make it highly available and meet traffic demands by adding a few Redis followers, or replicas."),(0,o.kt)("p",null,(0,o.kt)("strong",{parentName:"p"},"With Podman Desktop, you can prepare the Redis follower image and container on your local container engine, and deploy the results to Kubernetes pods and services."),"\nThis is functionally equal to the ",(0,o.kt)("inlineCode",{parentName:"p"},"redis-follower")," deployment that the Kubernetes example propose."),(0,o.kt)("h4",{id:"procedure-2"},"Procedure"),(0,o.kt)("ol",null,(0,o.kt)("li",{parentName:"ol"},"Open ",(0,o.kt)("strong",{parentName:"li"},(0,o.kt)(d,{icon:"fa-solid fa-cloud",size:"lg",mdxType:"Icon"})," Images > ",(0,o.kt)(d,{icon:"fa-solid fa-arrow-circle-down",size:"lg",mdxType:"Icon"})," Pull an image"),".",(0,o.kt)("ol",{parentName:"li"},(0,o.kt)("li",{parentName:"ol"},(0,o.kt)("strong",{parentName:"li"},"Image to Pull"),": enter ",(0,o.kt)("inlineCode",{parentName:"li"},"gcr.io/google_samples/gb-redis-follower:v2")),(0,o.kt)("li",{parentName:"ol"},"Click ",(0,o.kt)("strong",{parentName:"li"},"Pull image")," to pull the image to your container engine local image registry."),(0,o.kt)("li",{parentName:"ol"},"Click ",(0,o.kt)("strong",{parentName:"li"},"Done")," to get back to the images list."))),(0,o.kt)("li",{parentName:"ol"},(0,o.kt)("strong",{parentName:"li"},(0,o.kt)(d,{icon:"fa-solid fa-cloud",size:"lg",mdxType:"Icon"})," Search images"),": enter ",(0,o.kt)("inlineCode",{parentName:"li"},"gb-redis-follower:v2")," to find the image."),(0,o.kt)("li",{parentName:"ol"},"Click ",(0,o.kt)("strong",{parentName:"li"},(0,o.kt)(d,{icon:"fa-solid fa-play",size:"lg",mdxType:"Icon"}))," to open the ",(0,o.kt)("strong",{parentName:"li"},"Create a container from image")," dialog.",(0,o.kt)("ol",{parentName:"li"},(0,o.kt)("li",{parentName:"ol"},(0,o.kt)("strong",{parentName:"li"},"Container name"),": enter ",(0,o.kt)("inlineCode",{parentName:"li"},"follower"),","),(0,o.kt)("li",{parentName:"ol"},(0,o.kt)("strong",{parentName:"li"},"Local port for ",(0,o.kt)("inlineCode",{parentName:"strong"},"6379/tcp")),": ",(0,o.kt)("inlineCode",{parentName:"li"},"6379"),"."),(0,o.kt)("li",{parentName:"ol"},"Click ",(0,o.kt)("strong",{parentName:"li"},(0,o.kt)(d,{icon:"fa-solid fa-play",size:"lg",mdxType:"Icon"})," Start Container")," to start the container in your container engine."))),(0,o.kt)("li",{parentName:"ol"},(0,o.kt)("strong",{parentName:"li"},(0,o.kt)(d,{icon:"fa-solid fa-cloud",size:"lg",mdxType:"Icon"})," Search containers"),": enter ",(0,o.kt)("inlineCode",{parentName:"li"},"follower")," to find the running container."),(0,o.kt)("li",{parentName:"ol"},"Click ",(0,o.kt)("strong",{parentName:"li"},(0,o.kt)(d,{icon:"fa-solid fa-stop",size:"lg",mdxType:"Icon"}))," to stop the container: you do not need it to run in the container engine."),(0,o.kt)("li",{parentName:"ol"},"Click ",(0,o.kt)("strong",{parentName:"li"},(0,o.kt)(d,{icon:"fa-solid fa-ellipsis-v",size:"lg",mdxType:"Icon"})," > ",(0,o.kt)(d,{icon:"fa-solid fa-rocket",size:"lg",mdxType:"Icon"})," Deploy to Kubernetes")," to open the ",(0,o.kt)("strong",{parentName:"li"},"Deploy generated pod to Kubernetes")," screen.",(0,o.kt)("ol",{parentName:"li"},(0,o.kt)("li",{parentName:"ol"},(0,o.kt)("strong",{parentName:"li"},"Pod Name"),": enter ",(0,o.kt)("inlineCode",{parentName:"li"},"redis-follower"),"."),(0,o.kt)("li",{parentName:"ol"},(0,o.kt)("strong",{parentName:"li"},"Use Kubernetes Services"),": select ",(0,o.kt)("strong",{parentName:"li"},"Replace ",(0,o.kt)("inlineCode",{parentName:"strong"},"hostPort")," exposure on containers by Services. It is the recommended way to expose ports, as a cluster policy might prevent to use ",(0,o.kt)("inlineCode",{parentName:"strong"},"hostPort"),".")),(0,o.kt)("li",{parentName:"ol"},(0,o.kt)("strong",{parentName:"li"},"Expose service locally using Kubernetes Ingress"),": deselect ",(0,o.kt)("strong",{parentName:"li"},"Create a Kubernetes ingress to get access to the ports that this pod exposes, at the default ingress controller location. Example: on a default Kind cluster created with Podman Desktop: ",(0,o.kt)("inlineCode",{parentName:"strong"},"http://localhost:9090"),". Requirements: your cluster has an ingress controller`"),"."),(0,o.kt)("li",{parentName:"ol"},(0,o.kt)("strong",{parentName:"li"},"Kubernetes namespaces"),": select ",(0,o.kt)("inlineCode",{parentName:"li"},"default"),"."),(0,o.kt)("li",{parentName:"ol"},"Click ",(0,o.kt)("strong",{parentName:"li"},(0,o.kt)(d,{icon:"fa-solid fa-rocket",size:"lg",mdxType:"Icon"})," Deploy"),".\n",(0,o.kt)("img",{alt:"Deploy generated follower pod to Kubernetes screen",src:n(18738).Z,width:"1292",height:"968"})),(0,o.kt)("li",{parentName:"ol"},"Wait for the pod to reach the state: ",(0,o.kt)("strong",{parentName:"li"},"Phase: Running"),"."),(0,o.kt)("li",{parentName:"ol"},"Click ",(0,o.kt)("strong",{parentName:"li"},"Done"),"."))),(0,o.kt)("li",{parentName:"ol"},"To add replicas, repeat the last step with another ",(0,o.kt)("strong",{parentName:"li"},"Pod Name")," value.")),(0,o.kt)("h4",{id:"verification-3"},"Verification"),(0,o.kt)("ul",null,(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("p",{parentName:"li"},"The ",(0,o.kt)("strong",{parentName:"p"},(0,o.kt)(d,{icon:"fa-solid fa-cubes",size:"lg",mdxType:"Icon"})," Pods")," screen lists the running ",(0,o.kt)("inlineCode",{parentName:"p"},"redis-follower")," pods."),(0,o.kt)("p",{parentName:"li"},(0,o.kt)("img",{alt:"follower pods are running",src:n(15740).Z,width:"668",height:"286"})))),(0,o.kt)("h2",{id:"starting-the-default-frontend"},"Starting the default frontend"),(0,o.kt)("p",null,"Now that you have the Redis storage of your Guestbook up and running, start the Guestbook web servers.\nLike the Redis followers, deploy the frontend using Kubernetes pods and services."),(0,o.kt)("p",null,"The Guestbook app uses a PHP frontend.\nIt is configured to communicate with either the Redis follower or leader Services, depending on whether the request is a read or a write.\nThe frontend exposes a JSON interface, and serves a jQuery-Ajax-based UX."),(0,o.kt)("p",null,"With Podman Desktop, you can prepare the Guestbook frontend image and container on your local container engine, and deploy the results to Kubernetes pods and services.\nThis is functionally equal to the ",(0,o.kt)("inlineCode",{parentName:"p"},"frontend")," deployment that the Kubernetes example propose."),(0,o.kt)("h4",{id:"procedure-3"},"Procedure"),(0,o.kt)("ol",null,(0,o.kt)("li",{parentName:"ol"},"Open ",(0,o.kt)("strong",{parentName:"li"},(0,o.kt)(d,{icon:"fa-solid fa-cloud",size:"lg",mdxType:"Icon"})," Images > ",(0,o.kt)(d,{icon:"fa-solid fa-arrow-circle-down",size:"lg",mdxType:"Icon"})," Pull an image"),".",(0,o.kt)("ol",{parentName:"li"},(0,o.kt)("li",{parentName:"ol"},(0,o.kt)("strong",{parentName:"li"},"Image to Pull"),": enter ",(0,o.kt)("inlineCode",{parentName:"li"},"gcr.io/google_samples/gb-frontend:v5")),(0,o.kt)("li",{parentName:"ol"},"Click ",(0,o.kt)("strong",{parentName:"li"},"Pull image")," to pull the image to your container engine local image registry."),(0,o.kt)("li",{parentName:"ol"},"Wait for the pull to complete."),(0,o.kt)("li",{parentName:"ol"},"Click ",(0,o.kt)("strong",{parentName:"li"},"Done")," to get back to the images list."))),(0,o.kt)("li",{parentName:"ol"},(0,o.kt)("strong",{parentName:"li"},(0,o.kt)(d,{icon:"fa-solid fa-cloud",size:"lg",mdxType:"Icon"})," Search images"),": enter ",(0,o.kt)("inlineCode",{parentName:"li"},"gb-frontend:v5")," to find the image."),(0,o.kt)("li",{parentName:"ol"},"Click ",(0,o.kt)("strong",{parentName:"li"},(0,o.kt)(d,{icon:"fa-solid fa-play",size:"lg",mdxType:"Icon"}))," to open the ",(0,o.kt)("strong",{parentName:"li"},"Create a container from image")," dialog.",(0,o.kt)("ol",{parentName:"li"},(0,o.kt)("li",{parentName:"ol"},(0,o.kt)("strong",{parentName:"li"},"Container name"),": enter ",(0,o.kt)("inlineCode",{parentName:"li"},"frontend"),","),(0,o.kt)("li",{parentName:"ol"},(0,o.kt)("strong",{parentName:"li"},"Local port for ",(0,o.kt)("inlineCode",{parentName:"strong"},"80/tcp")),": ",(0,o.kt)("inlineCode",{parentName:"li"},"9000"),"."),(0,o.kt)("li",{parentName:"ol"},"Click ",(0,o.kt)("strong",{parentName:"li"},(0,o.kt)(d,{icon:"fa-solid fa-play",size:"lg",mdxType:"Icon"})," Start Container")," to start the container in your container engine."))),(0,o.kt)("li",{parentName:"ol"},(0,o.kt)("strong",{parentName:"li"},(0,o.kt)(d,{icon:"fa-solid fa-cloud",size:"lg",mdxType:"Icon"})," Search containers"),": enter ",(0,o.kt)("inlineCode",{parentName:"li"},"frontend")," to find the running container."),(0,o.kt)("li",{parentName:"ol"},"Click ",(0,o.kt)("strong",{parentName:"li"},(0,o.kt)(d,{icon:"fa-solid fa-stop",size:"lg",mdxType:"Icon"}))," to stop the container: you do not need it to run in the container engine."),(0,o.kt)("li",{parentName:"ol"},"Click ",(0,o.kt)("strong",{parentName:"li"},(0,o.kt)(d,{icon:"fa-solid fa-ellipsis-v",size:"lg",mdxType:"Icon"})," > ",(0,o.kt)(d,{icon:"fa-solid fa-rocket",size:"lg",mdxType:"Icon"})," Deploy to Kubernetes")," to open the ",(0,o.kt)("strong",{parentName:"li"},"Deploy generated pod to Kubernetes")," screen.",(0,o.kt)("ol",{parentName:"li"},(0,o.kt)("li",{parentName:"ol"},(0,o.kt)("strong",{parentName:"li"},"Pod Name"),": enter ",(0,o.kt)("inlineCode",{parentName:"li"},"frontend"),"."),(0,o.kt)("li",{parentName:"ol"},(0,o.kt)("strong",{parentName:"li"},"Use Kubernetes Services"),": select ",(0,o.kt)("strong",{parentName:"li"},"Replace ",(0,o.kt)("inlineCode",{parentName:"strong"},"hostPort")," exposure on containers by Services. It is the recommended way to expose ports, as a cluster policy might prevent to use ",(0,o.kt)("inlineCode",{parentName:"strong"},"hostPort"),".")),(0,o.kt)("li",{parentName:"ol"},(0,o.kt)("strong",{parentName:"li"},"Expose service locally using Kubernetes Ingress"),": select ",(0,o.kt)("strong",{parentName:"li"},"Create a Kubernetes ingress to get access to the ports that this pod exposes, at the default ingress controller location. Example: on a default Kind cluster created with Podman Desktop: ",(0,o.kt)("inlineCode",{parentName:"strong"},"http://localhost:9090"),". Requirements: your cluster has an ingress controller`"),"."),(0,o.kt)("li",{parentName:"ol"},(0,o.kt)("strong",{parentName:"li"},"Kubernetes namespaces"),": select ",(0,o.kt)("inlineCode",{parentName:"li"},"default"),"."),(0,o.kt)("li",{parentName:"ol"},"Click ",(0,o.kt)("strong",{parentName:"li"},(0,o.kt)(d,{icon:"fa-solid fa-rocket",size:"lg",mdxType:"Icon"})," Deploy"),".\n",(0,o.kt)("img",{alt:"Deploy generated frontend pod to Kubernetes screen",src:n(67104).Z,width:"1292",height:"968"})),(0,o.kt)("li",{parentName:"ol"},"Wait for the pod to reach the state: ",(0,o.kt)("strong",{parentName:"li"},"Phase: Running"),"."),(0,o.kt)("li",{parentName:"ol"},"Click ",(0,o.kt)("strong",{parentName:"li"},"Done"),".")))),(0,o.kt)("h4",{id:"verification-4"},"Verification"),(0,o.kt)("ol",null,(0,o.kt)("li",{parentName:"ol"},(0,o.kt)("p",{parentName:"li"},"The ",(0,o.kt)("strong",{parentName:"p"},(0,o.kt)(d,{icon:"fa-solid fa-cubes",size:"lg",mdxType:"Icon"})," Pods")," screen lists the running ",(0,o.kt)("inlineCode",{parentName:"p"},"frontend")," pod."),(0,o.kt)("p",{parentName:"li"},(0,o.kt)("img",{alt:"`frontend` pod is running",src:n(99992).Z,width:"674",height:"222"}))),(0,o.kt)("li",{parentName:"ol"},(0,o.kt)("p",{parentName:"li"},"Go to ",(0,o.kt)("inlineCode",{parentName:"p"},"http://localhost:9090"),": the Guestbook application is running."))))}k.isMDXComponent=!0},76893:(e,t,n)=>{n.d(t,{Z:()=>a});const a=n.p+"assets/images/create-a-kind-cluster-341ca1312e2e05d63d82a93726825a05.png"},18738:(e,t,n)=>{n.d(t,{Z:()=>a});const a=n.p+"assets/images/deploy-generated-follower-pod-to-kubernetes-dd643e002a1dbf69e29ef7863f0774d8.png"},67104:(e,t,n)=>{n.d(t,{Z:()=>a});const a=n.p+"assets/images/deploy-generated-frontend-pod-to-kubernetes-cf7e13dbd73427575b2cf583e223df38.png"},61781:(e,t,n)=>{n.d(t,{Z:()=>a});const a=n.p+"assets/images/deploy-generated-leader-pod-to-kubernetes-e812812296742ec54cd822d0ba969c28.png"},15740:(e,t,n)=>{n.d(t,{Z:()=>a});const a=n.p+"assets/images/follower-pods-are-running-be90e0689f30209b0694469405ecd6a9.png"},99992:(e,t,n)=>{n.d(t,{Z:()=>a});const a=n.p+"assets/images/frontend-pod-is-running-f6f55d91d200f35629788d3c550ae463.png"},10141:(e,t,n)=>{n.d(t,{Z:()=>a});const a=n.p+"assets/images/kind-cluster-context-in-the-tray-5bb9338bb1437bbcf79bf50dd401400e.png"},30712:(e,t,n)=>{n.d(t,{Z:()=>a});const a=n.p+"assets/images/kind-cluster-is-running-e721d473aa52100d8179cbb3d06e0ef9.png"},39272:(e,t,n)=>{n.d(t,{Z:()=>a});const a=n.p+"assets/images/leader-pod-is-running-a8caa174a15c06b287dff81b08041f7c.png"},65986:(e,t,n)=>{n.d(t,{Z:()=>a});const a=n.p+"assets/images/podman-is-running-745db8684c4d0240922a5aeb63e517d3.png"}}]); \ No newline at end of file diff --git a/assets/js/de311ed4.7419c21d.js b/assets/js/de311ed4.7419c21d.js deleted file mode 100644 index 0d2ca3ba927..00000000000 --- a/assets/js/de311ed4.7419c21d.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[1625],{35318:(e,t,n)=>{n.d(t,{Zo:()=>d,kt:()=>k});var a=n(27378);function i(e,t,n){return t in e?Object.defineProperty(e,t,{value:n,enumerable:!0,configurable:!0,writable:!0}):e[t]=n,e}function o(e,t){var n=Object.keys(e);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);t&&(a=a.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),n.push.apply(n,a)}return n}function r(e){for(var t=1;t=0||(i[n]=e[n]);return i}(e,t);if(Object.getOwnPropertySymbols){var o=Object.getOwnPropertySymbols(e);for(a=0;a=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(i[n]=e[n])}return i}var s=a.createContext({}),p=function(e){var t=a.useContext(s),n=t;return e&&(n="function"==typeof e?e(t):r(r({},t),e)),n},d=function(e){var t=p(e.components);return a.createElement(s.Provider,{value:t},e.children)},c={inlineCode:"code",wrapper:function(e){var t=e.children;return a.createElement(a.Fragment,{},t)}},m=a.forwardRef((function(e,t){var n=e.components,i=e.mdxType,o=e.originalType,s=e.parentName,d=l(e,["components","mdxType","originalType","parentName"]),m=p(n),k=i,u=m["".concat(s,".").concat(k)]||m[k]||c[k]||o;return n?a.createElement(u,r(r({ref:t},d),{},{components:n})):a.createElement(u,r({ref:t},d))}));function k(e,t){var n=arguments,i=t&&t.mdxType;if("string"==typeof e||i){var o=n.length,r=new Array(o);r[0]=m;var l={};for(var s in t)hasOwnProperty.call(t,s)&&(l[s]=t[s]);l.originalType=e,l.mdxType="string"==typeof e?e:i,r[1]=l;for(var p=2;p{n.r(t),n.d(t,{assets:()=>s,contentTitle:()=>r,default:()=>c,frontMatter:()=>o,metadata:()=>l,toc:()=>p});var a=n(25773),i=(n(27378),n(35318));const o={title:"Setting up and running a Kubernetes cluster locally with Podman Desktop",description:"Setting up and running a Kubernetes cluster locally with Podman Desktop",slug:"running-a-local-kubernetes-cluster-with-podman-desktop",authors:["themr0c"],tags:["podman-desktop","story","kubernetes","kind"],hide_table_of_contents:!1},r="Setting up and running a Kubernetes cluster locally with Podman Desktop",l={permalink:"/blog/running-a-local-kubernetes-cluster-with-podman-desktop",source:"@site/blog/2023-04-19-running-a-local-kubernetes-cluster-with-podman-desktop.md",title:"Setting up and running a Kubernetes cluster locally with Podman Desktop",description:"Setting up and running a Kubernetes cluster locally with Podman Desktop",date:"2023-04-19T00:00:00.000Z",formattedDate:"April 19, 2023",tags:[{label:"podman-desktop",permalink:"/blog/tags/podman-desktop"},{label:"story",permalink:"/blog/tags/story"},{label:"kubernetes",permalink:"/blog/tags/kubernetes"},{label:"kind",permalink:"/blog/tags/kind"}],readingTime:8.86,hasTruncateMarker:!0,authors:[{name:"Fabrice Flore-Thebault",title:"Technical writer",url:"https://github.com/themr0c",imageURL:"https://github.com/themr0c.png",key:"themr0c"}],frontMatter:{title:"Setting up and running a Kubernetes cluster locally with Podman Desktop",description:"Setting up and running a Kubernetes cluster locally with Podman Desktop",slug:"running-a-local-kubernetes-cluster-with-podman-desktop",authors:["themr0c"],tags:["podman-desktop","story","kubernetes","kind"],hide_table_of_contents:!1},prevItem:{title:"Release Notes - Podman Desktop 0.15",permalink:"/blog/podman-desktop-release-0.15"},nextItem:{title:"Release Notes - Podman Desktop 0.14",permalink:"/blog/podman-desktop-release-0.14"}},s={authorsImageUrls:[void 0]},p=[{value:"Installing Podman Desktop",id:"installing-podman-desktop",level:2},{value:"Installing and initializing your container engine: Podman",id:"installing-and-initializing-your-container-engine-podman",level:2},{value:"Procedure",id:"procedure",level:4},{value:"Verification",id:"verification",level:4},{value:"Installing and starting your local Kubernetes provider: Kind",id:"installing-and-starting-your-local-kubernetes-provider-kind",level:2},{value:"Verification",id:"verification-1",level:4},{value:"Additional resources",id:"additional-resources",level:4},{value:"Starting the Redis leader",id:"starting-the-redis-leader",level:2},{value:"Procedure",id:"procedure-1",level:4},{value:"Verification",id:"verification-2",level:4},{value:"Starting the Redis followers",id:"starting-the-redis-followers",level:2},{value:"Procedure",id:"procedure-2",level:4},{value:"Verification",id:"verification-3",level:4},{value:"Starting the default frontend",id:"starting-the-default-frontend",level:2},{value:"Procedure",id:"procedure-3",level:4},{value:"Verification",id:"verification-4",level:4}],d={toc:p};function c(e){let{components:t,...o}=e;return(0,i.kt)("wrapper",(0,a.Z)({},d,o,{components:t,mdxType:"MDXLayout"}),(0,i.kt)("p",null,"In this blog post you will learn to use Podman Desktop to run the ",(0,i.kt)("a",{parentName:"p",href:"https://kubernetes.io/docs/tutorials/stateless-application/guestbook/"},"Kubernetes documentation example: Deploying PHP Guestbook application with Redis"),"."),(0,i.kt)("p",null,"On the agenda:"),(0,i.kt)("ol",null,(0,i.kt)("li",{parentName:"ol"},"Installing Podman Desktop."),(0,i.kt)("li",{parentName:"ol"},"Installing and initializing your container engine: Podman."),(0,i.kt)("li",{parentName:"ol"},"Installing and starting your local Kubernetes provider: Kind."),(0,i.kt)("li",{parentName:"ol"},"Starting the Redis leader."),(0,i.kt)("li",{parentName:"ol"},"Starting and scaling the Redis followers."),(0,i.kt)("li",{parentName:"ol"},"Starting and exposing the Guestbook frontend.")),(0,i.kt)("h2",{id:"installing-podman-desktop"},"Installing Podman Desktop"),(0,i.kt)("p",null,"You need Podman Desktop."),(0,i.kt)("ol",null,(0,i.kt)("li",{parentName:"ol"},"Go to ",(0,i.kt)("a",{parentName:"li",href:"/docs/installation"},"Podman Desktop installation documentation"),"."),(0,i.kt)("li",{parentName:"ol"},"Click on your platform name: ",(0,i.kt)("a",{parentName:"li",href:"/docs/installation/windows-install"},"Windows"),", ",(0,i.kt)("a",{parentName:"li",href:"/docs/installation/macos-install"},"macOS"),", or ",(0,i.kt)("a",{parentName:"li",href:"/docs/installation/linux-install"},"Linux"),"."),(0,i.kt)("li",{parentName:"ol"},"Follow the instructions. Stick to the default installation method."),(0,i.kt)("li",{parentName:"ol"},"Start ",(0,i.kt)("strong",{parentName:"li"},"Podman Desktop"),".")),(0,i.kt)("p",null,"At this point, you have a graphical user interface to:"),(0,i.kt)("ul",null,(0,i.kt)("li",{parentName:"ul"},"Install Podman and Kind."),(0,i.kt)("li",{parentName:"ul"},"Control and work with your container engines and Kubernetes clusters."),(0,i.kt)("li",{parentName:"ul"},"Run your application on your container engine and migrate it to Kubernetes.")),(0,i.kt)("h2",{id:"installing-and-initializing-your-container-engine-podman"},"Installing and initializing your container engine: Podman"),(0,i.kt)("p",null,"Podman Desktop can control various container engines, such as:"),(0,i.kt)("ul",null,(0,i.kt)("li",{parentName:"ul"},"Docker"),(0,i.kt)("li",{parentName:"ul"},"Lima"),(0,i.kt)("li",{parentName:"ul"},"Podman")),(0,i.kt)("p",null,"Consider installing the Podman container engine for:"),(0,i.kt)("ul",null,(0,i.kt)("li",{parentName:"ul"},"Added security"),(0,i.kt)("li",{parentName:"ul"},"No daemon"),(0,i.kt)("li",{parentName:"ul"},"Open source")),(0,i.kt)("p",null,"Containers are a Linux technology."),(0,i.kt)("ul",null,(0,i.kt)("li",{parentName:"ul"},"On Linux, you can install Podman natively.\nSee: ",(0,i.kt)("a",{parentName:"li",href:"https://podman.io/docs/installation#installing-on-linux"},"Installing Podman on Linux"),"."),(0,i.kt)("li",{parentName:"ul"},"On macOS and Windows, Podman requires to run in a Linux virtual machine: the Podman machine.\nUse Podman Desktop to install Podman and initialize your Podman machine:")),(0,i.kt)("h4",{id:"procedure"},"Procedure"),(0,i.kt)("ol",null,(0,i.kt)("li",{parentName:"ol"},"Open Podman Desktop ",(0,i.kt)("strong",{parentName:"li"},"Dashboard")),(0,i.kt)("li",{parentName:"ol"},"The ",(0,i.kt)("strong",{parentName:"li"},"Dashboard")," displays ",(0,i.kt)("em",{parentName:"li"},"Podman Desktop was not able to find an installation of Podman"),"."),(0,i.kt)("li",{parentName:"ol"},"Click on ",(0,i.kt)("strong",{parentName:"li"},"Install"),"."),(0,i.kt)("li",{parentName:"ol"},"Podman Desktop checks the prerequisites to install Podman Engine. When necessary, follow the instructions to install prerequisites."),(0,i.kt)("li",{parentName:"ol"},"Podman displays the dialog: ",(0,i.kt)("em",{parentName:"li"},"Podman is not installed on this system, would you like to install Podman?"),". Click on ",(0,i.kt)("strong",{parentName:"li"},"Yes")," to install Podman."),(0,i.kt)("li",{parentName:"ol"},"Click on ",(0,i.kt)("strong",{parentName:"li"},"Initialize and start"),".")),(0,i.kt)("h4",{id:"verification"},"Verification"),(0,i.kt)("ul",null,(0,i.kt)("li",{parentName:"ul"},(0,i.kt)("p",{parentName:"li"},"The ",(0,i.kt)("strong",{parentName:"p"},"Dashboard")," displays ",(0,i.kt)("em",{parentName:"p"},"Podman is running"),"."),(0,i.kt)("p",{parentName:"li"},(0,i.kt)("img",{alt:"Podman is running",src:n(65986).Z,width:"611",height:"219"})))),(0,i.kt)("p",null,"At this point, you can start working with containers."),(0,i.kt)("h2",{id:"installing-and-starting-your-local-kubernetes-provider-kind"},"Installing and starting your local Kubernetes provider: Kind"),(0,i.kt)("p",null,"You want to deploy your application to a local Kubernetes cluster."),(0,i.kt)("p",null,"Podman Desktop can help you run Kind-powered local Kubernetes clusters on a container engine, such as Podman."),(0,i.kt)("p",null,"Podman Desktop helps you ",(0,i.kt)("a",{parentName:"p",href:"/docs/kind/installing"},"installing the ",(0,i.kt)("inlineCode",{parentName:"a"},"kind")," CLI"),":"),(0,i.kt)("ol",null,(0,i.kt)("li",{parentName:"ol"},(0,i.kt)("p",{parentName:"li"},"In the status bar, click on ",(0,i.kt)("strong",{parentName:"p"},"Kind"),", and follow the prompts.")),(0,i.kt)("li",{parentName:"ol"},(0,i.kt)("p",{parentName:"li"},"When the ",(0,i.kt)("inlineCode",{parentName:"p"},"kind")," CLI is available, the status bar does not display ",(0,i.kt)("strong",{parentName:"p"},"Kind"),".")),(0,i.kt)("li",{parentName:"ol"},(0,i.kt)("p",{parentName:"li"},"On Windows, ",(0,i.kt)("a",{parentName:"p",href:"/docs/kind/configuring-podman-for-kind-on-windows"},"configure Podman in rootful mode")),(0,i.kt)("pre",{parentName:"li"},(0,i.kt)("code",{parentName:"pre",className:"language-shell-session"},"$ podman system connection default podman-machine-default-root\n"))),(0,i.kt)("li",{parentName:"ol"},(0,i.kt)("p",{parentName:"li"},"Go to ",(0,i.kt)("strong",{parentName:"p"},(0,i.kt)("icon",{icon:"fa-solid fa-cog",size:"lg"})," Settings > Resources"))),(0,i.kt)("li",{parentName:"ol"},(0,i.kt)("p",{parentName:"li"},"In the ",(0,i.kt)("strong",{parentName:"p"},(0,i.kt)("img",{src:"/img/podman-icon.png",alt:"Podman icon",style:{height:"1.5em",display:"inline"}})," Podman")," tile, click on the ",(0,i.kt)("strong",{parentName:"p"},(0,i.kt)("icon",{icon:"fa-solid fa-repeat",size:"lg"}))," icon to restart the Podman container engine.")),(0,i.kt)("li",{parentName:"ol"},(0,i.kt)("p",{parentName:"li"},"In the ",(0,i.kt)("strong",{parentName:"p"},(0,i.kt)("img",{src:"/img/kind-icon.png",alt:"Kind icon",style:{height:"1.5em",display:"inline"}})," Kind")," tile, click on the ",(0,i.kt)("strong",{parentName:"p"},"Create new")," button."),(0,i.kt)("ol",{parentName:"li"},(0,i.kt)("li",{parentName:"ol"},(0,i.kt)("strong",{parentName:"li"},"Name"),": enter ",(0,i.kt)("inlineCode",{parentName:"li"},"kind-cluster"),"."),(0,i.kt)("li",{parentName:"ol"},(0,i.kt)("strong",{parentName:"li"},"Provider Type"),": select ",(0,i.kt)("inlineCode",{parentName:"li"},"podman"),"."),(0,i.kt)("li",{parentName:"ol"},(0,i.kt)("strong",{parentName:"li"},"HTTP Port"),": select ",(0,i.kt)("inlineCode",{parentName:"li"},"9090"),"."),(0,i.kt)("li",{parentName:"ol"},(0,i.kt)("strong",{parentName:"li"},"HTTPS Port"),": select ",(0,i.kt)("inlineCode",{parentName:"li"},"9443"),"."),(0,i.kt)("li",{parentName:"ol"},(0,i.kt)("strong",{parentName:"li"},"Setup an ingress controller"),": ",(0,i.kt)("inlineCode",{parentName:"li"},"Enabled")),(0,i.kt)("li",{parentName:"ol"},"Click the ",(0,i.kt)("strong",{parentName:"li"},"Create")," button.\n",(0,i.kt)("img",{alt:"Create a Kind cluster screen",src:n(76893).Z,width:"793",height:"711"})))),(0,i.kt)("li",{parentName:"ol"},(0,i.kt)("p",{parentName:"li"},"After successful creation, click on the ",(0,i.kt)("strong",{parentName:"p"},"Go back to resources")," button"))),(0,i.kt)("h4",{id:"verification-1"},"Verification"),(0,i.kt)("ol",null,(0,i.kt)("li",{parentName:"ol"},(0,i.kt)("p",{parentName:"li"},"In ",(0,i.kt)("strong",{parentName:"p"},(0,i.kt)("icon",{icon:"fa-solid fa-cog",size:"lg"})," Settings > Resources")," your Kind cluster is running/"),(0,i.kt)("p",{parentName:"li"},(0,i.kt)("img",{alt:"Kind cluster is running",src:n(30712).Z,width:"452",height:"189"}))),(0,i.kt)("li",{parentName:"ol"},(0,i.kt)("p",{parentName:"li"},"In the ",(0,i.kt)("strong",{parentName:"p"},"Podman Desktop")," tray, open the ",(0,i.kt)("strong",{parentName:"p"},"Kubernetes")," menu: you can set the context to your Kind cluster: ",(0,i.kt)("inlineCode",{parentName:"p"},"kind-kind-cluster"),"."),(0,i.kt)("p",{parentName:"li"},(0,i.kt)("img",{alt:"Kind cluster Kubernetes context in the tray",src:n(10141).Z,width:"273",height:"309"})),(0,i.kt)("p",{parentName:"li"},"At this point, you can start working with containers, and your local Kubernetes cluster."))),(0,i.kt)("h4",{id:"additional-resources"},"Additional resources"),(0,i.kt)("ul",null,(0,i.kt)("li",{parentName:"ul"},(0,i.kt)("a",{parentName:"li",href:"/docs/kind/creating-a-kind-cluster"},"Creating a local Kind-powered Kubernetes cluster"))),(0,i.kt)("h2",{id:"starting-the-redis-leader"},"Starting the Redis leader"),(0,i.kt)("p",null,"The Guestbook application uses Redis to store its data."),(0,i.kt)("p",null,"With Podman Desktop, you can prepare the Redis leader image and container on your local container engine, and deploy the results to a Kubernetes pod and service.\nThis is functionally equal to the ",(0,i.kt)("inlineCode",{parentName:"p"},"redis-leader")," deployment that the Kubernetes example propose."),(0,i.kt)("h4",{id:"procedure-1"},"Procedure"),(0,i.kt)("ol",null,(0,i.kt)("li",{parentName:"ol"},(0,i.kt)("p",{parentName:"li"},"Open ",(0,i.kt)("strong",{parentName:"p"},(0,i.kt)("icon",{icon:"fa-solid fa-cloud",size:"lg"})," Images > ",(0,i.kt)("icon",{icon:"fa-solid fa-arrow-circle-down",size:"lg"})," Pull an image"),"."),(0,i.kt)("ol",{parentName:"li"},(0,i.kt)("li",{parentName:"ol"},(0,i.kt)("strong",{parentName:"li"},"Image to Pull"),": enter ",(0,i.kt)("inlineCode",{parentName:"li"},"docker.io/redis:6.0.5")),(0,i.kt)("li",{parentName:"ol"},"Click ",(0,i.kt)("strong",{parentName:"li"},"Pull image")," to pull the image to your container engine local image registry."),(0,i.kt)("li",{parentName:"ol"},"Click ",(0,i.kt)("strong",{parentName:"li"},"Done")," to get back to the images list."))),(0,i.kt)("li",{parentName:"ol"},(0,i.kt)("p",{parentName:"li"},(0,i.kt)("strong",{parentName:"p"},(0,i.kt)("icon",{icon:"fa-solid fa-cloud",size:"lg"})," Search images"),": enter ",(0,i.kt)("inlineCode",{parentName:"p"},"redis:6.0.5")," to find the image.")),(0,i.kt)("li",{parentName:"ol"},(0,i.kt)("p",{parentName:"li"},"Click ",(0,i.kt)("strong",{parentName:"p"},(0,i.kt)("icon",{icon:"fa-solid fa-play",size:"lg"}))," to open the ",(0,i.kt)("strong",{parentName:"p"},"Create a container from image")," dialog."),(0,i.kt)("ol",{parentName:"li"},(0,i.kt)("li",{parentName:"ol"},(0,i.kt)("strong",{parentName:"li"},"Container name"),": enter ",(0,i.kt)("inlineCode",{parentName:"li"},"leader"),","),(0,i.kt)("li",{parentName:"ol"},(0,i.kt)("strong",{parentName:"li"},"Local port for ",(0,i.kt)("inlineCode",{parentName:"strong"},"6379/tcp")),": ",(0,i.kt)("inlineCode",{parentName:"li"},"6379"),"."),(0,i.kt)("li",{parentName:"ol"},"Click ",(0,i.kt)("strong",{parentName:"li"},(0,i.kt)("icon",{icon:"fa-solid fa-play",size:"lg"})," Start Container")," to start the container in your container engine."))),(0,i.kt)("li",{parentName:"ol"},(0,i.kt)("p",{parentName:"li"},(0,i.kt)("strong",{parentName:"p"},(0,i.kt)("icon",{icon:"fa-solid fa-cloud",size:"lg"})," Search containers"),": enter ",(0,i.kt)("inlineCode",{parentName:"p"},"leader")," to find the running container.")),(0,i.kt)("li",{parentName:"ol"},(0,i.kt)("p",{parentName:"li"},"Click ",(0,i.kt)("strong",{parentName:"p"},(0,i.kt)("icon",{icon:"fa-solid fa-stop",size:"lg"}))," to stop the container, and leave the ",(0,i.kt)("inlineCode",{parentName:"p"},"6379")," port available for the Redis follower container.")),(0,i.kt)("li",{parentName:"ol"},(0,i.kt)("p",{parentName:"li"},"Click ",(0,i.kt)("strong",{parentName:"p"},(0,i.kt)("icon",{icon:"fa-solid fa-ellipsis-v",size:"lg"})," > ",(0,i.kt)("icon",{icon:"fa-solid fa-rocket",size:"lg"})," Deploy to Kubernetes")," to open the ",(0,i.kt)("strong",{parentName:"p"},"Deploy generated pod to Kubernetes")," screen."),(0,i.kt)("ol",{parentName:"li"},(0,i.kt)("li",{parentName:"ol"},(0,i.kt)("strong",{parentName:"li"},"Pod Name"),": enter ",(0,i.kt)("inlineCode",{parentName:"li"},"redis-leader"),"."),(0,i.kt)("li",{parentName:"ol"},(0,i.kt)("strong",{parentName:"li"},"Use Kubernetes Services"),": select ",(0,i.kt)("strong",{parentName:"li"},"Replace ",(0,i.kt)("inlineCode",{parentName:"strong"},"hostPort")," exposure on containers by Services. It is the recommended way to expose ports, as a cluster policy might prevent to use ",(0,i.kt)("inlineCode",{parentName:"strong"},"hostPort"),".")),(0,i.kt)("li",{parentName:"ol"},(0,i.kt)("strong",{parentName:"li"},"Expose service locally using Kubernetes Ingress"),": deselect ",(0,i.kt)("strong",{parentName:"li"},"Create a Kubernetes ingress to get access to the ports that this pod exposes, at the default ingress controller location. Example: on a default Kind cluster created with Podman Desktop: ",(0,i.kt)("inlineCode",{parentName:"strong"},"http://localhost:9090"),". Requirements: your cluster has an ingress controller`"),"."),(0,i.kt)("li",{parentName:"ol"},(0,i.kt)("strong",{parentName:"li"},"Kubernetes namespaces"),": select ",(0,i.kt)("inlineCode",{parentName:"li"},"default"),"."),(0,i.kt)("li",{parentName:"ol"},"Click ",(0,i.kt)("strong",{parentName:"li"},(0,i.kt)("icon",{icon:"fa-solid fa-rocket",size:"lg"})," Deploy"),".\n",(0,i.kt)("img",{alt:"Deploy generated leader pod to Kubernetes screen",src:n(61781).Z,width:"1292",height:"968"})),(0,i.kt)("li",{parentName:"ol"},"Wait for the pod to reach the state: ",(0,i.kt)("strong",{parentName:"li"},"Phase: Running"),"."),(0,i.kt)("li",{parentName:"ol"},"Click ",(0,i.kt)("strong",{parentName:"li"},"Done"),".")))),(0,i.kt)("h4",{id:"verification-2"},"Verification"),(0,i.kt)("ul",null,(0,i.kt)("li",{parentName:"ul"},(0,i.kt)("p",{parentName:"li"},"The ",(0,i.kt)("strong",{parentName:"p"},(0,i.kt)("icon",{icon:"fa-solid fa-cubes",size:"lg"})," Pods")," screen lists the running ",(0,i.kt)("inlineCode",{parentName:"p"},"redis-leader")," pod."),(0,i.kt)("p",{parentName:"li"},(0,i.kt)("img",{alt:"leader pod is running",src:n(39272).Z,width:"684",height:"231"})))),(0,i.kt)("h2",{id:"starting-the-redis-followers"},"Starting the Redis followers"),(0,i.kt)("p",null,"Although the Redis leader is a single Pod, you can make it highly available and meet traffic demands by adding a few Redis followers, or replicas."),(0,i.kt)("p",null,(0,i.kt)("strong",{parentName:"p"},"With Podman Desktop, you can prepare the Redis follower image and container on your local container engine, and deploy the results to Kubernetes pods and services."),"\nThis is functionally equal to the ",(0,i.kt)("inlineCode",{parentName:"p"},"redis-follower")," deployment that the Kubernetes example propose."),(0,i.kt)("h4",{id:"procedure-2"},"Procedure"),(0,i.kt)("ol",null,(0,i.kt)("li",{parentName:"ol"},"Open ",(0,i.kt)("strong",{parentName:"li"},(0,i.kt)("icon",{icon:"fa-solid fa-cloud",size:"lg"})," Images > ",(0,i.kt)("icon",{icon:"fa-solid fa-arrow-circle-down",size:"lg"})," Pull an image"),".",(0,i.kt)("ol",{parentName:"li"},(0,i.kt)("li",{parentName:"ol"},(0,i.kt)("strong",{parentName:"li"},"Image to Pull"),": enter ",(0,i.kt)("inlineCode",{parentName:"li"},"gcr.io/google_samples/gb-redis-follower:v2")),(0,i.kt)("li",{parentName:"ol"},"Click ",(0,i.kt)("strong",{parentName:"li"},"Pull image")," to pull the image to your container engine local image registry."),(0,i.kt)("li",{parentName:"ol"},"Click ",(0,i.kt)("strong",{parentName:"li"},"Done")," to get back to the images list."))),(0,i.kt)("li",{parentName:"ol"},(0,i.kt)("strong",{parentName:"li"},(0,i.kt)("icon",{icon:"fa-solid fa-cloud",size:"lg"})," Search images"),": enter ",(0,i.kt)("inlineCode",{parentName:"li"},"gb-redis-follower:v2")," to find the image."),(0,i.kt)("li",{parentName:"ol"},"Click ",(0,i.kt)("strong",{parentName:"li"},(0,i.kt)("icon",{icon:"fa-solid fa-play",size:"lg"}))," to open the ",(0,i.kt)("strong",{parentName:"li"},"Create a container from image")," dialog.",(0,i.kt)("ol",{parentName:"li"},(0,i.kt)("li",{parentName:"ol"},(0,i.kt)("strong",{parentName:"li"},"Container name"),": enter ",(0,i.kt)("inlineCode",{parentName:"li"},"follower"),","),(0,i.kt)("li",{parentName:"ol"},(0,i.kt)("strong",{parentName:"li"},"Local port for ",(0,i.kt)("inlineCode",{parentName:"strong"},"6379/tcp")),": ",(0,i.kt)("inlineCode",{parentName:"li"},"6379"),"."),(0,i.kt)("li",{parentName:"ol"},"Click ",(0,i.kt)("strong",{parentName:"li"},(0,i.kt)("icon",{icon:"fa-solid fa-play",size:"lg"})," Start Container")," to start the container in your container engine."))),(0,i.kt)("li",{parentName:"ol"},(0,i.kt)("strong",{parentName:"li"},(0,i.kt)("icon",{icon:"fa-solid fa-cloud",size:"lg"})," Search containers"),": enter ",(0,i.kt)("inlineCode",{parentName:"li"},"follower")," to find the running container."),(0,i.kt)("li",{parentName:"ol"},"Click ",(0,i.kt)("strong",{parentName:"li"},(0,i.kt)("icon",{icon:"fa-solid fa-stop",size:"lg"}))," to stop the container: you do not need it to run in the container engine."),(0,i.kt)("li",{parentName:"ol"},"Click ",(0,i.kt)("strong",{parentName:"li"},(0,i.kt)("icon",{icon:"fa-solid fa-ellipsis-v",size:"lg"})," > ",(0,i.kt)("icon",{icon:"fa-solid fa-rocket",size:"lg"})," Deploy to Kubernetes")," to open the ",(0,i.kt)("strong",{parentName:"li"},"Deploy generated pod to Kubernetes")," screen.",(0,i.kt)("ol",{parentName:"li"},(0,i.kt)("li",{parentName:"ol"},(0,i.kt)("strong",{parentName:"li"},"Pod Name"),": enter ",(0,i.kt)("inlineCode",{parentName:"li"},"redis-follower"),"."),(0,i.kt)("li",{parentName:"ol"},(0,i.kt)("strong",{parentName:"li"},"Use Kubernetes Services"),": select ",(0,i.kt)("strong",{parentName:"li"},"Replace ",(0,i.kt)("inlineCode",{parentName:"strong"},"hostPort")," exposure on containers by Services. It is the recommended way to expose ports, as a cluster policy might prevent to use ",(0,i.kt)("inlineCode",{parentName:"strong"},"hostPort"),".")),(0,i.kt)("li",{parentName:"ol"},(0,i.kt)("strong",{parentName:"li"},"Expose service locally using Kubernetes Ingress"),": deselect ",(0,i.kt)("strong",{parentName:"li"},"Create a Kubernetes ingress to get access to the ports that this pod exposes, at the default ingress controller location. Example: on a default Kind cluster created with Podman Desktop: ",(0,i.kt)("inlineCode",{parentName:"strong"},"http://localhost:9090"),". Requirements: your cluster has an ingress controller`"),"."),(0,i.kt)("li",{parentName:"ol"},(0,i.kt)("strong",{parentName:"li"},"Kubernetes namespaces"),": select ",(0,i.kt)("inlineCode",{parentName:"li"},"default"),"."),(0,i.kt)("li",{parentName:"ol"},"Click ",(0,i.kt)("strong",{parentName:"li"},(0,i.kt)("icon",{icon:"fa-solid fa-rocket",size:"lg"})," Deploy"),".\n",(0,i.kt)("img",{alt:"Deploy generated follower pod to Kubernetes screen",src:n(18738).Z,width:"1292",height:"968"})),(0,i.kt)("li",{parentName:"ol"},"Wait for the pod to reach the state: ",(0,i.kt)("strong",{parentName:"li"},"Phase: Running"),"."),(0,i.kt)("li",{parentName:"ol"},"Click ",(0,i.kt)("strong",{parentName:"li"},"Done"),"."))),(0,i.kt)("li",{parentName:"ol"},"To add replicas, repeat the last step with another ",(0,i.kt)("strong",{parentName:"li"},"Pod Name")," value.")),(0,i.kt)("h4",{id:"verification-3"},"Verification"),(0,i.kt)("ul",null,(0,i.kt)("li",{parentName:"ul"},(0,i.kt)("p",{parentName:"li"},"The ",(0,i.kt)("strong",{parentName:"p"},(0,i.kt)("icon",{icon:"fa-solid fa-cubes",size:"lg"})," Pods")," screen lists the running ",(0,i.kt)("inlineCode",{parentName:"p"},"redis-follower")," pods."),(0,i.kt)("p",{parentName:"li"},(0,i.kt)("img",{alt:"follower pods are running",src:n(15740).Z,width:"668",height:"286"})))),(0,i.kt)("h2",{id:"starting-the-default-frontend"},"Starting the default frontend"),(0,i.kt)("p",null,"Now that you have the Redis storage of your Guestbook up and running, start the Guestbook web servers.\nLike the Redis followers, deploy the frontend using Kubernetes pods and services."),(0,i.kt)("p",null,"The Guestbook app uses a PHP frontend.\nIt is configured to communicate with either the Redis follower or leader Services, depending on whether the request is a read or a write.\nThe frontend exposes a JSON interface, and serves a jQuery-Ajax-based UX."),(0,i.kt)("p",null,"With Podman Desktop, you can prepare the Guestbook frontend image and container on your local container engine, and deploy the results to Kubernetes pods and services.\nThis is functionally equal to the ",(0,i.kt)("inlineCode",{parentName:"p"},"frontend")," deployment that the Kubernetes example propose."),(0,i.kt)("h4",{id:"procedure-3"},"Procedure"),(0,i.kt)("ol",null,(0,i.kt)("li",{parentName:"ol"},"Open ",(0,i.kt)("strong",{parentName:"li"},(0,i.kt)("icon",{icon:"fa-solid fa-cloud",size:"lg"})," Images > ",(0,i.kt)("icon",{icon:"fa-solid fa-arrow-circle-down",size:"lg"})," Pull an image"),".",(0,i.kt)("ol",{parentName:"li"},(0,i.kt)("li",{parentName:"ol"},(0,i.kt)("strong",{parentName:"li"},"Image to Pull"),": enter ",(0,i.kt)("inlineCode",{parentName:"li"},"gcr.io/google_samples/gb-frontend:v5")),(0,i.kt)("li",{parentName:"ol"},"Click ",(0,i.kt)("strong",{parentName:"li"},"Pull image")," to pull the image to your container engine local image registry."),(0,i.kt)("li",{parentName:"ol"},"Wait for the pull to complete."),(0,i.kt)("li",{parentName:"ol"},"Click ",(0,i.kt)("strong",{parentName:"li"},"Done")," to get back to the images list."))),(0,i.kt)("li",{parentName:"ol"},(0,i.kt)("strong",{parentName:"li"},(0,i.kt)("icon",{icon:"fa-solid fa-cloud",size:"lg"})," Search images"),": enter ",(0,i.kt)("inlineCode",{parentName:"li"},"gb-frontend:v5")," to find the image."),(0,i.kt)("li",{parentName:"ol"},"Click ",(0,i.kt)("strong",{parentName:"li"},(0,i.kt)("icon",{icon:"fa-solid fa-play",size:"lg"}))," to open the ",(0,i.kt)("strong",{parentName:"li"},"Create a container from image")," dialog.",(0,i.kt)("ol",{parentName:"li"},(0,i.kt)("li",{parentName:"ol"},(0,i.kt)("strong",{parentName:"li"},"Container name"),": enter ",(0,i.kt)("inlineCode",{parentName:"li"},"frontend"),","),(0,i.kt)("li",{parentName:"ol"},(0,i.kt)("strong",{parentName:"li"},"Local port for ",(0,i.kt)("inlineCode",{parentName:"strong"},"80/tcp")),": ",(0,i.kt)("inlineCode",{parentName:"li"},"9000"),"."),(0,i.kt)("li",{parentName:"ol"},"Click ",(0,i.kt)("strong",{parentName:"li"},(0,i.kt)("icon",{icon:"fa-solid fa-play",size:"lg"})," Start Container")," to start the container in your container engine."))),(0,i.kt)("li",{parentName:"ol"},(0,i.kt)("strong",{parentName:"li"},(0,i.kt)("icon",{icon:"fa-solid fa-cloud",size:"lg"})," Search containers"),": enter ",(0,i.kt)("inlineCode",{parentName:"li"},"frontend")," to find the running container."),(0,i.kt)("li",{parentName:"ol"},"Click ",(0,i.kt)("strong",{parentName:"li"},(0,i.kt)("icon",{icon:"fa-solid fa-stop",size:"lg"}))," to stop the container: you do not need it to run in the container engine."),(0,i.kt)("li",{parentName:"ol"},"Click ",(0,i.kt)("strong",{parentName:"li"},(0,i.kt)("icon",{icon:"fa-solid fa-ellipsis-v",size:"lg"})," > ",(0,i.kt)("icon",{icon:"fa-solid fa-rocket",size:"lg"})," Deploy to Kubernetes")," to open the ",(0,i.kt)("strong",{parentName:"li"},"Deploy generated pod to Kubernetes")," screen.",(0,i.kt)("ol",{parentName:"li"},(0,i.kt)("li",{parentName:"ol"},(0,i.kt)("strong",{parentName:"li"},"Pod Name"),": enter ",(0,i.kt)("inlineCode",{parentName:"li"},"frontend"),"."),(0,i.kt)("li",{parentName:"ol"},(0,i.kt)("strong",{parentName:"li"},"Use Kubernetes Services"),": select ",(0,i.kt)("strong",{parentName:"li"},"Replace ",(0,i.kt)("inlineCode",{parentName:"strong"},"hostPort")," exposure on containers by Services. It is the recommended way to expose ports, as a cluster policy might prevent to use ",(0,i.kt)("inlineCode",{parentName:"strong"},"hostPort"),".")),(0,i.kt)("li",{parentName:"ol"},(0,i.kt)("strong",{parentName:"li"},"Expose service locally using Kubernetes Ingress"),": select ",(0,i.kt)("strong",{parentName:"li"},"Create a Kubernetes ingress to get access to the ports that this pod exposes, at the default ingress controller location. Example: on a default Kind cluster created with Podman Desktop: ",(0,i.kt)("inlineCode",{parentName:"strong"},"http://localhost:9090"),". Requirements: your cluster has an ingress controller`"),"."),(0,i.kt)("li",{parentName:"ol"},(0,i.kt)("strong",{parentName:"li"},"Kubernetes namespaces"),": select ",(0,i.kt)("inlineCode",{parentName:"li"},"default"),"."),(0,i.kt)("li",{parentName:"ol"},"Click ",(0,i.kt)("strong",{parentName:"li"},(0,i.kt)("icon",{icon:"fa-solid fa-rocket",size:"lg"})," Deploy"),".\n",(0,i.kt)("img",{alt:"Deploy generated frontend pod to Kubernetes screen",src:n(67104).Z,width:"1292",height:"968"})),(0,i.kt)("li",{parentName:"ol"},"Wait for the pod to reach the state: ",(0,i.kt)("strong",{parentName:"li"},"Phase: Running"),"."),(0,i.kt)("li",{parentName:"ol"},"Click ",(0,i.kt)("strong",{parentName:"li"},"Done"),".")))),(0,i.kt)("h4",{id:"verification-4"},"Verification"),(0,i.kt)("ol",null,(0,i.kt)("li",{parentName:"ol"},(0,i.kt)("p",{parentName:"li"},"The ",(0,i.kt)("strong",{parentName:"p"},(0,i.kt)("icon",{icon:"fa-solid fa-cubes",size:"lg"})," Pods")," screen lists the running ",(0,i.kt)("inlineCode",{parentName:"p"},"frontend")," pod."),(0,i.kt)("p",{parentName:"li"},(0,i.kt)("img",{alt:"`frontend` pod is running",src:n(99992).Z,width:"674",height:"222"}))),(0,i.kt)("li",{parentName:"ol"},(0,i.kt)("p",{parentName:"li"},"Go to ",(0,i.kt)("inlineCode",{parentName:"p"},"http://localhost:9090"),": the Guestbook application is running."))))}c.isMDXComponent=!0},76893:(e,t,n)=>{n.d(t,{Z:()=>a});const a=n.p+"assets/images/create-a-kind-cluster-341ca1312e2e05d63d82a93726825a05.png"},18738:(e,t,n)=>{n.d(t,{Z:()=>a});const a=n.p+"assets/images/deploy-generated-follower-pod-to-kubernetes-dd643e002a1dbf69e29ef7863f0774d8.png"},67104:(e,t,n)=>{n.d(t,{Z:()=>a});const a=n.p+"assets/images/deploy-generated-frontend-pod-to-kubernetes-cf7e13dbd73427575b2cf583e223df38.png"},61781:(e,t,n)=>{n.d(t,{Z:()=>a});const a=n.p+"assets/images/deploy-generated-leader-pod-to-kubernetes-e812812296742ec54cd822d0ba969c28.png"},15740:(e,t,n)=>{n.d(t,{Z:()=>a});const a=n.p+"assets/images/follower-pods-are-running-be90e0689f30209b0694469405ecd6a9.png"},99992:(e,t,n)=>{n.d(t,{Z:()=>a});const a=n.p+"assets/images/frontend-pod-is-running-f6f55d91d200f35629788d3c550ae463.png"},10141:(e,t,n)=>{n.d(t,{Z:()=>a});const a=n.p+"assets/images/kind-cluster-context-in-the-tray-5bb9338bb1437bbcf79bf50dd401400e.png"},30712:(e,t,n)=>{n.d(t,{Z:()=>a});const a=n.p+"assets/images/kind-cluster-is-running-e721d473aa52100d8179cbb3d06e0ef9.png"},39272:(e,t,n)=>{n.d(t,{Z:()=>a});const a=n.p+"assets/images/leader-pod-is-running-a8caa174a15c06b287dff81b08041f7c.png"},65986:(e,t,n)=>{n.d(t,{Z:()=>a});const a=n.p+"assets/images/podman-is-running-745db8684c4d0240922a5aeb63e517d3.png"}}]); \ No newline at end of file diff --git a/assets/js/e44de27e.bbd5ecaa.js b/assets/js/e44de27e.bbd5ecaa.js new file mode 100644 index 00000000000..4a46545590b --- /dev/null +++ b/assets/js/e44de27e.bbd5ecaa.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[2599],{35318:(e,n,t)=>{t.d(n,{Zo:()=>s,kt:()=>u});var o=t(27378);function a(e,n,t){return n in e?Object.defineProperty(e,n,{value:t,enumerable:!0,configurable:!0,writable:!0}):e[n]=t,e}function r(e,n){var t=Object.keys(e);if(Object.getOwnPropertySymbols){var o=Object.getOwnPropertySymbols(e);n&&(o=o.filter((function(n){return Object.getOwnPropertyDescriptor(e,n).enumerable}))),t.push.apply(t,o)}return t}function i(e){for(var n=1;n=0||(a[t]=e[t]);return a}(e,n);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(e);for(o=0;o=0||Object.prototype.propertyIsEnumerable.call(e,t)&&(a[t]=e[t])}return a}var l=o.createContext({}),m=function(e){var n=o.useContext(l),t=n;return e&&(t="function"==typeof e?e(n):i(i({},n),e)),t},s=function(e){var n=m(e.components);return o.createElement(l.Provider,{value:n},e.children)},p={inlineCode:"code",wrapper:function(e){var n=e.children;return o.createElement(o.Fragment,{},n)}},d=o.forwardRef((function(e,n){var t=e.components,a=e.mdxType,r=e.originalType,l=e.parentName,s=c(e,["components","mdxType","originalType","parentName"]),d=m(t),u=a,f=d["".concat(l,".").concat(u)]||d[u]||p[u]||r;return t?o.createElement(f,i(i({ref:n},s),{},{components:t})):o.createElement(f,i({ref:n},s))}));function u(e,n){var t=arguments,a=n&&n.mdxType;if("string"==typeof e||a){var r=t.length,i=new Array(r);i[0]=d;var c={};for(var l in n)hasOwnProperty.call(n,l)&&(c[l]=n[l]);c.originalType=e,c.mdxType="string"==typeof e?e:a,i[1]=c;for(var m=2;m{t.r(n),t.d(n,{assets:()=>l,contentTitle:()=>i,default:()=>u,frontMatter:()=>r,metadata:()=>c,toc:()=>m});var o=t(25773),a=(t(27378),t(35318));const r={sidebar_position:50,title:"Setting Podman machine default connection",description:"How to set Podman machine default connection."},i="Setting Podman machine default connection",c={unversionedId:"podman/setting-podman-machine-default-connection",id:"podman/setting-podman-machine-default-connection",title:"Setting Podman machine default connection",description:"How to set Podman machine default connection.",source:"@site/docs/podman/setting-podman-machine-default-connection.md",sourceDirName:"podman",slug:"/podman/setting-podman-machine-default-connection",permalink:"/docs/podman/setting-podman-machine-default-connection",draft:!1,editUrl:"https://github.com/containers/podman-desktop/tree/main/website/docs/podman/setting-podman-machine-default-connection.md",tags:[],version:"current",sidebarPosition:50,frontMatter:{sidebar_position:50,title:"Setting Podman machine default connection",description:"How to set Podman machine default connection."},sidebar:"mySidebar",previous:{title:"Creating a Podman machine",permalink:"/docs/podman/creating-a-podman-machine"},next:{title:"Migrating from Docker",permalink:"/docs/migrating-from-docker/"}},l={},m=[{value:"Procedure",id:"procedure",level:4},{value:"Verification",id:"verification",level:4}],s=(p="Icon",function(e){return console.warn("Component "+p+" was not imported, exported, or provided by MDXProvider as global scope"),(0,a.kt)("div",e)});var p;const d={toc:m};function u(e){let{components:n,...t}=e;return(0,a.kt)("wrapper",(0,o.Z)({},d,t,{components:n,mdxType:"MDXLayout"}),(0,a.kt)("h1",{id:"setting-podman-machine-default-connection"},"Setting Podman machine default connection"),(0,a.kt)("p",null,"Each Podman machine exposes two connections:"),(0,a.kt)("ul",null,(0,a.kt)("li",{parentName:"ul"},"rootless"),(0,a.kt)("li",{parentName:"ul"},"rootful")),(0,a.kt)("p",null,"Podman has one default connection."),(0,a.kt)("p",null,"Podman Desktop, and other tools, such as Kind, connect to the default connection."),(0,a.kt)("p",null,"After an event that might have changed the default Podman machine connection, such as creating another Podman machine, consider verifying and setting the default connection."),(0,a.kt)("h4",{id:"procedure"},"Procedure"),(0,a.kt)("ol",null,(0,a.kt)("li",{parentName:"ol"},(0,a.kt)("p",{parentName:"li"},"List Podman machine connections, in a terminal:"),(0,a.kt)("pre",{parentName:"li"},(0,a.kt)("code",{parentName:"pre",className:"language-shell-session"},"$ podman system connection ls\n"))),(0,a.kt)("li",{parentName:"ol"},(0,a.kt)("p",{parentName:"li"},"Set the Podman machine default connection to your desired connection, such as ",(0,a.kt)("inlineCode",{parentName:"p"},"podman-machine-default-root"),", in a terminal:"),(0,a.kt)("pre",{parentName:"li"},(0,a.kt)("code",{parentName:"pre",className:"language-shell-session"},"$ podman system connection default podman-machine-default-root\n"))),(0,a.kt)("li",{parentName:"ol"},(0,a.kt)("p",{parentName:"li"},"List Podman machine connections, to verify which is the default, in a terminal:"),(0,a.kt)("pre",{parentName:"li"},(0,a.kt)("code",{parentName:"pre",className:"language-shell-session"},"$ podman system connection ls\n"))),(0,a.kt)("li",{parentName:"ol"},(0,a.kt)("p",{parentName:"li"},"Restart the Podman machine that has the default connection:"),(0,a.kt)("pre",{parentName:"li"},(0,a.kt)("code",{parentName:"pre",className:"language-shell-session"},"$ podman machine stop\n$ podman machine start\n"))),(0,a.kt)("li",{parentName:"ol"},(0,a.kt)("p",{parentName:"li"},"Refresh Podman Desktop connection to Podman: click the ",(0,a.kt)("strong",{parentName:"p"},(0,a.kt)(s,{icon:"fa-solid fa-lightbulb",size:"lg",mdxType:"Icon"}))," icon to open the ",(0,a.kt)("strong",{parentName:"p"},"Troubleshooting")," page, and click the ",(0,a.kt)("strong",{parentName:"p"},"Reconnect providers")," button."))),(0,a.kt)("h4",{id:"verification"},"Verification"),(0,a.kt)("ul",null,(0,a.kt)("li",{parentName:"ul"},"Podman Desktop lists images, containers, and pods that are accessible via the desired Podman machine connection.")))}u.isMDXComponent=!0}}]); \ No newline at end of file diff --git a/assets/js/e44de27e.bf2c1cc8.js b/assets/js/e44de27e.bf2c1cc8.js deleted file mode 100644 index c6851fe6b06..00000000000 --- a/assets/js/e44de27e.bf2c1cc8.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[2599],{35318:(e,n,t)=>{t.d(n,{Zo:()=>s,kt:()=>u});var a=t(27378);function o(e,n,t){return n in e?Object.defineProperty(e,n,{value:t,enumerable:!0,configurable:!0,writable:!0}):e[n]=t,e}function i(e,n){var t=Object.keys(e);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);n&&(a=a.filter((function(n){return Object.getOwnPropertyDescriptor(e,n).enumerable}))),t.push.apply(t,a)}return t}function r(e){for(var n=1;n=0||(o[t]=e[t]);return o}(e,n);if(Object.getOwnPropertySymbols){var i=Object.getOwnPropertySymbols(e);for(a=0;a=0||Object.prototype.propertyIsEnumerable.call(e,t)&&(o[t]=e[t])}return o}var l=a.createContext({}),m=function(e){var n=a.useContext(l),t=n;return e&&(t="function"==typeof e?e(n):r(r({},n),e)),t},s=function(e){var n=m(e.components);return a.createElement(l.Provider,{value:n},e.children)},p={inlineCode:"code",wrapper:function(e){var n=e.children;return a.createElement(a.Fragment,{},n)}},d=a.forwardRef((function(e,n){var t=e.components,o=e.mdxType,i=e.originalType,l=e.parentName,s=c(e,["components","mdxType","originalType","parentName"]),d=m(t),u=o,f=d["".concat(l,".").concat(u)]||d[u]||p[u]||i;return t?a.createElement(f,r(r({ref:n},s),{},{components:t})):a.createElement(f,r({ref:n},s))}));function u(e,n){var t=arguments,o=n&&n.mdxType;if("string"==typeof e||o){var i=t.length,r=new Array(i);r[0]=d;var c={};for(var l in n)hasOwnProperty.call(n,l)&&(c[l]=n[l]);c.originalType=e,c.mdxType="string"==typeof e?e:o,r[1]=c;for(var m=2;m{t.r(n),t.d(n,{assets:()=>l,contentTitle:()=>r,default:()=>p,frontMatter:()=>i,metadata:()=>c,toc:()=>m});var a=t(25773),o=(t(27378),t(35318));const i={sidebar_position:50,title:"Setting Podman machine default connection",description:"How to set Podman machine default connection."},r="Setting Podman machine default connection",c={unversionedId:"podman/setting-podman-machine-default-connection",id:"podman/setting-podman-machine-default-connection",title:"Setting Podman machine default connection",description:"How to set Podman machine default connection.",source:"@site/docs/podman/setting-podman-machine-default-connection.md",sourceDirName:"podman",slug:"/podman/setting-podman-machine-default-connection",permalink:"/docs/podman/setting-podman-machine-default-connection",draft:!1,editUrl:"https://github.com/containers/podman-desktop/tree/main/website/docs/podman/setting-podman-machine-default-connection.md",tags:[],version:"current",sidebarPosition:50,frontMatter:{sidebar_position:50,title:"Setting Podman machine default connection",description:"How to set Podman machine default connection."},sidebar:"mySidebar",previous:{title:"Creating a Podman machine",permalink:"/docs/podman/creating-a-podman-machine"},next:{title:"Migrating from Docker",permalink:"/docs/migrating-from-docker/"}},l={},m=[{value:"Procedure",id:"procedure",level:4},{value:"Verification",id:"verification",level:4}],s={toc:m};function p(e){let{components:n,...t}=e;return(0,o.kt)("wrapper",(0,a.Z)({},s,t,{components:n,mdxType:"MDXLayout"}),(0,o.kt)("h1",{id:"setting-podman-machine-default-connection"},"Setting Podman machine default connection"),(0,o.kt)("p",null,"Each Podman machine exposes two connections:"),(0,o.kt)("ul",null,(0,o.kt)("li",{parentName:"ul"},"rootless"),(0,o.kt)("li",{parentName:"ul"},"rootful")),(0,o.kt)("p",null,"Podman has one default connection."),(0,o.kt)("p",null,"Podman Desktop, and other tools, such as Kind, connect to the default connection."),(0,o.kt)("p",null,"After an event that might have changed the default Podman machine connection, such as creating another Podman machine, consider verifying and setting the default connection."),(0,o.kt)("h4",{id:"procedure"},"Procedure"),(0,o.kt)("ol",null,(0,o.kt)("li",{parentName:"ol"},(0,o.kt)("p",{parentName:"li"},"List Podman machine connections, in a terminal:"),(0,o.kt)("pre",{parentName:"li"},(0,o.kt)("code",{parentName:"pre",className:"language-shell-session"},"$ podman system connection ls\n"))),(0,o.kt)("li",{parentName:"ol"},(0,o.kt)("p",{parentName:"li"},"Set the Podman machine default connection to your desired connection, such as ",(0,o.kt)("inlineCode",{parentName:"p"},"podman-machine-default-root"),", in a terminal:"),(0,o.kt)("pre",{parentName:"li"},(0,o.kt)("code",{parentName:"pre",className:"language-shell-session"},"$ podman system connection default podman-machine-default-root\n"))),(0,o.kt)("li",{parentName:"ol"},(0,o.kt)("p",{parentName:"li"},"List Podman machine connections, to verify which is the default, in a terminal:"),(0,o.kt)("pre",{parentName:"li"},(0,o.kt)("code",{parentName:"pre",className:"language-shell-session"},"$ podman system connection ls\n"))),(0,o.kt)("li",{parentName:"ol"},(0,o.kt)("p",{parentName:"li"},"Restart the Podman machine that has the default connection:"),(0,o.kt)("pre",{parentName:"li"},(0,o.kt)("code",{parentName:"pre",className:"language-shell-session"},"$ podman machine stop\n$ podman machine start\n"))),(0,o.kt)("li",{parentName:"ol"},(0,o.kt)("p",{parentName:"li"},"Refresh Podman Desktop connection to Podman: click the ",(0,o.kt)("strong",{parentName:"p"},(0,o.kt)("icon",{icon:"fa-solid fa-lightbulb",size:"lg"}))," icon to open the ",(0,o.kt)("strong",{parentName:"p"},"Troubleshooting")," page, and click the ",(0,o.kt)("strong",{parentName:"p"},"Reconnect providers")," button."))),(0,o.kt)("h4",{id:"verification"},"Verification"),(0,o.kt)("ul",null,(0,o.kt)("li",{parentName:"ul"},"Podman Desktop lists images, containers, and pods that are accessible via the desired Podman machine connection.")))}p.isMDXComponent=!0}}]); \ No newline at end of file diff --git a/assets/js/eb17771c.21d051e3.js b/assets/js/eb17771c.21d051e3.js new file mode 100644 index 00000000000..8fffa624f74 --- /dev/null +++ b/assets/js/eb17771c.21d051e3.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[7480],{35318:(e,t,n)=>{n.d(t,{Zo:()=>l,kt:()=>b});var r=n(27378);function i(e,t,n){return t in e?Object.defineProperty(e,t,{value:n,enumerable:!0,configurable:!0,writable:!0}):e[t]=n,e}function o(e,t){var n=Object.keys(e);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(e);t&&(r=r.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),n.push.apply(n,r)}return n}function a(e){for(var t=1;t=0||(i[n]=e[n]);return i}(e,t);if(Object.getOwnPropertySymbols){var o=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(i[n]=e[n])}return i}var c=r.createContext({}),u=function(e){var t=r.useContext(c),n=t;return e&&(n="function"==typeof e?e(t):a(a({},t),e)),n},l=function(e){var t=u(e.components);return r.createElement(c.Provider,{value:t},e.children)},p={inlineCode:"code",wrapper:function(e){var t=e.children;return r.createElement(r.Fragment,{},t)}},d=r.forwardRef((function(e,t){var n=e.components,i=e.mdxType,o=e.originalType,c=e.parentName,l=s(e,["components","mdxType","originalType","parentName"]),d=u(n),b=i,g=d["".concat(c,".").concat(b)]||d[b]||p[b]||o;return n?r.createElement(g,a(a({ref:t},l),{},{components:n})):r.createElement(g,a({ref:t},l))}));function b(e,t){var n=arguments,i=t&&t.mdxType;if("string"==typeof e||i){var o=n.length,a=new Array(o);a[0]=d;var s={};for(var c in t)hasOwnProperty.call(t,c)&&(s[c]=t[c]);s.originalType=e,s.mdxType="string"==typeof e?e:i,a[1]=s;for(var u=2;u{n.r(t),n.d(t,{assets:()=>c,contentTitle:()=>a,default:()=>b,frontMatter:()=>o,metadata:()=>s,toc:()=>u});var r=n(25773),i=(n(27378),n(35318));const o={sidebar_position:2,title:"Selecting a context in the status bar",description:"Viewing and selecting the current Kubernetes context in the status bar",keywords:["podman desktop","podman","containers","pods","migrating","kubernetes"],tags:["migrating-to-kubernetes"]},a="Viewing and selecting the current Kubernetes context",s={unversionedId:"kubernetes/viewing-and-selecting-current-kubernete-context-in-the-status-bar",id:"kubernetes/viewing-and-selecting-current-kubernete-context-in-the-status-bar",title:"Selecting a context in the status bar",description:"Viewing and selecting the current Kubernetes context in the status bar",source:"@site/docs/kubernetes/viewing-and-selecting-current-kubernete-context-in-the-status-bar.md",sourceDirName:"kubernetes",slug:"/kubernetes/viewing-and-selecting-current-kubernete-context-in-the-status-bar",permalink:"/docs/kubernetes/viewing-and-selecting-current-kubernete-context-in-the-status-bar",draft:!1,editUrl:"https://github.com/containers/podman-desktop/tree/main/website/docs/kubernetes/viewing-and-selecting-current-kubernete-context-in-the-status-bar.md",tags:[{label:"migrating-to-kubernetes",permalink:"/docs/tags/migrating-to-kubernetes"}],version:"current",sidebarPosition:2,frontMatter:{sidebar_position:2,title:"Selecting a context in the status bar",description:"Viewing and selecting the current Kubernetes context in the status bar",keywords:["podman desktop","podman","containers","pods","migrating","kubernetes"],tags:["migrating-to-kubernetes"]},sidebar:"mySidebar",previous:{title:"Kubernetes",permalink:"/docs/kubernetes/"},next:{title:"Selecting a context",permalink:"/docs/kubernetes/viewing-and-selecting-current-kubernete-context"}},c={},u=[{value:"Prerequisites",id:"prerequisites",level:4},{value:"Procedure",id:"procedure",level:4}],l=(p="Icon",function(e){return console.warn("Component "+p+" was not imported, exported, or provided by MDXProvider as global scope"),(0,i.kt)("div",e)});var p;const d={toc:u};function b(e){let{components:t,...n}=e;return(0,i.kt)("wrapper",(0,r.Z)({},d,n,{components:t,mdxType:"MDXLayout"}),(0,i.kt)("h1",{id:"viewing-and-selecting-the-current-kubernetes-context"},"Viewing and selecting the current Kubernetes context"),(0,i.kt)("p",null,"With Podman Desktop, you can view and select your current Kubernetes context in the status bar."),(0,i.kt)("h4",{id:"prerequisites"},"Prerequisites"),(0,i.kt)("ul",null,(0,i.kt)("li",{parentName:"ul"},"You have a Kubernetes context in your kubeconfig file: ",(0,i.kt)("em",{parentName:"li"},"<","your_kubernetes_cluster",">"),".\nFor example, ",(0,i.kt)("a",{parentName:"li",href:"/docs/kind/creating-a-kind-cluster"},"Creating a kind cluster"),".")),(0,i.kt)("h4",{id:"procedure"},"Procedure"),(0,i.kt)("ol",null,(0,i.kt)("li",{parentName:"ol"},(0,i.kt)("p",{parentName:"li"},"To view your current Kubernetes context, in the ",(0,i.kt)("strong",{parentName:"p"},"Podman Desktop")," main window status bar, see the name next to the ",(0,i.kt)(l,{icon:"fa-solid fa-server",size:"lg",mdxType:"Icon"})," icon.")),(0,i.kt)("li",{parentName:"ol"},(0,i.kt)("p",{parentName:"li"},"(Optionally) To change your Kubernetes context:"),(0,i.kt)("ol",{parentName:"li"},(0,i.kt)("li",{parentName:"ol"},"Click ",(0,i.kt)(l,{icon:"fa-solid fa-server",size:"lg",mdxType:"Icon"}),"."),(0,i.kt)("li",{parentName:"ol"},"In the drop-down menu, click the context name to activate.")))))}b.isMDXComponent=!0}}]); \ No newline at end of file diff --git a/assets/js/eb17771c.f1561fea.js b/assets/js/eb17771c.f1561fea.js deleted file mode 100644 index d38f6a8e399..00000000000 --- a/assets/js/eb17771c.f1561fea.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[7480],{35318:(e,t,n)=>{n.d(t,{Zo:()=>l,kt:()=>b});var r=n(27378);function i(e,t,n){return t in e?Object.defineProperty(e,t,{value:n,enumerable:!0,configurable:!0,writable:!0}):e[t]=n,e}function a(e,t){var n=Object.keys(e);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(e);t&&(r=r.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),n.push.apply(n,r)}return n}function o(e){for(var t=1;t=0||(i[n]=e[n]);return i}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(i[n]=e[n])}return i}var c=r.createContext({}),u=function(e){var t=r.useContext(c),n=t;return e&&(n="function"==typeof e?e(t):o(o({},t),e)),n},l=function(e){var t=u(e.components);return r.createElement(c.Provider,{value:t},e.children)},p={inlineCode:"code",wrapper:function(e){var t=e.children;return r.createElement(r.Fragment,{},t)}},d=r.forwardRef((function(e,t){var n=e.components,i=e.mdxType,a=e.originalType,c=e.parentName,l=s(e,["components","mdxType","originalType","parentName"]),d=u(n),b=i,g=d["".concat(c,".").concat(b)]||d[b]||p[b]||a;return n?r.createElement(g,o(o({ref:t},l),{},{components:n})):r.createElement(g,o({ref:t},l))}));function b(e,t){var n=arguments,i=t&&t.mdxType;if("string"==typeof e||i){var a=n.length,o=new Array(a);o[0]=d;var s={};for(var c in t)hasOwnProperty.call(t,c)&&(s[c]=t[c]);s.originalType=e,s.mdxType="string"==typeof e?e:i,o[1]=s;for(var u=2;u{n.r(t),n.d(t,{assets:()=>c,contentTitle:()=>o,default:()=>p,frontMatter:()=>a,metadata:()=>s,toc:()=>u});var r=n(25773),i=(n(27378),n(35318));const a={sidebar_position:2,title:"Selecting a context in the status bar",description:"Viewing and selecting the current Kubernetes context in the status bar",keywords:["podman desktop","podman","containers","pods","migrating","kubernetes"],tags:["migrating-to-kubernetes"]},o="Viewing and selecting the current Kubernetes context",s={unversionedId:"kubernetes/viewing-and-selecting-current-kubernete-context-in-the-status-bar",id:"kubernetes/viewing-and-selecting-current-kubernete-context-in-the-status-bar",title:"Selecting a context in the status bar",description:"Viewing and selecting the current Kubernetes context in the status bar",source:"@site/docs/kubernetes/viewing-and-selecting-current-kubernete-context-in-the-status-bar.md",sourceDirName:"kubernetes",slug:"/kubernetes/viewing-and-selecting-current-kubernete-context-in-the-status-bar",permalink:"/docs/kubernetes/viewing-and-selecting-current-kubernete-context-in-the-status-bar",draft:!1,editUrl:"https://github.com/containers/podman-desktop/tree/main/website/docs/kubernetes/viewing-and-selecting-current-kubernete-context-in-the-status-bar.md",tags:[{label:"migrating-to-kubernetes",permalink:"/docs/tags/migrating-to-kubernetes"}],version:"current",sidebarPosition:2,frontMatter:{sidebar_position:2,title:"Selecting a context in the status bar",description:"Viewing and selecting the current Kubernetes context in the status bar",keywords:["podman desktop","podman","containers","pods","migrating","kubernetes"],tags:["migrating-to-kubernetes"]},sidebar:"mySidebar",previous:{title:"Kubernetes",permalink:"/docs/kubernetes/"},next:{title:"Selecting a context",permalink:"/docs/kubernetes/viewing-and-selecting-current-kubernete-context"}},c={},u=[{value:"Prerequisites",id:"prerequisites",level:4},{value:"Procedure",id:"procedure",level:4}],l={toc:u};function p(e){let{components:t,...n}=e;return(0,i.kt)("wrapper",(0,r.Z)({},l,n,{components:t,mdxType:"MDXLayout"}),(0,i.kt)("h1",{id:"viewing-and-selecting-the-current-kubernetes-context"},"Viewing and selecting the current Kubernetes context"),(0,i.kt)("p",null,"With Podman Desktop, you can view and select your current Kubernetes context in the status bar."),(0,i.kt)("h4",{id:"prerequisites"},"Prerequisites"),(0,i.kt)("ul",null,(0,i.kt)("li",{parentName:"ul"},"You have a Kubernetes context in your kubeconfig file: ",(0,i.kt)("em",{parentName:"li"},"<","your_kubernetes_cluster",">"),".\nFor example, ",(0,i.kt)("a",{parentName:"li",href:"/docs/kind/creating-a-kind-cluster"},"Creating a kind cluster"),".")),(0,i.kt)("h4",{id:"procedure"},"Procedure"),(0,i.kt)("ol",null,(0,i.kt)("li",{parentName:"ol"},(0,i.kt)("p",{parentName:"li"},"To view your current Kubernetes context, in the ",(0,i.kt)("strong",{parentName:"p"},"Podman Desktop")," main window status bar, see the name next to the ",(0,i.kt)("icon",{icon:"fa-solid fa-server",size:"lg"})," icon.")),(0,i.kt)("li",{parentName:"ol"},(0,i.kt)("p",{parentName:"li"},"(Optionally) To change your Kubernetes context:"),(0,i.kt)("ol",{parentName:"li"},(0,i.kt)("li",{parentName:"ol"},"Click ",(0,i.kt)("icon",{icon:"fa-solid fa-server",size:"lg"}),"."),(0,i.kt)("li",{parentName:"ol"},"In the drop-down menu, click the context name to activate.")))))}p.isMDXComponent=!0}}]); \ No newline at end of file diff --git a/assets/js/ed75cfcb.4a5a7db3.js b/assets/js/ed75cfcb.4a5a7db3.js deleted file mode 100644 index 85008c659cf..00000000000 --- a/assets/js/ed75cfcb.4a5a7db3.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[3584],{35318:(e,t,a)=>{a.d(t,{Zo:()=>l,kt:()=>k});var n=a(27378);function r(e,t,a){return t in e?Object.defineProperty(e,t,{value:a,enumerable:!0,configurable:!0,writable:!0}):e[t]=a,e}function o(e,t){var a=Object.keys(e);if(Object.getOwnPropertySymbols){var n=Object.getOwnPropertySymbols(e);t&&(n=n.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),a.push.apply(a,n)}return a}function i(e){for(var t=1;t=0||(r[a]=e[a]);return r}(e,t);if(Object.getOwnPropertySymbols){var o=Object.getOwnPropertySymbols(e);for(n=0;n=0||Object.prototype.propertyIsEnumerable.call(e,a)&&(r[a]=e[a])}return r}var s=n.createContext({}),c=function(e){var t=n.useContext(s),a=t;return e&&(a="function"==typeof e?e(t):i(i({},t),e)),a},l=function(e){var t=c(e.components);return n.createElement(s.Provider,{value:t},e.children)},p={inlineCode:"code",wrapper:function(e){var t=e.children;return n.createElement(n.Fragment,{},t)}},d=n.forwardRef((function(e,t){var a=e.components,r=e.mdxType,o=e.originalType,s=e.parentName,l=m(e,["components","mdxType","originalType","parentName"]),d=c(a),k=r,u=d["".concat(s,".").concat(k)]||d[k]||p[k]||o;return a?n.createElement(u,i(i({ref:t},l),{},{components:a})):n.createElement(u,i({ref:t},l))}));function k(e,t){var a=arguments,r=t&&t.mdxType;if("string"==typeof e||r){var o=a.length,i=new Array(o);i[0]=d;var m={};for(var s in t)hasOwnProperty.call(t,s)&&(m[s]=t[s]);m.originalType=e,m.mdxType="string"==typeof e?e:r,i[1]=m;for(var c=2;c{a.r(t),a.d(t,{assets:()=>s,contentTitle:()=>i,default:()=>p,frontMatter:()=>o,metadata:()=>m,toc:()=>c});var n=a(25773),r=(a(27378),a(35318));const o={sidebar_position:3,title:"Using `podman-mac-helper` on macOS",description:"Using the `podman-mac-helper` tool can make it easier to migrate from Docker to Podman on macOS, as it allows you to continue using familiar Docker commands while taking advantage of the benefits of Podman.",keywords:["podman desktop","podman","containers","migrating","docker","macos"],tags:["migrating-from-docker","mac0S"]},i="Using the podman-mac-helper tool to migrate from Docker to Podman on macOS",m={unversionedId:"migrating-from-docker/using-podman-mac-helper",id:"migrating-from-docker/using-podman-mac-helper",title:"Using `podman-mac-helper` on macOS",description:"Using the `podman-mac-helper` tool can make it easier to migrate from Docker to Podman on macOS, as it allows you to continue using familiar Docker commands while taking advantage of the benefits of Podman.",source:"@site/docs/migrating-from-docker/using-podman-mac-helper.md",sourceDirName:"migrating-from-docker",slug:"/migrating-from-docker/using-podman-mac-helper",permalink:"/docs/migrating-from-docker/using-podman-mac-helper",draft:!1,editUrl:"https://github.com/containers/podman-desktop/tree/main/website/docs/migrating-from-docker/using-podman-mac-helper.md",tags:[{label:"migrating-from-docker",permalink:"/docs/tags/migrating-from-docker"},{label:"mac0S",permalink:"/docs/tags/mac-0-s"}],version:"current",sidebarPosition:3,frontMatter:{sidebar_position:3,title:"Using `podman-mac-helper` on macOS",description:"Using the `podman-mac-helper` tool can make it easier to migrate from Docker to Podman on macOS, as it allows you to continue using familiar Docker commands while taking advantage of the benefits of Podman.",keywords:["podman desktop","podman","containers","migrating","docker","macos"],tags:["migrating-from-docker","mac0S"]},sidebar:"mySidebar",previous:{title:"Using the `DOCKER_HOST` environment variable",permalink:"/docs/migrating-from-docker/using-the-docker_host-environment-variable"},next:{title:"Emulating Docker CLI with Podman",permalink:"/docs/migrating-from-docker/emulating-docker-cli-with-podman"}},s={},c=[{value:"Prerequisites",id:"prerequisites",level:4},{value:"Procedure",id:"procedure",level:4},{value:"Verification",id:"verification",level:4},{value:"Additional resources",id:"additional-resources",level:4}],l={toc:c};function p(e){let{components:t,...a}=e;return(0,r.kt)("wrapper",(0,n.Z)({},l,a,{components:t,mdxType:"MDXLayout"}),(0,r.kt)("h1",{id:"using-the-podman-mac-helper-tool-to-migrate-from-docker-to-podman-on-macos"},"Using the ",(0,r.kt)("inlineCode",{parentName:"h1"},"podman-mac-helper")," tool to migrate from Docker to Podman on macOS"),(0,r.kt)("p",null,"Consider using ",(0,r.kt)("inlineCode",{parentName:"p"},"podman-mac-help")," to migrate transparently to Podman on macOS."),(0,r.kt)("ul",null,(0,r.kt)("li",{parentName:"ul"},"Continue using familiar Docker commands."),(0,r.kt)("li",{parentName:"ul"},"Take advantage of the benefits of Podman on macOS."),(0,r.kt)("li",{parentName:"ul"},"Your tools, such as ",(0,r.kt)("a",{parentName:"li",href:"https://maven.apache.org/"},"Maven")," or ",(0,r.kt)("a",{parentName:"li",href:"https://www.testcontainers.org/"},"Testcontainers"),", communicate with Podman without reconfiguration.")),(0,r.kt)("p",null,"The ",(0,r.kt)("inlineCode",{parentName:"p"},"podman-mac-helper")," tool provides a compatibility layer that allows you to use most Docker commands with Podman on macOS.\nThe service redirects ",(0,r.kt)("inlineCode",{parentName:"p"},"/var/run/docker")," to the fixed user-assigned UNIX socket location."),(0,r.kt)("h4",{id:"prerequisites"},"Prerequisites"),(0,r.kt)("ul",null,(0,r.kt)("li",{parentName:"ul"},"macOS"),(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("a",{parentName:"li",href:"/docs/installation/macos-install"},"Podman")),(0,r.kt)("li",{parentName:"ul"},"Docker service is ",(0,r.kt)("a",{parentName:"li",href:"https://docs.docker.com/desktop/use-desktop/pause/"},"paused")," and ",(0,r.kt)("a",{parentName:"li",href:"https://docs.docker.com/desktop/settings/mac/"},(0,r.kt)("em",{parentName:"a"},"Start Docker Desktop when you log in")," is disabled"),", or Docker is ",(0,r.kt)("a",{parentName:"li",href:"https://docs.docker.com/desktop/uninstall/"},"uninstalled"),".")),(0,r.kt)("h4",{id:"procedure"},"Procedure"),(0,r.kt)("ol",null,(0,r.kt)("li",{parentName:"ol"},(0,r.kt)("p",{parentName:"li"},"Set up the ",(0,r.kt)("inlineCode",{parentName:"p"},"podman-mac-helper")," service: run the command in a terminal:"),(0,r.kt)("pre",{parentName:"li"},(0,r.kt)("code",{parentName:"pre",className:"language-shell-session"},"sudo podman-mac-helper install\n"))),(0,r.kt)("li",{parentName:"ol"},(0,r.kt)("p",{parentName:"li"},"Restart your Podman machine: go to ",(0,r.kt)("strong",{parentName:"p"},(0,r.kt)("icon",{icon:"fa-solid fa-cog",size:"lg"})," Settings > Resources"),", and in the Podman tile, click ",(0,r.kt)("icon",{icon:"fa-solid fa-repeat",size:"lg"}),"."))),(0,r.kt)("h4",{id:"verification"},"Verification"),(0,r.kt)("ol",null,(0,r.kt)("li",{parentName:"ol"},(0,r.kt)("p",{parentName:"li"},"The Docker socket is a symbolic link for the Podman socket:"),(0,r.kt)("pre",{parentName:"li"},(0,r.kt)("code",{parentName:"pre",className:"language-shell-session"},"$ ls -la /var/run/docker.sock\n")),(0,r.kt)("p",{parentName:"li"},"The output points to a ",(0,r.kt)("inlineCode",{parentName:"p"},"podman.sock")," file such as:"),(0,r.kt)("pre",{parentName:"li"},(0,r.kt)("code",{parentName:"pre",className:"language-shell-session"},"/var/run/docker.sock -> /Users/username/.local/share/containers/podman/machine/podman.sock\n"))),(0,r.kt)("li",{parentName:"ol"},(0,r.kt)("p",{parentName:"li"},"When you query the Docker socket, you receive replies from Podman rather than Docker."),(0,r.kt)("p",{parentName:"li"},"For instance, this command outputs Podman version rather that Docker version:"),(0,r.kt)("pre",{parentName:"li"},(0,r.kt)("code",{parentName:"pre",className:"language-shell-session"},'$ curl -s --unix-socket /var/run/docker.sock "http://v1.41/info" | jq -r .ServerVersion\n'))),(0,r.kt)("li",{parentName:"ol"},(0,r.kt)("p",{parentName:"li"},"Your tools communicating to the Docker socket, such as ",(0,r.kt)("a",{parentName:"p",href:"https://maven.apache.org/"},"Maven")," or ",(0,r.kt)("a",{parentName:"p",href:"https://www.testcontainers.org/"},"Testcontainers"),", communicate with Podman without reconfiguration.")),(0,r.kt)("li",{parentName:"ol"},(0,r.kt)("p",{parentName:"li"},"(Optionally, if the ",(0,r.kt)("inlineCode",{parentName:"p"},"docker")," CLI is installed) The docker CLI context is set to the default value ",(0,r.kt)("inlineCode",{parentName:"p"},"unix:///var/run/docker.sock"),":"),(0,r.kt)("pre",{parentName:"li"},(0,r.kt)("code",{parentName:"pre",className:"language-shell-session"},"$ docker context list\nNAME TYPE DESCRIPTION DOCKER ENDPOINT KUBERNETES ENDPOINT ORCHESTRATOR\ndefault * moby Current DOCKER_HOST based configuration unix:///var/run/docker.sock\n"))),(0,r.kt)("li",{parentName:"ol"},(0,r.kt)("p",{parentName:"li"},"(Optionally, if the ",(0,r.kt)("inlineCode",{parentName:"p"},"docker")," CLI is installed) The ",(0,r.kt)("inlineCode",{parentName:"p"},"docker")," CLI communicates with the Podman socket."),(0,r.kt)("p",{parentName:"li"},"Therefore this command outputs Podman version rather that Docker version:"),(0,r.kt)("pre",{parentName:"li"},(0,r.kt)("code",{parentName:"pre",className:"language-shell-session"},"$ docker info --format=json | jq -r .ServerVersion\n")))),(0,r.kt)("h4",{id:"additional-resources"},"Additional resources"),(0,r.kt)("ul",null,(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("a",{parentName:"li",href:"https://github.com/containers/podman/tree/main/cmd/podman-mac-helper"},(0,r.kt)("inlineCode",{parentName:"a"},"podman-mac-helper")," source"))))}p.isMDXComponent=!0}}]); \ No newline at end of file diff --git a/assets/js/ed75cfcb.b0f7a881.js b/assets/js/ed75cfcb.b0f7a881.js new file mode 100644 index 00000000000..8a2adfb676e --- /dev/null +++ b/assets/js/ed75cfcb.b0f7a881.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[3584],{35318:(e,t,a)=>{a.d(t,{Zo:()=>l,kt:()=>u});var n=a(27378);function o(e,t,a){return t in e?Object.defineProperty(e,t,{value:a,enumerable:!0,configurable:!0,writable:!0}):e[t]=a,e}function r(e,t){var a=Object.keys(e);if(Object.getOwnPropertySymbols){var n=Object.getOwnPropertySymbols(e);t&&(n=n.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),a.push.apply(a,n)}return a}function i(e){for(var t=1;t=0||(o[a]=e[a]);return o}(e,t);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(e);for(n=0;n=0||Object.prototype.propertyIsEnumerable.call(e,a)&&(o[a]=e[a])}return o}var s=n.createContext({}),c=function(e){var t=n.useContext(s),a=t;return e&&(a="function"==typeof e?e(t):i(i({},t),e)),a},l=function(e){var t=c(e.components);return n.createElement(s.Provider,{value:t},e.children)},p={inlineCode:"code",wrapper:function(e){var t=e.children;return n.createElement(n.Fragment,{},t)}},d=n.forwardRef((function(e,t){var a=e.components,o=e.mdxType,r=e.originalType,s=e.parentName,l=m(e,["components","mdxType","originalType","parentName"]),d=c(a),u=o,k=d["".concat(s,".").concat(u)]||d[u]||p[u]||r;return a?n.createElement(k,i(i({ref:t},l),{},{components:a})):n.createElement(k,i({ref:t},l))}));function u(e,t){var a=arguments,o=t&&t.mdxType;if("string"==typeof e||o){var r=a.length,i=new Array(r);i[0]=d;var m={};for(var s in t)hasOwnProperty.call(t,s)&&(m[s]=t[s]);m.originalType=e,m.mdxType="string"==typeof e?e:o,i[1]=m;for(var c=2;c{a.r(t),a.d(t,{assets:()=>s,contentTitle:()=>i,default:()=>u,frontMatter:()=>r,metadata:()=>m,toc:()=>c});var n=a(25773),o=(a(27378),a(35318));const r={sidebar_position:3,title:"Using `podman-mac-helper` on macOS",description:"Using the `podman-mac-helper` tool can make it easier to migrate from Docker to Podman on macOS, as it allows you to continue using familiar Docker commands while taking advantage of the benefits of Podman.",keywords:["podman desktop","podman","containers","migrating","docker","macos"],tags:["migrating-from-docker","mac0S"]},i="Using the podman-mac-helper tool to migrate from Docker to Podman on macOS",m={unversionedId:"migrating-from-docker/using-podman-mac-helper",id:"migrating-from-docker/using-podman-mac-helper",title:"Using `podman-mac-helper` on macOS",description:"Using the `podman-mac-helper` tool can make it easier to migrate from Docker to Podman on macOS, as it allows you to continue using familiar Docker commands while taking advantage of the benefits of Podman.",source:"@site/docs/migrating-from-docker/using-podman-mac-helper.md",sourceDirName:"migrating-from-docker",slug:"/migrating-from-docker/using-podman-mac-helper",permalink:"/docs/migrating-from-docker/using-podman-mac-helper",draft:!1,editUrl:"https://github.com/containers/podman-desktop/tree/main/website/docs/migrating-from-docker/using-podman-mac-helper.md",tags:[{label:"migrating-from-docker",permalink:"/docs/tags/migrating-from-docker"},{label:"mac0S",permalink:"/docs/tags/mac-0-s"}],version:"current",sidebarPosition:3,frontMatter:{sidebar_position:3,title:"Using `podman-mac-helper` on macOS",description:"Using the `podman-mac-helper` tool can make it easier to migrate from Docker to Podman on macOS, as it allows you to continue using familiar Docker commands while taking advantage of the benefits of Podman.",keywords:["podman desktop","podman","containers","migrating","docker","macos"],tags:["migrating-from-docker","mac0S"]},sidebar:"mySidebar",previous:{title:"Using the `DOCKER_HOST` environment variable",permalink:"/docs/migrating-from-docker/using-the-docker_host-environment-variable"},next:{title:"Emulating Docker CLI with Podman",permalink:"/docs/migrating-from-docker/emulating-docker-cli-with-podman"}},s={},c=[{value:"Prerequisites",id:"prerequisites",level:4},{value:"Procedure",id:"procedure",level:4},{value:"Verification",id:"verification",level:4},{value:"Additional resources",id:"additional-resources",level:4}],l=(p="Icon",function(e){return console.warn("Component "+p+" was not imported, exported, or provided by MDXProvider as global scope"),(0,o.kt)("div",e)});var p;const d={toc:c};function u(e){let{components:t,...a}=e;return(0,o.kt)("wrapper",(0,n.Z)({},d,a,{components:t,mdxType:"MDXLayout"}),(0,o.kt)("h1",{id:"using-the-podman-mac-helper-tool-to-migrate-from-docker-to-podman-on-macos"},"Using the ",(0,o.kt)("inlineCode",{parentName:"h1"},"podman-mac-helper")," tool to migrate from Docker to Podman on macOS"),(0,o.kt)("p",null,"Consider using ",(0,o.kt)("inlineCode",{parentName:"p"},"podman-mac-help")," to migrate transparently to Podman on macOS."),(0,o.kt)("ul",null,(0,o.kt)("li",{parentName:"ul"},"Continue using familiar Docker commands."),(0,o.kt)("li",{parentName:"ul"},"Take advantage of the benefits of Podman on macOS."),(0,o.kt)("li",{parentName:"ul"},"Your tools, such as ",(0,o.kt)("a",{parentName:"li",href:"https://maven.apache.org/"},"Maven")," or ",(0,o.kt)("a",{parentName:"li",href:"https://www.testcontainers.org/"},"Testcontainers"),", communicate with Podman without reconfiguration.")),(0,o.kt)("p",null,"The ",(0,o.kt)("inlineCode",{parentName:"p"},"podman-mac-helper")," tool provides a compatibility layer that allows you to use most Docker commands with Podman on macOS.\nThe service redirects ",(0,o.kt)("inlineCode",{parentName:"p"},"/var/run/docker")," to the fixed user-assigned UNIX socket location."),(0,o.kt)("h4",{id:"prerequisites"},"Prerequisites"),(0,o.kt)("ul",null,(0,o.kt)("li",{parentName:"ul"},"macOS"),(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("a",{parentName:"li",href:"/docs/installation/macos-install"},"Podman")),(0,o.kt)("li",{parentName:"ul"},"Docker service is ",(0,o.kt)("a",{parentName:"li",href:"https://docs.docker.com/desktop/use-desktop/pause/"},"paused")," and ",(0,o.kt)("a",{parentName:"li",href:"https://docs.docker.com/desktop/settings/mac/"},(0,o.kt)("em",{parentName:"a"},"Start Docker Desktop when you log in")," is disabled"),", or Docker is ",(0,o.kt)("a",{parentName:"li",href:"https://docs.docker.com/desktop/uninstall/"},"uninstalled"),".")),(0,o.kt)("h4",{id:"procedure"},"Procedure"),(0,o.kt)("ol",null,(0,o.kt)("li",{parentName:"ol"},(0,o.kt)("p",{parentName:"li"},"Set up the ",(0,o.kt)("inlineCode",{parentName:"p"},"podman-mac-helper")," service: run the command in a terminal:"),(0,o.kt)("pre",{parentName:"li"},(0,o.kt)("code",{parentName:"pre",className:"language-shell-session"},"sudo podman-mac-helper install\n"))),(0,o.kt)("li",{parentName:"ol"},(0,o.kt)("p",{parentName:"li"},"Restart your Podman machine: go to ",(0,o.kt)("strong",{parentName:"p"},(0,o.kt)(l,{icon:"fa-solid fa-cog",size:"lg",mdxType:"Icon"})," Settings > Resources"),", and in the Podman tile, click ",(0,o.kt)(l,{icon:"fa-solid fa-repeat",size:"lg",mdxType:"Icon"}),"."))),(0,o.kt)("h4",{id:"verification"},"Verification"),(0,o.kt)("ol",null,(0,o.kt)("li",{parentName:"ol"},(0,o.kt)("p",{parentName:"li"},"The Docker socket is a symbolic link for the Podman socket:"),(0,o.kt)("pre",{parentName:"li"},(0,o.kt)("code",{parentName:"pre",className:"language-shell-session"},"$ ls -la /var/run/docker.sock\n")),(0,o.kt)("p",{parentName:"li"},"The output points to a ",(0,o.kt)("inlineCode",{parentName:"p"},"podman.sock")," file such as:"),(0,o.kt)("pre",{parentName:"li"},(0,o.kt)("code",{parentName:"pre",className:"language-shell-session"},"/var/run/docker.sock -> /Users/username/.local/share/containers/podman/machine/podman.sock\n"))),(0,o.kt)("li",{parentName:"ol"},(0,o.kt)("p",{parentName:"li"},"When you query the Docker socket, you receive replies from Podman rather than Docker."),(0,o.kt)("p",{parentName:"li"},"For instance, this command outputs Podman version rather that Docker version:"),(0,o.kt)("pre",{parentName:"li"},(0,o.kt)("code",{parentName:"pre",className:"language-shell-session"},'$ curl -s --unix-socket /var/run/docker.sock "http://v1.41/info" | jq -r .ServerVersion\n'))),(0,o.kt)("li",{parentName:"ol"},(0,o.kt)("p",{parentName:"li"},"Your tools communicating to the Docker socket, such as ",(0,o.kt)("a",{parentName:"p",href:"https://maven.apache.org/"},"Maven")," or ",(0,o.kt)("a",{parentName:"p",href:"https://www.testcontainers.org/"},"Testcontainers"),", communicate with Podman without reconfiguration.")),(0,o.kt)("li",{parentName:"ol"},(0,o.kt)("p",{parentName:"li"},"(Optionally, if the ",(0,o.kt)("inlineCode",{parentName:"p"},"docker")," CLI is installed) The docker CLI context is set to the default value ",(0,o.kt)("inlineCode",{parentName:"p"},"unix:///var/run/docker.sock"),":"),(0,o.kt)("pre",{parentName:"li"},(0,o.kt)("code",{parentName:"pre",className:"language-shell-session"},"$ docker context list\nNAME TYPE DESCRIPTION DOCKER ENDPOINT KUBERNETES ENDPOINT ORCHESTRATOR\ndefault * moby Current DOCKER_HOST based configuration unix:///var/run/docker.sock\n"))),(0,o.kt)("li",{parentName:"ol"},(0,o.kt)("p",{parentName:"li"},"(Optionally, if the ",(0,o.kt)("inlineCode",{parentName:"p"},"docker")," CLI is installed) The ",(0,o.kt)("inlineCode",{parentName:"p"},"docker")," CLI communicates with the Podman socket."),(0,o.kt)("p",{parentName:"li"},"Therefore this command outputs Podman version rather that Docker version:"),(0,o.kt)("pre",{parentName:"li"},(0,o.kt)("code",{parentName:"pre",className:"language-shell-session"},"$ docker info --format=json | jq -r .ServerVersion\n")))),(0,o.kt)("h4",{id:"additional-resources"},"Additional resources"),(0,o.kt)("ul",null,(0,o.kt)("li",{parentName:"ul"},(0,o.kt)("a",{parentName:"li",href:"https://github.com/containers/podman/tree/main/cmd/podman-mac-helper"},(0,o.kt)("inlineCode",{parentName:"a"},"podman-mac-helper")," source"))))}u.isMDXComponent=!0}}]); \ No newline at end of file diff --git a/assets/js/f425c855.23009f9f.js b/assets/js/f425c855.23009f9f.js new file mode 100644 index 00000000000..456b3515091 --- /dev/null +++ b/assets/js/f425c855.23009f9f.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[2783],{35318:(e,t,r)=>{r.d(t,{Zo:()=>p,kt:()=>d});var i=r(27378);function n(e,t,r){return t in e?Object.defineProperty(e,t,{value:r,enumerable:!0,configurable:!0,writable:!0}):e[t]=r,e}function o(e,t){var r=Object.keys(e);if(Object.getOwnPropertySymbols){var i=Object.getOwnPropertySymbols(e);t&&(i=i.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),r.push.apply(r,i)}return r}function a(e){for(var t=1;t=0||(n[r]=e[r]);return n}(e,t);if(Object.getOwnPropertySymbols){var o=Object.getOwnPropertySymbols(e);for(i=0;i=0||Object.prototype.propertyIsEnumerable.call(e,r)&&(n[r]=e[r])}return n}var c=i.createContext({}),l=function(e){var t=i.useContext(c),r=t;return e&&(r="function"==typeof e?e(t):a(a({},t),e)),r},p=function(e){var t=l(e.components);return i.createElement(c.Provider,{value:t},e.children)},u={inlineCode:"code",wrapper:function(e){var t=e.children;return i.createElement(i.Fragment,{},t)}},g=i.forwardRef((function(e,t){var r=e.components,n=e.mdxType,o=e.originalType,c=e.parentName,p=s(e,["components","mdxType","originalType","parentName"]),g=l(r),d=n,m=g["".concat(c,".").concat(d)]||g[d]||u[d]||o;return r?i.createElement(m,a(a({ref:t},p),{},{components:r})):i.createElement(m,a({ref:t},p))}));function d(e,t){var r=arguments,n=t&&t.mdxType;if("string"==typeof e||n){var o=r.length,a=new Array(o);a[0]=g;var s={};for(var c in t)hasOwnProperty.call(t,c)&&(s[c]=t[c]);s.originalType=e,s.mdxType="string"==typeof e?e:n,a[1]=s;for(var l=2;l{r.d(t,{ZP:()=>c});var i=r(25773),n=(r(27378),r(35318));const o=(a="Icon",function(e){return console.warn("Component "+a+" was not imported, exported, or provided by MDXProvider as global scope"),(0,n.kt)("div",e)});var a;const s={toc:[{value:"Verification",id:"verification",level:4}]};function c(e){let{components:t,...r}=e;return(0,n.kt)("wrapper",(0,i.Z)({},s,r,{components:t,mdxType:"MDXLayout"}),(0,n.kt)("h4",{id:"verification"},"Verification"),(0,n.kt)("ol",null,(0,n.kt)("li",{parentName:"ol"},"Go to ",(0,n.kt)("strong",{parentName:"li"},(0,n.kt)(o,{icon:"fa-solid fa-cloud",size:"lg",mdxType:"Icon"})," Images"),"."),(0,n.kt)("li",{parentName:"ol"},"You can pull a private image from the registry."),(0,n.kt)("li",{parentName:"ol"},"You can push an image to the registry:",(0,n.kt)("ol",{parentName:"li"},(0,n.kt)("li",{parentName:"ol"},"Build an image with the fully qualified name required for your registry, such as ",(0,n.kt)("inlineCode",{parentName:"li"},"quay.io/my-repository/my-image"),", ",(0,n.kt)("inlineCode",{parentName:"li"},"ghcr.io/my-repository/my-image"),", ",(0,n.kt)("inlineCode",{parentName:"li"},"docker.io/my-repository/my-image"),", or ",(0,n.kt)("inlineCode",{parentName:"li"},"my-registry.tld/my-repository/my-image"),"."),(0,n.kt)("li",{parentName:"ol"},"On your image line, click ",(0,n.kt)("strong",{parentName:"li"},(0,n.kt)(o,{icon:"fa-solid fa-ellipsis-v",size:"lg",mdxType:"Icon"})),"."),(0,n.kt)("li",{parentName:"ol"},"The contextual menu has a ",(0,n.kt)("strong",{parentName:"li"},(0,n.kt)(o,{icon:"fa-solid fa-arrow-up",size:"lg",mdxType:"Icon"}),"Push Image")," entry.")))))}c.isMDXComponent=!0},89844:(e,t,r)=>{r.r(t),r.d(t,{assets:()=>l,contentTitle:()=>s,default:()=>m,frontMatter:()=>a,metadata:()=>c,toc:()=>p});var i=r(25773),n=(r(27378),r(35318)),o=r(2696);const a={sidebar_position:10,title:"Authenticating to a registry",description:"Authenticating to a pre-configured registry.",keywords:["podman desktop","podman","containers","registry","registries"],tags:["images"]},s="Authenticating to a pre-configured registry",c={unversionedId:"containers/registries/authenticating-to-a-preconfigured-registry",id:"containers/registries/authenticating-to-a-preconfigured-registry",title:"Authenticating to a registry",description:"Authenticating to a pre-configured registry.",source:"@site/docs/containers/registries/authenticating-to-a-preconfigured-registry.md",sourceDirName:"containers/registries",slug:"/containers/registries/authenticating-to-a-preconfigured-registry",permalink:"/docs/containers/registries/authenticating-to-a-preconfigured-registry",draft:!1,editUrl:"https://github.com/containers/podman-desktop/tree/main/website/docs/containers/registries/authenticating-to-a-preconfigured-registry.md",tags:[{label:"images",permalink:"/docs/tags/images"}],version:"current",sidebarPosition:10,frontMatter:{sidebar_position:10,title:"Authenticating to a registry",description:"Authenticating to a pre-configured registry.",keywords:["podman desktop","podman","containers","registry","registries"],tags:["images"]},sidebar:"mySidebar",previous:{title:"Registries",permalink:"/docs/containers/registries/"},next:{title:"Adding an insecure registry",permalink:"/docs/containers/registries/insecure-registry"}},l={},p=[{value:"Prerequisites",id:"prerequisites",level:4},{value:"Procedure",id:"procedure",level:4}],u=(g="Icon",function(e){return console.warn("Component "+g+" was not imported, exported, or provided by MDXProvider as global scope"),(0,n.kt)("div",e)});var g;const d={toc:p};function m(e){let{components:t,...a}=e;return(0,n.kt)("wrapper",(0,i.Z)({},d,a,{components:t,mdxType:"MDXLayout"}),(0,n.kt)("h1",{id:"authenticating-to-a-pre-configured-registry"},"Authenticating to a pre-configured registry"),(0,n.kt)("p",null,"With Podman Desktop, you can authenticate to a set of pre-configured registries:"),(0,n.kt)("ul",null,(0,n.kt)("li",{parentName:"ul"},"Red Hat Quay"),(0,n.kt)("li",{parentName:"ul"},"Docker Hub"),(0,n.kt)("li",{parentName:"ul"},"GitHub"),(0,n.kt)("li",{parentName:"ul"},"Google Container registry")),(0,n.kt)("h4",{id:"prerequisites"},"Prerequisites"),(0,n.kt)("ul",null,(0,n.kt)("li",{parentName:"ul"},"You have credentials on a pre-configured image registry.")),(0,n.kt)("h4",{id:"procedure"},"Procedure"),(0,n.kt)("ol",null,(0,n.kt)("li",{parentName:"ol"},(0,n.kt)("p",{parentName:"li"},"Go to ",(0,n.kt)("strong",{parentName:"p"},(0,n.kt)(u,{icon:"fa-solid fa-cog",size:"lg",mdxType:"Icon"})," Settings > Registries"),".")),(0,n.kt)("li",{parentName:"ol"},(0,n.kt)("p",{parentName:"li"},"On your registry line, click ",(0,n.kt)("strong",{parentName:"p"},"Configure"),"."),(0,n.kt)("ol",{parentName:"li"},(0,n.kt)("li",{parentName:"ol"},(0,n.kt)("strong",{parentName:"li"},"User name"),": Enter your user name."),(0,n.kt)("li",{parentName:"ol"},(0,n.kt)("strong",{parentName:"li"},"Password"),": Enter your password or OAuth secret."),(0,n.kt)("li",{parentName:"ol"},"Click ",(0,n.kt)("strong",{parentName:"li"},"Login"),".")),(0,n.kt)("p",{parentName:"li"},(0,n.kt)("img",{alt:"Authenticating to a preconfigured registry",src:r(44633).Z,width:"933",height:"431"})))),(0,n.kt)(o.ZP,{mdxType:"Verification"}))}m.isMDXComponent=!0},44633:(e,t,r)=>{r.d(t,{Z:()=>i});const i=r.p+"assets/images/authenticating-to-a-preconfigured-registry-12cf722d1b380d17ae90e8129d31a981.png"}}]); \ No newline at end of file diff --git a/assets/js/f425c855.f323ad1d.js b/assets/js/f425c855.f323ad1d.js deleted file mode 100644 index 86ebb9c3783..00000000000 --- a/assets/js/f425c855.f323ad1d.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[2783],{35318:(e,t,r)=>{r.d(t,{Zo:()=>p,kt:()=>m});var i=r(27378);function n(e,t,r){return t in e?Object.defineProperty(e,t,{value:r,enumerable:!0,configurable:!0,writable:!0}):e[t]=r,e}function a(e,t){var r=Object.keys(e);if(Object.getOwnPropertySymbols){var i=Object.getOwnPropertySymbols(e);t&&(i=i.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),r.push.apply(r,i)}return r}function o(e){for(var t=1;t=0||(n[r]=e[r]);return n}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(i=0;i=0||Object.prototype.propertyIsEnumerable.call(e,r)&&(n[r]=e[r])}return n}var c=i.createContext({}),l=function(e){var t=i.useContext(c),r=t;return e&&(r="function"==typeof e?e(t):o(o({},t),e)),r},p=function(e){var t=l(e.components);return i.createElement(c.Provider,{value:t},e.children)},u={inlineCode:"code",wrapper:function(e){var t=e.children;return i.createElement(i.Fragment,{},t)}},g=i.forwardRef((function(e,t){var r=e.components,n=e.mdxType,a=e.originalType,c=e.parentName,p=s(e,["components","mdxType","originalType","parentName"]),g=l(r),m=n,d=g["".concat(c,".").concat(m)]||g[m]||u[m]||a;return r?i.createElement(d,o(o({ref:t},p),{},{components:r})):i.createElement(d,o({ref:t},p))}));function m(e,t){var r=arguments,n=t&&t.mdxType;if("string"==typeof e||n){var a=r.length,o=new Array(a);o[0]=g;var s={};for(var c in t)hasOwnProperty.call(t,c)&&(s[c]=t[c]);s.originalType=e,s.mdxType="string"==typeof e?e:n,o[1]=s;for(var l=2;l{r.d(t,{ZP:()=>o});var i=r(25773),n=(r(27378),r(35318));const a={toc:[{value:"Verification",id:"verification",level:4}]};function o(e){let{components:t,...r}=e;return(0,n.kt)("wrapper",(0,i.Z)({},a,r,{components:t,mdxType:"MDXLayout"}),(0,n.kt)("h4",{id:"verification"},"Verification"),(0,n.kt)("ol",null,(0,n.kt)("li",{parentName:"ol"},"Go to ",(0,n.kt)("strong",{parentName:"li"},(0,n.kt)("icon",{icon:"fa-solid fa-cloud",size:"lg"})," Images"),"."),(0,n.kt)("li",{parentName:"ol"},"You can pull a private image from the registry."),(0,n.kt)("li",{parentName:"ol"},"You can push an image to the registry:",(0,n.kt)("ol",{parentName:"li"},(0,n.kt)("li",{parentName:"ol"},"Build an image with the fully qualified name required for your registry, such as ",(0,n.kt)("inlineCode",{parentName:"li"},"quay.io/my-repository/my-image"),", ",(0,n.kt)("inlineCode",{parentName:"li"},"ghcr.io/my-repository/my-image"),", ",(0,n.kt)("inlineCode",{parentName:"li"},"docker.io/my-repository/my-image"),", or ",(0,n.kt)("inlineCode",{parentName:"li"},"my-registry.tld/my-repository/my-image"),"."),(0,n.kt)("li",{parentName:"ol"},"On your image line, click ",(0,n.kt)("strong",{parentName:"li"},(0,n.kt)("icon",{icon:"fa-solid fa-ellipsis-v",size:"lg"})),"."),(0,n.kt)("li",{parentName:"ol"},"The contextual menu has a ",(0,n.kt)("strong",{parentName:"li"},(0,n.kt)("icon",{icon:"fa-solid fa-arrow-up",size:"lg"}),"Push Image")," entry.")))))}o.isMDXComponent=!0},89844:(e,t,r)=>{r.r(t),r.d(t,{assets:()=>l,contentTitle:()=>s,default:()=>g,frontMatter:()=>o,metadata:()=>c,toc:()=>p});var i=r(25773),n=(r(27378),r(35318)),a=r(2696);const o={sidebar_position:10,title:"Authenticating to a registry",description:"Authenticating to a pre-configured registry.",keywords:["podman desktop","podman","containers","registry","registries"],tags:["images"]},s="Authenticating to a pre-configured registry",c={unversionedId:"containers/registries/authenticating-to-a-preconfigured-registry",id:"containers/registries/authenticating-to-a-preconfigured-registry",title:"Authenticating to a registry",description:"Authenticating to a pre-configured registry.",source:"@site/docs/containers/registries/authenticating-to-a-preconfigured-registry.md",sourceDirName:"containers/registries",slug:"/containers/registries/authenticating-to-a-preconfigured-registry",permalink:"/docs/containers/registries/authenticating-to-a-preconfigured-registry",draft:!1,editUrl:"https://github.com/containers/podman-desktop/tree/main/website/docs/containers/registries/authenticating-to-a-preconfigured-registry.md",tags:[{label:"images",permalink:"/docs/tags/images"}],version:"current",sidebarPosition:10,frontMatter:{sidebar_position:10,title:"Authenticating to a registry",description:"Authenticating to a pre-configured registry.",keywords:["podman desktop","podman","containers","registry","registries"],tags:["images"]},sidebar:"mySidebar",previous:{title:"Registries",permalink:"/docs/containers/registries/"},next:{title:"Adding an insecure registry",permalink:"/docs/containers/registries/insecure-registry"}},l={},p=[{value:"Prerequisites",id:"prerequisites",level:4},{value:"Procedure",id:"procedure",level:4}],u={toc:p};function g(e){let{components:t,...o}=e;return(0,n.kt)("wrapper",(0,i.Z)({},u,o,{components:t,mdxType:"MDXLayout"}),(0,n.kt)("h1",{id:"authenticating-to-a-pre-configured-registry"},"Authenticating to a pre-configured registry"),(0,n.kt)("p",null,"With Podman Desktop, you can authenticate to a set of pre-configured registries:"),(0,n.kt)("ul",null,(0,n.kt)("li",{parentName:"ul"},"Red Hat Quay"),(0,n.kt)("li",{parentName:"ul"},"Docker Hub"),(0,n.kt)("li",{parentName:"ul"},"GitHub"),(0,n.kt)("li",{parentName:"ul"},"Google Container registry")),(0,n.kt)("h4",{id:"prerequisites"},"Prerequisites"),(0,n.kt)("ul",null,(0,n.kt)("li",{parentName:"ul"},"You have credentials on a pre-configured image registry.")),(0,n.kt)("h4",{id:"procedure"},"Procedure"),(0,n.kt)("ol",null,(0,n.kt)("li",{parentName:"ol"},(0,n.kt)("p",{parentName:"li"},"Go to ",(0,n.kt)("strong",{parentName:"p"},(0,n.kt)("icon",{icon:"fa-solid fa-cog",size:"lg"})," Settings > Registries"),".")),(0,n.kt)("li",{parentName:"ol"},(0,n.kt)("p",{parentName:"li"},"On your registry line, click ",(0,n.kt)("strong",{parentName:"p"},"Configure"),"."),(0,n.kt)("ol",{parentName:"li"},(0,n.kt)("li",{parentName:"ol"},(0,n.kt)("strong",{parentName:"li"},"User name"),": Enter your user name."),(0,n.kt)("li",{parentName:"ol"},(0,n.kt)("strong",{parentName:"li"},"Password"),": Enter your password or OAuth secret."),(0,n.kt)("li",{parentName:"ol"},"Click ",(0,n.kt)("strong",{parentName:"li"},"Login"),".")),(0,n.kt)("p",{parentName:"li"},(0,n.kt)("img",{alt:"Authenticating to a preconfigured registry",src:r(44633).Z,width:"933",height:"431"})))),(0,n.kt)(a.ZP,{mdxType:"Verification"}))}g.isMDXComponent=!0},44633:(e,t,r)=>{r.d(t,{Z:()=>i});const i=r.p+"assets/images/authenticating-to-a-preconfigured-registry-12cf722d1b380d17ae90e8129d31a981.png"}}]); \ No newline at end of file diff --git a/assets/js/fb50ea3a.17de80bc.js b/assets/js/fb50ea3a.17de80bc.js deleted file mode 100644 index 87f6bccb25b..00000000000 --- a/assets/js/fb50ea3a.17de80bc.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[2451],{35318:(e,t,n)=>{n.d(t,{Zo:()=>c,kt:()=>u});var i=n(27378);function a(e,t,n){return t in e?Object.defineProperty(e,t,{value:n,enumerable:!0,configurable:!0,writable:!0}):e[t]=n,e}function r(e,t){var n=Object.keys(e);if(Object.getOwnPropertySymbols){var i=Object.getOwnPropertySymbols(e);t&&(i=i.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),n.push.apply(n,i)}return n}function o(e){for(var t=1;t=0||(a[n]=e[n]);return a}(e,t);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(e);for(i=0;i=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(a[n]=e[n])}return a}var s=i.createContext({}),p=function(e){var t=i.useContext(s),n=t;return e&&(n="function"==typeof e?e(t):o(o({},t),e)),n},c=function(e){var t=p(e.components);return i.createElement(s.Provider,{value:t},e.children)},d={inlineCode:"code",wrapper:function(e){var t=e.children;return i.createElement(i.Fragment,{},t)}},m=i.forwardRef((function(e,t){var n=e.components,a=e.mdxType,r=e.originalType,s=e.parentName,c=l(e,["components","mdxType","originalType","parentName"]),m=p(n),u=a,g=m["".concat(s,".").concat(u)]||m[u]||d[u]||r;return n?i.createElement(g,o(o({ref:t},c),{},{components:n})):i.createElement(g,o({ref:t},c))}));function u(e,t){var n=arguments,a=t&&t.mdxType;if("string"==typeof e||a){var r=n.length,o=new Array(r);o[0]=m;var l={};for(var s in t)hasOwnProperty.call(t,s)&&(l[s]=t[s]);l.originalType=e,l.mdxType="string"==typeof e?e:a,o[1]=l;for(var p=2;p{n.r(t),n.d(t,{assets:()=>s,contentTitle:()=>o,default:()=>d,frontMatter:()=>r,metadata:()=>l,toc:()=>p});var i=n(25773),a=(n(27378),n(35318));const r={sidebar_position:10,title:"Building and testing an image",description:"Building an image and testing it in Kind",keywords:["podman desktop","podman","containers","pods","migrating","kubernetes","kind"],tags:["migrating-to-kubernetes"]},o="Building an image and testing it in Kind",l={unversionedId:"kind/building-an-image-and-testing-it-in-kind",id:"kind/building-an-image-and-testing-it-in-kind",title:"Building and testing an image",description:"Building an image and testing it in Kind",source:"@site/docs/kind/building-an-image-and-testing-it-in-kind.md",sourceDirName:"kind",slug:"/kind/building-an-image-and-testing-it-in-kind",permalink:"/docs/kind/building-an-image-and-testing-it-in-kind",draft:!1,editUrl:"https://github.com/containers/podman-desktop/tree/main/website/docs/kind/building-an-image-and-testing-it-in-kind.md",tags:[{label:"migrating-to-kubernetes",permalink:"/docs/tags/migrating-to-kubernetes"}],version:"current",sidebarPosition:10,frontMatter:{sidebar_position:10,title:"Building and testing an image",description:"Building an image and testing it in Kind",keywords:["podman desktop","podman","containers","pods","migrating","kubernetes","kind"],tags:["migrating-to-kubernetes"]},sidebar:"mySidebar",previous:{title:"Deleting your Kind cluster",permalink:"/docs/kind/deleting-your-kind-cluster"},next:{title:"Push an image to Kind",permalink:"/docs/kind/pushing-an-image-to-kind"}},s={},p=[{value:"Prerequisites",id:"prerequisites",level:4},{value:"Procedure",id:"procedure",level:4},{value:"Verification",id:"verification",level:4}],c={toc:p};function d(e){let{components:t,...n}=e;return(0,a.kt)("wrapper",(0,i.Z)({},c,n,{components:t,mdxType:"MDXLayout"}),(0,a.kt)("h1",{id:"building-an-image-and-testing-it-in-kind"},"Building an image and testing it in Kind"),(0,a.kt)("p",null,"With Podman Desktop, you can build an image with your container engine, and test it in your local Kind-powered Kubernetes cluster."),(0,a.kt)("h4",{id:"prerequisites"},"Prerequisites"),(0,a.kt)("ul",null,(0,a.kt)("li",{parentName:"ul"},(0,a.kt)("a",{parentName:"li",href:"/docs/containers"},"You onboarded a container engine"),"."),(0,a.kt)("li",{parentName:"ul"},(0,a.kt)("a",{parentName:"li",href:"/docs/kind"},"You onboarded a Kind cluster"),"."),(0,a.kt)("li",{parentName:"ul"},(0,a.kt)("a",{parentName:"li",href:"/docs/kind/working-with-your-local-kind-cluster"},"You have set your Kubernetes context to your local Kind-powered Kubernetes cluster"),"."),(0,a.kt)("li",{parentName:"ul"},"A container definition file: ",(0,a.kt)("inlineCode",{parentName:"li"},"Containerfile")," or ",(0,a.kt)("inlineCode",{parentName:"li"},"Dockerfile"),".")),(0,a.kt)("h4",{id:"procedure"},"Procedure"),(0,a.kt)("ol",null,(0,a.kt)("li",{parentName:"ol"},(0,a.kt)("p",{parentName:"li"},"Build your image:"),(0,a.kt)("ol",{parentName:"li"},(0,a.kt)("li",{parentName:"ol"},"Open ",(0,a.kt)("strong",{parentName:"li"},(0,a.kt)("icon",{icon:"fa-solid fa-cloud",size:"lg"})," Images > ",(0,a.kt)("icon",{icon:"fa-solid fa-cube",size:"lg"})," Build an image"),"."),(0,a.kt)("li",{parentName:"ol"},(0,a.kt)("strong",{parentName:"li"},"Containerfile path"),": select your ",(0,a.kt)("inlineCode",{parentName:"li"},"Containerfile")," or ",(0,a.kt)("inlineCode",{parentName:"li"},"Dockerfile"),"."),(0,a.kt)("li",{parentName:"ol"},(0,a.kt)("strong",{parentName:"li"},"Build context directory"),": optionally, select a directory different from the directory containing your ",(0,a.kt)("inlineCode",{parentName:"li"},"Containerfile")," or ",(0,a.kt)("inlineCode",{parentName:"li"},"Dockerfile"),"."),(0,a.kt)("li",{parentName:"ol"},(0,a.kt)("strong",{parentName:"li"},"Image Name"),": enter your image name ",(0,a.kt)("inlineCode",{parentName:"li"},"my-custom-image"),"."),(0,a.kt)("li",{parentName:"ol"},"Click ",(0,a.kt)("strong",{parentName:"li"},(0,a.kt)("icon",{icon:"fa-solid fa-cube",size:"lg"})," Build"),"."),(0,a.kt)("li",{parentName:"ol"},"Wait for the image build to finish."),(0,a.kt)("li",{parentName:"ol"},"Click ",(0,a.kt)("strong",{parentName:"li"},"Done")," to get back to the images list."))),(0,a.kt)("li",{parentName:"ol"},(0,a.kt)("p",{parentName:"li"},"Push your image to your Kind cluster:"),(0,a.kt)("ol",{parentName:"li"},(0,a.kt)("li",{parentName:"ol"},(0,a.kt)("strong",{parentName:"li"},(0,a.kt)("icon",{icon:"fa-solid fa-cloud",size:"lg"})," Search images"),": enter your image name ",(0,a.kt)("inlineCode",{parentName:"li"},"my-custom-image")," to find the image."),(0,a.kt)("li",{parentName:"ol"},"Click ",(0,a.kt)("strong",{parentName:"li"},(0,a.kt)("icon",{icon:"fa-solid fa-ellipsis-v",size:"lg"})," > ",(0,a.kt)("icon",{icon:"fa-solid fa-ellipsis-v",size:"lg"})," Push image to Kind cluster"),"."))),(0,a.kt)("li",{parentName:"ol"},(0,a.kt)("p",{parentName:"li"},"Test your image by creating a container:"),(0,a.kt)("ol",{parentName:"li"},(0,a.kt)("li",{parentName:"ol"},"Click ",(0,a.kt)("strong",{parentName:"li"},(0,a.kt)("icon",{icon:"fa-solid fa-play",size:"lg"}))," to open the ",(0,a.kt)("strong",{parentName:"li"},"Create a container from image")," dialog."),(0,a.kt)("li",{parentName:"ol"},(0,a.kt)("strong",{parentName:"li"},"Container name"),": enter ",(0,a.kt)("inlineCode",{parentName:"li"},"my-custom-image-container"),"."),(0,a.kt)("li",{parentName:"ol"},"Review the parameters that Podman Desktop has detected from your image definition."),(0,a.kt)("li",{parentName:"ol"},"Click ",(0,a.kt)("strong",{parentName:"li"},(0,a.kt)("icon",{icon:"fa-solid fa-play",size:"lg"})," Start Container")," to start the container in your container engine."))),(0,a.kt)("li",{parentName:"ol"},(0,a.kt)("p",{parentName:"li"},"Test your image and container on your Kind cluster:"),(0,a.kt)("ol",{parentName:"li"},(0,a.kt)("li",{parentName:"ol"},(0,a.kt)("strong",{parentName:"li"},(0,a.kt)("icon",{icon:"fa-solid fa-cloud",size:"lg"})," Search containers"),": enter ",(0,a.kt)("inlineCode",{parentName:"li"},"my-custom-image-container")," to find the running container."),(0,a.kt)("li",{parentName:"ol"},"Click ",(0,a.kt)("strong",{parentName:"li"},(0,a.kt)("icon",{icon:"fa-solid fa-ellipsis-v",size:"lg"})," > ",(0,a.kt)("icon",{icon:"fa-solid fa-rocket",size:"lg"})," Deploy to Kubernetes")," to open the ",(0,a.kt)("strong",{parentName:"li"},"Deploy generated pod to Kubernetes")," screen."),(0,a.kt)("li",{parentName:"ol"},(0,a.kt)("strong",{parentName:"li"},"Pod Name"),": keep the proposed value ",(0,a.kt)("inlineCode",{parentName:"li"},"my-custom-image-container-pod"),"."),(0,a.kt)("li",{parentName:"ol"},(0,a.kt)("strong",{parentName:"li"},"Use Kubernetes Services"),": select ",(0,a.kt)("strong",{parentName:"li"},"Replace ",(0,a.kt)("inlineCode",{parentName:"strong"},"hostPort")," exposure on containers by Services. It is the recommended way to expose ports, as a cluster policy might prevent to use ",(0,a.kt)("inlineCode",{parentName:"strong"},"hostPort"),".")),(0,a.kt)("li",{parentName:"ol"},(0,a.kt)("strong",{parentName:"li"},"Expose service locally using Kubernetes Ingress"),": if your container is exposing at a port, select ",(0,a.kt)("strong",{parentName:"li"},"Create a Kubernetes ingress to get access to the ports that this pod exposes, at the default ingress controller location. Example: on a default Kind cluster created with Podman Desktop: ",(0,a.kt)("inlineCode",{parentName:"strong"},"http://localhost:9090"),". Requirements: your cluster has an ingress controller`"),"."),(0,a.kt)("li",{parentName:"ol"},"Optionally, if your container is exposing more than one port, select the port to expose."),(0,a.kt)("li",{parentName:"ol"},(0,a.kt)("strong",{parentName:"li"},"Kubernetes namespaces"),": select ",(0,a.kt)("inlineCode",{parentName:"li"},"default"),"."),(0,a.kt)("li",{parentName:"ol"},"Click ",(0,a.kt)("strong",{parentName:"li"},(0,a.kt)("icon",{icon:"fa-solid fa-rocket",size:"lg"})," Deploy"),"."),(0,a.kt)("li",{parentName:"ol"},"Wait for the pod to reach the state: ",(0,a.kt)("strong",{parentName:"li"},"Phase: Running"),"."),(0,a.kt)("li",{parentName:"ol"},"Click ",(0,a.kt)("strong",{parentName:"li"},"Done"),".")))),(0,a.kt)("h4",{id:"verification"},"Verification"),(0,a.kt)("ol",null,(0,a.kt)("li",{parentName:"ol"},"The ",(0,a.kt)("strong",{parentName:"li"},(0,a.kt)("icon",{icon:"fa-solid fa-cubes",size:"lg"})," Pods")," screen lists the running ",(0,a.kt)("inlineCode",{parentName:"li"},"my-image-container-pod")," pod."),(0,a.kt)("li",{parentName:"ol"},"Click on the pod name to view details and logs."),(0,a.kt)("li",{parentName:"ol"},"Optionally, if your container is exposing a port, go to ",(0,a.kt)("inlineCode",{parentName:"li"},"http://localhost:9090"),": your application is running.")))}d.isMDXComponent=!0}}]); \ No newline at end of file diff --git a/assets/js/fb50ea3a.9166135e.js b/assets/js/fb50ea3a.9166135e.js new file mode 100644 index 00000000000..d6e1b3f5c92 --- /dev/null +++ b/assets/js/fb50ea3a.9166135e.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[2451],{35318:(e,t,n)=>{n.d(t,{Zo:()=>d,kt:()=>u});var i=n(27378);function a(e,t,n){return t in e?Object.defineProperty(e,t,{value:n,enumerable:!0,configurable:!0,writable:!0}):e[t]=n,e}function r(e,t){var n=Object.keys(e);if(Object.getOwnPropertySymbols){var i=Object.getOwnPropertySymbols(e);t&&(i=i.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),n.push.apply(n,i)}return n}function o(e){for(var t=1;t=0||(a[n]=e[n]);return a}(e,t);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(e);for(i=0;i=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(a[n]=e[n])}return a}var s=i.createContext({}),p=function(e){var t=i.useContext(s),n=t;return e&&(n="function"==typeof e?e(t):o(o({},t),e)),n},d=function(e){var t=p(e.components);return i.createElement(s.Provider,{value:t},e.children)},m={inlineCode:"code",wrapper:function(e){var t=e.children;return i.createElement(i.Fragment,{},t)}},c=i.forwardRef((function(e,t){var n=e.components,a=e.mdxType,r=e.originalType,s=e.parentName,d=l(e,["components","mdxType","originalType","parentName"]),c=p(n),u=a,g=c["".concat(s,".").concat(u)]||c[u]||m[u]||r;return n?i.createElement(g,o(o({ref:t},d),{},{components:n})):i.createElement(g,o({ref:t},d))}));function u(e,t){var n=arguments,a=t&&t.mdxType;if("string"==typeof e||a){var r=n.length,o=new Array(r);o[0]=c;var l={};for(var s in t)hasOwnProperty.call(t,s)&&(l[s]=t[s]);l.originalType=e,l.mdxType="string"==typeof e?e:a,o[1]=l;for(var p=2;p{n.r(t),n.d(t,{assets:()=>s,contentTitle:()=>o,default:()=>u,frontMatter:()=>r,metadata:()=>l,toc:()=>p});var i=n(25773),a=(n(27378),n(35318));const r={sidebar_position:10,title:"Building and testing an image",description:"Building an image and testing it in Kind",keywords:["podman desktop","podman","containers","pods","migrating","kubernetes","kind"],tags:["migrating-to-kubernetes"]},o="Building an image and testing it in Kind",l={unversionedId:"kind/building-an-image-and-testing-it-in-kind",id:"kind/building-an-image-and-testing-it-in-kind",title:"Building and testing an image",description:"Building an image and testing it in Kind",source:"@site/docs/kind/building-an-image-and-testing-it-in-kind.md",sourceDirName:"kind",slug:"/kind/building-an-image-and-testing-it-in-kind",permalink:"/docs/kind/building-an-image-and-testing-it-in-kind",draft:!1,editUrl:"https://github.com/containers/podman-desktop/tree/main/website/docs/kind/building-an-image-and-testing-it-in-kind.md",tags:[{label:"migrating-to-kubernetes",permalink:"/docs/tags/migrating-to-kubernetes"}],version:"current",sidebarPosition:10,frontMatter:{sidebar_position:10,title:"Building and testing an image",description:"Building an image and testing it in Kind",keywords:["podman desktop","podman","containers","pods","migrating","kubernetes","kind"],tags:["migrating-to-kubernetes"]},sidebar:"mySidebar",previous:{title:"Deleting your Kind cluster",permalink:"/docs/kind/deleting-your-kind-cluster"},next:{title:"Push an image to Kind",permalink:"/docs/kind/pushing-an-image-to-kind"}},s={},p=[{value:"Prerequisites",id:"prerequisites",level:4},{value:"Procedure",id:"procedure",level:4},{value:"Verification",id:"verification",level:4}],d=(m="Icon",function(e){return console.warn("Component "+m+" was not imported, exported, or provided by MDXProvider as global scope"),(0,a.kt)("div",e)});var m;const c={toc:p};function u(e){let{components:t,...n}=e;return(0,a.kt)("wrapper",(0,i.Z)({},c,n,{components:t,mdxType:"MDXLayout"}),(0,a.kt)("h1",{id:"building-an-image-and-testing-it-in-kind"},"Building an image and testing it in Kind"),(0,a.kt)("p",null,"With Podman Desktop, you can build an image with your container engine, and test it in your local Kind-powered Kubernetes cluster."),(0,a.kt)("h4",{id:"prerequisites"},"Prerequisites"),(0,a.kt)("ul",null,(0,a.kt)("li",{parentName:"ul"},(0,a.kt)("a",{parentName:"li",href:"/docs/containers"},"You onboarded a container engine"),"."),(0,a.kt)("li",{parentName:"ul"},(0,a.kt)("a",{parentName:"li",href:"/docs/kind"},"You onboarded a Kind cluster"),"."),(0,a.kt)("li",{parentName:"ul"},(0,a.kt)("a",{parentName:"li",href:"/docs/kind/working-with-your-local-kind-cluster"},"You have set your Kubernetes context to your local Kind-powered Kubernetes cluster"),"."),(0,a.kt)("li",{parentName:"ul"},"A container definition file: ",(0,a.kt)("inlineCode",{parentName:"li"},"Containerfile")," or ",(0,a.kt)("inlineCode",{parentName:"li"},"Dockerfile"),".")),(0,a.kt)("h4",{id:"procedure"},"Procedure"),(0,a.kt)("ol",null,(0,a.kt)("li",{parentName:"ol"},(0,a.kt)("p",{parentName:"li"},"Build your image:"),(0,a.kt)("ol",{parentName:"li"},(0,a.kt)("li",{parentName:"ol"},"Open ",(0,a.kt)("strong",{parentName:"li"},(0,a.kt)(d,{icon:"fa-solid fa-cloud",size:"lg",mdxType:"Icon"})," Images > ",(0,a.kt)(d,{icon:"fa-solid fa-cube",size:"lg",mdxType:"Icon"})," Build an image"),"."),(0,a.kt)("li",{parentName:"ol"},(0,a.kt)("strong",{parentName:"li"},"Containerfile path"),": select your ",(0,a.kt)("inlineCode",{parentName:"li"},"Containerfile")," or ",(0,a.kt)("inlineCode",{parentName:"li"},"Dockerfile"),"."),(0,a.kt)("li",{parentName:"ol"},(0,a.kt)("strong",{parentName:"li"},"Build context directory"),": optionally, select a directory different from the directory containing your ",(0,a.kt)("inlineCode",{parentName:"li"},"Containerfile")," or ",(0,a.kt)("inlineCode",{parentName:"li"},"Dockerfile"),"."),(0,a.kt)("li",{parentName:"ol"},(0,a.kt)("strong",{parentName:"li"},"Image Name"),": enter your image name ",(0,a.kt)("inlineCode",{parentName:"li"},"my-custom-image"),"."),(0,a.kt)("li",{parentName:"ol"},"Click ",(0,a.kt)("strong",{parentName:"li"},(0,a.kt)(d,{icon:"fa-solid fa-cube",size:"lg",mdxType:"Icon"})," Build"),"."),(0,a.kt)("li",{parentName:"ol"},"Wait for the image build to finish."),(0,a.kt)("li",{parentName:"ol"},"Click ",(0,a.kt)("strong",{parentName:"li"},"Done")," to get back to the images list."))),(0,a.kt)("li",{parentName:"ol"},(0,a.kt)("p",{parentName:"li"},"Push your image to your Kind cluster:"),(0,a.kt)("ol",{parentName:"li"},(0,a.kt)("li",{parentName:"ol"},(0,a.kt)("strong",{parentName:"li"},(0,a.kt)(d,{icon:"fa-solid fa-cloud",size:"lg",mdxType:"Icon"})," Search images"),": enter your image name ",(0,a.kt)("inlineCode",{parentName:"li"},"my-custom-image")," to find the image."),(0,a.kt)("li",{parentName:"ol"},"Click ",(0,a.kt)("strong",{parentName:"li"},(0,a.kt)(d,{icon:"fa-solid fa-ellipsis-v",size:"lg",mdxType:"Icon"})," > ",(0,a.kt)(d,{icon:"fa-solid fa-ellipsis-v",size:"lg",mdxType:"Icon"})," Push image to Kind cluster"),"."))),(0,a.kt)("li",{parentName:"ol"},(0,a.kt)("p",{parentName:"li"},"Test your image by creating a container:"),(0,a.kt)("ol",{parentName:"li"},(0,a.kt)("li",{parentName:"ol"},"Click ",(0,a.kt)("strong",{parentName:"li"},(0,a.kt)(d,{icon:"fa-solid fa-play",size:"lg",mdxType:"Icon"}))," to open the ",(0,a.kt)("strong",{parentName:"li"},"Create a container from image")," dialog."),(0,a.kt)("li",{parentName:"ol"},(0,a.kt)("strong",{parentName:"li"},"Container name"),": enter ",(0,a.kt)("inlineCode",{parentName:"li"},"my-custom-image-container"),"."),(0,a.kt)("li",{parentName:"ol"},"Review the parameters that Podman Desktop has detected from your image definition."),(0,a.kt)("li",{parentName:"ol"},"Click ",(0,a.kt)("strong",{parentName:"li"},(0,a.kt)(d,{icon:"fa-solid fa-play",size:"lg",mdxType:"Icon"})," Start Container")," to start the container in your container engine."))),(0,a.kt)("li",{parentName:"ol"},(0,a.kt)("p",{parentName:"li"},"Test your image and container on your Kind cluster:"),(0,a.kt)("ol",{parentName:"li"},(0,a.kt)("li",{parentName:"ol"},(0,a.kt)("strong",{parentName:"li"},(0,a.kt)(d,{icon:"fa-solid fa-cloud",size:"lg",mdxType:"Icon"})," Search containers"),": enter ",(0,a.kt)("inlineCode",{parentName:"li"},"my-custom-image-container")," to find the running container."),(0,a.kt)("li",{parentName:"ol"},"Click ",(0,a.kt)("strong",{parentName:"li"},(0,a.kt)(d,{icon:"fa-solid fa-ellipsis-v",size:"lg",mdxType:"Icon"})," > ",(0,a.kt)(d,{icon:"fa-solid fa-rocket",size:"lg",mdxType:"Icon"})," Deploy to Kubernetes")," to open the ",(0,a.kt)("strong",{parentName:"li"},"Deploy generated pod to Kubernetes")," screen."),(0,a.kt)("li",{parentName:"ol"},(0,a.kt)("strong",{parentName:"li"},"Pod Name"),": keep the proposed value ",(0,a.kt)("inlineCode",{parentName:"li"},"my-custom-image-container-pod"),"."),(0,a.kt)("li",{parentName:"ol"},(0,a.kt)("strong",{parentName:"li"},"Use Kubernetes Services"),": select ",(0,a.kt)("strong",{parentName:"li"},"Replace ",(0,a.kt)("inlineCode",{parentName:"strong"},"hostPort")," exposure on containers by Services. It is the recommended way to expose ports, as a cluster policy might prevent to use ",(0,a.kt)("inlineCode",{parentName:"strong"},"hostPort"),".")),(0,a.kt)("li",{parentName:"ol"},(0,a.kt)("strong",{parentName:"li"},"Expose service locally using Kubernetes Ingress"),": if your container is exposing at a port, select ",(0,a.kt)("strong",{parentName:"li"},"Create a Kubernetes ingress to get access to the ports that this pod exposes, at the default ingress controller location. Example: on a default Kind cluster created with Podman Desktop: ",(0,a.kt)("inlineCode",{parentName:"strong"},"http://localhost:9090"),". Requirements: your cluster has an ingress controller`"),"."),(0,a.kt)("li",{parentName:"ol"},"Optionally, if your container is exposing more than one port, select the port to expose."),(0,a.kt)("li",{parentName:"ol"},(0,a.kt)("strong",{parentName:"li"},"Kubernetes namespaces"),": select ",(0,a.kt)("inlineCode",{parentName:"li"},"default"),"."),(0,a.kt)("li",{parentName:"ol"},"Click ",(0,a.kt)("strong",{parentName:"li"},(0,a.kt)(d,{icon:"fa-solid fa-rocket",size:"lg",mdxType:"Icon"})," Deploy"),"."),(0,a.kt)("li",{parentName:"ol"},"Wait for the pod to reach the state: ",(0,a.kt)("strong",{parentName:"li"},"Phase: Running"),"."),(0,a.kt)("li",{parentName:"ol"},"Click ",(0,a.kt)("strong",{parentName:"li"},"Done"),".")))),(0,a.kt)("h4",{id:"verification"},"Verification"),(0,a.kt)("ol",null,(0,a.kt)("li",{parentName:"ol"},"The ",(0,a.kt)("strong",{parentName:"li"},(0,a.kt)(d,{icon:"fa-solid fa-cubes",size:"lg",mdxType:"Icon"})," Pods")," screen lists the running ",(0,a.kt)("inlineCode",{parentName:"li"},"my-image-container-pod")," pod."),(0,a.kt)("li",{parentName:"ol"},"Click on the pod name to view details and logs."),(0,a.kt)("li",{parentName:"ol"},"Optionally, if your container is exposing a port, go to ",(0,a.kt)("inlineCode",{parentName:"li"},"http://localhost:9090"),": your application is running.")))}u.isMDXComponent=!0}}]); \ No newline at end of file diff --git a/assets/js/fc8a94e3.1bd597cd.js b/assets/js/fc8a94e3.1bd597cd.js deleted file mode 100644 index ae79878862f..00000000000 --- a/assets/js/fc8a94e3.1bd597cd.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[1425],{35318:(e,t,n)=>{n.d(t,{Zo:()=>c,kt:()=>k});var o=n(27378);function r(e,t,n){return t in e?Object.defineProperty(e,t,{value:n,enumerable:!0,configurable:!0,writable:!0}):e[t]=n,e}function a(e,t){var n=Object.keys(e);if(Object.getOwnPropertySymbols){var o=Object.getOwnPropertySymbols(e);t&&(o=o.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),n.push.apply(n,o)}return n}function i(e){for(var t=1;t=0||(r[n]=e[n]);return r}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(o=0;o=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(r[n]=e[n])}return r}var s=o.createContext({}),p=function(e){var t=o.useContext(s),n=t;return e&&(n="function"==typeof e?e(t):i(i({},t),e)),n},c=function(e){var t=p(e.components);return o.createElement(s.Provider,{value:t},e.children)},d={inlineCode:"code",wrapper:function(e){var t=e.children;return o.createElement(o.Fragment,{},t)}},m=o.forwardRef((function(e,t){var n=e.components,r=e.mdxType,a=e.originalType,s=e.parentName,c=l(e,["components","mdxType","originalType","parentName"]),m=p(n),k=r,u=m["".concat(s,".").concat(k)]||m[k]||d[k]||a;return n?o.createElement(u,i(i({ref:t},c),{},{components:n})):o.createElement(u,i({ref:t},c))}));function k(e,t){var n=arguments,r=t&&t.mdxType;if("string"==typeof e||r){var a=n.length,i=new Array(a);i[0]=m;var l={};for(var s in t)hasOwnProperty.call(t,s)&&(l[s]=t[s]);l.originalType=e,l.mdxType="string"==typeof e?e:r,i[1]=l;for(var p=2;p{n.r(t),n.d(t,{assets:()=>s,contentTitle:()=>i,default:()=>d,frontMatter:()=>a,metadata:()=>l,toc:()=>p});var o=n(25773),r=(n(27378),n(35318));const a={title:"Developer Sandbox",description:"Configuring access to a Developer Sandbox",keywords:["podman desktop","podman","containers","pods","migrating","kubernetes","openshift"],tags:["migrating-to-kubernetes","openshift"]},i="Configuring access to a Developer Sandbox",l={unversionedId:"openshift/developer-sandbox/index",id:"openshift/developer-sandbox/index",title:"Developer Sandbox",description:"Configuring access to a Developer Sandbox",source:"@site/docs/openshift/developer-sandbox/index.md",sourceDirName:"openshift/developer-sandbox",slug:"/openshift/developer-sandbox/",permalink:"/docs/openshift/developer-sandbox/",draft:!1,editUrl:"https://github.com/containers/podman-desktop/tree/main/website/docs/openshift/developer-sandbox/index.md",tags:[{label:"migrating-to-kubernetes",permalink:"/docs/tags/migrating-to-kubernetes"},{label:"openshift",permalink:"/docs/tags/openshift"}],version:"current",frontMatter:{title:"Developer Sandbox",description:"Configuring access to a Developer Sandbox",keywords:["podman desktop","podman","containers","pods","migrating","kubernetes","openshift"],tags:["migrating-to-kubernetes","openshift"]},sidebar:"mySidebar",previous:{title:"OpenShift",permalink:"/docs/openshift/"},next:{title:"OpenShift Local",permalink:"/docs/openshift/openshift-local/"}},s={},p=[{value:"Prerequisites",id:"prerequisites",level:4},{value:"Procedure",id:"procedure",level:4},{value:"Verification",id:"verification",level:4}],c={toc:p};function d(e){let{components:t,...a}=e;return(0,r.kt)("wrapper",(0,o.Z)({},c,a,{components:t,mdxType:"MDXLayout"}),(0,r.kt)("h1",{id:"configuring-access-to-a-developer-sandbox"},"Configuring access to a Developer Sandbox"),(0,r.kt)("p",null,"The ",(0,r.kt)("a",{parentName:"p",href:"https://developers.redhat.com/developer-sandbox"},"Developer Sandbox")," is a free, private OpenShift environment including one project and a resource quota of 14 GB RAM, and 40 GB storage.\nIt lasts 30 days."),(0,r.kt)("p",null,"With Podman Desktop, you can configure access to your Developer Sandbox instances."),(0,r.kt)("h4",{id:"prerequisites"},"Prerequisites"),(0,r.kt)("ul",null,(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("a",{parentName:"li",href:"https://developers.redhat.com/register"},"Register a Red Hat account"),".")),(0,r.kt)("h4",{id:"procedure"},"Procedure"),(0,r.kt)("ol",null,(0,r.kt)("li",{parentName:"ol"},"Install the ",(0,r.kt)("em",{parentName:"li"},"Developer Sandbox")," extension: go to ",(0,r.kt)("strong",{parentName:"li"},"Dashboard"),", and click ",(0,r.kt)("strong",{parentName:"li"},"Developer Sandbox ",(0,r.kt)("icon",{icon:"fa-solid fa-download",size:"lg"})),"."),(0,r.kt)("li",{parentName:"ol"},"Go to ",(0,r.kt)("strong",{parentName:"li"},(0,r.kt)("icon",{icon:"fa-solid fa-cog",size:"lg"})," Settings > Resources"),"."),(0,r.kt)("li",{parentName:"ol"},"In the ",(0,r.kt)("strong",{parentName:"li"},"Developer Sandbox")," tile, click ",(0,r.kt)("strong",{parentName:"li"},"Create new"),"."),(0,r.kt)("li",{parentName:"ol"},"In the ",(0,r.kt)("strong",{parentName:"li"},"Create a Developer Sandbox")," screen, click ",(0,r.kt)("strong",{parentName:"li"},"Log into Developer Sandbox"),"."),(0,r.kt)("li",{parentName:"ol"},"In the ",(0,r.kt)("strong",{parentName:"li"},"Open external website")," dialog, click ",(0,r.kt)("strong",{parentName:"li"},"Yes"),"."),(0,r.kt)("li",{parentName:"ol"},"In the ",(0,r.kt)("a",{parentName:"li",href:"https://developers.redhat.com/developer-sandbox"},"Developer Sandbox website"),":",(0,r.kt)("ol",{parentName:"li"},(0,r.kt)("li",{parentName:"ol"},"Click ",(0,r.kt)("strong",{parentName:"li"},"Start your sandbox for free")),(0,r.kt)("li",{parentName:"ol"},"If you never used this service, you might get through a verification workflow."),(0,r.kt)("li",{parentName:"ol"},"In the ",(0,r.kt)("strong",{parentName:"li"},"Login with...")," screen, click ",(0,r.kt)("strong",{parentName:"li"},"DevSandbox"),"."),(0,r.kt)("li",{parentName:"ol"},"In your Developer Sandbox Console, click on ",(0,r.kt)("strong",{parentName:"li"},"your login name > Copy login command")," from the menu."),(0,r.kt)("li",{parentName:"ol"},"In the ",(0,r.kt)("strong",{parentName:"li"},"Login with...")," screen, click ",(0,r.kt)("strong",{parentName:"li"},"DevSandbox"),"."),(0,r.kt)("li",{parentName:"ol"},"Click ",(0,r.kt)("strong",{parentName:"li"},"Display Token"),"."),(0,r.kt)("li",{parentName:"ol"},"Copy the ",(0,r.kt)("strong",{parentName:"li"},"Log in with this token")," full login command, similar to: ",(0,r.kt)("inlineCode",{parentName:"li"},"oc login --token=sha256~ --server=https://api.sandbox-m2..openshiftapps.com:6443"),"."))),(0,r.kt)("li",{parentName:"ol"},"Get back to Podman Desktop ",(0,r.kt)("strong",{parentName:"li"},"Create a Developer Sandbox")," screen.",(0,r.kt)("ol",{parentName:"li"},(0,r.kt)("li",{parentName:"ol"},(0,r.kt)("strong",{parentName:"li"},"Context name"),": Enter a name such as ",(0,r.kt)("inlineCode",{parentName:"li"},"Developer Sandbox"),"."),(0,r.kt)("li",{parentName:"ol"},(0,r.kt)("strong",{parentName:"li"},"Login command"),": Paste the ",(0,r.kt)("inlineCode",{parentName:"li"},"oc login")," command that you copied previously."))),(0,r.kt)("li",{parentName:"ol"},"The ",(0,r.kt)("strong",{parentName:"li"},"Creation")," screen displays ",(0,r.kt)("em",{parentName:"li"},"Successful operation"),". Click ",(0,r.kt)("strong",{parentName:"li"},"Go back to Resources"),".")),(0,r.kt)("h4",{id:"verification"},"Verification"),(0,r.kt)("ol",null,(0,r.kt)("li",{parentName:"ol"},(0,r.kt)("p",{parentName:"li"},"On the ",(0,r.kt)("strong",{parentName:"p"},(0,r.kt)("icon",{icon:"fa-solid fa-cog",size:"lg"})," Settings > Resources")," screen, your Developer Sandbox is running."),(0,r.kt)("p",{parentName:"li"},(0,r.kt)("img",{alt:"Developer Sandbox is running",src:n(73652).Z,width:"510",height:"211"}))),(0,r.kt)("li",{parentName:"ol"},(0,r.kt)("p",{parentName:"li"},(0,r.kt)("a",{parentName:"p",href:"/docs/kubernetes/viewing-and-selecting-current-kubernete-context"},"Select your Developer Sandbox in the Podman Desktop tray"))),(0,r.kt)("li",{parentName:"ol"},(0,r.kt)("p",{parentName:"li"},"Run basic tasks such as:"),(0,r.kt)("ul",{parentName:"li"},(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("a",{parentName:"li",href:"/docs/kubernetes/deploying-a-container-to-kubernetes"},"Deploying a container")),(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("a",{parentName:"li",href:"/docs/kubernetes/deploying-a-pod-to-kubernetes"},"Deploying a pod"))))))}d.isMDXComponent=!0},73652:(e,t,n)=>{n.d(t,{Z:()=>o});const o=n.p+"assets/images/resources-developer-sandbox-running-435054109642f996529ce6a133f1893e.png"}}]); \ No newline at end of file diff --git a/assets/js/fc8a94e3.3370fdba.js b/assets/js/fc8a94e3.3370fdba.js new file mode 100644 index 00000000000..fb4ad6ebcac --- /dev/null +++ b/assets/js/fc8a94e3.3370fdba.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([[1425],{35318:(e,t,n)=>{n.d(t,{Zo:()=>c,kt:()=>u});var o=n(27378);function r(e,t,n){return t in e?Object.defineProperty(e,t,{value:n,enumerable:!0,configurable:!0,writable:!0}):e[t]=n,e}function a(e,t){var n=Object.keys(e);if(Object.getOwnPropertySymbols){var o=Object.getOwnPropertySymbols(e);t&&(o=o.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),n.push.apply(n,o)}return n}function i(e){for(var t=1;t=0||(r[n]=e[n]);return r}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(o=0;o=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(r[n]=e[n])}return r}var s=o.createContext({}),p=function(e){var t=o.useContext(s),n=t;return e&&(n="function"==typeof e?e(t):i(i({},t),e)),n},c=function(e){var t=p(e.components);return o.createElement(s.Provider,{value:t},e.children)},d={inlineCode:"code",wrapper:function(e){var t=e.children;return o.createElement(o.Fragment,{},t)}},m=o.forwardRef((function(e,t){var n=e.components,r=e.mdxType,a=e.originalType,s=e.parentName,c=l(e,["components","mdxType","originalType","parentName"]),m=p(n),u=r,k=m["".concat(s,".").concat(u)]||m[u]||d[u]||a;return n?o.createElement(k,i(i({ref:t},c),{},{components:n})):o.createElement(k,i({ref:t},c))}));function u(e,t){var n=arguments,r=t&&t.mdxType;if("string"==typeof e||r){var a=n.length,i=new Array(a);i[0]=m;var l={};for(var s in t)hasOwnProperty.call(t,s)&&(l[s]=t[s]);l.originalType=e,l.mdxType="string"==typeof e?e:r,i[1]=l;for(var p=2;p{n.r(t),n.d(t,{assets:()=>s,contentTitle:()=>i,default:()=>u,frontMatter:()=>a,metadata:()=>l,toc:()=>p});var o=n(25773),r=(n(27378),n(35318));const a={title:"Developer Sandbox",description:"Configuring access to a Developer Sandbox",keywords:["podman desktop","podman","containers","pods","migrating","kubernetes","openshift"],tags:["migrating-to-kubernetes","openshift"]},i="Configuring access to a Developer Sandbox",l={unversionedId:"openshift/developer-sandbox/index",id:"openshift/developer-sandbox/index",title:"Developer Sandbox",description:"Configuring access to a Developer Sandbox",source:"@site/docs/openshift/developer-sandbox/index.md",sourceDirName:"openshift/developer-sandbox",slug:"/openshift/developer-sandbox/",permalink:"/docs/openshift/developer-sandbox/",draft:!1,editUrl:"https://github.com/containers/podman-desktop/tree/main/website/docs/openshift/developer-sandbox/index.md",tags:[{label:"migrating-to-kubernetes",permalink:"/docs/tags/migrating-to-kubernetes"},{label:"openshift",permalink:"/docs/tags/openshift"}],version:"current",frontMatter:{title:"Developer Sandbox",description:"Configuring access to a Developer Sandbox",keywords:["podman desktop","podman","containers","pods","migrating","kubernetes","openshift"],tags:["migrating-to-kubernetes","openshift"]},sidebar:"mySidebar",previous:{title:"OpenShift",permalink:"/docs/openshift/"},next:{title:"OpenShift Local",permalink:"/docs/openshift/openshift-local/"}},s={},p=[{value:"Prerequisites",id:"prerequisites",level:4},{value:"Procedure",id:"procedure",level:4},{value:"Verification",id:"verification",level:4}],c=(d="Icon",function(e){return console.warn("Component "+d+" was not imported, exported, or provided by MDXProvider as global scope"),(0,r.kt)("div",e)});var d;const m={toc:p};function u(e){let{components:t,...a}=e;return(0,r.kt)("wrapper",(0,o.Z)({},m,a,{components:t,mdxType:"MDXLayout"}),(0,r.kt)("h1",{id:"configuring-access-to-a-developer-sandbox"},"Configuring access to a Developer Sandbox"),(0,r.kt)("p",null,"The ",(0,r.kt)("a",{parentName:"p",href:"https://developers.redhat.com/developer-sandbox"},"Developer Sandbox")," is a free, private OpenShift environment including one project and a resource quota of 14 GB RAM, and 40 GB storage.\nIt lasts 30 days."),(0,r.kt)("p",null,"With Podman Desktop, you can configure access to your Developer Sandbox instances."),(0,r.kt)("h4",{id:"prerequisites"},"Prerequisites"),(0,r.kt)("ul",null,(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("a",{parentName:"li",href:"https://developers.redhat.com/register"},"Register a Red Hat account"),".")),(0,r.kt)("h4",{id:"procedure"},"Procedure"),(0,r.kt)("ol",null,(0,r.kt)("li",{parentName:"ol"},"Install the ",(0,r.kt)("em",{parentName:"li"},"Developer Sandbox")," extension: go to ",(0,r.kt)("strong",{parentName:"li"},"Dashboard"),", and click ",(0,r.kt)("strong",{parentName:"li"},"Developer Sandbox ",(0,r.kt)(c,{icon:"fa-solid fa-download",size:"lg",mdxType:"Icon"})),"."),(0,r.kt)("li",{parentName:"ol"},"Go to ",(0,r.kt)("strong",{parentName:"li"},(0,r.kt)(c,{icon:"fa-solid fa-cog",size:"lg",mdxType:"Icon"})," Settings > Resources"),"."),(0,r.kt)("li",{parentName:"ol"},"In the ",(0,r.kt)("strong",{parentName:"li"},"Developer Sandbox")," tile, click ",(0,r.kt)("strong",{parentName:"li"},"Create new"),"."),(0,r.kt)("li",{parentName:"ol"},"In the ",(0,r.kt)("strong",{parentName:"li"},"Create a Developer Sandbox")," screen, click ",(0,r.kt)("strong",{parentName:"li"},"Log into Developer Sandbox"),"."),(0,r.kt)("li",{parentName:"ol"},"In the ",(0,r.kt)("strong",{parentName:"li"},"Open external website")," dialog, click ",(0,r.kt)("strong",{parentName:"li"},"Yes"),"."),(0,r.kt)("li",{parentName:"ol"},"In the ",(0,r.kt)("a",{parentName:"li",href:"https://developers.redhat.com/developer-sandbox"},"Developer Sandbox website"),":",(0,r.kt)("ol",{parentName:"li"},(0,r.kt)("li",{parentName:"ol"},"Click ",(0,r.kt)("strong",{parentName:"li"},"Start your sandbox for free")),(0,r.kt)("li",{parentName:"ol"},"If you never used this service, you might get through a verification workflow."),(0,r.kt)("li",{parentName:"ol"},"In the ",(0,r.kt)("strong",{parentName:"li"},"Login with...")," screen, click ",(0,r.kt)("strong",{parentName:"li"},"DevSandbox"),"."),(0,r.kt)("li",{parentName:"ol"},"In your Developer Sandbox Console, click on ",(0,r.kt)("strong",{parentName:"li"},"your login name > Copy login command")," from the menu."),(0,r.kt)("li",{parentName:"ol"},"In the ",(0,r.kt)("strong",{parentName:"li"},"Login with...")," screen, click ",(0,r.kt)("strong",{parentName:"li"},"DevSandbox"),"."),(0,r.kt)("li",{parentName:"ol"},"Click ",(0,r.kt)("strong",{parentName:"li"},"Display Token"),"."),(0,r.kt)("li",{parentName:"ol"},"Copy the ",(0,r.kt)("strong",{parentName:"li"},"Log in with this token")," full login command, similar to: ",(0,r.kt)("inlineCode",{parentName:"li"},"oc login --token=sha256~ --server=https://api.sandbox-m2..openshiftapps.com:6443"),"."))),(0,r.kt)("li",{parentName:"ol"},"Get back to Podman Desktop ",(0,r.kt)("strong",{parentName:"li"},"Create a Developer Sandbox")," screen.",(0,r.kt)("ol",{parentName:"li"},(0,r.kt)("li",{parentName:"ol"},(0,r.kt)("strong",{parentName:"li"},"Context name"),": Enter a name such as ",(0,r.kt)("inlineCode",{parentName:"li"},"Developer Sandbox"),"."),(0,r.kt)("li",{parentName:"ol"},(0,r.kt)("strong",{parentName:"li"},"Login command"),": Paste the ",(0,r.kt)("inlineCode",{parentName:"li"},"oc login")," command that you copied previously."))),(0,r.kt)("li",{parentName:"ol"},"The ",(0,r.kt)("strong",{parentName:"li"},"Creation")," screen displays ",(0,r.kt)("em",{parentName:"li"},"Successful operation"),". Click ",(0,r.kt)("strong",{parentName:"li"},"Go back to Resources"),".")),(0,r.kt)("h4",{id:"verification"},"Verification"),(0,r.kt)("ol",null,(0,r.kt)("li",{parentName:"ol"},(0,r.kt)("p",{parentName:"li"},"On the ",(0,r.kt)("strong",{parentName:"p"},(0,r.kt)(c,{icon:"fa-solid fa-cog",size:"lg",mdxType:"Icon"})," Settings > Resources")," screen, your Developer Sandbox is running."),(0,r.kt)("p",{parentName:"li"},(0,r.kt)("img",{alt:"Developer Sandbox is running",src:n(73652).Z,width:"510",height:"211"}))),(0,r.kt)("li",{parentName:"ol"},(0,r.kt)("p",{parentName:"li"},(0,r.kt)("a",{parentName:"p",href:"/docs/kubernetes/viewing-and-selecting-current-kubernete-context"},"Select your Developer Sandbox in the Podman Desktop tray"))),(0,r.kt)("li",{parentName:"ol"},(0,r.kt)("p",{parentName:"li"},"Run basic tasks such as:"),(0,r.kt)("ul",{parentName:"li"},(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("a",{parentName:"li",href:"/docs/kubernetes/deploying-a-container-to-kubernetes"},"Deploying a container")),(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("a",{parentName:"li",href:"/docs/kubernetes/deploying-a-pod-to-kubernetes"},"Deploying a pod"))))))}u.isMDXComponent=!0},73652:(e,t,n)=>{n.d(t,{Z:()=>o});const o=n.p+"assets/images/resources-developer-sandbox-running-435054109642f996529ce6a133f1893e.png"}}]); \ No newline at end of file diff --git a/assets/js/runtime~main.33da2221.js b/assets/js/runtime~main.4bd03f2f.js similarity index 70% rename from assets/js/runtime~main.33da2221.js rename to assets/js/runtime~main.4bd03f2f.js index c931c100c3c..7eafa28a966 100644 --- a/assets/js/runtime~main.33da2221.js +++ b/assets/js/runtime~main.4bd03f2f.js @@ -1 +1 @@ -(()=>{"use strict";var e,f,a,c,d,b={},t={};function r(e){var f=t[e];if(void 0!==f)return f.exports;var a=t[e]={exports:{}};return b[e].call(a.exports,a,a.exports,r),a.exports}r.m=b,e=[],r.O=(f,a,c,d)=>{if(!a){var b=1/0;for(i=0;i=d)&&Object.keys(r.O).every((e=>r.O[e](a[o])))?a.splice(o--,1):(t=!1,d0&&e[i-1][2]>d;i--)e[i]=e[i-1];e[i]=[a,c,d]},r.n=e=>{var f=e&&e.__esModule?()=>e.default:()=>e;return r.d(f,{a:f}),f},a=Object.getPrototypeOf?e=>Object.getPrototypeOf(e):e=>e.__proto__,r.t=function(e,c){if(1&c&&(e=this(e)),8&c)return e;if("object"==typeof e&&e){if(4&c&&e.__esModule)return e;if(16&c&&"function"==typeof e.then)return e}var d=Object.create(null);r.r(d);var b={};f=f||[null,a({}),a([]),a(a)];for(var t=2&c&&e;"object"==typeof t&&!~f.indexOf(t);t=a(t))Object.getOwnPropertyNames(t).forEach((f=>b[f]=()=>e[f]));return b.default=()=>e,r.d(d,b),d},r.d=(e,f)=>{for(var a in f)r.o(f,a)&&!r.o(e,a)&&Object.defineProperty(e,a,{enumerable:!0,get:f[a]})},r.f={},r.e=e=>Promise.all(Object.keys(r.f).reduce(((f,a)=>(r.f[a](e,f),f)),[])),r.u=e=>"assets/js/"+({10:"33942509",53:"935f2afb",70:"86f2a982",114:"e665718d",138:"54590fd2",182:"c276ecb2",203:"c6aad055",205:"83d480e9",347:"bc816bf2",397:"6194ac84",406:"0cbb83d7",465:"f7b7f9b7",506:"9aa62c0e",522:"308aae28",523:"a0323d9f",533:"b2b675dd",534:"4b8121dd",563:"c685778b",592:"b39cdcf9",649:"512fbd77",743:"61d4c13a",745:"64abd3af",809:"840a98fb",822:"a00af9f0",873:"cabda5f8",899:"b985118d",921:"c37b4a03",944:"b2e1a0c8",945:"df322e14",1021:"901c37e5",1032:"a67ca768",1046:"4cb6c19a",1074:"9e8f4e9c",1297:"34cf6fc7",1342:"a766a857",1425:"fc8a94e3",1441:"382c5d2b",1447:"4974f5d2",1477:"b2f554cd",1625:"de311ed4",1676:"819ef483",1705:"94fb813f",1713:"a7023ddc",1724:"5087625a",1830:"b00bc883",1859:"2295be0e",1896:"25622900",1981:"b799648a",2079:"1a16e8bf",2082:"e85ba0e6",2111:"79665d43",2178:"ba322490",2193:"c5b2f0f9",2217:"d7fbbe43",2242:"1dcf37fa",2323:"6c80b6fe",2339:"17896441",2451:"fb50ea3a",2472:"65a10ffa",2535:"814f3328",2549:"5c63ba15",2599:"e44de27e",2609:"6269f1c0",2667:"368cce37",2778:"608238a8",2783:"f425c855",2896:"abc85917",2938:"c95aa39f",2958:"86063cd3",3010:"56c3a9b2",3089:"a6aa9e1f",3152:"33a21d7d",3154:"c6346fcf",3163:"232c546d",3207:"6603ef13",3233:"59a6f192",3237:"1df93b7f",3259:"03ccf92d",3296:"181ef600",3317:"846a5e19",3324:"1ce91f4c",3414:"35a7a45c",3427:"bd80aa65",3505:"72486833",3584:"ed75cfcb",3608:"9e4087bc",3636:"8b4dd820",3714:"894e67a6",3751:"3720c009",3820:"a5e1f61e",3840:"562ca3e9",3870:"5df556a2",3879:"2d629ea6",3973:"f523fb3f",4013:"01a85c17",4059:"9cb03f5d",4117:"fd684bd6",4121:"55960ee5",4157:"83e10f72",4220:"2bbe04e6",4322:"69c5f318",4356:"a9a76bf7",4386:"ae79aff5",4459:"19eded63",4617:"95366386",4651:"94f3d131",4672:"03685665",4781:"12f1535e",4918:"24bda87b",4929:"330dfcdb",4940:"c11c87f7",5018:"cd509849",5240:"22de4147",5248:"6101b3fc",5326:"af231220",5375:"97615df2",5414:"724f3974",5625:"657ac0bc",5708:"f0057c03",5765:"d18d294a",5776:"f0e3a130",5803:"ff8f5ed0",6026:"51dec273",6049:"f213dd13",6088:"88efc5aa",6103:"ccc49370",6120:"d4840880",6158:"51e516cc",6308:"e8dc4d98",6317:"959a8cfe",6328:"c0d19596",6521:"014457dd",6536:"3ed6e2e9",6608:"5099f3e0",6623:"b104dd1e",6690:"4816649b",6692:"2ae2e7fe",6766:"e5638e51",6843:"9f97f9d1",6932:"aaabcfd8",7007:"8593ff01",7034:"3e03f778",7134:"0b40a488",7138:"38a042e4",7141:"b5abacaa",7149:"822c343e",7159:"a8ce95ee",7220:"7591d420",7251:"ba5b9f11",7363:"583db3ef",7366:"75281220",7377:"708d858d",7438:"9c021584",7480:"eb17771c",7536:"f6e0e63c",7573:"48b6ff5f",7622:"dbbb982f",7653:"31de1779",7679:"83245ae6",7698:"cd23aec9",7714:"7bdcd7a7",7722:"213182ef",7741:"7d88b63f",7759:"ff38b1ce",7847:"43b416ef",7875:"021eaa84",7881:"2658ced2",7918:"10ce918d",7920:"1a4e3797",8145:"006e489c",8176:"5660752d",8215:"1cfced13",8221:"6af14956",8262:"059d1c6a",8290:"3fe48f60",8445:"99245987",8502:"b4657d81",8514:"d651e2ee",8532:"d1b15a6d",8533:"f3d54061",8566:"9dce5486",8610:"6875c492",8626:"c6f0d1b2",8768:"524ce9a0",8800:"e6fb1369",8811:"3289a752",8860:"0d040286",8893:"ba1dc56d",8960:"6bf124c2",8989:"d4bf7e47",9043:"473de3ed",9106:"72dd8f7e",9133:"02e265ea",9179:"79551407",9341:"a35cf155",9372:"07f59c2a",9387:"b0f1c099",9469:"3b85f227",9514:"1be78505",9558:"f41c0109",9579:"09b168a7",9626:"81e486a8",9671:"0e384e19",9817:"4f561e31",9924:"df203c0f",9944:"08570680",9973:"4213e5b1",9979:"987564cc"}[e]||e)+"."+{10:"b08d2c29",53:"56f5569d",70:"5d814a9b",114:"22a38c18",138:"8a802f7b",182:"c229eebf",203:"6430dd86",205:"7e07f847",347:"6de1587c",397:"06fc0336",406:"48100623",465:"1cbd3a08",506:"3f0bed63",522:"6de37e89",523:"2002b11a",533:"b499b841",534:"24fea72f",563:"995980f6",592:"581e4b87",649:"10a887e2",743:"89c00deb",745:"d733c2bb",809:"ff094bc8",822:"76d3862d",873:"919ad21c",899:"06293860",921:"f0615854",944:"a49ec1c2",945:"e05bb438",1021:"d78c26da",1032:"8ea0ed17",1046:"5cee8554",1074:"ead1b706",1297:"dee27ee5",1342:"ad19af20",1425:"1bd597cd",1441:"f8883a2a",1447:"a45d676f",1477:"7afd319e",1625:"7419c21d",1676:"57da3d2f",1705:"fa2462b2",1713:"299c19b3",1724:"2461c2e7",1830:"9c19e957",1859:"7e645e6c",1896:"f0255b71",1947:"bda1afcc",1981:"4e218966",2079:"e37eaeb3",2082:"bdc07deb",2111:"b6f563f5",2178:"13069292",2193:"c0c9ba07",2217:"60800c25",2242:"8e672378",2323:"f0b907ab",2339:"1a690c9c",2451:"17de80bc",2472:"262fc4a4",2535:"2e15ba67",2549:"808af98c",2599:"bf2c1cc8",2609:"dbc29b18",2667:"1900730d",2778:"d790be48",2783:"f323ad1d",2896:"d2b27867",2938:"309e0760",2958:"5d79ab5f",3010:"d11d7eb3",3089:"cf7d6632",3152:"fbbea2a5",3154:"fb63ac2a",3163:"4913f1cb",3207:"a41cd11b",3233:"5519362d",3237:"bed82708",3259:"d48e5470",3296:"717aa32f",3317:"7ce74ef2",3324:"a67d3beb",3414:"f94d9eaa",3427:"f0f8caf8",3505:"486eb6ae",3584:"4a5a7db3",3608:"6b194cc3",3636:"bac4874d",3714:"086e1f22",3751:"e6a1ff2c",3820:"75a6ed57",3840:"e6938fa9",3866:"6f22f670",3870:"045cc138",3879:"f60fd6be",3893:"43838999",3973:"83c24d96",4013:"17c10467",4059:"2e148b4d",4117:"ab52d392",4121:"42bd0c53",4157:"8f491252",4178:"a197f856",4220:"8cf11d92",4322:"1d5a3008",4356:"8c8bcc20",4386:"da92827f",4459:"997f1191",4617:"61371bc1",4651:"91c40158",4670:"c6602195",4672:"73c9ed61",4781:"007e12d4",4918:"cbf6de50",4929:"a0707feb",4940:"09f6f3d2",5018:"9d824327",5240:"641ec7fc",5248:"e7820b8e",5326:"de109415",5375:"f19ca62b",5414:"21a11f92",5625:"c4b6a5f2",5708:"9e67218b",5765:"efe24b1a",5776:"9289db31",5803:"7724e22b",6026:"6c6a5338",6049:"2f6bc428",6088:"0e41b8ce",6103:"0a9a510b",6120:"11c2c21b",6158:"e1bb3a48",6308:"326b3a51",6317:"e598f70b",6328:"9713d629",6521:"f3f94425",6536:"c4261de2",6608:"d1485738",6623:"7db7c3e0",6690:"13b901ec",6692:"9034be99",6766:"d8eb51cb",6843:"efcf1441",6932:"c58bf8b6",7007:"e073c454",7034:"1f958f58",7134:"c4e78e68",7138:"3f5eca4c",7141:"aa741b27",7149:"663ec94f",7159:"3dd3ba53",7171:"ed520d1e",7220:"31bb995a",7251:"75e3d1b3",7363:"95f0b138",7366:"26b00857",7377:"b821d601",7438:"ab961c74",7480:"f1561fea",7536:"3a66b423",7573:"09c42214",7622:"b17356bb",7653:"c909c603",7679:"03338c23",7698:"3d0c4450",7714:"b9bb2cdb",7722:"d40b4c8b",7735:"b12007f7",7741:"ff546f54",7759:"c79de414",7847:"2c70676d",7849:"bb1a7e66",7875:"6dede19a",7881:"e7f02a58",7918:"f4a75fd4",7920:"a7306422",8145:"691b93c2",8176:"3fd29c77",8215:"bcf97e6c",8221:"0aaa6e17",8262:"c004698d",8290:"f2aad630",8306:"5f30899d",8445:"4fc783d0",8502:"7b175b26",8514:"ae1174d6",8532:"58a24c58",8533:"caa2477a",8566:"1c39382d",8610:"51bd3ba5",8626:"d16e7ea7",8768:"a65a917e",8777:"e2ef1f93",8800:"a0bdbe06",8811:"fbe331d3",8860:"73ca0e0b",8893:"dfc51795",8960:"5d83dfab",8989:"17f0efbe",9043:"9ed7082a",9106:"3d077178",9127:"02f87f8d",9133:"7057011c",9179:"9200eda1",9341:"afc58592",9372:"7bc1a408",9387:"eaedac00",9469:"3235e126",9514:"0e6e9a66",9558:"7d7d2efa",9579:"23336dd5",9626:"e2d287c9",9671:"f2f2b025",9817:"5036f126",9924:"dc218f14",9944:"161e6f22",9973:"2a5e16f5",9979:"6bd3f7f0"}[e]+".js",r.miniCssF=e=>{},r.g=function(){if("object"==typeof globalThis)return globalThis;try{return this||new Function("return this")()}catch(e){if("object"==typeof window)return window}}(),r.o=(e,f)=>Object.prototype.hasOwnProperty.call(e,f),c={},d="docs:",r.l=(e,f,a,b)=>{if(c[e])c[e].push(f);else{var t,o;if(void 0!==a)for(var n=document.getElementsByTagName("script"),i=0;i{t.onerror=t.onload=null,clearTimeout(s);var d=c[e];if(delete c[e],t.parentNode&&t.parentNode.removeChild(t),d&&d.forEach((e=>e(a))),f)return f(a)},s=setTimeout(l.bind(null,void 0,{type:"timeout",target:t}),12e4);t.onerror=l.bind(null,t.onerror),t.onload=l.bind(null,t.onload),o&&document.head.appendChild(t)}},r.r=e=>{"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(e,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(e,"__esModule",{value:!0})},r.p="/",r.gca=function(e){return e={17896441:"2339",25622900:"1896",33942509:"10",72486833:"3505",75281220:"7366",79551407:"9179",95366386:"4617",99245987:"8445","935f2afb":"53","86f2a982":"70",e665718d:"114","54590fd2":"138",c276ecb2:"182",c6aad055:"203","83d480e9":"205",bc816bf2:"347","6194ac84":"397","0cbb83d7":"406",f7b7f9b7:"465","9aa62c0e":"506","308aae28":"522",a0323d9f:"523",b2b675dd:"533","4b8121dd":"534",c685778b:"563",b39cdcf9:"592","512fbd77":"649","61d4c13a":"743","64abd3af":"745","840a98fb":"809",a00af9f0:"822",cabda5f8:"873",b985118d:"899",c37b4a03:"921",b2e1a0c8:"944",df322e14:"945","901c37e5":"1021",a67ca768:"1032","4cb6c19a":"1046","9e8f4e9c":"1074","34cf6fc7":"1297",a766a857:"1342",fc8a94e3:"1425","382c5d2b":"1441","4974f5d2":"1447",b2f554cd:"1477",de311ed4:"1625","819ef483":"1676","94fb813f":"1705",a7023ddc:"1713","5087625a":"1724",b00bc883:"1830","2295be0e":"1859",b799648a:"1981","1a16e8bf":"2079",e85ba0e6:"2082","79665d43":"2111",ba322490:"2178",c5b2f0f9:"2193",d7fbbe43:"2217","1dcf37fa":"2242","6c80b6fe":"2323",fb50ea3a:"2451","65a10ffa":"2472","814f3328":"2535","5c63ba15":"2549",e44de27e:"2599","6269f1c0":"2609","368cce37":"2667","608238a8":"2778",f425c855:"2783",abc85917:"2896",c95aa39f:"2938","86063cd3":"2958","56c3a9b2":"3010",a6aa9e1f:"3089","33a21d7d":"3152",c6346fcf:"3154","232c546d":"3163","6603ef13":"3207","59a6f192":"3233","1df93b7f":"3237","03ccf92d":"3259","181ef600":"3296","846a5e19":"3317","1ce91f4c":"3324","35a7a45c":"3414",bd80aa65:"3427",ed75cfcb:"3584","9e4087bc":"3608","8b4dd820":"3636","894e67a6":"3714","3720c009":"3751",a5e1f61e:"3820","562ca3e9":"3840","5df556a2":"3870","2d629ea6":"3879",f523fb3f:"3973","01a85c17":"4013","9cb03f5d":"4059",fd684bd6:"4117","55960ee5":"4121","83e10f72":"4157","2bbe04e6":"4220","69c5f318":"4322",a9a76bf7:"4356",ae79aff5:"4386","19eded63":"4459","94f3d131":"4651","03685665":"4672","12f1535e":"4781","24bda87b":"4918","330dfcdb":"4929",c11c87f7:"4940",cd509849:"5018","22de4147":"5240","6101b3fc":"5248",af231220:"5326","97615df2":"5375","724f3974":"5414","657ac0bc":"5625",f0057c03:"5708",d18d294a:"5765",f0e3a130:"5776",ff8f5ed0:"5803","51dec273":"6026",f213dd13:"6049","88efc5aa":"6088",ccc49370:"6103",d4840880:"6120","51e516cc":"6158",e8dc4d98:"6308","959a8cfe":"6317",c0d19596:"6328","014457dd":"6521","3ed6e2e9":"6536","5099f3e0":"6608",b104dd1e:"6623","4816649b":"6690","2ae2e7fe":"6692",e5638e51:"6766","9f97f9d1":"6843",aaabcfd8:"6932","8593ff01":"7007","3e03f778":"7034","0b40a488":"7134","38a042e4":"7138",b5abacaa:"7141","822c343e":"7149",a8ce95ee:"7159","7591d420":"7220",ba5b9f11:"7251","583db3ef":"7363","708d858d":"7377","9c021584":"7438",eb17771c:"7480",f6e0e63c:"7536","48b6ff5f":"7573",dbbb982f:"7622","31de1779":"7653","83245ae6":"7679",cd23aec9:"7698","7bdcd7a7":"7714","213182ef":"7722","7d88b63f":"7741",ff38b1ce:"7759","43b416ef":"7847","021eaa84":"7875","2658ced2":"7881","10ce918d":"7918","1a4e3797":"7920","006e489c":"8145","5660752d":"8176","1cfced13":"8215","6af14956":"8221","059d1c6a":"8262","3fe48f60":"8290",b4657d81:"8502",d651e2ee:"8514",d1b15a6d:"8532",f3d54061:"8533","9dce5486":"8566","6875c492":"8610",c6f0d1b2:"8626","524ce9a0":"8768",e6fb1369:"8800","3289a752":"8811","0d040286":"8860",ba1dc56d:"8893","6bf124c2":"8960",d4bf7e47:"8989","473de3ed":"9043","72dd8f7e":"9106","02e265ea":"9133",a35cf155:"9341","07f59c2a":"9372",b0f1c099:"9387","3b85f227":"9469","1be78505":"9514",f41c0109:"9558","09b168a7":"9579","81e486a8":"9626","0e384e19":"9671","4f561e31":"9817",df203c0f:"9924","08570680":"9944","4213e5b1":"9973","987564cc":"9979"}[e]||e,r.p+r.u(e)},(()=>{var e={1303:0,532:0};r.f.j=(f,a)=>{var c=r.o(e,f)?e[f]:void 0;if(0!==c)if(c)a.push(c[2]);else if(/^(1303|532)$/.test(f))e[f]=0;else{var d=new Promise(((a,d)=>c=e[f]=[a,d]));a.push(c[2]=d);var b=r.p+r.u(f),t=new Error;r.l(b,(a=>{if(r.o(e,f)&&(0!==(c=e[f])&&(e[f]=void 0),c)){var d=a&&("load"===a.type?"missing":a.type),b=a&&a.target&&a.target.src;t.message="Loading chunk "+f+" failed.\n("+d+": "+b+")",t.name="ChunkLoadError",t.type=d,t.request=b,c[1](t)}}),"chunk-"+f,f)}},r.O.j=f=>0===e[f];var f=(f,a)=>{var c,d,b=a[0],t=a[1],o=a[2],n=0;if(b.some((f=>0!==e[f]))){for(c in t)r.o(t,c)&&(r.m[c]=t[c]);if(o)var i=o(r)}for(f&&f(a);n{"use strict";var e,f,a,d,c,b={},t={};function r(e){var f=t[e];if(void 0!==f)return f.exports;var a=t[e]={exports:{}};return b[e].call(a.exports,a,a.exports,r),a.exports}r.m=b,e=[],r.O=(f,a,d,c)=>{if(!a){var b=1/0;for(i=0;i=c)&&Object.keys(r.O).every((e=>r.O[e](a[o])))?a.splice(o--,1):(t=!1,c0&&e[i-1][2]>c;i--)e[i]=e[i-1];e[i]=[a,d,c]},r.n=e=>{var f=e&&e.__esModule?()=>e.default:()=>e;return r.d(f,{a:f}),f},a=Object.getPrototypeOf?e=>Object.getPrototypeOf(e):e=>e.__proto__,r.t=function(e,d){if(1&d&&(e=this(e)),8&d)return e;if("object"==typeof e&&e){if(4&d&&e.__esModule)return e;if(16&d&&"function"==typeof e.then)return e}var c=Object.create(null);r.r(c);var b={};f=f||[null,a({}),a([]),a(a)];for(var t=2&d&&e;"object"==typeof t&&!~f.indexOf(t);t=a(t))Object.getOwnPropertyNames(t).forEach((f=>b[f]=()=>e[f]));return b.default=()=>e,r.d(c,b),c},r.d=(e,f)=>{for(var a in f)r.o(f,a)&&!r.o(e,a)&&Object.defineProperty(e,a,{enumerable:!0,get:f[a]})},r.f={},r.e=e=>Promise.all(Object.keys(r.f).reduce(((f,a)=>(r.f[a](e,f),f)),[])),r.u=e=>"assets/js/"+({10:"33942509",53:"935f2afb",70:"86f2a982",114:"e665718d",138:"54590fd2",182:"c276ecb2",203:"c6aad055",205:"83d480e9",347:"bc816bf2",397:"6194ac84",406:"0cbb83d7",465:"f7b7f9b7",506:"9aa62c0e",522:"308aae28",523:"a0323d9f",533:"b2b675dd",534:"4b8121dd",563:"c685778b",592:"b39cdcf9",649:"512fbd77",743:"61d4c13a",745:"64abd3af",809:"840a98fb",822:"a00af9f0",873:"cabda5f8",899:"b985118d",921:"c37b4a03",944:"b2e1a0c8",945:"df322e14",1021:"901c37e5",1032:"a67ca768",1046:"4cb6c19a",1074:"9e8f4e9c",1297:"34cf6fc7",1342:"a766a857",1425:"fc8a94e3",1441:"382c5d2b",1447:"4974f5d2",1477:"b2f554cd",1625:"de311ed4",1676:"819ef483",1705:"94fb813f",1713:"a7023ddc",1724:"5087625a",1830:"b00bc883",1859:"2295be0e",1896:"25622900",1981:"b799648a",2079:"1a16e8bf",2082:"e85ba0e6",2111:"79665d43",2178:"ba322490",2193:"c5b2f0f9",2217:"d7fbbe43",2242:"1dcf37fa",2323:"6c80b6fe",2339:"17896441",2451:"fb50ea3a",2472:"65a10ffa",2535:"814f3328",2549:"5c63ba15",2599:"e44de27e",2609:"6269f1c0",2667:"368cce37",2778:"608238a8",2783:"f425c855",2896:"abc85917",2938:"c95aa39f",2958:"86063cd3",3010:"56c3a9b2",3089:"a6aa9e1f",3152:"33a21d7d",3154:"c6346fcf",3163:"232c546d",3207:"6603ef13",3233:"59a6f192",3237:"1df93b7f",3259:"03ccf92d",3296:"181ef600",3317:"846a5e19",3324:"1ce91f4c",3414:"35a7a45c",3427:"bd80aa65",3505:"72486833",3584:"ed75cfcb",3608:"9e4087bc",3636:"8b4dd820",3714:"894e67a6",3751:"3720c009",3820:"a5e1f61e",3840:"562ca3e9",3870:"5df556a2",3879:"2d629ea6",3973:"f523fb3f",4013:"01a85c17",4059:"9cb03f5d",4117:"fd684bd6",4121:"55960ee5",4157:"83e10f72",4220:"2bbe04e6",4322:"69c5f318",4356:"a9a76bf7",4386:"ae79aff5",4459:"19eded63",4617:"95366386",4651:"94f3d131",4672:"03685665",4781:"12f1535e",4918:"24bda87b",4929:"330dfcdb",4940:"c11c87f7",5018:"cd509849",5240:"22de4147",5248:"6101b3fc",5326:"af231220",5375:"97615df2",5414:"724f3974",5625:"657ac0bc",5708:"f0057c03",5765:"d18d294a",5776:"f0e3a130",5803:"ff8f5ed0",6026:"51dec273",6049:"f213dd13",6088:"88efc5aa",6103:"ccc49370",6120:"d4840880",6158:"51e516cc",6308:"e8dc4d98",6317:"959a8cfe",6328:"c0d19596",6521:"014457dd",6536:"3ed6e2e9",6608:"5099f3e0",6623:"b104dd1e",6690:"4816649b",6692:"2ae2e7fe",6766:"e5638e51",6843:"9f97f9d1",6932:"aaabcfd8",7007:"8593ff01",7034:"3e03f778",7134:"0b40a488",7138:"38a042e4",7141:"b5abacaa",7149:"822c343e",7159:"a8ce95ee",7220:"7591d420",7251:"ba5b9f11",7363:"583db3ef",7366:"75281220",7377:"708d858d",7438:"9c021584",7480:"eb17771c",7536:"f6e0e63c",7573:"48b6ff5f",7622:"dbbb982f",7653:"31de1779",7679:"83245ae6",7698:"cd23aec9",7714:"7bdcd7a7",7722:"213182ef",7741:"7d88b63f",7759:"ff38b1ce",7847:"43b416ef",7875:"021eaa84",7881:"2658ced2",7918:"10ce918d",7920:"1a4e3797",8145:"006e489c",8176:"5660752d",8215:"1cfced13",8221:"6af14956",8262:"059d1c6a",8290:"3fe48f60",8445:"99245987",8502:"b4657d81",8514:"d651e2ee",8532:"d1b15a6d",8533:"f3d54061",8566:"9dce5486",8610:"6875c492",8626:"c6f0d1b2",8768:"524ce9a0",8800:"e6fb1369",8811:"3289a752",8860:"0d040286",8893:"ba1dc56d",8960:"6bf124c2",8989:"d4bf7e47",9043:"473de3ed",9106:"72dd8f7e",9133:"02e265ea",9179:"79551407",9341:"a35cf155",9372:"07f59c2a",9387:"b0f1c099",9469:"3b85f227",9514:"1be78505",9558:"f41c0109",9579:"09b168a7",9626:"81e486a8",9671:"0e384e19",9817:"4f561e31",9924:"df203c0f",9944:"08570680",9973:"4213e5b1",9979:"987564cc"}[e]||e)+"."+{10:"b08d2c29",53:"56f5569d",70:"5d814a9b",114:"22a38c18",138:"05d927ca",182:"c229eebf",203:"6430dd86",205:"7e07f847",347:"6de1587c",397:"06fc0336",406:"48100623",465:"1cbd3a08",506:"3f0bed63",522:"6de37e89",523:"5edc8952",533:"b499b841",534:"12bc2380",563:"995980f6",592:"581e4b87",649:"10a887e2",743:"89c00deb",745:"769a0da2",809:"ff094bc8",822:"ba62cf4a",873:"919ad21c",899:"06293860",921:"f0615854",944:"a49ec1c2",945:"e05bb438",1021:"d78c26da",1032:"8ea0ed17",1046:"5cee8554",1074:"d3f71dc8",1297:"dee27ee5",1342:"ad19af20",1425:"3370fdba",1441:"f8883a2a",1447:"a45d676f",1477:"12630173",1625:"0d61b40e",1676:"57da3d2f",1705:"fa2462b2",1713:"299c19b3",1724:"2461c2e7",1830:"9c19e957",1859:"7e645e6c",1896:"a5170eed",1947:"bda1afcc",1981:"4e218966",2079:"1fb6071f",2082:"bdc07deb",2111:"b6f563f5",2178:"13069292",2193:"4d4620c9",2217:"60800c25",2242:"8e672378",2323:"f0b907ab",2339:"edf3f98f",2451:"9166135e",2472:"262fc4a4",2535:"2e15ba67",2549:"808af98c",2599:"bbd5ecaa",2609:"dbc29b18",2667:"37faff5c",2778:"d790be48",2783:"23009f9f",2896:"a2923a83",2938:"309e0760",2958:"5d79ab5f",3010:"d11d7eb3",3089:"a7e9e028",3152:"993d4689",3154:"fb63ac2a",3163:"4913f1cb",3207:"a41cd11b",3233:"5519362d",3237:"bed82708",3259:"d48e5470",3296:"717aa32f",3317:"7ce74ef2",3324:"a67d3beb",3414:"f94d9eaa",3427:"07ae56ee",3505:"486eb6ae",3584:"b0f7a881",3608:"6b194cc3",3636:"bac4874d",3714:"086e1f22",3751:"e6a1ff2c",3820:"75a6ed57",3840:"c43abc7d",3866:"6f22f670",3870:"74568e5d",3879:"f8d34b3d",3893:"43838999",3973:"83c24d96",4013:"17c10467",4059:"2e148b4d",4117:"ab52d392",4121:"42bd0c53",4157:"8f491252",4178:"a197f856",4220:"8cf11d92",4322:"1d5a3008",4356:"8c8bcc20",4386:"da92827f",4459:"997f1191",4617:"61371bc1",4651:"fd0510fd",4670:"c6602195",4672:"73c9ed61",4781:"007e12d4",4918:"cbf6de50",4929:"5351f9c1",4940:"09f6f3d2",5018:"9d824327",5240:"641ec7fc",5248:"e7820b8e",5326:"6661ae24",5375:"f19ca62b",5414:"21a11f92",5625:"c4b6a5f2",5708:"9e67218b",5765:"efe24b1a",5776:"9289db31",5803:"7724e22b",6026:"6c6a5338",6049:"2f6bc428",6088:"0e41b8ce",6103:"1191af98",6120:"11c2c21b",6158:"b48a3263",6308:"326b3a51",6317:"d67837c1",6328:"9713d629",6521:"ca826858",6536:"c4261de2",6608:"d1485738",6623:"e06e9c08",6690:"e532397c",6692:"9034be99",6766:"d8eb51cb",6843:"efcf1441",6932:"1dc6e4a1",7007:"e073c454",7034:"1f958f58",7134:"c4e78e68",7138:"3f5eca4c",7141:"aa741b27",7149:"663ec94f",7159:"49c3ddcc",7171:"ed520d1e",7220:"31bb995a",7251:"75e3d1b3",7363:"95f0b138",7366:"26b00857",7377:"b821d601",7438:"ab961c74",7480:"21d051e3",7536:"3a66b423",7573:"09c42214",7622:"b17356bb",7653:"c909c603",7679:"03338c23",7698:"3d0c4450",7714:"b9bb2cdb",7722:"d40b4c8b",7735:"b12007f7",7741:"ff546f54",7759:"c79de414",7847:"2c70676d",7849:"bb1a7e66",7875:"adb70247",7881:"e7f02a58",7918:"31bdb7d6",7920:"a7306422",8145:"ddaf0a3e",8176:"7df7d400",8215:"bcf97e6c",8221:"0aaa6e17",8262:"c004698d",8290:"f2aad630",8306:"5f30899d",8445:"4fc783d0",8502:"7b175b26",8514:"43a52878",8532:"51e398af",8533:"caa2477a",8566:"1e0f7d27",8610:"58abc53b",8626:"d16e7ea7",8768:"a65a917e",8777:"e2ef1f93",8800:"a0bdbe06",8811:"fbe331d3",8860:"73ca0e0b",8893:"dfc51795",8960:"2d89c3a9",8989:"17f0efbe",9043:"ac1acbcd",9106:"3d077178",9127:"02f87f8d",9133:"7057011c",9179:"9200eda1",9341:"afc58592",9372:"6701e01f",9387:"eaedac00",9469:"3235e126",9514:"0e6e9a66",9558:"7d7d2efa",9579:"b8dde927",9626:"9db760d6",9671:"f2f2b025",9817:"5036f126",9924:"dc218f14",9944:"161e6f22",9973:"eb013531",9979:"6bd3f7f0"}[e]+".js",r.miniCssF=e=>{},r.g=function(){if("object"==typeof globalThis)return globalThis;try{return this||new Function("return this")()}catch(e){if("object"==typeof window)return window}}(),r.o=(e,f)=>Object.prototype.hasOwnProperty.call(e,f),d={},c="docs:",r.l=(e,f,a,b)=>{if(d[e])d[e].push(f);else{var t,o;if(void 0!==a)for(var n=document.getElementsByTagName("script"),i=0;i{t.onerror=t.onload=null,clearTimeout(s);var c=d[e];if(delete d[e],t.parentNode&&t.parentNode.removeChild(t),c&&c.forEach((e=>e(a))),f)return f(a)},s=setTimeout(l.bind(null,void 0,{type:"timeout",target:t}),12e4);t.onerror=l.bind(null,t.onerror),t.onload=l.bind(null,t.onload),o&&document.head.appendChild(t)}},r.r=e=>{"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(e,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(e,"__esModule",{value:!0})},r.p="/",r.gca=function(e){return e={17896441:"2339",25622900:"1896",33942509:"10",72486833:"3505",75281220:"7366",79551407:"9179",95366386:"4617",99245987:"8445","935f2afb":"53","86f2a982":"70",e665718d:"114","54590fd2":"138",c276ecb2:"182",c6aad055:"203","83d480e9":"205",bc816bf2:"347","6194ac84":"397","0cbb83d7":"406",f7b7f9b7:"465","9aa62c0e":"506","308aae28":"522",a0323d9f:"523",b2b675dd:"533","4b8121dd":"534",c685778b:"563",b39cdcf9:"592","512fbd77":"649","61d4c13a":"743","64abd3af":"745","840a98fb":"809",a00af9f0:"822",cabda5f8:"873",b985118d:"899",c37b4a03:"921",b2e1a0c8:"944",df322e14:"945","901c37e5":"1021",a67ca768:"1032","4cb6c19a":"1046","9e8f4e9c":"1074","34cf6fc7":"1297",a766a857:"1342",fc8a94e3:"1425","382c5d2b":"1441","4974f5d2":"1447",b2f554cd:"1477",de311ed4:"1625","819ef483":"1676","94fb813f":"1705",a7023ddc:"1713","5087625a":"1724",b00bc883:"1830","2295be0e":"1859",b799648a:"1981","1a16e8bf":"2079",e85ba0e6:"2082","79665d43":"2111",ba322490:"2178",c5b2f0f9:"2193",d7fbbe43:"2217","1dcf37fa":"2242","6c80b6fe":"2323",fb50ea3a:"2451","65a10ffa":"2472","814f3328":"2535","5c63ba15":"2549",e44de27e:"2599","6269f1c0":"2609","368cce37":"2667","608238a8":"2778",f425c855:"2783",abc85917:"2896",c95aa39f:"2938","86063cd3":"2958","56c3a9b2":"3010",a6aa9e1f:"3089","33a21d7d":"3152",c6346fcf:"3154","232c546d":"3163","6603ef13":"3207","59a6f192":"3233","1df93b7f":"3237","03ccf92d":"3259","181ef600":"3296","846a5e19":"3317","1ce91f4c":"3324","35a7a45c":"3414",bd80aa65:"3427",ed75cfcb:"3584","9e4087bc":"3608","8b4dd820":"3636","894e67a6":"3714","3720c009":"3751",a5e1f61e:"3820","562ca3e9":"3840","5df556a2":"3870","2d629ea6":"3879",f523fb3f:"3973","01a85c17":"4013","9cb03f5d":"4059",fd684bd6:"4117","55960ee5":"4121","83e10f72":"4157","2bbe04e6":"4220","69c5f318":"4322",a9a76bf7:"4356",ae79aff5:"4386","19eded63":"4459","94f3d131":"4651","03685665":"4672","12f1535e":"4781","24bda87b":"4918","330dfcdb":"4929",c11c87f7:"4940",cd509849:"5018","22de4147":"5240","6101b3fc":"5248",af231220:"5326","97615df2":"5375","724f3974":"5414","657ac0bc":"5625",f0057c03:"5708",d18d294a:"5765",f0e3a130:"5776",ff8f5ed0:"5803","51dec273":"6026",f213dd13:"6049","88efc5aa":"6088",ccc49370:"6103",d4840880:"6120","51e516cc":"6158",e8dc4d98:"6308","959a8cfe":"6317",c0d19596:"6328","014457dd":"6521","3ed6e2e9":"6536","5099f3e0":"6608",b104dd1e:"6623","4816649b":"6690","2ae2e7fe":"6692",e5638e51:"6766","9f97f9d1":"6843",aaabcfd8:"6932","8593ff01":"7007","3e03f778":"7034","0b40a488":"7134","38a042e4":"7138",b5abacaa:"7141","822c343e":"7149",a8ce95ee:"7159","7591d420":"7220",ba5b9f11:"7251","583db3ef":"7363","708d858d":"7377","9c021584":"7438",eb17771c:"7480",f6e0e63c:"7536","48b6ff5f":"7573",dbbb982f:"7622","31de1779":"7653","83245ae6":"7679",cd23aec9:"7698","7bdcd7a7":"7714","213182ef":"7722","7d88b63f":"7741",ff38b1ce:"7759","43b416ef":"7847","021eaa84":"7875","2658ced2":"7881","10ce918d":"7918","1a4e3797":"7920","006e489c":"8145","5660752d":"8176","1cfced13":"8215","6af14956":"8221","059d1c6a":"8262","3fe48f60":"8290",b4657d81:"8502",d651e2ee:"8514",d1b15a6d:"8532",f3d54061:"8533","9dce5486":"8566","6875c492":"8610",c6f0d1b2:"8626","524ce9a0":"8768",e6fb1369:"8800","3289a752":"8811","0d040286":"8860",ba1dc56d:"8893","6bf124c2":"8960",d4bf7e47:"8989","473de3ed":"9043","72dd8f7e":"9106","02e265ea":"9133",a35cf155:"9341","07f59c2a":"9372",b0f1c099:"9387","3b85f227":"9469","1be78505":"9514",f41c0109:"9558","09b168a7":"9579","81e486a8":"9626","0e384e19":"9671","4f561e31":"9817",df203c0f:"9924","08570680":"9944","4213e5b1":"9973","987564cc":"9979"}[e]||e,r.p+r.u(e)},(()=>{var e={1303:0,532:0};r.f.j=(f,a)=>{var d=r.o(e,f)?e[f]:void 0;if(0!==d)if(d)a.push(d[2]);else if(/^(1303|532)$/.test(f))e[f]=0;else{var c=new Promise(((a,c)=>d=e[f]=[a,c]));a.push(d[2]=c);var b=r.p+r.u(f),t=new Error;r.l(b,(a=>{if(r.o(e,f)&&(0!==(d=e[f])&&(e[f]=void 0),d)){var c=a&&("load"===a.type?"missing":a.type),b=a&&a.target&&a.target.src;t.message="Loading chunk "+f+" failed.\n("+c+": "+b+")",t.name="ChunkLoadError",t.type=c,t.request=b,d[1](t)}}),"chunk-"+f,f)}},r.O.j=f=>0===e[f];var f=(f,a)=>{var d,c,b=a[0],t=a[1],o=a[2],n=0;if(b.some((f=>0!==e[f]))){for(d in t)r.o(t,d)&&(r.m[d]=t[d]);if(o)var i=o(r)}for(f&&f(a);n - + @@ -34,7 +34,7 @@ of Podman Desktop: not just local container engines, but Kubernetes too. More im providing tools that allow you to manage both environments and seamlessly move between them.

Some of these features were available in development mode over the last few releases, but since they are now in the release build, we will do a full roundup and talk about all the Kind features.

  • Kind Installation: Install Kind from the status bar
  • Manage Kind Clusters: Create and manage Kind clusters from Settings > Resources
  • Using Kind: Deploying YAML and sharing images to a cluster
  • Kind Ingress: Install a Contour ingress controller
  • UX and UI Improvements: Updated preferences and telemetry prompt

Podman Desktop 0.14 is now available. Click here to download it!

Podman-desktop-0-14-hero

· 4 min read
Tim deBoer

This release note covers Podman Desktop 0.13 release changes.

  • Podman Version: Podman 4.4.4 now included in Windows and Mac installers.
  • Compose: Support for installing Docker Compose.
  • Extensions: Improved extension support for Podman Desktop with additional capabilities.
  • UX and UI Improvements: Welcome page, task manager, resources, and update alerts.

Podman Desktop 0.13 is now available. Click here to download it!

Podman-desktop-0-13-hero

· 5 min read
Florent Benoit

The 5 things to know being a Docker user by using Podman Desktop:

  • Use a single UI: Podman Desktop works with several container engines, including Docker.
  • The compatibility mode: How to ensure tools are working with Podman instead of Docker.
  • Compose support: How to work with Compose files and Podman.
  • Kubernetes support: How to use Kubernetes with Podman.
  • Security: Use rootless mode or containers without root privileges.

5-things-to-know-for-a-docker-user-hero

· 5 min read
Stevan Le Meur

This release note covers Podman Desktop 0.12 release changes.

  • Podman Version: Podman 4.4.1 now included in Windows and Mac installers.
  • Containers Configuration: Configure port mappings for an image without exported ports.
  • Windows Home Support: Podman Desktop now supports Windows Home Edition.
  • Start minimized: Option to start Podman Desktop minimized to system tray.
  • UX and UI Improvements: Consistent actions, placeholder for logs, unified icons and others.

Podman Desktop 0.12 is now available. Click here to download it!

podman-desktop-0-12-hero

· 10 min read
Stevan Le Meur

This release note covers Podman Desktop 0.11 release changes.

  • Air-Gapped Installation: New all-in-one binaries for air-gapped installation.
  • Feedback: Submit feedback directly from Podman Desktop.
  • Docker Compatibility Mode: Information about the Docker compatibility mode.
  • Proxy Setting: Toggle on/off the proxy setting.
  • Deploy to Kubernetes: Select the namespace to deploy to Kubernetes.
  • Registry Configuration: Simplified registry configuration for well known registries.
  • UX/UI Improvements: View pod's container logs, better visual feedback, configurable editor font size, and more.

Podman Desktop 0.11 is now available. Click here to download it!

· 5 min read
Dev Kumar

This release note covers Podman Desktop 0.10 release changes.

  • Containers Configuration: Container creation wizzard allowing to define environment variables, networking and more configuration options.
  • Kubernetes Improvements: Play Kubernetes YAML, custom Kubeconfig path support, reload of kube context.
  • Registries Configuration: Revamped registries configuration UI.
  • Podman Version: Podman 4.3.1 now included in Windows and Mac installers.
  • UX/UI Improvements: Improved lists, better contrast, and more.

Podman Desktop 0.10 is now available. Click here to download it!

· 7 min read
Florent Benoit

GitHub announced last week that Codespaces is available for everyone and it includes free minutes.

Let see how we can use a Development Container having all the tools to build and run Podman Desktop. The Development Container works locally using Visual Studio Code but in this blog post we will see how it works directly with a simple click from GitHub.

The challenges are to run a desktop tool (Podman Desktop) and running a container engine (Podman) inside this Development Container without using too many memory !

- + \ No newline at end of file diff --git a/blog/5-things-to-know-for-a-docker-user.html b/blog/5-things-to-know-for-a-docker-user.html index 89ce721c627..296ff782982 100644 --- a/blog/5-things-to-know-for-a-docker-user.html +++ b/blog/5-things-to-know-for-a-docker-user.html @@ -13,13 +13,13 @@ - +

5 things to know about Podman Desktop for a Docker user

· 5 min read
Florent Benoit

The 5 things to know being a Docker user by using Podman Desktop:

  • Use a single UI: Podman Desktop works with several container engines, including Docker.
  • The compatibility mode: How to ensure tools are working with Podman instead of Docker.
  • Compose support: How to work with Compose files and Podman.
  • Kubernetes support: How to use Kubernetes with Podman.
  • Security: Use rootless mode or containers without root privileges.

5-things-to-know-for-a-docker-user-hero


Use Podman Desktop to interact with containers running in Docker

Docker Desktop provides a UI to interact with containers and images. But the UI depends on Docker API and it is not possible to use the UI with Docker and Podman at the same time.

Podman Desktop is a multi-engine UI tool. The UI is compatible with the API of Docker and Podman. It means all containers and images from all the engines at the same time are visible in the UI.

When migrating from Docker to Podman, you can use Podman Desktop to interact with containers running in Docker. Explore all commands and features of Podman Desktop and see all the resources from Docker.

Many container engines at the same time

Docker compatibility mode

Using Podman with Podman Desktop or with the Podman CLI is straightforward. But some tools expect to find docker CLI or docker.sock socket. In this case, you have to use the compatibility mode of Podman.

Socket file compatibility

The socket compatibility mode is a feature of Podman that allows to bind the Podman socket under the Docker socket path.

On Windows the socket compatibility mode is always enabled by default. On macOS, by using the .pkg installer it is active by default. But when installing with brew, it will not be there because it requires some admin permissions.

That is not an issue because you can enable it by invoking a CLI tool that will setup the compatibility mode.

For example if you use TestContainers in your Java project, you can use the compatibility mode to ensure that the tool will use Podman instead of Docker.

CLI compatibility

If you have scripts relying on docker CLI, you can use the compatibility mode to ensure that the tool is working with Podman instead of Docker.

If you have the docker CLI installed on your computer, you can use the socket file compatibility of docker to ensure that the tool is working with Podman engine instead of Docker.

If you do not have the docker CLI installed on your computer, you can Create a script called docker that will call the podman CLI

NOTE: creating a shell prompt alias, for example alias docker=podman, will not work inside scripts that you call.

Compose

As a user of Docker, you might use docker compose (or docker-compose) to run some of your applications.

For now Podman does not include a Compose support directly in the CLI with a command podman compose.

Compose can work with the Podman socket.

Based on the compatibility mode (see section about Docker compatibility mode):

You can now use the compose binary to run your applications and it will use Podman engine.

Podman Desktop has a compose extension that can fetch compose binary if not already available on the filesystem.

Podman Desktop UI displays the containers created by Compose are in the same group.

Compose support in the UI

Kubernetes

It is possible to start a Kubernetes cluster with Docker.

Podman supports directly a subset of Kubernetes resources that you can use with .yaml files.

For example if you only want to create a Pod resource, you can use the Play Kubernetes YAML button from the Containers list screen with your .yaml file. No need to install or start a Kubernetes cluster.

Play Kubernetes YAML

It is possible to do the counter-part. Export the definition of a container or pod to a Kubernetes resource. You can use the Generate kube button from the kebab menu of a given container or pod.

Kubernetes generate

Podman handles pods and in the Podman Desktop UI, you can see all the pods inside a Pod section. All containers inside the pod are in the same group.

Pods in the UI

Containers from pod

An experimental kind extension is bringing the creation of full-blown Kubernetes cluster with Podman.

Rootless mode

One of the difference of Docker and Podman is the way they handle containers. Docker requires root privileges to run containers by default. Podman can run containers without root privileges by default.

It means that for example, starting a container with a port < 1024 will not work. You need to use a port > 1024.

If you still need to create containers with a port < 1024, you can change the Podman machine configuration of the Podman Machine if you are on Windows or macOS.

The command is podman machine set --rootful to enable the execution with root privileges or podman machine set --rootful=false to switch back to rootless mode.

- + \ No newline at end of file diff --git a/blog/archive.html b/blog/archive.html index fae26a3440f..c75b2ca6182 100644 --- a/blog/archive.html +++ b/blog/archive.html @@ -13,13 +13,13 @@ - + - + \ No newline at end of file diff --git a/blog/develop-using-devcontainer.html b/blog/develop-using-devcontainer.html index b8e34a7d811..5e75bc383a7 100644 --- a/blog/develop-using-devcontainer.html +++ b/blog/develop-using-devcontainer.html @@ -13,7 +13,7 @@ - + @@ -23,7 +23,7 @@ Using --privileged we don't really know what are the privilege that are required while specifying all of them, people are aware of what is granted/denied.

"runArgs": [
"--cap-add=sys_admin",
"--security-opt",
"seccomp=unconfined",
"--device",
"/dev/fuse",
"--security-opt",
"label=disable",
"--security-opt",
"apparmor=unconfined"
],

Source code of Podman Desktop needs to be editable within the DevContainer so it needs to be mounted.

"workspaceMount": "source=${localWorkspaceFolder},target=/workspace,type=bind",
"workspaceFolder": "/workspace",

Then we need a command to build Podman Desktop.

For that, we use onCreateCommand hook with a custom command

"onCreateCommand": "${containerWorkspaceFolder}/.devcontainer/onCreateCommand.sh",

and in the .devcontainer folder the onCreateCommand.sh script is the following

#!/bin/sh
yarn

MODE=production yarn run build && yarn run electron-builder build --linux --dir --config .electron-builder.config.cjs

Two instructions:

  1. Fetch all Node.js dependencies.
  2. build Podman Desktop in the dist folder using Linux as target Operating System.

After the start of the container, how to launch Podman Desktop, the website and VNC, etc ?

Just use postStartCommand hook.

"postStartCommand": "${containerWorkspaceFolder}/.devcontainer/postStartCommand.sh",

and in the .devcontainer folder the postStartCommand.sh script is the following:

#!/bin/sh

# Start all services
/usr/bin/supervisord -c /etc/supervisord.conf &

# wait X server to be ready or after 2mn exit
echo "Waiting for X server to be ready"
timeout 120 bash -c 'until xdpyinfo -display :0 &> /dev/null; do printf "."; sleep 1; done'

# launch podman desktop
echo "Launching Podman Desktop"
cd dist/linux-unpacked/&& ./podman-desktop &

# Launch the 9000 redirect after 20 seconds
sleep 20
websockify --web=/usr/share/novnc localhost:9000 localhost:5900 &

# launch the website rendering
echo "Launching Website"
cd website && yarn start

It starts VNC and noVNC, start precompiled Podman Desktop and start the documentation rendering.

It is not launching the Watch mode/development mode of Podman Desktop as it requires a container having more than 8GB of memory.

Picking up a larger instance with for example 16GB, it's possible to use development mode.

Of course, to make VNC happy, we need to specify the DISPLAY environment variable.

"remoteEnv": {
"DISPLAY": ":0"
}

When the DevContainer is fully available, we want to have a way to quickly open the Website rendering URL and noVNC

Let's tweak the devcontainer.json file by adding the portsAttributes section

"portsAttributes": {
"9000": {
"label": "vnc",
"onAutoForward": "openPreview"
},
"3000": {
"label": "website"
}
}

After all post-creation steps, the Preview browser inside the VS Code editor will open a window to VNC. And another port (3000) is flagged for the website.

Using the DevContainer.json on Github Codespace

As a user, opening a workspace with all what we configured is done using a single click.

Go to https://github.com/containers/podman-desktop then click on the < > Code dropdown and click on Create codespace on main button.

Open Codespace

Once you click on the button, the codespace is setting up:

Preparing Codespace

After few minutes, as there is not yet prebuilt codespaces, the codespace is opening.

The simple Browser displays the noVNC window: Opening Codespace

Click on the connect button. Then on the terminal you can enter podman run quay.io/podman/hello and the container is detected in Podman Desktop. Testing Codespace

It's also possible using the port widget to get on 3000 port by clicking on the world icon a preview of the website in another tab. Changing source code of the website will refresh the content of the window.

Depending on the usecase, it's also possible to open documentation in the preview browser.

Edit website Codespace

Conclusion

The DevContainer image for Podman Desktop is recent so it'll probably evolve over time by adding new capabilities but it allows you to easily build/run/experiment and contribute to the tool or the website.

- + \ No newline at end of file diff --git a/blog/podman-desktop-release-0.10.html b/blog/podman-desktop-release-0.10.html index 656e5ef9b8b..e4d4c53a6b4 100644 --- a/blog/podman-desktop-release-0.10.html +++ b/blog/podman-desktop-release-0.10.html @@ -13,13 +13,13 @@ - +

Release Notes - Podman Desktop 0.10

· 5 min read
Dev Kumar

This release note covers Podman Desktop 0.10 release changes.

  • Containers Configuration: Container creation wizzard allowing to define environment variables, networking and more configuration options.
  • Kubernetes Improvements: Play Kubernetes YAML, custom Kubeconfig path support, reload of kube context.
  • Registries Configuration: Revamped registries configuration UI.
  • Podman Version: Podman 4.3.1 now included in Windows and Mac installers.
  • UX/UI Improvements: Improved lists, better contrast, and more.

Podman Desktop 0.10 is now available. Click here to download it!


Release Details

New configuration wizzard to create containers (#773)

Until now, we could only specify port binding when building images to start containers. The create container wizzard now includes several options enabling configuring volumes, environment variables, restart policy and settings on networking and security. It is also possible to reuse an existing (and already configured) a network when creating containers.

new container creation wizard

Kubernetes Capabilities Improvements

Custom Kubeconfig file path (#780)

Kubeconfig path location is now configurable from Settings > Preferences > Kubernetes: Kubeconfig and can be set to a custom path. By default, Podman Desktop use the path $HOME/.kube/config for the Kubeconfig file.

custom kubeconfig file path

Play Kubernetes YAML from the Pods list (#739)

Podman Desktop enables to play existing Kubernetes YAML files. This is now available from Play Kubernetes YAML button added to the Pods list, in addition to the Containers list.

play k8s yaml

Kube context automatically reloaded when updated (#813)

Any change to the kube context will now be detected by Podman Desktop in its running state. The system tray, allowing to select which Kubernetes environment to work with, will now reload the kube context without restarting Podman Desktop.

Revamped Container Registries UI (#446)

The registries configuration UI has been revamped. Instead of using tiles for displaying the registries, now it uses a list where each registry can be added or edited directly in the list. The kebab menu provides options to edit or remove a registry from the list.

registries

Update to Podman 4.3.1 (#913)

Podman Desktop 0.10 is now embedding Podman 4.3.1 in Windows and macOS installers.

UI/UX Improvements

Improved lists UX (#877)

To reduce the width used in the lists when displaying all the icons, main actions icons are now always displayed (before it was on hover) and the secondary actions are displayed in a kebab menu. For example Start/Stop and delete are primary actions while open the browser, inspect, generate kube yaml, etc. are secondary options.

kebab menu

Delay appearance of text in navbar (#767)

When minimizing or expanding the navbar, the text was overlapping for a few second the page. Now it's displayed with a fading animation.

Selected state: better text color contrast (#802)

In the Images page, on hover for both the image and the name column, the text contrast has been increased for better visibility: violet indicates that you have selected it.

text color when hover

On Linux and Windows, the menu bar is now hidden by default (#668)

With this change, the menu bar looks more integrated to the Operating System. The menu can appear if you hit the Alt key. Thanks to Dylan M. Taylor for contributing to fix this.

Exit when clicking on the close icon of the dashboard on Linux (#671)

For most users on Linux, there is no tray icon support. In this situation, when closed, Podman Desktop continues to run in background. Dylan M. Taylor added a property to exit the app by default when clicking on the close icon. For people having tray icon support or with the desire of a different behavior, it is possible to disable it from the Settings.


Other Notable Enhancements

  • Rename Started into Age in Containers list.(#878)
  • Added domain validation when adding a registry. (#838)
  • Provided a consistent behavior with Podman CLI, podman-machine-default is now the default name when creating a Podman machine from Podman Desktop. (#775)

Notable bug fixes

  • Fixed error handling when pulling images of Desktop Extensions. (#782)
  • Fixed use of the full height of the screen when displaying log in the details of a container. (#946)
  • Fixed First start of Podman Desktop on flatpak was not seeing the podman engine (#860)

Community Thank You

🎉 We’d like to say a big thank you to everyone who helped to make Podman Desktop 0.10 even better:

Final Notes

The complete list of issues fixed in this release is available here.

Get the latest release from the Downloads section of the website and boost your development journey with Podman Desktop. Additionally, visit the GitHub repository and see how you can help us make Podman Desktop better.

- + \ No newline at end of file diff --git a/blog/podman-desktop-release-0.11.html b/blog/podman-desktop-release-0.11.html index 8160d56dd03..6ffd83e7d41 100644 --- a/blog/podman-desktop-release-0.11.html +++ b/blog/podman-desktop-release-0.11.html @@ -13,7 +13,7 @@ - + @@ -27,7 +27,7 @@ See:

Provide pre-defined registries #1201

The experience of configuring a registry is getting simplified for the most popular ones. The user will be able to select a registry from a pre-defined list and will only have to provide the username and password. The following registries will be pre-defined:

  • Dockerhub
  • Red Hat Quay
  • GitHub
  • IBM Container Registry
  • Google Container Registry

UI/UX Improvements

View Pods logs #1122

The pods details view provides the ability to view the logs of each containers that might be running in a pod. Moreover, as it can also be hard to scan and identify which container is producing which output, we appended the container name at the beginning of each output and differentiate each container with a different color.

pods-logs

Improved feedback when clicking on container list action icons #1150 #1161

When starting/stopping or deleting a container, a spinner is now displayed. In case of error, a message indicating that the action failed will also be better indicated.

For containers that exit immediately or short-lived containers, the feedback is also improved and include report of error now provide a better feedback to the user #1161.

Allows to change the default font size for the editor #1160

An editor is used in several screens of Podman Desktop, from the inspect screen to container's outputs and Kubernetes YAML. The default font size is 10 pixels. It's now possible to adjust the font size to the one the one you prefer. This setting is persisted and will be used for all the editors of Podman Desktop and available from the preferences page (Settings -> Preferences).

Keep expanded state of pods when refreshing containers #1042

When switching from different screens of the application or simply refreshing the list of containers, the expanded state of each item in the list is now persisted and will be properly restored.

Click on the Pod name redirects to the Pod details page #1159

The list of containers also displays pods, now clicking on the pod name directly redirects to the Pod details page.

Improved styles of buttons for actions #984

The style of the buttons for actions on item in the list of in details pages have been improved. The background has been removed, but to make the hover state more visible, the "hover" circle is visible and the icon's color is also changing.

On lists: list-actions

On details pages: details-actions

Improved alignments in pages with lists #1182

The alignment of the items in the list of containers and pods have been improved. The header of each columns are now aligned with the text. and the actions icons are now aligned with the top of the text.

list-actions


Other Notable Enhancements

  • Statistics area in container details are always shown. (#1131)
  • Add more descriptive wording and more information to extensions. (#985)
  • Allow to install on-the fly Podman Desktop extensions using an OCI image. (#1187)
  • Display correctly non-multiplexed stream in logs (when using non interactive mode). (#1197)
  • Font changed from white to gray for non-name sections (creation date, size). (#1206)
  • Add Help/about menu for macOS/Windows/Linux. (#1207)

Documentation

Coming with this new version of Podman Desktop, the documentation has been getting attention (with number of editorial reviews) and new content have been added.

Content for helping users to migrate from Docker to Podman has been added:

Several of other improvements have been made to the documentation and the website:


Notable bug fixes

  • Update to v0.3.2 Docker Desktop API for extensions - #1070
  • Updated link to the Matrix room - #1076
  • Report error when container name already exists - #1142
  • Fixed connectivity to the Podman machine when the generated socket length is greater than 104 characters in MacOS - #1145
  • Do not use long calls for external clients - #1151
  • Invalid name/tag for images with registries using a different port - #1127
  • Invalid badge count for images when two images have the same tag - #1124
  • Fixed detection of WSL2 - #981
  • Handle invalid kubeconfig files instead of crashing - #953
  • Removed redundant actions from details pages - #1200
  • Fixed registry URL not aligned with header - #1205
  • Moved SVGs to reusable components - #1211

Extensions API has also been improved in this new release:

  • (extension-api): Allows to register a factory for kubernetes connection objects (like for container connections) - #1040
  • (extension-api): List or inspect containers, be notified on events - #1041
  • (extension-api): Allows to get provider notification - #1045
  • (dd-extension-api): Implement toast API - #1154
  • (extension-api): Moved extension properties to preferences - #948
  • (dd-extension-api): Added open dev console on dd webview in development mode - #1071
  • (extension-api): Added notes on extension and frameworks/tooling of Podman Desktop - #1166
  • (extension-api): Documentation on how to write an extension and use the api - #1172
  • (dd-extension-api): DD extensions should see only minimal information on containers - #1191

Community Thank You

🎉 We’d like to say a big thank you to everyone who helped to make Podman Desktop 0.11 even better:

Final Notes

The complete list of issues fixed in this release is available here.

Get the latest release from the Downloads section of the website and boost your development journey with Podman Desktop. Additionally, visit the GitHub repository and see how you can help us make Podman Desktop better.

- + \ No newline at end of file diff --git a/blog/podman-desktop-release-0.12.html b/blog/podman-desktop-release-0.12.html index a18223b3752..e77f1d8e626 100644 --- a/blog/podman-desktop-release-0.12.html +++ b/blog/podman-desktop-release-0.12.html @@ -13,14 +13,14 @@ - +

Release Notes - Podman Desktop 0.12

· 5 min read
Stevan Le Meur

This release note covers Podman Desktop 0.12 release changes.

  • Podman Version: Podman 4.4.1 now included in Windows and Mac installers.
  • Containers Configuration: Configure port mappings for an image without exported ports.
  • Windows Home Support: Podman Desktop now supports Windows Home Edition.
  • Start minimized: Option to start Podman Desktop minimized to system tray.
  • UX and UI Improvements: Consistent actions, placeholder for logs, unified icons and others.

Podman Desktop 0.12 is now available. Click here to download it!

podman-desktop-0-12-hero


Release Details

Update to Podman v4.4.1 #1456

Podman Desktop 0.12 embeds Podman 4.4.1 in Windows and macOS installers. Make sure to upgrade to benefit from the latest Podman features and bug fixes.

Configuring port mappings when an image has no exported port #1265

With the latest update, users can now add multiple local-to-remote port mappings when starting a container from an image that has no exported ports. This feature provides users with the flexibility to specify which ports on their local machine should map to which ports on the container, even if the container does not have any exported ports by default.

port-mapping

Installing Podman Desktop on Windows Home Edition #1268

Podman Desktop 0.12 offers the ability to be installed on Windows Home Edition. The mechanism uses Virtual Machine Platform detection, instead of hyper-v. WSL2 is still requires but can be installed along with the installation process.

install-windows-home-edition-2

Option to automatically minimize Podman Desktop on login #1374

Podman Desktop now provides a "start minimized" option when users log in onto the laptop. This option, available from the application's settings, can be useful if users want to automatically launch Podman Desktop at log in, but prefer not to have the window visible on the screen. With this feature, you can ensure that Podman Desktop is up and running in the background without any interruption to your workflows.

  • Go to Settings > Preferences > Login: Minimize to activate the option.

minimize-on-login

UI and UX Improvements

Improved actions consistency #1225

Actions displayed in the list pages for Images and Containers have been reviewed and made consistent between other pages.

action-consistency-1

Actions displayed in the header of the container's details page have been improved so that the actions are always displayed in the same order.

action-consistency-2

Consistent status icons for Pods, Containers, Images and Volumes #1326, #1377, #1459 and #1245

The status icons for Pods, Containers, Images, and Volumes have been unified and use consistent states.

pods-status-icon

Icons in empty screens have been updated to use the same consistent SVG icon as the status icons.

empty-screen-2

Placeholder when logs for containers are being fetched #1353

A placeholder is now displayed when logs are being fetched. placeholder-loading-logs

Fixed alignment in badges from the navigation sidebar #1357

Badges in the sidebar are now aligned with the title of the section.

alignement-badges

Enable/disable open browser action based on container state #1395 and #1397

The action to open the browser if a port is opened in a container, is now disabled when the container is stopped. It is also hidden in the kebab menu.

enable-disable-container-actions


Other Notable Enhancements

  • Display extension icons #1058
  • Solid Icons #1267
  • Differentiate icons compared to status icons #1268
  • Refactors window initializing #1309
  • Change window creation background color to dark #1310
  • Use Podman machine inspect to read the address to connect to the Podman machine #1364
  • Update the editor content when the pod name changes, and disable the deploy button when empty #1403
  • Ability to manually set color of tray icon for Windows and Linux #1243
  • Better UI feedback when starting pods #1242

Documentation

The documentation had many editorial reviews, and new content.


Notable bug fixes

  • Fixed handling path with spaces on Windows when installing Podman #1270
  • Removed padding from SVG icons #1253
  • Website: fixed download links for Windows and macOS binaries #1255
  • Fixed prettier commands on Windows #1266
  • Fixed new xterm instance spawn when clicking the logs route #1344
  • Fixed need to wait that telemetry has been initialized before proceeding #1373
  • Fixed new xterm instance spawn when clicking the logs route in pod details#1393
  • Fixed stop spinner if image cannot be retrieved #1394
  • Fixed escape command with quotes only for Windows #1462
  • Fixed random CRC status change #1420

Community Thank You

🎉 We’d like to say a big thank you to everyone who helped to make Podman Desktop 0.12 even better:

Final Notes

The complete list of issues fixed in this release is available here.

Get the latest release from the Downloads section of the website and boost your development journey with Podman Desktop. Additionally, visit the GitHub repository and see how you can help us make Podman Desktop better.

- + \ No newline at end of file diff --git a/blog/podman-desktop-release-0.13.html b/blog/podman-desktop-release-0.13.html index 858a8643700..7d92be34720 100644 --- a/blog/podman-desktop-release-0.13.html +++ b/blog/podman-desktop-release-0.13.html @@ -13,7 +13,7 @@ - + @@ -21,7 +21,7 @@

Release Notes - Podman Desktop 0.13

· 4 min read
Tim deBoer

This release note covers Podman Desktop 0.13 release changes.

  • Podman Version: Podman 4.4.4 now included in Windows and Mac installers.
  • Compose: Support for installing Docker Compose.
  • Extensions: Improved extension support for Podman Desktop with additional capabilities.
  • UX and UI Improvements: Welcome page, task manager, resources, and update alerts.

Podman Desktop 0.13 is now available. Click here to download it!

Podman-desktop-0-13-hero


Release details

Update to Podman v4.4.4

Podman Desktop 0.13 embeds Podman 4.4.4 in Windows and macOS installers #1456.

Compose support

You can install Docker Compose from the Podman Desktop UI #1578. This will allow you use Compose workflows using Podman.

Extensions

To make it easier to extend Podman Desktop we have:

UI and UX improvements

Welcome page #1726

The first time every user starts Podman Desktop, they will see a welcome page:

welcome-page

Note that the Welcome page will only appear the first time you run Podman Desktop 0.13.0, and none of your settings or assets in Podman Desktop will be affected by it. Over time, this page will be expanded to help with initial setup and configuration.

New Task Manager #1724

A new Task Manager has been added to the status bar to see the progress (or return to) long running tasks. To start with, building images #1725 and Podman machine #1742 are using the task manager.

task-manager

Updated Resources Settings #1582

The Settings > Resources page has been updated with a new design, making it easier to see and control your providers from a single place.

resources

The other settings pages have been updated for consistency with this new design.

Update Alerts #1827

A new alert button will appear in the status bar when future updates are available.

Prune buttons #1481, #1482, #1484

We've added buttons to prune unused volumes #1481, images #1482 and pods #1484.

prune-image


Other notable enhancements

  • Kubernetes pods are now shown in the Pods view #1312
  • Easy button to fix Docker compatibility mode on macOS #1697
  • Display extension icons #1058
  • API to cancel long running tasks #1777

Documentation

The documentation has new content:


Notable bug fixes

  • Periodically check and refresh Podman connection on Windows and Mac #1662
  • Fix inconsistent Log view behaviour #1710
  • Don't create route for regular Kubernetes clusters #1707
  • Fix copy button on empty screen #1804
  • Register extension tray items correctly #1778 and handle updates #1800

Community thank you

🎉 We’d like to say a big thank you to everyone who helped to make Podman Desktop 0.13 even better:

Final notes

The complete list of issues fixed in this release is available here.

Get the latest release from the Downloads section of the website and boost your development journey with Podman Desktop. Additionally, visit the GitHub repository and see how you can help us make Podman Desktop better.

- + \ No newline at end of file diff --git a/blog/podman-desktop-release-0.14.html b/blog/podman-desktop-release-0.14.html index 78b7183a423..8080486538d 100644 --- a/blog/podman-desktop-release-0.14.html +++ b/blog/podman-desktop-release-0.14.html @@ -13,7 +13,7 @@ - + @@ -46,7 +46,7 @@ making it easier to see and change preferences. Changes are live, no more Update 1927 This is more usable, one less prompt, and solves a window-layering issue for some users!

telemetry prompt


Other notable enhancements

  • Extension support for opening an external URL 2028 and accessing the clipboard 2023

Documentation

Naturally, we have a section in the documentation just for Kind.


Notable bug fixes

  • Avoid a dialog box if unable to check for updates 2062
  • Unable to get to the Dashboard if Kind (or Kubernetes) cluster was not running 2052

Final notes

The complete list of issues fixed in this release is available here.

Get the latest release from the Downloads section of the website and boost your development journey with Podman Desktop. Additionally, visit the GitHub repository and see how you can help us make Podman Desktop better.

- + \ No newline at end of file diff --git a/blog/podman-desktop-release-0.15.html b/blog/podman-desktop-release-0.15.html index 768d9d4d765..c46b69c7c9f 100644 --- a/blog/podman-desktop-release-0.15.html +++ b/blog/podman-desktop-release-0.15.html @@ -13,7 +13,7 @@ - + @@ -41,7 +41,7 @@ provider properties/creation pages


Other Notable Enhancements

  • We know which Settings page is used the most often, so now it's the default: Settings > Resources #2105.

  • Extensions can now use the Tasks API to let long running tasks continue in the background #2019 and the existing withProgress API also uses the task manager now #2187.

Task API

  • Images are now sorted by age #2311.

  • When you start/stop a container or pod, the button is now animated instead of having an separate spinner #2101.

  • The Settings > Preferences page now has a search bar #2128.

Search preferences

  • The Help page has been updated #431.

Updated Help


Notable Bug Fixes

  • There was no way to see log or outcome if you leave the Kind cluster creation page #2079.
  • Kind image load doesn't show a notification #2225.
  • Fix odd selection in Settings > Extensions #2130.
  • Menus are now cleaned up properly when extensions are stopped #2188.
  • Kind clusters are now cleaned up when Podman machine is stopped #2306.

Final notes

The complete list of issues fixed in this release is available here.

Get the latest release from the Downloads section of the website and boost your development journey with Podman Desktop. Additionally, visit the GitHub repository and see how you can help us make Podman Desktop better.

- + \ No newline at end of file diff --git a/blog/podman-desktop-release-1.0.html b/blog/podman-desktop-release-1.0.html index 11a75f61fb7..21e78cd9d7e 100644 --- a/blog/podman-desktop-release-1.0.html +++ b/blog/podman-desktop-release-1.0.html @@ -13,7 +13,7 @@ - + @@ -94,7 +94,7 @@ to get us here:

ucomesdag, xbabalov, zezo2019.


Final notes

The complete list of issues fixed in this release is available here and here.

Get the latest release from the Downloads section of the website and boost your development journey with Podman Desktop. Additionally, visit the GitHub repository and see how you can help us make Podman Desktop better.

- + \ No newline at end of file diff --git a/blog/podman-desktop-release-1.1.html b/blog/podman-desktop-release-1.1.html index affea1cb974..6933221f588 100644 --- a/blog/podman-desktop-release-1.1.html +++ b/blog/podman-desktop-release-1.1.html @@ -13,7 +13,7 @@ - + @@ -26,7 +26,7 @@ automatically check for and install extension updates.

- + \ No newline at end of file diff --git a/blog/podman-desktop-release-1.2.html b/blog/podman-desktop-release-1.2.html index 425da06c744..1d771f514d4 100644 --- a/blog/podman-desktop-release-1.2.html +++ b/blog/podman-desktop-release-1.2.html @@ -13,13 +13,13 @@ - +

Release Notes - Podman Desktop 1.2

· 7 min read
Charlie Drage

Podman Desktop 1.2 Release! 🎉

We're excited to announce the release of Podman Desktop version 1.2.0! This release includes many new features (Kubernetes, Compose and extension support!), bug fixes, and improvements to enhance your container management experience. Here's a summary of the key changes in this release:

  • Added start/stop/delete/restart buttons for Compose: You can now make changes to an entire Compose group of containers
  • Kubernetes context on the status bar: Choose from multiple Kubernetes contexts more easily all from the status bar
  • Rename images: Rename an image with a click of a button
  • Protocol handler support: Added support for protocol handlers such as open podman-desktop:extension/redhat.openshift-local
  • Troubleshooting page: A troubleshooting page for helping diagnose Podman Desktop related development issues

Podman Desktop 1.2 is now available. Click here to download it!

Podman-desktop-1-2-hero


Release Details

Added start/stop/delete/restart buttons for Compose

In the last month we've been addind support for more Compose features. Before you were only able to control a group of containers if they were in a Pod. Now we have added the ability to control a group of Compose containers. You can now start, stop, delete and restart a group of containers launched by either docker-compose or podman-compose.

Stay tuned as we add even more features to Compose! If you have any feedback or feature requests, feel free to open an issue or start a discussion on GitHub.

Kubernetes context on the status bar

With Kubernetes context on the status bar, you can switch from one context to another in just a couple of clicks. Easily switch to a different cluster all together. If there are multiple contexts available, you can now click and pick which one to use.

Rename images

Deployed an image but now you need to rename it / add a new tag? Podman Desktop allows you to edit an image now. Thanks to an awesome contributor @tuckerrc who added the new feature.

Troubleshooting page

Developing an extension for Podman Desktop? Want to view the logs of Podman Desktop as well as ping your container connection? We now have a troubleshooting page!

Click on the lightbulb button on the bottom right to access the page.

Protocol handler support

Podman Desktop now supports protocol handling when using the terminal! Want to access your favourite extension directly from a script or the terminal? If you type in open podman-desktop:extension/redhat.openshift-local in the terminal, Podman Desktop will automatically load up to the correct extension.


Other Notable Features

  • Background colors and FormPage (PR #2977)
  • Add ability to add insecure registry / skipping cert verify (PR #2896)
  • Add support for icon contribution (PR #2984)
  • Add warning dialog message that virtual machine has low memory limit (PR #2822)
  • Propose indexed name for new pod (PR #3028)
  • Add restart button after enabling / disabling mac os compatibility (PR #2841)
  • Add environment related helper constants (PR #3079)
  • Allow entrypoint and cmd when starting container (PR #3031)
  • Add a way to debug stores in troubleshooting page (PR #3121)
  • Add custompick component (#2855) (PR #3012)
  • Dynamic breadcrumbs (PR #3119)
  • Icons on form pages (PR #3155)
  • Switch more pages to formpage (PR #3162)
  • Add rename image button (PR #2588)
  • Fixed headers, improved scrollbars (PR #2863)
  • Reports warnings on failed kube deploy, fixes error out (PR #3050)
  • Kube context on statusbar (PR #2755)
  • Install provider if not installed when clicking on create new button (#2706) (PR #2817)
  • Add tag and authenticated push capacity to the extension API (PR #2876)
  • Add navigation bar e2e tests (PR #2950)

Documentation Updates

  • Fix documentation for building image of extensions (PR #2873)
  • Add Minikube install docs (PR #2824)
  • Add Minikube documentation (PR #2694)
  • Updated Building an image procedure (PR #2964)
  • Starting a container (PR #2958)
  • Pulling an image (PR #2956)
  • Updated selecting containers to run in a pod (PR #2970)
  • Pushing an image to a registry (PR #2969)
  • How to add an insecure registry (PR #2953)
  • Add documentation for lima (PR #2995)
  • Replace broken link to podman.io (PR #2994)
  • Authenticating to a pre-configured registry (PR #2965)
  • Lima is not a container engine (PR #3051)
  • Using the Troubleshooting page (PR #3083)
  • View and select your current Kubernetes context in the status bar (PR #3090)

Notable Bug Fixes

  • Deleting a running pod generates an error (PR #2827)
  • If kubeconfig is empty, does not try to do things, cancel (PR #2874)
  • Async telemetry startup (PR #2885)
  • Do not block startup while waiting for kube resource refresh (PR #2884)
  • Images list too wide (PR #2918)
  • Compose deactivate function never called (PR #2922)
  • Auto-scrolling on form pages, layout issues (PR #2927)
  • Show current context in quick pick (PR #2920)
  • Remove sticky position of loader in dashboard UI (#2535) (PR #2959)
  • Undo change that broke the website (PR #2992)
  • Detailspage, resizing & consistency (PR #2987)
  • Quick pick click to close and over nav bar (PR #2758)
  • Only show empty screen when no pods (PR #2929)
  • Do not redirect to /pods when deleting pod in containerlist (PR #2963)
  • Bulk delete on pods should call the pod deletion (PR #2979)
  • Update nodejs version to 18 in .nvmrc to fix yarn install failure (PR #2989)
  • Website check targets (PR #2996)
  • Don't show exception to user (PR #3034)
  • Interpret arguments given to info command for example (PR #3015)
  • Change defaults for Podman machine (PR #3061)
  • Normalize development/production folders path (PR #3113)
  • Calculate machine socket path for linux (PR #3070)
  • Replace backslash with slash so to support rendering on Windows (#3120) (PR #3122)
  • Keep stdout and stderr in the error object for Docker Desktop extensions (PR #3014)
  • Mark task completed if there's a failure (PR #3016)
  • Handle invalid kubeconfig file (PR #3129)
  • Do not remove registries when podman extension is stopping (PR #3136)
  • Warning should be amber (PR #3153)
  • Load user extensions from plugins as removable (PR #3152)
  • Images with spaces in entrypoints or commands fail to start (PR #3161)
  • Scrolling offscreen when clicking checkbox (PR #3178)
  • Avoid messagebox expanding offscreen (PR #2778)
  • Release-notes-generator run failure (PR #2752)
  • Unable to do a new build if the previous one failed (PR #2721)

Community Thank You

🎉 We’d like to say a big thank you to everyone who helped to make Podman Desktop even better.

A big shoutout to @afbjorklund, @tuckerrc and @evanshortiss who contributed to this release!


Final notes

The complete list of issues fixed in this release is available here and here.

Get the latest release from the Downloads section of the website and boost your development journey with Podman Desktop. Additionally, visit the GitHub repository and see how you can help us make Podman Desktop better.

- + \ No newline at end of file diff --git a/blog/podman-desktop-release-1.3.html b/blog/podman-desktop-release-1.3.html index 6cf6619d63f..1cafcd373ee 100644 --- a/blog/podman-desktop-release-1.3.html +++ b/blog/podman-desktop-release-1.3.html @@ -13,14 +13,14 @@ - +

Release Notes - Podman Desktop 1.3

· 6 min read
Denis Golovin

Podman Desktop 1.3 Release! 🎉

This is essentially a bug-fix release to fix various issues in UI, extension engine and featured extensions, but as usual we also added a few new features.

  • Podman 4.6.1: Podman 4.6.1 included in Windows and Mac installers
  • Podman user-mode networking support to Windows/WSL: A new switch `User mode networking' is available when creating Podman machine on Windows for Podman 4.6.0+ to configure podman to work in certain VPN setups and other specialized networking configurations
  • Compose group new UI elements: You can now see summary, inspect, deploy to kubernetes, generate kube yaml and view logs
  • Extension packs and extension dependencies: Install group of extensions in one click
  • Resource details page update: See summary and log for resource
  • Create Kind cluster form update: A new Node's container image field can be used to specify the Kubernetes version used for the control-planed
  • Support Docker Desktop extensions using a backend: When loading Docker Desktop extension the containers are created in the backend as described in the vm section of extension's descriptor
  • Podman Initial Onboarding (preview): Install and configure podman using included installer

Podman Desktop 1.3 is now available. Click here to download it!

Podman-desktop-1-3-bug-swatting


Release Details

Compose group Logs tab #3176

When clicking on the group of containers, you can now view the logs of the entire group of compose containers and don't need to open log for every component individually.

Screenshot 2023-07-11 at 12 48 47 PM

Podman user-mode networking support to Windows/WSL #3251

Certain VPN setups or other specialized networking configs will block traffic from the virtual WSL networking device, resulting in the podman WSL backend from being unable to contact systems on the VPN, and potentially losing internet access altogether. The new switch allows you to create a podman VM machine configured to work correctly in mentioned above networking environments.

user

Compose group Summary tab #3317,

Compose group Summary tab shows all containers in the group and let you navigate to Details page for specific container.

Compose group Inspect tab #3316

Compose group Inspect tab shows an array of "container inspect" from docker / podman.

Deploy to kubernetes in compose actions #3299

A button to deploy to kubernetes added to Compose group.

Generate Kube in Compose actions and Kube tab in compose details #3253

Generate Kube item added to Compose actions and "Kube" tab is now available in Compose details view.

Install multiple extensions using extension pack #3150

An Extension pack introduced in Extension engine is a way to declare set of extensions to install them all at once.

Customize icons from extension #3131

Extensions now can customize icons for list elements using when clause.

image

Resource details page update #1923

If you click on the arrow icon next to a resource name it will open up a details page (similarly to how clicking on a container in the container list opens up a details page).

image

Node's container image field added to Create a Kind cluster form #3508

The new Node's container image field can be used to specify the Kubernetes version used for the control-planed.

image

Support Docker Desktop extensions using a backend #3435

Podman Desktop now loads the containers in the backend as described in the vm section of extension descriptor the same way as Docker Desktop does.

Initial onboarding implementation for podman (experimental) #3308

This is the initial implementation for the onboarding feature. It only covers a simple onboarding for podman. Check system requirements -> install podman -> yay! Done!

Notable Bug Fixes

  • Updating videos to be adaptive for mobile by @mairin #3229
  • Consistent max width and padding in settings by @deboer-tim #3232
  • Settings navigation bar resizing by @deboer-tim in #3231
  • Move new registry button to header by @deboer-tim #3245
  • Bigger lima logo by @afbjorklund #3248
  • Horizontal docker logo by @afbjorklund #3236
  • Respect LIMA_HOME environment variable by @afbjorklund #3254
  • Add check before writing to terminal by @lstocchi #3263
  • Wait until remote side has fully initialized the extensions by @benoitf #3257
  • Fix loader not centered horizontally by @benoitf #3270
  • Troubleshooting still waiting after failure by @deboer-tim #3354
  • Store error for build by @cdrage #3365
  • Missing checkbox tooltips by @deboer-tim #3380
  • Load compose logs async not await by @cdrage #3377
  • Set rootful connection when starting rootful machine by @lstocchi #3364
  • Default last page by @deboer-tim #3388
  • Avoid dashboard displaying providers starting while they don't by @benoitf #3451
  • Do not use extensionInfo until it is defined by @benoitf #V
  • Allow BASIC authentication (all caps) by @cdrage #3471
  • Allow single domain registry such as localhost:5000 by @cdrage #3468
  • Create /usr/local/bin directory if it does not exist on binary install by @cdrage #3425
  • Only delete selected pods by @deboer-tim #
  • Add back 'Done' text on the button by @benoitf #3487
  • Do not wait for more than 5s when checking for podman ping by @benoitf #3497
  • Add proxy support for extension using patching get and request approach by @dgolovin #2825
  • Refresh component when field is updated by @benoitf #3525
  • Higher-res icons for featured extensions list by @mairin #3511
  • Main nav selection by @deboer-tim #3510
  • kube event error when switching context by @jeffmaury #3494
  • Reset error message each time we pull image by @benoitf #3550

Community Thank You

🎉 We’d like to say a big thank you to everyone who helped to make Podman Desktop even better.

A warm welcome to @rostalan and @axel7083 who made their first contribution to the project in this release.

Final Notes

The complete list of issues fixed in this release is available here.

Get the latest release from the Downloads section of the website and boost your development journey with Podman Desktop. Additionally, visit the GitHub repository and see how you can help us make Podman Desktop better.

- + \ No newline at end of file diff --git a/blog/podman-desktop-release-1.4.html b/blog/podman-desktop-release-1.4.html index a8cd66a569c..3a4f39cf434 100644 --- a/blog/podman-desktop-release-1.4.html +++ b/blog/podman-desktop-release-1.4.html @@ -13,13 +13,13 @@ - +

Release Notes - Podman Desktop 1.4

· 4 min read
Jeff Maury

Podman Desktop 1.4 Release! 🎉

This is essentially a bug-fix release to fix various issues in UI, but as usual we also added a few new features.

  • Podman 4.6.2: Podman 4.6.2 included with Podman Desktop 1.4
  • Windows Arm64: Native Windows on Arm64 installers and binaries
  • Port range mapping: Start containers and map a range of ports
  • Terminal UX Improvement: Persistent terminal sessions when SSH'ing in a container
  • Volume Creation: Create volume from the Volumes page
  • Bash support: Terminals are now using bash if available.

Podman Desktop 1.4 is now available. Click here to download it!

Podman-desktop-1-4-juggling


Release Details

Port range mapping #3654

When starting a new container, you can now map a port range between host and container. If the range is not valid between host and container, an error is raised.

Range mapping

Terminal lifetime #3725

When a terminal is opened for a container, it can now be reused after you switched to another part of the Podman Desktop UI.

terminal lifetime

Create volume #3742

The Volumes tab now has a Create volume button. The Create volume UI has a single field for the volume name.

create volume

bash support #3750

When a terminal is opened for a container, if bash is available within the container, it will be used. Otherwise, sh will be used.

bash sh

Notable Bug Fixes

  • Reduce API calls when listing containers by @benoitf #3489
  • Removing a connection(podman machine) should redirect to previous page by @benoitf #3576
  • Enhance error message when image is not there by @benoitf #3587
  • Dispose kind install button when extension is deactivated (#3586) by @lstocchi #3610
  • Replace backslash/slash on windows when building image (#3465) by @lstocchi #3618
  • Handle null value in container command (#3620) by @lstocchi #3625
  • Add maximum activation time for extensions by @benoitf #3446
  • Handle single non-spread arguments by @benoitf #3641
  • Grab usage data of volumes only on-demand by @benoitf #3635
  • Add arm64 binaries for Windows by @benoitf #3643
  • Include right airgap file for Windows and arm64 by @benoitf #3651
  • Redirect to previous page when removing a kubernetes connection by @benoitf #3650
  • Support port ranges when starting a container (#3204) by @lstocchi #3654
  • Add a strict undefined check to messagebox result (#3692) by @lstocchi #3699
  • Only restart if a machine is running by @cdrage #3491
  • Session to the terminal is reused by @benoitf #3725
  • Disable next button and show try again when onboarding failed (#3616) by @lstocchi #3711
  • Add podman in PATH after updating process environment PATH (#3729) by @lstocchi #3730
  • Allow to create a volume by @benoitf #3742
  • Using bash if available otherwise sh in terminal by @axel7083 #3750
  • Allow to embed existing component to onboarding (#3755) by @lstocchi #3763
  • Some containers never return logs, do not wait for them by @dgolovin #3784
  • Remove cancel button when on final onboarding step (#3771) by @lstocchi #3802
  • Onboarding add link micromark for commands by @cdrage #3747
  • Mounts can be null when using older podman by @afbjorklund #3806
  • Remove redundant step completion check when onboarding gets started by @lstocchi #3798
  • Ability to click enter in pull image name input by @deboer-tim #3850
  • Set proxy environment variable when launching process by @jeffmaury #3838
  • The socket location was moved for new podman by @afbjorklund #3853
  • Don't log console errors when activating lima extension by @afbjorklund #3852

Community Thank You

🎉 We’d like to say a big thank you to everyone who helped to make Podman Desktop even better.

A warm welcome to @tomgoren, @Julian, @Gelob and @cedricclyburn who made their first contribution to the project in this release.

Final Notes

The complete list of issues fixed in this release is available here.

Get the latest release from the Downloads section of the website and boost your development journey with Podman Desktop. Additionally, visit the GitHub repository and see how you can help us make Podman Desktop better.

- + \ No newline at end of file diff --git a/blog/podman-desktop-release-1.5.html b/blog/podman-desktop-release-1.5.html index 375864c7ea7..cb183008b6b 100644 --- a/blog/podman-desktop-release-1.5.html +++ b/blog/podman-desktop-release-1.5.html @@ -13,7 +13,7 @@ - + @@ -24,7 +24,7 @@ compose-onboarding-start compose-onboarding

Command Palette

A new, search-driven command palette is now available to enable quick access to various commands available across 🦭 Podman Desktop. You can try this new tool out by hitting the F1 key. #4081 && #3979

Expanded "Summary" tab for Kubernetes pods

Kubernetes pods now offer a more comprehensive set of information under the "Summary" tab, including networking, volumes, environment variables, and other key metadata.

Environment file support

When creating a container from the Images list, there's now an option to provide an environment file to set env variables for the new container. #4026 && #4025

Enhancements to the Settings area

The user experience for enabling or disabling Docker compatibility is improved, with a new entry in the Settings > Preferences screen that includes contextual guidance. #4093

Improved user experience for state changes

The user experience around state changes for containers, pods, and other objects in the UI is improved, with clear status messages and improved animated visual indicator of state changes. #4056

Extension API improvements

The 🦭 Podman Desktop extension API received many improvements, including:

  • In addition to pushing and listing image from an extension, it's now possible to pull images from a 🦭 Podman Desktop extension #4155

  • The 🦭 Podman Desktop extension API has been enhanced with both the ability to list images & networks and the ability to create containers & networks. #4172

  • 🦭 Podman Desktop extensions now have a consistent way to run administrative tasks. #4049

  • Extensions now have the ability to register a custom Kubernetes config generator. #3970

  • The ability of extensions to add commands to UI menus has been extended; previously for action menus it was only available in the Image list screen. It is now possible for extensions to add commands to the action menus of items listed on the Containers list screen as well. #3947 & #3963

  • Extensions have gained the ability to contribute menu items in the UI based on specific conditions. #3959

  • Enhanced logic for displaying or hiding properties listed under the Settings > Preferences screens is now available. #4159


Other Notable Enhancements

  • The progress of loading an image into Kind is now visible as a task in the task manager. #4061

kind-progress-task

  • It's now possible to start a new Podman machine right after creation, or you can create it and wait to start it later. It's up to you! #4046

podman-start-now-or-later

  • The Podman machine and Kubernetes provider creation forms have an updated look & feel consisted with other forms in the user interface, along with minor bug fixes. #4317

Updated provider creation forms

  • The empty screen message shown when a search filter results in no matches now provides a message specific to filter matching, including the specific filter terms and an explicit button for clearing the filter. Previously, the screen displayed a generic message about how to create new objects of the type displayed on the screen, which led to some confusion about the status of the system. #3988
  • New support for adding spin animations to icons is now available. #4188

  • There is a new indeterminate progress bar type available for the task manager; this is meant for providing limited status for actions whose APIs do not provide detailed status information. #4016

  • For authenticating as admin to perform administrative tasks, 🦭 Podman Desktop now provides touchID support for macOS. #4050

touchID-support

  • Support for connecting to interactive terminals for containers via tty was added. #3900

  • It's now more clear which container/pod providers will autostart when 🦭 Podman Desktop starts. Previously autostart had both a global and a per-provider setting. It has been simplified by removing the global setting. #3840

  • The "Working with containers" section of the documentation has been reworked and improved. #3951


Notable Bug Fixes

  • The disable registry command was not blocking subsequent pulls from disabled registries. This has been corrected. #4183

  • Some users behind network proxies were unable to complete workflow involving the download of online resources. The mechanism for fetching these resources has been fixed to be proxy compatible to address this issue. #3994

  • The status of pods running in Kubernetes that are undergoing the deletion process is now accurately reflected in the 🦭 Podman Desktop UI. #3877

  • The image details page always listed the image as being "not used" even when it was. This has been corrected. #3985

  • Previously, deleting a specific image tag would cause all tags with the same Image ID to be deleted. This has been fixed so only the selected image tag will be deleted. #3837

  • Could not view the pod details for some remote Kubernetes cluster pods due to an encoding error. #4371

  • Error logs were being tracked separately from the actions they applied to. This has been addressed for kind cluster creation failure #4427 and Compose installation failure #4407.

  • For Linux users, 🦭 Podman Desktop previously did not appear under the "Development" menu when installed via Flatpak; it appeared under "Utilities." 🦭 Podman Desktop now appears under the "Development" menu. #3911

  • Podman Machine names are no longer prefixed with the "Podman Machine" string. #3878

touchID-support

  • The initial action state of pods and containers was being displayed as "STARTING" regardless of actual state; this has been corrected. #3889

  • Resizing the application window no longer makes the last lines of a container's terminal invisible. #3993

  • An issue with incorrect terminal behavior in response to long lines in the terminal attached to a container has been resolved. #3955

  • A spacing issue on the run image form has been corrected. [#4089]https://github.com/containers/podman-desktop/pull/4089

  • The "podify" icon & button on the Containers list was unusually large in release 1.4. That regression has been corrected in this release. #4122

  • An error in the instructions for Windows users on migrating from Docker has been corrected. #4157


Community Thank You

🎉 We’d like to say a big thank you to everyone who helped to make 🦭 Podman Desktop even better. In this release we received pull requests from the following people:


Final notes

Known Issues

We have a discussion board topic where we have posted known issues with this release. If you run into problems, please check this list before filing a bug - if we already have an issue open for it, it saves you the time and trouble of filing, and there may be a workaround posted in the issue.

Known Issues: Podman Desktop 1.5.2

Fixed Issues

The complete list of issues fixed in this release is available here.

Where to Download

Get the latest release from the Downloads section of the website and boost your development journey with Podman Desktop. Additionally, visit the GitHub repository and see how you can help us make Podman Desktop better.

- + \ No newline at end of file diff --git a/blog/running-a-local-kubernetes-cluster-with-podman-desktop.html b/blog/running-a-local-kubernetes-cluster-with-podman-desktop.html index 13c396b477f..18ddd0992e8 100644 --- a/blog/running-a-local-kubernetes-cluster-with-podman-desktop.html +++ b/blog/running-a-local-kubernetes-cluster-with-podman-desktop.html @@ -13,7 +13,7 @@ - + @@ -31,7 +31,7 @@ It is configured to communicate with either the Redis follower or leader Service The frontend exposes a JSON interface, and serves a jQuery-Ajax-based UX.

With Podman Desktop, you can prepare the Guestbook frontend image and container on your local container engine, and deploy the results to Kubernetes pods and services. This is functionally equal to the frontend deployment that the Kubernetes example propose.

Procedure

  1. Open Images > Pull an image.
    1. Image to Pull: enter gcr.io/google_samples/gb-frontend:v5
    2. Click Pull image to pull the image to your container engine local image registry.
    3. Wait for the pull to complete.
    4. Click Done to get back to the images list.
  2. Search images: enter gb-frontend:v5 to find the image.
  3. Click to open the Create a container from image dialog.
    1. Container name: enter frontend,
    2. Local port for 80/tcp: 9000.
    3. Click Start Container to start the container in your container engine.
  4. Search containers: enter frontend to find the running container.
  5. Click to stop the container: you do not need it to run in the container engine.
  6. Click > Deploy to Kubernetes to open the Deploy generated pod to Kubernetes screen.
    1. Pod Name: enter frontend.
    2. Use Kubernetes Services: select Replace hostPort exposure on containers by Services. It is the recommended way to expose ports, as a cluster policy might prevent to use hostPort.
    3. Expose service locally using Kubernetes Ingress: select Create a Kubernetes ingress to get access to the ports that this pod exposes, at the default ingress controller location. Example: on a default Kind cluster created with Podman Desktop: http://localhost:9090. Requirements: your cluster has an ingress controller`.
    4. Kubernetes namespaces: select default.
    5. Click Deploy. Deploy generated frontend pod to Kubernetes screen
    6. Wait for the pod to reach the state: Phase: Running.
    7. Click Done.

Verification

  1. The Pods screen lists the running frontend pod.

    `frontend` pod is running

  2. Go to http://localhost:9090: the Guestbook application is running.

- + \ No newline at end of file diff --git a/blog/tags.html b/blog/tags.html index 7162733eb93..9a4765d0969 100644 --- a/blog/tags.html +++ b/blog/tags.html @@ -13,13 +13,13 @@ - + - + \ No newline at end of file diff --git a/blog/tags/codespaces.html b/blog/tags/codespaces.html index 386024ff6a5..b81c6f257f4 100644 --- a/blog/tags/codespaces.html +++ b/blog/tags/codespaces.html @@ -13,13 +13,13 @@ - +

One post tagged with "codespaces"

View All Tags

· 7 min read
Florent Benoit

GitHub announced last week that Codespaces is available for everyone and it includes free minutes.

Let see how we can use a Development Container having all the tools to build and run Podman Desktop. The Development Container works locally using Visual Studio Code but in this blog post we will see how it works directly with a simple click from GitHub.

The challenges are to run a desktop tool (Podman Desktop) and running a container engine (Podman) inside this Development Container without using too many memory !

- + \ No newline at end of file diff --git a/blog/tags/compose.html b/blog/tags/compose.html index bbe8553a301..0ff1ca434f9 100644 --- a/blog/tags/compose.html +++ b/blog/tags/compose.html @@ -13,7 +13,7 @@ - + @@ -24,7 +24,7 @@ compose-onboarding-start compose-onboarding

Command Palette

A new, search-driven command palette is now available to enable quick access to various commands available across 🦭 Podman Desktop. You can try this new tool out by hitting the F1 key. #4081 && #3979

Expanded "Summary" tab for Kubernetes pods

Kubernetes pods now offer a more comprehensive set of information under the "Summary" tab, including networking, volumes, environment variables, and other key metadata.

Environment file support

When creating a container from the Images list, there's now an option to provide an environment file to set env variables for the new container. #4026 && #4025

Enhancements to the Settings area

The user experience for enabling or disabling Docker compatibility is improved, with a new entry in the Settings > Preferences screen that includes contextual guidance. #4093

Improved user experience for state changes

The user experience around state changes for containers, pods, and other objects in the UI is improved, with clear status messages and improved animated visual indicator of state changes. #4056

Extension API improvements

The 🦭 Podman Desktop extension API received many improvements, including:

  • In addition to pushing and listing image from an extension, it's now possible to pull images from a 🦭 Podman Desktop extension #4155

  • The 🦭 Podman Desktop extension API has been enhanced with both the ability to list images & networks and the ability to create containers & networks. #4172

  • 🦭 Podman Desktop extensions now have a consistent way to run administrative tasks. #4049

  • Extensions now have the ability to register a custom Kubernetes config generator. #3970

  • The ability of extensions to add commands to UI menus has been extended; previously for action menus it was only available in the Image list screen. It is now possible for extensions to add commands to the action menus of items listed on the Containers list screen as well. #3947 & #3963

  • Extensions have gained the ability to contribute menu items in the UI based on specific conditions. #3959

  • Enhanced logic for displaying or hiding properties listed under the Settings > Preferences screens is now available. #4159


Other Notable Enhancements

  • The progress of loading an image into Kind is now visible as a task in the task manager. #4061

kind-progress-task

  • It's now possible to start a new Podman machine right after creation, or you can create it and wait to start it later. It's up to you! #4046

podman-start-now-or-later

  • The Podman machine and Kubernetes provider creation forms have an updated look & feel consisted with other forms in the user interface, along with minor bug fixes. #4317

Updated provider creation forms

  • The empty screen message shown when a search filter results in no matches now provides a message specific to filter matching, including the specific filter terms and an explicit button for clearing the filter. Previously, the screen displayed a generic message about how to create new objects of the type displayed on the screen, which led to some confusion about the status of the system. #3988
  • New support for adding spin animations to icons is now available. #4188

  • There is a new indeterminate progress bar type available for the task manager; this is meant for providing limited status for actions whose APIs do not provide detailed status information. #4016

  • For authenticating as admin to perform administrative tasks, 🦭 Podman Desktop now provides touchID support for macOS. #4050

touchID-support

  • Support for connecting to interactive terminals for containers via tty was added. #3900

  • It's now more clear which container/pod providers will autostart when 🦭 Podman Desktop starts. Previously autostart had both a global and a per-provider setting. It has been simplified by removing the global setting. #3840

  • The "Working with containers" section of the documentation has been reworked and improved. #3951


Notable Bug Fixes

  • The disable registry command was not blocking subsequent pulls from disabled registries. This has been corrected. #4183

  • Some users behind network proxies were unable to complete workflow involving the download of online resources. The mechanism for fetching these resources has been fixed to be proxy compatible to address this issue. #3994

  • The status of pods running in Kubernetes that are undergoing the deletion process is now accurately reflected in the 🦭 Podman Desktop UI. #3877

  • The image details page always listed the image as being "not used" even when it was. This has been corrected. #3985

  • Previously, deleting a specific image tag would cause all tags with the same Image ID to be deleted. This has been fixed so only the selected image tag will be deleted. #3837

  • Could not view the pod details for some remote Kubernetes cluster pods due to an encoding error. #4371

  • Error logs were being tracked separately from the actions they applied to. This has been addressed for kind cluster creation failure #4427 and Compose installation failure #4407.

  • For Linux users, 🦭 Podman Desktop previously did not appear under the "Development" menu when installed via Flatpak; it appeared under "Utilities." 🦭 Podman Desktop now appears under the "Development" menu. #3911

  • Podman Machine names are no longer prefixed with the "Podman Machine" string. #3878

touchID-support

  • The initial action state of pods and containers was being displayed as "STARTING" regardless of actual state; this has been corrected. #3889

  • Resizing the application window no longer makes the last lines of a container's terminal invisible. #3993

  • An issue with incorrect terminal behavior in response to long lines in the terminal attached to a container has been resolved. #3955

  • A spacing issue on the run image form has been corrected. [#4089]https://github.com/containers/podman-desktop/pull/4089

  • The "podify" icon & button on the Containers list was unusually large in release 1.4. That regression has been corrected in this release. #4122

  • An error in the instructions for Windows users on migrating from Docker has been corrected. #4157


Community Thank You

🎉 We’d like to say a big thank you to everyone who helped to make 🦭 Podman Desktop even better. In this release we received pull requests from the following people:


Final notes

Known Issues

We have a discussion board topic where we have posted known issues with this release. If you run into problems, please check this list before filing a bug - if we already have an issue open for it, it saves you the time and trouble of filing, and there may be a workaround posted in the issue.

Known Issues: Podman Desktop 1.5.2

Fixed Issues

The complete list of issues fixed in this release is available here.

Where to Download

Get the latest release from the Downloads section of the website and boost your development journey with Podman Desktop. Additionally, visit the GitHub repository and see how you can help us make Podman Desktop better.

· 4 min read
Tim deBoer

This release note covers Podman Desktop 0.13 release changes.

  • Podman Version: Podman 4.4.4 now included in Windows and Mac installers.
  • Compose: Support for installing Docker Compose.
  • Extensions: Improved extension support for Podman Desktop with additional capabilities.
  • UX and UI Improvements: Welcome page, task manager, resources, and update alerts.

Podman Desktop 0.13 is now available. Click here to download it!

Podman-desktop-0-13-hero

- + \ No newline at end of file diff --git a/blog/tags/devcontainer.html b/blog/tags/devcontainer.html index 9af88ae77c1..67c492f53a2 100644 --- a/blog/tags/devcontainer.html +++ b/blog/tags/devcontainer.html @@ -13,13 +13,13 @@ - +

One post tagged with "devcontainer"

View All Tags

· 7 min read
Florent Benoit

GitHub announced last week that Codespaces is available for everyone and it includes free minutes.

Let see how we can use a Development Container having all the tools to build and run Podman Desktop. The Development Container works locally using Visual Studio Code but in this blog post we will see how it works directly with a simple click from GitHub.

The challenges are to run a desktop tool (Podman Desktop) and running a container engine (Podman) inside this Development Container without using too many memory !

- + \ No newline at end of file diff --git a/blog/tags/docker.html b/blog/tags/docker.html index 4b360e04e86..0733ee9393b 100644 --- a/blog/tags/docker.html +++ b/blog/tags/docker.html @@ -13,13 +13,13 @@ - +

One post tagged with "docker"

View All Tags

· 5 min read
Florent Benoit

The 5 things to know being a Docker user by using Podman Desktop:

  • Use a single UI: Podman Desktop works with several container engines, including Docker.
  • The compatibility mode: How to ensure tools are working with Podman instead of Docker.
  • Compose support: How to work with Compose files and Podman.
  • Kubernetes support: How to use Kubernetes with Podman.
  • Security: Use rootless mode or containers without root privileges.

5-things-to-know-for-a-docker-user-hero

- + \ No newline at end of file diff --git a/blog/tags/extensions.html b/blog/tags/extensions.html index d161c690287..7759a34f8e4 100644 --- a/blog/tags/extensions.html +++ b/blog/tags/extensions.html @@ -13,7 +13,7 @@ - + @@ -24,7 +24,7 @@ compose-onboarding-start compose-onboarding

Command Palette

A new, search-driven command palette is now available to enable quick access to various commands available across 🦭 Podman Desktop. You can try this new tool out by hitting the F1 key. #4081 && #3979

Expanded "Summary" tab for Kubernetes pods

Kubernetes pods now offer a more comprehensive set of information under the "Summary" tab, including networking, volumes, environment variables, and other key metadata.

Environment file support

When creating a container from the Images list, there's now an option to provide an environment file to set env variables for the new container. #4026 && #4025

Enhancements to the Settings area

The user experience for enabling or disabling Docker compatibility is improved, with a new entry in the Settings > Preferences screen that includes contextual guidance. #4093

Improved user experience for state changes

The user experience around state changes for containers, pods, and other objects in the UI is improved, with clear status messages and improved animated visual indicator of state changes. #4056

Extension API improvements

The 🦭 Podman Desktop extension API received many improvements, including:

  • In addition to pushing and listing image from an extension, it's now possible to pull images from a 🦭 Podman Desktop extension #4155

  • The 🦭 Podman Desktop extension API has been enhanced with both the ability to list images & networks and the ability to create containers & networks. #4172

  • 🦭 Podman Desktop extensions now have a consistent way to run administrative tasks. #4049

  • Extensions now have the ability to register a custom Kubernetes config generator. #3970

  • The ability of extensions to add commands to UI menus has been extended; previously for action menus it was only available in the Image list screen. It is now possible for extensions to add commands to the action menus of items listed on the Containers list screen as well. #3947 & #3963

  • Extensions have gained the ability to contribute menu items in the UI based on specific conditions. #3959

  • Enhanced logic for displaying or hiding properties listed under the Settings > Preferences screens is now available. #4159


Other Notable Enhancements

  • The progress of loading an image into Kind is now visible as a task in the task manager. #4061

kind-progress-task

  • It's now possible to start a new Podman machine right after creation, or you can create it and wait to start it later. It's up to you! #4046

podman-start-now-or-later

  • The Podman machine and Kubernetes provider creation forms have an updated look & feel consisted with other forms in the user interface, along with minor bug fixes. #4317

Updated provider creation forms

  • The empty screen message shown when a search filter results in no matches now provides a message specific to filter matching, including the specific filter terms and an explicit button for clearing the filter. Previously, the screen displayed a generic message about how to create new objects of the type displayed on the screen, which led to some confusion about the status of the system. #3988
  • New support for adding spin animations to icons is now available. #4188

  • There is a new indeterminate progress bar type available for the task manager; this is meant for providing limited status for actions whose APIs do not provide detailed status information. #4016

  • For authenticating as admin to perform administrative tasks, 🦭 Podman Desktop now provides touchID support for macOS. #4050

touchID-support

  • Support for connecting to interactive terminals for containers via tty was added. #3900

  • It's now more clear which container/pod providers will autostart when 🦭 Podman Desktop starts. Previously autostart had both a global and a per-provider setting. It has been simplified by removing the global setting. #3840

  • The "Working with containers" section of the documentation has been reworked and improved. #3951


Notable Bug Fixes

  • The disable registry command was not blocking subsequent pulls from disabled registries. This has been corrected. #4183

  • Some users behind network proxies were unable to complete workflow involving the download of online resources. The mechanism for fetching these resources has been fixed to be proxy compatible to address this issue. #3994

  • The status of pods running in Kubernetes that are undergoing the deletion process is now accurately reflected in the 🦭 Podman Desktop UI. #3877

  • The image details page always listed the image as being "not used" even when it was. This has been corrected. #3985

  • Previously, deleting a specific image tag would cause all tags with the same Image ID to be deleted. This has been fixed so only the selected image tag will be deleted. #3837

  • Could not view the pod details for some remote Kubernetes cluster pods due to an encoding error. #4371

  • Error logs were being tracked separately from the actions they applied to. This has been addressed for kind cluster creation failure #4427 and Compose installation failure #4407.

  • For Linux users, 🦭 Podman Desktop previously did not appear under the "Development" menu when installed via Flatpak; it appeared under "Utilities." 🦭 Podman Desktop now appears under the "Development" menu. #3911

  • Podman Machine names are no longer prefixed with the "Podman Machine" string. #3878

touchID-support

  • The initial action state of pods and containers was being displayed as "STARTING" regardless of actual state; this has been corrected. #3889

  • Resizing the application window no longer makes the last lines of a container's terminal invisible. #3993

  • An issue with incorrect terminal behavior in response to long lines in the terminal attached to a container has been resolved. #3955

  • A spacing issue on the run image form has been corrected. [#4089]https://github.com/containers/podman-desktop/pull/4089

  • The "podify" icon & button on the Containers list was unusually large in release 1.4. That regression has been corrected in this release. #4122

  • An error in the instructions for Windows users on migrating from Docker has been corrected. #4157


Community Thank You

🎉 We’d like to say a big thank you to everyone who helped to make 🦭 Podman Desktop even better. In this release we received pull requests from the following people:


Final notes

Known Issues

We have a discussion board topic where we have posted known issues with this release. If you run into problems, please check this list before filing a bug - if we already have an issue open for it, it saves you the time and trouble of filing, and there may be a workaround posted in the issue.

Known Issues: Podman Desktop 1.5.2

Fixed Issues

The complete list of issues fixed in this release is available here.

Where to Download

Get the latest release from the Downloads section of the website and boost your development journey with Podman Desktop. Additionally, visit the GitHub repository and see how you can help us make Podman Desktop better.

- + \ No newline at end of file diff --git a/blog/tags/kind.html b/blog/tags/kind.html index 2453b1af000..c5a248a1074 100644 --- a/blog/tags/kind.html +++ b/blog/tags/kind.html @@ -13,7 +13,7 @@ - + @@ -27,7 +27,7 @@ of Podman Desktop: not just local container engines, but Kubernetes too. More im providing tools that allow you to manage both environments and seamlessly move between them.

Some of these features were available in development mode over the last few releases, but since they are now in the release build, we will do a full roundup and talk about all the Kind features.

  • Kind Installation: Install Kind from the status bar
  • Manage Kind Clusters: Create and manage Kind clusters from Settings > Resources
  • Using Kind: Deploying YAML and sharing images to a cluster
  • Kind Ingress: Install a Contour ingress controller
  • UX and UI Improvements: Updated preferences and telemetry prompt

Podman Desktop 0.14 is now available. Click here to download it!

Podman-desktop-0-14-hero

- + \ No newline at end of file diff --git a/blog/tags/kubernetes.html b/blog/tags/kubernetes.html index 7fea362400b..86926b53cf6 100644 --- a/blog/tags/kubernetes.html +++ b/blog/tags/kubernetes.html @@ -13,7 +13,7 @@ - + @@ -34,7 +34,7 @@ of Podman Desktop: not just local container engines, but Kubernetes too. More im providing tools that allow you to manage both environments and seamlessly move between them.

Some of these features were available in development mode over the last few releases, but since they are now in the release build, we will do a full roundup and talk about all the Kind features.

  • Kind Installation: Install Kind from the status bar
  • Manage Kind Clusters: Create and manage Kind clusters from Settings > Resources
  • Using Kind: Deploying YAML and sharing images to a cluster
  • Kind Ingress: Install a Contour ingress controller
  • UX and UI Improvements: Updated preferences and telemetry prompt

Podman Desktop 0.14 is now available. Click here to download it!

Podman-desktop-0-14-hero

· 4 min read
Tim deBoer

This release note covers Podman Desktop 0.13 release changes.

  • Podman Version: Podman 4.4.4 now included in Windows and Mac installers.
  • Compose: Support for installing Docker Compose.
  • Extensions: Improved extension support for Podman Desktop with additional capabilities.
  • UX and UI Improvements: Welcome page, task manager, resources, and update alerts.

Podman Desktop 0.13 is now available. Click here to download it!

Podman-desktop-0-13-hero

· 5 min read
Stevan Le Meur

This release note covers Podman Desktop 0.12 release changes.

  • Podman Version: Podman 4.4.1 now included in Windows and Mac installers.
  • Containers Configuration: Configure port mappings for an image without exported ports.
  • Windows Home Support: Podman Desktop now supports Windows Home Edition.
  • Start minimized: Option to start Podman Desktop minimized to system tray.
  • UX and UI Improvements: Consistent actions, placeholder for logs, unified icons and others.

Podman Desktop 0.12 is now available. Click here to download it!

podman-desktop-0-12-hero

· 10 min read
Stevan Le Meur

This release note covers Podman Desktop 0.11 release changes.

  • Air-Gapped Installation: New all-in-one binaries for air-gapped installation.
  • Feedback: Submit feedback directly from Podman Desktop.
  • Docker Compatibility Mode: Information about the Docker compatibility mode.
  • Proxy Setting: Toggle on/off the proxy setting.
  • Deploy to Kubernetes: Select the namespace to deploy to Kubernetes.
  • Registry Configuration: Simplified registry configuration for well known registries.
  • UX/UI Improvements: View pod's container logs, better visual feedback, configurable editor font size, and more.

Podman Desktop 0.11 is now available. Click here to download it!

· 5 min read
Dev Kumar

This release note covers Podman Desktop 0.10 release changes.

  • Containers Configuration: Container creation wizzard allowing to define environment variables, networking and more configuration options.
  • Kubernetes Improvements: Play Kubernetes YAML, custom Kubeconfig path support, reload of kube context.
  • Registries Configuration: Revamped registries configuration UI.
  • Podman Version: Podman 4.3.1 now included in Windows and Mac installers.
  • UX/UI Improvements: Improved lists, better contrast, and more.

Podman Desktop 0.10 is now available. Click here to download it!

- + \ No newline at end of file diff --git a/blog/tags/migrating.html b/blog/tags/migrating.html index ec535aed1a2..7da67549119 100644 --- a/blog/tags/migrating.html +++ b/blog/tags/migrating.html @@ -13,13 +13,13 @@ - +

One post tagged with "migrating"

View All Tags

· 5 min read
Florent Benoit

The 5 things to know being a Docker user by using Podman Desktop:

  • Use a single UI: Podman Desktop works with several container engines, including Docker.
  • The compatibility mode: How to ensure tools are working with Podman instead of Docker.
  • Compose support: How to work with Compose files and Podman.
  • Kubernetes support: How to use Kubernetes with Podman.
  • Security: Use rootless mode or containers without root privileges.

5-things-to-know-for-a-docker-user-hero

- + \ No newline at end of file diff --git a/blog/tags/onboarding.html b/blog/tags/onboarding.html index 85c086a9d8d..43502a73105 100644 --- a/blog/tags/onboarding.html +++ b/blog/tags/onboarding.html @@ -13,7 +13,7 @@ - + @@ -24,7 +24,7 @@ compose-onboarding-start compose-onboarding

Command Palette

A new, search-driven command palette is now available to enable quick access to various commands available across 🦭 Podman Desktop. You can try this new tool out by hitting the F1 key. #4081 && #3979

Expanded "Summary" tab for Kubernetes pods

Kubernetes pods now offer a more comprehensive set of information under the "Summary" tab, including networking, volumes, environment variables, and other key metadata.

Environment file support

When creating a container from the Images list, there's now an option to provide an environment file to set env variables for the new container. #4026 && #4025

Enhancements to the Settings area

The user experience for enabling or disabling Docker compatibility is improved, with a new entry in the Settings > Preferences screen that includes contextual guidance. #4093

Improved user experience for state changes

The user experience around state changes for containers, pods, and other objects in the UI is improved, with clear status messages and improved animated visual indicator of state changes. #4056

Extension API improvements

The 🦭 Podman Desktop extension API received many improvements, including:

  • In addition to pushing and listing image from an extension, it's now possible to pull images from a 🦭 Podman Desktop extension #4155

  • The 🦭 Podman Desktop extension API has been enhanced with both the ability to list images & networks and the ability to create containers & networks. #4172

  • 🦭 Podman Desktop extensions now have a consistent way to run administrative tasks. #4049

  • Extensions now have the ability to register a custom Kubernetes config generator. #3970

  • The ability of extensions to add commands to UI menus has been extended; previously for action menus it was only available in the Image list screen. It is now possible for extensions to add commands to the action menus of items listed on the Containers list screen as well. #3947 & #3963

  • Extensions have gained the ability to contribute menu items in the UI based on specific conditions. #3959

  • Enhanced logic for displaying or hiding properties listed under the Settings > Preferences screens is now available. #4159


Other Notable Enhancements

  • The progress of loading an image into Kind is now visible as a task in the task manager. #4061

kind-progress-task

  • It's now possible to start a new Podman machine right after creation, or you can create it and wait to start it later. It's up to you! #4046

podman-start-now-or-later

  • The Podman machine and Kubernetes provider creation forms have an updated look & feel consisted with other forms in the user interface, along with minor bug fixes. #4317

Updated provider creation forms

  • The empty screen message shown when a search filter results in no matches now provides a message specific to filter matching, including the specific filter terms and an explicit button for clearing the filter. Previously, the screen displayed a generic message about how to create new objects of the type displayed on the screen, which led to some confusion about the status of the system. #3988
  • New support for adding spin animations to icons is now available. #4188

  • There is a new indeterminate progress bar type available for the task manager; this is meant for providing limited status for actions whose APIs do not provide detailed status information. #4016

  • For authenticating as admin to perform administrative tasks, 🦭 Podman Desktop now provides touchID support for macOS. #4050

touchID-support

  • Support for connecting to interactive terminals for containers via tty was added. #3900

  • It's now more clear which container/pod providers will autostart when 🦭 Podman Desktop starts. Previously autostart had both a global and a per-provider setting. It has been simplified by removing the global setting. #3840

  • The "Working with containers" section of the documentation has been reworked and improved. #3951


Notable Bug Fixes

  • The disable registry command was not blocking subsequent pulls from disabled registries. This has been corrected. #4183

  • Some users behind network proxies were unable to complete workflow involving the download of online resources. The mechanism for fetching these resources has been fixed to be proxy compatible to address this issue. #3994

  • The status of pods running in Kubernetes that are undergoing the deletion process is now accurately reflected in the 🦭 Podman Desktop UI. #3877

  • The image details page always listed the image as being "not used" even when it was. This has been corrected. #3985

  • Previously, deleting a specific image tag would cause all tags with the same Image ID to be deleted. This has been fixed so only the selected image tag will be deleted. #3837

  • Could not view the pod details for some remote Kubernetes cluster pods due to an encoding error. #4371

  • Error logs were being tracked separately from the actions they applied to. This has been addressed for kind cluster creation failure #4427 and Compose installation failure #4407.

  • For Linux users, 🦭 Podman Desktop previously did not appear under the "Development" menu when installed via Flatpak; it appeared under "Utilities." 🦭 Podman Desktop now appears under the "Development" menu. #3911

  • Podman Machine names are no longer prefixed with the "Podman Machine" string. #3878

touchID-support

  • The initial action state of pods and containers was being displayed as "STARTING" regardless of actual state; this has been corrected. #3889

  • Resizing the application window no longer makes the last lines of a container's terminal invisible. #3993

  • An issue with incorrect terminal behavior in response to long lines in the terminal attached to a container has been resolved. #3955

  • A spacing issue on the run image form has been corrected. [#4089]https://github.com/containers/podman-desktop/pull/4089

  • The "podify" icon & button on the Containers list was unusually large in release 1.4. That regression has been corrected in this release. #4122

  • An error in the instructions for Windows users on migrating from Docker has been corrected. #4157


Community Thank You

🎉 We’d like to say a big thank you to everyone who helped to make 🦭 Podman Desktop even better. In this release we received pull requests from the following people:


Final notes

Known Issues

We have a discussion board topic where we have posted known issues with this release. If you run into problems, please check this list before filing a bug - if we already have an issue open for it, it saves you the time and trouble of filing, and there may be a workaround posted in the issue.

Known Issues: Podman Desktop 1.5.2

Fixed Issues

The complete list of issues fixed in this release is available here.

Where to Download

Get the latest release from the Downloads section of the website and boost your development journey with Podman Desktop. Additionally, visit the GitHub repository and see how you can help us make Podman Desktop better.

- + \ No newline at end of file diff --git a/blog/tags/openshift.html b/blog/tags/openshift.html index 4f42a9de0dd..b1249119362 100644 --- a/blog/tags/openshift.html +++ b/blog/tags/openshift.html @@ -13,7 +13,7 @@ - + @@ -28,7 +28,7 @@ log for every component individually.

Click here to download it!

Podman-desktop-1-1-hero

· 5 min read
Tim deBoer

Podman Desktop 1.0 Release! 🎉

We still have many things planned, but with a little polish and a few more bug fixes we felt we've reached a level of maturity and it is now time to declare our 1.0 release.

Thank you to everyone who has been with us on this journey so far! Please keep the feedback coming!

  • Highlighting Featured Extensions: Easily find and install new extensions.
  • Featured Extensions: Two new extensions supporting OpenShift.
  • Podman Machine as Root: Ability to run a Podman machine as root.
  • UX and UI Improvements: Opening external websites, editing numbers, and tooltips.

Podman Desktop 1.0 is now available. Click here to download it!

Podman-desktop-1-0-hero

- + \ No newline at end of file diff --git a/blog/tags/podman-desktop.html b/blog/tags/podman-desktop.html index f192ec317df..81c92c53d30 100644 --- a/blog/tags/podman-desktop.html +++ b/blog/tags/podman-desktop.html @@ -13,7 +13,7 @@ - + @@ -34,7 +34,7 @@ of Podman Desktop: not just local container engines, but Kubernetes too. More im providing tools that allow you to manage both environments and seamlessly move between them.

Some of these features were available in development mode over the last few releases, but since they are now in the release build, we will do a full roundup and talk about all the Kind features.

  • Kind Installation: Install Kind from the status bar
  • Manage Kind Clusters: Create and manage Kind clusters from Settings > Resources
  • Using Kind: Deploying YAML and sharing images to a cluster
  • Kind Ingress: Install a Contour ingress controller
  • UX and UI Improvements: Updated preferences and telemetry prompt

Podman Desktop 0.14 is now available. Click here to download it!

Podman-desktop-0-14-hero

· 4 min read
Tim deBoer

This release note covers Podman Desktop 0.13 release changes.

  • Podman Version: Podman 4.4.4 now included in Windows and Mac installers.
  • Compose: Support for installing Docker Compose.
  • Extensions: Improved extension support for Podman Desktop with additional capabilities.
  • UX and UI Improvements: Welcome page, task manager, resources, and update alerts.

Podman Desktop 0.13 is now available. Click here to download it!

Podman-desktop-0-13-hero

· 5 min read
Florent Benoit

The 5 things to know being a Docker user by using Podman Desktop:

  • Use a single UI: Podman Desktop works with several container engines, including Docker.
  • The compatibility mode: How to ensure tools are working with Podman instead of Docker.
  • Compose support: How to work with Compose files and Podman.
  • Kubernetes support: How to use Kubernetes with Podman.
  • Security: Use rootless mode or containers without root privileges.

5-things-to-know-for-a-docker-user-hero

· 5 min read
Stevan Le Meur

This release note covers Podman Desktop 0.12 release changes.

  • Podman Version: Podman 4.4.1 now included in Windows and Mac installers.
  • Containers Configuration: Configure port mappings for an image without exported ports.
  • Windows Home Support: Podman Desktop now supports Windows Home Edition.
  • Start minimized: Option to start Podman Desktop minimized to system tray.
  • UX and UI Improvements: Consistent actions, placeholder for logs, unified icons and others.

Podman Desktop 0.12 is now available. Click here to download it!

podman-desktop-0-12-hero

· 10 min read
Stevan Le Meur

This release note covers Podman Desktop 0.11 release changes.

  • Air-Gapped Installation: New all-in-one binaries for air-gapped installation.
  • Feedback: Submit feedback directly from Podman Desktop.
  • Docker Compatibility Mode: Information about the Docker compatibility mode.
  • Proxy Setting: Toggle on/off the proxy setting.
  • Deploy to Kubernetes: Select the namespace to deploy to Kubernetes.
  • Registry Configuration: Simplified registry configuration for well known registries.
  • UX/UI Improvements: View pod's container logs, better visual feedback, configurable editor font size, and more.

Podman Desktop 0.11 is now available. Click here to download it!

· 5 min read
Dev Kumar

This release note covers Podman Desktop 0.10 release changes.

  • Containers Configuration: Container creation wizzard allowing to define environment variables, networking and more configuration options.
  • Kubernetes Improvements: Play Kubernetes YAML, custom Kubeconfig path support, reload of kube context.
  • Registries Configuration: Revamped registries configuration UI.
  • Podman Version: Podman 4.3.1 now included in Windows and Mac installers.
  • UX/UI Improvements: Improved lists, better contrast, and more.

Podman Desktop 0.10 is now available. Click here to download it!

· 7 min read
Florent Benoit

GitHub announced last week that Codespaces is available for everyone and it includes free minutes.

Let see how we can use a Development Container having all the tools to build and run Podman Desktop. The Development Container works locally using Visual Studio Code but in this blog post we will see how it works directly with a simple click from GitHub.

The challenges are to run a desktop tool (Podman Desktop) and running a container engine (Podman) inside this Development Container without using too many memory !

- + \ No newline at end of file diff --git a/blog/tags/release.html b/blog/tags/release.html index aa2b32cec76..22cfb7b915d 100644 --- a/blog/tags/release.html +++ b/blog/tags/release.html @@ -13,7 +13,7 @@ - + @@ -34,7 +34,7 @@ of Podman Desktop: not just local container engines, but Kubernetes too. More im providing tools that allow you to manage both environments and seamlessly move between them.

Some of these features were available in development mode over the last few releases, but since they are now in the release build, we will do a full roundup and talk about all the Kind features.

  • Kind Installation: Install Kind from the status bar
  • Manage Kind Clusters: Create and manage Kind clusters from Settings > Resources
  • Using Kind: Deploying YAML and sharing images to a cluster
  • Kind Ingress: Install a Contour ingress controller
  • UX and UI Improvements: Updated preferences and telemetry prompt

Podman Desktop 0.14 is now available. Click here to download it!

Podman-desktop-0-14-hero

· 4 min read
Tim deBoer

This release note covers Podman Desktop 0.13 release changes.

  • Podman Version: Podman 4.4.4 now included in Windows and Mac installers.
  • Compose: Support for installing Docker Compose.
  • Extensions: Improved extension support for Podman Desktop with additional capabilities.
  • UX and UI Improvements: Welcome page, task manager, resources, and update alerts.

Podman Desktop 0.13 is now available. Click here to download it!

Podman-desktop-0-13-hero

· 5 min read
Stevan Le Meur

This release note covers Podman Desktop 0.12 release changes.

  • Podman Version: Podman 4.4.1 now included in Windows and Mac installers.
  • Containers Configuration: Configure port mappings for an image without exported ports.
  • Windows Home Support: Podman Desktop now supports Windows Home Edition.
  • Start minimized: Option to start Podman Desktop minimized to system tray.
  • UX and UI Improvements: Consistent actions, placeholder for logs, unified icons and others.

Podman Desktop 0.12 is now available. Click here to download it!

podman-desktop-0-12-hero

· 10 min read
Stevan Le Meur

This release note covers Podman Desktop 0.11 release changes.

  • Air-Gapped Installation: New all-in-one binaries for air-gapped installation.
  • Feedback: Submit feedback directly from Podman Desktop.
  • Docker Compatibility Mode: Information about the Docker compatibility mode.
  • Proxy Setting: Toggle on/off the proxy setting.
  • Deploy to Kubernetes: Select the namespace to deploy to Kubernetes.
  • Registry Configuration: Simplified registry configuration for well known registries.
  • UX/UI Improvements: View pod's container logs, better visual feedback, configurable editor font size, and more.

Podman Desktop 0.11 is now available. Click here to download it!

· 5 min read
Dev Kumar

This release note covers Podman Desktop 0.10 release changes.

  • Containers Configuration: Container creation wizzard allowing to define environment variables, networking and more configuration options.
  • Kubernetes Improvements: Play Kubernetes YAML, custom Kubeconfig path support, reload of kube context.
  • Registries Configuration: Revamped registries configuration UI.
  • Podman Version: Podman 4.3.1 now included in Windows and Mac installers.
  • UX/UI Improvements: Improved lists, better contrast, and more.

Podman Desktop 0.10 is now available. Click here to download it!

- + \ No newline at end of file diff --git a/blog/tags/settings.html b/blog/tags/settings.html index a4af8d5a8f9..9f9fc58b734 100644 --- a/blog/tags/settings.html +++ b/blog/tags/settings.html @@ -13,7 +13,7 @@ - + @@ -24,7 +24,7 @@ compose-onboarding-start compose-onboarding

Command Palette

A new, search-driven command palette is now available to enable quick access to various commands available across 🦭 Podman Desktop. You can try this new tool out by hitting the F1 key. #4081 && #3979

Expanded "Summary" tab for Kubernetes pods

Kubernetes pods now offer a more comprehensive set of information under the "Summary" tab, including networking, volumes, environment variables, and other key metadata.

Environment file support

When creating a container from the Images list, there's now an option to provide an environment file to set env variables for the new container. #4026 && #4025

Enhancements to the Settings area

The user experience for enabling or disabling Docker compatibility is improved, with a new entry in the Settings > Preferences screen that includes contextual guidance. #4093

Improved user experience for state changes

The user experience around state changes for containers, pods, and other objects in the UI is improved, with clear status messages and improved animated visual indicator of state changes. #4056

Extension API improvements

The 🦭 Podman Desktop extension API received many improvements, including:

  • In addition to pushing and listing image from an extension, it's now possible to pull images from a 🦭 Podman Desktop extension #4155

  • The 🦭 Podman Desktop extension API has been enhanced with both the ability to list images & networks and the ability to create containers & networks. #4172

  • 🦭 Podman Desktop extensions now have a consistent way to run administrative tasks. #4049

  • Extensions now have the ability to register a custom Kubernetes config generator. #3970

  • The ability of extensions to add commands to UI menus has been extended; previously for action menus it was only available in the Image list screen. It is now possible for extensions to add commands to the action menus of items listed on the Containers list screen as well. #3947 & #3963

  • Extensions have gained the ability to contribute menu items in the UI based on specific conditions. #3959

  • Enhanced logic for displaying or hiding properties listed under the Settings > Preferences screens is now available. #4159


Other Notable Enhancements

  • The progress of loading an image into Kind is now visible as a task in the task manager. #4061

kind-progress-task

  • It's now possible to start a new Podman machine right after creation, or you can create it and wait to start it later. It's up to you! #4046

podman-start-now-or-later

  • The Podman machine and Kubernetes provider creation forms have an updated look & feel consisted with other forms in the user interface, along with minor bug fixes. #4317

Updated provider creation forms

  • The empty screen message shown when a search filter results in no matches now provides a message specific to filter matching, including the specific filter terms and an explicit button for clearing the filter. Previously, the screen displayed a generic message about how to create new objects of the type displayed on the screen, which led to some confusion about the status of the system. #3988
  • New support for adding spin animations to icons is now available. #4188

  • There is a new indeterminate progress bar type available for the task manager; this is meant for providing limited status for actions whose APIs do not provide detailed status information. #4016

  • For authenticating as admin to perform administrative tasks, 🦭 Podman Desktop now provides touchID support for macOS. #4050

touchID-support

  • Support for connecting to interactive terminals for containers via tty was added. #3900

  • It's now more clear which container/pod providers will autostart when 🦭 Podman Desktop starts. Previously autostart had both a global and a per-provider setting. It has been simplified by removing the global setting. #3840

  • The "Working with containers" section of the documentation has been reworked and improved. #3951


Notable Bug Fixes

  • The disable registry command was not blocking subsequent pulls from disabled registries. This has been corrected. #4183

  • Some users behind network proxies were unable to complete workflow involving the download of online resources. The mechanism for fetching these resources has been fixed to be proxy compatible to address this issue. #3994

  • The status of pods running in Kubernetes that are undergoing the deletion process is now accurately reflected in the 🦭 Podman Desktop UI. #3877

  • The image details page always listed the image as being "not used" even when it was. This has been corrected. #3985

  • Previously, deleting a specific image tag would cause all tags with the same Image ID to be deleted. This has been fixed so only the selected image tag will be deleted. #3837

  • Could not view the pod details for some remote Kubernetes cluster pods due to an encoding error. #4371

  • Error logs were being tracked separately from the actions they applied to. This has been addressed for kind cluster creation failure #4427 and Compose installation failure #4407.

  • For Linux users, 🦭 Podman Desktop previously did not appear under the "Development" menu when installed via Flatpak; it appeared under "Utilities." 🦭 Podman Desktop now appears under the "Development" menu. #3911

  • Podman Machine names are no longer prefixed with the "Podman Machine" string. #3878

touchID-support

  • The initial action state of pods and containers was being displayed as "STARTING" regardless of actual state; this has been corrected. #3889

  • Resizing the application window no longer makes the last lines of a container's terminal invisible. #3993

  • An issue with incorrect terminal behavior in response to long lines in the terminal attached to a container has been resolved. #3955

  • A spacing issue on the run image form has been corrected. [#4089]https://github.com/containers/podman-desktop/pull/4089

  • The "podify" icon & button on the Containers list was unusually large in release 1.4. That regression has been corrected in this release. #4122

  • An error in the instructions for Windows users on migrating from Docker has been corrected. #4157


Community Thank You

🎉 We’d like to say a big thank you to everyone who helped to make 🦭 Podman Desktop even better. In this release we received pull requests from the following people:


Final notes

Known Issues

We have a discussion board topic where we have posted known issues with this release. If you run into problems, please check this list before filing a bug - if we already have an issue open for it, it saves you the time and trouble of filing, and there may be a workaround posted in the issue.

Known Issues: Podman Desktop 1.5.2

Fixed Issues

The complete list of issues fixed in this release is available here.

Where to Download

Get the latest release from the Downloads section of the website and boost your development journey with Podman Desktop. Additionally, visit the GitHub repository and see how you can help us make Podman Desktop better.

- + \ No newline at end of file diff --git a/blog/tags/story.html b/blog/tags/story.html index 49c3e3aceef..df502c6cd7f 100644 --- a/blog/tags/story.html +++ b/blog/tags/story.html @@ -13,13 +13,13 @@ - +

One post tagged with "story"

View All Tags

· 9 min read
Fabrice Flore-Thebault

In this blog post you will learn to use Podman Desktop to run the Kubernetes documentation example: Deploying PHP Guestbook application with Redis.

On the agenda:

  1. Installing Podman Desktop.
  2. Installing and initializing your container engine: Podman.
  3. Installing and starting your local Kubernetes provider: Kind.
  4. Starting the Redis leader.
  5. Starting and scaling the Redis followers.
  6. Starting and exposing the Guestbook frontend.
- + \ No newline at end of file diff --git a/core-values.html b/core-values.html index ece5f08a48d..7aa50ab7500 100644 --- a/core-values.html +++ b/core-values.html @@ -13,13 +13,13 @@ - +

Podman Desktop: Core Values

Podman Desktop is designed and built with the following core values in mind.

Fast and Light

Daemon-less and using the fastest technologies to make Podman Desktop fast to use.

Reactive and light on resources utilized from your environment.

Open

While focusing on Podman as a container engine packaged by default, Podman Desktop also enables other container engines.

This gives the end-user a single tool to manage all their containers independently from the engine used.

Simple

Managing a container engine locally can be hard.

Running Kubernetes in a local environment requires knowledge.

Podman Desktop takes care of this complexity and enables developers to focus on their code.

Extensible Workflow

Podman Desktop provides extensions points to enable the community to build more features.

This allows more in-deep integrations with other tools and technologies to extend workflows and capabilities of the tool.

Thus giving the developer a single tool to manage all their containers independently from the engine used.

- + \ No newline at end of file diff --git a/docs/compose.html b/docs/compose.html index 3150a611132..a236e750c47 100644 --- a/docs/compose.html +++ b/docs/compose.html @@ -13,13 +13,13 @@ - + - + \ No newline at end of file diff --git a/docs/compose/running-compose.html b/docs/compose/running-compose.html index 8973475edfe..46d965697a7 100644 --- a/docs/compose/running-compose.html +++ b/docs/compose/running-compose.html @@ -13,13 +13,13 @@ - +

Running Compose files

With Podman Desktop, you can manage multi-container applications defined in a Compose file.

Prerequisites

Procedure

  • Run the command in a terminal:

    $ podman compose --file compose.yaml up --detach

    (Alternatively) With an older Podman version, run docker-compose:

    1. Set the DOCKER_HOST variable.

    2. Run docker-compose rather than podman compose:

      $ docker-compose --file compose.yaml up --detach

    (Optionally) Learn about Compose commands:

    $ podman compose --help

Verification

  1. The Compose engine starts the containers and services, and adds a label to each resource:

    • Container label: com.docker.compose.project
    • Service label: com.docker.compose.service
  2. Podman Desktop detects the Compose labels, and displays the container group as a group of containers.

    The Podman Desktop Containers list displays the containers created by Compose grouped in a container group with a (compose) suffix, such as flask-redis (compose).

img2

- + \ No newline at end of file diff --git a/docs/compose/setting-up-compose.html b/docs/compose/setting-up-compose.html index f456799d89d..5343bb87750 100644 --- a/docs/compose/setting-up-compose.html +++ b/docs/compose/setting-up-compose.html @@ -13,13 +13,13 @@ - +

Setting up Compose

Podman Desktop can install the Compose engine.

Procedure

  1. Go to Settings > Resources.
  2. In the Compose tile, click Setup, and follow the prompts.

Verification

  1. The Compose reference implementation is in your PATH, therefore, you can display the Compose engine version in a terminal:

    $ docker-compose version
  2. Podman detects the same Compose version:

    $ podman compose version

Next steps

Additional resources

- + \ No newline at end of file diff --git a/docs/containers.html b/docs/containers.html index 44c51406053..6a3631a056a 100644 --- a/docs/containers.html +++ b/docs/containers.html @@ -13,13 +13,13 @@ - + - + \ No newline at end of file diff --git a/docs/containers/creating-a-pod.html b/docs/containers/creating-a-pod.html index d6c8bafcec5..6ea9db2748b 100644 --- a/docs/containers/creating-a-pod.html +++ b/docs/containers/creating-a-pod.html @@ -13,13 +13,13 @@ - +

Creating a pod from selected containers

With Podman Desktop, you can create a pod from your selected containers, and run the pod on the Podman container engine.

Consider running containers in a pod to:

  1. Expose your frontend application to the public network.
  2. Protect your database container in a private network.

Prerequisites

  • You are using the Podman container engine.
  • Your containers, such as database and frontend, running or stopped, are available on the Containers page.
  • The frontend container is configured to access the service exposed by the database container on localhost, such as localhost:6379.

Procedure

  1. Go to Containers.
  2. Click the checkbox in the container line for your containers, such as database and frontend.
  3. Click .
  4. In the Copy containers to a pod screen:
    1. Name of the pod: enter your pod name, such as my-pod.
    2. All selected ports will be exposed:
      1. Select frontend.
      2. Clear database.
  5. Click Create Pod.

Verification

  1. Go to Pods.
  2. Click your pod, such as my-pod.
  3. Go to Logs: see the combined logs from the two containers.
  4. Go to Summary: see the containers.
  5. Click frontend-podified.
  6. Click .
  7. Your browser opens the service exposed by your frontend-podified container.
  8. Go to Containers: see the running containers.
- + \ No newline at end of file diff --git a/docs/containers/images.html b/docs/containers/images.html index 6c5aafc8b72..ea77a6581f8 100644 --- a/docs/containers/images.html +++ b/docs/containers/images.html @@ -13,13 +13,13 @@ - + - + \ No newline at end of file diff --git a/docs/containers/images/building-an-image.html b/docs/containers/images/building-an-image.html index 315df77f8ec..46f9aab13c9 100644 --- a/docs/containers/images/building-an-image.html +++ b/docs/containers/images/building-an-image.html @@ -13,13 +13,13 @@ - +

Building an image on your container engine

With Podman Desktop, you can build an image from a Containerfile on your container engine.

Prerequisites

  • Your Containerfile: Containerfile or Dockerfile.

Procedure

  1. Go to Images.
  2. Click Build an image.
  3. On the Build Image from Containerfile screen
    1. Containerfile path: select the Containerfile or Dockerfile to build.
    2. Image Name: enter your image name, such as my-image. If you want to push the image to a registry, use the fully qualified image name that your registry requires, such as quay.io/my-repository/my-image, ghcr.io/my-repository/my-image, or docker.io/my-repository/my-image.
    3. Click Build.
    4. Click Done.

Verification

  1. Go to Images.
  2. : Enter your image name, such as quay.io/my-repository/my-image, ghcr.io/my-repository/my-image, or docker.io/my-repository/my-image.
  3. Click the line with your image name.
  4. Go to History.
    1. Click the content area to activate it.
    2. Enter Ctrl + F on Windows and Linux, or + F on macOS to start searching in the content.
  5. Go to Inspect.
    1. Click the content area to activate it.
    2. Enter Ctrl + F on Windows and Linux, or + F on macOS to start searching in the content.
  6. Click ..
    1. You see the Create a container screen.
- + \ No newline at end of file diff --git a/docs/containers/images/pulling-an-image.html b/docs/containers/images/pulling-an-image.html index fb9ba59fc35..1648dc8f383 100644 --- a/docs/containers/images/pulling-an-image.html +++ b/docs/containers/images/pulling-an-image.html @@ -13,13 +13,13 @@ - +

Pulling an image to your container engine

With Podman Desktop, you can pull an image from a registry, to your container engine.

Prerequisites

  • The image is available in a registry.
  • If the registry or the image are not publicly available, you configured access to the registry on Podman Desktop in Settings > Registries.

Procedure

  1. Go to Images.
  2. Click Pull an image.
  3. On the Image to Pull screen:
    1. Image to pull: enter the image name, such as quay.io/podman/hello. Prefer the fully qualified image name that specifies the registry, to the short name that might lead to registry resolution mistakes.
    2. Click Pull image.
  4. Click Done.

Verification

  1. Go to Images.
  2. Click the image name you pulled, such as quay.io/podman/hello. Podman Desktop always displays the fully qualified image name.
  3. Go to Summary.
  4. Go to History.
    1. Click the output area.
    2. Enter Ctrl + F on Windows and Linux, or + F on macOS to start searching in the content.
  5. Go to Inspect.
    1. Click the output area.
    2. Enter Ctrl + F on Windows and Linux, or + F on macOS to start searching in the content.
- + \ No newline at end of file diff --git a/docs/containers/images/pushing-an-image-to-a-registry.html b/docs/containers/images/pushing-an-image-to-a-registry.html index 47dd2628935..94d50f18498 100644 --- a/docs/containers/images/pushing-an-image-to-a-registry.html +++ b/docs/containers/images/pushing-an-image-to-a-registry.html @@ -13,14 +13,14 @@ - +

Pushing an image to a registry

With Podman Desktop, you can push an image to registries.

Prerequisites

  • You have configured your registry Settings > Registries.
  • You have built an image, which name is the fully qualified name required for your registry, such as quay.io/my-repository/my-image, ghcr.io/my-repository/my-image, or docker.io/my-repository/my-image. Ensure that the image name includes the registry where to publish the image. To publish on quay.io/repository the image my-image, the FQN image name should be quay.io/repository/my-image.

Procedure

  1. Go to Images.
  2. On your image line, click > Push Image.
  3. Select the Image tag for your registry.
  4. Click Push Image.
  5. Click Done.

Verification

  1. Go to your container registry.
  2. Find your image.
- + \ No newline at end of file diff --git a/docs/containers/onboarding.html b/docs/containers/onboarding.html index b943dd20950..092d26de985 100644 --- a/docs/containers/onboarding.html +++ b/docs/containers/onboarding.html @@ -13,13 +13,13 @@ - +

Onboarding for container workloads

To run container workloads, set up at least one container engine.

Podman Desktop does not automatically set up container engine resources that you might not need.

Procedure

  1. Select a container engine supporting your workload.

    WorkloadPodmanNative DockerDocker Desktop
    Rootless containers✅ yes✅ yes❌ no
    Rootful containers✅ yes✅ yes✅ yes
    Compose✅ yes✅ yes✅ yes
    Pods✅ yes❌ no❌ no

    Podman supports rootless container and pods, in addition to rootful containers and Compose.

  2. Select an execution environment supporting your container engine and your operating system.

    • Select a Podman execution environment:

      Host operating systemNative containersPodman MachineLima instance
      Windows❌ no✅ yes❌ experimental
      macOS❌ no✅ yes✅ yes
      Linux✅ yes❌ disabled in Podman Desktop✅ yes
    • Select a Docker execution environment:

      Host operating systemNative containersDocker DesktopLima instance
      Windows❌ no✅ yes❌ experimental
      macOS❌ no✅ yes✅ yes
      Linux✅ yes✅ yes✅ yes
  3. Setup your container engine.

- + \ No newline at end of file diff --git a/docs/containers/registries.html b/docs/containers/registries.html index 05e161db1d2..355341d13a9 100644 --- a/docs/containers/registries.html +++ b/docs/containers/registries.html @@ -13,13 +13,13 @@ - + - + \ No newline at end of file diff --git a/docs/containers/registries/authenticating-to-a-preconfigured-registry.html b/docs/containers/registries/authenticating-to-a-preconfigured-registry.html index b48518dd4ee..d066a36a44d 100644 --- a/docs/containers/registries/authenticating-to-a-preconfigured-registry.html +++ b/docs/containers/registries/authenticating-to-a-preconfigured-registry.html @@ -13,13 +13,13 @@ - +

Authenticating to a pre-configured registry

With Podman Desktop, you can authenticate to a set of pre-configured registries:

  • Red Hat Quay
  • Docker Hub
  • GitHub
  • Google Container registry

Prerequisites

  • You have credentials on a pre-configured image registry.

Procedure

  1. Go to Settings > Registries.

  2. On your registry line, click Configure.

    1. User name: Enter your user name.
    2. Password: Enter your password or OAuth secret.
    3. Click Login.

    Authenticating to a preconfigured registry

Verification

  1. Go to Images.
  2. You can pull a private image from the registry.
  3. You can push an image to the registry:
    1. Build an image with the fully qualified name required for your registry, such as quay.io/my-repository/my-image, ghcr.io/my-repository/my-image, docker.io/my-repository/my-image, or my-registry.tld/my-repository/my-image.
    2. On your image line, click .
    3. The contextual menu has a Push Image entry.
- + \ No newline at end of file diff --git a/docs/containers/registries/insecure-registry.html b/docs/containers/registries/insecure-registry.html index 064f14702ce..8de2e07e6fd 100644 --- a/docs/containers/registries/insecure-registry.html +++ b/docs/containers/registries/insecure-registry.html @@ -13,13 +13,13 @@ - +

Adding an Insecure Registry to Podman Desktop

In this guide, you will learn how to add an insecure registry to Podman Desktop. An insecure registry allows you to pull and push container images either over an unencrypted HTTP connection, or a HTTPS connection with a self-signed unverified certificate. Please note that using an insecure registry can expose your data to security risks, so it's recommended to use secure connections with a verifiable certificate whenever possible.

Prerequisites

Procedure

  1. Add your insecure registry within Settings > Registries.

    Adding a custom registry

  2. Click "Yes" to the insecure registry warning.

    Podman Desktop Registry Warning

  3. SSH into the Podman Machine to edit registries.conf.

    $ podman machine ssh [optional-machine-name]
  4. Open registries.conf.

    $ sudo vi /etc/containers/registries.conf
  5. Add the insecure registry: Add a new [[registry]] section for the URL of the insecure registry you want to use. For example, if your insecure registry is located at http://registry.example.com, add the following lines:

    [[registry]]
    location = "registry.example.com"
    insecure = true

    If you have multiple registries, you can add one [[registry]] block per registry.

  6. Save and exit the file.

  7. Restart Podman by the CLI or through Podman Desktop.

    $ podman machine stop
    $ podman machine start

Verification

  1. Go to Images.
  2. You can pull a private image from the registry.
  3. You can push an image to the registry:
    1. Build an image with the fully qualified name required for your registry, such as quay.io/my-repository/my-image, ghcr.io/my-repository/my-image, docker.io/my-repository/my-image, or my-registry.tld/my-repository/my-image.
    2. On your image line, click .
    3. The contextual menu has a Push Image entry.
- + \ No newline at end of file diff --git a/docs/containers/starting-a-container.html b/docs/containers/starting-a-container.html index d589e602be2..6a3540cacb5 100644 --- a/docs/containers/starting-a-container.html +++ b/docs/containers/starting-a-container.html @@ -13,14 +13,14 @@ - +

Starting a container on your container engine

With Podman Desktop, you can start a container from an image on your container engine. You can interact with the running container by using the terminal in Podman Desktop, or by opening your browser to the exposed ports.

Prerequisites

  • The Images list has your image, such as quay.io/podman/hello.

Procedure

  1. Go to Images.
  2. On the line with your image name, such as quay.io/podman/hello, click .
  3. On the Create a container screen, review the configuration.
  4. Click Start Container.

Verification

  1. Go to Containers.
  2. : Enter your image name, such as quay.io/podman/hello, to find your running container.
  3. Click your running container name.
  4. To view logs:
    1. Go to Logs.
    2. Browse the content.
  5. To inspect the container:
    1. Go to Inspect.
    2. Click the content area to activate it.
    3. Enter Ctrl + F on Windows and Linux, or + F on macOS to start searching in the content.
  6. To generate Kubernetes YAML, when your container engine is Podman:
    1. Go to Kube.
    2. Click the content area to activate it.
    3. Enter Ctrl + F on Windows and Linux, or + F on macOS to start searching in the content.
    4. Copy the content to a YAML file.
    5. Later, you can reuse this file to start a container in Podman from Kubernetes YAML, or to start a pod in Kubernetes.
  7. To interact with the container terminal:
    1. Go to Terminal.
    2. Click the content area to activate the terminal.
    3. Enter your commands.
  8. To interact with the exposed ports:
    1. Click .
    2. Your browser opens a page to the first exposed port on localhost.
  9. To deploy to your current Kubernetes context, when you container engine is Podman:
    1. Click .
    2. Review the Deploy generated pod to Kubernetes screen.
    3. Click .
  10. To stop the container:
  11. Click .
  12. To delete the container:
  13. Click .
- + \ No newline at end of file diff --git a/docs/extensions.html b/docs/extensions.html index 02bd9509adb..06318281032 100644 --- a/docs/extensions.html +++ b/docs/extensions.html @@ -13,13 +13,13 @@ - +

Podman Desktop extensions

Podman Desktop extensions contribute to:

  • Container engine support, such as Podman, Docker.
  • Virtual machine support, such as Lima.
  • Podman Desktop extension points such as tray icon menu, status bar items, icons, menus, and commands.
  • Integration with third parties tools, such as Kind or Compose.

Next steps

- + \ No newline at end of file diff --git a/docs/extensions/install.html b/docs/extensions/install.html index 23bce8c523a..3b58ab8e39e 100644 --- a/docs/extensions/install.html +++ b/docs/extensions/install.html @@ -13,13 +13,13 @@ - +

Installing a Podman Desktop extension

Consider installing Podman Desktop extensions to enrich the default capabilities of Podman Desktop.

Prerequisites

Procedure

  1. Go to the Settings > Extensions.

  2. In the Name of the Image field, write the extension OCI image name.

  3. Click the Install extension from the OCI image button.

Verification

  • If Podman Desktop satisfies the minimum required version of the extension, the extension activates.

  • Depending on the extension, items can appear in the status bar, tray menu, or other contributions.

- + \ No newline at end of file diff --git a/docs/extensions/publish.html b/docs/extensions/publish.html index b431eefda14..d714345c20b 100644 --- a/docs/extensions/publish.html +++ b/docs/extensions/publish.html @@ -13,7 +13,7 @@ - + @@ -21,7 +21,7 @@

Packaging and publishing a Podman Desktop extension

To enable users to install your extension, consider publishing your extension to an Open Container Initiative (OCI) image registry.

Prerequisites

  • The extension builds successfully. See Writing a Podman Desktop extension.

  • All runtime dependencies are inside the final binary.

  • An OCI image registry to publish to, such as quay.io/fbenoit/my-first-extension.

  • (Optional) The OCI image registry is public to enable anybody to fetch the image.

Procedure

  1. Create and edit a Containerfile file.

  2. Use a scratch image. The extension requires no runtime:

    FROM scratch
  3. Apply mandatory Podman Desktop metadata on the OCI image:

    LABEL org.opencontainers.image.title="My first extension" \
    org.opencontainers.image.description="Example of extension" \
    org.opencontainers.image.vendor="podman-desktop" \
    io.podman-desktop.api.version=">= 0.12.0"

    io.podman-desktop.api.version=">= 0.12.0" sets the minimal Podman Desktop version that the extension requires to run.

  4. Copy the extension assembly, including the metadata, icon, and production binary, to the /extension folder inside the image:

    COPY package.json /extension/
    COPY icon.png /extension/
    COPY dist /extension/dist
  5. Build an image:

    $ podman build -t quay.io/fbenoit/my-first-extension .
  6. Push the image and manifest to the OCI image registry:

    $ podman push quay.io/fbenoit/my-first-extension

Next steps

- + \ No newline at end of file diff --git a/docs/extensions/write.html b/docs/extensions/write.html index 125d408473e..a4f5e116f98 100644 --- a/docs/extensions/write.html +++ b/docs/extensions/write.html @@ -13,13 +13,13 @@ - +

Writing a Podman Desktop extension

To write a Podman Desktop extension, start a Node.js or TypeScript project calling the Podman Desktop API, and ensure all runtime dependencies are inside the final binary.

Initializing a Podman Desktop extension

Write the Podman Desktop extension Node.js package metadata.

Prerequisites

  • JavaScript or TypeScript

Procedure

  1. Create and edit a package.json file.

    {}
  2. Add TypeScript and Podman Desktop API to the development dependencies:

     "devDependencies": {
    "@podman-desktop/api": "latest",
    "typescript": "latest"
    },
  3. Add the required metadata:

      "name": "my-extension",
    "displayName": "My Hello World extension",
    "description": "How to write my first extension",
    "version": "0.0.1",
    "icon": "icon.png",
    "publisher": "benoitf",
  4. Add the Podman Desktop version that might run this extension:

      "engines": {
    "podman-desktop": "latest"
    },
  5. Add the main entry point:

     "main": "./dist/extension.js"
  6. Add a Hello World command contribution

      "contributes": {
    "commands": [
    {
    "command": "my.first.command",
    "title": "My First Extension: Hello World"
    }
    ]
    }
  7. Add an icon.png file to the project.

Verification

  • Full package.json example:

    {
    "devDependencies": {
    "@podman-desktop/api": "latest",
    "typescript": "latest"
    },
    "name": "my-extension",
    "displayName": "My Hello World extension",
    "description": "How to write my first extension",
    "version": "0.0.1",
    "icon": "icon.png",
    "publisher": "benoitf",
    "engines": {
    "podman-desktop": "latest"
    },
    "main": "./dist/extension.js",
    "contributes": {
    "commands": [
    {
    "command": "my.first.command",
    "title": "My First Extension: Hello World"
    }
    ]
    }
    }

Writing a Podman Desktop extension entry point

Write the extension features.

Prerequisites

  • JavaScript or TypeScript

Procedure

  1. Create and edit a dist/extension.js file.

  2. Import the Podman Desktop API

    import * as podmanDesktopAPI from '@podman-desktop/api';
  3. Expose the activate function to call on activation.

    The signature of the function can be:

    • Synchronous

      export function activate(): void;
    • Asynchronous

      export async function activate(): Promise<void>;
  4. (Optional) Add an extension context to the activate function enabling the extension to register disposable resources:

    export async function activate(extensionContext: podmanDesktopAPI.ExtensionContext): Promise<void> {}
  5. Register the command and the callback

    import * as podmanDesktopAPI from '@podman-desktop/api';
    export async function activate(extensionContext: podmanDesktopAPI.ExtensionContext): Promise<void> {
    // register the command referenced in package.json file
    const myFirstCommand = podmanDesktopAPI.commands.registerCommand('my.first.command', async () => {
    // display a choice to the user for selecting some values
    const result = await podmanDesktopAPI.window.showQuickPick(['un', 'deux', 'trois'], {
    canPickMany: true, // user can select more than one choice
    });

    // display an information message with the user choice
    await podmanDesktopAPI.window.showInformationMessage(`The choice was: ${result}`);
    });

    // create an item in the status bar to run our command
    // it will stick on the left of the status bar
    const item = podmanDesktopAPI.window.createStatusBarItem(podmanDesktopAPI.StatusBarAlignLeft, 100);
    item.text = 'My first command';
    item.command = 'my.first.command';
    item.show();

    // register disposable resources to it's removed when we deactivte the extension
    extensionContext.subscriptions.push(myFirstCommand);
    extensionContext.subscriptions.push(item);
    }
  6. (Optional) Expose the deactivate function to call on deactivation.

    The signature of the function can be:

    • Synchronous

      export function deactivate(): void;
    • Asynchronous

      export async function deactivate(): Promise<void>;

Verification

  • The extension compiles and produces the output in the dist folder.

  • All runtime dependencies are inside the final binary.

Additional resources

  • Consider a packer such as Rollup or Webpack to shrink the size of the artifact.

Next steps

- + \ No newline at end of file diff --git a/docs/extensions/write/when-clause-context.html b/docs/extensions/write/when-clause-context.html index a6ee50bce3a..94c73b95714 100644 --- a/docs/extensions/write/when-clause-context.html +++ b/docs/extensions/write/when-clause-context.html @@ -13,13 +13,13 @@ - +

When clause contexts

Podman Desktop uses when clauses to enable or disable extensions command and UI customizations, such as views.

For example, the Kind extension adds a custom icon to a container that has a label equals to io.x-k8s.kind.cluster by using the following instruction.

"views": {
"icons/containersList": [
{
"when": "io.x-k8s.kind.cluster in containerLabelKeys",
"icon": "${kind-icon}"
}
]
}

A when clause can consist of a context key (such as isLinux) or complex expressions to define a specific state.

Available context keys

Podman Desktop has a set of context keys that are evaluated to Boolean true/false.

Context keyTrue when
Operating system contexts
isLinuxTrue when the OS is Linux.
isWindowsTrue when the OS is Windows.
isMacTrue when the OS is macOS.

Podman Desktop also provides context keys that return values that can be used to create meaningful expressions

Context keyValue in it
containerLabelKeysA list of all labels belonging to the current container. Example: "value in containerLabelKeys"
selectedImageIdThe image id which the dashboard/image menu opened belong to. Example "selectedImageId in imagesPushInProgressToKind"

Add a custom when clause context

If you are creating your own extension and none of the existing keys suit your needs, you can set your own context key by calling the function setValue(key: string, value: any, scope?: 'onboarding') provided by the context namespace in the Podman Desktop API.

The scope, if specified, triggers a custom behavior to avoid any type of collisions between different extensions for that specific scope. Podman Desktop is responsible for handling its state and cleans it accordingly when necessary.

If omitted, the key/value is set globally. For this reason it is recommended to use the extension id as part of the key to avoid unexpected collisions with other extensions.

The first example below sets the key "podmanIsInstalled" to true globally while the second example sets the key "toolInstalled" to oc.exe using the onboarding scope.

   extensionsAPI.context.setValue('podmanIsInstalled', true);

extensionsAPI.context.setValue('toolInstalled', 'oc.exe', 'onboarding');

After setting the toolInstalled to oc.exe, you could use this information in the when clause to enable something

{
"when": "onboardingContext:toolInstalled == oc.exe"
}

Conditional operators

To create when clauses a bit more complex Podman Desktop offers a set of operators that can be combined with each other.

Logical operators

Logical operators allow combining simple context keys or when-clause expressions that include other operators

OperatorSymbolExample
Not!!podmanIsInstalled or !(podmanIsInstalled && isWindows)
And&&podmanIsInstalled && isWindows
Or\|\|isLinux \|\| isWindows

Equality operators

Equality operators allow checking for equality of a context key's value against a specified value.

Note: the right side is a value and not considered as a context key, so no value is searched in the context. If it contains whitespaces, it must be wrapped in single-quotes (for example 'my tool.exe')

OperatorSymbolExample
Equality==onboardingContext:toolInstalled == oc.exe
Inequality!=onboardingContext:toolInstalled != oc.exe

Comparison operators

Comparison operator allow comparing a context key's value against a number.

Note: the left and right side of the operator must be separated by whitespace - bar < 2, but not bar<2

OperatorSymbolExample
Greater than>, >=onboardingContext:toolInstalled > 2
Less than<, <=onboardingContext:toolInstalled <= 3

In and not in

The in/not in operators allow checking if a value exists/not exists within the other. The right should be a context key, which value is retrieved in the context. The left can be a value or a context key.

OperatorSymbolExample
Ininlabel in containerLabelKeys
Notnot inlabel not in containerLabelKeys

Match operator

The match operator allow treating the right side item as a regular expression literal to match against the left side.

OperatorSymbolExample
Matches=~label =~ /podman$/
- + \ No newline at end of file diff --git a/docs/installation.html b/docs/installation.html index 0510b789a73..c5434231af8 100644 --- a/docs/installation.html +++ b/docs/installation.html @@ -13,13 +13,13 @@ - + - + \ No newline at end of file diff --git a/docs/installation/linux-install.html b/docs/installation/linux-install.html index 573d9ea5a77..2a8f4c6c8d4 100644 --- a/docs/installation/linux-install.html +++ b/docs/installation/linux-install.html @@ -13,13 +13,13 @@ - +

Installing Podman Desktop on Linux

Consider installing the Podman Desktop from Flathub to have:

  • One command installation
  • Package updates

Alternatively, you can install Podman Desktop from:

Prerequisites

Procedure

  1. Verify the Flathub repository is enabled, and add it if required:

    $ flatpak remote-add --if-not-exists --user flathub https://flathub.org/repo/flathub.flatpakrepo
  2. Install Podman Desktop from Flathub:

    $ flatpak install --user flathub io.podman_desktop.PodmanDesktop

Verification

  • Open Podman Desktop from a terminal:

    $ flatpak run io.podman_desktop.PodmanDesktop

Update

  • Update Podman Desktop from Flathub:

    $ flatpak update --user io.podman_desktop.PodmanDesktop

Additional resources

Next steps

- + \ No newline at end of file diff --git a/docs/installation/linux-install/installing-podman-desktop-from-a-compressed-tar-file.html b/docs/installation/linux-install/installing-podman-desktop-from-a-compressed-tar-file.html index 81483ada485..53121fd7261 100644 --- a/docs/installation/linux-install/installing-podman-desktop-from-a-compressed-tar-file.html +++ b/docs/installation/linux-install/installing-podman-desktop-from-a-compressed-tar-file.html @@ -13,14 +13,14 @@ - +

Installing Podman Desktop from a compressed tar file

Consider installing from an archive rather than from Flathub, or from a Flatpak bundle when:

  • You cannot use Flatpak.
  • You install in a restricted environment.

Prerequisites

Procedure

  1. Download the podman-desktop-<version>.tar.gz archive from the Git repository release assets.
  2. Extract the content.
  3. Go to the extracted directory.
  4. Double-click on the podman-desktop executable file.

Next steps

- + \ No newline at end of file diff --git a/docs/installation/linux-install/installing-podman-desktop-from-a-flatpak-bundle.html b/docs/installation/linux-install/installing-podman-desktop-from-a-flatpak-bundle.html index c30cccd9987..ca9f160a930 100644 --- a/docs/installation/linux-install/installing-podman-desktop-from-a-flatpak-bundle.html +++ b/docs/installation/linux-install/installing-podman-desktop-from-a-flatpak-bundle.html @@ -13,13 +13,13 @@ - +

Installing Podman Desktop from a Flatpak bundle

Consider installing a Flatpak bundle rather than from Flathub when:

  • You cannot use Flathub.
  • You want to install an unreleased version.

Prerequisites

Procedure

  1. Download the Flatpak bundle to a $HOME/Downloads/podman-desktop-<version>.flatpak file from:

  2. Install Podman Desktop from the downloaded Flatpak bundle:

    $ flatpak install --user $HOME/Downloads/podman-desktop-<version>.flatpak

Verification

  • Open Podman Desktop from a terminal:

    $ flatpak run io.podman_desktop.PodmanDesktop

Additional resources

Next steps

- + \ No newline at end of file diff --git a/docs/installation/macos-install.html b/docs/installation/macos-install.html index 97bbf77fd4d..d25ae699efc 100644 --- a/docs/installation/macos-install.html +++ b/docs/installation/macos-install.html @@ -13,14 +13,14 @@ - +

MacOS

This page contains information regarding installation of Podman Desktop on MacOS.

You can install Podman Desktop on Mac:

  1. Using the .dmg file
  2. Using Brew
Prerequisite

Podman Desktop requires Podman Engine. If you don't have Podman Engine installed, Podman Desktop will prompt you to do so at a later stage.

Installing Podman Desktop on MacOS using .dmg file

  1. Download the .dmg file from the Downloads section of this website.

    While we recommend getting the "universal" binary file which will work irrespective of the chip architecture your Mac possesses, you also have the option to get the applicable .dmg file depending on your Mac Hardware Architecture (that is Intel or Apple M1).

  2. Locate the downloaded file, and double-click on it. (Usually, you will find the downloaded file in the Downloads folder)

    img0

  3. Drag Podman Desktop icon to the Applications folder.

    img1

  4. Start Podman Desktop from the 'Launchpad' or Mac's Applications directory.

    img2

  5. Install Podman from Podman Desktop, if not yet installed.

    When you open Podman Desktop for the first time, click on the "View detection checks" button to scan if all the prerequisites to use Podman Desktop are met. If it says ❌ podman cli was not found in the PATH, then you need to install the Podman CLI/Engine which can be done within the application.

    img3

  6. Click on the "Install" button next to the "View detection checks" button, and follow the instructions on screen.

  7. You will be redirected to the Podman Installer. Follow the instructions on screen and enter your system password when asked.

    img4

  8. After the installation is complete, close the installation program. Podman Engine has been installed and you are now ready to use Podman Desktop.

Installing Podman Desktop on MacOS using brew

Prerequisite

Installation steps

  1. Open a terminal on your Mac.

  2. Run the command mentioned below.

    brew install podman-desktop

    Brew will also install the Podman Engine along with the Podman Desktop application, in case you don't have it installed yet.

    After the command is executed, you can find the Podman Desktop Application within the Applications directory of the MacOS.

Getting Started

Learn more on how to get started with Podman Desktop by clicking here.

- + \ No newline at end of file diff --git a/docs/installation/windows-install.html b/docs/installation/windows-install.html index 137f203c5d7..6ab0de6ffff 100644 --- a/docs/installation/windows-install.html +++ b/docs/installation/windows-install.html @@ -13,13 +13,13 @@ - + - + \ No newline at end of file diff --git a/docs/installation/windows-install/installing-podman-desktop-and-podman-in-a-restricted-environment.html b/docs/installation/windows-install/installing-podman-desktop-and-podman-in-a-restricted-environment.html index 26b2a8d4cc2..64558fefb86 100644 --- a/docs/installation/windows-install/installing-podman-desktop-and-podman-in-a-restricted-environment.html +++ b/docs/installation/windows-install/installing-podman-desktop-and-podman-in-a-restricted-environment.html @@ -13,13 +13,13 @@ - +

Installing Podman Desktop and Podman in a restricted environment

Consider using the Windows installer for restricted environments to install the Podman Desktop and Podman in a restricted environment.

The Windows installer for restricted environments:

  • Has all artifacts required to install Podman Desktop and Podman.
  • Does not require Internet access to download resources during installation.
  • Does not contain additional utilities such as Compose or Kind.

Prerequisites

Procedure

  1. Download the Windows installer for restricted environments, and copy the downloaded file to the Windows host in a restricted environment.
  2. Run the Windows installer for restricted environments to install Podman Desktop.
  3. Open Podman Desktop and click the Install button to install Podman.
  4. (Optionally) Configure Podman Desktop to run behind your proxy.
  5. (Optionally) Configure Podman to run behind your VPN.
  6. Create and start a Podman machine

Next steps

- + \ No newline at end of file diff --git a/docs/installation/windows-install/installing-podman-desktop-silently-with-the-windows-installer.html b/docs/installation/windows-install/installing-podman-desktop-silently-with-the-windows-installer.html index 6700a5b7ae7..9cfd45acb0b 100644 --- a/docs/installation/windows-install/installing-podman-desktop-silently-with-the-windows-installer.html +++ b/docs/installation/windows-install/installing-podman-desktop-silently-with-the-windows-installer.html @@ -13,13 +13,13 @@ - + - + \ No newline at end of file diff --git a/docs/installation/windows-install/installing-podman-desktop-with-chocolatey.html b/docs/installation/windows-install/installing-podman-desktop-with-chocolatey.html index 43d275e53ee..77ba3d8975e 100644 --- a/docs/installation/windows-install/installing-podman-desktop-with-chocolatey.html +++ b/docs/installation/windows-install/installing-podman-desktop-with-chocolatey.html @@ -13,13 +13,13 @@ - + - + \ No newline at end of file diff --git a/docs/installation/windows-install/installing-podman-desktop-with-scoop.html b/docs/installation/windows-install/installing-podman-desktop-with-scoop.html index 79629ab7ea2..07ef86b862d 100644 --- a/docs/installation/windows-install/installing-podman-desktop-with-scoop.html +++ b/docs/installation/windows-install/installing-podman-desktop-with-scoop.html @@ -13,13 +13,13 @@ - + - + \ No newline at end of file diff --git a/docs/installation/windows-install/installing-podman-desktop-with-winget.html b/docs/installation/windows-install/installing-podman-desktop-with-winget.html index 8ab989e6445..3422b9ca6cb 100644 --- a/docs/installation/windows-install/installing-podman-desktop-with-winget.html +++ b/docs/installation/windows-install/installing-podman-desktop-with-winget.html @@ -13,13 +13,13 @@ - + - + \ No newline at end of file diff --git a/docs/intro.html b/docs/intro.html index 774f71ffc38..28193ddde22 100644 --- a/docs/intro.html +++ b/docs/intro.html @@ -13,13 +13,13 @@ - + - + \ No newline at end of file diff --git a/docs/kind.html b/docs/kind.html index 33b3425ed79..624985d1d5d 100644 --- a/docs/kind.html +++ b/docs/kind.html @@ -13,13 +13,13 @@ - + - + \ No newline at end of file diff --git a/docs/kind/building-an-image-and-testing-it-in-kind.html b/docs/kind/building-an-image-and-testing-it-in-kind.html index 308eeef05de..c4c53cf4449 100644 --- a/docs/kind/building-an-image-and-testing-it-in-kind.html +++ b/docs/kind/building-an-image-and-testing-it-in-kind.html @@ -13,13 +13,13 @@ - +

Building an image and testing it in Kind

With Podman Desktop, you can build an image with your container engine, and test it in your local Kind-powered Kubernetes cluster.

Prerequisites

Procedure

  1. Build your image:

    1. Open Images > Build an image.
    2. Containerfile path: select your Containerfile or Dockerfile.
    3. Build context directory: optionally, select a directory different from the directory containing your Containerfile or Dockerfile.
    4. Image Name: enter your image name my-custom-image.
    5. Click Build.
    6. Wait for the image build to finish.
    7. Click Done to get back to the images list.
  2. Push your image to your Kind cluster:

    1. Search images: enter your image name my-custom-image to find the image.
    2. Click > Push image to Kind cluster.
  3. Test your image by creating a container:

    1. Click to open the Create a container from image dialog.
    2. Container name: enter my-custom-image-container.
    3. Review the parameters that Podman Desktop has detected from your image definition.
    4. Click Start Container to start the container in your container engine.
  4. Test your image and container on your Kind cluster:

    1. Search containers: enter my-custom-image-container to find the running container.
    2. Click > Deploy to Kubernetes to open the Deploy generated pod to Kubernetes screen.
    3. Pod Name: keep the proposed value my-custom-image-container-pod.
    4. Use Kubernetes Services: select Replace hostPort exposure on containers by Services. It is the recommended way to expose ports, as a cluster policy might prevent to use hostPort.
    5. Expose service locally using Kubernetes Ingress: if your container is exposing at a port, select Create a Kubernetes ingress to get access to the ports that this pod exposes, at the default ingress controller location. Example: on a default Kind cluster created with Podman Desktop: http://localhost:9090. Requirements: your cluster has an ingress controller`.
    6. Optionally, if your container is exposing more than one port, select the port to expose.
    7. Kubernetes namespaces: select default.
    8. Click Deploy.
    9. Wait for the pod to reach the state: Phase: Running.
    10. Click Done.

Verification

  1. The Pods screen lists the running my-image-container-pod pod.
  2. Click on the pod name to view details and logs.
  3. Optionally, if your container is exposing a port, go to http://localhost:9090: your application is running.
- + \ No newline at end of file diff --git a/docs/kind/configuring-podman-for-kind-on-windows.html b/docs/kind/configuring-podman-for-kind-on-windows.html index f7e7c2ea80a..47d766a328f 100644 --- a/docs/kind/configuring-podman-for-kind-on-windows.html +++ b/docs/kind/configuring-podman-for-kind-on-windows.html @@ -13,13 +13,13 @@ - +

Configuring Podman for Kind on Windows Subsystem for Linux (WSL)

When you create a Podman machine, Podman creates the machine in rootless mode.

With a Podman machine running on WSL, Kind:

  • Requires the rootful machine.

Therefore, set the Podman machine to rootful mode.

Procedure

  1. Stop the Podman machine:

    $ podman machine stop
  2. Set the Podman machine in rootful mode:

    $ podman machine set --rootful
  3. Start the Podman machine:

    $ podman machine start
- + \ No newline at end of file diff --git a/docs/kind/creating-a-kind-cluster.html b/docs/kind/creating-a-kind-cluster.html index 1a41a5b8dbd..41422803025 100644 --- a/docs/kind/creating-a-kind-cluster.html +++ b/docs/kind/creating-a-kind-cluster.html @@ -13,13 +13,13 @@ - +

Creating a local Kind-powered Kubernetes cluster

You can create multiple local Kind-powered Kubernetes clusters.

Prerequisites

Procedure

  1. Go to Settings > Resources

  2. In the Kind tile, click on the Create new ... button.

  3. Choose your options, and click the Create button.

    The defaults are:

    • Name: kind-cluster
    • Provider Type: podman
    • HTTP Port: 9090
    • HTTPS Port: 9443
    • Setup an ingress controller (Contour https://projectcontour.io): Enabled
    • Node’s container image (Available image tags on kind/releases): Left empty to use latest.
  4. (Optionally) Click the Show logs button to display the logs.

  5. After successful creation, click on the Go back to resources button

Verification

  1. In Settings > Resources, in the Kind tile, your <kind-cluster> instance is running.
  2. In the Podman Desktop tray, open the Kubernetes menu, you can set the context to your Kind cluster: kind-<kind-cluster>.
- + \ No newline at end of file diff --git a/docs/kind/deleting-your-kind-cluster.html b/docs/kind/deleting-your-kind-cluster.html index d47a4188445..9792c42365e 100644 --- a/docs/kind/deleting-your-kind-cluster.html +++ b/docs/kind/deleting-your-kind-cluster.html @@ -13,13 +13,13 @@ - + - + \ No newline at end of file diff --git a/docs/kind/installing.html b/docs/kind/installing.html index 707497b1690..452280bed66 100644 --- a/docs/kind/installing.html +++ b/docs/kind/installing.html @@ -13,7 +13,7 @@ - + @@ -21,7 +21,7 @@ - + \ No newline at end of file diff --git a/docs/kind/pushing-an-image-to-kind.html b/docs/kind/pushing-an-image-to-kind.html index 5b68b922b4b..c572408183e 100644 --- a/docs/kind/pushing-an-image-to-kind.html +++ b/docs/kind/pushing-an-image-to-kind.html @@ -13,7 +13,7 @@ - + @@ -21,7 +21,7 @@

Pushing an image to your local Kind-powered Kubernetes cluster

With Podman Desktop, you can push an image to your local Kind-powered Kubernetes cluster.

Prerequisites

Procedure

  1. Open Podman Desktop dashboard > Images.
  2. Search images: <your_image>:<your_tag>.
  3. Click > Push image to Kind cluster.
  4. If you created many Kind clusters, select your Kind cluster from the list.

Verification

Kind does not enable you to list loaded images. Therefore, create a Pod that uses the loaded image.

  1. Create a verify_my_image.yaml Kubernetes YAML file on your workstation. Replace the placeholders:

    • Pod name and container name value must consist of lower case alphanumeric characters, '-' or '.', and must start and end with an alphanumeric character.
    • Container image value is the image you pushed.
    apiVersion: v1
    kind: Pod
    metadata:
    name: <verify-my-image>
    spec:
    containers:
    - name: <my-image>
    image: <my_image>:<my_tag>
    imagePullPolicy: Never
  2. Open Pods > Play Kubernetes YAML.

    1. Kubernetes YAML file: select your verify_my_image.yaml file.
    2. Select Runtime: Using a Kubernetes cluster.
    3. Click Play.
    4. Clik Done
  3. Open Pods.

  4. Search pods: <verify-my-image>.

  5. The pod Status is Running.

- + \ No newline at end of file diff --git a/docs/kind/restarting-your-kind-cluster.html b/docs/kind/restarting-your-kind-cluster.html index cc3d0f1eb4a..92aa3e71eac 100644 --- a/docs/kind/restarting-your-kind-cluster.html +++ b/docs/kind/restarting-your-kind-cluster.html @@ -13,7 +13,7 @@ - + @@ -22,7 +22,7 @@ Therefore, Podman Desktop stops the Kind cluster, starts it again, and hopes for the best. The Kind cluster might not restart successfully. In that case:

- + \ No newline at end of file diff --git a/docs/kind/working-with-your-local-kind-cluster.html b/docs/kind/working-with-your-local-kind-cluster.html index c8e5dc920a9..190cf8e4621 100644 --- a/docs/kind/working-with-your-local-kind-cluster.html +++ b/docs/kind/working-with-your-local-kind-cluster.html @@ -13,13 +13,13 @@ - + - + \ No newline at end of file diff --git a/docs/kubernetes.html b/docs/kubernetes.html index 4e67652e82a..3313fd907fe 100644 --- a/docs/kubernetes.html +++ b/docs/kubernetes.html @@ -13,13 +13,13 @@ - + - + \ No newline at end of file diff --git a/docs/kubernetes/deploying-a-container-to-kubernetes.html b/docs/kubernetes/deploying-a-container-to-kubernetes.html index 7f75b3272ac..97f804126cf 100644 --- a/docs/kubernetes/deploying-a-container-to-kubernetes.html +++ b/docs/kubernetes/deploying-a-container-to-kubernetes.html @@ -13,13 +13,13 @@ - +

Deploying a container to Kubernetes

With Podman Desktop, you can deploy a container to your Kubernetes cluster.

Prerequisites

  • Your are using the Podman container engine.
  • Your container, running or stopped, is available on the Containers page: <your_container>.
  • You registered the Kubernetes cluster in your kubeconfig file: <your_kubernetes_cluster>. For example, Creating a kind cluster.
  • The Kubernetes namespace to deploy to already exists.

Procedure

  1. Click Podman Desktop tray > Kubernetes > Context > <your_kubernetes_cluster> to set your Kubernetes context.
  2. Open Podman Desktop dashboard > Containers > <your_container> to see the Container Details page.
  3. Click to generate a Kubernetes pod.
  4. On the Deploy generated pod to Kubernetes screen, choose your options:
    1. Pod Name: edit the proposed name.
    2. Use Kubernetes Services: enable or disable Replace hostPort exposure on containers by Services. It is the recommended way to expose ports, as a cluster policy might prevent to use hostPort.
    3. Kubernetes namespace: select in the list the namespace to deploy the pod to.
  5. Click the Deploy button.

Verification

  • On the Deploy generated pod to Kubernetes screen, the created pod status is Phase: Running

    Deploying a container

  • Go to Containers: your pod is in the list.

- + \ No newline at end of file diff --git a/docs/kubernetes/deploying-a-pod-to-kubernetes.html b/docs/kubernetes/deploying-a-pod-to-kubernetes.html index ea42dbfdfa3..ddd5ed8e51b 100644 --- a/docs/kubernetes/deploying-a-pod-to-kubernetes.html +++ b/docs/kubernetes/deploying-a-pod-to-kubernetes.html @@ -13,13 +13,13 @@ - +

Deploying a pod to Kubernetes

With Podman Desktop, you can deploy a pod to your Kubernetes cluster.

Prerequisites

  • Your are using the Podman container engine.
  • Your pod, running or stopped, is available on the Pods page: <your_pod>.
  • You registered the Kubernetes cluster in your kubeconfig file: <your_kubernetes_cluster>. For example, Creating a kind cluster.
  • The Kubernetes namespace to deploy to already exists.

Procedure

  1. Click Podman Desktop tray > Kubernetes > Context > <your_kubernetes_cluster> to set your Kubernetes context.
  2. Open Podman Desktop dashboard > Pods > <your_pod> to see the Pod Details page.
  3. Click to generate a Kubernetes pod.
  4. On the Deploy generated pod to Kubernetes screen, choose your options:
    1. Pod Name: edit the proposed name.
    2. Use Kubernetes Services: enable or disable Replace hostPort exposure on containers by Services. It is the recommended way to expose ports, as a cluster policy might prevent to use hostPort.
    3. Kubernetes namespace: select in the list the namespace to deploy the pod to.
  5. Click the Deploy button.

Verification

  • On the Deploy generated pod to Kubernetes screen, the created pod status is Phase: Running

    Deploying a pod

  • Go to Pods: your pod is in the list.

- + \ No newline at end of file diff --git a/docs/kubernetes/existing-kubernetes.html b/docs/kubernetes/existing-kubernetes.html index ce98d15134c..eced959ad54 100644 --- a/docs/kubernetes/existing-kubernetes.html +++ b/docs/kubernetes/existing-kubernetes.html @@ -13,13 +13,13 @@ - +

Configuring access to a Kubernetes cluster

Podman Desktop configures the access to Kubernetes clusters automatically when:

You can also use the Kubernetes CLI to configure access to your Kubernetes cluster:

Prerequisites

  • You have credentials for your Kubernetes cluster.

Procedure

  1. (Optionally) Go to Settings > Preferences > Path to the kubeconfig file to adapt your kubeconfig file location, when different from the default $HOME/.kube/config.

  2. Register your <my_kubernetes> Kubernetes cluster:

    $ kubectl config set-cluster <my_kubernetes> --server=<my_kubernetes_url>

Verification

Additional resopurces

- + \ No newline at end of file diff --git a/docs/kubernetes/kind/pushing-an-image-to-kind.html b/docs/kubernetes/kind/pushing-an-image-to-kind.html index 66ce6cead4c..a45bac7f2c6 100644 --- a/docs/kubernetes/kind/pushing-an-image-to-kind.html +++ b/docs/kubernetes/kind/pushing-an-image-to-kind.html @@ -13,7 +13,7 @@ - + @@ -21,7 +21,7 @@

Pushing an image to your local Kind-powered Kubernetes cluster

With Podman Desktop, you can push an image to your local Kind-powered Kubernetes cluster.

Prerequisites

Procedure

  1. Open Podman Desktop dashboard > Images.
  2. Search images: <your_image>:<your_tag>.
  3. Click > Push image to Kind cluster.
  4. If you created many Kind clusters, select your Kind cluster from the list.

Verification

Kind does not enable you to list loaded images. Therefore, create a Pod that uses the loaded image.

  1. Create a verify_my_image.yaml Kubernetes YAML file on your workstation. Replace the placeholders:

    • Pod name and container name value must consist of lower case alphanumeric characters, '-' or '.', and must start and end with an alphanumeric character.
    • Container image value is the image you pushed.
    apiVersion: v1
    kind: Pod
    metadata:
    name: <verify-my-image>
    spec:
    containers:
    - name: <my-image>
    image: <my_image>:<my_tag>
    imagePullPolicy: Never
  2. Open Pods > Play Kubernetes YAML.

    1. Kubernetes YAML file: select your verify_my_image.yaml file.
    2. Select Runtime: Using a Kubernetes cluster.
    3. Click Play.
    4. Click Done
  3. Open Pods.

  4. Search pods: <verify-my-image>.

  5. The pod Status is Running.

- + \ No newline at end of file diff --git a/docs/kubernetes/viewing-and-selecting-current-kubernete-context-in-the-status-bar.html b/docs/kubernetes/viewing-and-selecting-current-kubernete-context-in-the-status-bar.html index 0a45dff2a69..9ac1e25db01 100644 --- a/docs/kubernetes/viewing-and-selecting-current-kubernete-context-in-the-status-bar.html +++ b/docs/kubernetes/viewing-and-selecting-current-kubernete-context-in-the-status-bar.html @@ -13,14 +13,14 @@ - +

Viewing and selecting the current Kubernetes context

With Podman Desktop, you can view and select your current Kubernetes context in the status bar.

Prerequisites

  • You have a Kubernetes context in your kubeconfig file: <your_kubernetes_cluster>. For example, Creating a kind cluster.

Procedure

  1. To view your current Kubernetes context, in the Podman Desktop main window status bar, see the name next to the icon.

  2. (Optionally) To change your Kubernetes context:

    1. Click .
    2. In the drop-down menu, click the context name to activate.
- + \ No newline at end of file diff --git a/docs/kubernetes/viewing-and-selecting-current-kubernete-context.html b/docs/kubernetes/viewing-and-selecting-current-kubernete-context.html index e8cda358203..2b26dfe7586 100644 --- a/docs/kubernetes/viewing-and-selecting-current-kubernete-context.html +++ b/docs/kubernetes/viewing-and-selecting-current-kubernete-context.html @@ -13,14 +13,14 @@ - +

Viewing and selecting the current Kubernetes context

With Podman Desktop, you can view and select your current Kubernetes context.

Prerequisites

  • You have a Kubernetes context in your kubeconfig file: <your_kubernetes_cluster>. For example, Creating a kind cluster.

Procedure

  1. Open the Podman Desktop tray menu.

    In the task bar, click Show hidden icons.

    Podman Desktop tray

    Right-click the Podman Desktop tray icon to open the menu.

    Podman Desktop tray

  2. Click Kubernetes to see your current Kubernetes context.

    Podman Desktop tray

  3. (Optionally) To change your Kubernetes context, click on the context name to activate.

- + \ No newline at end of file diff --git a/docs/lima.html b/docs/lima.html index 4d7e85224fd..1d25997909a 100644 --- a/docs/lima.html +++ b/docs/lima.html @@ -13,13 +13,13 @@ - + - + \ No newline at end of file diff --git a/docs/lima/creating-a-kubernetes-instance.html b/docs/lima/creating-a-kubernetes-instance.html index 18784fc4d96..7c2566f7f92 100644 --- a/docs/lima/creating-a-kubernetes-instance.html +++ b/docs/lima/creating-a-kubernetes-instance.html @@ -13,7 +13,7 @@ - + @@ -21,7 +21,7 @@

Creating a Lima instance for Kubernetes workloads with Podman Desktop

To use the Lima provider you need a Lima instance running a Linux virtual machine.

In the future, Podman Desktop might be able to create Lima instances.

Consider creating a custom Lima instance to:

  • Control the assigned resources: CPUs, memory, and disk size.
  • Control which Kubernetes distribution (template) to install.

Prerequisites

  1. Install the lima CLI.

Procedure

  1. In a terminal, create the Lima instance.

    • To create a single-node Kubernetes cluster running k3s:

      $ limactl start template://k3s
    • To create a single-node Kubernetes cluster running k8s:

      $ limactl start template://k8s
    • To select the number of CPUs, the memory, and the disk size, add the options to the limactl start command:

      --cpus=4 --memory=4 --disk=100
  2. Wait for the instance to start, and restart the Lima extension.

    • Go to Settings > Preferences > Extension: Lima, to change the instance name and type.

      • k3s

        • Type: kubernetes
        • Name: k3s Lima preferences k3s
      • k8s

        • Type: kubernetes
        • Name: k8s Lima preferences k8s
    • Go to Settings > Extensions > Lima, to disable and enable the extension after changes.

Verification

  1. When the installation is done, the location of the KUBECONFIG file is printed. See Configuring access to a Kubernetes cluster.

    • Go to Settings > Preferences > Path to the kubeconfig file, to set the path of the file.
  2. Use the kubectl.lima wrapper script to connect to the cluster:

    $ kubectl.lima version
- + \ No newline at end of file diff --git a/docs/lima/creating-a-lima-instance.html b/docs/lima/creating-a-lima-instance.html index 804c380ed41..6394e102b71 100644 --- a/docs/lima/creating-a-lima-instance.html +++ b/docs/lima/creating-a-lima-instance.html @@ -13,7 +13,7 @@ - + @@ -21,7 +21,7 @@

Creating a Lima instance for container workloads with Podman Desktop

To use the Lima provider you need a Lima instance running a Linux virtual machine.

In the future, Podman Desktop might be able to create Lima instances.

Consider creating a custom Lima instance to:

  • Control the assigned resources: CPUs, memory, and disk size.
  • Use the rootful connection by default, for example to run Kind.

Prerequisites

  1. Install the lima CLI.

Procedure

  1. In a terminal, create the Lima instance.

    • To create a Lima instance with rootless Podman, use the podman template:

      $ limactl start --name=podman template://podman
    • To create a Lima instance with rootful Podman, use the podman-rootful template:

      $ limactl start --name=podman template://podman-rootful
    • To create an Lima instance with rootless Docker, use the docker template:

      $ limactl start --name=docker template://docker
    • To create an Lima instance with rootful Docker, use the docker-rootful template:

      $ limactl start --name=docker template://docker-rootful
    • To select the number of CPUs, the memory, and the disk size, add the options to the limactl start command:

      --cpus=2 --memory=2 --disk=50
  2. Wait for the instance to start, and restart the Lima extension.

    • Go to Settings > Preferences > Extension: Lima, to change the instance name and type.

      • Podman (default)

        • Type: podman
        • Name: podman Lima preferences Podman
      • Docker

        • Type: docker
        • Name: docker Lima preferences Docker
    • Go to Settings > Extensions > Lima, to disable and enable the extension after changes.

Verification

  • To verify the connection to a running "podman" instance:

    $ podman.lima version
  • To verify the connection to a running "docker" instance:

    $ docker.lima version
- + \ No newline at end of file diff --git a/docs/lima/customizing.html b/docs/lima/customizing.html index 6812f2f892e..608193cb0de 100644 --- a/docs/lima/customizing.html +++ b/docs/lima/customizing.html @@ -13,7 +13,7 @@ - + @@ -23,7 +23,7 @@ or you can install Dir.

  • /var/run/docker.sock
  • /run/podman/podman.sock
export DOCKER_HOST="unix://{{.Dir}}/sock/docker.sock"

Kubernetes

You can install Kubernetes, on top of the existing container engine.

For instance you can use CRI-O for Podman, or CRI-Dockerd for Docker. After that you can copy the kubeconfig.yaml file, to the host Dir.

  • /etc/rancher/k3s/k3s.yaml
  • /etc/kubernetes/admin.conf
export KUBECONFIG="{{.Dir}}/copied-from-guest/kubeconfig.yaml"
- + \ No newline at end of file diff --git a/docs/lima/installing.html b/docs/lima/installing.html index e741ea05f30..0512ccb88dd 100644 --- a/docs/lima/installing.html +++ b/docs/lima/installing.html @@ -13,14 +13,14 @@ - + - + \ No newline at end of file diff --git a/docs/migrating-from-docker.html b/docs/migrating-from-docker.html index 57406715c46..f317189e90c 100644 --- a/docs/migrating-from-docker.html +++ b/docs/migrating-from-docker.html @@ -13,13 +13,13 @@ - + - + \ No newline at end of file diff --git a/docs/migrating-from-docker/emulating-docker-cli-with-podman.html b/docs/migrating-from-docker/emulating-docker-cli-with-podman.html index 69334720510..b6584acc6e9 100644 --- a/docs/migrating-from-docker/emulating-docker-cli-with-podman.html +++ b/docs/migrating-from-docker/emulating-docker-cli-with-podman.html @@ -13,14 +13,14 @@ - +

Emulating Docker CLI with Podman

Consider emulating Docker CLI with Podman to migrate transparently to Podman.

  • Continue using familiar Docker commands.
  • Take advantage of the benefits of Podman on macOS.
  • Your tools, such as Maven or Testcontainers, communicate with Podman without reconfiguration.

Prerequisites

  • Podman

Procedure

  1. Create a /usr/local/bin/docker script:

    #!/usr/bin/sh
    [ -e /etc/containers/nodocker ] || \
    echo "Emulate Docker CLI using podman. Create /etc/containers/nodocker to quiet msg." >&2
    exec podman "$@"
  2. (Optional) Create an empty /etc/containers/nodocker file to avoid the Emulate Docker CLI using podman. message when running the script.

    # touch /etc/containers/nodocker
  3. Make the script executable:

    # chmod +x /usr/local/bin/docker

Verification

  • Use the docker script to run commands. Example:

    $ docker run -it docker.io/hello-world
- + \ No newline at end of file diff --git a/docs/migrating-from-docker/importing-saved-containers.html b/docs/migrating-from-docker/importing-saved-containers.html index ef85d840d96..a7ae3dfd1f8 100644 --- a/docs/migrating-from-docker/importing-saved-containers.html +++ b/docs/migrating-from-docker/importing-saved-containers.html @@ -13,14 +13,14 @@ - +

Importing saved containers to Podman

Consider importing saved containers to continue using familiar containers.

Prerequisites

  • Podman

  • You saved your existing containers by running the command:

    $ podman save <your_container> > <your_container_archive>.tar

Procedure

  • Import your existing containers into Podman. Run the command for each container archive:

    $ podman import <your_container_archive>.tar

Verification

  • Your imported containers appear in the Podman Desktop Images section.

Additional resources

- + \ No newline at end of file diff --git a/docs/migrating-from-docker/using-podman-mac-helper.html b/docs/migrating-from-docker/using-podman-mac-helper.html index e75dc9beec8..469d8fc29ad 100644 --- a/docs/migrating-from-docker/using-podman-mac-helper.html +++ b/docs/migrating-from-docker/using-podman-mac-helper.html @@ -13,14 +13,14 @@ - +

Using the podman-mac-helper tool to migrate from Docker to Podman on macOS

Consider using podman-mac-help to migrate transparently to Podman on macOS.

  • Continue using familiar Docker commands.
  • Take advantage of the benefits of Podman on macOS.
  • Your tools, such as Maven or Testcontainers, communicate with Podman without reconfiguration.

The podman-mac-helper tool provides a compatibility layer that allows you to use most Docker commands with Podman on macOS. The service redirects /var/run/docker to the fixed user-assigned UNIX socket location.

Prerequisites

Procedure

  1. Set up the podman-mac-helper service: run the command in a terminal:

    sudo podman-mac-helper install
  2. Restart your Podman machine: go to Settings > Resources, and in the Podman tile, click .

Verification

  1. The Docker socket is a symbolic link for the Podman socket:

    $ ls -la /var/run/docker.sock

    The output points to a podman.sock file such as:

    /var/run/docker.sock -> /Users/username/.local/share/containers/podman/machine/podman.sock
  2. When you query the Docker socket, you receive replies from Podman rather than Docker.

    For instance, this command outputs Podman version rather that Docker version:

    $ curl -s --unix-socket /var/run/docker.sock "http://v1.41/info"  | jq -r .ServerVersion
  3. Your tools communicating to the Docker socket, such as Maven or Testcontainers, communicate with Podman without reconfiguration.

  4. (Optionally, if the docker CLI is installed) The docker CLI context is set to the default value unix:///var/run/docker.sock:

    $ docker context list
    NAME TYPE DESCRIPTION DOCKER ENDPOINT KUBERNETES ENDPOINT ORCHESTRATOR
    default * moby Current DOCKER_HOST based configuration unix:///var/run/docker.sock
  5. (Optionally, if the docker CLI is installed) The docker CLI communicates with the Podman socket.

    Therefore this command outputs Podman version rather that Docker version:

    $ docker info --format=json | jq -r .ServerVersion

Additional resources

- + \ No newline at end of file diff --git a/docs/migrating-from-docker/using-the-docker_host-environment-variable.html b/docs/migrating-from-docker/using-the-docker_host-environment-variable.html index 6ed337fbfc0..730b68c7500 100644 --- a/docs/migrating-from-docker/using-the-docker_host-environment-variable.html +++ b/docs/migrating-from-docker/using-the-docker_host-environment-variable.html @@ -13,13 +13,13 @@ - +

Using the DOCKER_HOST environment variable

Consider using the DOCKER_HOST environment variable to migrate transparently from Docker to Podman Desktop on all platforms.

  • Continue using familiar Docker commands.
  • Take advantage of the benefits of Podman.
  • Your tools, such as Gradle or Testcontainers, communicate with Podman without reconfiguration.

Prerequisites

  • Podman

Procedure

  1. Identify the location of your Podman pipe
$ podman machine inspect --format '{{.ConnectionInfo.PodmanPipe.Path}}'
  1. Set the DOCKER_HOST environment variable to your Podman pipe location. You'll need to replace back slashes with forward slashes and add the npipe:// scheme to the path retrieved previously:

Example:

prefixpodman-pipe

npipe:////./pipe/podman-machine-default

Depending on your terminal emulator of preference there is a little variation between the commands to set a session level environment variable:

cmd - Command Prompt
set DOCKER_HOST=npipe://<inspect_command_output>
Git Bash
export DOCKER_HOST=npipe://<inspect_command_output>
Powershell

Don't miss the quotes on the value or powershell will try to interpret it as a separate command instead of a value.

$env:DOCKER_HOST="npipe://<inspect_command_output>"

Ideally you should set DOCKER_HOST at the system or user level environment variables (or even load it in your CL emulator init script of choice)

Note: Setting the DOCKER_HOST environment variable isn't necessary on Windows since Podman also listens to the default docker_engine pipe. But it may be necessary if you get the following error: Error: socket of machine is not set while trying to use the podman compose command.

Verification

  • Your tools using the DOCKER_HOST environment variable, such as Gradle or Testcontainers, communicate with Podman without reconfiguration.
- + \ No newline at end of file diff --git a/docs/migrating-from-docker/verifying-your-tools-are-using-podman.html b/docs/migrating-from-docker/verifying-your-tools-are-using-podman.html index 58236f36d21..25ee52fb1a6 100644 --- a/docs/migrating-from-docker/verifying-your-tools-are-using-podman.html +++ b/docs/migrating-from-docker/verifying-your-tools-are-using-podman.html @@ -13,13 +13,13 @@ - +

Verifying that your tools are using Podman

When you have configured your host to use Podman rather then Docker, consider verifying your setup works as intended.

Prerequisites

Procedure

  1. The Docker socket replies successfully for listing all containers:

    $ curl --unix-socket npipe:////./pipe/docker_engine "http:/v1.41/containers/json?all=true"
  2. Podman commands run successfully when redirected to the Docker socket:

    $ CONTAINER_HOST=npipe:////./pipe/docker_engine podman ps
- + \ No newline at end of file diff --git a/docs/minikube.html b/docs/minikube.html index 6f8e35a1f8f..550f745b0ca 100644 --- a/docs/minikube.html +++ b/docs/minikube.html @@ -13,13 +13,13 @@ - +
- + \ No newline at end of file diff --git a/docs/minikube/building-an-image-and-testing-it-in-minikube.html b/docs/minikube/building-an-image-and-testing-it-in-minikube.html index 0d5ac628d9e..9affd95eb2c 100644 --- a/docs/minikube/building-an-image-and-testing-it-in-minikube.html +++ b/docs/minikube/building-an-image-and-testing-it-in-minikube.html @@ -13,13 +13,13 @@ - +

Building an image and testing it in Minikube

With Podman Desktop, you can build an image with your container engine, and test it in your local Minikube-powered Kubernetes cluster.

Prerequisites

Procedure

  1. Build your image:

    1. Open Images > Build an image.
    2. Containerfile path: select your Containerfile or Dockerfile.
    3. Build context directory: optionally, select a directory different from the directory containing your Containerfile or Dockerfile.
    4. Image Name: enter your image name my-custom-image.
    5. Click Build.
    6. Wait for the image build to finish.
    7. Click Done to get back to the images list.
  2. Push your image to your Minikube cluster:

    1. Search images: enter your image name my-custom-image to find the image.
    2. Click > Push image to Minikube cluster.
  3. Test your image by creating a container:

    1. Click to open the Create a container from image dialog.
    2. Container name: enter my-custom-image-container.
    3. Review the parameters that Podman Desktop has detected from your image definition.
    4. Click Start Container to start the container in your container engine.
  4. Test your image and container on your Minikube cluster:

    1. Search containers: enter my-custom-image-container to find the running container.
    2. Click > Deploy to Kubernetes to open the Deploy generated pod to Kubernetes screen.
    3. Pod Name: keep the proposed value my-custom-image-container-pod.
    4. Use Kubernetes Services: select Replace hostPort exposure on containers by Services. It is the recommended way to expose ports, as a cluster policy might prevent to use hostPort.
    5. Expose service locally using Kubernetes LoadBalancer: if your container is exposing a service, you can use minikube service to get a web browser or an URL to use.
    6. Optionally, if your container is exposing more than one port, select the port to expose.
    7. Kubernetes namespaces: select default.
    8. Click Deploy.
    9. Wait for the pod to reach the state: Phase: Running.
    10. Click Done.

Verification

  1. The Pods screen lists the running my-image-container-pod pod.
  2. Click on the pod name to view details and logs.
  3. Optionally, if your container is exposing a service, go to the server URL: your application is running.
- + \ No newline at end of file diff --git a/docs/minikube/configuring-podman-for-minikube-on-windows.html b/docs/minikube/configuring-podman-for-minikube-on-windows.html index 97040b5bfa3..eb74985a21c 100644 --- a/docs/minikube/configuring-podman-for-minikube-on-windows.html +++ b/docs/minikube/configuring-podman-for-minikube-on-windows.html @@ -13,13 +13,13 @@ - +

Configuring Podman for Minikube on Windows Subsystem for Linux (WSL)

When you create a Podman machine, Podman creates the machine in rootless mode.

With a Podman machine running on WSL, Minikube:

  • Requires a rootful machine.

Therefore, set the Podman machine to rootful mode.

Procedure

  1. Stop the Podman machine:

    $ podman machine stop
  2. Set the Podman machine in rooful mode:

    $ podman machine set --rootful
  3. Start the Podman machine:

    $ podman machine start
- + \ No newline at end of file diff --git a/docs/minikube/creating-a-minikube-cluster.html b/docs/minikube/creating-a-minikube-cluster.html index da8c8827b9f..4509253ccdc 100644 --- a/docs/minikube/creating-a-minikube-cluster.html +++ b/docs/minikube/creating-a-minikube-cluster.html @@ -13,13 +13,13 @@ - +

Creating a local Minikube-powered Kubernetes cluster

You can create multiple local Minikube-powered Kubernetes clusters.

Prerequisites

Procedure

  1. Go to Settings > Resources

  2. In the Minikube tile, click on the Create new ... button.

  3. Choose your options, and click the Create button.

    The defaults are:

    • Name: minikube
    • Driver: podman
    • Container runtime: cri-o
  4. (Optionally) Click the Show logs button to display the logs.

  5. After successful creation, click on the Go back to resources button

Verification

  1. In Settings > Resources, in the Minikube tile, your <minikube> instance is running.
  2. In the Podman Desktop tray, open the Kubernetes menu, you can set the context to your Minikube cluster: minikube.
- + \ No newline at end of file diff --git a/docs/minikube/deleting-your-minikube-cluster.html b/docs/minikube/deleting-your-minikube-cluster.html index 346860c6d83..31418881d1d 100644 --- a/docs/minikube/deleting-your-minikube-cluster.html +++ b/docs/minikube/deleting-your-minikube-cluster.html @@ -13,13 +13,13 @@ - + - + \ No newline at end of file diff --git a/docs/minikube/installing.html b/docs/minikube/installing.html index 5598e773b9f..920f094c86f 100644 --- a/docs/minikube/installing.html +++ b/docs/minikube/installing.html @@ -13,7 +13,7 @@ - + @@ -21,7 +21,7 @@ - + \ No newline at end of file diff --git a/docs/minikube/pushing-an-image-to-minikube.html b/docs/minikube/pushing-an-image-to-minikube.html index e4e457b9c28..49b533acdac 100644 --- a/docs/minikube/pushing-an-image-to-minikube.html +++ b/docs/minikube/pushing-an-image-to-minikube.html @@ -13,14 +13,14 @@ - +

Pushing an image to your local Minikube-powered Kubernetes cluster

With Podman Desktop, you can push an image to your local Minikube-powered Kubernetes cluster.

Prerequisites

Procedure

  1. Open Podman Desktop dashboard > Images.
  2. Search images: <your_image>:<your_tag>.
  3. Click > Push image to Minikube cluster.
  4. If you created many Minikube clusters, select your Minikube cluster from the list.

Verification

Minikube enables you to list loaded images, using:

$ minikube image list

You can also create a Pod that uses the loaded image:

  1. Create a verify_my_image.yaml Kubernetes YAML file on your workstation. Replace the placeholders:

    • Pod name and container name value must consist of lower case alphanumeric characters, '-' or '.', and must start and end with an alphanumeric character.
    • Container image value is the image you pushed.
    apiVersion: v1
    kind: Pod
    metadata:
    name: <verify-my-image>
    spec:
    containers:
    - name: <my-image>
    image: <my_image>:<my_tag>
    imagePullPolicy: Never
  2. Open Pods > Play Kubernetes YAML.

    1. Kubernetes YAML file: select your verify_my_image.yaml file.
    2. Select Runtime: Using a Kubernetes cluster.
    3. Click Play.
    4. Clik Done
  3. Open Pods.

  4. Search pods: <verify-my-image>.

  5. The pod Status is Running.

- + \ No newline at end of file diff --git a/docs/minikube/restarting-your-minikube-cluster.html b/docs/minikube/restarting-your-minikube-cluster.html index 5e506c7e900..71098cbffa1 100644 --- a/docs/minikube/restarting-your-minikube-cluster.html +++ b/docs/minikube/restarting-your-minikube-cluster.html @@ -13,7 +13,7 @@ - + @@ -22,7 +22,7 @@ Therefore, Podman Desktop stops the Minikube cluster, and starts it again. The Minikube cluster might not restart successfully. In that case:

- + \ No newline at end of file diff --git a/docs/minikube/working-with-your-local-minikube-cluster.html b/docs/minikube/working-with-your-local-minikube-cluster.html index 9330a3621b3..31c7e185183 100644 --- a/docs/minikube/working-with-your-local-minikube-cluster.html +++ b/docs/minikube/working-with-your-local-minikube-cluster.html @@ -13,13 +13,13 @@ - + - + \ No newline at end of file diff --git a/docs/openshift.html b/docs/openshift.html index 06109ef5326..7f8e987b24e 100644 --- a/docs/openshift.html +++ b/docs/openshift.html @@ -13,13 +13,13 @@ - +

Red Hat OpenShift

OpenShift is a hybrid cloud platform built around Linux containers, orchestrated and managed by Kubernetes on a foundation of Red Hat Enterprise Linux.

You can try OpenShift online for free with the Developer Sandbox, or install it locally via OpenShift Local.

Next steps

  1. OpenShift Developer Sandbox.
  2. OpenShift Local.
- + \ No newline at end of file diff --git a/docs/openshift/developer-sandbox.html b/docs/openshift/developer-sandbox.html index 9dd0508c71e..c919ba7a0e3 100644 --- a/docs/openshift/developer-sandbox.html +++ b/docs/openshift/developer-sandbox.html @@ -13,14 +13,14 @@ - +

Configuring access to a Developer Sandbox

The Developer Sandbox is a free, private OpenShift environment including one project and a resource quota of 14 GB RAM, and 40 GB storage. It lasts 30 days.

With Podman Desktop, you can configure access to your Developer Sandbox instances.

Prerequisites

Procedure

  1. Install the Developer Sandbox extension: go to Dashboard, and click Developer Sandbox .
  2. Go to Settings > Resources.
  3. In the Developer Sandbox tile, click Create new.
  4. In the Create a Developer Sandbox screen, click Log into Developer Sandbox.
  5. In the Open external website dialog, click Yes.
  6. In the Developer Sandbox website:
    1. Click Start your sandbox for free
    2. If you never used this service, you might get through a verification workflow.
    3. In the Login with... screen, click DevSandbox.
    4. In your Developer Sandbox Console, click on your login name > Copy login command from the menu.
    5. In the Login with... screen, click DevSandbox.
    6. Click Display Token.
    7. Copy the Log in with this token full login command, similar to: oc login --token=sha256~<token> --server=https://api.sandbox-m2.<sandbox_id>.openshiftapps.com:6443.
  7. Get back to Podman Desktop Create a Developer Sandbox screen.
    1. Context name: Enter a name such as Developer Sandbox.
    2. Login command: Paste the oc login command that you copied previously.
  8. The Creation screen displays Successful operation. Click Go back to Resources.

Verification

  1. On the Settings > Resources screen, your Developer Sandbox is running.

    Developer Sandbox is running

  2. Select your Developer Sandbox in the Podman Desktop tray

  3. Run basic tasks such as:

- + \ No newline at end of file diff --git a/docs/openshift/openshift-local.html b/docs/openshift/openshift-local.html index b74c51ed2da..8e290dfa23f 100644 --- a/docs/openshift/openshift-local.html +++ b/docs/openshift/openshift-local.html @@ -13,13 +13,13 @@ - +

Creating an OpenShift Local instance

Red Hat OpenShift Local manages a minimal OpenShift or MicroShift cluster on your workstation for local development and testing.

With Podman Desktop and the OpenShift Local extension, you can manage your OpenShift Local instances.

Prerequisites

Procedure

  1. Install the OpenShift Local extension: on to Dashboard, click OpenShift Local .

  2. Install the OpenShift Local binaries, when on the Dashboard, you see Podman Desktop was not able to find an installation of OpenShift Local.

    1. In the OpenShift Local tile, click Install.
    2. When prerequisites are missing, follow the instructions.
    3. In the Red Hat OpenShift Local screen, click Yes to start the installation.
    4. Follow the installation program instructions.
    5. Reboot to finalize system changes.
  3. (Optionally) Review the extension settings in Settings > Preferences > Extension: Red Hat OpenShift Local.

  4. On the Dashboard, click Initialize and start.

    1. Select your OpenShift Local Virtual machine preset, if not set in Settings > Preferences > Extension: Red Hat OpenShift Local > Preset.

      • MicroShift (experimental): provides a lightweight and optimized environment with a limited set of services.
      • OpenShift: provides a single node OpenShift cluster with a fuller set of services, including a web console (requires more resources).
    2. Provide a pull secret, required to pull container images from the registry:

      1. Open the Red Hat OpenShift Local download page.
      2. Click Copy pull secret.
      3. Get back to Podman Desktop.
      4. Paste the pull secret, and press Enter.

Verification

  1. On the Dashboard screen, OpenShift Local is running.

  2. On the Settings > Resources screen, your OpenShift Local instance is running.

    Developer Sandbox is running

  3. Select your OpenShift Local instance the Podman Desktop tray.

  4. Run basic tasks such as:

Additional resources

- + \ No newline at end of file diff --git a/docs/podman.html b/docs/podman.html index e41496cd7b7..eff6c925293 100644 --- a/docs/podman.html +++ b/docs/podman.html @@ -13,13 +13,13 @@ - + - + \ No newline at end of file diff --git a/docs/podman/creating-a-podman-machine.html b/docs/podman/creating-a-podman-machine.html index bc3f5f98091..42795a2f4aa 100644 --- a/docs/podman/creating-a-podman-machine.html +++ b/docs/podman/creating-a-podman-machine.html @@ -13,7 +13,7 @@ - + @@ -28,7 +28,7 @@ Enable to use the rootful connection by default. Required to use Kind on Windows.
  • (On Windows) User mode networking (traffic relayed by a user process): Enable to route the traffic through the network connection from your Windows session. Required to access resources behind your VPN connection.
  • Click Create
  • Create a Podman machine

    - + \ No newline at end of file diff --git a/docs/podman/installing-podman-with-openshift-local-on-windows.html b/docs/podman/installing-podman-with-openshift-local-on-windows.html index 51a165c6b00..e6d32746d4a 100644 --- a/docs/podman/installing-podman-with-openshift-local-on-windows.html +++ b/docs/podman/installing-podman-with-openshift-local-on-windows.html @@ -13,13 +13,13 @@ - +

    Installing the Podman Preset with OpenShift Local on Windows

    On Windows, running the Podman container engine requires running a Linux distribution on a virtual machine.

    Consider installing the Podman Preset in OpenShift Local rather than installing Podman with Podman Desktop when you require one of following:

    • No WSL 2
    • Full control on the HyperV virtual machine
    • User without administrator privileges
    • VPN
    • Windows 10

    Prerequisites

    • The user is a member of the Hyper-V Administrators group. The user can add a virtual machine, start or stop this virtual machine, and access the resources related to this virtual machine.
    • Windows 10 version 1709 or later, Enterprise or Professional edition, or Windows 11, Enterprise or Professional edition

    Procedure

    1. Install the OpenShift Local extension.

    2. Install OpenShift Local.

    3. Select the Podman container runtime preset:

      $ crc config set preset podman
    4. Set up your host machine for Red Hat OpenShift Local:

      $ crc setup
    5. Start the Red Hat OpenShift instance:

      $ crc start

    Additional resources

    Next steps

    - + \ No newline at end of file diff --git a/docs/podman/installing.html b/docs/podman/installing.html index 8ae27ed1977..a104b75a793 100644 --- a/docs/podman/installing.html +++ b/docs/podman/installing.html @@ -13,7 +13,7 @@ - + @@ -24,7 +24,7 @@ See Additional resources

    Next steps

    - + \ No newline at end of file diff --git a/docs/podman/setting-podman-machine-default-connection.html b/docs/podman/setting-podman-machine-default-connection.html index 3cc59eeaa71..914a4a534b2 100644 --- a/docs/podman/setting-podman-machine-default-connection.html +++ b/docs/podman/setting-podman-machine-default-connection.html @@ -13,13 +13,13 @@ - +

    Setting Podman machine default connection

    Each Podman machine exposes two connections:

    • rootless
    • rootful

    Podman has one default connection.

    Podman Desktop, and other tools, such as Kind, connect to the default connection.

    After an event that might have changed the default Podman machine connection, such as creating another Podman machine, consider verifying and setting the default connection.

    Procedure

    1. List Podman machine connections, in a terminal:

      $ podman system connection ls
    2. Set the Podman machine default connection to your desired connection, such as podman-machine-default-root, in a terminal:

      $ podman system connection default podman-machine-default-root
    3. List Podman machine connections, to verify which is the default, in a terminal:

      $ podman system connection ls
    4. Restart the Podman machine that has the default connection:

      $ podman machine stop
      $ podman machine start
    5. Refresh Podman Desktop connection to Podman: click the icon to open the Troubleshooting page, and click the Reconnect providers button.

    Verification

    • Podman Desktop lists images, containers, and pods that are accessible via the desired Podman machine connection.
    - + \ No newline at end of file diff --git a/docs/proxy.html b/docs/proxy.html index 50e37ba20bd..a4e0a3e11e2 100644 --- a/docs/proxy.html +++ b/docs/proxy.html @@ -13,13 +13,13 @@ - + - + \ No newline at end of file diff --git a/docs/proxy/using-a-proxy-in-your-containers.html b/docs/proxy/using-a-proxy-in-your-containers.html index 252c5e06dc6..d5b429f182c 100644 --- a/docs/proxy/using-a-proxy-in-your-containers.html +++ b/docs/proxy/using-a-proxy-in-your-containers.html @@ -13,13 +13,13 @@ - +

    Using a proxy in your containers on macOS and Windows

    You can configure your Podman machine to use a proxy for your containers.

    Prerequisites

    • <your.proxy.tld:port>: Your proxy URL.

    Procedure

    1. Open a shell prompt on the Podman machine:

      $ podman machine ssh
    2. Edit the containers.conf file to pass the proxy environment variables to Podman CLI.

      The file location depends on your connection mode:

      • rootless: $HOME/.config/containers/containers.conf

      • rootful: /etc/containers/containers.conf

    3. Set the proxy environment variables to pass into the containers:

      [containers]
      http_proxy = true
      env = ["http_proxy=<your.proxy.tld:port>", "https_proxy=<your.proxy.tld:port>"]
    4. Go to Settings > Resources and restart the Podman machine.

    - + \ No newline at end of file diff --git a/docs/proxy/using-a-proxy-on-linux.html b/docs/proxy/using-a-proxy-on-linux.html index 291729f9392..2c730cbe2dc 100644 --- a/docs/proxy/using-a-proxy-on-linux.html +++ b/docs/proxy/using-a-proxy-on-linux.html @@ -13,13 +13,13 @@ - +

    Using Podman Desktop behind a proxy on Linux

    You can configure Podman to run behind a proxy.

    Prerequisites

    • <proxy_ca.pem>: Your proxy Certificate Authorities (CA), in Privacy-Enhanced Mail (PEM) format.
    • <your.proxy.tld:port>: Your proxy URL.

    Procedure

    1. Edit the containers.conf file to pass the proxy environment variables to Podman CLI.

      The file location depends on your connection mode:

      • rootless: $HOME/.config/containers/containers.conf

      • rootful: /etc/containers/containers.conf

    2. Set the proxy environment variables to pass into the containers:

      [containers]
      http_proxy = true
      env = ["http_proxy=<your.proxy.tld:port>", "https_proxy=<your.proxy.tld:port>"]
    3. Set the proxy environment variables to pass into the Podman engine:

      [engine]
      env = ["http_proxy=<your.proxy.tld:port>", "https_proxy=<your.proxy.tld:port>"]
    4. Add the custom Certificate Authorities (CA) for your proxy:

      $ sudo cp <proxy_ca.pem> /etc/pki/ca-trust/source/anchors/
      $ sudo update-ca-trust
    5. Restart all podman processes.

      $ pkill podman
    6. Restart Podman Desktop: Ctrl + q.

    Verification

    1. Go to Images.
    2. Click Pull an image.
    3. Image to Pull: bash
    4. Click Pull image.
    5. Podman Desktop reports Download complete.
    - + \ No newline at end of file diff --git a/docs/proxy/using-a-proxy-requiring-a-custom-ca.html b/docs/proxy/using-a-proxy-requiring-a-custom-ca.html index 02a8af1412b..41d3ee59bf2 100644 --- a/docs/proxy/using-a-proxy-requiring-a-custom-ca.html +++ b/docs/proxy/using-a-proxy-requiring-a-custom-ca.html @@ -13,14 +13,14 @@ - +

    Using Podman Desktop behind a proxy requiring custom Certificate Authorities (CA) on macOS and Windows

    You can configure Podman Desktop to run behind a proxy requiring custom Certificate Authorities (CA), such as self-signed certificates. The configuration applies to the Podman engine, but not to your containers.

    Prerequisites

    • Your proxy URL: <your.proxy.tld:port>
    • Your proxy Certificate Authorities (CA) is stored in your home directory, in the proxy_ca.pem file, in Privacy-Enhanced Mail (PEM) format.

    Procedure

    1. Go to Settings > Proxy, and set your proxy URL:

      1. Proxy configuration enabled: yes
      2. Web Proxy (HTTP): <your.proxy.tld:port>
      3. Secure Web Proxy (HTTPS): <your.proxy.tld:port>
      4. Click the Update button
    2. Copy the certificate to the Podman machine:

      $ cat proxy_ca.pem | podman machine ssh podman-machine-default "cat > proxy_ca.pem"
    3. Open a shell prompt on the Podman machine:

      $ podman machine ssh podman-machine-default
    4. Add the custom Certificate Authorities (CA) for your proxy:

      $ sudo cp proxy_ca.pem /etc/pki/ca-trust/source/anchors/
      $ sudo update-ca-trust
    5. Go to Settings > Resources and restart the Podman machine.

    Verification

    1. Go to Images.
    2. Click Pull an image.
    3. Image to Pull: bash
    4. Click Pull image.
    5. Podman Desktop reports Download complete.
    - + \ No newline at end of file diff --git a/docs/proxy/using-a-proxy.html b/docs/proxy/using-a-proxy.html index 59dc4c81c14..818994d260a 100644 --- a/docs/proxy/using-a-proxy.html +++ b/docs/proxy/using-a-proxy.html @@ -13,13 +13,13 @@ - +

    Using Podman Desktop behind a proxy on macOS and Windows

    You can configure Podman Desktop to run behind a proxy.

    The configuration applies to:

    • Processes that Podman Desktop started, such as downloading Podman, Compose, or Kind installers.
    • Podman engine.

    The configuration does not apply to:

    • Your Podman containers.
    • Command line tools that Podman Desktop did not start.

    Prerequisites

    Procedure

    1. Go to Settings > Proxy, and set your proxy URL:

      1. Proxy configuration enabled: yes
      2. Web Proxy (HTTP): <your.proxy.tld:port>
      3. Secure Web Proxy (HTTPS): <your.proxy.tld:port>
      4. Click the Update button
    2. Go to Settings > Resources and restart the Podman machine.

    Verification

    1. You can install extensions such as:

    2. Podman can pull images.

      1. Go to Images.
      2. Click Pull an image.
      3. Image to Pull: bash
      4. Click Pull image.
      5. Podman Desktop reports Download complete.

    Additional resources

    - + \ No newline at end of file diff --git a/docs/proxy/using-a-vpn-on-windows.html b/docs/proxy/using-a-vpn-on-windows.html index 5cb68378824..e53b7510c75 100644 --- a/docs/proxy/using-a-vpn-on-windows.html +++ b/docs/proxy/using-a-vpn-on-windows.html @@ -13,13 +13,13 @@ - +

    Accessing resources behind a VPN with Podman on Windows

    On Windows, if Podman needs to access resources behind a user-controlled VPN, enable user mode networking in your Podman machine.

    Prerequisites

    • Windows host with updated WSL2.
    • Podman 4.6.0 or greater.

    Procedure

    Verification

    • You can now access resources that are behind the VPN.
    - + \ No newline at end of file diff --git a/docs/tags.html b/docs/tags.html index c6b0588b1ca..d0761d61e0b 100644 --- a/docs/tags.html +++ b/docs/tags.html @@ -13,13 +13,13 @@ - + - + \ No newline at end of file diff --git a/docs/tags/chocolatey.html b/docs/tags/chocolatey.html index 1781c702a9c..9915e6a24d6 100644 --- a/docs/tags/chocolatey.html +++ b/docs/tags/chocolatey.html @@ -13,13 +13,13 @@ - + - + \ No newline at end of file diff --git a/docs/tags/compose.html b/docs/tags/compose.html index 5e6db6411ea..fbeef86864c 100644 --- a/docs/tags/compose.html +++ b/docs/tags/compose.html @@ -13,13 +13,13 @@ - +

    3 docs tagged with "compose"

    View All Tags

    Compose

    With Podman Desktop, you can install a Compose engine and manage multi-container applications defined in Compose files.

    Running Compose files

    With Podman Desktop, you can manage multi-container applications defined in Compose files.

    - + \ No newline at end of file diff --git a/docs/tags/containers.html b/docs/tags/containers.html index 622b1a1da77..e74b8dd4e34 100644 --- a/docs/tags/containers.html +++ b/docs/tags/containers.html @@ -13,13 +13,13 @@ - +

    5 docs tagged with "containers"

    View All Tags

    Images

    Working with container images

    Lima

    Podman Desktop can assist you to create a custom Lima instance on Linux and macOS.

    - + \ No newline at end of file diff --git a/docs/tags/docker.html b/docs/tags/docker.html index bef8871ac2e..a38b3fa3b85 100644 --- a/docs/tags/docker.html +++ b/docs/tags/docker.html @@ -13,13 +13,13 @@ - + - + \ No newline at end of file diff --git a/docs/tags/extension.html b/docs/tags/extension.html index 77be317b77f..8611cc12ad5 100644 --- a/docs/tags/extension.html +++ b/docs/tags/extension.html @@ -13,13 +13,13 @@ - +

    4 docs tagged with "extension"

    View All Tags

    Writing

    Writing a Podman Desktop extension

    - + \ No newline at end of file diff --git a/docs/tags/flathub.html b/docs/tags/flathub.html index 10282965ca5..044755aad9b 100644 --- a/docs/tags/flathub.html +++ b/docs/tags/flathub.html @@ -13,13 +13,13 @@ - +

    2 docs tagged with "flathub"

    View All Tags

    Linux

    You can install Podman Desktop on Linux from Flathub, a Flatpak bundle, or a ZIP archive.

    - + \ No newline at end of file diff --git a/docs/tags/flatpak.html b/docs/tags/flatpak.html index 09a2bc2a03b..5caa566bfe3 100644 --- a/docs/tags/flatpak.html +++ b/docs/tags/flatpak.html @@ -13,13 +13,13 @@ - +

    2 docs tagged with "flatpak"

    View All Tags

    Linux

    You can install Podman Desktop on Linux from Flathub, a Flatpak bundle, or a ZIP archive.

    - + \ No newline at end of file diff --git a/docs/tags/images.html b/docs/tags/images.html index de3daf09f4d..f3920fa2efa 100644 --- a/docs/tags/images.html +++ b/docs/tags/images.html @@ -13,13 +13,13 @@ - +

    9 docs tagged with "images"

    View All Tags

    Containers

    Starting a container on your container engine.

    Images

    Working with container images

    - + \ No newline at end of file diff --git a/docs/tags/installing.html b/docs/tags/installing.html index db328f65881..8d77ee58ada 100644 --- a/docs/tags/installing.html +++ b/docs/tags/installing.html @@ -13,13 +13,13 @@ - +

    16 docs tagged with "installing"

    View All Tags

    In your containers

    Using Podman Desktop behind a proxy requiring custom Certificate Authorities (CA).

    Installation

    You can install Podman Desktop on Windows, macOS, and Linux.

    Installing Podman

    Podman Desktop can assist you to install Podman on Windows and macOS.

    Linux

    You can install Podman Desktop on Linux from Flathub, a Flatpak bundle, or a ZIP archive.

    Windows

    How to install Podman on Windows.

    - + \ No newline at end of file diff --git a/docs/tags/kind.html b/docs/tags/kind.html index 82525e93526..23e01e23397 100644 --- a/docs/tags/kind.html +++ b/docs/tags/kind.html @@ -13,13 +13,13 @@ - +

    7 docs tagged with "kind"

    View All Tags

    Kind

    Kind is one way to get Kubernetes running on your workstation.

    - + \ No newline at end of file diff --git a/docs/tags/kubernetes.html b/docs/tags/kubernetes.html index 0097c78bb70..306f1bdec1f 100644 --- a/docs/tags/kubernetes.html +++ b/docs/tags/kubernetes.html @@ -13,13 +13,13 @@ - +

    3 docs tagged with "kubernetes"

    View All Tags

    Lima

    Podman Desktop can assist you to create a custom Lima instance on Linux and macOS.

    - + \ No newline at end of file diff --git a/docs/tags/lima.html b/docs/tags/lima.html index 682de1f46a2..6c3b6a99bb6 100644 --- a/docs/tags/lima.html +++ b/docs/tags/lima.html @@ -13,13 +13,13 @@ - + - + \ No newline at end of file diff --git a/docs/tags/linux.html b/docs/tags/linux.html index 24b70a18aa3..de056c97012 100644 --- a/docs/tags/linux.html +++ b/docs/tags/linux.html @@ -13,13 +13,13 @@ - +

    10 docs tagged with "linux"

    View All Tags

    In your containers

    Using Podman Desktop behind a proxy requiring custom Certificate Authorities (CA).

    Lima

    Podman Desktop can assist you to create a custom Lima instance on Linux and macOS.

    Linux

    You can install Podman Desktop on Linux from Flathub, a Flatpak bundle, or a ZIP archive.

    Linux

    Using Podman Desktop behind a proxy on Linux.

    - + \ No newline at end of file diff --git a/docs/tags/mac-0-s.html b/docs/tags/mac-0-s.html index 24528fc6865..0c8495d1da7 100644 --- a/docs/tags/mac-0-s.html +++ b/docs/tags/mac-0-s.html @@ -13,13 +13,13 @@ - +

    One doc tagged with "mac0S"

    View All Tags

    Using `podman-mac-helper` on macOS

    Using the `podman-mac-helper` tool can make it easier to migrate from Docker to Podman on macOS, as it allows you to continue using familiar Docker commands while taking advantage of the benefits of Podman.

    - + \ No newline at end of file diff --git a/docs/tags/mac-os.html b/docs/tags/mac-os.html index 8ed54cba566..c591ab7476c 100644 --- a/docs/tags/mac-os.html +++ b/docs/tags/mac-os.html @@ -13,13 +13,13 @@ - +

    4 docs tagged with "macOS"

    View All Tags

    Lima

    Podman Desktop can assist you to create a custom Lima instance on Linux and macOS.

    - + \ No newline at end of file diff --git a/docs/tags/macos.html b/docs/tags/macos.html index f655fd7b502..d72782dc580 100644 --- a/docs/tags/macos.html +++ b/docs/tags/macos.html @@ -13,13 +13,13 @@ - +

    4 docs tagged with "macos"

    View All Tags

    In your containers

    Using Podman Desktop behind a proxy requiring custom Certificate Authorities (CA).

    - + \ No newline at end of file diff --git a/docs/tags/migrating-from-docker.html b/docs/tags/migrating-from-docker.html index d4d6a6b104b..87c6aa42206 100644 --- a/docs/tags/migrating-from-docker.html +++ b/docs/tags/migrating-from-docker.html @@ -13,13 +13,13 @@ - +

    6 docs tagged with "migrating-from-docker"

    View All Tags

    Emulating Docker CLI with Podman

    Emulation Docker CLI with Podman can make it easier to migrate from Docker to Podman, as it allows you to continue using familiar Docker commands while taking advantage of the benefits of Podman.

    Using `podman-mac-helper` on macOS

    Using the `podman-mac-helper` tool can make it easier to migrate from Docker to Podman on macOS, as it allows you to continue using familiar Docker commands while taking advantage of the benefits of Podman.

    Using the `DOCKER_HOST` environment variable

    Using the `DOCKER_HOST` environment variable can make it easier to migrate from Docker to Podman Desktop, as it allows you to continue using familiar Docker commands while taking advantage of the benefits of Podman.

    - + \ No newline at end of file diff --git a/docs/tags/migrating-to-kubernetes.html b/docs/tags/migrating-to-kubernetes.html index 27df0e7632f..7e6ce718511 100644 --- a/docs/tags/migrating-to-kubernetes.html +++ b/docs/tags/migrating-to-kubernetes.html @@ -13,13 +13,13 @@ - +

    29 docs tagged with "migrating-to-kubernetes"

    View All Tags

    Kind

    Kind is one way to get Kubernetes running on your workstation.

    Kubernetes

    Migrate transparently from Podman to Kubernetes, and continue using familiar workflows.

    Minikube

    Minikube is one way to get Kubernetes running on your workstation.

    - + \ No newline at end of file diff --git a/docs/tags/minikube.html b/docs/tags/minikube.html index 50533adb898..549c0b7d695 100644 --- a/docs/tags/minikube.html +++ b/docs/tags/minikube.html @@ -13,13 +13,13 @@ - +

    7 docs tagged with "minikube"

    View All Tags

    Minikube

    Minikube is one way to get Kubernetes running on your workstation.

    - + \ No newline at end of file diff --git a/docs/tags/onboarding.html b/docs/tags/onboarding.html index d8523751a18..2e21fb6f7b8 100644 --- a/docs/tags/onboarding.html +++ b/docs/tags/onboarding.html @@ -13,13 +13,13 @@ - +

    5 docs tagged with "onboarding"

    View All Tags

    Lima

    Podman Desktop can assist you to create a custom Lima instance on Linux and macOS.

    - + \ No newline at end of file diff --git a/docs/tags/openshift-local.html b/docs/tags/openshift-local.html index 8712f07dbc9..384ec677fee 100644 --- a/docs/tags/openshift-local.html +++ b/docs/tags/openshift-local.html @@ -13,13 +13,13 @@ - + - + \ No newline at end of file diff --git a/docs/tags/openshift.html b/docs/tags/openshift.html index 4437140f196..b0f522dc642 100644 --- a/docs/tags/openshift.html +++ b/docs/tags/openshift.html @@ -13,13 +13,13 @@ - +

    3 docs tagged with "openshift"

    View All Tags
    - + \ No newline at end of file diff --git a/docs/tags/podman-desktop.html b/docs/tags/podman-desktop.html index c8af395a4d3..ed6c6c4534f 100644 --- a/docs/tags/podman-desktop.html +++ b/docs/tags/podman-desktop.html @@ -13,13 +13,13 @@ - +

    27 docs tagged with "podman-desktop"

    View All Tags

    Images

    Working with container images

    In your containers

    Using Podman Desktop behind a proxy requiring custom Certificate Authorities (CA).

    Installation

    You can install Podman Desktop on Windows, macOS, and Linux.

    Installing Podman

    Podman Desktop can assist you to install Podman on Windows and macOS.

    Lima

    Podman Desktop can assist you to create a custom Lima instance on Linux and macOS.

    Linux

    You can install Podman Desktop on Linux from Flathub, a Flatpak bundle, or a ZIP archive.

    Linux

    Using Podman Desktop behind a proxy on Linux.

    Windows

    How to install Podman on Windows.

    Writing

    Writing a Podman Desktop extension

    - + \ No newline at end of file diff --git a/docs/tags/podman.html b/docs/tags/podman.html index 06822a5f7cd..284d5fc5f51 100644 --- a/docs/tags/podman.html +++ b/docs/tags/podman.html @@ -13,13 +13,13 @@ - +

    5 docs tagged with "podman"

    View All Tags

    Installing Podman

    Podman Desktop can assist you to install Podman on Windows and macOS.

    - + \ No newline at end of file diff --git a/docs/tags/pods.html b/docs/tags/pods.html index ec95f870644..5586cb6b924 100644 --- a/docs/tags/pods.html +++ b/docs/tags/pods.html @@ -13,13 +13,13 @@ - + - + \ No newline at end of file diff --git a/docs/tags/proxy.html b/docs/tags/proxy.html index 806eb286c3c..c4dd60f1b0a 100644 --- a/docs/tags/proxy.html +++ b/docs/tags/proxy.html @@ -13,13 +13,13 @@ - +

    2 docs tagged with "proxy"

    View All Tags

    Linux

    Using Podman Desktop behind a proxy on Linux.

    - + \ No newline at end of file diff --git a/docs/tags/publishing.html b/docs/tags/publishing.html index 711e19be329..2e325bba4e3 100644 --- a/docs/tags/publishing.html +++ b/docs/tags/publishing.html @@ -13,13 +13,13 @@ - + - + \ No newline at end of file diff --git a/docs/tags/registries.html b/docs/tags/registries.html index 2695c8f1157..da0cd3caa29 100644 --- a/docs/tags/registries.html +++ b/docs/tags/registries.html @@ -13,13 +13,13 @@ - + - + \ No newline at end of file diff --git a/docs/tags/restricted-environment.html b/docs/tags/restricted-environment.html index 452385e69dc..153cfad2f41 100644 --- a/docs/tags/restricted-environment.html +++ b/docs/tags/restricted-environment.html @@ -13,13 +13,13 @@ - +

    2 docs tagged with "restricted-environment"

    View All Tags
    - + \ No newline at end of file diff --git a/docs/tags/scoop.html b/docs/tags/scoop.html index 7f59b700084..3fa7fa94463 100644 --- a/docs/tags/scoop.html +++ b/docs/tags/scoop.html @@ -13,13 +13,13 @@ - + - + \ No newline at end of file diff --git a/docs/tags/vpn.html b/docs/tags/vpn.html index 015b23196ee..14e4aae78f9 100644 --- a/docs/tags/vpn.html +++ b/docs/tags/vpn.html @@ -13,13 +13,13 @@ - + - + \ No newline at end of file diff --git a/docs/tags/when-clause.html b/docs/tags/when-clause.html index 69297602967..b0c9d313965 100644 --- a/docs/tags/when-clause.html +++ b/docs/tags/when-clause.html @@ -13,13 +13,13 @@ - + - + \ No newline at end of file diff --git a/docs/tags/windows.html b/docs/tags/windows.html index 63247d34c5e..37b2812a67c 100644 --- a/docs/tags/windows.html +++ b/docs/tags/windows.html @@ -13,13 +13,13 @@ - +

    14 docs tagged with "windows"

    View All Tags

    In your containers

    Using Podman Desktop behind a proxy requiring custom Certificate Authorities (CA).

    Installing Podman

    Podman Desktop can assist you to install Podman on Windows and macOS.

    Windows

    How to install Podman on Windows.

    - + \ No newline at end of file diff --git a/docs/tags/winget.html b/docs/tags/winget.html index 5efd928db1b..fb488ed8632 100644 --- a/docs/tags/winget.html +++ b/docs/tags/winget.html @@ -13,13 +13,13 @@ - + - + \ No newline at end of file diff --git a/docs/tags/writing.html b/docs/tags/writing.html index 4196ac1b5ca..e4019cfeed3 100644 --- a/docs/tags/writing.html +++ b/docs/tags/writing.html @@ -13,13 +13,13 @@ - + - + \ No newline at end of file diff --git a/docs/troubleshooting.html b/docs/troubleshooting.html index 5db07b61bba..9b560562fca 100644 --- a/docs/troubleshooting.html +++ b/docs/troubleshooting.html @@ -13,13 +13,13 @@ - +

    Troubleshooting

    If you cannot find your issue here or in the documentation, please fill an issue on our repository. You can also explore the discussions and do a search on similar issues on the repository.

    Using the Troubleshooting page

    Podman Desktop has a Troubleshooting page to help identify and fix most common errors.

    Procedure

    1. To open the Troubleshooting page, click the icon.

    2. To test the connection to the container engine, click the Ping button.

      Expect a reply such as: Responded: 79,75 (9.10ms).

    3. To test Click the Check containers button.

      Expect a reply such as: Responded: 16 containers (108.70ms).

    4. When connection to the container engine failed, to recreate connections to the sockets, click the Reconnect providers button.

      Expect a reply such as: Done in (5.00ms).

    5. Search for errors in the Logs section.

    Additional resources

    - + \ No newline at end of file diff --git a/docs/troubleshooting/troubleshooting-openshift-local.html b/docs/troubleshooting/troubleshooting-openshift-local.html index 65d8ea74ab9..f288cc4a761 100644 --- a/docs/troubleshooting/troubleshooting-openshift-local.html +++ b/docs/troubleshooting/troubleshooting-openshift-local.html @@ -13,13 +13,13 @@ - +

    Troubleshooting OpenShift Local

    You can find here troubleshooting help for issues specific to OpenShift Local.

    1. To verify that your user can run crc, verify that the crc binary is available in the user PATH (/usr/local/bin/crc on macOS and Linux).

    2. To verify that the host is ready to run OpenShift Local, in a terminal, run this command and verify the output has no errors:

      $ crc setup --check-only

      Sample output:

      INFO Using bundle path <bundle_path>
      INFO Checking if running as non-root
      INFO Checking if running inside WSL2
      INFO Checking if crc-admin-helper executable is cached
      crc-admin-helper executable is not cached
    3. To verify the configured preset, in a terminal, run:

      $ crc config get preset
    - + \ No newline at end of file diff --git a/docs/troubleshooting/troubleshooting-podman-on-linux.html b/docs/troubleshooting/troubleshooting-podman-on-linux.html index 6198fe8c83d..5587106025b 100644 --- a/docs/troubleshooting/troubleshooting-podman-on-linux.html +++ b/docs/troubleshooting/troubleshooting-podman-on-linux.html @@ -13,14 +13,14 @@ - +

    Troubleshooting Podman on Linux

    Podman Desktop does not manage native Podman

    On Linux, Podman usually runs natively on the host. Podman might also run in a virtual machine.

    Podman Desktop does only connect to the native rootless podman connection.

    Podman Desktop does not manage podman native configuration or podman machine (create, configure, start, stop, delete).

    Podman Desktop might manage configuration relative to connections to registries and proxies.

    - + \ No newline at end of file diff --git a/docs/troubleshooting/troubleshooting-podman-on-macos.html b/docs/troubleshooting/troubleshooting-podman-on-macos.html index c32299bf1be..53e566621ae 100644 --- a/docs/troubleshooting/troubleshooting-podman-on-macos.html +++ b/docs/troubleshooting/troubleshooting-podman-on-macos.html @@ -13,7 +13,7 @@ - + @@ -23,7 +23,7 @@ or any similar error denoting that Podman Engine does not exist.

    Explanation

    The Podman Installer and Homebrew use different locations to store the Podman Engine files in the file system. For example, Podman Installer installs Podman Engine in the path /opt/podman whereas Homebrew uses the path /usr/local for macOS Intel, /opt/homebrew for Apple Silicon and /home/linuxbrew/.linuxbrew for Linux.

    Solution

    To check where exactly is your Podman Engine installed, run the command-

    which podman

    This returns the path where the Podman Engine would be installed. This would help determine further action.

    For example, if you’re looking to completely uninstall Podman Engine from your system for a fresh installation, running which podman returns the exact path where Podman still exists. This could be the path where Podman Installer stores Podman Engine, such as /opt/podman. Once you know the path, run:

    sudo rm -rf /opt/podman

    Or

    sudo rm -rf path-where-podman-exists

    Here, you would replace path-where-podman-exists with the output of which podman.

    You can now proceed for a fresh installation of Podman Desktop

    Podman machine on Apple Silicon

    Issue

    If you are using an Apple Silicon and brew, you might encounter the following error when starting Podman from Podman Desktop

    Error: qemu exited unexpectedly with exit code 1, stderr: qemu-system-x86_64: invalid accelerator hvf
    qemu-system-x86_64: falling back to tcg
    qemu-system-x86_64: unable to find CPU model 'host'

    Explanation

    Podman machine is running as a x86_64 process and it could be due to a dual install of homebrew: one for x86_64 and one for arm64.

    Solution

    You can

    1. Uninstall Podman machine on your x86_64 brew install (for example from a terminal running under rosetta) brew uninstall podman
    2. or uninstall brew x86_64 as most brew receipe have now arm64 support: follow these instructions from a terminal running under rosetta

    Then run a terminal in native mode (default) and install Podman machine brew install podman

    Finally clean the Podman machine VMs that had been previously created, and create new ones.

    $ podman machine rm podman-machine-default
    $ podman machine init

    You should be a happy camper from here.

    Recovering from a failed start

    After a failed start, the Podman machine might be unable to start because a QEMU process is still running and the PID file is in use.

    Workaround

    1. Kill the remaining QEMU process and stop the Podman machine:

      $ ps -edf | grep qemu-system | grep -v grep | awk '{print $2}' | xargs -I{} kill -9 {}; podman machine stop
    2. Start the Podman machine.

    Solution

    Use Podman 4.6.1 or greater.

    Podman machine not starting with QEMU 8.1.0 from brew

    When you installed Podman and QEMU with brew, and QEMU version is 8.1.0, Podman machine might fail to start with an error such as: Error: qemu exited unexpectedly with exit code -1, stderr: qemu-system-x86_64: Error: HV_DENIED

    Solution

    Workaround

    Keep your brew-based installation and apply one of these workarounds:

    • Rollback the QEMU brew package to v8.0.3.

      $ brew uninstall qemu
      $ curl -OSL https://raw.githubusercontent.com/Homebrew/homebrew-core/dc0669eca9479e9eeb495397ba3a7480aaa45c2e/Formula/qemu.rb
      $ brew install ./qemu.rb
    • Alternatively, sign the QEMU brew binary locally:

      $ cat >entitlements.xml <<EOF
      <?xml version="1.0" encoding="UTF-8"?>
      <!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
      <plist version="1.0">
      <dict>
      <key>com.apple.security.hypervisor</key>
      <true/>
      </dict>
      </plist>
      EOF
      $ codesign --sign - --entitlements entitlements.xml --force /usr/local/bin/qemu-system-$(uname -m | sed -e s/arm64/aarch64/)

    Additional resources

    - + \ No newline at end of file diff --git a/docs/troubleshooting/troubleshooting-podman-on-windows.html b/docs/troubleshooting/troubleshooting-podman-on-windows.html index 802b6824102..b6a72c4facc 100644 --- a/docs/troubleshooting/troubleshooting-podman-on-windows.html +++ b/docs/troubleshooting/troubleshooting-podman-on-windows.html @@ -13,13 +13,13 @@ - +

    Troubleshooting Podman on Windows

    You can find here troubleshooting help for issues specific to Windows.

    Deleting a corrupted Podman Machine

    Issue

    1. You are not able to stop your Podman Machine.

      $ podman machine stop
    2. The Logs contain this error:

      Error: Error stopping sysd: exit status 1

    Workaround

    1. To display the active Windows Subsystem for Linux (WSL) distribution list: in the terminal, run:

      $ wsl --list
    2. The command returns the list of active WSL distributions. Identify your Podman Machine in the list, such as podman-machine-default.

    3. To stop, and uninstall your Podman Machine: in the terminal, replace podman-machine-default by your Podman machine name, and run:

      $ wsl --unregister podman-machine-default

    Additional resources

    The terminal session attaches to Podman Desktop when launching it from the command line

    Issue

    1. When you start Podman Desktop from the command line in Windows the terminal session attaches to it.
    2. When you quit the terminal, it kills Podman Desktop.

    Workaround

    • Set the environment variable ELECTRON_NO_ATTACH_CONSOLE to true before launching Podman Desktop.

    When the host is behind a VPN, Podman cannot access network resources

    When the host is behind a VPN, Podman might fail to access network resources, and display errors such as Temporary failure in name resolution.

    Solution

    See Accessing resources behind a VPN with Podman on Windows.

    Older WSL versions might lead to networking issues

    Older versions of WSL might cause networking issues, such as the Get-NetTCPConnection error, indicating that the WSL loopback forwarding facility is not functioning correctly. Recent versions of WSL do not have this issue.

    Solution

    1. Update Windows to either the 21H1, 21H2, or 22H2 version of Windows 10, or to the 21H1 version of Windows 11, or greater.

    2. Update WSL:

      wsl --update
    3. Optionally, delete your Podman machine, and create a new one.

    - + \ No newline at end of file diff --git a/docs/troubleshooting/troubleshooting-podman.html b/docs/troubleshooting/troubleshooting-podman.html index 65e8ef425cd..1934e8955d1 100644 --- a/docs/troubleshooting/troubleshooting-podman.html +++ b/docs/troubleshooting/troubleshooting-podman.html @@ -13,7 +13,7 @@ - + @@ -23,7 +23,7 @@ After each step, quit and restart Podman Desktop to ensure that it can detect yo img

    Solution

    1. Stop and restart Podman Desktop.

    2. In Podman Desktop, restart the Podman machine.

    3. In a terminal, restart the Podman machine:

      $ podman machine stop
      $ podman machine start
    4. If the previous step did not work for you, delete your Podman machine, and create a new one:

      $ podman machine rm
      $ podman machine init
    5. If the previous steps did not work for you, delete your Podman configuration files, and create a new Podman machine:

      $ rm -rf ~/.local/share/containers/podman
      $ rm -rf ~/.config/containers/
      $ podman machine init

    Podman Desktop is failing to display the images or containers from a rootful Podman machine

    The rootful configuration for a Podman machine depends on the Podman machine default connection. The default connection can be modified by external events, or when creating a new Podman machine. Podman Desktop might then reconnect in rootless mode, and fail to display the images or containers.

    Workaround

    1. Verify that the Podman default connection is the rootful connection to your Podman machine:

      $ podman system connection ls

      The default connection has true at the end of the line.

      The rootful connection has a -root name suffix, and a ssh://root@ URI prefix.

      Example default rootful connection:

      Name                        URI                                                         Identity                                      Default
      podman-machine-default ssh://user@127.0.0.1:54826/run/user/1000/podman/podman.sock c:\Users\username\.ssh\podman-machine-default false
      podman-machine-default-root ssh://root@127.0.0.1:54826/run/podman/podman.sock c:\Users\username\.ssh\podman-machine-default true

      Example default rootless connection:

      Name                        URI                                                         Identity                                      Default
      podman-machine-default ssh://user@127.0.0.1:54826/run/user/1000/podman/podman.sock c:\Users\username\.ssh\podman-machine-default true
      podman-machine-default-root ssh://root@127.0.0.1:54826/run/podman/podman.sock c:\Users\username\.ssh\podman-machine-default false

      Continue with the next steps only if the default connection is not the rootful connection to your Podman machine.

    2. Set the Podman machine in rootful mode:

      $ podman machine set --rootful
    3. Restart the Podman machine:

      $ podman machine stop
      $ podman machine start
    4. Verify that Podman default connection points to the rootful connection:

      $ podman system connection ls

      Continue with the next steps only if the default connection is not the rootful connection to your Podman machine.

    5. Set the Podman machine, such as podman-machine-default in rootful mode:

      $ podman system connection default podman-machine-default-root
    6. Restart the Podman machine:

      $ podman machine stop
      $ podman machine start

    Verification

    1. The Podman default connection is the rootful connection to your Podman machine:

      $ podman system connection ls

    Warning about Docker compatibility mode

    Issue

    When running the Podman provider, a warning shows regarding Docker compatibility mode on the dashboard:

    ⚠️ Docker Socket Compatibility: Podman is not emulating the default Docker socket path: '/var/run/docker.sock'. Docker-specific tools may not work. See troubleshooting page on podman-desktop.io for more information.

    This might appear when either:

    • The Docker socket is not mounted correctly.
    • Docker Desktop is also being ran at the same time.

    Solution

    1. Stop Docker Desktop (if installed).

    2. On macOS, Run the podman-mac-helper binary:

      $ sudo podman-mac-helper install
    3. Restart the Podman machine to recreate and activate the default Docker socket path.

    Note: If Docker Desktop is started again, it will automatically re-alias the default Docker socket location and the Podman compatibility warning will re-appear.

    - + \ No newline at end of file diff --git a/downloads.html b/downloads.html index 7f91c07dce2..af387670861 100644 --- a/downloads.html +++ b/downloads.html @@ -13,13 +13,13 @@ - +

    Downloads

    Windows

    Podman Desktop for Windows

    Download NowWindows installer x64, version
    Other Windows downloads:
    Installer:
    Portable binary:
    Installer for restricted environments:
    Package Managers Guide

    Using winget? Install in one command:

    winget install -e --id RedHat.Podman-Desktop

    macOS

    Podman Desktop for macOS

    Download NowUniversal *.dmg, version

    Using Brew? Install in one command:

    brew install podman-desktop

    Linux

    Podman Desktop for Linux

    Download NowLinux *.flatpak, version
    Other Linux downloads:
    AMD64 binary (tar.gz)

    Using Flathub ? Install in one command:

    flatpak install flathub io.podman_desktop.PodmanDesktop
    - + \ No newline at end of file diff --git a/downloads/linux.html b/downloads/linux.html index 341be452323..8cc072cdac2 100644 --- a/downloads/linux.html +++ b/downloads/linux.html @@ -13,13 +13,13 @@ - +

    Linux Downloads

    Linux

    Podman Desktop for Linux

    Download NowLinux *.flatpak, version
    Other Linux downloads:
    AMD64 binary (tar.gz)

    Using Flathub ? Install in one command:

    flatpak install flathub io.podman_desktop.PodmanDesktop
    - + \ No newline at end of file diff --git a/downloads/macos.html b/downloads/macos.html index ecb5486f2af..3b727e0e1c4 100644 --- a/downloads/macos.html +++ b/downloads/macos.html @@ -13,13 +13,13 @@ - +

    macOS Downloads

    macOS

    Podman Desktop for macOS

    Download NowUniversal *.dmg, version

    Using Brew? Install in one command:

    brew install podman-desktop

    - + \ No newline at end of file diff --git a/downloads/windows.html b/downloads/windows.html index 03aabb9247f..3057fce6d6f 100644 --- a/downloads/windows.html +++ b/downloads/windows.html @@ -13,13 +13,13 @@ - +

    Windows Downloads

    Windows

    Podman Desktop for Windows

    Download NowWindows installer x64, version
    Other Windows downloads:
    Installer:
    Portable binary:
    Installer for restricted environments:
    Package Managers Guide

    Using winget? Install in one command:

    winget install -e --id RedHat.Podman-Desktop
    - + \ No newline at end of file diff --git a/extend.html b/extend.html index e4776747743..41de7487154 100644 --- a/extend.html +++ b/extend.html @@ -13,13 +13,13 @@ - +

    Extend capabilities with Docker Desktop extensions.

    Podman Desktop is able to use Docker Desktop UI plug-ins by adding a wrapper to intercept the API calls.

    By adding a Docker Desktop extension, you can extend the capabilities of Podman Desktop.

    Extend with Docker Desktop extensionsExtend with Docker Desktop extensionsReuse Docker Desktop extensionsReuse Docker Desktop extensions

    Extend capabilities with Podman Desktop plug-ins.

    Podman Desktop is using plug-ins under the hood to manage the different container engine.

    By adding a new plugin, you can extend the capabilities of Podman Desktop.

    For example plug a new container engine like Podman, Docker, or use Lima.

    Extensibility diagramExtensibility diagram

    Extensions are written in JavaScript/Typescript
    It consumes a TypeScript definition of the extension model.

    More extension points

    Several extension points exists in addition to adding a Provider connection.

    User interaction, dialogs, launching commands are among the possible ways to extend Podman Desktop

    - + \ No newline at end of file diff --git a/features.html b/features.html index cf3d6d0b936..dbf8c00e09e 100644 --- a/features.html +++ b/features.html @@ -13,13 +13,13 @@ - +

    Manage containers

    List, Search, Inspect, Connect, Run and Stop containers.

    Manage containersManage containers
    Pull image and manage registriesPull image and manage registries

    Build, Pull and Push images

    Build images from the tool.

    Pull and push images by managing registries.

    Run containers from these images

    Management from the tray icon

    Check status and start/stop container engines.

    Create new machine if needed as well as start or stop Podman machines directly from the tray icon.

    Quickly check activity status and stay updated without losing focus from other tasks.

    Manage Podman MachineManage Podman Machine
    Manage Podman MachineManage Podman Machine

    Manage Podman resources

    View allocated memory, CPU and storage.

    Create new machine if needed

    Create and start Pods with Podman

    Select containers to run as a Pod.

    Play Kubernetes YAML locally without Kubernetes.

    Generate Kubernetes YAML from Pods.

    Manage PodsManage Pods
    Pull image and manage registriesPull image and manage registries

    Import Docker Desktop extensions

    Specify OCI image of a Docker Desktop extension to import it.

    For example: security scanner or deploy to OpenShift extensions.

    - + \ No newline at end of file diff --git a/index.html b/index.html index 142010a6a56..2150f62330c 100644 --- a/index.html +++ b/index.html @@ -13,13 +13,13 @@ - +

    Containers and Kubernetes for application developers

    Podman Desktop is an open source graphical tool enabling you to seamlessly work with containers and Kubernetes from your local environment.

    Podman Desktop home page

    Available on Windows, Mac and Linux

    Use the same UI across different operating systems

    features

    Build, run and manage containers.

    Inspect

    Get a terminal in your container

    Inspect logs

    Push

    Push images to OCI registries

    Deploy & Test images on Kubernetes

    features

    Work with Pods and Kubernetes

    Working with pods

    Create Pods from existing containers

    Create, start, inspect and manage pods

    Working with Kubernetes

    Play Kubernetes YAML directly with Podman Engine

    Generate Kubernetes YAML from pods

    Deploy to existing Kubernetes environments

    Running Kubernetes on your workstation with Kind and Podman

    Configure

    Multiple configuration options

    Resources Utilization

    Configure CPU/Memory/Disk of Podman machines.

    extensibility

    Bring new features with Podman Desktop plug-ins or Docker Desktop Extensions.

    • Container engines are plugged through extension points
    • JavaScript extensions can contribute new behaviour
    • Reuse existing extensions such as Trivy and OpenShift directly in Podman Desktop

    Current Podman Desktop plugins: Podman, Docker, Lima, Kubernetes, and OpenShift Local with the Podman preset.

    Reuse Docker Desktop extensionsReuse Docker Desktop extensions

    update

    Install and keep up to date Podman

    Install Podman and other dependencies directly from Podman Desktop if not yet installed.

    Check for updates and get notified about new changes.

    Available on Windows and macOS!

    - + \ No newline at end of file diff --git a/search.html b/search.html index 593d48187ee..5dd8f3ec49b 100644 --- a/search.html +++ b/search.html @@ -13,13 +13,13 @@ - + - + \ No newline at end of file