Հիմնական Linux հրամաններ փորձարկողների համար և այլն

Նախաբան

Բարեւ բոլորին! Իմ անունը Սաշա է, և ես ավելի քան վեց տարի փորձարկում եմ backend-ը (Linux ծառայություններ և API): Հոդվածի գաղափարն ինձ մոտ ծագեց փորձարկող ընկերոջ մեկ այլ խնդրանքից հետո՝ ասելու նրան, թե ինչ կարող է կարդալ Linux-ի հրամանների մասին հարցազրույցից առաջ: Սովորաբար, QA-ի ինժեների պաշտոնի թեկնածուից պահանջվում է իմանալ հիմնական հրամանները (եթե, իհարկե, դրանք ներառում են Linux-ի հետ աշխատելը), բայց ինչպե՞ս կարող եք իմանալ, թե որ հրամաններն արժե կարդալ հարցազրույցի պատրաստվելիս, եթե քիչ ունեք: կամ Linux-ի հետ փորձ չունե՞ք:

Հետևաբար, չնայած այս մասին արդեն բազմիցս գրվել է, ես դեռ որոշեցի գրել ևս մեկ հոդված «Linux սկսնակների համար» և այստեղ թվարկել այն հիմնական հրամանները, որոնք դուք պետք է իմանաք Linux-ի օգտագործող բաժանմունքում (կամ ընկերությունում) ցանկացած հարցազրույցից առաջ: Ես մտածեցի, թե որ հրամաններն ու կոմունալ ծառայությունները և ինչ պարամետրերով եմ օգտագործում ամենից հաճախ, հավաքեցի իմ գործընկերների կարծիքը և ամբողջը կազմեցի մեկ հոդվածում: Հոդվածը բաժանված է 3 մասի. նախ՝ հակիրճ տեղեկատվություն Linux տերմինալում I/O-ի հիմունքների մասին, այնուհետև ամենահիմնական հրամանների ակնարկ, իսկ երրորդ մասում նկարագրվում է, թե ինչպես լուծել ընդհանուր խնդիրները Linux-ում:

Յուրաքանչյուր հրաման ունի բազմաթիվ տարբերակներ, դրանք բոլորն այստեղ չեն նշվի: Դուք միշտ կարող եք մուտքագրել `մարդ <հրաման>«կամ».<հրաման> - օգնություն«Թիմի մասին ավելին իմանալու համար:

Example:

[user@testhost ~]$ mkdir --help
Usage: mkdir [OPTION]... DIRECTORY...
Create the DIRECTORY(ies), if they do not already exist.

Mandatory arguments to long options are mandatory for short options too.
  -m, --mode=MODE   set file mode (as in chmod), not a=rwx - umask
  -p, --parents     no error if existing, make parent directories as needed
  -v, --verbose     print a message for each created directory
  -Z                   set SELinux security context of each created directory
                         to the default type
      --context[=CTX]  like -Z, or if CTX is specified then set the SELinux
                         or SMACK security context to CTX
      --help     display this help and exit
      --version  output version information and exit

GNU coreutils online help: <http://www.gnu.org/software/coreutils/>
For complete documentation, run: info coreutils 'mkdir invocation'

Եթե ​​հրամանի ավարտը չափազանց երկար է տևում, կարող եք դադարեցնել այն՝ սեղմելով վահանակի վրա Ctrl + C (գործընթացին ազդանշան է ուղարկվում SIGINT- ը).

Մի փոքր հրամանի թողարկման մասին

Երբ Linux-ում գործընթացը սկսվում է, այդ գործընթացի համար ստեղծվում են 3 ստանդարտ տվյալների հոսքեր. stdin, stdout и stderr. Դրանք համարակալված են համապատասխանաբար 0, 1 և 2: Բայց հիմա մեզ հետաքրքրում է stdout և ավելի քիչ չափով, stderr. Անուններից դա հեշտ է կռահել stdout օգտագործվում է տվյալների ելքի համար և stderr — սխալի հաղորդագրություններ ցուցադրելու համար: Լռելյայնորեն Linux-ում հրաման գործարկելիս stdout и stderr թողարկեք ամբողջ տեղեկատվությունը վահանակ, սակայն, եթե հրամանի ելքը մեծ է, կարող է հարմար լինել այն վերահղել դեպի ֆայլ: Դա կարելի է անել, օրինակ, այսպես.

[user@testhost ~]$ man signal > man_signal

Եթե ​​մենք թողարկենք ֆայլի բովանդակությունը մարդ_ազդանշան, ապա մենք կտեսնենք, որ դա նույնական է, ինչ կլիներ, եթե մենք պարզապես գործարկեինք «տղամարդու ազդանշան`.

Վերահղման գործողությունը`>` լռելյայն է stdout. Դուք կարող եք նշել վերահղում stdout հստակորեն1>«. Նմանապես, դուք կարող եք նշել վերահղումը stderr``2>«. Դուք կարող եք համատեղել այս գործողությունները և այդպիսով առանձնացնել սովորական հրամանի ելքը և սխալի հաղորդագրությունը.

[user@testhost ~]$ man signal 1> man_signal 2> man_signal_error_log

Վերահղում և stdoutԻսկ stderr մեկ ֆայլի մեջ հետևյալ կերպ.

[user@testhost ~]$ man signal > man_signal 2>&1

