Sync from SUSE:ALP:Source:Standard:1.0 libcontainers-common revision 28a2239c3ba078dcefba76f5c4fd724a
This commit is contained in:
commit
4e3dc06447
23
.gitattributes
vendored
Normal file
23
.gitattributes
vendored
Normal file
@ -0,0 +1,23 @@
|
|||||||
|
## Default LFS
|
||||||
|
*.7z filter=lfs diff=lfs merge=lfs -text
|
||||||
|
*.bsp filter=lfs diff=lfs merge=lfs -text
|
||||||
|
*.bz2 filter=lfs diff=lfs merge=lfs -text
|
||||||
|
*.gem filter=lfs diff=lfs merge=lfs -text
|
||||||
|
*.gz filter=lfs diff=lfs merge=lfs -text
|
||||||
|
*.jar filter=lfs diff=lfs merge=lfs -text
|
||||||
|
*.lz filter=lfs diff=lfs merge=lfs -text
|
||||||
|
*.lzma filter=lfs diff=lfs merge=lfs -text
|
||||||
|
*.obscpio filter=lfs diff=lfs merge=lfs -text
|
||||||
|
*.oxt filter=lfs diff=lfs merge=lfs -text
|
||||||
|
*.pdf filter=lfs diff=lfs merge=lfs -text
|
||||||
|
*.png filter=lfs diff=lfs merge=lfs -text
|
||||||
|
*.rpm filter=lfs diff=lfs merge=lfs -text
|
||||||
|
*.tbz filter=lfs diff=lfs merge=lfs -text
|
||||||
|
*.tbz2 filter=lfs diff=lfs merge=lfs -text
|
||||||
|
*.tgz filter=lfs diff=lfs merge=lfs -text
|
||||||
|
*.ttf filter=lfs diff=lfs merge=lfs -text
|
||||||
|
*.txz filter=lfs diff=lfs merge=lfs -text
|
||||||
|
*.whl filter=lfs diff=lfs merge=lfs -text
|
||||||
|
*.xz filter=lfs diff=lfs merge=lfs -text
|
||||||
|
*.zip filter=lfs diff=lfs merge=lfs -text
|
||||||
|
*.zst filter=lfs diff=lfs merge=lfs -text
|
189
LICENSE
Normal file
189
LICENSE
Normal file
@ -0,0 +1,189 @@
|
|||||||
|
|
||||||
|
Apache License
|
||||||
|
Version 2.0, January 2004
|
||||||
|
https://www.apache.org/licenses/
|
||||||
|
|
||||||
|
TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION
|
||||||
|
|
||||||
|
1. Definitions.
|
||||||
|
|
||||||
|
"License" shall mean the terms and conditions for use, reproduction,
|
||||||
|
and distribution as defined by Sections 1 through 9 of this document.
|
||||||
|
|
||||||
|
"Licensor" shall mean the copyright owner or entity authorized by
|
||||||
|
the copyright owner that is granting the License.
|
||||||
|
|
||||||
|
"Legal Entity" shall mean the union of the acting entity and all
|
||||||
|
other entities that control, are controlled by, or are under common
|
||||||
|
control with that entity. For the purposes of this definition,
|
||||||
|
"control" means (i) the power, direct or indirect, to cause the
|
||||||
|
direction or management of such entity, whether by contract or
|
||||||
|
otherwise, or (ii) ownership of fifty percent (50%) or more of the
|
||||||
|
outstanding shares, or (iii) beneficial ownership of such entity.
|
||||||
|
|
||||||
|
"You" (or "Your") shall mean an individual or Legal Entity
|
||||||
|
exercising permissions granted by this License.
|
||||||
|
|
||||||
|
"Source" form shall mean the preferred form for making modifications,
|
||||||
|
including but not limited to software source code, documentation
|
||||||
|
source, and configuration files.
|
||||||
|
|
||||||
|
"Object" form shall mean any form resulting from mechanical
|
||||||
|
transformation or translation of a Source form, including but
|
||||||
|
not limited to compiled object code, generated documentation,
|
||||||
|
and conversions to other media types.
|
||||||
|
|
||||||
|
"Work" shall mean the work of authorship, whether in Source or
|
||||||
|
Object form, made available under the License, as indicated by a
|
||||||
|
copyright notice that is included in or attached to the work
|
||||||
|
(an example is provided in the Appendix below).
|
||||||
|
|
||||||
|
"Derivative Works" shall mean any work, whether in Source or Object
|
||||||
|
form, that is based on (or derived from) the Work and for which the
|
||||||
|
editorial revisions, annotations, elaborations, or other modifications
|
||||||
|
represent, as a whole, an original work of authorship. For the purposes
|
||||||
|
of this License, Derivative Works shall not include works that remain
|
||||||
|
separable from, or merely link (or bind by name) to the interfaces of,
|
||||||
|
the Work and Derivative Works thereof.
|
||||||
|
|
||||||
|
"Contribution" shall mean any work of authorship, including
|
||||||
|
the original version of the Work and any modifications or additions
|
||||||
|
to that Work or Derivative Works thereof, that is intentionally
|
||||||
|
submitted to Licensor for inclusion in the Work by the copyright owner
|
||||||
|
or by an individual or Legal Entity authorized to submit on behalf of
|
||||||
|
the copyright owner. For the purposes of this definition, "submitted"
|
||||||
|
means any form of electronic, verbal, or written communication sent
|
||||||
|
to the Licensor or its representatives, including but not limited to
|
||||||
|
communication on electronic mailing lists, source code control systems,
|
||||||
|
and issue tracking systems that are managed by, or on behalf of, the
|
||||||
|
Licensor for the purpose of discussing and improving the Work, but
|
||||||
|
excluding communication that is conspicuously marked or otherwise
|
||||||
|
designated in writing by the copyright owner as "Not a Contribution."
|
||||||
|
|
||||||
|
"Contributor" shall mean Licensor and any individual or Legal Entity
|
||||||
|
on behalf of whom a Contribution has been received by Licensor and
|
||||||
|
subsequently incorporated within the Work.
|
||||||
|
|
||||||
|
2. Grant of Copyright License. Subject to the terms and conditions of
|
||||||
|
this License, each Contributor hereby grants to You a perpetual,
|
||||||
|
worldwide, non-exclusive, no-charge, royalty-free, irrevocable
|
||||||
|
copyright license to reproduce, prepare Derivative Works of,
|
||||||
|
publicly display, publicly perform, sublicense, and distribute the
|
||||||
|
Work and such Derivative Works in Source or Object form.
|
||||||
|
|
||||||
|
3. Grant of Patent License. Subject to the terms and conditions of
|
||||||
|
this License, each Contributor hereby grants to You a perpetual,
|
||||||
|
worldwide, non-exclusive, no-charge, royalty-free, irrevocable
|
||||||
|
(except as stated in this section) patent license to make, have made,
|
||||||
|
use, offer to sell, sell, import, and otherwise transfer the Work,
|
||||||
|
where such license applies only to those patent claims licensable
|
||||||
|
by such Contributor that are necessarily infringed by their
|
||||||
|
Contribution(s) alone or by combination of their Contribution(s)
|
||||||
|
with the Work to which such Contribution(s) was submitted. If You
|
||||||
|
institute patent litigation against any entity (including a
|
||||||
|
cross-claim or counterclaim in a lawsuit) alleging that the Work
|
||||||
|
or a Contribution incorporated within the Work constitutes direct
|
||||||
|
or contributory patent infringement, then any patent licenses
|
||||||
|
granted to You under this License for that Work shall terminate
|
||||||
|
as of the date such litigation is filed.
|
||||||
|
|
||||||
|
4. Redistribution. You may reproduce and distribute copies of the
|
||||||
|
Work or Derivative Works thereof in any medium, with or without
|
||||||
|
modifications, and in Source or Object form, provided that You
|
||||||
|
meet the following conditions:
|
||||||
|
|
||||||
|
(a) You must give any other recipients of the Work or
|
||||||
|
Derivative Works a copy of this License; and
|
||||||
|
|
||||||
|
(b) You must cause any modified files to carry prominent notices
|
||||||
|
stating that You changed the files; and
|
||||||
|
|
||||||
|
(c) You must retain, in the Source form of any Derivative Works
|
||||||
|
that You distribute, all copyright, patent, trademark, and
|
||||||
|
attribution notices from the Source form of the Work,
|
||||||
|
excluding those notices that do not pertain to any part of
|
||||||
|
the Derivative Works; and
|
||||||
|
|
||||||
|
(d) If the Work includes a "NOTICE" text file as part of its
|
||||||
|
distribution, then any Derivative Works that You distribute must
|
||||||
|
include a readable copy of the attribution notices contained
|
||||||
|
within such NOTICE file, excluding those notices that do not
|
||||||
|
pertain to any part of the Derivative Works, in at least one
|
||||||
|
of the following places: within a NOTICE text file distributed
|
||||||
|
as part of the Derivative Works; within the Source form or
|
||||||
|
documentation, if provided along with the Derivative Works; or,
|
||||||
|
within a display generated by the Derivative Works, if and
|
||||||
|
wherever such third-party notices normally appear. The contents
|
||||||
|
of the NOTICE file are for informational purposes only and
|
||||||
|
do not modify the License. You may add Your own attribution
|
||||||
|
notices within Derivative Works that You distribute, alongside
|
||||||
|
or as an addendum to the NOTICE text from the Work, provided
|
||||||
|
that such additional attribution notices cannot be construed
|
||||||
|
as modifying the License.
|
||||||
|
|
||||||
|
You may add Your own copyright statement to Your modifications and
|
||||||
|
may provide additional or different license terms and conditions
|
||||||
|
for use, reproduction, or distribution of Your modifications, or
|
||||||
|
for any such Derivative Works as a whole, provided Your use,
|
||||||
|
reproduction, and distribution of the Work otherwise complies with
|
||||||
|
the conditions stated in this License.
|
||||||
|
|
||||||
|
5. Submission of Contributions. Unless You explicitly state otherwise,
|
||||||
|
any Contribution intentionally submitted for inclusion in the Work
|
||||||
|
by You to the Licensor shall be under the terms and conditions of
|
||||||
|
this License, without any additional terms or conditions.
|
||||||
|
Notwithstanding the above, nothing herein shall supersede or modify
|
||||||
|
the terms of any separate license agreement you may have executed
|
||||||
|
with Licensor regarding such Contributions.
|
||||||
|
|
||||||
|
6. Trademarks. This License does not grant permission to use the trade
|
||||||
|
names, trademarks, service marks, or product names of the Licensor,
|
||||||
|
except as required for reasonable and customary use in describing the
|
||||||
|
origin of the Work and reproducing the content of the NOTICE file.
|
||||||
|
|
||||||
|
7. Disclaimer of Warranty. Unless required by applicable law or
|
||||||
|
agreed to in writing, Licensor provides the Work (and each
|
||||||
|
Contributor provides its Contributions) on an "AS IS" BASIS,
|
||||||
|
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
|
||||||
|
implied, including, without limitation, any warranties or conditions
|
||||||
|
of TITLE, NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A
|
||||||
|
PARTICULAR PURPOSE. You are solely responsible for determining the
|
||||||
|
appropriateness of using or redistributing the Work and assume any
|
||||||
|
risks associated with Your exercise of permissions under this License.
|
||||||
|
|
||||||
|
8. Limitation of Liability. In no event and under no legal theory,
|
||||||
|
whether in tort (including negligence), contract, or otherwise,
|
||||||
|
unless required by applicable law (such as deliberate and grossly
|
||||||
|
negligent acts) or agreed to in writing, shall any Contributor be
|
||||||
|
liable to You for damages, including any direct, indirect, special,
|
||||||
|
incidental, or consequential damages of any character arising as a
|
||||||
|
result of this License or out of the use or inability to use the
|
||||||
|
Work (including but not limited to damages for loss of goodwill,
|
||||||
|
work stoppage, computer failure or malfunction, or any and all
|
||||||
|
other commercial damages or losses), even if such Contributor
|
||||||
|
has been advised of the possibility of such damages.
|
||||||
|
|
||||||
|
9. Accepting Warranty or Additional Liability. While redistributing
|
||||||
|
the Work or Derivative Works thereof, You may choose to offer,
|
||||||
|
and charge a fee for, acceptance of support, warranty, indemnity,
|
||||||
|
or other liability obligations and/or rights consistent with this
|
||||||
|
License. However, in accepting such obligations, You may act only
|
||||||
|
on Your own behalf and on Your sole responsibility, not on behalf
|
||||||
|
of any other Contributor, and only if You agree to indemnify,
|
||||||
|
defend, and hold each Contributor harmless for any liability
|
||||||
|
incurred by, or claims asserted against, such Contributor by reason
|
||||||
|
of your accepting any such warranty or additional liability.
|
||||||
|
|
||||||
|
END OF TERMS AND CONDITIONS
|
||||||
|
|
||||||
|
Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
you may not use this file except in compliance with the License.
|
||||||
|
You may obtain a copy of the License at
|
||||||
|
|
||||||
|
https://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
|
||||||
|
Unless required by applicable law or agreed to in writing, software
|
||||||
|
distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
See the License for the specific language governing permissions and
|
||||||
|
limitations under the License.
|
30
_service
Normal file
30
_service
Normal file
@ -0,0 +1,30 @@
|
|||||||
|
<services>
|
||||||
|
<service name="tar_scm" mode="manual">
|
||||||
|
<param name="url">https://github.com/containers/storage.git</param>
|
||||||
|
<param name="scm">git</param>
|
||||||
|
<param name="filename">storage</param>
|
||||||
|
<param name="revision">v1.51.0</param>
|
||||||
|
<param name="versionformat">@PARENT_TAG@</param>
|
||||||
|
<param name="versionrewrite-pattern">v(.*)</param>
|
||||||
|
</service>
|
||||||
|
<service name="tar_scm" mode="manual">
|
||||||
|
<param name="url">https://github.com/containers/image.git</param>
|
||||||
|
<param name="scm">git</param>
|
||||||
|
<param name="filename">image</param>
|
||||||
|
<param name="revision">v5.29.2</param>
|
||||||
|
<param name="versionformat">@PARENT_TAG@</param>
|
||||||
|
<param name="versionrewrite-pattern">v(.*)</param>
|
||||||
|
</service>
|
||||||
|
<service name="tar_scm" mode="manual">
|
||||||
|
<param name="url">https://github.com/containers/common.git</param>
|
||||||
|
<param name="scm">git</param>
|
||||||
|
<param name="filename">common</param>
|
||||||
|
<param name="revision">v0.57.4</param>
|
||||||
|
<param name="versionformat">@PARENT_TAG@</param>
|
||||||
|
<param name="versionrewrite-pattern">v(.*)</param>
|
||||||
|
</service>
|
||||||
|
<service name="recompress" mode="manual">
|
||||||
|
<param name="file">*.tar</param>
|
||||||
|
<param name="compression">xz</param>
|
||||||
|
</service>
|
||||||
|
</services>
|
BIN
common-0.57.4.tar.xz
(Stored with Git LFS)
Normal file
BIN
common-0.57.4.tar.xz
(Stored with Git LFS)
Normal file
Binary file not shown.
720
containers.conf
Normal file
720
containers.conf
Normal file
@ -0,0 +1,720 @@
|
|||||||
|
# The containers configuration file specifies all of the available configuration
|
||||||
|
# command-line options/flags for container engine tools like Podman & Buildah,
|
||||||
|
# but in a TOML format that can be easily modified and versioned.
|
||||||
|
|
||||||
|
# Please refer to containers.conf(5) for details of all configuration options.
|
||||||
|
# Not all container engines implement all of the options.
|
||||||
|
# All of the options have hard coded defaults and these options will override
|
||||||
|
# the built in defaults. Users can then override these options via the command
|
||||||
|
# line. Container engines will read containers.conf files in up to three
|
||||||
|
# locations in the following order:
|
||||||
|
# 1. /usr/share/containers/containers.conf
|
||||||
|
# 2. /etc/containers/containers.conf
|
||||||
|
# 3. $HOME/.config/containers/containers.conf (Rootless containers ONLY)
|
||||||
|
# Items specified in the latter containers.conf, if they exist, override the
|
||||||
|
# previous containers.conf settings, or the default settings.
|
||||||
|
|
||||||
|
[containers]
|
||||||
|
|
||||||
|
# List of annotation. Specified as
|
||||||
|
# "key = value"
|
||||||
|
# If it is empty or commented out, no annotations will be added
|
||||||
|
#
|
||||||
|
#annotations = []
|
||||||
|
|
||||||
|
# Used to change the name of the default AppArmor profile of container engine.
|
||||||
|
#
|
||||||
|
#apparmor_profile = "container-default"
|
||||||
|
|
||||||
|
# The hosts entries from the base hosts file are added to the containers hosts
|
||||||
|
# file. This must be either an absolute path or as special values "image" which
|
||||||
|
# uses the hosts file from the container image or "none" which means
|
||||||
|
# no base hosts file is used. The default is "" which will use /etc/hosts.
|
||||||
|
#
|
||||||
|
#base_hosts_file = ""
|
||||||
|
|
||||||
|
# Default way to to create a cgroup namespace for the container
|
||||||
|
# Options are:
|
||||||
|
# `private` Create private Cgroup Namespace for the container.
|
||||||
|
# `host` Share host Cgroup Namespace with the container.
|
||||||
|
#
|
||||||
|
#cgroupns = "private"
|
||||||
|
|
||||||
|
# Control container cgroup configuration
|
||||||
|
# Determines whether the container will create CGroups.
|
||||||
|
# Options are:
|
||||||
|
# `enabled` Enable cgroup support within container
|
||||||
|
# `disabled` Disable cgroup support, will inherit cgroups from parent
|
||||||
|
# `no-conmon` Do not create a cgroup dedicated to conmon.
|
||||||
|
#
|
||||||
|
#cgroups = "enabled"
|
||||||
|
|
||||||
|
# List of default capabilities for containers. If it is empty or commented out,
|
||||||
|
# the default capabilities defined in the container engine will be added.
|
||||||
|
#
|
||||||
|
default_capabilities = [
|
||||||
|
"CHOWN",
|
||||||
|
"DAC_OVERRIDE",
|
||||||
|
"FOWNER",
|
||||||
|
"FSETID",
|
||||||
|
"KILL",
|
||||||
|
"NET_BIND_SERVICE",
|
||||||
|
"SETFCAP",
|
||||||
|
"SETGID",
|
||||||
|
"SETPCAP",
|
||||||
|
"SETUID",
|
||||||
|
"SYS_CHROOT"
|
||||||
|
]
|
||||||
|
|
||||||
|
# A list of sysctls to be set in containers by default,
|
||||||
|
# specified as "name=value",
|
||||||
|
# for example:"net.ipv4.ping_group_range=0 0".
|
||||||
|
#
|
||||||
|
default_sysctls = [
|
||||||
|
"net.ipv4.ping_group_range=0 0",
|
||||||
|
]
|
||||||
|
|
||||||
|
# A list of ulimits to be set in containers by default, specified as
|
||||||
|
# "<ulimit name>=<soft limit>:<hard limit>", for example:
|
||||||
|
# "nofile=1024:2048"
|
||||||
|
# See setrlimit(2) for a list of resource names.
|
||||||
|
# Any limit not specified here will be inherited from the process launching the
|
||||||
|
# container engine.
|
||||||
|
# Ulimits has limits for non privileged container engines.
|
||||||
|
#
|
||||||
|
#default_ulimits = [
|
||||||
|
# "nofile=1280:2560",
|
||||||
|
#]
|
||||||
|
|
||||||
|
# List of devices. Specified as
|
||||||
|
# "<device-on-host>:<device-on-container>:<permissions>", for example:
|
||||||
|
# "/dev/sdc:/dev/xvdc:rwm".
|
||||||
|
# If it is empty or commented out, only the default devices will be used
|
||||||
|
#
|
||||||
|
#devices = []
|
||||||
|
|
||||||
|
# List of default DNS options to be added to /etc/resolv.conf inside of the container.
|
||||||
|
#
|
||||||
|
#dns_options = []
|
||||||
|
|
||||||
|
# List of default DNS search domains to be added to /etc/resolv.conf inside of the container.
|
||||||
|
#
|
||||||
|
#dns_searches = []
|
||||||
|
|
||||||
|
# Set default DNS servers.
|
||||||
|
# This option can be used to override the DNS configuration passed to the
|
||||||
|
# container. The special value "none" can be specified to disable creation of
|
||||||
|
# /etc/resolv.conf in the container.
|
||||||
|
# The /etc/resolv.conf file in the image will be used without changes.
|
||||||
|
#
|
||||||
|
#dns_servers = []
|
||||||
|
|
||||||
|
# Environment variable list for the conmon process; used for passing necessary
|
||||||
|
# environment variables to conmon or the runtime.
|
||||||
|
#
|
||||||
|
#env = [
|
||||||
|
# "PATH=/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin",
|
||||||
|
# "TERM=xterm",
|
||||||
|
#]
|
||||||
|
|
||||||
|
# Pass all host environment variables into the container.
|
||||||
|
#
|
||||||
|
#env_host = false
|
||||||
|
|
||||||
|
# Set the ip for the host.containers.internal entry in the containers /etc/hosts
|
||||||
|
# file. This can be set to "none" to disable adding this entry. By default it
|
||||||
|
# will automatically choose the host ip.
|
||||||
|
#
|
||||||
|
# NOTE: When using podman machine this entry will never be added to the containers
|
||||||
|
# hosts file instead the gvproxy dns resolver will resolve this hostname. Therefore
|
||||||
|
# it is not possible to disable the entry in this case.
|
||||||
|
#
|
||||||
|
#host_containers_internal_ip = ""
|
||||||
|
|
||||||
|
# Default proxy environment variables passed into the container.
|
||||||
|
# The environment variables passed in include:
|
||||||
|
# http_proxy, https_proxy, ftp_proxy, no_proxy, and the upper case versions of
|
||||||
|
# these. This option is needed when host system uses a proxy but container
|
||||||
|
# should not use proxy. Proxy environment variables specified for the container
|
||||||
|
# in any other way will override the values passed from the host.
|
||||||
|
#
|
||||||
|
#http_proxy = true
|
||||||
|
|
||||||
|
# Run an init inside the container that forwards signals and reaps processes.
|
||||||
|
#
|
||||||
|
#init = false
|
||||||
|
|
||||||
|
# Container init binary, if init=true, this is the init binary to be used for containers.
|
||||||
|
#
|
||||||
|
init_path = "/usr/bin/catatonit"
|
||||||
|
|
||||||
|
# Default way to to create an IPC namespace (POSIX SysV IPC) for the container
|
||||||
|
# Options are:
|
||||||
|
# "host" Share host IPC Namespace with the container.
|
||||||
|
# "none" Create shareable IPC Namespace for the container without a private /dev/shm.
|
||||||
|
# "private" Create private IPC Namespace for the container, other containers are not allowed to share it.
|
||||||
|
# "shareable" Create shareable IPC Namespace for the container.
|
||||||
|
#
|
||||||
|
#ipcns = "shareable"
|
||||||
|
|
||||||
|
# keyring tells the container engine whether to create
|
||||||
|
# a kernel keyring for use within the container.
|
||||||
|
#
|
||||||
|
#keyring = true
|
||||||
|
|
||||||
|
# label tells the container engine whether to use container separation using
|
||||||
|
# MAC(SELinux) labeling or not.
|
||||||
|
# The label flag is ignored on label disabled systems.
|
||||||
|
#
|
||||||
|
#label = true
|
||||||
|
|
||||||
|
# Logging driver for the container. Available options: k8s-file and journald.
|
||||||
|
#
|
||||||
|
log_driver = "journald"
|
||||||
|
|
||||||
|
# Maximum size allowed for the container log file. Negative numbers indicate
|
||||||
|
# that no size limit is imposed. If positive, it must be >= 8192 to match or
|
||||||
|
# exceed conmon's read buffer. The file is truncated and re-opened so the
|
||||||
|
# limit is never exceeded.
|
||||||
|
#
|
||||||
|
#log_size_max = -1
|
||||||
|
|
||||||
|
# Specifies default format tag for container log messages.
|
||||||
|
# This is useful for creating a specific tag for container log messages.
|
||||||
|
# Containers logs default to truncated container ID as a tag.
|
||||||
|
#
|
||||||
|
#log_tag = ""
|
||||||
|
|
||||||
|
# Default way to to create a Network namespace for the container
|
||||||
|
# Options are:
|
||||||
|
# `private` Create private Network Namespace for the container.
|
||||||
|
# `host` Share host Network Namespace with the container.
|
||||||
|
# `none` Containers do not use the network
|
||||||
|
#
|
||||||
|
#netns = "private"
|
||||||
|
|
||||||
|
# Create /etc/hosts for the container. By default, container engine manage
|
||||||
|
# /etc/hosts, automatically adding the container's own IP address.
|
||||||
|
#
|
||||||
|
#no_hosts = false
|
||||||
|
|
||||||
|
# Default way to to create a PID namespace for the container
|
||||||
|
# Options are:
|
||||||
|
# `private` Create private PID Namespace for the container.
|
||||||
|
# `host` Share host PID Namespace with the container.
|
||||||
|
#
|
||||||
|
#pidns = "private"
|
||||||
|
|
||||||
|
# Maximum number of processes allowed in a container.
|
||||||
|
#
|
||||||
|
#pids_limit = 2048
|
||||||
|
|
||||||
|
# Copy the content from the underlying image into the newly created volume
|
||||||
|
# when the container is created instead of when it is started. If false,
|
||||||
|
# the container engine will not copy the content until the container is started.
|
||||||
|
# Setting it to true may have negative performance implications.
|
||||||
|
#
|
||||||
|
#prepare_volume_on_create = false
|
||||||
|
|
||||||
|
# Run all containers with root file system mounted read-only
|
||||||
|
#
|
||||||
|
# read_only = false
|
||||||
|
|
||||||
|
# Path to the seccomp.json profile which is used as the default seccomp profile
|
||||||
|
# for the runtime.
|
||||||
|
#
|
||||||
|
#seccomp_profile = "/usr/share/containers/seccomp.json"
|
||||||
|
|
||||||
|
# Size of /dev/shm. Specified as <number><unit>.
|
||||||
|
# Unit is optional, values:
|
||||||
|
# b (bytes), k (kilobytes), m (megabytes), or g (gigabytes).
|
||||||
|
# If the unit is omitted, the system uses bytes.
|
||||||
|
#
|
||||||
|
#shm_size = "65536k"
|
||||||
|
|
||||||
|
# Set timezone in container. Takes IANA timezones as well as "local",
|
||||||
|
# which sets the timezone in the container to match the host machine.
|
||||||
|
#
|
||||||
|
#tz = ""
|
||||||
|
|
||||||
|
# Set umask inside the container
|
||||||
|
#
|
||||||
|
#umask = "0022"
|
||||||
|
|
||||||
|
# Default way to to create a User namespace for the container
|
||||||
|
# Options are:
|
||||||
|
# `auto` Create unique User Namespace for the container.
|
||||||
|
# `host` Share host User Namespace with the container.
|
||||||
|
#
|
||||||
|
#userns = "host"
|
||||||
|
|
||||||
|
# Default way to to create a UTS namespace for the container
|
||||||
|
# Options are:
|
||||||
|
# `private` Create private UTS Namespace for the container.
|
||||||
|
# `host` Share host UTS Namespace with the container.
|
||||||
|
#
|
||||||
|
#utsns = "private"
|
||||||
|
|
||||||
|
# List of volumes. Specified as
|
||||||
|
# "<directory-on-host>:<directory-in-container>:<options>", for example:
|
||||||
|
# "/db:/var/lib/db:ro".
|
||||||
|
# If it is empty or commented out, no volumes will be added
|
||||||
|
#
|
||||||
|
#volumes = []
|
||||||
|
#
|
||||||
|
#[engine.platform_to_oci_runtime]
|
||||||
|
#"wasi/wasm" = ["crun-wasm"]
|
||||||
|
#"wasi/wasm32" = ["crun-wasm"]
|
||||||
|
#"wasi/wasm64" = ["crun-wasm"]
|
||||||
|
|
||||||
|
[secrets]
|
||||||
|
#driver = "file"
|
||||||
|
|
||||||
|
[secrets.opts]
|
||||||
|
#root = "/example/directory"
|
||||||
|
|
||||||
|
[network]
|
||||||
|
|
||||||
|
# Network backend determines what network driver will be used to set up and tear down container networks.
|
||||||
|
# Valid values are "cni" and "netavark".
|
||||||
|
# The default value is empty which means that it will automatically choose CNI or netavark. If there are
|
||||||
|
# already containers/images or CNI networks preset it will choose CNI.
|
||||||
|
#
|
||||||
|
# Before changing this value all containers must be stopped otherwise it is likely that
|
||||||
|
# iptables rules and network interfaces might leak on the host. A reboot will fix this.
|
||||||
|
#
|
||||||
|
#network_backend = ""
|
||||||
|
|
||||||
|
# Path to directory where CNI plugin binaries are located.
|
||||||
|
#
|
||||||
|
cni_plugin_dirs = ["@LIBEXECDIR@/cni"]
|
||||||
|
|
||||||
|
# The network name of the default network to attach pods to.
|
||||||
|
#
|
||||||
|
#default_network = "podman"
|
||||||
|
|
||||||
|
# The default subnet for the default network given in default_network.
|
||||||
|
# If a network with that name does not exist, a new network using that name and
|
||||||
|
# this subnet will be created.
|
||||||
|
# Must be a valid IPv4 CIDR prefix.
|
||||||
|
#
|
||||||
|
#default_subnet = "10.88.0.0/16"
|
||||||
|
|
||||||
|
# DefaultSubnetPools is a list of subnets and size which are used to
|
||||||
|
# allocate subnets automatically for podman network create.
|
||||||
|
# It will iterate through the list and will pick the first free subnet
|
||||||
|
# with the given size. This is only used for ipv4 subnets, ipv6 subnets
|
||||||
|
# are always assigned randomly.
|
||||||
|
#
|
||||||
|
#default_subnet_pools = [
|
||||||
|
# {"base" = "10.89.0.0/16", "size" = 24},
|
||||||
|
# {"base" = "10.90.0.0/15", "size" = 24},
|
||||||
|
# {"base" = "10.92.0.0/14", "size" = 24},
|
||||||
|
# {"base" = "10.96.0.0/11", "size" = 24},
|
||||||
|
# {"base" = "10.128.0.0/9", "size" = 24},
|
||||||
|
#]
|
||||||
|
|
||||||
|
# Path to the directory where network configuration files are located.
|
||||||
|
# For the CNI backend the default is "/etc/cni/net.d" as root
|
||||||
|
# and "$HOME/.config/cni/net.d" as rootless.
|
||||||
|
# For the netavark backend "/etc/containers/networks" is used as root
|
||||||
|
# and "$graphroot/networks" as rootless.
|
||||||
|
#
|
||||||
|
#network_config_dir = "/etc/cni/net.d/"
|
||||||
|
|
||||||
|
# Port to use for dns forwarding daemon with netavark in rootful bridge
|
||||||
|
# mode and dns enabled.
|
||||||
|
# Using an alternate port might be useful if other dns services should
|
||||||
|
# run on the machine.
|
||||||
|
#
|
||||||
|
#dns_bind_port = 53
|
||||||
|
|
||||||
|
[engine]
|
||||||
|
# Index to the active service
|
||||||
|
#
|
||||||
|
#active_service = production
|
||||||
|
|
||||||
|
# The compression format to use when pushing an image.
|
||||||
|
# Valid options are: `gzip`, `zstd` and `zstd:chunked`.
|
||||||
|
#
|
||||||
|
#compression_format = "gzip"
|
||||||
|
|
||||||
|
|
||||||
|
# Cgroup management implementation used for the runtime.
|
||||||
|
# Valid options "systemd" or "cgroupfs"
|
||||||
|
#
|
||||||
|
#cgroup_manager = "systemd"
|
||||||
|
|
||||||
|
# Environment variables to pass into conmon
|
||||||
|
#
|
||||||
|
#conmon_env_vars = [
|
||||||
|
# "PATH=/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin"
|
||||||
|
#]
|
||||||
|
|
||||||
|
# Paths to look for the conmon container manager binary
|
||||||
|
#
|
||||||
|
#conmon_path = [
|
||||||
|
# "/usr/libexec/podman/conmon",
|
||||||
|
# "/usr/local/libexec/podman/conmon",
|
||||||
|
# "/usr/local/lib/podman/conmon",
|
||||||
|
# "/usr/bin/conmon",
|
||||||
|
# "/usr/sbin/conmon",
|
||||||
|
# "/usr/local/bin/conmon",
|
||||||
|
# "/usr/local/sbin/conmon"
|
||||||
|
#]
|
||||||
|
|
||||||
|
# Enforces using docker.io for completing short names in Podman's compatibility
|
||||||
|
# REST API. Note that this will ignore unqualified-search-registries and
|
||||||
|
# short-name aliases defined in containers-registries.conf(5).
|
||||||
|
#compat_api_enforce_docker_hub = true
|
||||||
|
|
||||||
|
# Specify the keys sequence used to detach a container.
|
||||||
|
# Format is a single character [a-Z] or a comma separated sequence of
|
||||||
|
# `ctrl-<value>`, where `<value>` is one of:
|
||||||
|
# `a-z`, `@`, `^`, `[`, `\`, `]`, `^` or `_`
|
||||||
|
#
|
||||||
|
#detach_keys = "ctrl-p,ctrl-q"
|
||||||
|
|
||||||
|
# Determines whether engine will reserve ports on the host when they are
|
||||||
|
# forwarded to containers. When enabled, when ports are forwarded to containers,
|
||||||
|
# ports are held open by as long as the container is running, ensuring that
|
||||||
|
# they cannot be reused by other programs on the host. However, this can cause
|
||||||
|
# significant memory usage if a container has many ports forwarded to it.
|
||||||
|
# Disabling this can save memory.
|
||||||
|
#
|
||||||
|
#enable_port_reservation = true
|
||||||
|
|
||||||
|
# Environment variables to be used when running the container engine (e.g., Podman, Buildah).
|
||||||
|
# For example "http_proxy=internal.proxy.company.com".
|
||||||
|
# Note these environment variables will not be used within the container.
|
||||||
|
# Set the env section under [containers] table, if you want to set environment variables for the container.
|
||||||
|
#
|
||||||
|
#env = []
|
||||||
|
|
||||||
|
# Define where event logs will be stored, when events_logger is "file".
|
||||||
|
#events_logfile_path=""
|
||||||
|
|
||||||
|
# Sets the maximum size for events_logfile_path.
|
||||||
|
# The size can be b (bytes), k (kilobytes), m (megabytes), or g (gigabytes).
|
||||||
|
# The format for the size is `<number><unit>`, e.g., `1b` or `3g`.
|
||||||
|
# If no unit is included then the size will be read in bytes.
|
||||||
|
# When the limit is exceeded, the logfile will be rotated and the old one will be deleted.
|
||||||
|
# If the maximum size is set to 0, then no limit will be applied,
|
||||||
|
# and the logfile will not be rotated.
|
||||||
|
#events_logfile_max_size = "1m"
|
||||||
|
|
||||||
|
# Selects which logging mechanism to use for container engine events.
|
||||||
|
# Valid values are `journald`, `file` and `none`.
|
||||||
|
#
|
||||||
|
#events_logger = "journald"
|
||||||
|
|
||||||
|
# Creates a more verbose container-create event which includes a JSON payload
|
||||||
|
# with detailed information about the container.
|
||||||
|
#events_container_create_inspect_data = false
|
||||||
|
|
||||||
|
# A is a list of directories which are used to search for helper binaries.
|
||||||
|
#
|
||||||
|
#helper_binaries_dir = [
|
||||||
|
# "/usr/local/libexec/podman",
|
||||||
|
# "/usr/local/lib/podman",
|
||||||
|
# "/usr/libexec/podman",
|
||||||
|
# "/usr/lib/podman",
|
||||||
|
#]
|
||||||
|
|
||||||
|
# Path to OCI hooks directories for automatically executed hooks.
|
||||||
|
#
|
||||||
|
#hooks_dir = [
|
||||||
|
# "/usr/share/containers/oci/hooks.d",
|
||||||
|
#]
|
||||||
|
|
||||||
|
# Manifest Type (oci, v2s2, or v2s1) to use when pulling, pushing, building
|
||||||
|
# container images. By default image pulled and pushed match the format of the
|
||||||
|
# source image. Building/committing defaults to OCI.
|
||||||
|
#
|
||||||
|
#image_default_format = ""
|
||||||
|
|
||||||
|
# Default transport method for pulling and pushing for images
|
||||||
|
#
|
||||||
|
#image_default_transport = "docker://"
|
||||||
|
|
||||||
|
# Maximum number of image layers to be copied (pulled/pushed) simultaneously.
|
||||||
|
# Not setting this field, or setting it to zero, will fall back to containers/image defaults.
|
||||||
|
#
|
||||||
|
#image_parallel_copies = 0
|
||||||
|
|
||||||
|
# Tells container engines how to handle the builtin image volumes.
|
||||||
|
# * bind: An anonymous named volume will be created and mounted
|
||||||
|
# into the container.
|
||||||
|
# * tmpfs: The volume is mounted onto the container as a tmpfs,
|
||||||
|
# which allows users to create content that disappears when
|
||||||
|
# the container is stopped.
|
||||||
|
# * ignore: All volumes are just ignored and no action is taken.
|
||||||
|
#
|
||||||
|
#image_volume_mode = ""
|
||||||
|
|
||||||
|
# Default command to run the infra container
|
||||||
|
#
|
||||||
|
#infra_command = "/pause"
|
||||||
|
|
||||||
|
# Infra (pause) container image name for pod infra containers. When running a
|
||||||
|
# pod, we start a `pause` process in a container to hold open the namespaces
|
||||||
|
# associated with the pod. This container does nothing other then sleep,
|
||||||
|
# reserving the pods resources for the lifetime of the pod. By default container
|
||||||
|
# engines run a builtin container using the pause executable. If you want override
|
||||||
|
# specify an image to pull.
|
||||||
|
#
|
||||||
|
#infra_image = ""
|
||||||
|
|
||||||
|
# Specify the locking mechanism to use; valid values are "shm" and "file".
|
||||||
|
# Change the default only if you are sure of what you are doing, in general
|
||||||
|
# "file" is useful only on platforms where cgo is not available for using the
|
||||||
|
# faster "shm" lock type. You may need to run "podman system renumber" after
|
||||||
|
# you change the lock type.
|
||||||
|
#
|
||||||
|
#lock_type** = "shm"
|
||||||
|
|
||||||
|
# MultiImageArchive - if true, the container engine allows for storing archives
|
||||||
|
# (e.g., of the docker-archive transport) with multiple images. By default,
|
||||||
|
# Podman creates single-image archives.
|
||||||
|
#
|
||||||
|
#multi_image_archive = "false"
|
||||||
|
|
||||||
|
# Default engine namespace
|
||||||
|
# If engine is joined to a namespace, it will see only containers and pods
|
||||||
|
# that were created in the same namespace, and will create new containers and
|
||||||
|
# pods in that namespace.
|
||||||
|
# The default namespace is "", which corresponds to no namespace. When no
|
||||||
|
# namespace is set, all containers and pods are visible.
|
||||||
|
#
|
||||||
|
#namespace = ""
|
||||||
|
|
||||||
|
# Path to the slirp4netns binary
|
||||||
|
#
|
||||||
|
#network_cmd_path = ""
|
||||||
|
|
||||||
|
# Default options to pass to the slirp4netns binary.
|
||||||
|
# Valid options values are:
|
||||||
|
#
|
||||||
|
# - allow_host_loopback=true|false: Allow the slirp4netns to reach the host loopback IP (`10.0.2.2`).
|
||||||
|
# Default is false.
|
||||||
|
# - mtu=MTU: Specify the MTU to use for this network. (Default is `65520`).
|
||||||
|
# - cidr=CIDR: Specify ip range to use for this network. (Default is `10.0.2.0/24`).
|
||||||
|
# - enable_ipv6=true|false: Enable IPv6. Default is true. (Required for `outbound_addr6`).
|
||||||
|
# - outbound_addr=INTERFACE: Specify the outbound interface slirp should bind to (ipv4 traffic only).
|
||||||
|
# - outbound_addr=IPv4: Specify the outbound ipv4 address slirp should bind to.
|
||||||
|
# - outbound_addr6=INTERFACE: Specify the outbound interface slirp should bind to (ipv6 traffic only).
|
||||||
|
# - outbound_addr6=IPv6: Specify the outbound ipv6 address slirp should bind to.
|
||||||
|
# - port_handler=rootlesskit: Use rootlesskit for port forwarding. Default.
|
||||||
|
# Note: Rootlesskit changes the source IP address of incoming packets to a IP address in the container
|
||||||
|
# network namespace, usually `10.0.2.100`. If your application requires the real source IP address,
|
||||||
|
# e.g. web server logs, use the slirp4netns port handler. The rootlesskit port handler is also used for
|
||||||
|
# rootless containers when connected to user-defined networks.
|
||||||
|
# - port_handler=slirp4netns: Use the slirp4netns port forwarding, it is slower than rootlesskit but
|
||||||
|
# preserves the correct source IP address. This port handler cannot be used for user-defined networks.
|
||||||
|
#
|
||||||
|
#network_cmd_options = []
|
||||||
|
|
||||||
|
# Whether to use chroot instead of pivot_root in the runtime
|
||||||
|
#
|
||||||
|
#no_pivot_root = false
|
||||||
|
|
||||||
|
# Number of locks available for containers and pods.
|
||||||
|
# If this is changed, a lock renumber must be performed (e.g. with the
|
||||||
|
# 'podman system renumber' command).
|
||||||
|
#
|
||||||
|
#num_locks = 2048
|
||||||
|
|
||||||
|
# Set the exit policy of the pod when the last container exits.
|
||||||
|
#pod_exit_policy = "continue"
|
||||||
|
|
||||||
|
# Whether to pull new image before running a container
|
||||||
|
#
|
||||||
|
#pull_policy = "missing"
|
||||||
|
|
||||||
|
# Indicates whether the application should be running in remote mode. This flag modifies the
|
||||||
|
# --remote option on container engines. Setting the flag to true will default
|
||||||
|
# `podman --remote=true` for access to the remote Podman service.
|
||||||
|
#
|
||||||
|
#remote = false
|
||||||
|
|
||||||
|
# Default OCI runtime
|
||||||
|
#
|
||||||
|
#runtime = "crun"
|
||||||
|
|
||||||
|
# List of the OCI runtimes that support --format=json. When json is supported
|
||||||
|
# engine will use it for reporting nicer errors.
|
||||||
|
#
|
||||||
|
#runtime_supports_json = ["crun", "runc", "kata", "runsc", "youki", "krun"]
|
||||||
|
|
||||||
|
# List of the OCI runtimes that supports running containers with KVM Separation.
|
||||||
|
#
|
||||||
|
#runtime_supports_kvm = ["kata", "krun"]
|
||||||
|
|
||||||
|
# List of the OCI runtimes that supports running containers without cgroups.
|
||||||
|
#
|
||||||
|
#runtime_supports_nocgroups = ["crun", "krun"]
|
||||||
|
|
||||||
|
# Default location for storing temporary container image content. Can be overridden with the TMPDIR environment
|
||||||
|
# variable. If you specify "storage", then the location of the
|
||||||
|
# container/storage tmp directory will be used.
|
||||||
|
# image_copy_tmp_dir="/var/tmp"
|
||||||
|
|
||||||
|
# Number of seconds to wait without a connection
|
||||||
|
# before the `podman system service` times out and exits
|
||||||
|
#
|
||||||
|
#service_timeout = 5
|
||||||
|
|
||||||
|
# Directory for persistent engine files (database, etc)
|
||||||
|
# By default, this will be configured relative to where the containers/storage
|
||||||
|
# stores containers
|
||||||
|
# Uncomment to change location from this default
|
||||||
|
#
|
||||||
|
#static_dir = "/var/lib/containers/storage/libpod"
|
||||||
|
|
||||||
|
# Number of seconds to wait for container to exit before sending kill signal.
|
||||||
|
#
|
||||||
|
#stop_timeout = 10
|
||||||
|
|
||||||
|
# Number of seconds to wait before exit command in API process is given to.
|
||||||
|
# This mimics Docker's exec cleanup behaviour, where the default is 5 minutes (value is in seconds).
|
||||||
|
#
|
||||||
|
#exit_command_delay = 300
|
||||||
|
|
||||||
|
# map of service destinations
|
||||||
|
#
|
||||||
|
#[service_destinations]
|
||||||
|
# [service_destinations.production]
|
||||||
|
# URI to access the Podman service
|
||||||
|
# Examples:
|
||||||
|
# rootless "unix://run/user/$UID/podman/podman.sock" (Default)
|
||||||
|
# rootful "unix://run/podman/podman.sock (Default)
|
||||||
|
# remote rootless ssh://engineering.lab.company.com/run/user/1000/podman/podman.sock
|
||||||
|
# remote rootful ssh://root@10.10.1.136:22/run/podman/podman.sock
|
||||||
|
#
|
||||||
|
# uri = "ssh://user@production.example.com/run/user/1001/podman/podman.sock"
|
||||||
|
# Path to file containing ssh identity key
|
||||||
|
# identity = "~/.ssh/id_rsa"
|
||||||
|
|
||||||
|
# Directory for temporary files. Must be tmpfs (wiped after reboot)
|
||||||
|
#
|
||||||
|
#tmp_dir = "/run/libpod"
|
||||||
|
|
||||||
|
# Directory for libpod named volumes.
|
||||||
|
# By default, this will be configured relative to where containers/storage
|
||||||
|
# stores containers.
|
||||||
|
# Uncomment to change location from this default.
|
||||||
|
#
|
||||||
|
#volume_path = "/var/lib/containers/storage/volumes"
|
||||||
|
|
||||||
|
# Default timeout (in seconds) for volume plugin operations.
|
||||||
|
# Plugins are external programs accessed via a REST API; this sets a timeout
|
||||||
|
# for requests to that API.
|
||||||
|
# A value of 0 is treated as no timeout.
|
||||||
|
#volume_plugin_timeout = 5
|
||||||
|
|
||||||
|
# Paths to look for a valid OCI runtime (crun, runc, kata, runsc, krun, etc)
|
||||||
|
[engine.runtimes]
|
||||||
|
#crun = [
|
||||||
|
# "/usr/bin/crun",
|
||||||
|
# "/usr/sbin/crun",
|
||||||
|
# "/usr/local/bin/crun",
|
||||||
|
# "/usr/local/sbin/crun",
|
||||||
|
# "/sbin/crun",
|
||||||
|
# "/bin/crun",
|
||||||
|
# "/run/current-system/sw/bin/crun",
|
||||||
|
#]
|
||||||
|
|
||||||
|
#kata = [
|
||||||
|
# "/usr/bin/kata-runtime",
|
||||||
|
# "/usr/sbin/kata-runtime",
|
||||||
|
# "/usr/local/bin/kata-runtime",
|
||||||
|
# "/usr/local/sbin/kata-runtime",
|
||||||
|
# "/sbin/kata-runtime",
|
||||||
|
# "/bin/kata-runtime",
|
||||||
|
# "/usr/bin/kata-qemu",
|
||||||
|
# "/usr/bin/kata-fc",
|
||||||
|
#]
|
||||||
|
|
||||||
|
#runc = [
|
||||||
|
# "/usr/bin/runc",
|
||||||
|
# "/usr/sbin/runc",
|
||||||
|
# "/usr/local/bin/runc",
|
||||||
|
# "/usr/local/sbin/runc",
|
||||||
|
# "/sbin/runc",
|
||||||
|
# "/bin/runc",
|
||||||
|
# "/usr/lib/cri-o-runc/sbin/runc",
|
||||||
|
#]
|
||||||
|
|
||||||
|
#runsc = [
|
||||||
|
# "/usr/bin/runsc",
|
||||||
|
# "/usr/sbin/runsc",
|
||||||
|
# "/usr/local/bin/runsc",
|
||||||
|
# "/usr/local/sbin/runsc",
|
||||||
|
# "/bin/runsc",
|
||||||
|
# "/sbin/runsc",
|
||||||
|
# "/run/current-system/sw/bin/runsc",
|
||||||
|
#]
|
||||||
|
|
||||||
|
#youki = [
|
||||||
|
# "/usr/local/bin/youki",
|
||||||
|
# "/usr/bin/youki",
|
||||||
|
# "/bin/youki",
|
||||||
|
# "/run/current-system/sw/bin/youki",
|
||||||
|
#]
|
||||||
|
|
||||||
|
#krun = [
|
||||||
|
# "/usr/bin/krun",
|
||||||
|
# "/usr/local/bin/krun",
|
||||||
|
#]
|
||||||
|
|
||||||
|
[engine.volume_plugins]
|
||||||
|
#testplugin = "/run/podman/plugins/test.sock"
|
||||||
|
|
||||||
|
[machine]
|
||||||
|
# Number of CPU's a machine is created with.
|
||||||
|
#
|
||||||
|
#cpus=1
|
||||||
|
|
||||||
|
# The size of the disk in GB created when init-ing a podman-machine VM.
|
||||||
|
#
|
||||||
|
#disk_size=10
|
||||||
|
|
||||||
|
# Default image URI when creating a new VM using `podman machine init`.
|
||||||
|
# Options: On Linux/Mac, `testing`, `stable`, `next`. On Windows, the major
|
||||||
|
# version of the OS (e.g `36`) for Fedora 36. For all platforms you can
|
||||||
|
# alternatively specify a custom download URL to an image. Container engines
|
||||||
|
# translate URIs $OS and $ARCH to the native OS and ARCH. URI
|
||||||
|
# "https://example.com/$OS/$ARCH/foobar.ami" becomes
|
||||||
|
# "https://example.com/linux/amd64/foobar.ami" on a Linux AMD machine.
|
||||||
|
# The default value is `testing`.
|
||||||
|
#
|
||||||
|
#image = "testing"
|
||||||
|
|
||||||
|
# Memory in MB a machine is created with.
|
||||||
|
#
|
||||||
|
#memory=2048
|
||||||
|
|
||||||
|
# The username to use and create on the podman machine OS for rootless
|
||||||
|
# container access.
|
||||||
|
#
|
||||||
|
#user = "core"
|
||||||
|
|
||||||
|
# Host directories to be mounted as volumes into the VM by default.
|
||||||
|
# Environment variables like $HOME as well as complete paths are supported for
|
||||||
|
# the source and destination. An optional third field `:ro` can be used to
|
||||||
|
# tell the container engines to mount the volume readonly.
|
||||||
|
#
|
||||||
|
# volumes = [
|
||||||
|
# "$HOME:$HOME",
|
||||||
|
#]
|
||||||
|
|
||||||
|
# Virtualization provider used to run Podman machine.
|
||||||
|
# If it is empty or commented out, the default provider will be used.
|
||||||
|
#
|
||||||
|
#provider = ""
|
||||||
|
|
||||||
|
# The [machine] table MUST be the last entry in this file.
|
||||||
|
# (Unless another table is added)
|
||||||
|
# TOML does not provide a way to end a table other than a further table being
|
||||||
|
# defined, so every key hereafter will be part of [machine] and not the
|
||||||
|
# main config.
|
31
default.yaml
Normal file
31
default.yaml
Normal file
@ -0,0 +1,31 @@
|
|||||||
|
# This is a default registries.d configuration file. You may
|
||||||
|
# add to this file or create additional files in registries.d/.
|
||||||
|
#
|
||||||
|
# sigstore: indicates a location that is read and write
|
||||||
|
# sigstore-staging: indicates a location that is only for write
|
||||||
|
#
|
||||||
|
# sigstore and sigstore-staging take a value of the following:
|
||||||
|
# sigstore: {schema}://location
|
||||||
|
#
|
||||||
|
# For reading signatures, schema may be http, https, or file.
|
||||||
|
# For writing signatures, schema may only be file.
|
||||||
|
|
||||||
|
# This is the default signature write location for docker registries.
|
||||||
|
default-docker:
|
||||||
|
# sigstore: file:///var/lib/containers/sigstore
|
||||||
|
sigstore-staging: file:///var/lib/containers/sigstore
|
||||||
|
|
||||||
|
# The 'docker' indicator here is the start of the configuration
|
||||||
|
# for docker registries.
|
||||||
|
#
|
||||||
|
# docker:
|
||||||
|
#
|
||||||
|
# privateregistry.com:
|
||||||
|
# sigstore: http://privateregistry.com/sigstore/
|
||||||
|
# sigstore-staging: /mnt/nfs/privateregistry/sigstore
|
||||||
|
|
||||||
|
docker:
|
||||||
|
registry.suse.com:
|
||||||
|
use-sigstore-attachments: true
|
||||||
|
registry.suse.de:
|
||||||
|
use-sigstore-attachments: true
|
BIN
image-5.29.2.tar.xz
(Stored with Git LFS)
Normal file
BIN
image-5.29.2.tar.xz
(Stored with Git LFS)
Normal file
Binary file not shown.
4649
libcontainers-common.changes
Normal file
4649
libcontainers-common.changes
Normal file
File diff suppressed because it is too large
Load Diff
0
libcontainers-common.rpmlintrc
Normal file
0
libcontainers-common.rpmlintrc
Normal file
219
libcontainers-common.spec
Normal file
219
libcontainers-common.spec
Normal file
@ -0,0 +1,219 @@
|
|||||||
|
#
|
||||||
|
# spec file for package libcontainers-common
|
||||||
|
#
|
||||||
|
# Copyright (c) 2023 SUSE LLC
|
||||||
|
#
|
||||||
|
# All modifications and additions to the file contributed by third parties
|
||||||
|
# remain the property of their copyright owners, unless otherwise agreed
|
||||||
|
# upon. The license for this file, and modifications and additions to the
|
||||||
|
# file, is the same license as for the pristine package itself (unless the
|
||||||
|
# license for the pristine package is not an Open Source License, in which
|
||||||
|
# case the license is the MIT License). An "Open Source License" is a
|
||||||
|
# license that conforms to the Open Source Definition (Version 1.9)
|
||||||
|
# published by the Open Source Initiative.
|
||||||
|
|
||||||
|
# Please submit bugfixes or comments via https://bugs.opensuse.org/
|
||||||
|
#
|
||||||
|
|
||||||
|
|
||||||
|
# commonver - version from containers/common
|
||||||
|
%define commonver 0.57.4
|
||||||
|
# storagever - version from containers/storage
|
||||||
|
%define storagever 1.51.0
|
||||||
|
# imagever - version from containers/image
|
||||||
|
%define imagever 5.29.2
|
||||||
|
# skopeover - version from containers/skopeo
|
||||||
|
%define skopeover 1.14.2
|
||||||
|
# https://github.com/containers/shortnames
|
||||||
|
%define shortnamesver 2023.02.20
|
||||||
|
Name: libcontainers-common
|
||||||
|
Version: 20240206
|
||||||
|
Release: 0
|
||||||
|
Summary: Configuration files common to github.com/containers
|
||||||
|
License: Apache-2.0
|
||||||
|
Group: System/Management
|
||||||
|
URL: https://github.com/containers
|
||||||
|
Source0: image-%{imagever}.tar.xz
|
||||||
|
Source1: storage-%{storagever}.tar.xz
|
||||||
|
Source2: LICENSE
|
||||||
|
# https://raw.githubusercontent.com/containers/skopeo/main/default-policy.json
|
||||||
|
Source3: https://raw.githubusercontent.com/containers/skopeo/v%{skopeover}/default-policy.json#./policy.json
|
||||||
|
# https://github.com/containers/storage/blob/main/storage.conf + custom changes
|
||||||
|
Source4: storage.conf
|
||||||
|
# heavily modified version of https://github.com/containers/common/blob/main/pkg/subscriptions/mounts.conf
|
||||||
|
Source5: mounts.conf
|
||||||
|
# https://raw.githubusercontent.com/containers/image/main/registries.conf with our own registries inserted
|
||||||
|
Source6: registries.conf
|
||||||
|
# https://github.com/containers/skopeo/blob/main/default.yaml but heavily modified
|
||||||
|
Source7: default.yaml
|
||||||
|
Source8: common-%{commonver}.tar.xz
|
||||||
|
# https://github.com/containers/common/blob/main/pkg/config/containers.conf with custom settings
|
||||||
|
Source9: containers.conf
|
||||||
|
Source10: %{name}.rpmlintrc
|
||||||
|
Source11: https://raw.githubusercontent.com/containers/shortnames/v%{shortnamesver}/shortnames.conf
|
||||||
|
Source12: openSUSE-policy.json
|
||||||
|
BuildRequires: go-go-md2man
|
||||||
|
Requires(post): %{_bindir}/sed
|
||||||
|
# add SLE-specific mounts for only SLES systems
|
||||||
|
Requires: (libcontainers-sles-mounts if (product(SUSE_SLE) or product(SLE-Micro)))
|
||||||
|
Requires: libcontainers-policy >= %{version}
|
||||||
|
Suggests: (libcontainers-policy-openSUSE if openSUSE-release)
|
||||||
|
Provides: libcontainers-image = %{version}
|
||||||
|
Provides: libcontainers-storage = %{version}
|
||||||
|
Obsoletes: libcontainers-image < %{version}
|
||||||
|
Obsoletes: libcontainers-storage < %{version}
|
||||||
|
BuildArch: noarch
|
||||||
|
|
||||||
|
%description
|
||||||
|
Configuration files and manpages shared by tools that are based on the
|
||||||
|
github.com/containers libraries, such as Buildah, CRI-O, Podman and Skopeo.
|
||||||
|
|
||||||
|
%package -n libcontainers-sles-mounts
|
||||||
|
Summary: Default mounts for SLE distributions
|
||||||
|
|
||||||
|
%description -n libcontainers-sles-mounts
|
||||||
|
Updates /etc/containers/mounts.conf with default mounts for SLE distributions
|
||||||
|
|
||||||
|
%package -n libcontainers-openSUSE-policy
|
||||||
|
Summary: Policy to enforce image verification for SLE BCI
|
||||||
|
Provides: libcontainers-policy = %{version}-%{release}
|
||||||
|
|
||||||
|
RemovePathPostfixes: .openSUSE
|
||||||
|
Conflicts: libcontainers-default-policy
|
||||||
|
|
||||||
|
%description -n libcontainers-openSUSE-policy
|
||||||
|
This package ships a /etc/containers/policy.json which enforces image verification for SLE BCI.
|
||||||
|
|
||||||
|
%package -n libcontainers-default-policy
|
||||||
|
Summary: Default containers policy.json
|
||||||
|
Provides: libcontainers-policy = %{version}-%{release}
|
||||||
|
|
||||||
|
RemovePathPostfixes: .default
|
||||||
|
Conflicts: libcontainers-openSUSE-policy
|
||||||
|
|
||||||
|
%description -n libcontainers-default-policy
|
||||||
|
This package ships the default /etc/containers/policy.json
|
||||||
|
|
||||||
|
%prep
|
||||||
|
%setup -q -Tcq -b0 -b1 -b8
|
||||||
|
# copy the LICENSE file in the build root
|
||||||
|
cp %{SOURCE2} .
|
||||||
|
|
||||||
|
%build
|
||||||
|
cd ..
|
||||||
|
pwd
|
||||||
|
# compile containers/image manpages
|
||||||
|
cd image-%{imagever}
|
||||||
|
for md in docs/*.md
|
||||||
|
do
|
||||||
|
go-md2man -in $md -out $md
|
||||||
|
done
|
||||||
|
rename '.5.md' '.5' docs/*
|
||||||
|
rename '.md' '.1' docs/*
|
||||||
|
cd ..
|
||||||
|
# compile containers/storage manpages
|
||||||
|
cd storage-%{storagever}
|
||||||
|
for md in docs/*.md
|
||||||
|
do
|
||||||
|
go-md2man -in $md -out $md
|
||||||
|
done
|
||||||
|
rename '.5.md' '.5' docs/*
|
||||||
|
rename '.md' '.1' docs/*
|
||||||
|
cd ..
|
||||||
|
# compile subset of containers/common manpages
|
||||||
|
cd common-%{commonver}
|
||||||
|
go-md2man -in pkg/hooks/docs/oci-hooks.5.md -out pkg/hooks/docs/oci-hooks.5
|
||||||
|
cd ..
|
||||||
|
|
||||||
|
# These would only be used on SLE-systems
|
||||||
|
# via libcontainers-sles-mounts subpackage
|
||||||
|
cat >>%{SOURCE5} <<EOL
|
||||||
|
%{_sysconfdir}/SUSEConnect:%{_sysconfdir}/SUSEConnect
|
||||||
|
%{_sysconfdir}/zypp/credentials.d/SCCcredentials:%{_sysconfdir}/zypp/credentials.d/SCCcredentials
|
||||||
|
EOL
|
||||||
|
|
||||||
|
# Disable CNI related configs on ALP (bsc#1213556)
|
||||||
|
# https://github.com/containers/podman/issues/19327
|
||||||
|
%if 0%{?suse_version} >= 1600 && !0%{?is_opensuse}
|
||||||
|
sed -i 's/cni_plugin_dirs = .*/\# cni_plugin_dirs = []/g' %{SOURCE9}
|
||||||
|
%endif
|
||||||
|
|
||||||
|
cd common-%{commonver}
|
||||||
|
%make_build docs
|
||||||
|
cd ..
|
||||||
|
|
||||||
|
%install
|
||||||
|
cd ..
|
||||||
|
install -d -m 0755 %{buildroot}/%{_sysconfdir}/containers
|
||||||
|
install -d -m 0755 %{buildroot}/%{_sysconfdir}/containers/oci/hooks.d
|
||||||
|
install -d -m 0755 %{buildroot}/%{_datadir}/containers/oci/hooks.d
|
||||||
|
install -d -m 0755 %{buildroot}/%{_sysconfdir}/containers/registries.d
|
||||||
|
install -d -m 0755 %{buildroot}/%{_sysconfdir}/containers/registries.conf.d
|
||||||
|
install -d -m 0755 %{buildroot}/%{_sysconfdir}/containers/systemd
|
||||||
|
install -d -m 0755 %{buildroot}/%{_datadir}/containers/systemd
|
||||||
|
|
||||||
|
install -D -m 0644 %{SOURCE3} %{buildroot}/%{_sysconfdir}/containers/policy.json.default
|
||||||
|
install -D -m 0644 %{SOURCE3} %{buildroot}/%{_sysconfdir}/containers/policy.json.openSUSE
|
||||||
|
install -D -m 0644 %{SOURCE4} %{buildroot}/%{_sysconfdir}/containers/storage.conf
|
||||||
|
install -D -m 0644 %{SOURCE5} %{buildroot}/%{_datadir}/containers/mounts.conf
|
||||||
|
install -D -m 0644 %{SOURCE5} %{buildroot}/%{_sysconfdir}/containers/mounts.conf
|
||||||
|
install -D -m 0644 %{SOURCE6} %{buildroot}/%{_sysconfdir}/containers/registries.conf
|
||||||
|
install -D -m 0644 %{SOURCE11} %{buildroot}/%{_sysconfdir}/containers/registries.conf.d/000-shortnames.conf
|
||||||
|
install -D -m 0644 %{SOURCE7} %{buildroot}/%{_sysconfdir}/containers/registries.d/default.yaml
|
||||||
|
sed -e 's-@LIBEXECDIR@-%{_libexecdir}-g' -i %{SOURCE9}
|
||||||
|
install -D -m 0644 %{SOURCE9} %{buildroot}/%{_datadir}/containers/containers.conf
|
||||||
|
install -D -m 0644 common-%{commonver}/pkg/seccomp/seccomp.json %{buildroot}/%{_datadir}/containers/seccomp.json
|
||||||
|
install -D -m 0644 common-%{commonver}/pkg/seccomp/seccomp.json %{buildroot}/%{_sysconfdir}/containers/seccomp.json
|
||||||
|
|
||||||
|
install -d %{buildroot}/%{_mandir}/man1
|
||||||
|
install -d %{buildroot}/%{_mandir}/man5
|
||||||
|
install -D -m 0644 image-%{imagever}/docs/*.1 %{buildroot}/%{_mandir}/man1/
|
||||||
|
install -D -m 0644 image-%{imagever}/docs/*.5 %{buildroot}/%{_mandir}/man5/
|
||||||
|
install -D -m 0644 storage-%{storagever}/docs/*.1 %{buildroot}/%{_mandir}/man1/
|
||||||
|
install -D -m 0644 storage-%{storagever}/docs/*.5 %{buildroot}/%{_mandir}/man5/
|
||||||
|
install -D -m 0644 common-%{commonver}/pkg/hooks/docs/oci-hooks.5 %{buildroot}/%{_mandir}/man5/
|
||||||
|
install -D -m 0644 common-%{commonver}/docs/containers-mounts.conf.5 %{buildroot}/%{_mandir}/man5/
|
||||||
|
install -D -m 0644 common-%{commonver}/docs/containers.conf.5 %{buildroot}/%{_mandir}/man5/
|
||||||
|
|
||||||
|
install -D -m 0644 %{SOURCE12} %{buildroot}/%{_sysconfdir}/containers/policy.json.openSUSE
|
||||||
|
install -D -m 0644 %{SOURCE3} %{buildroot}/%{_sysconfdir}/containers/policy.json.default
|
||||||
|
|
||||||
|
%post
|
||||||
|
# Comment out ostree_repo if it's blank [boo#1189893]
|
||||||
|
sed -i 's/ostree_repo = ""/\#ostree_repo = ""/g' %{_sysconfdir}/containers/storage.conf
|
||||||
|
|
||||||
|
%files
|
||||||
|
%dir %{_sysconfdir}/containers
|
||||||
|
%dir %{_sysconfdir}/containers/oci
|
||||||
|
%dir %{_sysconfdir}/containers/oci/hooks.d
|
||||||
|
%dir %{_sysconfdir}/containers/registries.d
|
||||||
|
%dir %{_sysconfdir}/containers/registries.conf.d
|
||||||
|
%dir %{_sysconfdir}/containers/systemd
|
||||||
|
%dir %{_datadir}/containers
|
||||||
|
%dir %{_datadir}/containers/oci
|
||||||
|
%dir %{_datadir}/containers/oci/hooks.d
|
||||||
|
%dir %{_datadir}/containers/systemd
|
||||||
|
|
||||||
|
%config(noreplace) %{_sysconfdir}/containers/storage.conf
|
||||||
|
%config(noreplace) %{_sysconfdir}/containers/registries.conf
|
||||||
|
%config(noreplace) %{_sysconfdir}/containers/seccomp.json
|
||||||
|
%config(noreplace) %{_sysconfdir}/containers/registries.d/default.yaml
|
||||||
|
%config(noreplace) %{_sysconfdir}/containers/registries.conf.d/000-shortnames.conf
|
||||||
|
%{_datadir}/containers/seccomp.json
|
||||||
|
%{_datadir}/containers/containers.conf
|
||||||
|
|
||||||
|
%{_mandir}/man1/*.1%{?ext_man}
|
||||||
|
%{_mandir}/man5/*.5%{?ext_man}
|
||||||
|
%license LICENSE
|
||||||
|
|
||||||
|
%files -n libcontainers-sles-mounts
|
||||||
|
%config(noreplace) %{_sysconfdir}/containers/mounts.conf
|
||||||
|
%{_datadir}/containers/mounts.conf
|
||||||
|
|
||||||
|
%files -n libcontainers-openSUSE-policy
|
||||||
|
%config(noreplace) %{_sysconfdir}/containers/policy.json.openSUSE
|
||||||
|
|
||||||
|
%files -n libcontainers-default-policy
|
||||||
|
%config(noreplace) %{_sysconfdir}/containers/policy.json.default
|
||||||
|
|
||||||
|
%changelog
|
3
mounts.conf
Normal file
3
mounts.conf
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
# This configuration file specifies the default mounts for each container of the
|
||||||
|
# tools adhering to this file (e.g., CRI-O, Podman, Buildah). The format of the
|
||||||
|
# config is /SRC:/DST, one mount per line.
|
21
openSUSE-policy.json
Normal file
21
openSUSE-policy.json
Normal file
@ -0,0 +1,21 @@
|
|||||||
|
{
|
||||||
|
"default": [
|
||||||
|
{
|
||||||
|
"type": "insecureAcceptAnything"
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"transports": {
|
||||||
|
"docker-daemon": {
|
||||||
|
"": [{"type":"insecureAcceptAnything"}]
|
||||||
|
},
|
||||||
|
"docker": {
|
||||||
|
"registry.suse.com/bci": [{
|
||||||
|
"type": "sigstoreSigned",
|
||||||
|
"keyPath": "/usr/share/pki/containers/suse-container-key.pem",
|
||||||
|
"signedIdentity": {
|
||||||
|
"type": "matchRepository"
|
||||||
|
}
|
||||||
|
}]
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
14
policy.json
Normal file
14
policy.json
Normal file
@ -0,0 +1,14 @@
|
|||||||
|
{
|
||||||
|
"default": [
|
||||||
|
{
|
||||||
|
"type": "insecureAcceptAnything"
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"transports":
|
||||||
|
{
|
||||||
|
"docker-daemon":
|
||||||
|
{
|
||||||
|
"": [{"type":"insecureAcceptAnything"}]
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
77
registries.conf
Normal file
77
registries.conf
Normal file
@ -0,0 +1,77 @@
|
|||||||
|
# For more information on this configuration file, see containers-registries.conf(5).
|
||||||
|
#
|
||||||
|
# NOTE: RISK OF USING UNQUALIFIED IMAGE NAMES
|
||||||
|
# We recommend always using fully qualified image names including the registry
|
||||||
|
# server (full dns name), namespace, image name, and tag
|
||||||
|
# (e.g., registry.opensuse.org/opensuse/tumbleweed:latest). Pulling by digest (i.e.,
|
||||||
|
# registry.opensuse.org/project/name@digest) further eliminates the ambiguity of tags.
|
||||||
|
# When using short names, there is always an inherent risk that the image being
|
||||||
|
# pulled could be spoofed. For example, a user wants to pull an image named
|
||||||
|
# `foobar` from a registry and expects it to come from myregistry.com. If
|
||||||
|
# myregistry.com is not first in the search list, an attacker could place a
|
||||||
|
# different `foobar` image at a registry earlier in the search list. The user
|
||||||
|
# would accidentally pull and run the attacker's image and code rather than the
|
||||||
|
# intended content. We recommend only adding registries which are completely
|
||||||
|
# trusted (i.e., registries which don't allow unknown or anonymous users to
|
||||||
|
# create accounts with arbitrary names). This will prevent an image from being
|
||||||
|
# spoofed, squatted or otherwise made insecure. If it is necessary to use one
|
||||||
|
# of these registries, it should be added at the end of the list.
|
||||||
|
#
|
||||||
|
# # An array of host[:port] registries to try when pulling an unqualified image, in order.
|
||||||
|
unqualified-search-registries = ["registry.opensuse.org", "registry.suse.com", "docker.io"]
|
||||||
|
#
|
||||||
|
# [[registry]]
|
||||||
|
# # The "prefix" field is used to choose the relevant [[registry]] TOML table;
|
||||||
|
# # (only) the TOML table with the longest match for the input image name
|
||||||
|
# # (taking into account namespace/repo/tag/digest separators) is used.
|
||||||
|
# #
|
||||||
|
# # The prefix can also be of the form: *.example.com for wildcard subdomain
|
||||||
|
# # matching.
|
||||||
|
# #
|
||||||
|
# # If the prefix field is missing, it defaults to be the same as the "location" field.
|
||||||
|
# prefix = "example.com/foo"
|
||||||
|
#
|
||||||
|
# # If true, unencrypted HTTP as well as TLS connections with untrusted
|
||||||
|
# # certificates are allowed.
|
||||||
|
# insecure = false
|
||||||
|
#
|
||||||
|
# # If true, pulling images with matching names is forbidden.
|
||||||
|
# blocked = false
|
||||||
|
#
|
||||||
|
# # The physical location of the "prefix"-rooted namespace.
|
||||||
|
# #
|
||||||
|
# # By default, this is equal to "prefix" (in which case "prefix" can be omitted
|
||||||
|
# # and the [[registry]] TOML table can only specify "location").
|
||||||
|
# #
|
||||||
|
# # Example: Given
|
||||||
|
# # prefix = "example.com/foo"
|
||||||
|
# # location = "internal-registry-for-example.net/bar"
|
||||||
|
# # requests for the image example.com/foo/myimage:latest will actually work with the
|
||||||
|
# # internal-registry-for-example.net/bar/myimage:latest image.
|
||||||
|
#
|
||||||
|
# # The location can be empty iff prefix is in a
|
||||||
|
# # wildcarded format: "*.example.com". In this case, the input reference will
|
||||||
|
# # be used as-is without any rewrite.
|
||||||
|
# location = internal-registry-for-example.com/bar"
|
||||||
|
#
|
||||||
|
# # (Possibly-partial) mirrors for the "prefix"-rooted namespace.
|
||||||
|
# #
|
||||||
|
# # The mirrors are attempted in the specified order; the first one that can be
|
||||||
|
# # contacted and contains the image will be used (and if none of the mirrors contains the image,
|
||||||
|
# # the primary location specified by the "registry.location" field, or using the unmodified
|
||||||
|
# # user-specified reference, is tried last).
|
||||||
|
# #
|
||||||
|
# # Each TOML table in the "mirror" array can contain the following fields, with the same semantics
|
||||||
|
# # as if specified in the [[registry]] TOML table directly:
|
||||||
|
# # - location
|
||||||
|
# # - insecure
|
||||||
|
# [[registry.mirror]]
|
||||||
|
# location = "example-mirror-0.local/mirror-for-foo"
|
||||||
|
# [[registry.mirror]]
|
||||||
|
# location = "example-mirror-1.local/mirrors/foo"
|
||||||
|
# insecure = true
|
||||||
|
# # Given the above, a pull of example.com/foo/image:latest will try:
|
||||||
|
# # 1. example-mirror-0.local/mirror-for-foo/image:latest
|
||||||
|
# # 2. example-mirror-1.local/mirrors/foo/image:latest
|
||||||
|
# # 3. internal-registry-for-example.net/bar/image:latest
|
||||||
|
# # in order, and use the first one that exists.
|
121
shortnames.conf
Normal file
121
shortnames.conf
Normal file
@ -0,0 +1,121 @@
|
|||||||
|
[aliases]
|
||||||
|
# almalinux
|
||||||
|
"almalinux" = "docker.io/library/almalinux"
|
||||||
|
"almalinux-minimal" = "docker.io/library/almalinux-minimal"
|
||||||
|
# Arch Linux
|
||||||
|
"archlinux" = "docker.io/library/archlinux"
|
||||||
|
# centos
|
||||||
|
"centos" = "quay.io/centos/centos"
|
||||||
|
# containers
|
||||||
|
"skopeo" = "quay.io/skopeo/stable"
|
||||||
|
"buildah" = "quay.io/buildah/stable"
|
||||||
|
"podman" = "quay.io/podman/stable"
|
||||||
|
"hello" = "quay.io/podman/hello"
|
||||||
|
"hello-world" = "quay.io/podman/hello"
|
||||||
|
# docker
|
||||||
|
"alpine" = "docker.io/library/alpine"
|
||||||
|
"docker" = "docker.io/library/docker"
|
||||||
|
"registry" = "docker.io/library/registry"
|
||||||
|
"swarm" = "docker.io/library/swarm"
|
||||||
|
# Fedora
|
||||||
|
"fedora-minimal" = "registry.fedoraproject.org/fedora-minimal"
|
||||||
|
"fedora" = "registry.fedoraproject.org/fedora"
|
||||||
|
# openSUSE
|
||||||
|
"opensuse/tumbleweed" = "registry.opensuse.org/opensuse/tumbleweed"
|
||||||
|
"opensuse/tumbleweed-dnf" = "registry.opensuse.org/opensuse/tumbleweed-dnf"
|
||||||
|
"opensuse/tumbleweed-microdnf" = "registry.opensuse.org/opensuse/tumbleweed-microdnf"
|
||||||
|
"opensuse/leap" = "registry.opensuse.org/opensuse/leap"
|
||||||
|
"opensuse/busybox" = "registry.opensuse.org/opensuse/busybox"
|
||||||
|
"tumbleweed" = "registry.opensuse.org/opensuse/tumbleweed"
|
||||||
|
"tumbleweed-dnf" = "registry.opensuse.org/opensuse/tumbleweed-dnf"
|
||||||
|
"tumbleweed-microdnf" = "registry.opensuse.org/opensuse/tumbleweed-microdnf"
|
||||||
|
"leap" = "registry.opensuse.org/opensuse/leap"
|
||||||
|
"leap-dnf" = "registry.opensuse.org/opensuse/leap-dnf"
|
||||||
|
"leap-microdnf" = "registry.opensuse.org/opensuse/leap-microdnf"
|
||||||
|
"tw-busybox" = "registry.opensuse.org/opensuse/busybox"
|
||||||
|
# SUSE
|
||||||
|
"suse/sle15" = "registry.suse.com/suse/sle15"
|
||||||
|
"suse/sles12sp5" = "registry.suse.com/suse/sles12sp5"
|
||||||
|
"suse/sles12sp4" = "registry.suse.com/suse/sles12sp4"
|
||||||
|
"suse/sles12sp3" = "registry.suse.com/suse/sles12sp3"
|
||||||
|
"sle15" = "registry.suse.com/suse/sle15"
|
||||||
|
"sles12sp5" = "registry.suse.com/suse/sles12sp5"
|
||||||
|
"sles12sp4" = "registry.suse.com/suse/sles12sp4"
|
||||||
|
"sles12sp3" = "registry.suse.com/suse/sles12sp3"
|
||||||
|
"bci/bci-base" = "registry.suse.com/bci/bci-base"
|
||||||
|
"bci/bci-micro" = "registry.suse.com/bci/bci-micro"
|
||||||
|
"bci/bci-minimal" = "registry.suse.com/bci/bci-minimal"
|
||||||
|
"bci/bci-busybox" = "registry.suse.com/bci/bci-busybox"
|
||||||
|
# Red Hat Enterprise Linux
|
||||||
|
"rhel" = "registry.access.redhat.com/rhel"
|
||||||
|
"rhel6" = "registry.access.redhat.com/rhel6"
|
||||||
|
"rhel7" = "registry.access.redhat.com/rhel7"
|
||||||
|
"rhel7.9" = "registry.access.redhat.com/rhel7.9"
|
||||||
|
"rhel-atomic" = "registry.access.redhat.com/rhel-atomic"
|
||||||
|
"rhel-minimal" = "registry.access.redhat.com/rhel-minimum"
|
||||||
|
"rhel-init" = "registry.access.redhat.com/rhel-init"
|
||||||
|
"rhel7-atomic" = "registry.access.redhat.com/rhel7-atomic"
|
||||||
|
"rhel7-minimal" = "registry.access.redhat.com/rhel7-minimum"
|
||||||
|
"rhel7-init" = "registry.access.redhat.com/rhel7-init"
|
||||||
|
"rhel7/rhel" = "registry.access.redhat.com/rhel7/rhel"
|
||||||
|
"rhel7/rhel-atomic" = "registry.access.redhat.com/rhel7/rhel7/rhel-atomic"
|
||||||
|
"ubi7/ubi" = "registry.access.redhat.com/ubi7/ubi"
|
||||||
|
"ubi7/ubi-minimal" = "registry.access.redhat.com/ubi7-minimal"
|
||||||
|
"ubi7/ubi-init" = "registry.access.redhat.com/ubi7-init"
|
||||||
|
"ubi7" = "registry.access.redhat.com/ubi7"
|
||||||
|
"ubi7-init" = "registry.access.redhat.com/ubi7-init"
|
||||||
|
"ubi7-minimal" = "registry.access.redhat.com/ubi7-minimal"
|
||||||
|
"rhel8" = "registry.access.redhat.com/ubi8"
|
||||||
|
"rhel8-init" = "registry.access.redhat.com/ubi8-init"
|
||||||
|
"rhel8-minimal" = "registry.access.redhat.com/ubi8-minimal"
|
||||||
|
"rhel8-micro" = "registry.access.redhat.com/ubi8-micro"
|
||||||
|
"ubi8" = "registry.access.redhat.com/ubi8"
|
||||||
|
"ubi8-minimal" = "registry.access.redhat.com/ubi8-minimal"
|
||||||
|
"ubi8-init" = "registry.access.redhat.com/ubi8-init"
|
||||||
|
"ubi8-micro" = "registry.access.redhat.com/ubi8-micro"
|
||||||
|
"ubi8/ubi" = "registry.access.redhat.com/ubi8/ubi"
|
||||||
|
"ubi8/ubi-minimal" = "registry.access.redhat.com/ubi8-minimal"
|
||||||
|
"ubi8/ubi-init" = "registry.access.redhat.com/ubi8-init"
|
||||||
|
"ubi8/ubi-micro" = "registry.access.redhat.com/ubi8-micro"
|
||||||
|
"ubi8/podman" = "registry.access.redhat.com/ubi8/podman"
|
||||||
|
"ubi8/buildah" = "registry.access.redhat.com/ubi8/buildah"
|
||||||
|
"ubi8/skopeo" = "registry.access.redhat.com/ubi8/skopeo"
|
||||||
|
"rhel9" = "registry.access.redhat.com/ubi9"
|
||||||
|
"rhel9-init" = "registry.access.redhat.com/ubi9-init"
|
||||||
|
"rhel9-minimal" = "registry.access.redhat.com/ubi9-minimal"
|
||||||
|
"rhel9-micro" = "registry.access.redhat.com/ubi9-micro"
|
||||||
|
"ubi9" = "registry.access.redhat.com/ubi9"
|
||||||
|
"ubi9-minimal" = "registry.access.redhat.com/ubi9-minimal"
|
||||||
|
"ubi9-init" = "registry.access.redhat.com/ubi9-init"
|
||||||
|
"ubi9-micro" = "registry.access.redhat.com/ubi9-micro"
|
||||||
|
"ubi9/ubi" = "registry.access.redhat.com/ubi9/ubi"
|
||||||
|
"ubi9/ubi-minimal" = "registry.access.redhat.com/ubi9-minimal"
|
||||||
|
"ubi9/ubi-init" = "registry.access.redhat.com/ubi9-init"
|
||||||
|
"ubi9/ubi-micro" = "registry.access.redhat.com/ubi9-micro"
|
||||||
|
"ubi9/podman" = "registry.access.redhat.com/ubi9/podman"
|
||||||
|
"ubi9/buildah" = "registry.access.redhat.com/ubi9/buildah"
|
||||||
|
"ubi9/skopeo" = "registry.access.redhat.com/ubi9/skopeo"
|
||||||
|
# Rocky Linux
|
||||||
|
"rockylinux" = "docker.io/library/rockylinux"
|
||||||
|
# Debian
|
||||||
|
"debian" = "docker.io/library/debian"
|
||||||
|
# Kali Linux
|
||||||
|
"kali-bleeding-edge" = "docker.io/kalilinux/kali-bleeding-edge"
|
||||||
|
"kali-dev" = "docker.io/kalilinux/kali-dev"
|
||||||
|
"kali-experimental" = "docker.io/kalilinux/kali-experimental"
|
||||||
|
"kali-last-release" = "docker.io/kalilinux/kali-last-release"
|
||||||
|
"kali-rolling" = "docker.io/kalilinux/kali-rolling"
|
||||||
|
# Ubuntu
|
||||||
|
"ubuntu" = "docker.io/library/ubuntu"
|
||||||
|
# Oracle Linux
|
||||||
|
"oraclelinux" = "container-registry.oracle.com/os/oraclelinux"
|
||||||
|
# busybox
|
||||||
|
"busybox" = "docker.io/library/busybox"
|
||||||
|
# php
|
||||||
|
"php" = "docker.io/library/php"
|
||||||
|
# python
|
||||||
|
"python" = "docker.io/library/python"
|
||||||
|
# rust
|
||||||
|
"rust" = "docker.io/library/rust"
|
||||||
|
# node
|
||||||
|
"node" = "docker.io/library/node"
|
BIN
storage-1.51.0.tar.xz
(Stored with Git LFS)
Normal file
BIN
storage-1.51.0.tar.xz
(Stored with Git LFS)
Normal file
Binary file not shown.
240
storage.conf
Normal file
240
storage.conf
Normal file
@ -0,0 +1,240 @@
|
|||||||
|
# This file is the configuration file for all tools
|
||||||
|
# that use the containers/storage library. The storage.conf file
|
||||||
|
# overrides all other storage.conf files. Container engines using the
|
||||||
|
# container/storage library do not inherit fields from other storage.conf
|
||||||
|
# files.
|
||||||
|
#
|
||||||
|
# Note: The storage.conf file overrides other storage.conf files based on this precedence:
|
||||||
|
# /usr/containers/storage.conf
|
||||||
|
# /etc/containers/storage.conf
|
||||||
|
# $HOME/.config/containers/storage.conf
|
||||||
|
# $XDG_CONFIG_HOME/containers/storage.conf (If XDG_CONFIG_HOME is set)
|
||||||
|
# See man 5 containers-storage.conf for more information
|
||||||
|
# The "container storage" table contains all of the server options.
|
||||||
|
[storage]
|
||||||
|
|
||||||
|
# Default Storage Driver, Must be set for proper operation.
|
||||||
|
driver = "overlay"
|
||||||
|
|
||||||
|
# Temporary storage location
|
||||||
|
runroot = "/run/containers/storage"
|
||||||
|
|
||||||
|
# Priority list for the storage drivers that will be tested one
|
||||||
|
# after the other to pick the storage driver if it is not defined.
|
||||||
|
# driver_priority = ["btrfs", "overlay"]
|
||||||
|
|
||||||
|
# Primary Read/Write location of container storage
|
||||||
|
# When changing the graphroot location on an SELINUX system, you must
|
||||||
|
# ensure the labeling matches the default locations labels with the
|
||||||
|
# following commands:
|
||||||
|
# semanage fcontext -a -e /var/lib/containers/storage /NEWSTORAGEPATH
|
||||||
|
# restorecon -R -v /NEWSTORAGEPATH
|
||||||
|
graphroot = "/var/lib/containers/storage"
|
||||||
|
|
||||||
|
|
||||||
|
# Storage path for rootless users
|
||||||
|
#
|
||||||
|
# rootless_storage_path = "$HOME/.local/share/containers/storage"
|
||||||
|
|
||||||
|
# Transient store mode makes all container metadata be saved in temporary storage
|
||||||
|
# (i.e. runroot above). This is faster, but doesn't persist across reboots.
|
||||||
|
# transient_store = true
|
||||||
|
|
||||||
|
[storage.options]
|
||||||
|
# Storage options to be passed to underlying storage drivers
|
||||||
|
|
||||||
|
# AdditionalImageStores is used to pass paths to additional Read/Only image stores
|
||||||
|
# Must be comma separated list.
|
||||||
|
additionalimagestores = [
|
||||||
|
]
|
||||||
|
|
||||||
|
# Allows specification of how storage is populated when pulling images. This
|
||||||
|
# option can speed the pulling process of images compressed with format
|
||||||
|
# zstd:chunked. Containers/storage looks for files within images that are being
|
||||||
|
# pulled from a container registry that were previously pulled to the host. It
|
||||||
|
# can copy or create a hard link to the existing file when it finds them,
|
||||||
|
# eliminating the need to pull them from the container registry. These options
|
||||||
|
# can deduplicate pulling of content, disk storage of content and can allow the
|
||||||
|
# kernel to use less memory when running containers.
|
||||||
|
|
||||||
|
# containers/storage supports four keys
|
||||||
|
# * enable_partial_images="true" | "false"
|
||||||
|
# Tells containers/storage to look for files previously pulled in storage
|
||||||
|
# rather then always pulling them from the container registry.
|
||||||
|
# * use_hard_links = "false" | "true"
|
||||||
|
# Tells containers/storage to use hard links rather then create new files in
|
||||||
|
# the image, if an identical file already existed in storage.
|
||||||
|
# * ostree_repos = ""
|
||||||
|
# Tells containers/storage where an ostree repository exists that might have
|
||||||
|
# previously pulled content which can be used when attempting to avoid
|
||||||
|
# pulling content from the container registry
|
||||||
|
pull_options = {enable_partial_images = "false", use_hard_links = "false", ostree_repos=""}
|
||||||
|
|
||||||
|
# Remap-UIDs/GIDs is the mapping from UIDs/GIDs as they should appear inside of
|
||||||
|
# a container, to the UIDs/GIDs as they should appear outside of the container,
|
||||||
|
# and the length of the range of UIDs/GIDs. Additional mapped sets can be
|
||||||
|
# listed and will be heeded by libraries, but there are limits to the number of
|
||||||
|
# mappings which the kernel will allow when you later attempt to run a
|
||||||
|
# container.
|
||||||
|
#
|
||||||
|
# remap-uids = 0:1668442479:65536
|
||||||
|
# remap-gids = 0:1668442479:65536
|
||||||
|
|
||||||
|
# Remap-User/Group is a user name which can be used to look up one or more UID/GID
|
||||||
|
# ranges in the /etc/subuid or /etc/subgid file. Mappings are set up starting
|
||||||
|
# with an in-container ID of 0 and then a host-level ID taken from the lowest
|
||||||
|
# range that matches the specified name, and using the length of that range.
|
||||||
|
# Additional ranges are then assigned, using the ranges which specify the
|
||||||
|
# lowest host-level IDs first, to the lowest not-yet-mapped in-container ID,
|
||||||
|
# until all of the entries have been used for maps.
|
||||||
|
#
|
||||||
|
# remap-user = "containers"
|
||||||
|
# remap-group = "containers"
|
||||||
|
|
||||||
|
# Root-auto-userns-user is a user name which can be used to look up one or more UID/GID
|
||||||
|
# ranges in the /etc/subuid and /etc/subgid file. These ranges will be partitioned
|
||||||
|
# to containers configured to create automatically a user namespace. Containers
|
||||||
|
# configured to automatically create a user namespace can still overlap with containers
|
||||||
|
# having an explicit mapping set.
|
||||||
|
# This setting is ignored when running as rootless.
|
||||||
|
# root-auto-userns-user = "storage"
|
||||||
|
#
|
||||||
|
# Auto-userns-min-size is the minimum size for a user namespace created automatically.
|
||||||
|
# auto-userns-min-size=1024
|
||||||
|
#
|
||||||
|
# Auto-userns-max-size is the minimum size for a user namespace created automatically.
|
||||||
|
# auto-userns-max-size=65536
|
||||||
|
|
||||||
|
[storage.options.overlay]
|
||||||
|
# ignore_chown_errors can be set to allow a non privileged user running with
|
||||||
|
# a single UID within a user namespace to run containers. The user can pull
|
||||||
|
# and use any image even those with multiple uids. Note multiple UIDs will be
|
||||||
|
# squashed down to the default uid in the container. These images will have no
|
||||||
|
# separation between the users in the container. Only supported for the overlay
|
||||||
|
# and vfs drivers.
|
||||||
|
#ignore_chown_errors = "false"
|
||||||
|
|
||||||
|
# Inodes is used to set a maximum inodes of the container image.
|
||||||
|
# inodes = ""
|
||||||
|
|
||||||
|
# Path to an helper program to use for mounting the file system instead of mounting it
|
||||||
|
# directly.
|
||||||
|
#mount_program = "/usr/bin/fuse-overlayfs"
|
||||||
|
|
||||||
|
# mountopt specifies comma separated list of extra mount options
|
||||||
|
mountopt = "nodev,metacopy=on"
|
||||||
|
|
||||||
|
# Set to skip a PRIVATE bind mount on the storage home directory.
|
||||||
|
# skip_mount_home = "false"
|
||||||
|
|
||||||
|
# Size is used to set a maximum size of the container image.
|
||||||
|
# size = ""
|
||||||
|
|
||||||
|
# ForceMask specifies the permissions mask that is used for new files and
|
||||||
|
# directories.
|
||||||
|
#
|
||||||
|
# The values "shared" and "private" are accepted.
|
||||||
|
# Octal permission masks are also accepted.
|
||||||
|
#
|
||||||
|
# "": No value specified.
|
||||||
|
# All files/directories, get set with the permissions identified within the
|
||||||
|
# image.
|
||||||
|
# "private": it is equivalent to 0700.
|
||||||
|
# All files/directories get set with 0700 permissions. The owner has rwx
|
||||||
|
# access to the files. No other users on the system can access the files.
|
||||||
|
# This setting could be used with networked based homedirs.
|
||||||
|
# "shared": it is equivalent to 0755.
|
||||||
|
# The owner has rwx access to the files and everyone else can read, access
|
||||||
|
# and execute them. This setting is useful for sharing containers storage
|
||||||
|
# with other users. For instance have a storage owned by root but shared
|
||||||
|
# to rootless users as an additional store.
|
||||||
|
# NOTE: All files within the image are made readable and executable by any
|
||||||
|
# user on the system. Even /etc/shadow within your image is now readable by
|
||||||
|
# any user.
|
||||||
|
#
|
||||||
|
# OCTAL: Users can experiment with other OCTAL Permissions.
|
||||||
|
#
|
||||||
|
# Note: The force_mask Flag is an experimental feature, it could change in the
|
||||||
|
# future. When "force_mask" is set the original permission mask is stored in
|
||||||
|
# the "user.containers.override_stat" xattr and the "mount_program" option must
|
||||||
|
# be specified. Mount programs like "/usr/bin/fuse-overlayfs" present the
|
||||||
|
# extended attribute permissions to processes within containers rather then the
|
||||||
|
# "force_mask" permissions.
|
||||||
|
#
|
||||||
|
# force_mask = ""
|
||||||
|
|
||||||
|
[storage.options.thinpool]
|
||||||
|
# Storage Options for thinpool
|
||||||
|
|
||||||
|
# autoextend_percent determines the amount by which pool needs to be
|
||||||
|
# grown. This is specified in terms of % of pool size. So a value of 20 means
|
||||||
|
# that when threshold is hit, pool will be grown by 20% of existing
|
||||||
|
# pool size.
|
||||||
|
# autoextend_percent = "20"
|
||||||
|
|
||||||
|
# autoextend_threshold determines the pool extension threshold in terms
|
||||||
|
# of percentage of pool size. For example, if threshold is 60, that means when
|
||||||
|
# pool is 60% full, threshold has been hit.
|
||||||
|
# autoextend_threshold = "80"
|
||||||
|
|
||||||
|
# basesize specifies the size to use when creating the base device, which
|
||||||
|
# limits the size of images and containers.
|
||||||
|
# basesize = "10G"
|
||||||
|
|
||||||
|
# blocksize specifies a custom blocksize to use for the thin pool.
|
||||||
|
# blocksize="64k"
|
||||||
|
|
||||||
|
# directlvm_device specifies a custom block storage device to use for the
|
||||||
|
# thin pool. Required if you setup devicemapper.
|
||||||
|
# directlvm_device = ""
|
||||||
|
|
||||||
|
# directlvm_device_force wipes device even if device already has a filesystem.
|
||||||
|
# directlvm_device_force = "True"
|
||||||
|
|
||||||
|
# fs specifies the filesystem type to use for the base device.
|
||||||
|
# fs="xfs"
|
||||||
|
|
||||||
|
# log_level sets the log level of devicemapper.
|
||||||
|
# 0: LogLevelSuppress 0 (Default)
|
||||||
|
# 2: LogLevelFatal
|
||||||
|
# 3: LogLevelErr
|
||||||
|
# 4: LogLevelWarn
|
||||||
|
# 5: LogLevelNotice
|
||||||
|
# 6: LogLevelInfo
|
||||||
|
# 7: LogLevelDebug
|
||||||
|
# log_level = "7"
|
||||||
|
|
||||||
|
# min_free_space specifies the min free space percent in a thin pool require for
|
||||||
|
# new device creation to succeed. Valid values are from 0% - 99%.
|
||||||
|
# Value 0% disables
|
||||||
|
# min_free_space = "10%"
|
||||||
|
|
||||||
|
# mkfsarg specifies extra mkfs arguments to be used when creating the base
|
||||||
|
# device.
|
||||||
|
# mkfsarg = ""
|
||||||
|
|
||||||
|
# metadata_size is used to set the `pvcreate --metadatasize` options when
|
||||||
|
# creating thin devices. Default is 128k
|
||||||
|
# metadata_size = ""
|
||||||
|
|
||||||
|
# Size is used to set a maximum size of the container image.
|
||||||
|
# size = ""
|
||||||
|
|
||||||
|
# use_deferred_removal marks devicemapper block device for deferred removal.
|
||||||
|
# If the thinpool is in use when the driver attempts to remove it, the driver
|
||||||
|
# tells the kernel to remove it as soon as possible. Note this does not free
|
||||||
|
# up the disk space, use deferred deletion to fully remove the thinpool.
|
||||||
|
# use_deferred_removal = "True"
|
||||||
|
|
||||||
|
# use_deferred_deletion marks thinpool device for deferred deletion.
|
||||||
|
# If the device is busy when the driver attempts to delete it, the driver
|
||||||
|
# will attempt to delete device every 30 seconds until successful.
|
||||||
|
# If the program using the driver exits, the driver will continue attempting
|
||||||
|
# to cleanup the next time the driver is used. Deferred deletion permanently
|
||||||
|
# deletes the device and all data stored in device will be lost.
|
||||||
|
# use_deferred_deletion = "True"
|
||||||
|
|
||||||
|
# xfs_nospace_max_retries specifies the maximum number of retries XFS should
|
||||||
|
# attempt to complete IO when ENOSPC (no space) error is returned by
|
||||||
|
# underlying storage device.
|
||||||
|
# xfs_nospace_max_retries = "0"
|
Loading…
Reference in New Issue
Block a user