Newer
Older
A [Linux](https://www.kernel.org/) önmaga csak egy kernel, nem tartalmaz egy programot sem.
Amikor Linuxról beszélünk, általában GNU/Linux-ra gondolunk,
ami azt jelenti, hogy Linux kernelen futtatunk [GNU
rendszerprogramokat](https://www.gnu.org/software/coreutils/) és könyvtárakat.
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
<Note type="warning" label="Megjegyzés">
Ha Linux-ot mondunk ebben a segédletben, sok esetben itt is
GNU/Linux-ra gondolunk
</Note>
<Note type="tip" label="Extra infó">
Vannak nem GNU programokat használó Linux [disztribúciók](#disztribúciók) is,
pl: az Alpine Linux vagy az Android
</Note>
### Disztribúciók
Nem lenne túl kényelmes kézzel lefordítani és helyére másolni
minden programot (beleértve a fordítót és kernelt is).
Ennek a problémának az áthidalására születtek meg
a Linux disztribúciók, vagy röviden disztrók.
Egy disztró feladatai:
- telepítés megkönnyítése
- telepítő diszk, akár grafikus telepítővel
- telepítéskor alap rendszerprogramok feltelepítése
- használat megkönnyítése
- csomagkezelő biztosítása a könnyű és biztonságos
programtelepítéshez
- értelmes alapbeállítások programokhoz
- segítségkérés
- minden disztrónak van fóruma, soknak wikije is,
így az esetleges hibákra gyorsan lehet találni megoldást
[Nagyon sok disztró van](https://upload.wikimedia.org/wikipedia/commons/8/83/Linux_Distribution_Timeline_27_02_21.svg),
mindenki meg tudja találni a magának megfelelőt.
Az [Ubuntu](https://ubuntu.com/) a legelterjedtebb disztró,
a továbbiakban is Ubuntut fogunk használni, de a legtöbb dolog
univerzális.
### GUI
Linux-ra van nagyon sokféle GUI shell (vagy Desktop Environment, DE),
a legelterjedtebbek a
Gnome, KDE, Xfce.
<center>
<ImageZoom
src="pics/ubuntu.jpg"
/>
Gnome Ubuntun
<br>
</center>
<br>
<center>
<ImageZoom
src="pics/kde.jpg"
/>
KDE
<br>
</center>
<br>
<center>
<ImageZoom
src="pics/xfce.png"
/>
Xfce
<br>
</center>
<br>
<center>
<ImageZoom
src="pics/elementary.png"
/>
elementary OS
<br>
</center>
<br>
Az asztali számítógépre szánt disztrókon általában alapértelmezetten
telepítve van valamilyen DE.
Ez a fejezet sok fogalmat tartalmaz, kérlek **_ne_** magold be ezeket.
Csupán annyi a célja a fejezetnek, hogy akik nemigazán
használtak CLI-t, azoknak bemutasson pár alapelemet.
A fő cél, hogy értsd, tudd használni; nem az, hogy tudd a definíciókat.
</Note>
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
### CLI
**C**ommand **L**ine **I**nterface,
egy felhasználói felület, ami alapvetően szövegesen kommunikál a userrel.
Szöveg be → szöveg ki.
Ennél sokkal bővebben nem hiszem,
hogy bárkinek is be kell mutatni, hogy mit jelent.
### Terminál
Ez jeleníti meg a karaktereket és adja meg a programnak a beírt karaktereket.
Régebben külön céleszközök voltak, ma már programok.
### Shell
Egy olyan CLI program, amibe parancsokat lehet bepötyögni és a shell
a megfelelő programokat elindítva és összekapcsolva<sup>(erről később lesz szó)</sup>
lefuttatja azt.
### Pár ismertebb shell
#### `sh`
[Bourne shell](https://en.wikipedia.org/wiki/Bourne_shell)
(a készítőjének neve után) vagy
[POSIX shell](https://en.wikipedia.org/wiki/Unix_shell)
Egy butább shell, ami megtalálható minden UNIX-szerű számítógépen.
Jó régen, az eredeti UNIX-hoz hozták létre a Bourne shell-t, ami később
[bővítve](https://en.wikipedia.org/wiki/KornShell), majd specifikálva lett a
[POSIX](https://en.wikipedia.org/wiki/POSIX) szabványban.
#### `bash`
**B**ourne-**a**gain **sh**ell, dupla szójáték. 😉
A [bash](https://en.wikipedia.org/wiki/Bash_(Unix_shell)) az alapértelmezett shell a Linux disztribúciók
túlnyomó többségén. Később ezzel fogunk dolgozni.
Kellően okos és többnyire elvárható, hogy ott legyen mindenhol, ahova beléptek.
A hatalmas elterjedtsége (és nagy kompatibilitása) miatt esett erre a választás.
#### `zsh`
[zsh](https://en.wikipedia.org/wiki/Z_shell) vagy Z shell.
Gyakorlatilag a bash kibővítése,
a legtöbb Linuxos disztrón csomagkezelővel telepíthető,
emellett macOS-en alap shell. Minden bash parancs működik itt is,
de nem minden zsh parancs működik bash-ben.
#### `fish`
[fish](https://en.wikipedia.org/wiki/Fish_(Unix_shell)),
**f**riendly **i**nteractive **sh**ell.
Különlegessége, hogy kifejezetten felhasználóbarátnak van tervezve,
alapbeállításokkal is nagyon kényelmes használni.
Azonban *nem* POSIX shell, vagyis a következőekben bemutatott parancsok
nem feltétlenül működnek benne.
Innentől bash-ről lesz szó. Ha olyat olvasol, hogy
"írjuk be a shellünkbe", akkor ott a "bashünkre" gondolunk.
</Note>
### Hogy is néz ki?
TL;DR: sokféleképpen.
Például sok helyen így néz ki az alap beállításokkal:
[mike@thinkyboi ~]$ ls *.pdf
mozilla.pdf
[mike@thinkyboi ~]$ ls *.txt
asd.txt ize.txt metrics.txt pcr2.txt pcrtouse.txt pcr.txt
[mike@thinkyboi ~]$ ls *.txt | grep rt
pcrtouse.txt
[mike@thinkyboi ~]$
```
Ez mit is mutat?
- `[mike@thinkyboi ~]$`: a prompt
- mutatja, hogy a `mike` user van belépve
- a `thinkyboi` nevű számítógépre
- éppen a `~` mappában vagyunk
- sima user jogosultságokkal `$`
- `ls *.pdf`: egy parancs, ami minden .pdf végű fájlt kilistáz
- `ls *.txt`: egy parancs, ami minden .txt végű fájlt kilistáz
- `ls *.txt | grep rt`: egy parancs, ami minden .txt végű fájlt kilistáz, mely nevében megtalálható az "rt"
Ne ijedjünk meg az ismeretlen fogalmaktól, erről mind lesz szó bővebben.
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
- parancs: egy program, a kapcsolói, és egyéb opciók
- általában: `parancs --kapcsoló -k fájl.txt`
- kapcsolók: programok különböző funkcióit
lehet velük ki-be kapcsolni
- pl:
- `ls -la`: kilistáza a mostani mappa tartalmát
- `ls`: listázó program
- `-l`: listaként jelenjen meg
- `-a`: rejtett fájlokat is megjeleníti
- `ls -a en_mappam`: kilistázza az `en_mappam` mappa tartalmát
a rejtett fájlokkal együtt
- `ip address`: kiírja a gépünk IP címeit
- `cd en_mappam`: belelép az `en_mappam` mappába
- `cd ..`: egy mappával feljebb lép
- redirekció (`>`, `<`)
- `>`: átirányítja egy program kimenetét egy fájlba
- `<`: egy program konzolos bemenetét egy fájlból olvassa
- pl:
- `ls > fajlok.txt`: a jelenlegi mappában létrehozza
a `fajlok.txt` fájlt és beleírja a jelenlegi
mappában lévő fájlok és mappák neveit
- pipe (`|`)
- egy program kimenetét beleírja egy másik program bemenetébe
- pl:
- `ls -l *.txt | grep alma`:
- `ls -l *.txt`: kíírja a jelenlegi mappában lévő
txt fájlok neveit, ez lesz a grep bemenete
- `grep alma`: kiszűri a bementén kapott szövegből
azokat a sorokat, amikben nem szerepel az alma szó
- → kilistázza azokat a txt fájlokat, amelyek nevében
szerepel az, hogy alma.
- shell execution `"$(parancs)"`
- egy program kimenetét beleteszi egy stringbe
- pl:
- `echo a mappa tartalma: $(ls)`
#### [Egyéb hasznos shell cuccok](https://devhints.io/bash)
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
- `nano`: egyszerű szövegszerkesztő
- terminál alján kiír pár támogatott billentyűkombinációt
- használat:
- `nano <fájl>`
- írkáljunk
- `CTRL+S` ment
- `CTRL+X` bezár
- `vi`: bonyolultabb picivel, de többet tud
- `vim`: vi improved, továbbfejlesztés
- `nvim`: neovim, vim továbbfejlesztés
- használat
- `vim <fájl>`
- `i` (insert mode)
- írkáljunk
- `ESC` (normal mode)
- `:wq` (parancs: write, quit)
- a fejlettebb funkcióit nem mutatjuk most be
### Fontosabb shell parancsok/programok
- `ls`: listáz
- `man <parancs>`: "manual", felhasználói útmutató programokhoz
- pl: `man ip`
- `cat <fájlok>`: fájlokat ír ki
- `less`: a bemenetén kapott szöveget görgeti, így lassabban
lehet olvasni, mint ahogy jön
- `echo <szöveg>`: kiír egy szöveget
- `cd <mappa>`: mappát vált
- `mkdir <mappa>`: mappa létrehozása
- `rm <fájlok>`: fájlok törlése
- `rmdir <mappa>`: mappa törlése
- `touch <fájl>`: üres fájl létrehozása
**Gyakorlatilag egy program, amit tudsz telepíteni.**
A különböző programokat nevezzük csomagoknak (package), melyek
a bináris (futtatható) fájlokon kívül különböző konfigurációs fájlokat és
a program más programoktól való függőségeit is tartalmazza.
A programokat telepíthetjük [kézzel](http://www.linuxfromscratch.org/lfs/downloads/stable/LFS-BOOK-10.1.pdf) (8.2-es fejezet), de ez
ezért csomagkezelőt (package manager) szoktunk használni a csomagok
telepítéséhez. A csomagkezelő egy egyszerű program, mellyel biztonságosan telepíthetünk,
frissíthetünk, eltávolíthatunk és kereshetünk csomagokat.
Egy csomagkezelő frissen tudja tartani a rendszert, kezeli a függőségeket és ütközéseket.
Mi az apt nevű csomagkezelőt fogjuk használni a továbbiakban.
```shell-session {highlight: [1, 3, 12, 24, 33, 42, 51, 59, 61]}
[patrik@patrik-laptop ~]$ cowsay test
bash: cowsay: command not found
Get:1 http://archive.ubuntu.com/ubuntu focal InRelease [265 kB]
Get:2 http://security.ubuntu.com/ubuntu focal-security InRelease [109 kB]
[...]
Fetched 17.2 MB in 2s (11.2 MB/s)
Reading package lists... Done
Building dependency tree
Reading state information... Done
1 package can be upgraded. Run 'apt list --upgradable' to see it.
Sorting... Done
Full Text Search... Done
cowsay/focal 3.03+dfsg2-7 all
configurable talking cow
cowsay-off/focal 3.03+dfsg2-7 all
configurable talking cow (offensive cows)
xcowsay/focal 1.5-1 amd64
Graphical configurable talking cow
Reading package lists... Done
Building dependency tree
Reading state information... Done
[...]
After this operation, 46.4 MB of additional disk space will be used.
Do you want to continue? [Y/n] y
[...]
Setting up cowsay (3.03+dfsg2-7) ...
[patrik@patrik-laptop ~]$ cowsay test
______
< test >
------
\ ^__^
\ (oo)\_______
(__)\ )\/\
||----w |
|| ||
[...]
The following packages will be upgraded:
libzstd1
1 upgraded, 0 newly installed, 0 to remove and 0 not upgraded.
Need to get 237 kB of archives.
After this operation, 0 B of additional disk space will be used.
Do you want to continue? [Y/n] y
[...]
[...]
The following packages will be REMOVED:
cowsay
0 upgraded, 0 newly installed, 1 to remove and 0 not upgraded.
After this operation, 93.2 kB disk space will be freed.
Do you want to continue? [Y/n] y
Removing cowsay (3.03+dfsg2-7) ...
[patrik@patrik-laptop ~]$ cowsay test
bash: cowsay: command not found
[patrik@patrik-laptop ~]$
<Note type="success" label="Infó">
Ahogy látod, kihagytunk részeket a parancsok kimenetéből.
Ez azért van, mert nem fér bele értelmesen a doksiba.
A videón látható ezek kimenete, de bátran próbáljátok ki ti is.
</Note>
Az `apt update` paranccsal frissíthetjük az apt adatbázisát, mely a
csomagok elérhetőségéről tárol adatokat.
Az `apt search a_csomag_neve` paranccsal a csomagkezelő megkeresi a
hasonló nevű csomagokat és kilistázza azokat.
Az `apt install a_csomag_neve` paranccsal a megadott csomagot telepíti a
csomagkezelő, ha azt megtalálja.
Az `apt upgrade` paranccsal a telepített csomagokhoz elérhető frissítéseket
telepíti a csomagkezelő.
Az `apt remove a_csomag_neve` paranccsal a megadott csomag távolítható el.
A különböző Linux disztribúciók különböző csomagkezelőket használnak, ilyenek például
az alábbi táblázatban található csomagkezelők is. Néhány csomagkezelő disztribúcióhoz van kötve,
azonban egyre jobban kezdenek elterjedni a disztribúcióktól független csomagkezelők is.
- `apt`: Debian és Ubuntu alapú disztrókon
- `dnf`: Red Hat (alapú) disztrók: Fedora, CentOS, Red Hat Enterprise Linux
- `pacman`: Arch Linux, Manjaro
- `flatpak` és `snap`: disztrófüggetlen, mindenhol működik, ha [feltelepítjük](https://flatpak.org/setup/) egy
disztróspecifikus csomagkezelővel
| parancs | apt | dnf | pacman | snap | flatpak |
|---|---|---|---|---|---|
| telepítés | install | install | -S | install | install |
| adatbázis frissítése | update | check-update | -Sy | automatikus | a frissítéssel együtt ez is megtörténik (update) |
| frissítés | upgrade | upgrade | -Syu | automatikus (ha kézzel akarod: refresh) | update |
| törlés | remove | remove | -R | nincs ilyen | nincs ilyen |
| törlés beállításokkal | purge | nincs ilyen | -Rns | remove | uninstall |
---
<Note type="danger" label="Légy óvatos">
Itt szó lesz két azonos nevű, de különbőző dologról.
- `root` user
- `root` mappa
A kettő teljesen független egymástól, ne keverjük össze.
</Note>
UNIX-on a mappastruktúra a `/`-ből indul, ellenben a Windows-zal, ahol a
meghajtók külön betűket kapnak (`C:\ `, `D:\ `, stb).
Emellett UNIX-on a mappaelválasztó a `/`, míg Windows-on a `\ `.
Itt a rendszermeghajtó lesz a `/` <sup>(root, ejtsd: rút)</sup>,
minden mappa innen indul. Erre fel lehet csatolni (`mount`-olni) más meghajtókat is,
tetszőleges mappákba. Például, ha a rendszerünket egy SSD-re telepítjük, majd egy
HDD-t felcsatolunk a `/mnt/HDD` mappába, akkor:
- a `/home/béla/random_file.txt` az SSD-n lesz
- a `/mnt/HDD/cucc/random_file.txt` pedig a merevlemezen lesz
Ennek a megközelítésnek egy nagy előnye, hogy bármit tehetünk bárhova,
például - az előző példát folytatva - ha azt szeretnénk, hogy a fájljaink
a merevlemezen legyenek, de a rendszer és a programok az SSD-n, hogy felcsatoljuk
a merevlemezt a `/home`-ra, így a userek fájljai a merevlemezre kerülnek.
### [Könyvtárak](https://www.linux.com/training-tutorials/linux-filesystem-explained/)
A fájlrendszer mappastruktúráját nem kell tudni fejből,
elég ha tudod, hogy a konfigurációs fájlokat a `/etc`-ben szokás keresni
és a userek a `/home/<username>` alatt élnek.
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
- `/bin`: "binaries", futtatható programok
- `/boot`: bootloader, kernel és egyéb indításhoz szükséges fájl<sup>erről később lesz szó</sup>
- `/dev`: "devices", eszközök<sup>erről később lesz szó</sup>
- `/etc`: konfigurációs fájlok
- `/home`: userek fájljai
- `/lib`: "libraries", programok futásához szükséges könyvtárak
- `/lib64`: 64 bites `/lib`
- `/mnt`: felcsatolt meghajtók
- `/opt`: "optional programs", néhány program itt él <sup>(olyan programok, amik nem kötődnek a rendszerhez)</sup>
- `/proc`: futó programokról információk<sup>erről később lesz szó</sup>
- `/root`: a [root user](#user-ek-és-groupok) home-ja
- `/run`: rendszerindításonként újraépül, a futó szolgáltatásokhoz való csatlakozásban segít <!-- TODO -->
- `/sbin`: "system binaries", rendszerprogramok
- `/srv`: "servers", a gépen futtatott szerver programok fájljai
- `/sys`: "system", hardvereléréshez kell<sup>erről később lesz szó</sup>
- `/tmp`: "temporary", ideiglenes fájlok, RAM-ban tartva
- `/usr`: "user installed", a telepített csomagok pakolnak ide fájlokat
- `/var`: szolgáltatások tárhelyei
### Speciális "mappák"
- `.`: a jelenlegi mappa
- `././././.`: ez is a jelenlegi mappa, mert a jelenlegi mappa jelenlegi mappájának [...] jelenlegi mappája
- `..`: az egy szinttel feljebb lévő mappa
- `/..` == `/`, root fölé nem lehet menni
- `~`: a mi userünk home mappája
- `~béla`: a `béla` user home mappája
A UNIX permission rendszer elemei:
- user-ek
- group-ok
- módok
Minden fájl és mappa egy user-hez és egy group-hoz tartozik,
vagyis a user és a group annak a fájlnak és mappának a tulajdonosa.
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
Minden fájlra és mappára meg lehet adni, hogy mi legyen
a módja (továbbiakban permissionjei), ezek:
- `user`: a birtokló user tudja-e:
- `r`: read, olvasni
- `w`: write, írni
- `x`: futtatni (ha fájl) vagy a tartalmát listázni (ha mappa)
- `group`: a birtokló csoport tagjai tudják-e:
- `r`: olvasni
- `w`: írni
- `x`: futtatni vagy listázni
- `others`: bárki más tudja-e:
- `r`: olvasni
- `w`: írni
- `x`: futtatni vagy listázni
<Note type="tip" label="Extra infó">
Van két extra permission, a `setuid` és `setgid`.
Ezekkel meg lehet adni, hogy egy program a tulajdonos nevében
vagy tulajdonos csoport nevében fusson.
Ezt a permission-t használja pár program, amit mindennapi userek
is kell, hogy tudjanak futtatni, de mégis kell valami, csak nagyobb
jogosultsággal elérhető funkció bele.
Ezen kívül van egy ma már nem igazán használt permission is,
a "sticky bit", erről [itt](http://permissions-calculator.org/info/#sticky-bit) olvashatsz.
</Note>
Mindezek számok alapján vannak tárolva,
de a programok okosan feloldják nevekre ezeket.
Egy user az pont ugyanaz, mint aminek elképzelted,
egy felhasználó, aki tud programokat futtatni.
Egy különleges felhasználó a `root`, ő a főfelhasználó (super-user),
az ő nevében lehet csak a rendszerbeállításokat módosítani,
ez a Windows-os "Rendszergazda" vagy "Adminisztrátor" megfelelője.
Minden userhez tartozik egy ugyanolyan nevű group is, azonban egy
user több groupban is benne lehet.
### Példa a jogosultságokra
Alul látható, hogy hogy néz ki egy listázás `ls`-sel.
A permission-ök user, group, other sorrendben követik egymást.
<Note type="tip" label="Tip">
A különböző fájlokhoz/mappákhoz tartozó magyarázatokat
lenyíló szövegként tettük az oldalra, hogy össze tudd
nézni a magyarázatot és a shell-t.
</Note>
[mike@thinkyboi permissions]$ ls -la -tr
total 0
drwxr-xr-x 3 mike mike 120 Mar 11 13:19 .
drwxrwxrwt 21 root root 640 Mar 11 04:20 ..
-rw-r----- 1 root ftp 0 Mar 11 13:37 egyik
-rw-r--r-- 1 mike daemon 0 Mar 11 13:37 másik
-rwx------ 1 mike mike 0 Mar 11 13:37 harmadik
drwxr-xr-x 2 mike daemon 40 Mar 11 13:37 negyedik
-rwsr-sr-x 1 mike mike 0 Mar 11 13:37 ötödik
```
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
574
575
576
577
578
579
580
581
582
583
584
585
586
587
588
589
590
591
592
593
594
595
596
597
598
599
600
601
602
603
604
605
606
607
608
609
610
611
612
613
614
615
616
617
618
619
620
621
622
623
624
625
626
627
628
629
630
631
632
633
634
635
636
637
638
639
640
641
642
643
644
645
646
647
648
649
650
651
652
653
654
655
656
657
658
659
660
<details>
<summary>
<code>ls -la -tr</code>
</summary>
- `ls`: fájlokat és mappákat listázó program
- `-la`
- `l`: listaként
- `a`: a `.`-tal kezdődő fájlokat is
- `-tr`
- `t`: idő szerint rendezve
- `r`: visszafelé rendezve
(ezt meg lehetne adni úgy is, hogy `ls -latr`,
de az olvashatóság kevéért mi külön vettük)
</details>
<details>
<summary>
<code>.</code> (a jelenlegi mappa, vagyis `permissions`, ami a prompt-ból látszik)
</summary>
- `d`: egy mappa
- `rwx`: a birtokos usernek (`mike`) van joga:
- olvasni
- írni
- listázni
- `r-x`: a birtokos csoportnak (szintén `mike`) van joga:
- olvasni
- listázni
- `r-x`: mindenki másnak van joga:
- olvasni
- listázni
- → bárki meglesheti mi van benne, de csak `mike`
tehet bele dolgokat
</details>
<details>
<summary>
<code>..</code> (az eggyel e fölött lévő mappa)
</summary>
- `d`: egy mappa
- `rwx`: `root` user mindent csinálhat vele
- `rwx`: `root` group mindent csinálhat vele
- `rwt`: mindenki más is bármit csinálhat, de mivel a mappa
"sticky", így ha valakinél meg van nyitva valami benne, azt
más nem piszkálhatja
- `t` == `x` + sticky bit
</details>
<details>
<summary>
<code>egyik</code>
</summary>
- egy file (nem `d`-vel kezdődik a permission sor)
- `rw-`: `root` user tudja olvasni és írni
- `r--`: `ftp` csoport tagjai tudják olvasni
- `---`: a többiek nem tudnak semmit csinálni vele
</details>
<details>
<summary>
<code>másik</code>
</summary>
- egy file
- `mike` tudja olvasni és írni
- `daemon` csoport tagja tudják olvasni
- mindenki más is tudja olvasni
</details>
<details>
<summary>
<code>harmadik</code>
</summary>
- egy file
- `mike` tudja írni, olvasni, futtatni
- `x`: mivel lehet futtatni, ez vagy egy program,
vagy hibát dob, ha megpróbáljuk futtatni
</details>
<details>
<summary>
<code>negyedik</code>
</summary>
- egy mappa
- mindenki tudja olvasni és listázni, de csak `mike` tud benne
fájlt létrehozni
</details>
<details>
<summary>
<code>ötödik</code>
</summary>
- `rws`: `mike` tudja futtani, és ha futtatva van bárki által,
akkor is `mike` usere nevében fut
- `s` == `x` + setuid
- `r-s`: `mike` csoport tagjai tudják olvasni és futtatni, és
ha bárki futtatja, akkor is kap `mike` csoporttagságot a program
- `r-x`: bárki futtathatja
- → bárki olvashatja és futtathatja, és ha futtatja, akkor
`mike` nevében fog futni a program
664
665
666
667
668
669
670
671
672
673
674
675
676
677
678
679
680
681
682
683
684
685
686
687
688
689
690
691
692
693
694
695
696
697
698
699
700
701
702
703
704
705
706
707
708
709
710
711
712
713
714
715
716
717
718
719
720
721
722
723
724
725
726
727
728
729
730
731
732
733
734
735
736
737
738
739
740
741
742
743
744
745
746
747
748
749
750
751
752
753
754
755
756
757
758
759
760
761
762
763
764
765
766
767
768
769
770
771
772
773
774
775
776
777
778
779
780
781
782
783
784
785
786
787
788
789
790
791
792
793
794
795
796
797
798
799
800
801
802
803
804
805
806
807
808
809
810
811
812
813
814
### Jogosultságok megváltoztatása
Vannak különböző parancsok, melyek segítségével megváltoztathatjuk mind a user-ek,
mind a group-ok, mind a többi felhasználó jogosultságait, sőt megváltoztathajtuk a
tulajdonosokat is.
####`chmod`
Segítségével megváltoztathajtuk az állományok hozzáférési jogait (change mode).
Ha nem a saját fájljaink, mappáink jogait szeretnénk módosítani, ahhoz `sudo` is kell.
Ehhez megadjuk a `chmod` után, hogy kire vonatkozzon (user, group, others),
megadjuk, hogy hozzáférést szeretnénk-e adni vagy elvenni akarjuk azt,
valamint magát az állományt. A különböző paramétérek a következőek:
`u` - user, a birtokló user
`g` - group, a birtokló csoport tagjai
`o` - others, bárki más
`+` hozzáad egy jogot
`-` eltávolítja a jogot
`r` - read, olvasási jog
`w` - write, írási jog
`x` - execute, végrehajtási jog
Például:
`chmod u+x <fájlnév vagy mappanév>` itt a user kap listázási vagy futtatási jogot.
`chmod g-w <fájlnév vagy mappanév>` itt a group-nak szűnik meg az írási joga
Ugyanezen konvenció alapján működik mindegyik parancs.
Kicsit szemléletessebben:
```
patrik@ubuntu:~/Documents$ ls -la
total 8
drwxr-xr-x 2 patrik patrik 4096 Mar 18 19:38 .
drwxr-xr-x 15 patrik patrik 4096 Mar 17 16:20 ..
-rw-rw-r-- 1 patrik patrik 0 Mar 18 19:37 linux.pdf
-rw-rw-r-- 1 patrik patrik 0 Mar 18 19:37 pálinka.txt
-rw-rw-r-- 1 patrik patrik 0 Mar 18 19:38 pörkölt.txt
-rw-rw-r-- 1 patrik patrik 0 Mar 18 19:37 randomsorok.txt
-rw-rw-r-- 1 patrik patrik 0 Mar 18 19:37 recept.txt
patrik@ubuntu:~/Documents$ chmod o+w pörkölt.txt
patrik@ubuntu:~/Documents$ ls -la
total 8
drwxr-xr-x 2 patrik patrik 4096 Mar 18 19:38 .
drwxr-xr-x 15 patrik patrik 4096 Mar 17 16:20 ..
-rw-rw-r-- 1 patrik patrik 0 Mar 18 19:37 linux.pdf
-rw-rw-r-- 1 patrik patrik 0 Mar 18 19:37 pálinka.txt
-rw-rw-rw- 1 patrik patrik 0 Mar 18 19:38 pörkölt.txt
-rw-rw-r-- 1 patrik patrik 0 Mar 18 19:37 randomsorok.txt
-rw-rw-r-- 1 patrik patrik 0 Mar 18 19:37 recept.txt
patrik@ubuntu:~/Documents$
```
Itt a `chmod o+w pörkölt.txt` parancs segítségével mások kapnak írási jogot
a pörkölt.txt fájlhoz, ami eddig nem volt nekik.
A `-rw-rw-r--` megváltozott `-rw-rw-rw-` -ra.
Az others-re az utolsó három karakter vonatkozik, ezek közül
a második változott meg, míg eddig egy `-` jel volt, vagyis nincs joga hozzá,
most pedig `w` lett, vagyis van hozzá joga.
Ha egyszerre szeretnénk jogot adni a user-nek, group-nak, others-nek vagy elvenni,
valamint ha többféle joggal szeretnénk ezt, akkor több paramétért is megadhatunk egy parancsban.
Ezt kétféleképpen is megtehetjük:
- `chmod` `u` `g` `o` közül a kiválaszottak `+` vagy `-` az `r` `w` `x` közül a
kiválaszottak. Vagyis a bal oldalra írjuk kinek a jogait szeretnénk módosítani,
középre, hogy elvenni vagy adni szeretnénk, jobb oldalra pedig, hogy mely jogokat.
```
patrik@ubuntu:~/Documents$ chmod ug-rw pörkölt.txt
patrik@ubuntu:~/Documents$ ls -la
total 8
drwxr-xr-x 2 patrik patrik 4096 Mar 18 19:38 .
drwxr-xr-x 15 patrik patrik 4096 Mar 17 16:20 ..
-rw-rw-r-- 1 patrik patrik 0 Mar 18 19:37 linux.pdf
-rw-rw-r-- 1 patrik patrik 0 Mar 18 19:37 pálinka.txt
-------rw- 1 patrik patrik 0 Mar 18 19:38 pörkölt.txt
-rw-rw-r-- 1 patrik patrik 0 Mar 18 19:37 randomsorok.txt
-rw-rw-r-- 1 patrik patrik 0 Mar 18 19:37 recept.txt
patrik@ubuntu:~/Documents$
```
- Másik módja, hogy a különböző műveleteket vesszővel elválasztva adjuk meg.
```
patrik@ubuntu:~/Documents$ chmod u+rw,g+r,o-rw pörkölt.txt
patrik@ubuntu:~/Documents$ ls -la
total 8
drwxr-xr-x 2 patrik patrik 4096 Mar 18 19:38 .
drwxr-xr-x 15 patrik patrik 4096 Mar 17 16:20 ..
-rw-rw-r-- 1 patrik patrik 0 Mar 18 19:37 linux.pdf
-rw-rw-r-- 1 patrik patrik 0 Mar 18 19:37 pálinka.txt
-rw-r----- 1 patrik patrik 0 Mar 18 19:38 pörkölt.txt
-rw-rw-r-- 1 patrik patrik 0 Mar 18 19:37 randomsorok.txt
-rw-rw-r-- 1 patrik patrik 0 Mar 18 19:37 recept.txt
patrik@ubuntu:~/Documents$
```
####`chown`
Segítségével megváltoztatható az állományok tulajdonosa
(a change the owner rövidítése).
Egy fájl vagy mappa tulajdonosának megváltoztatásához `sudo` jog kell.
```
patrik@ubuntu:~/Documents$ sudo chown mike recept.txt
[sudo] password for patrik:
patrik@ubuntu:~/Documents$ ls -la
total 8
drwxr-xr-x 2 patrik patrik 4096 Mar 18 19:38 .
drwxr-xr-x 15 patrik patrik 4096 Mar 17 16:20 ..
-rw-rw-r-- 1 patrik patrik 0 Mar 18 19:37 linux.pdf
-rw-rw-r-- 1 patrik patrik 0 Mar 18 19:37 pálinka.txt
-rw-r----- 1 patrik patrik 0 Mar 18 19:38 pörkölt.txt
-rw-rw-r-- 1 patrik patrik 0 Mar 18 19:37 randomsorok.txt
-rw-rw-r-- 1 mike patrik 0 Mar 18 19:37 recept.txt
patrik@ubuntu:~/Documents$
```
####`chgrp`
A parancs lehetőséget ad arra, egy fájl vagy mappa csoportját megváltoztassuk
(a change group rövidítése).
Normál felhasználó akkor módosíthatja a fájl vagy mappa csoportját,
ha a régi és új csoportnak is tagja, ellenkező esetben a `sudo` parancs is szükséges.
```
patrik@ubuntu:~/Documents$ sudo chgrp mike recept.txt
patrik@ubuntu:~/Documents$ ls -la
total 8
drwxr-xr-x 2 patrik patrik 4096 Mar 18 19:38 .
drwxr-xr-x 15 patrik patrik 4096 Mar 17 16:20 ..
-rw-rw-r-- 1 patrik patrik 0 Mar 18 19:37 linux.pdf
-rw-rw-r-- 1 patrik patrik 0 Mar 18 19:37 pálinka.txt
-rw-r----- 1 patrik patrik 0 Mar 18 19:38 pörkölt.txt
-rw-rw-r-- 1 patrik patrik 0 Mar 18 19:37 randomsorok.txt
-rw-rw-r-- 1 mike mike 0 Mar 18 19:37 recept.txt
patrik@ubuntu:~/Documents$
```