Վերահղման գործողությունը`2> & 1- նշանակում է վերահղում stderr նույն վայրում, ինչպես նշված է stdout.

Մեկ այլ հարմար գործիք I/O-ի հետ աշխատելու համար (ավելի ճիշտ՝ միջգործընթացային հաղորդակցության համար հարմար գործիք է). խողովակ (Կամ կոնվեյեր) Խողովակաշարերը հաճախ օգտագործվում են մի քանի հրամաններ փոխանցելու համար. stdout հրամանները վերահղվում են դեպի stdin հաջորդը և այլն շղթայում.

[user@testhost ~]$ ps aux | grep docker | tail -n 2
root     1045894  0.0  0.0   7512  3704 ?        Sl   16:04   0:00 docker-containerd-shim -namespace moby -workdir /var/lib/docker/containerd/daemon/io.containerd.runtime.v1.linux/moby/2fbfddaf91c1bb7b9a0a6f788f3505dd7266f1139ad381d5b51ec1f47e1e7b28 -address /var/run/docker/containerd/docker-containerd.sock -containerd-binary /usr/bin/docker-containerd -runtime-root /var/run/docker/runtime-runc
531      1048313  0.0  0.0 110520  2084 pts/2    S+   16:12   0:00 grep --color=auto docker

Հիմնական Linux հրամաններ

հզ

Ցուցադրել ընթացիկ (աշխատանքային) գրացուցակը:

[user@testhost ~]$ pwd
/home/user

ամսաթիվ

Ցուցադրել ընթացիկ համակարգի ամսաթիվը և ժամը:

[user@testhost ~]$ date
Mon Dec 16 13:37:07 UTC 2019
[user@testhost ~]$ date +%s
1576503430

w

Այս հրամանը ցույց է տալիս, թե ովքեր են մուտք գործել համակարգ: Բացի այդ, էկրանին ցուցադրվում են նաև գործարկման ժամանակը և LA (բեռնվածության միջինը):

[user@testhost ~]$ w
 05:47:17 up 377 days, 17:57,  1 user,  load average: 0,00, 0,01, 0,05
USER     TTY      FROM             LOGIN@   IDLE   JCPU   PCPU WHAT
user     pts/0    32.175.94.241    05:47    2.00s  0.01s  0.00s w

ls

Տպել գրացուցակի բովանդակությունը: Եթե ​​դուք չեք անցնում ուղին, կցուցադրվի ընթացիկ գրացուցակի բովանդակությունը:

[user@testhost ~]$ pwd
/home/user
[user@testhost ~]$ ls
qqq
[user@testhost ~]$ ls /home/user
qqq
[user@testhost ~]$ ls /
bin  boot  cgroup  dev  etc  home  lib  lib64  local  lost+found  media  mnt  opt  proc  root  run  sbin  selinux  srv  swap  sys  tmp  usr  var

Անձամբ ես հաճախ եմ օգտագործում տարբերակները -l (երկար ցուցակման ձևաչափ - ելք ֆայլերի մասին լրացուցիչ տեղեկություններով սյունակում), -t (տեսակավորում ըստ ֆայլի/տեղեկատուի փոփոխման ժամանակի) և -r (հակադարձ տեսակավորում - հետ համատեղ -t ամենավերջին ֆայլերը կլինեն ներքևում):

[user@testhost ~]$ ls -ltr /
total 4194416
drwxr-xr-x    2 root root       4096 Jan  6  2012 srv
drwxr-xr-x    2 root root       4096 Jan  6  2012 selinux
drwxr-xr-x    2 root root       4096 Jan  6  2012 mnt
drwxr-xr-x    2 root root       4096 Jan  6  2012 media
drwx------    2 root root      16384 Oct  1  2017 lost+found
drwxr-xr-x    2 root root       4096 Oct  1  2017 local
drwxr-xr-x   13 root root       4096 Oct  1  2017 usr
drwxr-xr-x   11 root root       4096 Apr 10  2018 cgroup
drwxr-xr-x    4 root root       4096 Apr 10  2018 run
-rw-------    1 root root 4294967296 Sep 10  2018 swap
dr-xr-xr-x   10 root root       4096 Dec 13  2018 lib
drwxr-xr-x    6 root root       4096 Mar  7  2019 opt
drwxr-xr-x   20 root root       4096 Mar 19  2019 var
dr-xr-xr-x   10 root root      12288 Apr  9  2019 lib64
dr-xr-xr-x    2 root root       4096 Apr  9  2019 bin
dr-xr-xr-x    4 root root       4096 Apr  9  2019 boot
dr-xr-xr-x    2 root root      12288 Apr  9  2019 sbin
dr-xr-xr-x 3229 root root          0 Jul  2 10:19 proc
drwxr-xr-x   34 root root       4096 Oct 28 13:27 home
drwxr-xr-x   93 root root       4096 Oct 30 16:00 etc
dr-xr-x---   11 root root       4096 Nov  1 13:02 root
dr-xr-xr-x   13 root root          0 Nov 13 20:28 sys
drwxr-xr-x   16 root root       2740 Nov 26 08:55 dev
drwxrwxrwt    3 root root       4096 Nov 26 08:57 tmp

Կան 2 հատուկ գրացուցակի անուններ.."Եւ"..«. Առաջինը նշանակում է ընթացիկ գրացուցակը, երկրորդը՝ մայր գրացուցակը: Դրանք կարող են հարմար լինել հատկապես տարբեր թիմերում օգտագործելու համար ls:

[user@testhost home]$ pwd
/home
[user@testhost home]$ ls ..
bin  boot  cgroup  dev  etc  home  lib  lib64  local  lost+found  media  mnt  opt  proc  root  run  sbin  selinux  srv  swap  sys  tmp  usr  var
[user@testhost home]$ ls ../home/user/
qqq

Կա նաև թաքնված ֆայլեր ցուցադրելու օգտակար տարբերակ (սկսած «.") - -a:

[user@testhost ~]$ ls -a
.  ..  1  .bash_history  .bash_logout  .bash_profile  .bashrc  .lesshst  man_signal  man_signal_error_log  .mongorc.js  .ssh  temp  test  .viminfo

Կարող եք նաև օգտագործել տարբերակը -h - ելք մարդու համար ընթեռնելի ձևաչափով (ուշադրություն դարձրեք ֆայլերի չափերին).

[user@testhost ~]$ ls -ltrh
total 16K
-rwxrwx--x 1 user user   31 Nov 26 11:09 temp
-rw-rw-r-- 1 user user 6.0K Dec  3 16:02 1
drwxrwxr-x 2 user user 4.0K Dec  4 10:39 test

cd

Փոխել ընթացիկ գրացուցակը:

[user@testhost ~]$ pwd
/home/user
[user@testhost ~]$ cd /home/
[user@testhost home]$ pwd
/home

Եթե ​​գրացուցակի անունը որպես արգումենտ չփոխանցեք, շրջակա միջավայրի փոփոխականը կօգտագործվի $ HOME- ը, այսինքն՝ տնային գրացուցակը։ Այն կարող է նաև հարմար լինել օգտագործելու համար~«Հատուկ բնույթի նշանակություն է $ HOME- ը:

[user@testhost etc]$ pwd
/etc
[user@testhost etc]$ cd ~/test/
[user@testhost test]$ pwd
/home/user/test

mkdir

Ստեղծեք գրացուցակ:

[user@testhost ~]$ mkdir test
[user@testhost ~]$ ls -ltr
total 38184
-rw-rw-r-- 1 user user 39091284 Nov 22 14:14 qqq
drwxrwxr-x 2 user user     4096 Nov 26 10:29 test

Երբեմն ձեզ անհրաժեշտ է ստեղծել գրացուցակի հատուկ կառուցվածք. օրինակ՝ տեղեկատու գրացուցակում, որը գոյություն չունի: Մի քանի անգամ անընդմեջ մտնելուց խուսափելու համար mkdir, կարող եք օգտագործել տարբերակը -p — այն թույլ է տալիս ստեղծել հիերարխիայում բացակայող բոլոր դիրեկտորիաները: Նաև այս տարբերակով mkdir չի վերադարձնի սխալ, եթե գրացուցակը գոյություն ունի:

[user@testhost ~]$ ls
qqq  test
[user@testhost ~]$ mkdir test2/subtest
mkdir: cannot create directory ‘test2/subtest’: No such file or directory
[user@testhost ~]$ mkdir -p test2/subtest
[user@testhost ~]$ ls
qqq  test  test2
[user@testhost ~]$ ls test2/
subtest
[user@testhost ~]$ mkdir test2/subtest
mkdir: cannot create directory ‘test2/subtest’: File exists
[user@testhost ~]$ mkdir -p test2/subtest
[user@testhost ~]$ ls test2/
subtest

rm

Ջնջել ֆայլը:

[user@testhost ~]$ ls
qqq  test  test2
[user@testhost ~]$ rm qqq
[user@testhost ~]$ ls
test  test2

Տարբերակ -r թույլ է տալիս ռեկուրսիվ կերպով ջնջել տեղեկատուներն իրենց ողջ բովանդակությամբ, տարբերակ -f թույլ է տալիս անտեսել սխալները ջնջելիս (օրինակ՝ գոյություն չունեցող ֆայլի մասին): Այս տարբերակները թույլ են տալիս, կոպիտ ասած, երաշխավորված ջնջել ֆայլերի և գրացուցակների ամբողջ հիերարխիան (եթե օգտագործողը իրավունք ունի դա անելու), հետևաբար, դրանք պետք է օգտագործվեն զգուշությամբ (դասական կատակի օրինակ է «rm-rf /«Որոշակի հանգամանքներում կջնջի ձեզ, եթե ոչ ամբողջ համակարգը, ապա դրա կատարման համար կարևոր շատ ֆայլեր):

[user@testhost ~]$ ls
test  test2
[user@testhost ~]$ ls -ltr test2/
total 4
-rw-rw-r-- 1 user user    0 Nov 26 10:40 temp
drwxrwxr-x 2 user user 4096 Nov 26 10:40 temp_dir
[user@testhost ~]$ rm -rf test2
[user@testhost ~]$ ls
test

cp

Պատճենել ֆայլ կամ գրացուցակ:

[user@testhost ~]$ ls
temp  test
[user@testhost ~]$ cp temp temp_clone
[user@testhost ~]$ ls
temp  temp_clone  test

Այս հրամանն ունի նաև տարբերակներ -r и -f, դրանք կարող են օգտագործվել՝ ապահովելու համար, որ դիրեկտորիաների և թղթապանակների հիերարխիան պատճենվի մեկ այլ վայրում։

mv

Տեղափոխեք կամ վերանվանեք ֆայլը կամ գրացուցակը:

[user@testhost ~]$ ls -ltr
total 4
drwxrwxr-x 2 user user 4096 Nov 26 10:29 test
-rw-rw-r-- 1 user user    0 Nov 26 10:45 temp
-rw-rw-r-- 1 user user    0 Nov 26 10:46 temp_clone
[user@testhost ~]$ ls test
[user@testhost ~]$ mv test test_renamed
[user@testhost ~]$ mv temp_clone test_renamed/
[user@testhost ~]$ ls
temp  test_renamed
[user@testhost ~]$ ls test_renamed/
temp_clone

կատու

Տպեք ֆայլի (կամ ֆայլերի) բովանդակությունը:

[user@testhost ~]$ cat temp
Content of a file.
Lalalala...

Արժե նաև ուշադրություն դարձնել հրամաններին գլխավոր (արդյունք n ֆայլի առաջին տողերը կամ բայթերը) և պոչ (նրա մասին ավելի ուշ):

պոչ

Վերցրեք n ֆայլի վերջին տողերը կամ բայթերը:

[user@testhost ~]$ tail -1 temp
Lalalala...

Տարբերակը շատ օգտակար է -f — այն թույլ է տալիս իրական ժամանակում ցուցադրել նոր տվյալներ ֆայլում:

ավելի քիչ

Երբեմն տեքստային ֆայլը չափազանց մեծ է, և անհարմար է այն ցուցադրել հրամանով կատու. Այնուհետև կարող եք բացել այն՝ օգտագործելով հրամանը ավելի քիչ: ֆայլը կթողարկվի մասերի, այս մասերի միջով նավարկություն, որոնում և այլ պարզ գործառույթներ հասանելի են:

[user@testhost ~]$ less temp

Այն կարող է նաև հարմար լինել օգտագործելու համար ավելի քիչ փոխակրիչով (խողովակ):

[user@testhost ~]$ grep "ERROR" /tmp/some.log | less

ps

Թվարկեք գործընթացները:

[user@testhost ~]$ ps
    PID TTY          TIME CMD
 761020 pts/2    00:00:00 bash
 809720 pts/2    00:00:00 ps

Ես ինքս սովորաբար օգտագործում եմ BSD տարբերակները»:որ- ցուցադրել բոլոր գործընթացները համակարգում (քանի որ կարող են լինել շատ գործընթացներ, ես ցուցադրեցի դրանցից միայն առաջին 5-ը խողովակաշարի միջոցով (խողովակ) և թիմը գլխավոր):

[user@testhost ~]$ ps aux | head -5
USER         PID %CPU %MEM    VSZ   RSS TTY      STAT START   TIME COMMAND
root           1  0.0  0.0  19692  2600 ?        Ss   Jul02   0:10 /sbin/init
root           2  0.0  0.0      0     0 ?        S    Jul02   0:03 [kthreadd]
root           4  0.0  0.0      0     0 ?        I<   Jul02   0:00 [kworker/0:0H]
root           6  0.0  0.0      0     0 ?        I<   Jul02   0:00 [mm_percpu_wq]

Շատերն օգտագործում են նաև BSD տարբերակները»axjf«, որը թույլ է տալիս ցուցադրել գործընթացի ծառը (այստեղ ես հանեցի ելքի մի մասը ցուցադրման համար).

[user@testhost ~]$ ps axjf
   PPID     PID    PGID     SID TTY        TPGID STAT   UID   TIME COMMAND
      0       2       0       0 ?             -1 S        0   0:03 [kthreadd]
      2       4       0       0 ?             -1 I<       0   0:00  _ [kworker/0:0H]
      2       6       0       0 ?             -1 I<       0   0:00  _ [mm_percpu_wq]
      2       7       0       0 ?             -1 S        0   4:08  _ [ksoftirqd/0]
...
...
...
      1    4293    4293    4293 tty6        4293 Ss+      0   0:00 /sbin/mingetty /dev/tty6
      1  532967  532964  532964 ?             -1 Sl     495   0:00 /opt/td-agent/embedded/bin/ruby /usr/sbin/td-agent --log /var/log/td-agent/td-agent.log --use-v1-config --group td-agent --daemon /var/run/td-agent/td-agent.pid
 532967  532970  532964  532964 ?             -1 Sl     495 803:06  _ /opt/td-agent/embedded/bin/ruby /usr/sbin/td-agent --log /var/log/td-agent/td-agent.log --use-v1-config --group td-agent --daemon /var/run/td-agent/td-agent.pid
      1  537162  533357  532322 ?             -1 Sl       0 5067:43 /usr/bin/dockerd --default-ulimit nofile=262144:262144 --dns=172.17.0.1
 537162  537177  537177  537177 ?             -1 Ssl      0 4649:28  _ docker-containerd --config /var/run/docker/containerd/containerd.toml
 537177  537579  537579  537177 ?             -1 Sl       0   4:48  |   _ docker-containerd-shim -namespace moby -workdir /var/lib/docker/containerd/daemon/io.containerd.runtime.v1.linux/moby/0ee89b20deb3cf08648cd92e1f3e3c661ccffef7a0971
 537579  537642  537642  537642 ?             -1 Ss    1000  32:11  |   |   _ /usr/bin/python /usr/bin/supervisord -c /etc/supervisord/api.conf
 537642  539764  539764  537642 ?             -1 S     1000   0:00  |   |       _ sh -c echo "READY"; while read -r line; do echo "$line"; supervisorctl shutdown; done
 537642  539767  539767  537642 ?             -1 S     1000   5:09  |   |       _ php-fpm: master process (/etc/php73/php-fpm.conf)
 539767  783097  539767  537642 ?             -1 S     1000   0:00  |   |       |   _ php-fpm: pool test
 539767  783131  539767  537642 ?             -1 S     1000   0:00  |   |       |   _ php-fpm: pool test
 539767  783185  539767  537642 ?             -1 S     1000   0:00  |   |       |   _ php-fpm: pool test
...
...
...

Այս հրամանն ունի բազմաթիվ տարբեր տարբերակներ, այնպես որ, եթե դուք ակտիվորեն օգտագործում եք այն, խորհուրդ եմ տալիս կարդալ փաստաթղթերը: Շատ դեպքերում բավական է միայն իմանալ «ps aux»:

սպանել

Գործընթացին ազդանշան ուղարկեք: Լռելյայն ազդանշանն ուղարկվում է ՍԻԳՏԵՐՄ, որը դադարեցնում է գործընթացը:

[user@testhost ~]$ ps ux
USER         PID %CPU %MEM    VSZ   RSS TTY      STAT START   TIME COMMAND
531      1027147  0.0  0.0 119956  4260 ?        S    14:51   0:00 sshd: user@pts/1
531      1027149  0.0  0.0 115408  3396 pts/1    Ss   14:51   0:00 -bash
531      1027170  0.0  0.0 119956  4136 ?        R    14:51   0:00 sshd: user@pts/2
531      1027180  0.0  0.0 115408  3564 pts/2    Ss   14:51   0:00 -bash
531      1033727  0.0  0.0 107960   708 pts/1    S+   15:17   0:00 sleep 300
531      1033752  0.0  0.0 117264  2604 pts/2    R+   15:17   0:00 ps ux
[user@testhost ~]$ kill 1033727
[user@testhost ~]$ ps ux
USER         PID %CPU %MEM    VSZ   RSS TTY      STAT START   TIME COMMAND
531      1027147  0.0  0.0 119956  4260 ?        S    14:51   0:00 sshd: user@pts/1
531      1027149  0.0  0.0 115408  3396 pts/1    Ss+  14:51   0:00 -bash
531      1027170  0.0  0.0 119956  4136 ?        R    14:51   0:00 sshd: user@pts/2
531      1027180  0.0  0.0 115408  3564 pts/2    Ss   14:51   0:00 -bash
531      1033808  0.0  0.0 117268  2492 pts/2    R+   15:17   0:00 ps ux

Քանի որ գործընթացը կարող է ունենալ ազդանշանի մշակիչներ, սպանել միշտ չէ, որ հանգեցնում է ակնկալվող արդյունքի` գործընթացի ակնթարթային ավարտին: Գործընթացը հաստատ «սպանելու» համար անհրաժեշտ է ազդանշան ուղարկել գործընթացին ՍԻԳԿԻԼ. Այնուամենայնիվ, դա կարող է հանգեցնել տվյալների կորստի (օրինակ, եթե գործընթացը դադարեցնելուց առաջ անհրաժեշտ է որոշակի տեղեկատվություն պահպանել սկավառակի վրա), այնպես որ դուք պետք է զգուշությամբ օգտագործեք այս հրամանը: Ազդանշանի համարը ՍԻԳԿԻԼ - 9, ուստի հրամանի կարճ տարբերակը հետևյալն է.

