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

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

    <bug>
          <bug_id>40041</bug_id>
          
          <creation_ts>2021-05-12 15:51:29 +0300</creation_ts>
          <short_desc>lxc-attach leaks $TMP and $TMPDIR</short_desc>
          <delta_ts>2021-06-03 12:02:49 +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>lxc-templates</component>
          <version>unstable</version>
          <rep_platform>x86_64</rep_platform>
          <op_sys>Linux</op_sys>
          <bug_status>REOPENED</bug_status>
          <resolution></resolution>
          
          <see_also>https://bugzilla.altlinux.org/show_bug.cgi?id=16024</see_also>
          <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="Сергей Бессонов">s</reporter>
          <assigned_to name="Alexey Shabalin">shaba</assigned_to>
          <cc>dans</cc>
    
    <cc>ldv</cc>
    
    <cc>mike</cc>
    
    <cc>shaba</cc>
    
    <cc>sin</cc>
          
          <qa_contact>qa-sisyphus</qa_contact>

      

      

      

          <comment_sort_order>oldest_to_newest</comment_sort_order>  
          <long_desc isprivate="0" >
    <commentid>198404</commentid>
    <comment_count>0</comment_count>
    <who name="Сергей Бессонов">s</who>
    <bug_when>2021-05-12 15:51:29 +0300</bug_when>
    <thetext>При установке alt внутри контейнера LXC директории /tmp/.private/root не существует, соответственно, все утилиты, предполагающие наличие каталога временных файлов, перестают работать.

Возможно, это связано с тем, что root попадает в контейнер не через ssh, а через lxc-attach.

---

Distribution: 
alt
Release: 
p9
Architecture: 
amd64

Downloading the image index
Downloading the rootfs
Downloading the metadata
The image cache is now ready
Unpacking the rootfs

---
You just created an Altlinux p9 x86_64 (20210512_01:17) container.
host-15 ~ # lxc-start -n 1
host-15 ~ # lxc-ls -f
NAME STATE   AUTOSTART GROUPS IPV4         IPV6 UNPRIVILEGED 
1    RUNNING 0         -      10.101.101.4 -    false        
host-15 ~ # lxc-attach -n 1
[root@1 ~]# echo $TMP
/tmp/.private/root
[root@1 ~]# ls $TMP
ls: невозможно получить доступ к &apos;/tmp/.private/root&apos;: Нет такого файла или каталога
[root@1 ~]#</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>198405</commentid>
    <comment_count>1</comment_count>
    <who name="Michael Shigorin">mike</who>
    <bug_when>2021-05-12 16:12:19 +0300</bug_when>
    <thetext>Возможно ещё, разъехались состояния по pam_mktemp -- попробуй в контейнере
