Разные операционные системы длительное время обслуживают различные аудитории: Windows — бизнес-профессионалов, Mac — творческих, а Linux — разработчиков. Разработчикам ОС такой тип рыночного спектра сильно упростил концепцию продукта, технические требования, пользовательский опыт и направление рынка. Однако, он также ужесточил нормы рабочего пространства, что деформировало отдельных пользователей под узкие, непересекающиеся области: у бизнесменов нет возможности заглянуть в творческий процесс, а у разработчиков нет представления о проблемах бизнеса.
- Почему современные бизнес-аналитики должны знать Linux
- Фундаментальная единица Linux: "оболочка"
- Изучаем несколько важных концептов
- Продвинутые и не часто используемые команды
В реальности знания и опыт — динамичны, они охватывают несколько дисциплин и сфер деятельности. Представление о том, что "можно иметь способности только к чему-то одному" — это не руководство к овладению мастерством, а попытка справиться с преждевременной оптимизацией. Узнать о том, в чём вы хорошо разбираетесь можно только когда вы попробовали себя в нескольких разных вопросах. И может оказаться, что у вас есть способности ко многим видам деятельности.
Для современных бизнес-аналитиков особенно актуален вопрос ликвидации пробела между бизнесом и разработкой. Бизнес-аналитики должны быть двухплатформенными, способными использовать командную строку, доступную только на Linux (или в macOS), но при этом уметь извлекать широкие возможности из Microsoft Office в Windows. Очевидно, что мир Linux пугает тех, у кого образование в сфере бизнеса. К счастью, как и в большем количестве вопросов, вам необходимо изучить 20% информации, чтобы выполнить 80% работы. Вот мои 20%.
- Освойте азы современных языков программирования
- Изучите работу с Git и командной строкой
- Выберите себе профессию или улучшите навыки
Почему современные бизнес-аналитики должны знать Linux
Благодаря своим open source корням, Linux выиграл от вкладов тысяч разработчиков за всё время его существования. Они построили программы и утилиты, чтобы упростить работу не только себе, но и тем программистам, которые последовали за ними. В результате open source разработка создала эффект сетевой выгоды: чем больше разработчики строили утилиты на оригинальной платформе, тем больше других разработчиков могло влиять на эти утилиты, чтобы писать собственные программы.
В результате получился огромный пакет программ и утилит (то есть софт), который был написан на Linux и под Linux. Большая часть его никогда не портировалась в Windows. Один из примеров — популярная система контроля версий (VCS), которая называется git. Разработчики могли написать софт под Windows, но они этого не сделали. Они написали его для работы в командной строке, для Linux, потому что Linux — экосистема, в которой уже были все необходимые инструменты.
Если вдаваться в подробности, разработка на Windows ведёт к двум основным проблемам:
- Базовые задачи, вроде парсинга файлов, рабочего планирования и поиска текста используются чаще, чем запуск утилиты командной строки.
- Языки программирования (Python, C++) и связанные с ними библиотеки выкидывают ошибки, потому что они ожидают конкретных параметров Linux или специфических локаций файловой системы.
Если собрать всё вместе, это выльется в трату времени на переписывание базовых инструментов, которые уже доступны в Linux, они позволят избежать ошибок совместимости с ОС. Тут нет никаких сюрпризов — экосистема Windows просто не была задумана и спроектирована под нужды разработки софта.
Теперь давайте рассмотрим базовые идеи Linux.
Фундаментальная единица Linux: "оболочка"
Shell (оболочка, также известная как терминал, консоль или командная строка) — это текстовый интерфейс пользователя, через который команды отправляются машине. На Linux, по-умолчанию, язык оболочки называется bash. В отличие от Windows-пользователей, которые в своём большинстве используют навигацию "навести-кликнуть" по окну, Linux-разработчики привязаны к клавиатуре и пишут команды в оболочке. Хоть этот переход далёк от естественного для тех, у кого нет бэкграунда в программировании, плюсы разработки в Linux сильно перевешивают изначальное вложение в обучение.
Изучаем несколько важных концептов
В сравнении с достаточно зрелым языком программирования, bash имеет всего несколько основных концептов, которые необходимо выучить. Как только вы охватите это, остаток bash — простое запоминание. Я переформулирую понятней: хорошо разбираться в bash значит запомнить 20-30 команд и их часто используемые аргументы.
Linux кажется непроницаемым для тех, кто не касается разработки, из-за способа, которым разработчики (не напрягаясь) извергают эзотерические команды терминала, когда им захочется. Правда в том, что они хорошо знают только несколько десятков команд — за всем более сложным они так же (как и все смертные) обращаются в Google.
Опуская мелкие загвоздки, стоящие на пути, вот главные концепты в bash.
Командный синтаксис
Команды соответствуют синтаксису: {command} {arguments..}
Например, в 'grep -inr', grep — это команда (для поиска текстовой строки) и -inr это флаги/аргументы, которые меняют то, что grep выполняет по умолчанию. Единственный способ понять, что это значит, поискать что-то о них через Google или просто ввести 'man grep'. Я рекомендую выучить команды и их самые используемые аргументы: слишком обременительно помнить, что делает каждый флаг.
Псевдонимы директорий
- Текущая директория (где я?):
.
- Родительская директория текущей директории:
..
- Домашняя директория пользователя:
~
- Корень файловой системы (или родитель всех родителей):
/
Например, чтобы поменять текущую директорию на родительскую директорию нужно ввести: cd ..
Таким же способом, чтобы скопировать файл, расположенный в "/path/to/file.txt" в текущую директорию, нужно ввести cp /path/to/file.txt .
(заметьте, что в конце команды точка). Поскольку это всего лишь псевдонимы, вместо них может использоваться реальное имя пути.
Полезная информация У нас есть курс по операционным системам. Зарегистрированные пользователи могут пройти его бесплатно. Другие бесплатные курсы можно найти по ссылке.
STDIN / STDOUT
Всё, что вы пишите в окне и подтверждаете (с помощью ENTER), называется стандартным вводом (STDIN).
Всё, что программа выводит в ответе в терминал (например текст из файла), называется стандартным выводом (STDOUT)
Конвейер (piping)
|
Pipe принимает STDOUT от команды слева от pipe и превращает его в STDIN для команды справа от pipe.
пример: echo 'test text' | wc -l
>
Символ "больше" принимает STDOUT от команды слева и записывает/перезаписывает в новый файл справа
пример: ls > tmp.txt
>>
Два символа "больше" принимают STDOUT от команды слева и добавляют к новому или существующему файлу справа.
пример: date >> tmp.txt
Шаблоны поиска (wildcards)
Можете представить это как символ % в SQL. Например, можно написать WHERE first_name LIKE 'John%'
, чтобы найти любые позиции, где данные начинаются с имени John.
В bash можно написать John*
. Если вы хотите вывести список всех файлов в какой-то папке, заканчивающихся на ".json", пишете : ls *.json
Завершение с помощью tab
Bash часто завершает команды сам, по определённой логике, если вы начинаете вводить команду и нажимаете TAB.
Однако, стоит попробовать что-то вроде zsh или fish для автозаполнения, потому что запоминать команды и все их параметры очень сложно. Более того, эти инструменты применят автозаполнение, основываясь на вашей истории используемых команд.
Также полезно: Зачем нужна команда pwd и что такое текущая рабочая директория
Выход
Иногда вы застреваете в какой-нибудь программе и не можете оттуда выйти. Это очень часто повторяющееся событие для новичков в Linux, которое невероятно демотивирует. Часто выход происходит с помощью чего-то, содержащего q. Хорошо бы запомнить то, что будет написано ниже и использовать, когда вы в ловушке.
- Bash
- CTRL+c
- q
- exit
- Python: quit()
- Nano: CTRL+x
- Vim: Esc :q!
Что я помню из команд bash
Это те команды, которые я использую чаще всего в Linux (начиная от самых часто используемых к самым редко используемым). Как я уже писал раньше, знание всего горстки команд поможет выполнять большой набор необходимых программируемых задач.
cd {directory}
изменить директориюls -lha
вывести директорию в виде списка (подробного)vim
илиnano
редактор командной строкиtouch {file}
создать новый пустой файлcp -R {original_name} {new_name}
скопировать файл или директорию (и всё их содержимое)mv {original_name} {new_name}
переместить или переименовать файлrm {file}
удалить файлrm -rf {file/folder}
удалить файл или папку без возможности восстановления [использовать аккуратно!]pwd
вывести текущую рабочую директориюcat
илиless
илиtail
илиhead -n10 {file}
вывести в STDOUT содержимое файлаmkdir {directory}
создать пустую директориюgrep -inr {string}
найти строку в любом файле этой директории или дочерних директорияхcolumn -s, -t <delimited_file>
отобразить разделенный запятыми файл в виде столбцовssh {username}@{hostname}
соединиться с удалённой машинойtree -LhaC 3
показать структуру директории на 3 уровнями вглубь (с размерами файлов и включая скрытые директории)htop
(илиtop
) диспетчер задачpip install --user {pip_package}
пакетный менеджер Python для установки пакетов в ~/.local/binpushd . ; popd ; dirs; cd -
push/pop/view директорию в стек + изменить обратно на последнюю директориюsed -i "s/{find}/{replace}/g" {file}
заменить строку в файлеfind . -type f -name '*.txt' -exec sed -i "s/{find}/{replace}/g" {} \;
заменить строку для каждого файла в этой и дочерней папках с именем типа *.txttmux new -s session, tmux attach -t session
создать новую сессию терминала без создания нового окна [продвинутый уровень]wget {link}
загрузить веб-страницу или веб-ресурсcurl -X POST -d "{key: value}" http://www.google.com
отправить HTTP-запрос на веб-серверfind <directory>
вывести список всего содержимого директории и её дочерних директорий рекурсивно
Читайте также Как упростить разработку с помощью виртуализации.
Продвинутые и не часто используемые команды
Я считаю хорошей практикой хранить список команд, которые полезны в определённых ситуациях, даже если подобные ситуации случаются редко (например, какой процесс блокирует конкретный сетевой порт). Вот несколько нестандартных команд, которые у меня всегда под рукой:
lsof -i :8080
вывести список дескрипторов открытых файлов (-i
— флаг для сетевых интерфейсов)netstat | head -n20
вывести список открытых интернет/UNIX сокетов и связанной с ними информацииdstat -a
транслировать текущий диск, сеть, активность CPU и другоеnslookup <IP address>
найти hostname для удалённого IP-адресаstrace -f -e <syscall> <cmd>
отследить системные вызовы программы (-e
— флаг для фильтрования конкретных системных вызовов)ps aux | head -n20
вывести текущие активные процессыfile <file>
проверить тип файла (например исполняемый, бинарный, текстовый файл с кодировкой ASCII)uname -a
информация о ядре ОСlsb_release -a
информация об ОСhostname
проверить hostname текущего компьютера (например, название, чтобы другие компьютеры могли иметь доступ к вашему)pstree
визуализировать форки процессовtime <cmd>
исполнить команду и составить статистику о том, сколько времени потребовалось на исполнениеCTRL + z ; bg; jobs; fg
отправить процесс в текущий tty в background и обратно на передний планcat file.txt | xargs -n1 | sort | uniq -c
посчитать количество уникальных слов в файлеwc -l <file>
количество строк в файлеdu -ha
показать размер на диске для директорий и их содержимогоzcat <file.gz>
вывести содержимое заархивированного текстового файлаscp <user@remote_host> <local_path>
скопировать файл с удалённого на локальный сервер или наоборотman {command}
показать инструкцию, (т.е. документацию) для команды (но скорее всего легче использовать Google)
- Освойте азы современных языков программирования
- Изучите работу с Git и командной строкой
- Выберите себе профессию или улучшите навыки
Это перевод статьи Алекса Петралиа Learn just enough Linux to get things done.