[user@testhost ~]$ ps ux | grep sleep
531      1034930  0.0  0.0 107960   636 pts/1    S+   15:21   0:00 sleep 300
531      1034953  0.0  0.0 110516  2104 pts/2    S+   15:21   0:00 grep --color=auto sleep
[user@testhost ~]$ kill -9 1034930
[user@testhost ~]$ ps ux | grep sleep
531      1035004  0.0  0.0 110516  2092 pts/2    S+   15:22   0:00 grep --color=auto sleep

Նշվածներից բացի ՍԻԳՏԵՐՄ и ՍԻԳԿԻԼ Կան ավելի շատ տարբեր ազդանշաններ, որոնց ցանկը հեշտությամբ կարելի է գտնել ինտերնետում: Եվ մի մոռացեք, որ ազդանշանները ՍԻԳԿԻԼ и ՍԻԳՍՏՈՊ չի կարելի ընդհատել կամ անտեսել:

սուլոց

Ուղարկեք ICMP փաթեթ հյուրընկալողին ECHO_QUEST.

[user@testhost ~]$ ping google.com
PING google.com (172.217.15.78) 56(84) bytes of data.
64 bytes from iad23s63-in-f14.1e100.net (172.217.15.78): icmp_seq=1 ttl=47 time=1.85 ms
64 bytes from iad23s63-in-f14.1e100.net (172.217.15.78): icmp_seq=2 ttl=47 time=1.48 ms
64 bytes from iad23s63-in-f14.1e100.net (172.217.15.78): icmp_seq=3 ttl=47 time=1.45 ms
64 bytes from iad23s63-in-f14.1e100.net (172.217.15.78): icmp_seq=4 ttl=47 time=1.46 ms
64 bytes from iad23s63-in-f14.1e100.net (172.217.15.78): icmp_seq=5 ttl=47 time=1.45 ms
^C
--- google.com ping statistics ---
5 packets transmitted, 5 received, 0% packet loss, time 4006ms
rtt min/avg/max/mdev = 1.453/1.541/1.850/0.156 ms

