AppArmor Support (dsR8)

Story: 2010310
Task: 47620

Signed-off-by: Elisamara Aoki Goncalves <elisamaraaoki.goncalves@windriver.com>
Change-Id: I97065a0d0c345bb32663e1ff631c5c4ca524231d
This commit is contained in:
Elisamara Aoki Goncalves 2023-03-10 16:42:03 -03:00
parent 35af206725
commit ace0287d7a
20 changed files with 872 additions and 17 deletions

View File

@ -112,6 +112,13 @@ Install-time-only parameters
* ``password`` * ``password``
* ``secure`` * ``secure``
* ``registry.k8s.io``
* ``url``
* ``username``
* ``password``
* ``secure``
* ``defaults`` * ``defaults``
* ``url`` * ``url``
@ -305,6 +312,8 @@ additionally specifies an alternate CA certificate.
url: my.quayregistry.io url: my.quayregistry.io
docker.io: docker.io:
url: my.dockerregistry.io url: my.dockerregistry.io
registry.k8s.io:
url: my.registry.k8s.io
defaults: defaults:
url: my.registry.io url: my.registry.io
username: myreguser username: myreguser

View File

@ -180,6 +180,8 @@ Bootstrap system on controller-0
url: myprivateregistry.abc.com:9001/k8s.gcr.io url: myprivateregistry.abc.com:9001/k8s.gcr.io
docker.io: docker.io:
url: myprivateregistry.abc.com:9001/docker.io url: myprivateregistry.abc.com:9001/docker.io
registry.k8s.io:
url: myprivateregistry.abc.com:9001/registry.k8s.io
defaults: defaults:
type: docker type: docker
username: <your_myprivateregistry.abc.com_username> username: <your_myprivateregistry.abc.com_username>

View File

@ -180,6 +180,8 @@ Bootstrap system on controller-0
url: myprivateregistry.abc.com:9001/k8s.gcr.io url: myprivateregistry.abc.com:9001/k8s.gcr.io
docker.io: docker.io:
url: myprivateregistry.abc.com:9001/docker.io url: myprivateregistry.abc.com:9001/docker.io
registry.k8s.io
url: myprivateregistry.abc.com:9001/registry.k8s.io
defaults: defaults:
type: docker type: docker
username: <your_myprivateregistry.abc.com_username> username: <your_myprivateregistry.abc.com_username>

View File

@ -30,6 +30,8 @@ your server is isolated from the public Internet.
url: <my-registry.io>/docker.io url: <my-registry.io>/docker.io
docker.elastic.co: docker.elastic.co:
url: <my-registry.io>/docker.elastic.co url: <my-registry.io>/docker.elastic.co
registry.k8s.io:
url: <my-registry.io>/registry.k8s.io
defaults: defaults:
type: docker type: docker
username: <your_my-registry.io_username> username: <your_my-registry.io_username>

View File

@ -243,6 +243,8 @@ Bootstrap system on controller-0
url: myprivateregistry.abc.com:9001/k8s.ghcr.io url: myprivateregistry.abc.com:9001/k8s.ghcr.io
docker.io: docker.io:
url: myprivateregistry.abc.com:9001/docker.io url: myprivateregistry.abc.com:9001/docker.io
registry.k8s.io:
url: myprivateregistry.abc.com:9001/registry.k8s.io
defaults: defaults:
type: docker type: docker
username: <your_myprivateregistry.abc.com_username> username: <your_myprivateregistry.abc.com_username>

View File

@ -243,6 +243,8 @@ command with the ``install-values.yaml`` file containing the desired
url: registry.central:9001/docker.io url: registry.central:9001/docker.io
docker.elastic.co: docker.elastic.co:
url: registry.central:9001/docker.elastic.co url: registry.central:9001/docker.elastic.co
registry.k8s.io:
url: registry.central:9001/registry.k8s.io
defaults: defaults:
username: sysinv username: sysinv
password: <sysinv_password> password: <sysinv_password>

View File

@ -196,6 +196,8 @@ subcloud, the subcloud installation process has two phases:
url: registry.central:9001/docker.io url: registry.central:9001/docker.io
docker.elastic.co: docker.elastic.co:
url: registry.central:9001/docker.elastic.co url: registry.central:9001/docker.elastic.co
registry.k8s.io:
url: registry.central:9001/registry.k8s.io
defaults: defaults:
username: sysinv username: sysinv
password: <sysinv_password> password: <sysinv_password>

