自动生成systemd unit 文件
podman generate systemd --new --name web --files
# container-d1154c740c9c8b9492488a3af91c2d7bcb6f515b82c67c21357139f3288dc1ef.service
# autogenerated by Podman 3.4.4
# Sat Apr 27 09:54:33 UTC 2024
[Unit]
Description=Podman container-d1154c740c9c8b9492488a3af91c2d7bcb6f515b82c67c21357139f3288dc1ef.service
Documentation=man:podman-generate-systemd(1)
Wants=network-online.target
After=network-online.target
RequiresMountsFor=/run/user/1000/containers
[Service]
Environment=PODMAN_SYSTEMD_UNIT=%n
Restart=always
TimeoutStopSec=70
ExecStart=/usr/bin/podman start d1154c740c9c8b9492488a3af91c2d7bcb6f515b82c67c21357139f3288dc1ef
ExecStop=/usr/bin/podman stop -t 10 d1154c740c9c8b9492488a3af91c2d7bcb6f515b82c67c21357139f3288dc1ef
ExecStopPost=/usr/bin/podman stop -t 10 d1154c740c9c8b9492488a3af91c2d7bcb6f515b82c67c21357139f3288dc1ef
PIDFile=/run/user/1000/containers/overlay-containers/d1154c740c9c8b9492488a3af91c2d7bcb6f515b82c67c21357139f3288dc1ef/userdata/conmon.pid
Type=forking
[Install]
WantedBy=default.target
镜像配置地址
全局配置文件:/etc/containers/registries.conf
用户配置文件:~/.config/containers/registries.conf
启动
podman-compose 项目
https://github.com/containers/podman-compose
vscode remote container 找不到docker.sock 解决方法
核心思路就是。把docker.sock 软连接岛 podman 的sock 。
#先看自己的podman 有没有起来api服务,没有看下面的连接。我配过开机自启的docker 服务所有就有了
systemctl status podman
#然后搜索sock在哪
find / -name podman.sock
/run/user/1000/podman/podman.sock
#最好建立一个软连接。如果最后提示权限不行。记得把前线设置一下。
sudo ln -s /run/user/1000/podman/podman.sock /var/run/docker.sock
#如果你和我一样使用了非root的账户操作的。在使用官方的开发镜像时候会报权限问题。原因是官方会用vscode 账号登陆镜像然后在root中创建文件。所以报错之后要手动先上环境给/root 复权一下。不然跑不起来
这个软连接每次重启会被清空。所以要开机启动自动建立他
[Unit]
Description=Create Symlink for podman Socket
[Service]
Type=oneshot
ExecStart=/bin/ln -s /run/user/1000/podman/podman.sock /var/run/docker.sock
[Install]
WantedBy=multi-user.target
##移动到这个地方并且复权
sudo chmod 644 /etc/systemd/system/create-symlink.service
sudo systemctl daemon-reload
sudo systemctl enable create-symlink.service
sudo systemctl start create-symlink.service
sudo systemctl status create-symlink.service
【- Podman API Service】
https://docs.redhat.com/zh_hans/documentation/red_hat_enterprise_linux/8/html/building_running_and_managing_containers/enabling-the-podman-api-using-systemd-in-rootless-mode_using-the-container-tools-api
https://xie.infoq.cn/article/8eaab3ee40aa48e389ba37525
[[非root 创建开发容器]
https://code.visualstudio.com/remote/advancedcontainers/add-nonroot-user