By default սուլոց աշխատում է այնքան ժամանակ, մինչև այն ձեռքով չդադարեցվի: Հետևաբար տարբերակը կարող է օգտակար լինել -c - ուղարկելուց հետո փաթեթների քանակը սուլոց կավարտվի ինքնուրույն: Մեկ այլ տարբերակ, որը ես երբեմն օգտագործում եմ, սա է -i, փաթեթներ ուղարկելու միջակայքը:

[user@testhost ~]$ ping -c 3 -i 5 google.com
PING google.com (172.217.5.238) 56(84) bytes of data.
64 bytes from iad30s07-in-f238.1e100.net (172.217.5.238): icmp_seq=1 ttl=47 time=1.55 ms
64 bytes from iad30s07-in-f14.1e100.net (172.217.5.238): icmp_seq=2 ttl=47 time=1.17 ms
64 bytes from iad30s07-in-f14.1e100.net (172.217.5.238): icmp_seq=3 ttl=47 time=1.16 ms

--- google.com ping statistics ---
3 packets transmitted, 3 received, 0% packet loss, time 10006ms
rtt min/avg/max/mdev = 1.162/1.295/1.551/0.181 ms

ssh

OpenSSH SSH հաճախորդը թույլ է տալիս միանալ հեռավոր հոսթին:

MacBook-Pro-User:~ user$ ssh [email protected]
Last login: Tue Nov 26 11:27:39 2019 from another_host
[user@testhost ~]$ hostname
testhost

SSH-ի օգտագործման մեջ կան բազմաթիվ նրբերանգներ, և այս հաճախորդը նույնպես ունի մեծ թվով հնարավորություններ, այնպես որ, եթե ցանկանում եք (կամ կարիք ունեք), կարող եք կարդալ դրա մասին: մանրամասներով.

scp

Պատճենեք ֆայլերը հյուրընկալողների միջև (այս օգտագործման համար ssh).

[user@testhost ~]$ pwd
/home/user
[user@testhost ~]$ ls
temp  test_renamed
[user@testhost ~]$ exit
logout
Connection to 11.11.22.22 closed.
MacBook-Pro-Aleksandr:~ user$ scp [email protected]:/home/user/temp Downloads/
temp                                                                                                                                                                                                        100%   31     0.2KB/s   00:00
MacBook-Pro-Aleksandr:~ user$ cat Downloads/temp
Content of a file.
Lalalala...

rsync

Դուք կարող եք նաև օգտագործել դիրեկտորիաները հոսթերների միջև համաժամեցնելու համար rsync (-a — արխիվային ռեժիմ, թույլ է տալիս պատճենել գրացուցակի ամբողջ բովանդակությունը «ինչպես կա», -v — լրացուցիչ տեղեկատվության ելք դեպի վահանակ).

MacBook-Pro-User:~ user$ ls Downloads/user
ls: Downloads/user: No such file or directory
MacBook-Pro-User:~ user$ rsync -av user@testhost:/home/user Downloads
receiving file list ... done
user/
user/.bash_history
user/.bash_logout
user/.bash_profile
user/.bashrc
user/.lesshst
user/.mongorc.js
user/.viminfo
user/1
user/man_signal
user/man_signal_error_log
user/temp
user/.ssh/
user/.ssh/authorized_keys
user/test/
user/test/created_today
user/test/temp_clone

sent 346 bytes  received 29210 bytes  11822.40 bytes/sec
total size is 28079  speedup is 0.95
MacBook-Pro-User:~ user$ ls -a Downloads/user
.                    .bash_history        .bash_profile        .lesshst             .ssh                 1                    man_signal_error_log test
..                   .bash_logout         .bashrc              .mongorc.js          .viminfo             man_signal           temp

կարոտել

Ցուցադրել տեքստի տող:

[user@testhost ~]$ echo "Hello"
Hello

Ընտրանքներ, որոնք արժե հաշվի առնել այստեղ -n - վերջում գծի ընդմիջումով մի ավելացրեք տողը, և -e — միացնել «փախչող» մեկնաբանություն օգտագործելով «»:

[user@testhost ~]$ echo "tHellon"
tHellon
[user@testhost ~]$ echo -n "tHellon"
tHellon[user@testhost ~]$
[user@testhost ~]$ echo -ne "tHellon"
	Hello

Դուք կարող եք նաև ցուցադրել փոփոխականների արժեքները՝ օգտագործելով այս հրամանը: Օրինակ, Linux-ում վերջին ավարտված հրամանի ելքի կոդը պահվում է հատուկ փոփոխականում $?, և այս կերպ դուք կարող եք պարզել, թե կոնկրետ ինչ սխալ է տեղի ունեցել վերջին գործող հավելվածում.

[user@testhost ~]$ ls    # ошибки не будет
1  man_signal  man_signal_error_log  temp  test
[user@testhost ~]$ echo $?    # получим 0 — ошибки не было
0
[user@testhost ~]$ ls qwerty    # будет ошибка
ls: cannot access qwerty: No such file or directory
[user@testhost ~]$ echo $?    # получим 2 — Misuse of shell builtins (according to Bash documentation)
2
[user@testhost ~]$ echo $?    # последний echo отработал без ошибок, получим 0
0

telnet

Հաճախորդ TELNET արձանագրության համար: Օգտագործվում է մեկ այլ հաղորդավարի հետ շփվելու համար:

[user@testhost ~]$ telnet example.com 80
Trying 93.184.216.34...
Connected to example.com.
Escape character is '^]'.
GET / HTTP/1.1
Host: example.com

HTTP/1.1 200 OK
Cache-Control: max-age=604800
Content-Type: text/html; charset=UTF-8
Date: Tue, 26 Nov 2019 11:59:18 GMT
Etag: "3147526947+gzip+ident"
Expires: Tue, 03 Dec 2019 11:59:18 GMT
Last-Modified: Thu, 17 Oct 2019 07:18:26 GMT
Server: ECS (dcb/7F3B)
Vary: Accept-Encoding
X-Cache: HIT
Content-Length: 1256

... здесь было тело ответа, которое я вырезал руками ...

Եթե ​​Ձեզ անհրաժեշտ է օգտագործել TLS արձանագրությունը (հիշեցնեմ, որ SSL-ը վաղուց հնացել է), ապա telnet հարմար չէ այդ նպատակների համար: Բայց հաճախորդը կգա openssl:

Openssl-ի օգտագործման օրինակ՝ GET հարցմանը պատասխան տալով

