Ключевые моменты о привилегированных портах
1. Диапазон привилегированных портов — от 0 до 1023. Эти номера хорошо известны и стандартизированы.
2. Концепция привилегированных портов восходит к зарождению Unix, когда определенные порты были зарезервированы для таких известных сервисов, как HTTP (порт 80), FTP (порт 21), Telnet (порт 23) и т. д.
3. Привилегированные порты доступны только корневым процессам, чтобы предотвратить получение непривилегированными пользователями или вредоносным программным обеспечением контроля над критически важными сетевыми службами.
4. Вместо запуска целых служб от имени пользователя root современные методы системного администрирования рекомендуют использовать такие инструменты, как sudo. Кроме того, многие сетевые демоны внедрили методы «разделения привилегий», чтобы минимизировать риск уязвимостей.
5. Некоторые современные подходы, такие как использование обратных прокси-серверов или балансировщиков нагрузки, могут позволить непривилегированным процессам перенаправлять трафик с порта с большим номером на привилегированный.
6. Попытка привязать процесс без полномочий root к привилегированному порту приведет к ошибке «Отказано в доступе», что защищает безопасность системы.
1. Диапазон привилегированных портов — от 0 до 1023. Эти номера хорошо известны и стандартизированы.
2. Концепция привилегированных портов восходит к зарождению Unix, когда определенные порты были зарезервированы для таких известных сервисов, как HTTP (порт 80), FTP (порт 21), Telnet (порт 23) и т. д.
3. Привилегированные порты доступны только корневым процессам, чтобы предотвратить получение непривилегированными пользователями или вредоносным программным обеспечением контроля над критически важными сетевыми службами.
4. Вместо запуска целых служб от имени пользователя root современные методы системного администрирования рекомендуют использовать такие инструменты, как sudo. Кроме того, многие сетевые демоны внедрили методы «разделения привилегий», чтобы минимизировать риск уязвимостей.
5. Некоторые современные подходы, такие как использование обратных прокси-серверов или балансировщиков нагрузки, могут позволить непривилегированным процессам перенаправлять трафик с порта с большим номером на привилегированный.
6. Попытка привязать процесс без полномочий root к привилегированному порту приведет к ошибке «Отказано в доступе», что защищает безопасность системы.
Поиск файлов по владельцу
Команда
Найти файлы, принадлежащие пользователю Josh:
Найти файлы, принадлежащие текущему вошедшему пользователю:
Найти файлы, принадлежащие группе developers:
Найти файлы, принадлежащие пользователю с UID 1001:
Команда
find в сочетании с флагом -user помогает искать файлы по имени владельцаНайти файлы, принадлежащие пользователю Josh:
find /path/to/search -type f -user JoshНайти файлы, принадлежащие текущему вошедшему пользователю:
find /path/to/search -type f -user $USERНайти файлы, принадлежащие группе developers:
find /path/to/search -type f -group developersНайти файлы, принадлежащие пользователю с UID 1001:
find /path/to/search -type f -uid 1001Исключение папки из поиска с помощью команды find
Один из подходов к исключению папки из поиска предполагает использование комбинации флагов -path, -prune и логического ИЛИ:
Важно, что путь должен оканчиваться на *, затем идёт -prune и только потом -o.
Один из подходов к исключению папки из поиска предполагает использование комбинации флагов -path, -prune и логического ИЛИ:
find . -path «./path/to/folder/*» -prune -o -name SEARCH_NAMEВажно, что путь должен оканчиваться на *, затем идёт -prune и только потом -o.
Время доступа (atime)
Atime обновляется каждый раз, когда файл открывается, читается или копируется. Даже простой просмотр содержимого файла обновляет его время.
Например, с помощью atime можно вывести список всех файлов, к которым не было доступа в течение как минимум 7 дней:
Также можете использовать -atime -7 для поиска файлов, к которым обращались в течение последних 7 дней.
Atime — временная метка файлов, которая указывает, когда в последний раз к содержимому файла обращался (читал) какой-либо процесс. Atime обновляется каждый раз, когда файл открывается, читается или копируется. Даже простой просмотр содержимого файла обновляет его время.
Например, с помощью atime можно вывести список всех файлов, к которым не было доступа в течение как минимум 7 дней:
find /path/to/search -type f -atime +7Также можете использовать -atime -7 для поиска файлов, к которым обращались в течение последних 7 дней.
Время модификации (mtime)
Mtime обновляется при изменении содержимого файла, например, во время редактирования, перезаписи или добавления.
Например, с помощью mtime можно найти все файлы, претерпевшие изменения за последние 3 дня:
Mtime — временная метка файлов, которая представляет собой последний раз, когда содержимое файла было изменено или записано.Mtime обновляется при изменении содержимого файла, например, во время редактирования, перезаписи или добавления.
Например, с помощью mtime можно найти все файлы, претерпевшие изменения за последние 3 дня:
find /path/to/search -type f -mtime -3Время изменения (ctime)
Метаданные: права доступа к файлам, право собственности и временные метки.
Изменения ctime происходят при изменении атрибутов файла, например при изменении разрешений или переименовании файла. Важно отметить, что на время ctime влияют не только действия пользователя, но и системные действия, такие как резервное копирование.
Например, с помощью ctime можно найти все файлы, созданные 5 и более дней назад:
Ctime — временная метка файла, представляющая собой последний раз, когда метаданные файла были изменены. Метаданные: права доступа к файлам, право собственности и временные метки.
Изменения ctime происходят при изменении атрибутов файла, например при изменении разрешений или переименовании файла. Важно отметить, что на время ctime влияют не только действия пользователя, но и системные действия, такие как резервное копирование.
Например, с помощью ctime можно найти все файлы, созданные 5 и более дней назад:
find /path/to/search -type f -ctime +5Управление выполнения команд с помощью anacron
1. Создание anacron job
Anacron jobs определяются в файле /etc/anacrontab. Для каждого задания указывается период (в днях), по истечении которого задание должно быть выполнено.
Пример базовой записи:
Чтобы вручную запустить anacron и выполнить запланированные задачи, используйте следующую команду:
Вы можете проверить, когда anacron job выполнялось в последний раз, проверив временную метку в соответствующем файле временных меток. Эти файлы обычно хранятся в
anacron — это утилита в Linux, которая помогает выполнять запланированные задачи, даже если ваша система не всегда включена. 1. Создание anacron job
Anacron jobs определяются в файле /etc/anacrontab. Для каждого задания указывается период (в днях), по истечении которого задание должно быть выполнено.
Пример базовой записи:
# /etc/anacrontab
# syntax: period delay job-identifier command
7 1 anacron_daily /bin/sh /path/to/your/noscript.sh
2. Запуск Чтобы вручную запустить anacron и выполнить запланированные задачи, используйте следующую команду:
anacron -s
3. Проверка последнего выполненияВы можете проверить, когда anacron job выполнялось в последний раз, проверив временную метку в соответствующем файле временных меток. Эти файлы обычно хранятся в
/var/spool/anacron/ и имеют те же имена, что и идентификаторы заданий в файле anacrontab.Синхронизация и передача файлов и каталогов с помощью rsync
Примеры использования:
Скопировать файл из одного каталога в другой локально:
Скопировать весь каталог и его содержимое в другую папку:
Скопировать файлы или каталоги на удаленный сервер с помощью SSH:
rsync — инструмент командной строки, который обычно используется в целях резервного копирования.Примеры использования:
Скопировать файл из одного каталога в другой локально:
rsync /path/to/source/file /path/to/destination/Скопировать весь каталог и его содержимое в другую папку:
rsync -av /path/to/source/directory/ /path/to/destination/
Скопировать файлы или каталоги на удаленный сервер с помощью SSH:
rsync -av /path/to/local/source user@remote:/path/to/remote/destinationИзменение или преобразование изображений
Команда
изменить размер изображений до определенной ширины и высоты:
повернуть изображения на указанный угол (по часовой стрелке):
преобразовать изображения в чб:
добавить текст к изображениям с указанным шрифтом, размером и цветом:
Команда
mogrify предназначена для модификации изображений. Будьте осторожны при использовании, так как команда может перезаписать исходные изображения.изменить размер изображений до определенной ширины и высоты:
mogrify -resize 800x600 image1.jpg image2.png
повернуть изображения на указанный угол (по часовой стрелке):
mogrify -rotate 90 image1.jpg image2.png
преобразовать изображения в чб:
mogrify -type Grayscale image1.jpg image2.pngдобавить текст к изображениям с указанным шрифтом, размером и цветом:
mogrify -pointsize 24 -draw "text 100,100 'Hello, World!'" image1.jpg image2.pngНаложения одного изображения на другое в терминале
Команда
Чтобы наложить изображение на другое:
overlay.png — изображение, которое вы хотите наложить.
base.jpg — изображение, на которое вы хотите наложить другое изображение.
output.jpg — выходное изображение.
Также можно наложить изображение с прозрачностью:
Команда
composite используется для объединения двух или более изображений путем наложения одного изображения на другое.Чтобы наложить изображение на другое:
composite overlay.png base.jpg output.jpg
overlay.png — изображение, которое вы хотите наложить.
base.jpg — изображение, на которое вы хотите наложить другое изображение.
output.jpg — выходное изображение.
Также можно наложить изображение с прозрачностью:
composite -blend 50% overlay.png base.jpg output.jpgСоздание коллажей в терминале
Команда
Создать базовую мозаичную компоновку изображений:
Можно также добавить границы вокруг каждого изображения:
Команда
montage используется для создания составного изображения путем расположения нескольких изображений в виде сетки или мозаики.Создать базовую мозаичную компоновку изображений:
montage image1.jpg image2.png image3.jpg -mode concatenate -tile 2x2 output.jpg
Можно также добавить границы вокруг каждого изображения:
montage image1.jpg image2.png -mode concatenate -tile 2x1 -border 10 output.jpgСоздание анимации и гивок
Команда
Отобразить последовательность изображений в виде анимации:
Контроль задержки (в миллисекундах) между кадрами:
Зациклить анимацию определенное количество раз (используйте 0 для бесконечного цикла):
Команда
animate — универсальный инструмент для создания простых анимаций, анимированных GIF-файлов и многого другого.Отобразить последовательность изображений в виде анимации:
animate frame1.jpg frame2.png frame3.jpg
Контроль задержки (в миллисекундах) между кадрами:
animate -delay 100 frame1.jpg frame2.png frame3.jpg
Зациклить анимацию определенное количество раз (используйте 0 для бесконечного цикла):
animate -loop 3 frame1.jpg frame2.png frame3.jpgСравнение двух изображений
Команда
Сравнить два изображения и создать разностное изображение:
Команда
compare используется для сравнения двух изображений для обнаружения различий между изображениями, который может быть полезен для контроля качества, тестирования и анализа изображений.Сравнить два изображения и создать разностное изображение:
compare image1.jpg image2.png difference.pngНастройка Git и GitHub на линукс
Шаг 1: Убедитесь, что у вас установлен Git на вашем Linux-устройстве. Если нет, выполните следующую команду:
Шаг 2: Когда Git установлен, следующим шагом является настройка вашего имени пользователя и адреса электронной почты. Выполните следующие команды, заменив "
Шаг 3: Прежде чем мы начнем использовать Git, нам нужно создать новый репозиторий на GitHub. Зайдите на сайт GitHub, войдите в свою учетную запись и нажмите кнопку "New repository".
Шаг 4: Теперь, когда есть репозиторий на GitHub, свяжем его с нашим локальным Git-репозиторием. Перейдите в каталог вашего проекта и выполните следующие команды:
Здесь "username" - ваше имя пользователя на GitHub, а "repository" - название вашего репозитория.
Шаг 1: Убедитесь, что у вас установлен Git на вашем Linux-устройстве. Если нет, выполните следующую команду:
sudo apt-get install gitШаг 2: Когда Git установлен, следующим шагом является настройка вашего имени пользователя и адреса электронной почты. Выполните следующие команды, заменив "
Your Name" и "your@email.com":git config --global user.name "Your Name"
git config --global user.email "your@email.com"Шаг 3: Прежде чем мы начнем использовать Git, нам нужно создать новый репозиторий на GitHub. Зайдите на сайт GitHub, войдите в свою учетную запись и нажмите кнопку "New repository".
Шаг 4: Теперь, когда есть репозиторий на GitHub, свяжем его с нашим локальным Git-репозиторием. Перейдите в каталог вашего проекта и выполните следующие команды:
git init
git remote add origin https://github.com/username/repository.gitЗдесь "username" - ваше имя пользователя на GitHub, а "repository" - название вашего репозитория.
Скриптовые языки
Языки программирования, которые позволяют создавать скрипты для автоматического выполнения серии команд, обработки данных, управления файлами, выполнения задач на расписании и многое другое.
Самый распространённый скриптовый язык - Bash. Это командный язык интерпретатора оболочки UNIX. Он используется для написания скриптов на Linux и других UNIX-подобных операционных системах.
Пример скрипта на Bash:
Языки программирования, которые позволяют создавать скрипты для автоматического выполнения серии команд, обработки данных, управления файлами, выполнения задач на расписании и многое другое.
Самый распространённый скриптовый язык - Bash. Это командный язык интерпретатора оболочки UNIX. Он используется для написания скриптов на Linux и других UNIX-подобных операционных системах.
Пример скрипта на Bash:
#!/bin/bash
echo "Привет, мир!"С помощью скриптовых языков можно сделать все!
Ну или почти все… благодаря им можно:
1. Автоматизировать повторяющиеся задачи:
Есть задача, которую нужно выполнять регулярно, вы можете написать скрипт, который будет выполнять эту задачу за вас. Например, скрипт для резервного копирования файлов, автоматической обработки данных или запуска ночных процессов.
2. Упростить сложные задачи:
Если есть сложная задача с множеством шагов или с большим объемом данных, скрипт может помочь вам разбить эту задачу на более простые части и автоматизировать каждый шаг. Это поможет снизить вероятность ошибок в процессе выполнения задачи и сэкономить время.
3. Улучшить процесс разработки:
Можно использовать для автоматизации сборки, тестирования и развертывания приложений. Например, вы можете написать скрипт для автоматической компиляции кода, запуска модульных тестов и развертывания приложений на сервере. Это позволяет сократить время разработки и повысить ее эффективность.
Ну или почти все… благодаря им можно:
1. Автоматизировать повторяющиеся задачи:
Есть задача, которую нужно выполнять регулярно, вы можете написать скрипт, который будет выполнять эту задачу за вас. Например, скрипт для резервного копирования файлов, автоматической обработки данных или запуска ночных процессов.
2. Упростить сложные задачи:
Если есть сложная задача с множеством шагов или с большим объемом данных, скрипт может помочь вам разбить эту задачу на более простые части и автоматизировать каждый шаг. Это поможет снизить вероятность ошибок в процессе выполнения задачи и сэкономить время.
3. Улучшить процесс разработки:
Можно использовать для автоматизации сборки, тестирования и развертывания приложений. Например, вы можете написать скрипт для автоматической компиляции кода, запуска модульных тестов и развертывания приложений на сервере. Это позволяет сократить время разработки и повысить ее эффективность.
Скрипт для обработки большого файла данных
Этот пример скрипта обрабатывает файл данных, извлекает конкретную информацию (имя и продажи) и генерирует индивидуальный отчет в
Чтобы использовать этот скрипт:
1. Сохраните его в файл (например,
2. Сделайте его исполняемым с помощью
4. Запустите его с помощью
Этот пример скрипта обрабатывает файл данных, извлекает конкретную информацию (имя и продажи) и генерирует индивидуальный отчет в
report.txt. Он подсчитывает общее количество обработанных записей, общий объем продаж, средний объем продаж на запись и перечисляет 5 лучших продавцов на основе продаж.Чтобы использовать этот скрипт:
1. Сохраните его в файл (например,
data-processing.sh).2. Сделайте его исполняемым с помощью
chmod +x data-processing.sh.
3. Поместите файл данных в тот же каталог или укажите полный путь в data_file.4. Запустите его с помощью
./data-processing.shМассовое переименование файлов
В этом примере скрипт переименовывает все файлы с определенным расширением. Вы можете настроить переменные
В этом примере скрипт переименовывает все файлы с определенным расширением. Вы можете настроить переменные
$source_extension и $new_extension, чтобы указать исходное и новое расширения файлов. После выполнения переименования скрипт выведет сообщение об успешном завершении.Обновление системы
В этом примере скрипт обновляет операционную систему Linux. Он выполняет команды apt update, apt upgrade, apt autoclean и apt autoremove для обновления пакетов, очистки кэша и удаления неиспользуемых пакетов. После выполнения обновления скрипт выведет сообщение об успешном завершении.
В этом примере скрипт обновляет операционную систему Linux. Он выполняет команды apt update, apt upgrade, apt autoclean и apt autoremove для обновления пакетов, очистки кэша и удаления неиспользуемых пакетов. После выполнения обновления скрипт выведет сообщение об успешном завершении.
Преимущества python над bash в написании скриптов
Python и Bash оба являются мощными инструментами для написания скриптов, но у них есть некоторые различия и особенности.
Преимущества:
Универсальность и многофункциональность: Python - полноценный язык программирования, который может использоваться для разработки разнообразных приложений, не только скриптов.
Простота чтения и понимания кода: Python-скрипты легче читать и поддерживать в долгосрочной перспективе.
Большая гибкость: Python обладает более широким функционалом и операционными возможностями по сравнению с Bash.
Переносимость: Python считается языком с высокой переносимостью. Скрипты, написанные на Python, могут выполняться на разных платформах и операционных системах, без необходимости модификации их кода.
Python и Bash оба являются мощными инструментами для написания скриптов, но у них есть некоторые различия и особенности.
Преимущества:
Универсальность и многофункциональность: Python - полноценный язык программирования, который может использоваться для разработки разнообразных приложений, не только скриптов.
Простота чтения и понимания кода: Python-скрипты легче читать и поддерживать в долгосрочной перспективе.
Большая гибкость: Python обладает более широким функционалом и операционными возможностями по сравнению с Bash.
Переносимость: Python считается языком с высокой переносимостью. Скрипты, написанные на Python, могут выполняться на разных платформах и операционных системах, без необходимости модификации их кода.
Преимущества bash над python в написании скриптов
Хотя Python является более универсальным и гибким языком программирования, Bash также имеет свои преимущества в написании скриптов:
Близость к командной строке: Bash - это язык командной строки, который имеет прямой доступ к системным командам и утилитам.
Простота и скорость выполнения команд: Bash предоставляет простой способ выполнения команд и утилит операционной системы. Кроме того, Bash-скрипты выполняются намного быстрее.
Поддержка для системных задач: Bash обеспечивает прямой доступ к системным вызовам и возможности работы с процессами, переменными окружения, временными файлами и другими системными ресурсами.
Хотя Python является более универсальным и гибким языком программирования, Bash также имеет свои преимущества в написании скриптов:
Близость к командной строке: Bash - это язык командной строки, который имеет прямой доступ к системным командам и утилитам.
Простота и скорость выполнения команд: Bash предоставляет простой способ выполнения команд и утилит операционной системы. Кроме того, Bash-скрипты выполняются намного быстрее.
Поддержка для системных задач: Bash обеспечивает прямой доступ к системным вызовам и возможности работы с процессами, переменными окружения, временными файлами и другими системными ресурсами.