Środowisko programisty/Wprowadzenie do Basha
Czym jest bash?
Bash (Bourne-Again Shell) jest najpopularniejszą odmianą shell'a. Innymi znanymi są np. ksh (Korn Shell), csh (C Shell).
Shell możemy kojarzyć z linią poleceń, dzięki ktorej możemy wpisywać komendy z klawiatury służące na ogół do uruchamiania innych programów, poleceń lub wyświetlania informacji. Shell służy też do uruchamiania własnoręcznie napisanych skryptów.
Najprostsze skrypty są po prostu ciągiem poleceń, ale możemy też pisać bardziej skomplikowane mechanizmy, które w istocie rzeczy można nazwać wręcz programami. Składnia skryptów nie jest skomplikowana. Oprócz znajomości różnych programów użytkowych i systemowych, jest zaledwie kilka reguł, które wystarczy się nauczyć, żeby swobodnie pisać skrypty składające poznane programy w celu wykonania zaplanowanych działań.
Shell jest podstawowym narzędziem pod system typu UNIX, ale nie tylko. Pod Windowsem mamy np. interpretator poleceń, a skryptami są np. pliki o rozszerzeniu bat. Niemniej możliwości i funkcjonalność takich skryptów pod Windowsem są znikome w porównania do basha pod Unixem, ze względu na ograniczenia składniowe, jak i dostępny zbiór polecenień użytkowych. Aby uzyskać możliwość uruchamiania skryptów napisanych w Bashu pod Windowsem możemy sobie zainstalować pakiet Cygwin.
Do czego się przydaje?
Skrypty pisze się jak chce się zautomatyzować lub uprościć jakąś czynność, powtarzalną badź nie. Czynności te, to
- kompilacja, budowanie aplikacji,
- przetwarzanie plików (tworzenie, usuwanie, szukanie, itp.),
- prosta obróbka (np. tekstowa) plików,
- administracja systemem (np. konfiguracja, uruchamianie demonów),
- i wiele innych...
Do czego się nie nadaje?
Bash jest interpreterem. Skryptów napisanych w bashu się nie kompiluje. Nie ma też żadnych skomplikowanych struktur danych (jak tablice wielowymiarowe, czy drzewa), ani konstrukcji znanych z języków wyższych poziomów (jak rekordy, klasy). W związku z tym skrypty nie nadają się na przykład do:
- zadań trudnych obliczeniowo, wymagających szybkiego działania,
- operacji skomplikowanych algorytmicznie, czy też matematycznie,
- operacji niskopoziomowych, jak dostęp do sprzętu.
Zaczynamy pracować
Przykład
Shell może ułatwiać nam wykonywanie nawet bardzo skomplikowanych czynności. Spójrzmy na następujący przykład. Załóżmy, że mamy projekt o nazwie ecmnet, którego źródła znajdują sie w katalogu o tej samej nazwie. Chcemy wysłać sobie mailem archiwum z źródłami tego projektu. Chcemy również, aby w tym archiwum nie znalazły się pliki o rozszerzeniu bak, czy kończące się znakiem ~. Ponadto nazwa archiwum powinna zawierać aktulną datę z dokładności co do sekundy. Oto jak może wyglądać przykładowa sesja w bashu realizujaca te zadanie .
Wiele rzeczy, czy też niektóre komendy mogą być w tym momencie niezrozumiałe, niemniej warto być świadomym możliwości, że tego typu czynności można wykonywać bardzo sprawnie. Skomentujmy po krótce przeznaczenie użytych poleceń, o których więcej szczegółów zostanych podanych w trakcie kursu.
bashtest@host:~$ cp -a ecmnet/ /tmp/
cp -a kopiuje rekurencyjnie katalog ecment do katalogu /tmp/ (jest to standardowy katalog, w którym trzyma się pliki tymczasowe).
bashtest@host:~$ cd /tmp/
Zmienia aktualny katalog na /tmp.
bashtest@host:/tmp$ find ecmnet/ -name "*.bak" -o -name "*~" bashtest@host:/tmp$ find ecmnet/ -name "*.bak" -o -name "*~" -execdir rm -f {} +
find potrafi wyszukiwać pliki rekurencyjnie w rozmaity sposób i nie tylko. W tym przypadku użyliśmy go do znalezienia plików o rozszerzeniu bak lub kończących się znakiem ~. W drugiej linii zmodyfikowaliśmy komendę tak, aby te znalezione pliki zostałe od razu usunięte.
bashtest@host:/tmp$ date +%Y%m%d%H%M%S
date służy wyświetla aktulną datę/godziny lub jej zmieniania. W tym przypadku wyświetlamy datę w odpowiednim formacie.
bashtest@host:/tmp$ tar cvz ecmnet/ | uuencode ecmnet-`date +%Y%m%d%H%M%S`.tgz | mail me@somehost
Tutaj mamy przykład potoku. Komenda tar służy do składania plików w jedno archiwum z lub bez kompresji. To co wyprodukuje ta komenda jest przekazywane komendzie uuencode, która służy do kodowania plików binarnych, tak aby mogły być użyte w mediach tekstowych. Wynik wywołania komendy date jest użyty do nazwania pliku archiwum. Ostateczny wynik dostaje komenda mail, która wysyła go na adres me@somehost.
bashtest@host:/tmp$ rm -rf ecmnet/
Usuwa rekurencyjnie katalog ecmnet.
bashtest@host:/tmp$ cd
Zmienia katalog z powrotem na domowy katalog użytkownika.
Dokumentacja
W powyższym przykładzie widzimy, że główną siłą była znajomość komend i opcji z jakimi trzeba ich użyć. Jeśli chodzi o uzyskiwanie informacji na temat opcji danej komendy, to z pomocą przychdzą nam dwa polecenia:
- man
- info
Na przykład, żeby dowiedzieć się co oznacza magiczne +%Y%m%d%H%M%S przy poleceniu date możemy napisać :
bashtest@host:~$ man date
Dostajemy tekstowy opis komendy date wraz z wszystkimi opcjami, który możemy sobie spokojnie poprzeglądać. Komenda info jest podobna do komendy man z tą różnicą, że daje jeszcze większą wygodę porusznia się i na ogół jest znacznie więcej informacji. W niektórych dystrybucjach linuxa większość informacji o dostępnych komendach użytkowych można uzyskać na przykład poprzez polecenie:
bashtest@host:~$ info coreutils
Gdzie znaleźć jakie w ogóle są komendy? Wiele z nich wymienionych jest własnie w info coreutils. Inne komendy można samemu spróbować poszukać w liście zainstalowanych pakietów danej dystrybucji. Jednak takie szukanie jest czasochłonne. Tak naprawdę lista wszystkich poleceń nie istnieje, gdyż co chwilę powstają nowe programy dające nowe możliwości lub ułatwiające życie.
W tym kursie przedstawimy podstawowe narzędzia, które powinny w praktyce wystarczyć do większości celów. Jednak przy potrzebie bardziej wysublimowanych komend, trzeba będzie odpowiednie narzędzie znaleźć lub też samemu napisać używając bardziej zaawansowanych języków jak Perl, Python, C, czy Java.