[user@testhost ~]$ openssl s_client -connect example.com:443
CONNECTED(00000003)
depth=2 C = US, O = DigiCert Inc, OU = www.digicert.com, CN = DigiCert Global Root CA
verify return:1
depth=1 C = US, O = DigiCert Inc, CN = DigiCert SHA2 Secure Server CA
verify return:1
depth=0 C = US, ST = California, L = Los Angeles, O = Internet Corporation for Assigned Names and Numbers, OU = Technology, CN = www.example.org
verify return:1
---
Certificate chain
 0 s:/C=US/ST=California/L=Los Angeles/O=Internet Corporation for Assigned Names and Numbers/OU=Technology/CN=www.example.org
   i:/C=US/O=DigiCert Inc/CN=DigiCert SHA2 Secure Server CA
 1 s:/C=US/O=DigiCert Inc/CN=DigiCert SHA2 Secure Server CA
   i:/C=US/O=DigiCert Inc/OU=www.digicert.com/CN=DigiCert Global Root CA
 2 s:/C=US/O=DigiCert Inc/OU=www.digicert.com/CN=DigiCert Global Root CA
   i:/C=US/O=DigiCert Inc/OU=www.digicert.com/CN=DigiCert Global Root CA
---
Server certificate
-----BEGIN CERTIFICATE-----
MIIHQDCCBiigAwIBAgIQD9B43Ujxor1NDyupa2A4/jANBgkqhkiG9w0BAQsFADBN
MQswCQYDVQQGEwJVUzEVMBMGA1UEChMMRGlnaUNlcnQgSW5jMScwJQYDVQQDEx5E
aWdpQ2VydCBTSEEyIFNlY3VyZSBTZXJ2ZXIgQ0EwHhcNMTgxMTI4MDAwMDAwWhcN
MjAxMjAyMTIwMDAwWjCBpTELMAkGA1UEBhMCVVMxEzARBgNVBAgTCkNhbGlmb3Ju
aWExFDASBgNVBAcTC0xvcyBBbmdlbGVzMTwwOgYDVQQKEzNJbnRlcm5ldCBDb3Jw
b3JhdGlvbiBmb3IgQXNzaWduZWQgTmFtZXMgYW5kIE51bWJlcnMxEzARBgNVBAsT
ClRlY2hub2xvZ3kxGDAWBgNVBAMTD3d3dy5leGFtcGxlLm9yZzCCASIwDQYJKoZI
hvcNAQEBBQADggEPADCCAQoCggEBANDwEnSgliByCGUZElpdStA6jGaPoCkrp9vV
rAzPpXGSFUIVsAeSdjF11yeOTVBqddF7U14nqu3rpGA68o5FGGtFM1yFEaogEv5g
rJ1MRY/d0w4+dw8JwoVlNMci+3QTuUKf9yH28JxEdG3J37Mfj2C3cREGkGNBnY80
eyRJRqzy8I0LSPTTkhr3okXuzOXXg38ugr1x3SgZWDNuEaE6oGpyYJIBWZ9jF3pJ
QnucP9vTBejMh374qvyd0QVQq3WxHrogy4nUbWw3gihMxT98wRD1oKVma1NTydvt
hcNtBfhkp8kO64/hxLHrLWgOFT/l4tz8IWQt7mkrBHjbd2XLVPkCAwEAAaOCA8Ew
ggO9MB8GA1UdIwQYMBaAFA+AYRyCMWHVLyjnjUY4tCzhxtniMB0GA1UdDgQWBBRm
mGIC4AmRp9njNvt2xrC/oW2nvjCBgQYDVR0RBHoweIIPd3d3LmV4YW1wbGUub3Jn
ggtleGFtcGxlLmNvbYILZXhhbXBsZS5lZHWCC2V4YW1wbGUubmV0ggtleGFtcGxl
Lm9yZ4IPd3d3LmV4YW1wbGUuY29tgg93d3cuZXhhbXBsZS5lZHWCD3d3dy5leGFt
cGxlLm5ldDAOBgNVHQ8BAf8EBAMCBaAwHQYDVR0lBBYwFAYIKwYBBQUHAwEGCCsG
AQUFBwMCMGsGA1UdHwRkMGIwL6AtoCuGKWh0dHA6Ly9jcmwzLmRpZ2ljZXJ0LmNv
bS9zc2NhLXNoYTItZzYuY3JsMC+gLaArhilodHRwOi8vY3JsNC5kaWdpY2VydC5j
b20vc3NjYS1zaGEyLWc2LmNybDBMBgNVHSAERTBDMDcGCWCGSAGG/WwBATAqMCgG
CCsGAQUFBwIBFhxodHRwczovL3d3dy5kaWdpY2VydC5jb20vQ1BTMAgGBmeBDAEC
AjB8BggrBgEFBQcBAQRwMG4wJAYIKwYBBQUHMAGGGGh0dHA6Ly9vY3NwLmRpZ2lj
ZXJ0LmNvbTBGBggrBgEFBQcwAoY6aHR0cDovL2NhY2VydHMuZGlnaWNlcnQuY29t
L0RpZ2lDZXJ0U0hBMlNlY3VyZVNlcnZlckNBLmNydDAMBgNVHRMBAf8EAjAAMIIB
fwYKKwYBBAHWeQIEAgSCAW8EggFrAWkAdwCkuQmQtBhYFIe7E6LMZ3AKPDWYBPkb
37jjd80OyA3cEAAAAWdcMZVGAAAEAwBIMEYCIQCEZIG3IR36Gkj1dq5L6EaGVycX
sHvpO7dKV0JsooTEbAIhALuTtf4wxGTkFkx8blhTV+7sf6pFT78ORo7+cP39jkJC
AHYAh3W/51l8+IxDmV+9827/Vo1HVjb/SrVgwbTq/16ggw8AAAFnXDGWFQAABAMA
RzBFAiBvqnfSHKeUwGMtLrOG3UGLQIoaL3+uZsGTX3MfSJNQEQIhANL5nUiGBR6g
l0QlCzzqzvorGXyB/yd7nttYttzo8EpOAHYAb1N2rDHwMRnYmQCkURX/dxUcEdkC
wQApBo2yCJo32RMAAAFnXDGWnAAABAMARzBFAiEA5Hn7Q4SOyqHkT+kDsHq7ku7z
RDuM7P4UDX2ft2Mpny0CIE13WtxJAUr0aASFYZ/XjSAMMfrB0/RxClvWVss9LHKM
MA0GCSqGSIb3DQEBCwUAA4IBAQBzcIXvQEGnakPVeJx7VUjmvGuZhrr7DQOLeP4R
8CmgDM1pFAvGBHiyzvCH1QGdxFl6cf7wbp7BoLCRLR/qPVXFMwUMzcE1GLBqaGZM
v1Yh2lvZSLmMNSGRXdx113pGLCInpm/TOhfrvr0TxRImc8BdozWJavsn1N2qdHQu
N+UBO6bQMLCD0KHEdSGFsuX6ZwAworxTg02/1qiDu7zW7RyzHvFYA4IAjpzvkPIa
X6KjBtpdvp/aXabmL95YgBjT8WJ7pqOfrqhpcmOBZa6Cg6O1l4qbIFH/Gj9hQB5I
0Gs4+eH6F9h3SojmPTYkT+8KuZ9w84Mn+M8qBXUQoYoKgIjN
-----END CERTIFICATE-----
subject=/C=US/ST=California/L=Los Angeles/O=Internet Corporation for Assigned Names and Numbers/OU=Technology/CN=www.example.org
issuer=/C=US/O=DigiCert Inc/CN=DigiCert SHA2 Secure Server CA
---
No client certificate CA names sent
Peer signing digest: SHA256
Server Temp Key: ECDH, P-256, 256 bits
---
SSL handshake has read 4643 bytes and written 415 bytes
---
New, TLSv1/SSLv3, Cipher is ECDHE-RSA-AES128-GCM-SHA256
Server public key is 2048 bit
Secure Renegotiation IS supported
Compression: NONE
Expansion: NONE
No ALPN negotiated
SSL-Session:
    Protocol  : TLSv1.2
    Cipher    : ECDHE-RSA-AES128-GCM-SHA256
    Session-ID: 91950DC50FADB57BF026D2661E6CFAA1F522E5CA60D2310E106EE0E0FD6E70BD
    Session-ID-ctx:
    Master-Key: 704E9145253EEB4E9DC47E3DC6725D296D4A470EA296D54F71D65E74EAC09EB096EA1305CBEDD9E7020B8F72FD2B68A5
    Key-Arg   : None
    Krb5 Principal: None
    PSK identity: None
    PSK identity hint: None
    TLS session ticket lifetime hint: 7200 (seconds)
    TLS session ticket:
    0000 - 68 84 4e 77 be e3 f5 00-49 c5 44 40 53 4d b9 61   [email protected]
    0010 - c9 fe df e4 05 51 d0 53-ae cf 89 4c b6 ef 6c 9e   .....Q.S...L..l.
    0020 - fe 12 9a f0 e8 e5 4e 87-42 89 ac af ca e5 4a 85   ......N.B.....J.
    0030 - 38 08 26 e3 22 89 08 b5-62 c0 8b 7e b8 05 d3 54   8.&."...b..~...T
    0040 - 8c 24 91 a7 b4 4f 79 ad-36 59 7c 69 2d e5 7f 62   .$...Oy.6Y|i-..b
    0050 - f6 73 a3 8b 92 63 c1 e3-df 78 ba 8c 5a cc 82 50   .s...c...x..Z..P
    0060 - 33 4e 13 4b 10 e4 97 31-cc b4 13 65 45 60 3e 13   3N.K...1...eE`>.
    0070 - ac 9e b1 bb 4b 18 d9 16-ea ce f0 9b 5b 0c 8b bf   ....K.......[...
    0080 - fd 78 74 a0 1a ef c2 15-2a 0a 14 8d d1 3f 52 7a   .xt.....*....?Rz
    0090 - 12 6b c7 81 15 c4 c4 af-7e df c2 20 a8 dd 4b 93   .k......~.. ..K.

    Start Time: 1574769867
    Timeout   : 300 (sec)
    Verify return code: 0 (ok)
---
GET / HTTP/1.1
Host: example.com

HTTP/1.1 200 OK
Cache-Control: max-age=604800
Content-Type: text/html; charset=UTF-8
Date: Tue, 26 Nov 2019 12:04:38 GMT
Etag: "3147526947+ident"
Expires: Tue, 03 Dec 2019 12:04:38 GMT
Last-Modified: Thu, 17 Oct 2019 07:18:26 GMT
Server: ECS (dcb/7EC8)
Vary: Accept-Encoding
X-Cache: HIT
Content-Length: 1256

<!doctype html>
<html>
<head>
    <title>Example Domain</title>

    <meta charset="utf-8" />
    <meta http-equiv="Content-type" content="text/html; charset=utf-8" />
    <meta name="viewport" content="width=device-width, initial-scale=1" />
    <style type="text/css">
    body {
        background-color: #f0f0f2;
        margin: 0;
        padding: 0;
        font-family: -apple-system, system-ui, BlinkMacSystemFont, "Segoe UI", "Open Sans", "Helvetica Neue", Helvetica, Arial, sans-serif;

    }
    div {
        width: 600px;
        margin: 5em auto;
        padding: 2em;
        background-color: #fdfdff;
        border-radius: 0.5em;
        box-shadow: 2px 3px 7px 2px rgba(0,0,0,0.02);
    }
    a:link, a:visited {
        color: #38488f;
        text-decoration: none;
    }
    @media (max-width: 700px) {
        div {
            margin: 0 auto;
            width: auto;
        }
    }
    </style>
</head>

<body>
<div>
    <h1>Example Domain</h1>
    <p>This domain is for use in illustrative examples in documents. You may use this
    domain in literature without prior coordination or asking for permission.</p>
    <p><a href="https://www.iana.org/domains/example">More information...</a></p>
</div>
</body>
</html>

Linux-ում ընդհանուր խնդիրների լուծում

Փոխել ֆայլի սեփականատիրոջը

Դուք կարող եք փոխել ֆայլի կամ գրացուցակի տիրոջը՝ օգտագործելով հրամանը երգչախումբը:

[user@testhost ~]$ chown user:user temp
[user@testhost ~]$ ls -l temp
-rw-rw-r-- 1 user user 31 Nov 26 11:09 temp

Այս հրամանի պարամետրը պետք է տրվի նոր սեփականատիրոջը և խմբին (ըստ ցանկության)՝ առանձնացված երկու կետով: Նաև գրացուցակի սեփականատիրոջը փոխելիս տարբերակը կարող է օգտակար լինել -R - այնուհետև սեփականատերերը կփոխվեն գրացուցակի բոլոր բովանդակության համար:

Փոխել ֆայլի թույլտվությունները

Այս խնդիրը կարող է լուծվել հրամանի միջոցով chmod. Որպես օրինակ, ես կտամ թույլտվության կարգավորումը «սեփականատիրոջը թույլատրվում է կարդալ, գրել և կատարել, խմբին թույլատրվում է կարդալ և գրել, մնացած բոլորին ոչինչ չի թույլատրվում»:

[user@testhost ~]$ ls -l temp
-rw-rw-r-- 1 user user 31 Nov 26 11:09 temp
[user@testhost ~]$ chmod 760 temp
[user@testhost ~]$ ls -l temp
-rwxrw---- 1 user user 31 Nov 26 11:09 temp

Առաջին 7-ը (սա 0b111 է բիթերի ներկայացման մեջ) պարամետրում նշանակում է «բոլոր իրավունքները սեփականատիրոջ համար», երկրորդ 6-ը (սա 0b110 է բիթերի ներկայացման մեջ) նշանակում է «կարդալ և գրել», իսկ 0-ը ոչինչ չի նշանակում մնացածի համար: . Bitmask-ը բաղկացած է երեք բիթից. ամենաքիչ նշանակալից («աջ») բիթը պատասխանատու է կատարման համար, հաջորդ («միջին») բիթը գրելու համար է, իսկ ամենակարևորը («ձախ»)՝ կարդալու համար։
Կարող եք նաև թույլտվություններ սահմանել՝ օգտագործելով հատուկ նիշեր (մնեմոնիկ շարահյուսություն) Օրինակ, հետևյալ օրինակը սկզբում հեռացնում է կատարման իրավունքները ընթացիկ օգտատիրոջ համար, այնուհետև փոխում է դրանք.

[user@testhost ~]$ ls -l temp
-rwxrw---- 1 user user 31 Nov 26 11:09 temp
[user@testhost ~]$ chmod -x temp
[user@testhost ~]$ ls -l temp
-rw-rw---- 1 user user 31 Nov 26 11:09 temp
[user@testhost ~]$ chmod +x temp
[user@testhost ~]$ ls -l temp
-rwxrwx--x 1 user user 31 Nov 26 11:09 temp

Այս հրամանը շատ օգտագործում է, ուստի խորհուրդ եմ տալիս ավելին կարդալ դրա մասին (հատկապես մնեմոնիկ շարահյուսության մասին, օրինակ. այստեղ).

Տպեք երկուական ֆայլի բովանդակությունը

Դա կարելի է անել՝ օգտագործելով կոմունալը hexdump. Ստորև բերված են դրա օգտագործման օրինակներ:

[user@testhost ~]$ cat temp
Content of a file.
Lalalala...
[user@testhost ~]$ hexdump -c temp
0000000   C   o   n   t   e   n   t       o   f       a       f   i   l
0000010   e   .  n   L   a   l   a   l   a   l   a   .   .   .  n
000001f
[user@testhost ~]$ hexdump -x temp
0000000    6f43    746e    6e65    2074    666f    6120    6620    6c69
0000010    2e65    4c0a    6c61    6c61    6c61    2e61    2e2e    000a
000001f
[user@testhost ~]$ hexdump -C temp
00000000  43 6f 6e 74 65 6e 74 20  6f 66 20 61 20 66 69 6c  |Content of a fil|
00000010  65 2e 0a 4c 61 6c 61 6c  61 6c 61 2e 2e 2e 0a     |e..Lalalala....|
0000001f

Օգտագործելով այս կոմունալ ծրագիրը, դուք կարող եք ելքային տվյալներ այլ ձևաչափերով, բայց դրանք օգտագործելու ամենահաճախ օգտակար տարբերակներն են:

Որոնել ֆայլեր

Դուք կարող եք ֆայլը գտնել իր անվան մասով գրացուցակի ծառում՝ օգտագործելով հրամանը գտնել:

[user@testhost ~]$ find test_dir/ -name "*le*"
test_dir/file_1
test_dir/file_2
test_dir/subdir/file_3

Հասանելի են նաև որոնման այլ տարբերակներ և զտիչներ: Օրինակ, այսպես կարող եք գտնել ֆայլեր թղթապանակում փորձարկումստեղծված ավելի քան 5 օր առաջ՝

[user@testhost ~]$ ls -ltr test
total 0
-rw-rw-r-- 1 user user 0 Nov 26 10:46 temp_clone
-rw-rw-r-- 1 user user 0 Dec  4 10:39 created_today
[user@testhost ~]$ find test/ -type f -ctime +5
test/temp_clone

Որոնեք տեքստ ֆայլերում

Թիմը կօգնի ձեզ հաղթահարել այս խնդիրը grep. Այն ունի բազմաթիվ կիրառումներ, ամենապարզը բերված է այստեղ որպես օրինակ։

[user@testhost ~]$ grep -nr "content" test_dir/
test_dir/file_1:1:test content for file_1
test_dir/file_2:1:test content for file_2
test_dir/subdir/file_3:1:test content for file_3

Հրամանի օգտագործման հանրաճանաչ եղանակներից մեկը grep - օգտագործելով այն խողովակաշարում (խողովակ):

[user@testhost ~]$ sudo tail -f /var/log/test.log | grep "ERROR"

Տարբերակ -v թույլ է տալիս էֆեկտ ստեղծել grepև հակառակը` միայն տողեր, որոնք չեն պարունակում փոխանցված օրինակը grep.

