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

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

Подписка


ЛУЧШЕЕ

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

One-shot промптинг. Как я начал вайбкодить в 10? раз быстрее +55

08:00

Всё везде и сразу +35

08:05

Самодельная паяльная станция с цифровой индикацией температуры на жесткой логике +33

08:34

Лабиринты текста как игровая механика, или как неэкранизируемая литература становится источником геймдизайна +29

06:54

Picodata: вторая жизнь in-memory баз данных +23

05:15

Как я разработал расширение для браузера за 3 дня — и получил первого платного пользователя уже на следующий день +21

07:58

Я нашёл огромную дыру в дейтинг-приложении, а разработчики попытались её скрыть +20

09:01

ЦОД 2050: три реалистичные концепции развития дата-центров +18

14:45

Переходим от legacy к построению Feature Store +17

09:34

Криптография эпохи Ренессанса: классика не стареет +16

09:18

Распродажа в издательстве «Питер» +15

07:00

LLM as a Judge: опыт оптимизации генератора описаний Pull Request +15

07:00

Электрокэбы, полный привод и гонки: история дореволюционного автопрома +13

06:09

Left Shift Testing: как выстроить процесс, чтобы тесты реально помогали +13

07:01

Финансовый учет: всё и немного больше про проводки +12

04:56

Кто выполняет функции системного аналитика в США? +12

13:01

Введение в RawTherapee +11

10:57

Вселенная дистрибутивов Linux: От Ubuntu до Arch, от Mint до Fedora – подробный гид по выбору +10

14:12

Как я сменил лопату на клавиатуру: мой путь в IT после 30 +9

11:41

Зрение и его коррекция — не то, чем кажется +9

14:22

Ещё 10 ошибок авторов Хабра +135

07:43

Больше нет входа в IT. Только выход +62

14:15

Мое производство электрощитов приносит 40 млн в год. Спасибо нейросетям и СССР за конструкторскую школу +58

05:16

Дело о Транзитроне — или Ламповый тьюториал для любопытных +45

08:01

Трамплин в интернет: как мы ускорили запуск Яндекс Браузера +44

13:06

Введение в Angie: краткая история и отличия от Nginx +41

08:35

Распределённый инференс и шардирование LLM. Часть 1: настройка GPU, проброс в Proxmox и настройка Kubernetes +35

03:22

Как за один вечер создать репутацию вашего стартапа в поисковой выдаче: 20 бесплатных площадок для быстрого буста +35

16:15

Как я написал эмулятор Nintendo Gameboy на C++ за две недели +32

12:00

Story Points не работают? И другие мифы про оценку задач, в которые мы почему-то верим +32

13:01

Как создавались вокальные эффекты Daft Punk +31

07:00

DevOps без боли: 8 инструментов для мониторинга, автоматизации и стабильной работы команд +30

06:53

Важное обновление BatteryTest 2 +30

04:53

Баффет наконец накопил достаточно для выхода на пенсию, а в OpenAI выкатили новый хитрый план +26

10:26

От релиз-менеджера до разработчика: почему я ушел из QA и не жалею +24

10:09

Как настраивать сети: готовые решения Selectel для максимальной отказоустойчивости +24

09:01

Почему из технологий делают культы +24

09:31

Как ESLint помогает управлять архитектурой проекта +23

08:57

Разбор полётов: что умеет отечественная СХД Аэродиск AQ440 +22

12:08

Эффект душа: почему отдых и переключение на хобби помогают принимать крутые решения +21

19:36

ООП не мертво. Вы просто пользуетесь им как молотком по клавиатуре +151

08:00

Электробус из 1907 года от мошенников-стартаперов. И да, он возил пассажиров +53

13:01

Как serverless-архитектура влияет на модернизацию инфраструктуры +43

17:21

CTO: рынок, стратегия и инженерная культура +37

09:01

Google Maps не знают, как работает адресация улиц +36

09:15

Wizordum — пример правильной ностальгии +35

06:30

Дискретные тригонометрические функции, машинный эпсилон и автоматическое дифференцирование +35

10:00

Multi-GPU Rendering для игр жив? +34

16:08

Как отключить слежку на умном ТВ +33

10:05

Разговоры с мамой, остросюжетный роман и дофаминовые ловушки. Что и зачем читать продакту в 2025 году +31

15:16

Заговор разработчиков против корпораций: работа с командой +25

12:28

Как устроен arXiv — самая преобразующая платформа во всей науке +23

07:00

От песка в глазах к панораме: как 49-дюймовый монитор заменил два 27-дюймовых и сделал жизнь и работу комфортнее +22

05:47

Убить героя: почему героизм — это выбор легкого пути, который вредит не только вам, но и окружающим +21

14:46

Что открыть в 2025, если ты не Илон Маск и не хочешь продавать курсы? +20

16:24

Корутины в C++20: архитектура и практическое применение +16

17:01

PTTJS — формат текстового хранения комплексных таблиц +14

14:00

Корпоративное ЕГЭ или как обучение сотрудников НЕ влияет на рост и эффективность +14

18:20

Подмена E-EDID на Windows +12

18:33

Пишем (и используем) ИИ-агент на Gradle и Ollama +10

ОБСУЖДАЕМОЕ

  • Больше нет входа в IT. Только выход +62

    • 452   108000

    От песка в глазах к панораме: как 49-дюймовый монитор заменил два 27-дюймовых и сделал жизнь и работу комфортнее +22

    • 360   65000

    ООП не мертво. Вы просто пользуетесь им как молотком по клавиатуре +151

    • 283   39000

    Ещё 10 ошибок авторов Хабра +135

    • 124   6700

    Мое производство электрощитов приносит 40 млн в год. Спасибо нейросетям и СССР за конструкторскую школу +58

    • 102   51000

    «Накопитель риска» в команде: как одиночные эксперты тормозят развитие +4

    • 77   8900

    Google Maps не знают, как работает адресация улиц +36

    • 76   9800

    Массовые увольнения в российском IT: что на самом деле происходит в компаниях — взгляд CEO +9

    • 67   13000

    Как отключить слежку на умном ТВ +33

    • 60   16000

    Дело о Транзитроне — или Ламповый тьюториал для любопытных +45

    • 56   4500

    Бирюзовые компании в РФ: как не посинеть в найме +20

    • 45   40000

    Трамплин в интернет: как мы ускорили запуск Яндекс Браузера +44

    • 45   4000

    One-shot промптинг. Как я начал вайбкодить в 10? раз быстрее +55

    • 40   12000

    Быстрый алгоритм fulltext-поиска без токенизации +15

    • 37   2100

    Проводной умный дом – какие системы актуальны в 2025 году? -3

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