View File

@ -0,0 +1,52 @@
.. _about-apparmor-ebdab8f1ed87:
==============
About AppArmor
==============
AppArmor is a Mandatory Access Control (MAC) system built on Linux's LSM (Linux
Security Modules) interface. In practice, the kernel queries AppArmor before
each system call to know whether the process is authorized to do the given
operation. Through this mechanism, AppArmor confines programs to a limited set
of resources.
AppArmor helps administrators in running a more secure kubernetes deployment by
restricting what containers/pods are allowed to do, and/or provide better
auditing through system logs. The access needed by a container/pod is
configured through profiles tuned to allow access such as Linux capabilities,
network access, file permissions, etc.
AppArmor applies a set of rules (known as a “profile”) on each program. The
profile applied by the kernel depends on the installation path of the program
being executed, the rules applied do not depend on the user. All users face the
same set of rules when they are executing the same program, but traditional
user permissions still apply and might result in different behavior.
AppArmor profiles contain a list of access control rules on resources that each
program can make use of. Each profile can be loaded either in enforcing or
complaining mode. The former enforces the policy and reports violation
attempts, while the latter does not enforce the policy but still logs the
system calls that would have been denied.
In order to apply a profile to a particular pod, the profile needs to be
available to the host machine where the pod is launched. Security Profile
Operator (SPO, https://github.com/kubernetes-sigs/security-profiles-operator)
provides AppArmor profile management (i.e. loading/unloading) across
Kubernetes nodes. |SPO| defines an AppArmor Profile |CRD|, such that end users
can define AppArmor profiles for |SPO| to manage. Once an AppArmor profile is
loaded to the Kubernetes nodes, it can be applied to a particular pod using
annotations on the pod specification.
For example:
.. code-block:: none
container.apparmor.security.beta.kubernetes.io/<pod_name>:localhost/<profile_ref>
For more information, refer to `Restrict a Container's Access to Resources with
AppArmor: Example
<https://kubernetes.io/docs/tutorials/security/apparmor/#example>`__.

View File

@ -0,0 +1,99 @@
.. _apply-a-profile-to-a-pod-c2fa4d958dec:
========================
Apply a Profile to a Pod
========================
AppArmor profiles are specified per-container.
.. rubric:: |prereq|
- AppArmor should be enabled on the host(s) (described in
:ref:`Enable/Disable AppArmor on a Host
<enable-disable-apparmor-on-a-host-63a7a184d310>`), where workloads need to
be protected using AppArmor.
- Security Profiles Operator (SPO) should be installed. As described in
:ref:`Install Security Profiles Operator (SPO)
<install-security-profiles-operator-1b2f9a0f0108>`.
- A profile should be loaded using |SPO| (described in :ref:`Profile
Management <profile-management-a8df19c86a5d>`).
To specify the AppArmor profile to run a Pod container with, add an annotation
to the Pod's metadata:
.. code-block:: none
container.apparmor.security.beta.kubernetes.io/<container_name>: <profile_ref>
.. rubric:: |eg|
#. Attach a profile to a container in the Pod.
.. code-block:: none
$ vi test-apparmor.yaml
apiVersion: v1
kind: Pod
metadata:
name: test-apparmor
annotations:
# Tell Kubernetes to apply the AppArmor profile "test-profile".
container.apparmor.security.beta.kubernetes.io/test-apparmor: localhost/test-profile
spec:
containers:
- name: test-apparmor
image: busybox:1.28
command: [ "sh", "-c", "echo 'Hello Test AppArmor!' && sleep 1h" ]
$ kubectl apply -f test-apparmor.yaml
#. Verify that the container is actually running with that profile by checking
its proc attr.
.. code-block:: none
$ kubectl exec test-apparmor -- cat /proc/1/attr/current
test-profile (complain)
#. Verify if violations are blocked by writing to a file.
.. code-block:: none
$ kubectl exec test-apparmor -- touch /tmp/test
touch: /tmp/test: Permission denied
command terminated with exit code 1
.. note::
If a profile is not created/loaded on a host, ``kubelet`` will reject the
pod.
.. code-block:: none
$ kubectl get pods
NAME READY STATUS RESTARTS AGE
hello-apparmor 0/1 CreateContainerError 0 (49m ago) 113m
Running ``kubectl describe pod hello-apparmor`` or
``kubect get event | grep hello-apparmor`` will show the following error:
.. code-block:: none
Error: : failed to generate apparmor spec opts: apparmor profile not found test-profile
Any profile rules updates are reflected to the running pods.
Any profile deletion while it is attached to a pod will not have any impact
on the pod state (It will show in running state). The application in the
pod may not behave correctly as it might try to access
``/proc/self/attr/apparmor/exec`` which throw error as profile is not
loaded.
For more details, refer to `Restrict a Container's Access to Resources with
AppArmor: Example
<https://kubernetes.io/docs/tutorials/security/apparmor/#example>`__.

View File

@ -0,0 +1,148 @@
.. _author-apparmor-profiles-b02de0a22771:
========================
Author AppArmor Profiles
========================
AppArmor profiles can be written using a variety of approaches: AppArmor
policy language, Bane and/or aa-logprof.
Core Policy Reference
*********************
AppArmor wiki provides the guidelines and semantics for AppArmor policy
enforcement and reference profile language which can be found at below link.
https://gitlab.com/apparmor/apparmor/-/wikis/AppArmor_Core_Policy_Reference
Bane
****
`bane <https://github.com/genuinetools/bane>`__ is an AppArmor profile
generator for Docker that uses a simplified profile language. This could be
used for generating a profile using an easy-to-read configuration file.
https://www.padok.fr/en/blog/security-docker-apparmor#Generate_an_AppArmor_profile_for_a_docker_container_with_bane
Generate a profile using aa-logprof
***********************************
#. Create a profile with name ``<appname>-profile`` under ``/etc/apparmor.d``,
which denies everything.
For example:
.. code-block:: none
#include <tunables/global>
profile <appname>-profile flags=(attach_disconnected, complain) {
#include <abstractions/base>
}
#. Use ``apparmor_parser`` to load the above created profile in complain mode:
.. code-block:: none
apparmor_parser -q /etc/apparmor.d/<profilename>
#. Attach the profile to the pod, launch the pod and perform the pod's allowed
operations.
#. Below permission change needs to be done by a user with sudo capability
(e.g. 'sysadmin' user) to allow a ``sys_protected`` group member (e.g.
'sysadmin' user) to update the profile using :command:`aa-logprof`.
.. code-block:: none
sudo setfacl -m g:sys_protected:rwx /etc/apparmor.d/
#. Use :command:`aa-logprof` to update the profile as follows:
.. code-block:: none
aa-logprof -f <(sed 's/kernel: notice/kernel:/' < /var/log/kern.log)
This would update the profile under ``/etc/apparmor.d``.
#. Add the updated profile in the policy section of the AppArmor |CRD| after
changing complain to enforce and load it in enforced mode as specified in
:ref:`Load a profile in enforce mode across all hosts using SPO
<load-a-profile-in-enforce-mode-across-all-hosts-using-spo>`.
Example profiles 1
******************
Below is an example of a sample profile which adds Linux capabilities, network
access rule, process limit, and file access.
.. code-block:: none
# This loads a file containing variable definitions.
include <tunables/home>
# profile name
profile Sample_profile flags=(attach_disconnected, mediate_deleted) {
# This keyword allows to include rules from other files -
#include <abstractions/base>
# enables POSIX.1e draft capabilitie. application can change process UIDs and GIDs s
capability setuid,
capability setgid,
# network access IPv4 TCP and IPv4 UPD is allowed -
network inet dgram,
network inet stream,
# rlimit stack size is limited to 5KB
rlimit stack >= 5K,
# file permissions application can read and write to ~/myfile and it can execute ~/app
@{HOME}/myfile rw,
@{HOME}/app ix,
}
}
Example profiles 2
******************
Below is an example profile of tcpdump a packet analyzer application. The
rules are more focused on Linux capabilities and Network access.
.. code-block:: none
#include <tunables/global>
/usr/sbin/tcpdump {
#include <abstractions/base>
#include <abstractions/nameservice>
#include <abstractions/user-tmp>
capability net_raw,
capability setuid,
capability setgid,
capability dac_override,
network raw,
network packet,
# for -D
capability sys_module,
@{PROC}/bus/usb/ r,
@{PROC}/bus/usb/** r,
# for -F and -w
audit deny @{HOME}/.* mrwkl,
audit deny @{HOME}/.*/ rw,
audit deny @{HOME}/.*/** mrwkl,
audit deny @{HOME}/bin/ rw,
audit deny @{HOME}/bin/** mrwkl,
@{HOME}/ r,
@{HOME}/** rw,
/usr/sbin/tcpdump r,
}

View File

@ -0,0 +1,31 @@
.. _enable-apparmor-log-bb600560d794:
===================
Enable AppArmor Log
===================
AppArmor usually outputs messages when it is interacting with an application
and if there are AppArmor denied messages. A message is logged, via the Linux
Auditing System, when a profile is in complain mode and application tries to
access denied resources. The Linux Auditing System is disabled in the |prod|
kernel by default. To enable it, please refer to :ref:`Enable Auditd in the
Kernel <auditd-support-339a51d8ce16>`.
.. note::
Enabling Auditd in the kernel is necessary for AppArmor logging. User do
NOT need to install Auditd system application.
Once enabled, the logged message can be seen at ``/var/log/kern.log``.
.. code-block:: none
2023-02-01T01:48:45.412 controller-0 kernel: notice [ 4028.407687] audit: type=1400 audit(1675216125.410:3110): apparmor="ALLOWED" operation="open" profile="test-profile" name="/proc/1/attr/current" pid=331323 comm="cat" requested_mask="r" denied_mask="r" fsuid=0 ouid=0
If auditd system application is installed as described in :ref:`Start Auditd
System Application <auditd-support-339a51d8ce16>`, the messages are logged at
``/var/log/audit/audit.log``.

View File

@ -0,0 +1,62 @@
.. _enable-disable-apparmor-on-a-host-63a7a184d310:
=================================
Enable/Disable AppArmor on a Host
=================================
By default, AppArmor is disabled on a host. It can be enabled in the kernel
using system CLI commands as follows. In the below example AppArmor is enabled
on controller-0.
.. note::
Enabling AppArmor can result in some performance degradation, see |org|
System Engineering Guidelines.
.. note::
On a multi-host configuration, AppArmor should be enabled on all hosts to
ensure that the AppArmor profiles are loaded on any host where a pod may be
scheduled by kubernetes.
#. To enable AppArmor on a host, run the following commands:
.. code-block:: none
~(keystone_admin)]$ system host-lock controller-0
~(keystone_admin)]$ system host-update controller-0 apparmor=enabled
~(keystone_admin)]$ system host-unlock controller-0
Wait for controller-0 to reset and return to an unlocked/enabled/available
state.
#. Verify if AppArmor is enabled by running the following commands on the
host.
.. code-block:: none
sysadmin@controller-0:~$ aa-enabled
Yes
To disable AppArmor on a host, run the following commands.
#. In the below example AppArmor is disabled on controller-0.
.. code-block:: none
~(keystone_admin)]$ system host-lock controller-0
~(keystone_admin)]$ system host-update controller-0 apparmor=disabled
~(keystone_admin)]$ system host-unlock controller-0
Wait for controller-0 to reset and return to an unlocked/enabled/available
state.
#. Verify if AppArmor is disabled by running the following commands on the
host.
.. code-block:: none
sysadmin@controller-0:~$ aa-enabled
No

View File

@ -190,6 +190,21 @@ Linux Auditing System
auditd-support-339a51d8ce16 auditd-support-339a51d8ce16
********
AppArmor
********
.. toctree::
:maxdepth: 1
about-apparmor-ebdab8f1ed87
enable-disable-apparmor-on-a-host-63a7a184d310
install-security-profiles-operator-1b2f9a0f0108
profile-management-a8df19c86a5d
apply-a-profile-to-a-pod-c2fa4d958dec
enable-apparmor-log-bb600560d794
author-apparmor-profiles-b02de0a22771
************************************* *************************************
Operator Login/Authentication Logging Operator Login/Authentication Logging
************************************* *************************************

View File

@ -0,0 +1,121 @@
.. _install-security-profiles-operator-1b2f9a0f0108:
========================================
Install Security Profiles Operator (SPO)
========================================
In order to apply the profiles to a particular pod, the profiles need to be
available to the host machine where the pod is launched. Security Profile
Operator (SPO, https://github.com/kubernetes-sigs/security-profiles-operator)
provides AppArmor profile management (i.e. loading/unloading) across Kubernetes
nodes. |SPO| defines an AppArmor Profile |CRD|, such that end users' can define
AppArmor profiles for |SPO| to manage.
|SPO| is packaged as a system application and is managed using system
application commands. To install |SPO|, use the following procedure.
.. rubric:: |prereq|
AppArmor should be enabled on the host(s) (described in :ref:`Enable/Disable
AppArmor on a Host <enable-disable-apparmor-on-a-host-63a7a184d310>`), where
workloads need to be protected using AppArmor.
.. rubric:: |proc|
#. Locate the |SPO| tarball in ``/usr/local/share/applications/helm``.
For example:
.. code-block:: none
/usr/local/share/applications/helm/security-profiles-operator-<version>.tgz
#. Upload the application.
.. code-block:: none
~(keystone_admin)]$ system application-upload /usr/local/share/applications/helm/security-profiles-operator-<version>.tgz
#. Verify the |SPO| tarball has been uploaded.
.. code-block:: none
~(keystone_admin)]$ system application-list
#. Apply the application.
.. code-block:: none
~(keystone_admin)]$ system application-apply security-profiles-operator
#. Monitor the status.
.. code-block:: none
~(keystone_admin)]$ watch -n 5 system application-list
OR
~(keystone_admin)]$ watch kubectl get pods -n security-profiles-operator
The configuration of the installed ``security-profiles-operator`` application
is as follows:
``security-profiles-operator``
Runs as a deployment, replica count of 3 on the controller(s).
``security-profiles-operator-webhook``
Runs as a deployment, replica count of 3.
``spod``
Runs as a daemonset on every Kubernetes host (i.e., controller(s) and
worker(s)), where application pods can be scheduled.
.. _remove-security-profiles-operator-spo:
Remove Security Profiles Operator (SPO)
---------------------------------------
Run the following commands to remove |SPO|. This will remove pods and other
resources created by the application installation.
.. note::
This procedure does not remove the apparmor profiles created using |SPO|,
You can delete the profiles previously created by following the procedure
described in :ref:`Delete a profile across all hosts using SPO
<delete-a-profile-across-all-hosts-using-spo>`.
If an AppArmor profile is deleted, all pods with that AppArmor profile
annotation should be either removed or updated to remove the annotation.
#. Remove the application.
.. code-block:: none
~(keystone_admin)]$ system application-remove security-profiles-operator
#. Delete the application.
.. code-block:: none
~(keystone_admin)]$ system application-delete security-profiles-operator
.. note::
To remove AppArmor from a |prod| deployment requires removing |SPO| as
specified in this section and then disabling AppArmor on all the host(s).
For more details, see :ref:`Enable/Disable AppArmor on a Host
<enable-disable-apparmor-on-a-host-63a7a184d310>`.
Disable AppArmor from a StarlingX deployment
--------------------------------------------
To disable AppArmor from a deployment, need to follow below steps:
#. Remove |SPO| system app (refer to :ref:`Remove Security Profiles Operator
(SPO) <remove-security-profiles-operator-spo>`).
#. Disable AppArmor on host(s) (refer to :ref:`Enable/Disable AppArmor on a
Host <enable-disable-apparmor-on-a-host-63a7a184d310>`).

View File

@ -0,0 +1,257 @@
.. _profile-management-a8df19c86a5d:
==================
Profile Management
==================
AppArmor profiles can be managed using |SPO| |CRD| (``apparmorprofile``). A
user can load, update, and delete a profile.
.. _load-a-profile-in-enforce-mode-across-all-hosts-using-spo:
Load a profile in enforce mode across all hosts using SPO
---------------------------------------------------------
#. Apply the profile.
.. code-block:: none
$ vi apparmorprofile.yaml
---
apiVersion: security-profiles-operator.x-k8s.io/v1alpha1
kind: AppArmorProfile
metadata:
name: test-profile
annotations:
description: Block writing to any files in the disk.
spec:
policy: |
#include <tunables/global>
profile test-profile flags=(attach_disconnected) {
#include <abstractions/base>
file,
# Deny all file writes.
deny /** w,
}
$ kubectl apply -f apparmorprofile.yaml
#. Verify if ``apparmorprofile`` resource is created.
.. code-block:: none
$ kubectl get apparmorprofiles
NAME AGE
test-profile 3d5h
#. Verify if test-profile is loaded in enforce mode on a host.
.. code-block:: none
$ aa-status
apparmor module is loaded.
20 profiles are loaded.
13 profiles are in enforce mode.
/usr/bin/man
/usr/lib/ipsec/charon
/usr/lib/ipsec/stroke
/usr/sbin/ntpd
cri-containerd.apparmor.d
docker-default
lsb_release
man_filter
man_groff
nvidia_modprobe
nvidia_modprobe//kmod
tcpdump
test-profile
7 profiles are in complain mode.
/usr/bin/keystone-wsgi-public
/usr/sbin/sssd
/usr/sbin/sssd//null-/usr/libexec/sssd/sssd_be
/usr/sbin/sssd//null-/usr/libexec/sssd/sssd_nss
/usr/sbin/sssd//null-/usr/libexec/sssd/sssd_pam
Load a profile in complain mode across all hosts using SPO
----------------------------------------------------------
#. Apply the profile.
.. code-block:: none
$ vi apparmorprofile.yaml
---
apiVersion: security-profiles-operator.x-k8s.io/v1alpha1
kind: AppArmorProfile
metadata:
name: test-profile
annotations:
description: Block writing to any files in the disk.
spec:
policy: |
#include <tunables/global>
profile test-profile flags=(attach_disconnected, complain) {
#include <abstractions/base>
file,
# Deny all file writes.
deny /** w,
}
$ kubectl apply -f apparmorprofile.yaml
#. Verify if apparmorprofile resource is created.
.. code-block:: none
$ kubectl get apparmorprofiles
NAME AGE
test-profile 3d5h
#. Verify if test-profile is loaded in complain mode on a host.
.. code-block:: none
aa-status
apparmor module is loaded.
20 profiles are loaded.
12 profiles are in enforce mode.
/usr/bin/man
/usr/lib/ipsec/charon
/usr/lib/ipsec/stroke
/usr/sbin/ntpd
cri-containerd.apparmor.d
docker-default
lsb_release
man_filter
man_groff
nvidia_modprobe
nvidia_modprobe//kmod
tcpdump
6 profiles are in complain mode.
/usr/bin/keystone-wsgi-public
/usr/sbin/sssd
/usr/sbin/sssd//null-/usr/libexec/sssd/sssd_be
/usr/sbin/sssd//null-/usr/libexec/sssd/sssd_nss
/usr/sbin/sssd//null-/usr/libexec/sssd/sssd_pam
test-profile
0 processes have profiles defined.
0 processes are in enforce mode.
0 processes are in complain mode.
0 processes are unconfined but have a profile defined.
Update a profile across all hosts using SPO
-------------------------------------------
#. Update the policy section of the ``.yaml`` used to create the profile.
.. code-block:: none
$ vi apparmorprofile.yaml
---
apiVersion: security-profiles-operator.x-k8s.io/v1alpha1
kind: AppArmorProfile
metadata:
name: test-profile
annotations:
description: Block writing to any files in the disk.
spec:
policy: |
#include <tunables/global>
profile test-profile flags=(attach_disconnected, complain) {
#include <abstractions/base>
file,
# Deny all file writes.
deny /** w,
network inet tcp,
network inet udp,
capability chown,
}
#. Update the profile.
.. code-block:: none
$ kubectl apply -f apparmorprofile.yaml
#. Verify if the test-profile is added. Check the test-profile content at
``/etc/apparmor.d`` on a host.
.. code-block:: none
$ cat test-profile
#include <tunables/global>
profile test-profile flags=(attach_disconnected, complain) {
#include <abstractions/base>
file,
# Deny all file writes.
deny /** w,
network inet tcp,
network inet udp,
capability chown,
}
.. _delete-a-profile-across-all-hosts-using-spo:
Delete a profile across all hosts using SPO
-------------------------------------------
#. List the AppArmor profiles.
.. code-block:: none
$ kubectl get apparmorprofiles.security-profiles-operator.x-k8s.io
NAME AGE
test-profile 4d1h
#. Delete the AppArmor profiles using ``.yaml`` file as follows:
.. code-block:: none
$ kubectl delete -f apparmorprofile.yaml
OR using imperative commands:
.. code-block:: none
$ kubectl delete apparmorprofiles.security-profiles-operator.x-k8s.io <profile-name>
#. Verify if apparmorprofile resource is deleted.
.. code-block:: none
$ kubectl get apparmorprofiles.security-profiles-operator.x-k8s.io
No resources found in default namespace.
#. Verify if test-profile is removed from a host using ``aa-status``.
.. code-block:: none
$ aa-status
apparmor module is loaded.
20 profiles are loaded.
13 profiles are in enforce mode.
/usr/bin/man
/usr/lib/ipsec/charon
/usr/lib/ipsec/stroke
/usr/sbin/ntpd
cri-containerd.apparmor.d
docker-default
lsb_release
man_filter
man_groff
nvidia_modprobe
nvidia_modprobe//kmod
tcpdump
7 profiles are in complain mode.
/usr/bin/keystone-wsgi-public
/usr/sbin/sssd
/usr/sbin/sssd//null-/usr/libexec/sssd/sssd_be
/usr/sbin/sssd//null-/usr/libexec/sssd/sssd_nss
/usr/sbin/sssd//null-/usr/libexec/sssd/sssd_pam

View File

@ -76,6 +76,7 @@
.. |LDAP| replace:: :abbr:`LDAP (Lightweight Directory Access Protocol)` .. |LDAP| replace:: :abbr:`LDAP (Lightweight Directory Access Protocol)`
.. |LDPC| replace:: :abbr:`LDPC (Low-Density Parity Check)` .. |LDPC| replace:: :abbr:`LDPC (Low-Density Parity Check)`
.. |LLDP| replace:: :abbr:`LLDP (Link Layer Discovery Protocol)` .. |LLDP| replace:: :abbr:`LLDP (Link Layer Discovery Protocol)`
.. |LSM| replace:: :abbr:`LSM (Linux Security Modules)`
.. |LVG| replace:: :abbr:`LVG (Local Volume Groups)` .. |LVG| replace:: :abbr:`LVG (Local Volume Groups)`
.. |MAC| replace:: :abbr:`MAC (Media Access Control)` .. |MAC| replace:: :abbr:`MAC (Media Access Control)`
.. |MEC| replace:: :abbr:`MEC (Multi-access Edge Computing)` .. |MEC| replace:: :abbr:`MEC (Multi-access Edge Computing)`
@ -142,6 +143,7 @@
.. |SMT| replace:: :abbr:`SMT (Simultaneous Multithreading)` .. |SMT| replace:: :abbr:`SMT (Simultaneous Multithreading)`
.. |SNAT| replace:: :abbr:`SNAT (Source Network Address Translation)` .. |SNAT| replace:: :abbr:`SNAT (Source Network Address Translation)`
.. |SNMP| replace:: :abbr:`SNMP (Simple Network Management Protocol)` .. |SNMP| replace:: :abbr:`SNMP (Simple Network Management Protocol)`
.. |SPO| replace:: :abbr:`SPO (Security Profile Operator)`
.. |SRIOV| replace:: :abbr:`SR-IOV (Single Root I/O Virtualization)` .. |SRIOV| replace:: :abbr:`SR-IOV (Single Root I/O Virtualization)`
.. |SRIOVs| replace:: :abbr:`SR-IOVs (Single Root I/O Virtualizations)` .. |SRIOVs| replace:: :abbr:`SR-IOVs (Single Root I/O Virtualizations)`
.. |SSD| replace:: :abbr:`SSD (Solid State Drive)` .. |SSD| replace:: :abbr:`SSD (Solid State Drive)`

View File

@ -53,6 +53,10 @@ This is an example of the output:
| a84328a0-3219-4b54-b4fa-5903f25f70ea | docker | quay-registry | auth-secret | c293a43d-0e4b-4dec-a5f4-baffb65e07f0 | None | None | | a84328a0-3219-4b54-b4fa-5903f25f70ea | docker | quay-registry | auth-secret | c293a43d-0e4b-4dec-a5f4-baffb65e07f0 | None | None |
| 96b6eb45-b101-4bcb-8168-3f9f79baaa7d | docker | quay-registry | type | docker | None | None | | 96b6eb45-b101-4bcb-8168-3f9f79baaa7d | docker | quay-registry | type | docker | None | None |
| 0fe2e1b9-8005-4ff8-98c2-ba0ad66103b9 | docker | quay-registry | url | old-registry.domain.com:5001/product-abc/starlingx/quay.io | None | None | | 0fe2e1b9-8005-4ff8-98c2-ba0ad66103b9 | docker | quay-registry | url | old-registry.domain.com:5001/product-abc/starlingx/quay.io | None | None |
| d88d2562-2a58-43fb-ab42-d5e63c6bf500 | docker | registryk8s-registry | type | docker | None | None |
| fa8c3e00-b1b0-469b-8d73-5362f8d99725 | docker | registryk8s-registry | url | old-registry.domain.com:5001/product-abc/starlingx/registry.k8s.io | None | None |
| f3449be4-b8d5-43fd-8493-ede6429f411f | docker | registryk8s-registry | auth-secret | a48cfbac-849e-42cb-b012-b0b4f23bf2b9 | None | None |
The new registry uses **username** and **password** authentication. Its path is The new registry uses **username** and **password** authentication. Its path is
the same as the existing registry path. For example if ``docker.io`` path is the same as the existing registry path. For example if ``docker.io`` path is

View File

@ -85,5 +85,18 @@ You will get the following output:
| resource | None | | resource | None |
+-------------+---------------------------------------------------------------------------+ +-------------+---------------------------------------------------------------------------+
+-------------+---------------------------------------------------------------------------+
| Property | Value |
+-------------+---------------------------------------------------------------------------+
| uuid | ea52a3cd-5aae-425a-967e-5a2bc19a1398 |
| service | docker |
| section | registryk8s-registry |
| name | url |
| value | new-registry.domain.com:9001/product-abc/starlingx/registry.k8s.io |
| personality | None |
| resource | None |
+-------------+---------------------------------------------------------------------------+
To validate the registry, see :ref:`Display Updated Registries' URLs and Auth-Secrets To validate the registry, see :ref:`Display Updated Registries' URLs and Auth-Secrets
<validate-existing-registry-and-new-url>`. <validate-existing-registry-and-new-url>`.

View File

@ -163,5 +163,33 @@ You will get the following output:
| resource | None | | resource | None |
+-------------+--------------------------------------+ +-------------+--------------------------------------+
+---------------+------------------------------------------------------------------------+
| Field | Value |
+---------------+------------------------------------------------------------------------+
| Secret href | http://controller:9311/v1/secrets/d88d2562-2a58-43fb-ab42-d5e63c6bf500 |
| Name | registryk8s-registry-secret |
| Created | None |
| Status | None |
| Content types | None |
| Algorithm | aes |
| Bit length | 256 |
| Secret type | opaque |
| Mode | cbc |
| Expiration | None |
+---------------+------------------------------------------------------------------------+
+-------------+--------------------------------------+
| Property | Value |
+-------------+--------------------------------------+
| uuid | fa8c3e00-b1b0-469b-8d73-5362f8d99725 |
| service | docker |
| section | registryk8s-registry |
| name | auth-secret |
| value | d88d2562-2a58-43fb-ab42-d5e63c6bf500 |
| personality | None |
| resource | None |
+-------------+--------------------------------------+
To update the registry secrets, go to :ref:`Update To update the registry secrets, go to :ref:`Update
the Registries' Auth-Secrets <update-the-registry-secrets>`. the Registries' Auth-Secrets <update-the-registry-secrets>`.

View File

@ -26,6 +26,8 @@ You will get the following output:
elastic-registry URL is new-registry.domain.com:9001/product-abc/starlingx/docker.elastic.co elastic-registry URL is new-registry.domain.com:9001/product-abc/starlingx/docker.elastic.co
gcr-registry URL is new-registry.domain.com:9001/product-abc/starlingx/gcr.io gcr-registry URL is new-registry.domain.com:9001/product-abc/starlingx/gcr.io
k8s-registry URL is new-registry.domain.com:9001/product-abc/starlingx/k8s.gcr.io k8s-registry URL is new-registry.domain.com:9001/product-abc/starlingx/k8s.gcr.io
registryk8s-registry URL is new-registry.domain.com:9001/product-abc/starlingx/registry.k8s.io
If the existing registries used authentication, use the following command to If the existing registries used authentication, use the following command to
display their auth-secrets: display their auth-secrets: