Обычная модель прав в Linux проста: есть владелец, группа и все остальные. Для большинства случаев этого хватает, но не всегда.
А что если нужно, чтобы user1 и user2 имели разные права к одному и тому же файлу? Или чтобы у определённого пользователя был доступ только к подкаталогу?
Тут на сцену выходит ACL — Access Control List.
ACL позволяет задавать права не только для владельца и группы, а для любого пользователя или группы. Это похоже на “дополнительный слой” поверх обычных разрешений.
Посмотрим на файл:
ls -l report.txt
-rw-r-----+ 1 marina staff 2048 Oct 22 11:20 report.txt
Плюсик
+ после прав (rw-r-----+) говорит, что у файла есть ACL.Подробнее:
getfacl report.txt
Результат может выглядеть так:
# file: report.txt
# owner: marina
# group: staff
user::rw-
user:john:r--
group::r--
mask::r--
other::---
Мы видим, что кроме владельца и группы, есть отдельная запись для пользователя john.
Выдать пользователю john права на чтение файла:
setfacl -m u:john:r file.txt
Выдать группе designers права на запись:
setfacl -m g:designers:rw file.txt
setfacl -x u:john file.txt
Сбросить все расширенные права (оставив только базовые chmod-права):
setfacl -b file.txt
🗂 Установка ACL по умолчанию для каталога
ACL можно "прикрепить" к каталогу, чтобы новые файлы наследовали права автоматически.
Пример: всем пользователям группы team разрешить читать и писать в каталог /srv/docs:
setfacl -d -m g:team:rw /srv/docs
Теперь любой файл, созданный внутри /srv/docs, получит те же права.
mask в выводе getfacl — это "ограничитель" максимальных разрешений ACL. Даже если пользователю выданы права rwx, но в качестве mask стоит rw-, то выполнение будет заблокировано.Маску можно менять отдельно:
setfacl -m m:rw file.txt
Пусть в /var/www/project лежит сайт, над которым работают два человека: admin и editor. Админ имеет полный доступ, а редактор — только чтение и запись контента:
chown -R admin:admin /var/www/project
setfacl -R -m u:editor:rw /var/www/project/content
setfacl -d -m u:editor:rw /var/www/project/content
Первая команда
setfacl назначает права доступа для уже существующих файлов и каталогов в /var/www/project/content. Вторая устанавливает шаблон прав, который унаследуют будущие файлы и папки, созданные в /var/www/project/content.Теперь editor сможет редактировать файлы в /content (в том числе и все созданные в дальнейшем), но не затронет код приложения.
Please open Telegram to view this post
VIEW IN TELEGRAM
Утилита
Так можно удалить все файлы, найденные предыдущей командой. Работает с
Конечно, если список можно выразить шаблоном, то проще всего передать шаблон команде
Это не требует промежуточных команд и работает мгновенно.
Но
Можно использовать и более сложные фильтры, включая регулярные выражения.
Если установлен
Вы получаете список файлов, выбираете нужные пробелом, и
#вопросы
xargs в Unix-подобных операционных системах считывает данные из стандартного ввода и использует их для построения и выполнения команд. С ее помощью можно, например, удалить список файлов, полученный от другой команды:ls *.log | xargs rm
Так можно удалить все файлы, найденные предыдущей командой. Работает с
find, grep и многими другими.Конечно, если список можно выразить шаблоном, то проще всего передать шаблон команде
rm:rm *.log
rm file{1..100}.txt
Это не требует промежуточных команд и работает мгновенно.
Но
xargs тоже может пригодиться. Например, можно удалить только те файлы, имена которых содержат определённое слово:ls | grep "temp" | xargs rm
Можно использовать и более сложные фильтры, включая регулярные выражения.
Если установлен
fzf, можно удалять файлы выборочно:ls | fzf -m | xargs -r rm
Вы получаете список файлов, выбираете нужные пробелом, и
xargs их удаляет. Очень удобно.#вопросы
❤3👍2
Выберите правильный вариант для поиска в указанных файлах (files) строк, где встречается BOB, Bob, BOb или BoB.
Anonymous Quiz
27%
grep –i Bob files
52%
grep 'B[oO][bB]' files
5%
grep '[BOB]' files
6%
grep -v 'Bob' files
11%
Посмотреть ответ
Это две команды, предназначенные для установки, удаления и обновления программного обеспечения на системе.
apt-get - это одна из первых команд, использовавшихся для управления пакетами в системах Debian и Ubuntu.apt-get является стандартной командой для управления пакетами в Debian и Ubuntu, что делает ее широко распространенной и надежной.apt-get выводит подробную информацию о процессе установки или удаления пакета, что позволяет пользователям следить за процессом.apt-get иногда может работать медленно из-за обновления индексов пакетов перед выполнением команды.apt-get требует ввода длинных команд, что может быть неудобно для новичков.apt - это более новая команда, предназначенная для упрощения управления пакетами в системах Debian и Ubuntu. Она является частью более современного инструмента APT (Advanced Package Tool), который объединяет несколько функций в одном интерфейсе.
apt предоставляет более простой и интуитивно понятный интерфейс для управления пакетами, что делает его более удобным в использовании.apt автоматически обновляет индексы пакетов перед выполнением команды, что уменьшает время ожидания пользователя.apt вывод может быть менее подробным по сравнению с apt-get, что затрудняет отслеживание процесса установки или удаления пакета.apt может иметь ограниченную поддержку сторонних репозиториев по сравнению с apt-get, хотя это не так часто встречается.Please open Telegram to view this post
VIEW IN TELEGRAM
🔥1
Ни для кого не секрет, что Linux - система, с которой можно работать от разных пользователей. Сегодня я запускаю сессию от Паши, завтра от Пети.
Когда вы в сессии открываете терминал, стартует оболочка, которая подстраивает окружение под конкретного юзера: выполняет скрипты, определяет переменные.
Бывает, приходится, работая в сессии одного пользователя, переключиться на другого, например, чтобы использовать ресурсы, ограниченные правами доступа. Для этого мы используем команду
su (substitute user), которая позволяет сменить пользователя в текущей оболочке:$ su vasya
После выполнения команды создастся дочерняя оболочка, которая переймет все переменные окружения родителя, определит пользовательские (USER, HOME ...) и выполнит локальные "Васины" скрипты: /home/vasya/.bashrc и т.д.:
$ export USER1VAR="vasya"
$ su xoadmin
$ printenv | grep USER
USER=xoadmin
USER1VAR=vasya
Какая-то каша выходит. Половина Васиных переменных, половина юзера xoadmin. Такой способ полезен, когда нам нужно быстро поменять пользователя и не требуется его окружение в изначальном виде.
Если нужно полностью воссоздать среду, как при чистом входе в систему, следует использовать
su -: $ su - xoadmin
Окружение родителя мы не наследуем и запускаем оболочку типа "login shell", которая выполнит дополнительные скрипты инициализации "/etc/profile", "~/.bash_profile".
Также, когда мы используем
su -, наш рабочий каталог переключается на домашний для целевого пользователя. Мелочь, но факт: $ pwd
/home/vasya/Music
$ su - xoadmin
$ pwd
/home/xoadmin
Please open Telegram to view this post
VIEW IN TELEGRAM
👍7
Please open Telegram to view this post
VIEW IN TELEGRAM
Комбинация
#вопросы
find, du и sort позволит найти 10 самых "тяжёлых" файлов с путями и размерами.find . -type f -exec du -h {} + | sort -rh | head -n 10#вопросы
👍5🔥1🎉1
Какая команда используется для копирования файлов и директорий?
Anonymous Quiz
4%
copy
1%
cpy
90%
cp
3%
rn
2%
Посмотреть ответ
gzip — это стандартная утилита в Linux для сжатия и распаковки файлов. Она уменьшает размер файлов, экономит место и ускоряет передачу данных по сети. Поддерживает разные уровни сжатия (от -1 — быстро до -9 — максимально).gzip применяется для уменьшения размеров логов и бэкапов, упаковки результатов сборки, сжатия данных перед передачей по сети, автоматических задач (cron, CI/CD).В этом посте мы рассмотрим несколько сценариев использования
gzip.gzip -9 имя_файла
Это удобно для критических случаев, где важнее уменьшить размер файла, чем скорость обработки.
gzip может сжимать данные не только из файлов, но и через стандартный ввод. Например, можно сжать вывод другой команды:mysqldump имя_базы_данных | gzip > backup.sql.gz
Эта команда создаст резервную копию базы данных, одновременно сжимая её, что особенно полезно для экономии места при больших базах.
pigz имя_файла
pigz поддерживает все те же параметры, что и gzip, но работает быстрее на многоядерных системах.gzip -l имя_файла.gz
Вывод покажет размер до и после сжатия, степень сжатия и имя исходного файла. Для более детализированного отчета добавьте параметр
-v:gzip -lv имя_файла.gz
Это полезно для оценки эффективности сжатия файлов перед их распаковкой.
-r:gzip -r имя_каталога
Эта команда пройдется по всей структуре каталога и сожмет каждый файл.
Чтобы распаковать все файлы в каталоге рекурсивно, используйте:
gzip -dr имя_каталога
gzip используется вместе с командой tar. Например:tar -czf архив.tar.gz имя_каталога
Здесь
-c создает архив, -z указывает на использование сжатия через gzip, а -f определяет имя файла архива. Для распаковки архива:
tar -xzf архив.tar.gz
Сжать лог-файлы перед отправкой по сети:
cat /var/log/syslog | gzip -9 | nc -w 3 192.168.1.10 8888
Эта команда сжимает лог и отправляет его по сети с помощью netcat.
Please open Telegram to view this post
VIEW IN TELEGRAM
❤3
Большинство из нас, работающих с системами на базе Debian, регулярно используют команду
apt-get для установки и обновления пакетов. Но как часто мы задумываемся об очистке системы? Давайте рассмотрим три полезные команды для очистки ненужных файлов:
apt-get clean, apt-get autoclean и apt-get autoremove.Команда
apt-get clean очищает локальный репозиторий от извлеченных файлов пакетов, находящихся в каталоге /var/cache/apt/archives/. Она удаляет все файлы пакетов, кроме файлов блокировки и пустых подкаталогов. Эта команда полезна для освобождения дискового пространства, особенно если вы часто устанавливаете и удаляете пакеты.
Например, до выполнения команды
apt-get clean в каталоге /var/cache/apt/archives/ могут находиться следующие файлы:/var/cache/apt/archives/db6.1-util_6.1.27+dfsg1-0.7ubuntu2_amd64.deb
/var/cache/apt/archives/db-util_2%3a6.121~exp1ubuntu1_all.deb
/var/cache/apt/archives/lock
/var/cache/apt/archives/postfix_3.4.6-2ubuntu2_amd64.deb
/var/cache/apt/archives/sasl2-bin_2.2.25+dfsg-1build2_amd64.deb
После выполнения команды sudo apt-get clean этот каталог будет очищен, и оставлены будут только файлы блокировки и пустые подкаталоги.
Команда
apt-get autoclean похожа на clean, но она удаляет только те пакеты, которые больше не могут быть загружены из репозиториев и, следовательно, больше не нужны. Это предотвращает переполнение кэша устаревшими файлами.Выполнение следующей команды очистит кэш от бесполезных пакетов, оставляя только актуальные и доступные для загрузки файлы:
sudo apt-get autoclean
Команда
apt-get autoremove удаляет пакеты, которые были установлены автоматически как зависимости для других пакетов, но теперь больше не требуются. Использование этой команды после удаления пакетов помогает поддерживать чистоту системы и предотвращает накопление ненужных файлов.
Пример использования:
sudo apt-get autoremove
После выполнения команды вы увидите список пакетов, которые больше не нужны, например:
The following packages were automatically installed and are no longer required:
g++-8 gir1.2-mutter-4 libapache2-mod-php7.2 libcrystalhd3
libdouble-conversion1 libgnome-desktop-3-17 libigdgmm5 libllvm8
liblouisutdml8 libmutter-4-0 libmysqlclient20 libpoppler85 linsydc++-8-dev
libtagc0 libvpx5 libx265-165 php7.2 php7.2-cli php7.2-common php7.2-json
php7.2-opcache php7.2-readline
Use 'sudo apt-get autoremove' to remove them.
Please open Telegram to view this post
VIEW IN TELEGRAM
🔥6👍4❤1🎉1
Please open Telegram to view this post
VIEW IN TELEGRAM
Для вывода определенных столбцов текстовых файлов удобно пользоваться командой
Эта команда покажет второй и пятый столбцы. Отлично подходит для логов и CSV без кавычек.
#вопросы
awk:awk '{print $2, $5}' data.txtЭта команда покажет второй и пятый столбцы. Отлично подходит для логов и CSV без кавычек.
#вопросы
💋4🔥2❤1🥰1
Команда
scp используется для безопасного копирования файлов между локальным компьютером и удаленным сервером, а также между двумя удаленными серверами, используя протокол SSH. Она позволяет передавать файлы и каталоги по зашифрованному каналу, что гарантирует конфиденциальность данных.scp [опции] <источник> <назначение>
scp file.txt user@remote_host:/path/to/destination
scp user@remote_host:/path/to/file.txt ./
scp -r папка user@remote_host:/path/to/destination
-r — ключ для копирования директорииЕсли вдруг используется нестандартный порт, мы можем его передать установив флаг
-P:scp -P 2222 file.txt user@remote_host:/path/to/destination
-C.Please open Telegram to view this post
VIEW IN TELEGRAM
👍4❤1🔥1
В обычном состоянии, если приложение запущено и пишет в лог файл, его не рекомендуется удалять, поскольку в *nix, открытый файловый дескриптор связан не с именем файла, а с iNode.
И если мы удалим лог-файл, приложение может не начать писать в новый файл с нуля, а продолжать писать в старый, который для нас уже будет недоступен по имени (мы же его удалили). Затем, когда приложение остановится и закроет дескриптор, данные удалятся с файловой системы.
(Большинство программ при записи в лог каждый раз открывают и закрывают файл, и тогда этой проблеме они не подвержены).
Поэтому очистку файла следует делать либо так (очистим файл, не удаляя его):
> application.log
Либо так (файл будет урезан до указанного размера):
truncate --size=1M application.log
Но эта команда именно урежет, т.е. в файле останутся старые данные, а свежие как раз и будут урезаны.
Поэтому можно делать вот так, сохраняя последние 1000 строк:
echo "$(tail -n 1000 application.log)" > application.log
Please open Telegram to view this post
VIEW IN TELEGRAM
👍5🔥1
Многие знают про:
~ для домашнего каталога,cd - — переключение между текущей и предыдущей папками:$ cd -
/home/xoadmin/Documents
$ cd -
/home/xoadmin/Music
Но если вы часто работаете с одними и теми же каталогами, вводить длинные пути быстро надоедает.
Допустим, вы часто заходите в каталог
/home/smith/Family/Memories/Photos
Чтобы попасть туда, каждый раз приходится писать:
cd ~/Family/Memories/Photos
А хотелось бы просто:
cd Photos
Однако, если в текущей папке нет подкаталога Photos, Bash выдаст:
bash: cd: Photos: No such file or directory
Переменная CDPATH говорит Bash, где ещё искать каталоги при выполнении
cd.CDPATH=$HOME/Family/Memories
Теперь, где бы вы ни находились:
$ pwd
/etc
$ cd Photos
/home/smith/Family/Memories/Photos
Работает!
Можно указать сразу несколько мест (через двоеточие):
CDPATH=$HOME:$HOME/Projects:$HOME/Family/Memories:/usr/local
Bash будет проверять их по порядку. Первое совпадение — и переход произойдёт именно туда.
Чтобы не прописывать CDPATH вручную при каждом запуске терминала, добавьте строку в ~/.bashrc (для конкретного пользователя) или /etc/profile (для всех пользователей системы).
export CDPATH=$HOME:$HOME/Sources:/usr/local
Пусть у вас есть каталог ~/Sources, где хранятся проекты:
echo $CDPATH
/home/xoadmin/Sources
Теперь:
$ pwd
/home/xoadmin/Music
$ cd picom
/home/xoadmin/Sources/picom
Без лишнего ввода — просто
cd picom.Если каталог найден через CDPATH,
cd выведет полный путь:$ cd Photos
/home/smith/Family/Memories/Photos
Это нормально — просто признак, что каталог был найден не в текущей директории.
Текущее место (
.) можно тоже включить в CDPATH, чтобы cd вела себя стандартно:export CDPATH=.:$HOME/Projects
CDPATH — это как "умный поиск" для
cd. Если вы часто прыгаете между проектами, архивами или каталогами с данными, он экономит десятки нажатий и делает навигацию в консоли почти мгновенной.Please open Telegram to view this post
VIEW IN TELEGRAM
👍10🔥3❤2