control pam_mktemp disabled</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>198406</commentid>
    <comment_count>2</comment_count>
    <who name="Vladimir D. Seleznev">vseleznv</who>
    <bug_when>2021-05-12 17:43:45 +0300</bug_when>
    <thetext>(In reply to Aceler from comment #0)
&gt; При установке alt внутри контейнера LXC директории /tmp/.private/root не
&gt; существует, соответственно, все утилиты, предполагающие наличие каталога
&gt; временных файлов, перестают работать.
&gt; 
&gt; Возможно, это связано с тем, что root попадает в контейнер не через ssh, а
&gt; через lxc-attach.

Да, если заходить через lxc-attach, то pam не отрабатывает. Могу предложить выполнять lxc-attach -n $CONT su, а лучше не использовать lxc-attach (использование вхождения в неймспейсы является одним из векторов атаки для побега злонамеренных процессов из контейнеров), а использовать ssh.

Такое поведение by design, поэтому закрываю как NOTABUG. Можете открыть повторно, если возникнет предложение как можно исправить эту проблему.</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>198407</commentid>
    <comment_count>3</comment_count>
    <who name="Сергей Бессонов">s</who>
    <bug_when>2021-05-12 18:05:38 +0300</bug_when>
    <thetext>В образе есть сервис systemd-tmpfiles-setup.service, который как раз предназначен для таких штук. 

Можно создать конфиг вида:
$ cat /etc/tmpfiles.d/root
D /tmp/.private/root 1700 root root - -</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>198408</commentid>
    <comment_count>4</comment_count>
    <who name="Vladimir D. Seleznev">vseleznv</who>
    <bug_when>2021-05-12 18:15:25 +0300</bug_when>
    <thetext>(In reply to Aceler from comment #3)
&gt; В образе есть сервис systemd-tmpfiles-setup.service, который как раз
&gt; предназначен для таких штук. 
&gt; 
&gt; Можно создать конфиг вида:
&gt; $ cat /etc/tmpfiles.d/root
&gt; D /tmp/.private/root 1700 root root - -

Это будет тогда работать только для рута, но не для остальных пользователей. И это не исключает того, что всё остальное, что должен был сделать pam, сделано не будет. В любом случае, если так и делать, что уже не в пакете lxc.</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>198429</commentid>
    <comment_count>5</comment_count>
    <who name="Dmitry V. Levin">ldv</who>
    <bug_when>2021-05-13 12:04:24 +0300</bug_when>
    <thetext>(In reply to Aceler from comment #0)
[...]
&gt; host-15 ~ # lxc-attach -n 1
&gt; [root@1 ~]# echo $TMP
&gt; /tmp/.private/root
&gt; [root@1 ~]# ls $TMP
&gt; ls: невозможно получить доступ к &apos;/tmp/.private/root&apos;: Нет такого файла или
&gt; каталога

У меня вопрос, откуда взялось значение переменной $TMP (и $TMPDIR, что более важно)? Утекло из parent process через lxc-attach?
&gt; [root@1 ~]#</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>198433</commentid>
    <comment_count>6</comment_count>
    <who name="Сергей Бессонов">s</who>
    <bug_when>2021-05-13 12:14:31 +0300</bug_when>
    <thetext>Да.

host-15 ~ # echo $TMP
/tmp/.private/root
host-15 ~ # TMP=/tmp
host-15 ~ # lxc-start -n 1 
host-15 ~ # lxc-attach -n 1
[root@1 ~]# echo $TMP
/tmp
[root@1 ~]#</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>198435</commentid>
    <comment_count>7</comment_count>
    <who name="Dmitry V. Levin">ldv</who>
    <bug_when>2021-05-13 12:24:28 +0300</bug_when>
    <thetext>$ rpmquery --changelog coreutils
...
* Sat Aug 30 2008 Dmitry V. Levin &lt;ldv@altlinux&gt; 6.12-alt1
...
- chroot: Purge TMP and TMPDIR variables from environment (closes: #16024).

Предлагаю пропатчить lxc-attach аналогичным образом.</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>198436</commentid>
    <comment_count>8</comment_count>
    <who name="Сергей Бессонов">s</who>
    <bug_when>2021-05-13 12:32:03 +0300</bug_when>
    <thetext>Возможно, это сломает поведение lxc-attach, потому что для очистки переменных там есть отдельный ключик --clear-env</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>198437</commentid>
    <comment_count>9</comment_count>
    <who name="Michael Shigorin">mike</who>
    <bug_when>2021-05-13 13:09:49 +0300</bug_when>
    <thetext>(Ответ для Aceler на комментарий #8)
&gt; Возможно, это сломает поведение lxc-attach
Куда дальше наблюдаемого-то?

&gt; потому что для очистки переменных там есть отдельный ключик --clear-env
А тут про две конкретные переменные разговор.</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>198448</commentid>
    <comment_count>10</comment_count>
    <who name="Сергей Бессонов">s</who>
    <bug_when>2021-05-13 15:56:30 +0300</bug_when>
    <thetext>(Ответ для Michael Shigorin на комментарий #9)

В теории, какой-нибудь juju может использовать lxc-attach, чтобы рулить контейнерами. И наверняка ожидает, что все переменные передаются в контейнер.

Удаление пары переменных при сохранении остальных может что-то сломать. И чинить потом будет очень сложно.

Да и в принципе, неконсистентненько.</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>198459</commentid>
    <comment_count>11</comment_count>
    <who name="Michael Shigorin">mike</who>
    <bug_when>2021-05-13 20:04:15 +0300</bug_when>
    <thetext>Ты не понял; подумай получше конкретно над своей же багой и тем, что именно это за переменные, кто и как их выставляет и что требуется для их работы.</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>198885</commentid>
    <comment_count>12</comment_count>
    <who name="Vladimir D. Seleznev">vseleznv</who>
    <bug_when>2021-06-03 12:02:49 +0300</bug_when>
    <thetext>(In reply to Aceler from comment #8)
&gt; Возможно, это сломает поведение lxc-attach, потому что для очистки
&gt; переменных там есть отдельный ключик --clear-env

(In reply to Aceler from comment #10)
&gt; (Ответ для Michael Shigorin на комментарий #9)
&gt; 
&gt; В теории, какой-нибудь juju может использовать lxc-attach, чтобы рулить
&gt; контейнерами. И наверняка ожидает, что все переменные передаются в контейнер.
&gt; 
&gt; Удаление пары переменных при сохранении остальных может что-то сломать. И
&gt; чинить потом будет очень сложно.
&gt; 
&gt; Да и в принципе, неконсистентненько.

Апстрим предупреждал, что нужно быть готовым к поломке поведения в переменных окружения. Я на самом деле хочу поменять поведение по-умолчанию на clear env. Для прошлого поведения будет доступен ключит --keep-env. Вопрос: насколько сложно научить тот же juju использовать этот ключик?</thetext>
  </long_desc>
      
      

    </bug>

</bugzilla>