• Главная
  • Контакты
Подписаться:
  • Twitter
  • Facebook
  • RSS
  • VK
  • PushAll
logo

logo

  • Все
    • Положительные
    • Отрицательные
  • За сегодня
    • Положительные
    • Отрицательные
  • За вчера
    • Положительные
    • Отрицательные
  • За 3 дня
    • Положительные
    • Отрицательные
  • За неделю
    • Положительные
    • Отрицательные
  • За месяц
    • Положительные
    • Отрицательные
  • За год
    • Положительные
    • Отрицательные
  • Сортировка
    • По дате (возр)
    • По дате (убыв)
    • По рейтингу (возр)
    • По рейтингу (убыв)
    • По комментам (возр)
    • По комментам (убыв)
    • По просмотрам (возр)
    • По просмотрам (убыв)
Главная
  • Все
    • Положительные
    • Отрицательные
  • За сегодня
    • Положительные
    • Отрицательные
  • За вчера
    • Положительные
    • Отрицательные
  • За 3 дня
    • Положительные
    • Отрицательные
  • За неделю
    • Положительные
    • Отрицательные
  • За месяц
    • Положительные
    • Отрицательные
  • Главная
  • 10 мини-лайфхаков в Bash

10 мини-лайфхаков в Bash +15

23.04.2017 19:07
Zorinoid 21 14500 Источник
*nix*
1. Чтобы быстро скопировать/переименовать файл с длинным именем, можно набрать:

cp /home/user1/myfile123456789.txt{,-new}

и обратно:

cp /home/user1/myfile123456789.txt{-new,}

2. Бесполезная, но прикольная форк-бомба (правда, не сработает, если у Вас задан ulimit для количества процессов):

:(){ :|:& };:

3. Эмулятор сетевого принтера на локальном компьютере:

nc -l -p 9100 > job.prn

4. Простейшее нагрузочное тестирование веб-сайта:

for i in {1..1000}; do echo ya.ru; done | xargs -P 20 wget &>/dev/null

5. Удобочитаемый вывод команды mount:

mount | column -t

6. SSH туннель с локального порта 7777 на удаленный порт 8888 на сервере myserver.com:

ssh -fN user@myserver.com -L 7777:myserver.com:8888

7. Вывести случайное число от 0 до 32767:

echo $RANDOM

8. Выполнить в консоли команды из текстового файла:

source ./commands.txt

9. Создать случайный пароль:

openssl rand -base64 8

10. Защита от одновременного запуска нескольких копий скрипта:

flock -n /tmp/lock.txt -c "/home/user1/test.sh > test.log"

На этом пока все, удачных экспериментов в командной строке!
Поделиться с друзьями
-->