Դիտեք տեղադրված փաթեթները

Չկա ունիվերսալ հրաման, քանի որ ամեն ինչ կախված է Linux բաշխումից և օգտագործվող փաթեթի կառավարիչից: Ամենայն հավանականությամբ, հետևյալ հրամաններից մեկը կօգնի ձեզ.

yum list installed
apt list --installed
zypper se —installed-only
pacman -Qqe
dpkg -l
rpm -qa

Տեսեք, թե որքան տեղ է զբաղեցնում գրացուցակի ծառը

Հրամանի օգտագործման տարբերակներից մեկը du:

[user@testhost ~]$ du -h -d 1 test_dir/
8,0K test_dir/subdir
20K test_dir/

Դուք կարող եք փոխել պարամետրի արժեքը -dգրացուցակի ծառի մասին ավելի մանրամասն տեղեկություններ ստանալու համար: Դուք կարող եք նաև օգտագործել հրամանը համակցված տեսակ:

[user@testhost ~]$ du -h -d 1 test_dir/ | sort -h
8,0K test_dir/subdir
16K test_dir/subdir_2
36K test_dir/
[user@testhost ~]$ du -h -d 1 test_dir/ | sort -h -r
36K test_dir/
16K test_dir/subdir_2
8,0K test_dir/subdir

