<?xml version="1.0" encoding="UTF-8" ?>

<bugzilla version="5.2"
          urlbase="https://bugzilla.altlinux.org/"
          
          maintainer="jenya@basealt.ru"
>

    <bug>
          <bug_id>48038</bug_id>
          
          <creation_ts>2023-10-17 10:36:51 +0300</creation_ts>
          <short_desc>Ошибка при сканировании kubernetes</short_desc>
          <delta_ts>2024-09-26 18:24:21 +0300</delta_ts>
          <reporter_accessible>1</reporter_accessible>
          <cclist_accessible>1</cclist_accessible>
          <classification_id>4</classification_id>
          <classification>Development</classification>
          <product>Sisyphus</product>
          <component>trivy</component>
          <version>unstable</version>
          <rep_platform>x86_64</rep_platform>
          <op_sys>Linux</op_sys>
          <bug_status>CLOSED</bug_status>
          <resolution>NOTABUG</resolution>
          
          
          <bug_file_loc></bug_file_loc>
          <status_whiteboard></status_whiteboard>
          <keywords></keywords>
          <priority>P5</priority>
          <bug_severity>normal</bug_severity>
          <target_milestone>---</target_milestone>
          
          
          <everconfirmed>1</everconfirmed>
          <reporter name="Alexander Makeenkov">amakeenk</reporter>
          <assigned_to name="Ivan">pepelyaevip</assigned_to>
          <cc>kaf</cc>
    
    <cc>pepelyaevip</cc>
    
    <cc>shaba</cc>
    
    <cc>varaksaaa</cc>
    
    <cc>zurabishvilinn</cc>
          
          <qa_contact>qa-sisyphus</qa_contact>

      

      

      

          <comment_sort_order>oldest_to_newest</comment_sort_order>  
          <long_desc isprivate="0" >
    <commentid>235047</commentid>
    <comment_count>0</comment_count>
    <who name="Alexander Makeenkov">amakeenk</who>
    <bug_when>2023-10-17 10:36:51 +0300</bug_when>
    <thetext>Версия пакета:
trivy-0.45.1-alt1.x86_64

Шаги воспроизведения:
1. Настроить kubernetes кластер по инструкции https://www.altlinux.org/Kubernetes
2. На первом хосте кластера установить пакет: # apt-get install trivy
3. Выполнить команду: $ trivy --debug kubernetes --report=summary cluster

Получаемый результат:
2023-10-17T10:27:23.069+0300    DEBUG   Severities: [&quot;UNKNOWN&quot; &quot;LOW&quot; &quot;MEDIUM&quot; &quot;HIGH&quot; &quot;CRITICAL&quot;]
2023-10-17T10:27:23.070+0300    DEBUG   Ignore statuses {&quot;statuses&quot;: null}
2023-10-17T10:32:23.089+0300    FATAL   get k8s artifacts with node info error:
    github.com/aquasecurity/trivy/pkg/k8s/commands.clusterRun
        /usr/src/RPM/BUILD/trivy-0.45.1/pkg/k8s/commands/cluster.go:34
  - running node-collector job: runner received timeout

Не воспроизводится в p10 на версии 0.45.0-alt2.

Доказательство работоспособности кластера:
$ kubectl get pods --namespace kube-system
NAME                                READY   STATUS    RESTARTS   AGE
coredns-787d4945fb-hxnj7            1/1     Running   1          38m
coredns-787d4945fb-wsmfm            1/1     Running   1          38m
etcd-kubehosta                      1/1     Running   1          38m
kube-apiserver-kubehosta            1/1     Running   1          38m
kube-controller-manager-kubehosta   1/1     Running   1          38m
kube-proxy-4tqqs                    1/1     Running   1          38m
kube-proxy-cgwdg                    1/1     Running   1          38m
kube-scheduler-kubehosta            1/1     Running   1          38m

$ kubectl get svc nginx
NAME    TYPE       CLUSTER-IP      EXTERNAL-IP   PORT(S)        AGE
nginx   NodePort   10.108.205.61   &lt;none&gt;        80:30546/TCP   39m