Комментарии (21)


  1. Jogger
    23.04.2017 22:44
    #10187752
    +9

    И это что, статья? Надо хотя бы объяснять, что значат какие параметры. А то какой-то бессистемный набор «заклинаний» получается.


    1. ploop
      23.04.2017 22:49
      #10187756
      +12

      Согласен — «делай так и будет щастье!!!111» никогда не нравилось. Даже если находил такие решения — приходилось по ним гуглить/манить/доки читать. А то так недалеко и rm -rf скопипастить от какого-нибудь приколиста.


  1. 776166
    23.04.2017 23:00
    #10187766
    +3

    Слово «лайфхак» в названии понижает уровень материала на 3 порядка.


  1. amarao
    24.04.2017 03:23
    #10187894
    +3

    Пытаюсь понять чью жизнь вы взламываете. Свою? Читателя?


  1. mikkisse
    24.04.2017 09:11
    #10188028
    +8

    Похоже, что астрологи объявили месяц статей о bash на Хабре. Количество гневных комментариев увеличилось вдвое.


  1. redfs
    24.04.2017 11:02
    #10188194
    +6

    Из 10 пунктов примерно 8.5 никакого отношения к bash не имеют. Думаю, что автору надо переименовать статью в «Моя записная книжка».


    1. RPG
      24.04.2017 23:51
      #10189440

      У меня такая же есть на 32 Кб, всё думаю, может и правда сделать заметку "во что превратился мой .bashrc"?:)


  1. ubobrov
    24.04.2017 12:54
    #10188404
    -2

    Пусть это и не статья, но для себя полезное я нашёл.


  1. inkvizitor68sl
    24.04.2017 12:56
    #10188408
    +4

    Да оставили бы просто ссылку на https://www.commandlinefu.com/commands/browse


  1. CaptainFlint
    24.04.2017 13:24
    #10188472
    +2

    mount | column -t
    
    findmnt удобнее.

    source ./commands.txt
    
    Вместо source можно использовать просто точку:
    . ./commands.txt
    


    1. ghostinushanka
      25.04.2017 00:28
      #10189472

      Всем юниорам/эникеям бью по рукам за «точку» и заставляю писать source. Читаемость и восприятие возрастает на порядок. Проверено годами практики — иногда излишняя краткость во вред, особенно учитывая что в баш скриптах подгрузка «библиотек» используется редко и мало (ну а если надо много подгружать и функционал расширять — Python/Ruby/Perl на выбор).


      1. RPG
        25.04.2017 00:38
        #10189480

        .(){ bash -e "$1";}

        Подарите джуниорам бесценные часы отладки:) Можно добавить более весёлую шутку на свой вкус.


      1. CaptainFlint
        25.04.2017 01:52
        #10189520

        Баш не только для долговременных скриптов используется. Там, где важна поддержка, предпочтительнее читабельность. А для командной строки и разовых скриптов краткость здорово экономит время. Вы же не будете в командной строке каждый раз вбивать ls -l --almost-all --human-readable --recursive вместо ls -lAhR.


  1. icCE
    24.04.2017 13:50
    #10188506

    Вспомнилось

    dd if=/dev/zero of=/dev/null?

    или

    cat /dev/urandom | gzip > /dev/null

    Еще так

    tail /dev/urandom | cat — | grep something


  1. ALexhha
    24.04.2017 13:57
    #10188520
    +1

    Выполнить в консоли команды из текстового файла:
    source ./commands.txt

    а вы при этом знаете, в чем будет отличие от bash ./commands.txt?

    Простейшее нагрузочное тестирование веб-сайта:

    серьезно? А чем вас не устроил ab?


    1. kmeaw
      24.04.2017 23:33
      #10189414

      а вы при этом знаете, в чем будет отличие от bash ./commands.txt?

      В том, что команды будут выполнены в том же окружении, будто их ввели прямо в этот шелл с клавиатуры; bash ./commands.txt, напротив, запустит новый процесс:

      $ foo() { echo This is function foo.; }
      $ cat commands.txt
      foo
      $ source ./commands.txt
      This is function foo.
      $ bash ./commands.txt
      ./commands.txt: line 1: foo: command not found


      1. ALexhha
        25.04.2017 13:29
        #10190184

        что команды будут выполнены в том же окружении

        только не окружении, а сессии. И стоило бы указывать этот момент. Ибо «Выполнить в консоли команды из текстового файла» мало о чем говорят


    1. RPG
      24.04.2017 23:46
      #10189436

      а вы при этом знаете, в чем будет отличие от bash ./commands.txt?

      лишний раз subshell не будет запускаться (вдруг и правда кому-то нужно)


      серьезно? А чем вас не устроил ab?

      тоже хотел узнать, что может быть проще ab, к тому же предлагаемый вариант ужасен — wget намусорит файлами вида index.html.*


      И если уж на то пошло, сильно укоротить можно: seq 1000 | xargs -I{} -P20 wget -qO/dev/null ya.ru (да простит нас Яндекс)


  1. iassasin
    24.04.2017 14:44
    #10188626

    Поясните, пожалуйста, как работает форк-бомба из пункта 2?


    1. grossws
      24.04.2017 15:04
      #10188678
      +1

      Объявляется функция :, которая вызывает два своих экземпляра (команды через pipe запускаются параллельно) в фоне. Далее (после точки с запятой) вызывается функция :.


      1. iassasin
        24.04.2017 15:26
        #10188730

        А, понял, спасибо. Меня запутал ':', подумал, что это еще какой-то оператор и ничего про него не нашел.

МЕТКИ

  • Хабы
  • Теги

*nix

bash

СЕРВИСЫ
  • logo

    CloudLogs.ru - Облачное логирование

    • Храните логи вашего сервиса или приложения в облаке. Удобно просматривайте и анализируйте их.
Все публикации автора
  • 10 мини-лайфхаков в Bash +15

    • 23.04.2017 19:07

Подписка


ЛУЧШЕЕ

  • Сегодня
  • Вчера
  • Позавчера
07:01

Как написать постановку на разработку, чтобы ни у кого не было вопросов +44

11:47

Почтовик TheBat! Легенда, прошедшая сквозь время +35

07:00

Телеграфная связь XVIII века: 230 километров за 9 минут, служебные пакеты и станции оптической ретрансляции +34

07:22

Ядро Linux: Реально ли это просто программа? +33

07:37

История Уолли Уика — персонажа, который подарил жизнь новому жанру… и Диззи +32