Տարբերակ -h թիմը տեսակ թույլ է տալիս տեսակավորել մարդու ընթերցվող ձևաչափով գրված չափերը (օրինակ՝ 1K, 2G), տարբերակ -r թույլ է տալիս տեսակավորել տվյալները հակառակ հերթականությամբ:

«Գտնել և փոխարինել» ֆայլում, ֆայլերում՝ գրացուցակում

Այս գործողությունը կատարվում է կոմունալ ծրագրի միջոցով Sed (առանց դրոշի g վերջում տողում կփոխարինվի միայն «հին տեքստի» առաջին դեպքը).

sed -i 's/old-text/new-text/g' input.txt

Դուք կարող եք այն օգտագործել միանգամից մի քանի ֆայլերի համար.

[user@testhost ~]$ cat test_dir/file_*
test content for file_1
test content for file_2
[user@testhost ~]$ sed -i 's/test/edited/g' test_dir/file_*
[user@testhost ~]$ cat test_dir/file_*
edited content for file_1
edited content for file_2

Արդյունքից նկարեք սյունակ

Դա կօգնի հաղթահարել այս խնդիրը awk. Այս օրինակը ցուցադրում է հրամանի ելքի երկրորդ սյունակը `ps ux`:

[user@testhost ~]$ ps ux | awk '{print $2}'
PID
11023
25870
25871
25908
25909

Միաժամանակ պետք է նկատի ունենալ, որ awk ունի շատ ավելի հարուստ ֆունկցիոնալություն, այնպես որ, եթե Ձեզ անհրաժեշտ է աշխատել տեքստի հետ հրամանի տողում, ապա պետք է ավելին կարդալ այս հրամանի մասին:

Պարզեք IP հասցեն ըստ հյուրընկալողի անունով

Հետևյալ հրամաններից մեկը կօգնի դրան.

[user@testhost ~]$ host ya.ru
ya.ru has address 87.250.250.242
ya.ru has IPv6 address 2a02:6b8::2:242
ya.ru mail is handled by 10 mx.yandex.ru.

[user@testhost ~]$ dig +short ya.ru
87.250.250.242

[user@testhost ~]$ nslookup ya.ru
Server: 8.8.8.8
Address: 8.8.8.8#53

Non-authoritative answer:
Name: ya.ru
Address: 87.250.250.242

Ցանցի տեղեկատվություն

Կարող եք օգտագործել ifconfig:

[user@testhost ~]$ ifconfig
eth0: flags=4163<UP,BROADCAST,RUNNING,MULTICAST>  mtu 1500
        inet 47.89.93.67  netmask 255.255.224.0  broadcast 47.89.95.255
        inet6 fd90::302:57ff:fe79:1  prefixlen 64  scopeid 0x20<link>
        ether 04:01:57:79:00:01  txqueuelen 1000  (Ethernet)
        RX packets 11912135  bytes 9307046034 (8.6 GiB)
        RX errors 0  dropped 0  overruns 0  frame 0
        TX packets 14696632  bytes 2809191835 (2.6 GiB)
        TX errors 0  dropped 0 overruns 0  carrier 0  collisions 0


lo: flags=73<UP,LOOPBACK,RUNNING>  mtu 65536
        inet 127.0.0.1  netmask 255.0.0.0
        inet6 ::1  prefixlen 128  scopeid 0x10<host>
        loop  txqueuelen 0  (Local Loopback)
        RX packets 10  bytes 866 (866.0 B)
        RX errors 0  dropped 0  overruns 0  frame 0
        TX packets 10  bytes 866 (866.0 B)
        TX errors 0  dropped 0 overruns 0  carrier 0  collisions 0

Կամ գուցե ip:

[user@testhost ~]$ ip a
1: lo: <LOOPBACK,UP,LOWER_UP> mtu 65536 qdisc noqueue state UNKNOWN group default
    link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00
    inet 127.0.0.1/8 scope host lo
       valid_lft forever preferred_lft forever
    inet6 ::1/128 scope host
       valid_lft forever preferred_lft forever
2: eth0: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc pfifo_fast state UP group default qlen 1000
    link/ether 04:01:57:79:00:01 brd ff:ff:ff:ff:ff:ff
    inet 47.89.93.67/19 brd 47.89.95.255 scope global eth0
       valid_lft forever preferred_lft forever
    inet6 fd90::302:57ff:fe79:1/64 scope link
       valid_lft forever preferred_lft forever
3: ip_vti0: <NOARP> mtu 1500 qdisc noop state DOWN group default
    link/ipip 0.0.0.0 brd 0.0.0.0

Ավելին, եթե, օրինակ, ձեզ հետաքրքրում է միայն IPv4-ը, ապա կարող եք ավելացնել տարբերակը -4:

[user@testhost ~]$ ip -4 a
1: lo: <LOOPBACK,UP,LOWER_UP> mtu 65536 qdisc noqueue state UNKNOWN group default
    inet 127.0.0.1/8 scope host lo
       valid_lft forever preferred_lft forever
2: eth0: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc pfifo_fast state UP group default qlen 1000
    inet 47.89.93.67/19 brd 47.89.95.255 scope global eth0
       valid_lft forever preferred_lft forever

Դիտեք բաց նավահանգիստները

Դա անելու համար օգտագործեք կոմունալը netstat. Օրինակ, բոլոր TCP և UDP լսողական նավահանգիստները դիտելու համար պորտում լսվող գործընթացի PID-ի ցուցադրմամբ և պորտի թվային ներկայացմամբ, դուք պետք է այն օգտագործեք հետևյալ ընտրանքներով.

[user@testhost ~]$ netstat -lptnu

Համակարգի տեղեկատվություն

Դուք կարող եք ստանալ այս տեղեկատվությունը հրամանի միջոցով uname.

[user@testhost ~]$ uname -a
Linux alexander 3.10.0-123.8.1.el7.x86_64 #1 SMP Mon Sep 22 19:06:58 UTC 2014 x86_64 x86_64 x86_64 GNU/Linux