$ curl -s 192.168.0.14:30546 | grep title
&lt;title&gt;Welcome to nginx!&lt;/title&gt;</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>235283</commentid>
    <comment_count>1</comment_count>
    <who name="Ivan">pepelyaevip</who>
    <bug_when>2023-10-20 15:00:01 +0300</bug_when>
    <thetext>(In reply to Alexander Makeenkov from comment #0)
&gt; Версия пакета:
&gt; trivy-0.45.1-alt1.x86_64
&gt; 
&gt; Шаги воспроизведения:
&gt; 1. Настроить kubernetes кластер по инструкции
&gt; https://www.altlinux.org/Kubernetes
&gt; 2. На первом хосте кластера установить пакет: # apt-get install trivy
&gt; 3. Выполнить команду: $ trivy --debug kubernetes --report=summary cluster
&gt; 
&gt; Получаемый результат:
&gt; 2023-10-17T10:27:23.069+0300    DEBUG   Severities: [&quot;UNKNOWN&quot; &quot;LOW&quot;
&gt; &quot;MEDIUM&quot; &quot;HIGH&quot; &quot;CRITICAL&quot;]
&gt; 2023-10-17T10:27:23.070+0300    DEBUG   Ignore statuses {&quot;statuses&quot;: null}
&gt; 2023-10-17T10:32:23.089+0300    FATAL   get k8s artifacts with node info
&gt; error:
&gt;     github.com/aquasecurity/trivy/pkg/k8s/commands.clusterRun
&gt;         /usr/src/RPM/BUILD/trivy-0.45.1/pkg/k8s/commands/cluster.go:34
&gt;   - running node-collector job: runner received timeout
&gt; 
&gt; Не воспроизводится в p10 на версии 0.45.0-alt2.
&gt; 
&gt; Доказательство работоспособности кластера:
&gt; $ kubectl get pods --namespace kube-system
&gt; NAME                                READY   STATUS    RESTARTS   AGE
&gt; coredns-787d4945fb-hxnj7            1/1     Running   1          38m
&gt; coredns-787d4945fb-wsmfm            1/1     Running   1          38m
&gt; etcd-kubehosta                      1/1     Running   1          38m
&gt; kube-apiserver-kubehosta            1/1     Running   1          38m
&gt; kube-controller-manager-kubehosta   1/1     Running   1          38m
&gt; kube-proxy-4tqqs                    1/1     Running   1          38m
&gt; kube-proxy-cgwdg                    1/1     Running   1          38m
&gt; kube-scheduler-kubehosta            1/1     Running   1          38m
&gt; 
&gt; $ kubectl get svc nginx
&gt; NAME    TYPE       CLUSTER-IP      EXTERNAL-IP   PORT(S)        AGE
&gt; nginx   NodePort   10.108.205.61   &lt;none&gt;        80:30546/TCP   39m
&gt; 
&gt; $ curl -s 192.168.0.14:30546 | grep title
&gt; &lt;title&gt;Welcome to nginx!&lt;/title&gt;

node-collector не запускался из-за taint&apos;a

Лечится командой:
kubectl taint nodes &lt;нода&gt; node-role.kubernetes.io/control-plane:NoSchedule-

Источник:
https://kubernetes.io/docs/reference/labels-annotations-taints/#node-role-kubernetes-io-control-plane-taint</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>235286</commentid>
    <comment_count>2</comment_count>
    <who name="Alexander Makeenkov">amakeenk</who>
    <bug_when>2023-10-20 15:09:45 +0300</bug_when>
    <thetext>(Ответ для Ivan на комментарий #1)
&gt; Лечится командой:
&gt; kubectl taint nodes &lt;нода&gt; node-role.kubernetes.io/control-plane:NoSchedule-

Помогло, спасибо.</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>240028</commentid>
    <comment_count>3</comment_count>
    <who name="ALexey Kostarev">kaf</who>
    <bug_when>2024-01-10 14:42:05 +0300</bug_when>
    <thetext>При  разворачивании в отсутствии доступа в Интернет возникает проблема доступа к образу ghcr.io/aquasecurity/node-collector:0.0.9

В этом случае необходимо:
- получить этот образ на рабочем месте с доступом в Интернет
- заархивировать его (podman save)
- перенести в на рабочее место пользователя imagemaker и поместить в локальный регистратор

# podman tag ghcr.io/aquasecurity/node-collector:0.0.9 registry.local/aquasecurity/node-collector
# podman push registry.local/aquasecurity/node-collector

- при вызове `trivy kubernetes ...` указать имя этого образа в флаге --node-collector-imageref

trivy kubernetes --node-collector-imageref registry.local/aquasecurity/node-collector ...</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>240280</commentid>
    <comment_count>4</comment_count>
    <who name="ALexey Kostarev">kaf</who>
    <bug_when>2024-01-17 15:14:37 +0300</bug_when>
    <thetext>(Ответ для ALexey Kostarev на комментарий #3)
&gt; При  разворачивании в отсутствии доступа в Интернет возникает проблема
&gt; доступа к образу ghcr.io/aquasecurity/node-collector:0.0.9
&gt; 
&gt; В этом случае необходимо:
&gt; - получить этот образ на рабочем месте с доступом в Интернет
&gt; - заархивировать его (podman save)
&gt; - перенести в на рабочее место пользователя imagemaker и поместить в
&gt; локальный регистратор
&gt; 
&gt; # podman tag ghcr.io/aquasecurity/node-collector:0.0.9
&gt; registry.local/aquasecurity/node-collector
&gt; # podman push registry.local/aquasecurity/node-collector
&gt; 
&gt; - при вызове `trivy kubernetes ...` указать имя этого образа в флаге
&gt; --node-collector-imageref
&gt; 
&gt; trivy kubernetes --node-collector-imageref
&gt; registry.local/aquasecurity/node-collector ...

К сожалению этот подход имеет проблемы - хотя флаг node-collector-imageref присутствует в исходных кодах trivy он в настоящее время не поддерживается :-(

Поэтому порядок действия должен быть таким:

1. получить этот образ на рабочем месте с доступом в Интернет

# podman pull ghcr.io/aquasecurity/node-collector:0.0.9 

2. заархивировать его

# podman save ghcr.io/aquasecurity/node-collector:0.0.9 | xz -9v &gt; node.collector.tar.xz

3. перенести архив node.collector.tar.xz на рабочее место, где будет запускаться trivy ... kubernetes ...

Eсли на рабочем месте включены политики доступа в /etc/containers/policy.json, допускающие возможность запуска только подписанных образов из регистратора registry.local, то дальнейшие действия необходимо производить ТОЛЬКО ПОД ПОЛЬЗОВАТЕЛЕМ, ВХОДЯЩИМ В ГРУППУ podman_dev (класса создателей образов). 
В ином случае пользователь может быть любым, включая пользователя root

4. Разархивировать образ (podman load)

$ xz -d &lt; node.collector.tar.xz | podman load

5. Запускать команду

trivy ... kubernetes ...

от имени выбранного пользователя

Для защищенных платформ c10f? 
возможно стоит включить архив образа node.collector.tar.xz (12Mb) в состав ISO-образа и разворачивать образ при разворачивании kuber-решений</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>240754</commentid>
    <comment_count>5</comment_count>
    <who name="ALexey Kostarev">kaf</who>
    <bug_when>2024-01-28 17:49:53 +0300</bug_when>
    <thetext>В последней версии
trivy-0.48.3-alt2
у клиента trivy
есть возможность указания имени образа node-collector флагом:
 --node-collector-imageref=

Договорились создать следующие образы:
- registry.altlinux.org/alt/k8s-trivy-node-collector:sisyphus
- registry.altlinux.org/alt/k8s-trivy-node-collector:p10
- registry.altlinux.org/alt/k8s-trivy-node-collector:c10f1
- registry.altlinux.org/alt/k8s-trivy-node-collector:c10f2

В пакеты trivy соответствующих платформ в качестве образа по умолчанию 
вместо образа ghcr.io/aquasecurity/node-collector использоваь образы:
* sisyphus - registry.altlinux.org/alt/k8s-trivy-node-collector:sisyphus
* p10 - registry.altlinux.org/alt/k8s-trivy-node-collector:p10
* c10f1 - registry.local/alt/k8s-trivy-node-collector:c10f1
* c10f2 - registry.local/alt/k8s-trivy-node-collector:c10f2

Для дистрибутивов c10f1, c10f2 необходимо включить соответствующие образы в архив образов на ISO-диске и обеспечить их подпись помещение в локальный регистратор под именем:
- c10f1 - registry.local/alt/k8s-trivy-node-collector:c10f1 (алиас образа registry.altlinux.org/alt/k8s-trivy-node-collector:c10f1)
- c10f2 - registry.local/alt/k8s-trivy-node-collector:c10f2 (алиас образа registry.altlinux.org/alt/k8s-trivy-node-collector:c10f2)

Для этого необходимо в пакете podsec модифицировать команду формирования архив ISO-образов [podsec-k8s-save-oci](https://github.com/alt-cloud/podsec/blob/master/podsec-k8s/bin/podsec-k8s-save-oci)</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>240756</commentid>
    <comment_count>6</comment_count>
    <who name="ALexey Kostarev">kaf</who>
    <bug_when>2024-01-28 18:01:52 +0300</bug_when>
    <thetext>По задаче создания образов добавил задачу - https://bugzilla.altlinux.org/49211</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>240758</commentid>
    <comment_count>7</comment_count>
    <who name="ALexey Kostarev">kaf</who>
    <bug_when>2024-01-28 18:13:17 +0300</bug_when>
    <thetext>По задаче изменения образа по умолчания для пакета trivy добавлил задачу
https://bugzilla.altlinux.org/49212</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>240760</commentid>
    <comment_count>8</comment_count>
    <who name="ALexey Kostarev">kaf</who>
    <bug_when>2024-01-28 18:18:41 +0300</bug_when>
    <thetext>По задаче модификации команды podsec-k8s формирования архив ISO-образов добавил задачу 
https://bugzilla.altlinux.org/49213</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>240768</commentid>
    <comment_count>9</comment_count>
    <who name="Alexey Shabalin">shaba</who>
    <bug_when>2024-01-29 03:49:34 +0300</bug_when>
    <thetext>Не совсем понятно, зачем для разных бранчей делать разные образы. Если мы будем стараться держать одинаковую версию trivy во всех браняах. Это значит, что нужно в разные бранчи добавлять разные патчи. Или в спеке делать sed на изменение url. Может один образ сделать(например на базе p10) и все? Без привязки к бранчам.Тут тэги больше по версиям подходят, а не по нашим бранчам.</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>240773</commentid>
    <comment_count>10</comment_count>
    <who name="ALexey Kostarev">kaf</who>
    <bug_when>2024-01-29 09:03:10 +0300</bug_when>
    <thetext>(Ответ для Alexey Shabalin на комментарий #9)
&gt; Не совсем понятно, зачем для разных бранчей делать разные образы. Если мы
&gt; будем стараться держать одинаковую версию trivy во всех браняах. Это значит,
&gt; что нужно в разные бранчи добавлять разные патчи. Или в спеке делать sed на
&gt; изменение url. Может один образ сделать(например на базе p10) и все? Без
&gt; привязки к бранчам.Тут тэги больше по версиям подходят, а не по нашим
&gt; бранчам.

Тут как скажут постановщики задач. Мы же для разных платформ (p10, c10f1, ...) делаем разные образы на основе одного исходного кода</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>240774</commentid>
    <comment_count>11</comment_count>
    <who name="ALexey Kostarev">kaf</who>
    <bug_when>2024-01-29 09:10:59 +0300</bug_when>
    <thetext>(Ответ для Alexey Shabalin на комментарий #9)
&gt; Не совсем понятно, зачем для разных бранчей делать разные образы. Если мы
&gt; будем стараться держать одинаковую версию trivy во всех браняах. Это значит,
&gt; что нужно в разные бранчи добавлять разные патчи. Или в спеке делать sed на
&gt; изменение url. Может один образ сделать(например на базе p10) и все? Без
&gt; привязки к бранчам.Тут тэги больше по версиям подходят, а не по нашим
&gt; бранчам.

Но если требования замены в исходных кодах trivy образа по умолчанию ghcr.io/aquasecurity/node-collector на наш образ registry.altlinux.org/alt/k8s-trivy-node-collector является обязательным, то надо иметь в виду, что для команды trivy для платформ c10 надо указывать образ с регистратора
registry.local.
То есть для команды trivy для платформ p10 будет
registry.altlinux.org/alt/k8s-trivy-node-collector
То есть для команды trivy для платформ c10 будет
registry.local/alt/k8s-trivy-node-collector

Если снять это требование (и оставить в trivy имя образа registry.altlinux.org/alt/k8s-trivy-node-collector), то можно будет для платформ c10 использовать флаг --node-collector-imageref=registry.local/aquasecurity/node-collector:
trivy --debug kubernetes --node-collector-imageref=registry.local/aquasecurity/node-collector --report=summary cluster</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>252042</commentid>
    <comment_count>12</comment_count>
    <who name="Nikolai Zurabishvili">zurabishvilinn</who>
    <bug_when>2024-09-24 15:20:18 +0300</bug_when>
    <thetext>k8s-trivy-node-collector-0.3.1-alt1
trivy-0.55.0-alt1

Стенды (обновлены до сизифа):

Server 10.2 office x86-64

Ошибка воспроизводится по шагам из https://bugzilla.altlinux.org/show_bug.cgi?id=48038#c0 :

  - get k8s artifacts with node info error:
    github.com/aquasecurity/trivy/pkg/k8s/commands.clusterRun
        /usr/src/RPM/BUILD/trivy-0.55.0/pkg/k8s/commands/cluster.go:42
  - running node-collector job: runner received timeout

При добавлении --timeout :

  - get k8s artifacts with node info error:
    github.com/aquasecurity/trivy/pkg/k8s/commands.clusterRun
        /usr/src/RPM/BUILD/trivy-0.55.0/pkg/k8s/commands/cluster.go:42
  - running node-collector job: job failed: DeadlineExceeded: Job was active longer than specified deadline

Команда # kubectl taint nodes &lt;нода&gt; node-role.kubernetes.io/control-plane:NoSchedule- не помогает</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>252223</commentid>
    <comment_count>13</comment_count>
    <who name="Ivan">pepelyaevip</who>
    <bug_when>2024-09-26 18:24:21 +0300</bug_when>
    <thetext>В контейнере node-collector не хватало пакета procps
После пересборки с procps ошибок не было</thetext>
  </long_desc>
      
      

    </bug>

</bugzilla>