09:01

«Привет! Я [0.44, -0.91, 0.66...]» или как научить машину чувствовать смысл слов +27

08:06

Анимированные визуализации потоков данных: движение товаров, денег и пользователей +27

08:42

Фаззинг телекома с генетическим алгоритмом: как тестировать продукт на безопасность, если обычных методов недостаточно +24

08:00

От закрытого 25 порта к собственному SMTP-сервису: как и почему это произошло +20

08:20

Экономисты OpenAI уволились, потому что компания отказывается публиковать правду об ИИ и рабочих местах +18

09:40

Assumed Breach как эволюция подходов к внутреннему пентесту +17

13:01

Админ vs студент: разбор тестового задания — сервис консультаций на Laravel за неделю +15

11:13

Почему я выбрал Suno AI для создания мемного альбома «Вася Тестировщик»? +13

09:28

Как достучаться до клиента в мобильном приложении: вчера и сегодня +13

11:24

Чпоньк! — как сделать разработку в 1С такой же быстрой, как Ctrl+C в VS Code +12

07:00

Эволюция умного дома: от ОВЕН к Wiren Board и Home Assistant +11

14:20

NetBSD и NVIDIA Optimus +9

06:44

GTA в реальности: история башен Уоттса +9

18:21

Готов лектор, давно готов! Про митапы и вебинары +8

09:00

Мышление QA: что происходит у меня в голове, когда я тестирую +8

13:01

Я мечтал о фотоаппарате, которого не существует, поэтому создал его сам +136

08:01

Грохот, который узнают за десятки километров: легенда Ан-22 +115

08:53

Перестань вайбкодить: почему «разработка на расслабоне» убьет твою карьеру +98

06:00

Проектирование сервиса персональной ленты. Как решать System Design? +70

15:13

Редчайший прототип Motorola E398, который работал на… Linux +42

12:00

Экстремальное масштабирование: концепт многочиплетного пакета Intel +42

14:00

NetBSD: вторая жизнь Nintendo Wii. Как и зачем я установил эту ОС на игровую консоль +33

09:01

Будущее дронов: встроенный ИИ +33

10:01

Топ-10 инструментов для управления лог-файлами в 2026 году +32

08:50

Как протестировать собственный контроллер памяти SDRAM на FPGA +30

12:12

Как Mozilla смогла отключить интернет в Китае +29

10:07

Go: сборщик мусора там, где его не ждут +27

21:47

Лабораторный стенд мобильного оператора в домашних условиях +26

14:05

Микрофичи, которые хотелось бы шире распространить в языках программирования +26

05:21

Планы Трампа после Венесуэлы, а также бикини-скандал с Grok +23

15:14

Корутины C++20 +22

16:32

PostgreSQL 19: Часть 1 или Коммитфест 2025-07 +18

08:11

Основы производственной этики для IT-специалистов +18

13:58

Напишите мне плохой отзыв, а я приду и выясню за что +15

06:26

Это стиль: влияние баухауса на графический дизайн +15

ОБСУЖДАЕМОЕ

  • Как Mozilla смогла отключить интернет в Китае +29

    • 128   36000

    Перестань вайбкодить: почему «разработка на расслабоне» убьет твою карьеру +98

    • 113   22000

    Грохот, который узнают за десятки километров: легенда Ан-22 +115

    • 97   88000

    Свобода по цене чая: как я перестал бороться с VPN и перешел на прокси за 26 рублей в месяц в 2026 году -41

    • 78   117000

    Почему учёные не могут прекратить поиски инопланетной жизни +3

    • 72   6900

    Редчайший прототип Motorola E398, который работал на… Linux +42

    • 58   15000

    Программирование можно будет освоить за день без курсов, когда решат эту проблему. И нейросети тут не причем -2

    • 53   8400

    Я мечтал о фотоаппарате, которого не существует, поэтому создал его сам +136

    • 52   43000

    Подходы к state management в React -1

    • 41   5900

    Как микросервисы стали тормозом. И почему мы вернулись к монолиту +8

    • 37   24000

    Будущее дронов: встроенный ИИ +33

    • 33   13000

    Константа во всем: одна простая задача за O(1) +6

    • 32   8900

    Почему жене не стоит работать за копейки, и как найти золотую середину -7

    • 31   7100

    Конструктор для параноика: история «сборки» TOTP-гаджета +9

    • 30   8600

    Свой луна-парк с блэкджеком и нейронками: Автоматизация с Flowgate. Часть 2 +3

    • 27   7900
  • Главная
  • Контакты
© 2026. Все публикации принадлежат авторам.