Հասկանալու համար, թե ինչ ձևաչափով է արտադրվում ելքը, կարող եք դիմել օգնություն«Այս հրամանի համար.

[user@testhost ~]$ uname --help
Использование: uname [КЛЮЧ]…
Печатает определенные сведения о системе.  Если КЛЮЧ не задан,
подразумевается -s.

  -a, --all          напечатать всю информацию, в следующем порядке,
                       кроме -p и -i, если они неизвестны:
  -s, --kernel-name  напечатать имя ядра
  -n, --nodename     напечатать имя машины в сети
  -r, --release      напечатать номер выпуска операционной системы
  -v, --kernel-version     напечатать версию ядра
  -m, --machine            напечатать тип оборудования машины
  -p, --processor          напечатать тип процессора или «неизвестно»
  -i, --hardware-platform  напечатать тип аппаратной платформы или «неизвестно»
  -o, --operating-system   напечатать имя операционной системы
      --help     показать эту справку и выйти
      --version  показать информацию о версии и выйти

Հիշողության մասին տեղեկատվություն

Հասկանալու համար, թե որքան RAM է զբաղված կամ ազատ, կարող եք օգտագործել հրամանը ազատ.

[user@testhost ~]$ free -h
              total        used        free      shared  buff/cache   available
Mem:           3,9G        555M        143M         56M        3,2G        3,0G
Swap:            0B          0B          0B

Տեղեկություններ ֆայլային համակարգերի մասին (սկավառակի ազատ տարածություն)

Թիմ df թույլ է տալիս տեսնել, թե որքան տարածք է ազատ և զբաղված մոնտաժված ֆայլային համակարգերում:

[user@testhost ~]$ df -hT
Файловая система Тип      Размер Использовано  Дост Использовано% Cмонтировано в
/dev/vda1        ext4        79G          21G   55G           27% /
devtmpfs         devtmpfs   2,0G            0  2,0G            0% /dev
tmpfs            tmpfs      2,0G            0  2,0G            0% /dev/shm
tmpfs            tmpfs      2,0G          57M  1,9G            3% /run
tmpfs            tmpfs      2,0G            0  2,0G            0% /sys/fs/cgroup
tmpfs            tmpfs      396M            0  396M            0% /run/user/1001

Տարբերակ -T նշում է, որ ֆայլային համակարգի տեսակը պետք է ենթադրվի:

Տեղեկություններ առաջադրանքների և համակարգի տարբեր վիճակագրության մասին

Դա անելու համար օգտագործեք հրամանը վերեւ. Այն ի վիճակի է ցուցադրել տարբեր տեղեկություններ. օրինակ՝ լավագույն պրոցեսները՝ ըստ RAM-ի օգտագործման կամ լավագույն գործընթացները՝ ըստ պրոցեսորի ժամանակի օգտագործման: Այն նաև ցուցադրում է տեղեկատվություն հիշողության, պրոցեսորի, ժամանակի և LA-ի (բեռնվածության միջին) մասին:

[user@testhost ~]$ top | head -10
top - 17:19:13 up 154 days,  6:59,  3 users,  load average: 0.21, 0.21, 0.27
Tasks: 2169 total,   2 running, 2080 sleeping,   0 stopped,   0 zombie
Cpu(s):  1.7%us,  0.7%sy,  0.0%ni, 97.5%id,  0.0%wa,  0.0%hi,  0.1%si,  0.0%st
Mem:  125889960k total, 82423048k used, 43466912k free, 16026020k buffers
Swap:        0k total,        0k used,        0k free, 31094516k cached

    PID USER      PR  NI  VIRT  RES  SHR S %CPU %MEM    TIME+  COMMAND
  25282 user      20   0 16988 3936 1964 R  7.3  0.0   0:00.04 top
   4264 telegraf  20   0 2740m 240m  22m S  1.8  0.2  23409:39 telegraf
   6718 root      20   0 35404 4768 3024 S  1.8  0.0   0:01.49 redis-server

Այս կոմունալն ունի հարուստ ֆունկցիոնալություն, այնպես որ, եթե ձեզ անհրաժեշտ է հաճախ օգտագործել այն, ավելի լավ է կարդալ դրա փաստաթղթերը:

Ցանցային տրաֆիկի աղբավայր

Linux-ում ցանցային երթևեկությունը կասեցնելու համար օգտագործվում է կոմունալ ծրագիր tcpdump. 12345 նավահանգստի երթևեկությունը լցնելու համար կարող եք օգտագործել հետևյալ հրամանը.

[user@testhost ~]$ sudo tcpdump -i any -A port 12345

Տարբերակ -A ասում է, որ մենք ուզում ենք ելքը տեսնել ASCII-ում (այնպես որ դա լավ է տեքստային արձանագրությունների համար), - ցանկացած ցույց է տալիս, որ մեզ չի հետաքրքրում ցանցային ինտերֆեյսը, նավահանգիստ — որ նավահանգստի երթևեկությունը թափել: Փոխարեն նավահանգիստ Դուք կարող եք օգտագործել հյուրընկալող, կամ համակցություն հյուրընկալող и նավահանգիստ (հյուրընկալող A և պորտ X) Մեկ այլ օգտակար տարբերակ կարող է լինել -n — ելքում հասցեները մի փոխարկեք հոսթների անունների:
Իսկ եթե տրաֆիկը երկուական է: Այդ դեպքում տարբերակը մեզ կօգնի -X — ելքային տվյալներ hex և ASCII.

[user@testhost ~]$ sudo tcpdump -i any -X port 12345

Պետք է հաշվի առնել, որ երկու օգտագործման դեպքում էլ թողարկվելու են IP փաթեթներ, ուստի դրանցից յուրաքանչյուրի սկզբում կլինեն երկուական IP և TCP վերնագրեր։ Ահա հարցման ելքի օրինակ «123« ուղարկվել է սերվերին, որը լսում է 12345 նավահանգստում.

[user@testhost ~]$ sudo tcpdump -i any -X port 12345
tcpdump: verbose output suppressed, use -v or -vv for full protocol decode
listening on any, link-type LINUX_SLL (Linux cooked), capture size 262144 bytes
14:27:13.224762 IP localhost.49794 > localhost.italk: Flags [P.], seq 2262177478:2262177483, ack 3317210845, win 342, options [nop,nop,TS val 3196604972 ecr 3196590131], length 5
    0x0000:  4510 0039 dfb6 4000 4006 5cf6 7f00 0001  E..9..@.@......
    0x0010:  7f00 0001 c282 3039 86d6 16c6 c5b8 9edd  ......09........
    0x0020:  8018 0156 fe2d 0000 0101 080a be88 522c  ...V.-........R,
    0x0030:  be88 1833 3132 330d 0a00 0000 0000 0000  ...3123.........
    0x0040:  0000 0000 0000 0000 00                   .........

Արտադրանքի փոխարեն

Իհարկե, Linux-ում շատ ավելի հետաքրքիր բաներ կան, որոնց մասին կարող եք կարդալ Habré-ում, StackOverflow-ում և այլ կայքերում (ես ձեզ օրինակ կտամ. Հրամանի տողի արվեստը, որը նույնպես թարգմանության մեջ) Համակարգի ադմինիստրատորները և DevOps-ն օգտագործում են շատ ավելի շատ հրամաններ և կոմունալ ծառայություններ սերվերները կարգավորելու համար, բայց նույնիսկ փորձարկողները կարող են չբավականացնել թվարկված հրամանները: Ձեզ կարող է անհրաժեշտ լինել ստուգել հաճախորդի և սերվերի միջև որոշակի բարդ ժամանակի ճշգրտությունը կամ սերվերի աշխատանքը, երբ սկավառակի ազատ տարածություն չկա: Էլ չեմ խոսում, օրինակ, Docker-ի մասին, որն այժմ ակտիվորեն օգտագործվում է բազմաթիվ ընկերությունների կողմից։ Արդյո՞ք հետաքրքիր կլինի, որպես այս հղումային հոդվածի շարունակության մաս, դիտել Linux-ի կոնսոլների տարբեր կոմունալ ծառայությունների փորձարկման գործընթացում օգտագործելու մի քանի օրինակներ: Կիսվեք նաև ձեր լավագույն թիմերով մեկնաբանություններում :)

Source: www.habr.com

Добавить комментарий