2
0
Fork 0
mirror of https://github.com/Idnan/bash-guide.git synced 2018-11-09 02:29:39 +01:00
bash-guide/README.md

1191 lines
28 KiB
Markdown
Raw Normal View History

2017-04-01 12:27:42 +02:00
<p align="center">
<img src="https://cloud.githubusercontent.com/assets/2059754/24601246/753a7f36-1858-11e7-9d6b-7a0e64fb27f7.png" alt="bash logo"/>
2017-04-01 12:27:42 +02:00
</p>
2017-04-01 10:44:11 +02:00
## Table of Contents
2017-04-01 15:03:37 +02:00
1. [Basic Operations](#1-basic-operations)
2017-04-01 14:15:21 +02:00
1.1. [File Operations](#11-file-operations)
2017-04-01 14:47:53 +02:00
1.2. [Text Operations](#12-text-operations)
2017-04-01 14:46:15 +02:00
1.3. [Directory Operations](#13-directory-operations)
1.4. [SSH, System Info & Network Operations](#14-ssh-system-info--network-operations)
1.5. [Process Monitoring Operations](#15-process-monitoring-operations)
2017-04-01 15:03:37 +02:00
2. [Basic Shell Programming](#2-basic-shell-programming)
2017-04-01 10:48:11 +02:00
2.1. [Variables](#21-variables)
2.2. [Array](#22-array)
2017-04-11 05:53:29 +02:00
2.3. [String Substitution](#23-string-substitution)
2.4. [Functions](#24-functions)
2.5. [Conditionals](#25-conditionals)
2.6. [Loops](#26-loops)
2017-04-04 05:06:11 +02:00
3. [Tricks](#3-tricks)
4. [Debugging](#4-debugging)
2017-04-01 15:03:37 +02:00
2017-04-01 09:47:13 +02:00
2017-04-01 14:55:35 +02:00
# 1. Basic Operations
2017-04-01 09:47:13 +02:00
### a. `export`
Displays all environment variables. If you want to get details of a specific variable, use `echo $VARIABLE_NAME`.
```bash
2017-04-01 09:47:13 +02:00
export
```
Example:
```bash
2017-04-01 09:47:13 +02:00
$ export
AWS_HOME=/Users/adnanadnan/.aws
LANG=en_US.UTF-8
LC_CTYPE=en_US.UTF-8
LESS=-R
$ echo $AWS_HOME
/Users/adnanadnan/.aws
2017-04-01 09:47:13 +02:00
```
### b. `whatis`
whatis shows description for user commands, system calls, library functions, and others in manual pages
```bash
whatis something
```
Example:
```bash
$ whatis bash
bash (1) - GNU Bourne-Again SHell
```
### c. `whereis`
whereis searches for executables, source files, and manual pages using a database built by system automatically.
```bash
2017-04-01 12:19:47 +02:00
whereis name
2017-04-01 09:47:13 +02:00
```
Example:
```bash
2017-04-01 09:47:13 +02:00
$ whereis php
/usr/bin/php
```
### d. `which`
which searches for executables in the directories specified by the environment variable PATH. This command will print the full path of the executable(s).
```bash
2017-04-01 12:19:47 +02:00
which program_name
```
Example:
```bash
$ which php
/c/xampp/php/php
```
### e. clear
Clears content on window.
2017-04-01 09:47:13 +02:00
2017-04-01 14:15:21 +02:00
## 1.1. File Operations
2017-04-01 10:04:51 +02:00
<table>
2017-04-01 10:13:47 +02:00
<tr>
2017-04-04 20:51:26 +02:00
<td><a href="#a-cat">cat</a></td>
<td><a href="#b-chmod">chmod</a></td>
<td><a href="#c-chown">chown</a></td>
<td><a href="#d-cp">cp</a></td>
<td><a href="#e-diff">diff</a></td>
<td><a href="#f-file">file</a></td>
<td><a href="#g-find">find</a></td>
<td><a href="#h-gunzip">gunzip</a></td>
<td><a href="#i-gzcat">gzcat</a></td>
<td><a href="#j-gzip">gzip</a></td>
<td><a href="#k-head">head</a></td>
</tr>
<tr>
<td><a href="#l-lpq">lpq</a></td>
<td><a href="#m-lpr">lpr</a></td>
<td><a href="#n-lprm">lprm</a></td>
<td><a href="#o-ls">ls</a></td>
<td><a href="#p-more">more</a></td>
<td><a href="#q-mv">mv</a></td>
<td><a href="#r-rm">rm</a></td>
<td><a href="#s-tail">tail</a></td>
<td><a href="#t-touch">touch</a></td>
2017-04-01 10:13:47 +02:00
</tr>
2017-04-01 10:04:51 +02:00
</table>
2017-04-04 20:51:26 +02:00
### a. `cat`
It can be used for the following purposes under UNIX or Linux.
2017-04-02 05:40:56 +02:00
* Display text files on screen
2017-04-02 05:39:18 +02:00
* Copy text files
* Combine text files
* Create new text files
```bash
2017-04-02 05:37:46 +02:00
cat filename
cat file1 file2
cat file1 file2 > newcombinedfile
2017-04-09 10:18:02 +02:00
cat < file1 > file2 #copy file1 to file2
2017-04-01 09:47:13 +02:00
```
2017-04-04 20:51:26 +02:00
### b. `chmod`
The chmod command stands for "change mode" and allows you to change the read, write, and execute permissions on your files and folders. For more information on this command check this [link](https://ss64.com/bash/chmod.html).
```bash
2017-04-04 20:51:26 +02:00
chmod -options filename
2017-04-01 09:47:13 +02:00
```
### c. `chown`
The chown command stands for "change owner", and allows you to change the owner of a given file or folder, which can be a user and a group. Basic usage is simple forward first comes the user (owner), and then the group, delimited by a colon.
```bash
chown -options user:group filename
```
### d. `cp`
Copies a file from one location to other.
```bash
2017-04-01 12:19:47 +02:00
cp filename1 filename2
2017-04-01 09:47:13 +02:00
```
Where `filename1` is the source path to the file and `filename2` is the destination path to the file.
### e. `diff`
Compares files, and lists their differences.
```bash
2017-04-01 12:19:47 +02:00
diff filename1 filename2
2017-04-01 09:47:13 +02:00
```
### f. `file`
2017-04-04 20:51:26 +02:00
Determine file type.
```bash
2017-04-04 20:51:26 +02:00
file filename
2017-04-01 09:47:13 +02:00
```
2017-04-04 20:51:26 +02:00
Example:
```bash
2017-04-04 20:51:26 +02:00
$ file index.html
index.html: HTML document, ASCII text
2017-04-01 09:47:13 +02:00
```
### g. `find`
2017-04-05 07:48:07 +02:00
Find files in directory
```bash
find directory options pattern
```
Example:
```bash
$ find . -name README.md
$ find /home/user1 -name '*.png'
```
2017-04-01 09:47:13 +02:00
### h. `gunzip`
Un-compresses files compressed by gzip.
```bash
2017-04-01 12:19:47 +02:00
gunzip filename
2017-04-01 09:47:13 +02:00
```
### i. `gzcat`
Lets you look at gzipped file without actually having to gunzip it.
```bash
2017-04-01 12:19:47 +02:00
gzcat filename
2017-04-01 09:47:13 +02:00
```
### j. `gzip`
2017-04-04 20:51:26 +02:00
Compresses files.
```bash
2017-04-04 20:51:26 +02:00
gzip filename
2017-04-01 09:47:13 +02:00
```
### k. `head`
2017-04-04 20:51:26 +02:00
Outputs the first 10 lines of file
```bash
head filename
```
### l. `lpq`
Check out the printer queue.
```bash
2017-04-01 09:47:13 +02:00
lpq
```
Example:
```bash
2017-04-01 09:47:13 +02:00
$ lpq
Rank Owner Job File(s) Total Size
active adnanad 59 demo 399360 bytes
1st adnanad 60 (stdin) 0 bytes
```
### m. `lpr`
2017-04-04 20:51:26 +02:00
Print the file.
```bash
lpr filename
```
### n. `lprm`
Remove something from the printer queue.
```bash
2017-04-01 12:19:47 +02:00
lprm jobnumber
2017-04-01 09:47:13 +02:00
```
### o. `ls`
2017-04-04 20:51:26 +02:00
Lists your files. `ls` has many options: `-l` lists files in 'long format', which contains the exact size of the file, who owns the file, who has the right to look at it, and when it was last modified. `-a` lists all files, including hidden files. For more information on this command check this [link](https://ss64.com/bash/ls.html).
```bash
2017-04-04 20:51:26 +02:00
ls option
```
Example:
2017-04-04 20:51:26 +02:00
<pre>
$ ls -la
2017-04-04 20:51:26 +02:00
rwxr-xr-x 33 adnan staff 1122 Mar 27 18:44 .
drwxrwxrwx 60 adnan staff 2040 Mar 21 15:06 ..
-rw-r--r--@ 1 adnan staff 14340 Mar 23 15:05 .DS_Store
-rw-r--r-- 1 adnan staff 157 Mar 25 18:08 .bumpversion.cfg
-rw-r--r-- 1 adnan staff 6515 Mar 25 18:08 .config.ini
-rw-r--r-- 1 adnan staff 5805 Mar 27 18:44 .config.override.ini
drwxr-xr-x 17 adnan staff 578 Mar 27 23:36 .git
-rwxr-xr-x 1 adnan staff 2702 Mar 25 18:08 .gitignore
</pre>
### p. `more`
2017-04-04 20:51:26 +02:00
Shows the first part of a file (move with space and type q to quit).
```bash
2017-04-04 20:51:26 +02:00
more filename
```
### q. `mv`
2017-04-04 20:51:26 +02:00
Moves a file from one location to other.
```bash
mv filename1 filename2
```
Where `filename1` is the source path to the file and `filename2` is the destination path to the file.
2017-04-06 18:39:33 +02:00
Also it can be used for rename a file.
```bash
mv old_name new_name
```
### r. `rm`
2017-04-04 20:51:26 +02:00
Removes a file. Using this command on a directory gives you an error.
`rm: directory: is a directory`
To remove a directory you have to pass `-r` which will remove the content of the directory recursively. Optionally you can use `-f` flag to force the deletion i.e. without any confirmations etc.
```bash
rm filename
```
### s. `tail`
2017-04-04 20:51:26 +02:00
Outputs the last 10 lines of file. Use `-f` to output appended data as the file grows.
```bash
tail filename
```
### t. `touch`
Updates access and modification time stamps of your file. If it doesn't exists, it'll be created.
2017-04-04 20:51:26 +02:00
```bash
touch filename
```
Example:
```bash
$ touch trick.md
```
2017-04-01 14:46:15 +02:00
## 1.2. Text Operations
<table>
2017-04-04 20:51:26 +02:00
<tr>
2017-04-01 14:46:15 +02:00
<td><a href="#a-awk">awk</a></td>
2017-04-04 20:51:26 +02:00
<td><a href="#b-cut">cut</a></td>
<td><a href="#c-echo">echo</a></td>
<td><a href="#d-egrep">egrep</a></td>
<td><a href="#e-fgrep">fgrep</a></td>
<td><a href="#f-fmt">fmt</a></td>
<td><a href="#g-grep">grep</a></td>
<td><a href="#h-nl">nl</a></td>
<td><a href="#i-sed">sed</a></td>
<td><a href="#j-sort">sort</a></td>
2017-04-01 14:46:15 +02:00
</tr>
<tr>
2017-04-04 20:51:26 +02:00
<td><a href="#k-tr">tr</a></td>
<td><a href="#l-uniq">uniq</a></td>
<td><a href="#m-wc">wc</a></td>
2017-04-01 14:46:15 +02:00
</tr>
</table>
### a. `awk`
awk is the most useful command for handling text files. It operates on an entire file line by line. By default it uses whitespace to separate the fields. The most common syntax for awk command is
2017-04-01 14:46:15 +02:00
```bash
awk '/search_pattern/ { action_to_take_if_pattern_matches; }' file_to_parse
```
Lets take following file `/etc/passwd`. Here's the sample data that this file contains:
2017-04-01 14:46:15 +02:00
```
root:x:0:0:root:/root:/usr/bin/zsh
daemon:x:1:1:daemon:/usr/sbin:/usr/sbin/nologin
bin:x:2:2:bin:/bin:/usr/sbin/nologin
sys:x:3:3:sys:/dev:/usr/sbin/nologin
sync:x:4:65534:sync:/bin:/bin/sync
```
So now lets get only username from this file. Where `-F` specifies that on which base we are going to separate the fields. In our case it's `:`. `{ print $1 }` means print out the first matching field.
2017-04-01 14:46:15 +02:00
```bash
awk -F':' '{ print $1 }' /etc/passwd
```
After running the above command you will get following output.
```
root
daemon
bin
sys
sync
```
For more detail on how to use `awk`, check following [link](https://www.cyberciti.biz/faq/bash-scripting-using-awk).
2017-04-04 20:51:26 +02:00
### b. `cut`
Remove sections from each line of files
*example.txt*
```bash
red riding hood went to the park to play
```
*show me columns 2 , 7 , and 9 with a space as a separator*
```bash
cut -d " " -f2,7,9 example.txt
```
```bash
riding park play
```
### c. `echo`
Display a line of text
*display "Hello World"*
```bash
echo Hello World
```
```bash
Hello World
```
*display "Hello World" with newlines between words*
```bash
echo -ne "Hello\nWorld\n"
```
```bash
Hello
World
```
### d. `egrep`
Print lines matching a pattern - Extended Expression (alias for: 'grep -E')
*example.txt*
```bash
Lorem ipsum
dolor sit amet,
consetetur
sadipscing elitr,
sed diam nonumy
eirmod tempor
invidunt ut labore
et dolore magna
aliquyam erat, sed
diam voluptua. At
vero eos et
accusam et justo
duo dolores et ea
rebum. Stet clita
kasd gubergren,
no sea takimata
sanctus est Lorem
ipsum dolor sit
amet.
```
*display lines that have either "Lorem" or "dolor" in them.*
```bash
egrep '(Lorem|dolor)' example.txt
or
grep -E '(Lorem|dolor)' example.txt
```
```bash
Lorem ipsum
dolor sit amet,
et dolore magna
duo dolores et ea
sanctus est Lorem
ipsum dolor sit
```
### e. `fgrep`
Print lines matching a pattern - FIXED pattern matching (alias for: 'grep -F')
*example.txt*
```bash
Lorem ipsum
dolor sit amet,
consetetur
sadipscing elitr,
sed diam nonumy
eirmod tempor
foo (Lorem|dolor)
invidunt ut labore
et dolore magna
aliquyam erat, sed
diam voluptua. At
vero eos et
accusam et justo
duo dolores et ea
rebum. Stet clita
kasd gubergren,
no sea takimata
sanctus est Lorem
ipsum dolor sit
amet.
```
2017-04-06 12:06:32 +02:00
*Find the exact string '(Lorem|dolor)' in example.txt*
2017-04-04 20:51:26 +02:00
```bash
fgrep '(Lorem|dolor)' example.txt
or
grep -F '(Lorem|dolor)' example.txt
```
```bash
foo (Lorem|dolor)
```
### f. `fmt`
Simple optimal text formatter
*example: example.txt (1 line)*
```bash
Lorem ipsum dolor sit amet, consetetur sadipscing elitr, sed diam nonumy eirmod tempor invidunt ut labore et dolore magna aliquyam erat, sed diam voluptua. At vero eos et accusam et justo duo dolores et ea rebum. Stet clita kasd gubergren, no sea takimata sanctus est Lorem ipsum dolor sit amet.
```
*output the lines of example.txt to 20 character width*
```bash
cat example.txt | fmt -w 20
```
```bash
Lorem ipsum
dolor sit amet,
consetetur
sadipscing elitr,
sed diam nonumy
eirmod tempor
invidunt ut labore
et dolore magna
aliquyam erat, sed
diam voluptua. At
vero eos et
accusam et justo
duo dolores et ea
rebum. Stet clita
kasd gubergren,
no sea takimata
sanctus est Lorem
ipsum dolor sit
amet.
```
### g. `grep`
2017-04-01 09:47:13 +02:00
Looks for text inside files. You can use grep to search for lines of text that match one or many regular expressions, and outputs only the matching lines.
```bash
2017-04-01 12:19:47 +02:00
grep pattern filename
2017-04-01 09:47:13 +02:00
```
Example:
```bash
2017-04-01 09:47:13 +02:00
$ grep admin /etc/passwd
_kadmin_admin:*:218:-2:Kerberos Admin Service:/var/empty:/usr/bin/false
_kadmin_changepw:*:219:-2:Kerberos Change Password Service:/var/empty:/usr/bin/false
_krb_kadmin:*:231:-2:Open Directory Kerberos Admin Service:/var/empty:/usr/bin/false
```
You can also force grep to ignore word case by using `-i` option. `-r` can be used to search all files under the specified directory, for example:
```bash
2017-04-01 09:47:13 +02:00
$ grep -r admin /etc/
```
2017-04-01 14:54:32 +02:00
And `-w` to search for words only. For more detail on `grep`, check following [link](https://www.cyberciti.biz/faq/grep-in-bash).
2017-04-01 09:47:13 +02:00
2017-04-04 20:51:26 +02:00
### h. `nl`
Number lines of files
*example.txt*
2017-04-01 14:46:15 +02:00
```bash
2017-04-04 20:51:26 +02:00
Lorem ipsum
dolor sit amet,
consetetur
sadipscing elitr,
sed diam nonumy
eirmod tempor
invidunt ut labore
et dolore magna
aliquyam erat, sed
diam voluptua. At
vero eos et
accusam et justo
duo dolores et ea
rebum. Stet clita
kasd gubergren,
no sea takimata
sanctus est Lorem
ipsum dolor sit
amet.
2017-04-01 14:46:15 +02:00
```
2017-04-04 20:51:26 +02:00
*show example.txt with line numbers*
2017-04-01 14:46:15 +02:00
```bash
2017-04-04 20:51:26 +02:00
nl -s". " example.txt
```
```bash
1. Lorem ipsum
2. dolor sit amet,
3. consetetur
4. sadipscing elitr,
5. sed diam nonumy
6. eirmod tempor
7. invidunt ut labore
8. et dolore magna
9. aliquyam erat, sed
10. diam voluptua. At
11. vero eos et
12. accusam et justo
13. duo dolores et ea
14. rebum. Stet clita
15. kasd gubergren,
16. no sea takimata
17. sanctus est Lorem
18. ipsum dolor sit
19. amet.
2017-04-01 14:46:15 +02:00
```
2017-04-04 20:51:26 +02:00
### i. `sed`
Stream editor for filtering and transforming text
*example.txt*
```bash
Hello This is a Test 1 2 3 4
```
*replace all spaces with hyphens*
```bash
sed 's/ /-/g' example.txt
```
```bash
Hello-This-is-a-Test-1-2-3-4
```
*replace all digits with "d"*
```bash
sed 's/[0-9]/d/g' example.txt
```
```bash
Hello This is a Test d d d d
```
2017-04-01 14:46:15 +02:00
2017-04-04 20:51:26 +02:00
### j. `sort`
Sort lines of text files
*example.txt*
```bash
f
b
c
g
a
e
d
```
*sort example.txt*
```bash
sort example.txt
```
```bash
a
b
c
d
e
f
g
```
*randomize a sorted example.txt*
```bash
sort example.txt | sort -R
```
```bash
b
f
a
2017-04-04 20:51:26 +02:00
c
d
g
e
```
2017-04-01 14:46:15 +02:00
2017-04-04 20:51:26 +02:00
### k. `tr`
Translate or delete characters
2017-04-01 14:46:15 +02:00
*example.txt*
```bash
Hello World Foo Bar Baz!
```
*take all lower case letters and make them upper case*
```bash
cat example.txt | tr 'a-z' 'A-Z'
```
```bash
HELLO WORLD FOO BAR BAZ!
```
*take all spaces and make them into newlines*
```bash
cat example.txt | tr ' ' '\n'
```
```bash
Hello
World
Foo
Bar
Baz!
```
2017-04-04 20:51:26 +02:00
### l. `uniq`
Report or omit repeated lines
*example.txt*
```bash
2017-04-04 20:51:26 +02:00
a
a
b
a
b
c
d
c
```
2017-04-04 20:51:26 +02:00
*show only unique lines of example.txt (first you need to sort it, otherwise it won't see the overlap)*
```bash
2017-04-04 20:51:26 +02:00
sort example.txt | uniq
```
```bash
2017-04-04 20:51:26 +02:00
a
b
c
d
```
2017-04-04 20:51:26 +02:00
*show the unique items for each line, and tell me how many instances it found*
```bash
2017-04-04 20:51:26 +02:00
sort example.txt | uniq -c
```
```bash
2017-04-04 20:51:26 +02:00
3 a
2 b
2 c
1 d
```
2017-04-04 20:51:26 +02:00
### m. `wc`
Tells you how many lines, words and characters there are in a file.
```bash
2017-04-04 20:51:26 +02:00
wc filename
```
2017-04-04 20:51:26 +02:00
Example:
```bash
2017-04-04 20:51:26 +02:00
$ wc demo.txt
7459 15915 398400 demo.txt
```
2017-04-04 20:51:26 +02:00
Where `7459` is lines, `15915` is words and `398400` is characters.
2017-04-01 14:46:15 +02:00
## 1.3. Directory Operations
2017-04-01 09:47:13 +02:00
2017-04-01 10:21:38 +02:00
<table>
<tr>
2017-04-04 20:51:26 +02:00
<td><a href="#a-cd">cd</a></td>
<td><a href="#b-mkdir">mkdir</a></td>
<td><a href="#c-pwd">pwd</a></td>
2017-04-01 10:21:38 +02:00
</tr>
</table>
2017-04-04 20:51:26 +02:00
### a. `cd`
Moves you from one directory to other. Running this
```bash
2017-04-01 09:47:13 +02:00
$ cd
```
moves you to home directory. This command accepts an optional `dirname`, which moves you to that directory.
```bash
2017-04-01 12:19:47 +02:00
cd dirname
2017-04-01 09:47:13 +02:00
```
2017-04-04 20:51:26 +02:00
### b. `mkdir`
Makes a new directory.
```bash
mkdir dirname
```
2017-04-01 09:47:13 +02:00
### c. `pwd`
Tells you which directory you currently are in.
```bash
2017-04-01 09:47:13 +02:00
pwd
```
2017-04-01 14:46:15 +02:00
## 1.4. SSH, System Info & Network Operations
2017-04-01 09:47:13 +02:00
<table>
<tr>
2017-04-04 20:51:26 +02:00
<td><a href="#a-bg">bg</a></td>
<td><a href="#b-cal">cal</a></td>
<td><a href="#c-date">date</a></td>
<td><a href="#d-df">df</a></td>
<td><a href="#e-dig">dig</a></td>
<td><a href="#f-du">du</a></td>
<td><a href="#g-fg">fg</a></td>
<td><a href="#h-finger">finger</a></td>
<td><a href="#i-jobs">jobs</a></td>
<td><a href="#j-last">last</a></td>
</tr>
<tr>
2017-05-02 08:34:26 +02:00
<td><a href="#k-man">man</a></td>
<td><a href="#l-passwd">passwd</a></td>
<td><a href="#m-ping">ping</a></td>
<td><a href="#n-ps">ps</a></td>
<td><a href="#o-quota">quota</a></td>
<td><a href="#p-scp">scp</a></td>
<td><a href="#q-ssh">ssh</a></td>
<td><a href="#r-top">top</a></td>
<td><a href="#s-uname">uname</a></td>
<td><a href="#t-uptime">uptime</a></td>
</tr>
<tr>
2017-05-02 08:34:26 +02:00
<td><a href="#u-w">w</a></td>
<td><a href="#v-wget">wget</a></td>
<td><a href="#w-whoami">whoami</a></td>
<td><a href="#x-whois">whois</a></td>
</tr>
</table>
2017-04-04 20:51:26 +02:00
### a. `bg`
Lists stopped or background jobs; resume a stopped job in the background.
2017-04-01 09:47:13 +02:00
2017-04-04 20:51:26 +02:00
### b. `cal`
Shows the month's calendar.
2017-04-01 09:47:13 +02:00
2017-04-04 20:51:26 +02:00
### c. `date`
Shows the current date and time.
2017-04-01 09:47:13 +02:00
2017-04-04 20:51:26 +02:00
### d. `df`
Shows disk usage.
2017-04-01 09:47:13 +02:00
2017-04-04 20:51:26 +02:00
### e. `dig`
Gets DNS information for domain.
```bash
2017-04-04 20:51:26 +02:00
dig domain
2017-04-01 09:47:13 +02:00
```
2017-04-04 20:51:26 +02:00
### f. `du`
Shows the disk usage of files or directories. For more information on this command check this [link](http://www.linfo.org/du.html)
```bash
du [option] [filename|directory]
```
Options:
- `-h` (human readable) Displays output it in kilobytes (K), megabytes (M) and gigabytes (G).
- `-s` (supress or summarize) Outputs total disk space of a directory and supresses reports for subdirectories.
Example:
2017-04-05 21:38:43 +02:00
```bash
du -sh pictures
1.4M pictures
2017-04-01 09:47:13 +02:00
```
2017-04-04 20:51:26 +02:00
### g. `fg`
Brings the most recent job in the foreground.
2017-04-01 09:47:13 +02:00
2017-04-04 20:51:26 +02:00
### h. `finger`
Displays information about user.
```bash
2017-04-04 20:51:26 +02:00
finger username
2017-04-01 09:47:13 +02:00
```
### i. `jobs`
Lists the jobs running in the background, giving the job number.
2017-04-01 09:47:13 +02:00
### j. `last`
2017-04-04 20:51:26 +02:00
Lists your last logins of specified user.
```bash
last yourUsername
```
2017-04-01 09:47:13 +02:00
### k. `man`
2017-04-04 20:51:26 +02:00
Shows the manual for specified command.
```bash
man command
```
2017-04-01 09:47:13 +02:00
### l. `passwd`
2017-04-04 20:51:26 +02:00
Allows the current logged user to change his password.
2017-04-01 09:47:13 +02:00
### m. `ping`
Pings host and outputs results.
```bash
2017-04-01 12:19:47 +02:00
ping host
2017-04-01 09:47:13 +02:00
```
### n. `ps`
2017-04-04 20:51:26 +02:00
Lists your processes.
```bash
2017-04-04 20:51:26 +02:00
ps -u yourusername
2017-04-01 09:47:13 +02:00
```
Use the flags ef. e for every process and f for full listing.
```bash
ps -ef
```
2017-04-01 09:47:13 +02:00
### o. `quota`
2017-04-04 20:51:26 +02:00
Shows what your disk quota is.
```bash
2017-04-04 20:51:26 +02:00
quota -v
2017-04-01 09:47:13 +02:00
```
### p. `scp`
Transfer files between a local host and a remote host or between two remote hosts.
*copy from local host to remote host*
```bash
scp source_file user@host:directory/target_file
```
*copy from remote host to local host*
```bash
scp user@host:directory/source_file target_file
scp -r user@host:directory/source_folder target_folder
```
2017-04-04 19:33:58 +02:00
This command also accepts an option `-P` that can be used to connect to specific port.
```bash
scp -P port user@host:directory/source_file target_file
```
### q. `ssh`
2017-04-04 20:51:26 +02:00
ssh (SSH client) is a program for logging into and executing commands on a remote machine.
```bash
ssh user@host
```
This command also accepts an option `-p` that can be used to connect to specific port.
```bash
ssh -p port user@host
```
### r. `top`
2017-04-04 20:51:26 +02:00
Displays your currently active processes.
### s. `uname`
2017-04-04 20:51:26 +02:00
Shows kernel information.
```bash
uname -a
```
### t. `uptime`
2017-04-04 20:51:26 +02:00
Shows current uptime.
### u. `w`
2017-04-04 20:51:26 +02:00
Displays who is online.
### v. `wget`
2017-04-04 20:51:26 +02:00
Downloads file.
```bash
wget file
```
### w. `whoami`
2017-04-04 20:51:26 +02:00
Return current logged in username.
### x. `whois`
2017-04-04 20:51:26 +02:00
Gets whois information for domain.
```bash
whois domain
```
## 1.5. Process Monitoring Operations
<table>
<tr>
<td><a href="#a-kill">kill</a></td>
<td><a href="#b-killall">killall</a></td>
<td><a href="#c-&">&amp;</a></td>
2017-04-24 21:44:09 +02:00
<td><a href="#d-nohup">nohup</a></td>
</tr>
</table>
### a. `kill`
Kills (ends) the processes with the ID you gave.
```bash
kill PID
```
### b. `killall`
Kill all processes with the name.
```bash
killall processname
```
2017-04-24 21:45:41 +02:00
### c. &
The `&` symbol instructs the command to run as a background process in a subshell.
```bash
command &
```
### d. `nohup`
nohup stands for "No Hang Up". This allows to run command/process or shell script that can continue running in the background after you log out from a shell.
```bash
nohup command
```
Combine it with `&` to create background processes
```bash
nohup command &
```
2017-04-01 09:47:13 +02:00
# 2. Basic Shell Programming
2017-04-01 15:03:37 +02:00
2017-04-04 19:33:58 +02:00
The first line that you will write in bash script files is called `shebang`. This line in any script determines the script's ability to be executed like a standalone executable without typing sh, bash, python, php etc beforehand in the terminal.
2017-04-01 15:03:37 +02:00
```bash
#!/bin/bash
```
2017-04-01 09:47:13 +02:00
## 2.1. Variables
Creating variables in bash is similar to other languages. There are no data types. A variable in bash can contain a number, a character, a string of characters, etc. You have no need to declare a variable, just assigning a value to its reference will create it.
2017-04-01 09:47:13 +02:00
Example:
```bash
2017-04-01 09:47:13 +02:00
str="hello world"
```
The above line creates a variable `str` and assigns "hello world" to it. The value of variable is retrieved by putting the `$` in the beginning of variable name.
2017-04-01 09:47:13 +02:00
Example:
```bash
2017-04-01 09:47:13 +02:00
echo $str # hello world
```
## 2.2. Array
Like other languages bash has also arrays. An array is variable containing multiple values. There's no maximum limit on the size of array. Array in bash are zero based. The first element is indexed with element 0. There are several ways for creating arrays in bash. Which are given below.
2017-04-01 09:47:13 +02:00
Examples:
```bash
2017-04-01 09:47:13 +02:00
array[0] = val
array[1] = val
array[2] = val
array=([2]=val [0]=val [1]=val)
array=(val val val)
2017-04-01 09:47:13 +02:00
```
To display a value at specific index use following syntax:
2017-04-01 09:47:13 +02:00
```bash
2017-04-01 09:47:13 +02:00
${array[i]} # where i is the index
```
If no index is supplied, array element 0 is assumed. To find out how many values there are in the array use the following syntax:
2017-04-01 09:47:13 +02:00
```bash
2017-04-01 09:47:13 +02:00
${#array[@]}
```
Bash has also support for the ternary conditions. Check some examples below.
```bash
2017-04-01 09:47:13 +02:00
${varname:-word} # if varname exists and isn't null, return its value; otherwise return word
${varname:=word} # if varname exists and isn't null, return its value; otherwise set it word and then return its value
${varname:+word} # if varname exists and isn't null, return word; otherwise return null
${varname:offset:length} # performs substring expansion. It returns the substring of $varname starting at offset and up to length characters
```
## 2.3 String Substitution
2017-04-01 09:47:13 +02:00
Check some of the syntax on how to manipulate strings
```bash
2017-04-01 09:47:13 +02:00
${variable#pattern} # if the pattern matches the beginning of the variable's value, delete the shortest part that matches and return the rest
${variable##pattern} # if the pattern matches the beginning of the variable's value, delete the longest part that matches and return the rest
${variable%pattern} # if the pattern matches the end of the variable's value, delete the shortest part that matches and return the rest
${variable%%pattern} # if the pattern matches the end of the variable's value, delete the longest part that matches and return the rest
${variable/pattern/string} # the longest match to pattern in variable is replaced by string. Only the first match is replaced
${variable//pattern/string} # the longest match to pattern in variable is replaced by string. All matches are replaced
${#varname} # returns the length of the value of the variable as a character string
```
## 2.4. Functions
2017-04-01 09:47:13 +02:00
As in almost any programming language, you can use functions to group pieces of code in a more logical way or practice the divine art of recursion. Declaring a function is just a matter of writing function my_func { my_code }. Calling a function is just like calling another program, you just write its name.
```bash
2017-05-14 13:17:29 +02:00
function name() {
2017-04-01 09:47:13 +02:00
shell commands
}
```
Example:
```bash
2017-04-01 09:47:13 +02:00
#!/bin/bash
function hello {
echo world!
}
hello
function say {
echo $1
}
say "hello world!"
```
When you run the above example the `hello` function will output "world!". The above two functions `hello` and `say` are identical. The main difference is function `say`. This function, prints the first argument it receives. Arguments, within functions, are treated in the same manner as arguments given to the script.
2017-04-01 09:47:13 +02:00
## 2.5. Conditionals
2017-04-01 09:47:13 +02:00
The conditional statement in bash is similar to other programming languages. Conditions have many form like the most basic form is `if` expression `then` statement where statement is only executed if expression is true.
```bash
2017-04-01 09:47:13 +02:00
if [expression]; then
will execute only if expression is true
else
will execute if expression is false
fi
```
Sometime if conditions becoming confusing so you can write the same condition using the `case statements`.
```bash
2017-04-01 09:47:13 +02:00
case expression in
pattern1 )
statements ;;
pattern2 )
statements ;;
...
esac
```
Expression Examples:
```bash
2017-04-01 09:47:13 +02:00
statement1 && statement2 # both statements are true
statement1 || statement2 # at least one of the statements is true
2017-04-01 09:47:13 +02:00
str1=str2 # str1 matches str2
str1!=str2 # str1 does not match str2
str1<str2 # str1 is less than str2
str1>str2 # str1 is greater than str2
-n str1 # str1 is not null (has length greater than 0)
-z str1 # str1 is null (has length 0)
-a file # file exists
-d file # file exists and is a directory
-e file # file exists; same -a
-f file # file exists and is a regular file (i.e., not a directory or other special type of file)
-r file # you have read permission
-s file # file exists and is not empty
-w file # you have write permission
2017-04-01 09:47:13 +02:00
-x file # you have execute permission on file, or directory search permission if it is a directory
-N file # file was modified since it was last read
-O file # you own file
-G file # file's group ID matches yours (or one of yours, if you are in multiple groups)
file1 -nt file2 # file1 is newer than file2
file1 -ot file2 # file1 is older than file2
-lt # less than
-le # less than or equal
-eq # equal
-ge # greater than or equal
-gt # greater than
-ne # not equal
```
## 2.6. Loops
2017-04-01 09:47:13 +02:00
There are three types of loops in bash. `for`, `while` and `until`.
Different `for` Syntax:
```bash
2017-04-01 09:47:13 +02:00
for x := 1 to 10 do
begin
statements
end
for name [in list]
do
statements that can use $name
done
for (( initialisation ; ending condition ; update ))
do
statements...
done
```
`while` Syntax:
```bash
2017-04-01 09:47:13 +02:00
while condition; do
statements
done
```
`until` Syntax:
```bash
2017-04-01 09:47:13 +02:00
until condition; do
statements
done
```
# 3. Tricks
2017-04-01 09:47:13 +02:00
2017-04-04 05:06:11 +02:00
## Set an alias
2017-04-01 09:47:13 +02:00
Open `bash_profile` by running following command `nano ~/.bash_profile`
> alias dockerlogin='ssh www-data@adnan.local -p2222' # add your alias in .bash_profile
2017-04-04 05:06:11 +02:00
## To quickly go to a specific directory
2017-04-01 09:47:13 +02:00
nano ~/.bashrc
> export hotellogs="/workspace/hotel-api/storage/logs"
```bash
2017-04-01 09:47:13 +02:00
source ~/.bashrc
cd $hotellogs
```
2017-04-01 09:47:13 +02:00
2017-04-16 10:02:21 +02:00
## Exit traps
Make your bash scripts more robust by reliably performing cleanup.
```bash
function finish {
# your cleanup here. e.g. kill any forked processes
jobs -p | xargs kill
}
trap finish EXIT
```
## Saving your environment variables
When you do `export FOO = BAR`, your variable is only exported in this current shell and all its children, to persist in the future you can simply append in your `~/.bash_profile` file the command to export your variable
```bash
echo export FOO=BAR >> ~/.bash_profile
```
## Accessing your scripts
You can easily access your scripts by creating a bin folder in your home with `mkdir ~/bin`, now all the scripts you put in this folder you can access in any directory.
If you can not access, try append the code below in your `~/.bash_profile` file and after do `source ~/.bash_profile`.
```bash
# set PATH so it includes user's private bin if it exists
if [ -d "$HOME/bin" ] ; then
PATH="$HOME/bin:$PATH"
fi
```
# 4. Debugging
2017-04-01 09:47:13 +02:00
You can easily debug the bash script by passing different options to `bash` command. For example `-n` will not run commands and check for syntax errors only. `-v` echo commands before running them. `-x` echo commands after command-line processing.
```bash
2017-04-01 09:47:13 +02:00
bash -n scriptname
bash -v scriptname
bash -x scriptname
```
2017-04-01 15:03:37 +02:00
## Contribution
- Report issues [How to](https://help.github.com/articles/creating-an-issue/)
- Open pull request with improvements [How to](https://help.github.com/articles/about-pull-requests/)
2017-04-01 15:03:37 +02:00
- Spread the word
2017-05-07 20:04:37 +02:00
## Translation
- [Chinese | 简体中文](https://github.com/vuuihc/bash-guide)
2017-05-07 20:04:37 +02:00
- [Turkish | Türkçe](https://github.com/omergulen/bash-guide)
2017-06-30 05:03:43 +02:00
- [Japanese | 日本語](https://github.com/itooww/bash-guide)
2017-05-07 20:04:37 +02:00
2017-04-01 15:03:37 +02:00
## License
[![License: CC BY 4.0](https://img.shields.io/badge/License-CC%20BY%204.0-lightgrey.svg)](https://creativecommons.org/licenses/by/4.0/)