Журнал лабораторных работ

Содержание

Журнал

Вторник (11/28/17)

/dev/pts/5
10:14:12
#ls ?a*
bash  cat  dash  date  false  nano  tailf  tar
10:14:45
#ls ?[ap]*
bash  cat  cp  cpio  dash  date  false  ip  nano  open  openvt  tailf  tar  ypdomainname
/dev/pts/0
10:15:10
#ls -alS
итого 64
-rw-------  1 root root 5380 Ноя 28 10:24 .viminfo
-rw-r--r--  1 root root 5268 Ноя 27 16:00 install
drwx------  5 root root 4096 Ноя 28 11:03 .
drwxr-xr-x 24 root root 4096 Окт 15  2014 ..
drwx------  2 root root 4096 Июн 27  2014 .aptitude
drwxr-xr-x  2 root root 4096 Ноя 28 11:17 .lilalo
drwxr-xr-x  2 root root 4096 Ноя 27 17:19 .vim
-rw-------  1 root root 2616 Ноя 28 11:01 .bash_history
-rw-r--r--  1 root root  630 Июн 27  2014 .bashrc
-rw-r--r--  1 root root  140 Ноя 19  2007 .profile
-rw-r--r--  1 root root   77 Ноя 27 17:45 .vimrc
-rw-r--r--  1 root root   51 Ноя 24 15:18 .l3rc
-rw-------  1 root root   39 Ноя 28 11:03 .lesshst
-rw-r--r--  1 root root   10 Июн 27  2014 .bash_profile
/dev/pts/5
10:16:16
#ls ?[a-p]*
bash   dir            kbd_mode  mknod           openvt    sh             which
cat    dmesg          kill      mktemp          pidof     sh.distrib     ypdomainname
chgrp  dnsdomainname  kmod      more            ping      sleep          zcat
chmod  domainname     less      mount           ping6     tailf          zcmp
chown  echo           lessecho  mountpoint      rbash     tar            zdiff
chvt   egrep          lessfile  nano            readlink  tempfile       zegrep
cp     false          lesskey   nc              rm        touch          zfgrep
cpio   fgconsole      lesspipe  nc.traditional  rmdir     umount         zforce
dash   fgrep          ln        netcat          rnano     uname          zgrep
date   findmnt        loadkeys  netstat         sed       uncompress     zless
dd     hostname       login     nisdomainname   setfont   unicode_start  zmore
df     ip             mkdir     open            setupcon  vdir           znew
10:16:46
#ls ?[a-p]* | wc -l
84
/dev/pts/0
10:18:10
#ls -S
install
10:18:15
#man cat
/dev/pts/5
10:19:40
#man wc
10:23:52
#ls ?[!a-p]* | wc -l
25
10:23:57
#ls ?[!a-p]*
busybox   grep    gzip  lsblk  mt-gnu  pwd        ss    sync  zsh4
dumpkeys  gunzip  ksh   lsmod  mv      run-parts  stty  true
fuser     gzexe   ls    mt     ps      rzsh       su    zsh
10:24:05
#cd

10:25:23
#> 123

10:26:06
#> 1234512323

10:26:09
#> 2345

10:26:12
#> 78985

10:26:15
#> 78345

10:26:17
#> 78asd

10:26:19
#> 3sdfs567

10:26:25
#> 256j

10:26:35
#ls
123  1234512323  2345  256j  3sdfs567  78345  78985  78asd  install
10:26:36
#sho
shopt            showconsolefont  showkey
10:26:36
#shopt
autocd          off
cdable_vars     off
cdspell         off
checkhash       off
checkjobs       off
checkwinsize    on
cmdhist         on
compat31        off
compat32        off
compat40        off
...
no_empty_cmd_completion off
nocaseglob      off
nocasematch     off
nullglob        off
progcomp        on
promptvars      on
restricted_shell        off
shift_verbose   off
sourcepath      on
xpg_echo        off
10:27:57
#shopt | grep reg

10:28:06
#shopt | grep reg*
direxpand       off
force_fignore   on
histreedit      off
restricted_shell        off
10:28:08
#shopt | grep ext*
direxpand       off
execfail        off
expand_aliases  on
extdebug        off
extglob         off
extquote        on
huponexit       off
10:28:39
#shopt -s extglob

10:29:25
#shopt | grep ext*
direxpand       off
execfail        off
expand_aliases  on
extdebug        off
extglob         on
extquote        on
huponexit       off
10:29:28
#echo 'shopt | grep ext*' >> .bashrc

10:30:47
#cat .bash
cat: .bash: Нет такого файла или каталога
10:30:52
#cat .bashrc
# ~/.bashrc: executed by bash(1) for non-login shells.
# Note: PS1 and umask are already set in /etc/profile. You should not
# need this unless you want different defaults for root.
# PS1='${debian_chroot:+($debian_chroot)}\h:\w\$ '
# umask 022
# You may uncomment the following lines if you want `ls' to be colorized:
# export LS_OPTIONS='--color=auto'
# eval "`dircolors`"
# alias ls='ls $LS_OPTIONS'
# alias ll='ls $LS_OPTIONS -l'
# alias l='ls $LS_OPTIONS -lA'
#
# Some more alias to avoid making mistakes:
# alias rm='rm -i'
# alias cp='cp -i'
# alias mv='mv -i'
[ $0 == l3script ] && . /root/.lilalo/l3bashrc && _l3_start
shopt | grep ext*
10:31:21
#vi !$
--- /tmp/l3-saved-7973.21022.15852	2017-11-28 11:31:28.066857043 +0200
+++ .bashrc	2017-11-28 11:31:34.738804659 +0200
@@ -17,5 +17,4 @@
 # alias cp='cp -i'
 # alias mv='mv -i'
 [ $0 == l3script ] && . /root/.lilalo/l3bashrc && _l3_start
-shopt | grep ext*
 shopt -s extglob
10:31:34
#ls +([[:digit:]])
123  1234512323  2345  78345  78985
10:32:02
#man ls
10:32:22
#help ls
l3script: help: no help topics match `ls'.  Try `help help' or `man -k ls' or `info ls'.
10:32:27
#man bash
10:40:19
#cat /etc/passwd | awk -F: '{print $1}'
root
daemon
bin
sys
sync
games
man
lp
mail
news
...
backup
list
irc
gnats
nobody
libuuid
Debian-exim
user
sshd
ivan
10:40:47
#touch f{1,2,3,4,5}

10:43:46
#ls
123  1234512323  2345  256j  3sdfs567  78345  78985  78asd  f1  f2  f3  f4  f5  install
10:46:41
#ls
256j  3sdfs567  78asd  f1  f2  f3  f4  f5  install
10:46:43
#touch f{1,2,3,4,5}

10:47:08
#ls f{1,2,3,4,5} | xargs -i cp -v {} /tmp
«f1» -> «/tmp/f1»
«f2» -> «/tmp/f2»
«f3» -> «/tmp/f3»
«f4» -> «/tmp/f4»
«f5» -> «/tmp/f5»
10:49:39
#who
root     pts/0        2017-11-28 10:07 (192.168.16.211)
user     pts/2        2017-11-28 09:17 (192.168.16.211)
ivan     pts/4        2017-11-28 10:19 (192.168.16.211)
root     pts/5        2017-11-28 10:59 (192.168.16.211)
10:55:28
#which who
/usr/bin/who
10:56:09
#ls -l /usr/bin/who
-rwxr-xr-x 1 root root 55888 Янв 26  2013 /usr/bin/who
10:56:39
#ls -l `which who`
-rwxr-xr-x 1 root root 55888 Янв 26  2013 /usr/bin/who
10:57:27
#ls -l $(which who)
-rwxr-xr-x 1 root root 55888 Янв 26  2013 /usr/bin/who
прошло 24 минуты
11:22:01
#echo $[5+8]
13
11:23:35
#echo $[5/8]
0
11:23:56
#echo $[5/10]
0
11:24:01
#echo $[10/5]
2
11:24:09
#ps ax
  PID TTY      STAT   TIME COMMAND
    1 ?        Ss     0:06 init [2]
    2 ?        S      0:00 [kthreadd]
    3 ?        S      0:01 [ksoftirqd/0]
    5 ?        S      0:00 [kworker/u:0]
    6 ?        S      0:00 [migration/0]
    7 ?        S      0:03 [watchdog/0]
    8 ?        S<     0:00 [cpuset]
    9 ?        S<     0:00 [khelper]
   10 ?        S      0:00 [kdevtmpfs]
...
 7546 pts/1    Ss+    0:00 l3script
 7701 ?        Ss     0:00 sshd: ivan [priv]
 7703 ?        S      0:00 sshd: ivan@pts/4
 7704 pts/4    Ss+    0:00 -bash
 7894 ?        Ss     0:00 sshd: root@pts/5
 7896 pts/5    Ss     0:00 -bash
 7941 pts/5    S+     0:00 script -f -c l3script -q /root/.lilalo//28749221202138130065-151
 7972 pts/5    S+     0:00 script -f -c l3script -q /root/.lilalo//28749221202138130065-151
 7973 pts/6    Ss     0:00 l3script
 8580 pts/6    R+     0:00 ps ax
11:24:38
#ps ax | wc -l
68
11:25:05
#top
top - 12:25:27 up 3 days, 20:38,  4 users,  load average: 0,00, 0,01, 0,05
Tasks:  66 total,   1 running,  65 sleeping,   0 stopped,   0 zombie
%Cpu(s):  0,0 us,  0,3 sy,  0,0 ni, 98,7 id,  1,0 wa,  0,0 hi,  0,0 si,  0,0 st
KiB Mem:    507368 total,   343716 used,   163652 free,    84376 buffers
KiB Swap:        0 total,        0 used,        0 free,   152476 cached
  PID USER      PR  NI  VIRT  RES  SHR S  %CPU %MEM    TIME+  COMMAND
 4776 root      20   0     0    0    0 S   0,3  0,0   0:01.75 kworker/0:1
 7894 root      20   0 71288 3684 2888 S   0,3  0,7   0:00.32 sshd
 8597 root      20   0 25284 1588 1128 R   0,3  0,3   0:00.01 top
    1 root      20   0 10648  828  696 S   0,0  0,2   0:06.60 init
...
 3551 user      20   0 47912  10m 1712 S   0,0  2,1   3:24.39 l3-agent
 4776 root      20   0     0    0    0 S   0,0  0,0   0:01.75 kworker/0:1
 4794 root      20   0 21224  984  524 S   0,0  0,2   0:00.00 udevd
 6814 root      20   0 71288 3608 2820 S   0,0  0,7   0:00.02 sshd
 6816 user      20   0 71288 1880 1088 S   0,0  0,4   0:00.00 sshd
 6817 user      20   0 22180 2872 1724 S   0,0  0,6   0:00.04 bash
 6862 user      20   0 18164  840  684 S   0,0  0,2   0:00.04 script
 6933 user      20   0 18168  472  308 S   0,0  0,1   0:00.00 script
 6934 user      20   0 22180 2796 1656 S   0,0  0,6   0:00.05 l3script
 7467 root      20   0 71288 3680 2888 S   0,0  0,7   0:00.10 sshd
11:25:32
#ps ax
  PID TTY      STAT   TIME COMMAND
    1 ?        Ss     0:06 init [2]
    2 ?        S      0:00 [kthreadd]
    3 ?        S      0:01 [ksoftirqd/0]
    5 ?        S      0:00 [kworker/u:0]
    6 ?        S      0:00 [migration/0]
    7 ?        S      0:03 [watchdog/0]
    8 ?        S<     0:00 [cpuset]
    9 ?        S<     0:00 [khelper]
   10 ?        S      0:00 [kdevtmpfs]
...
 7546 pts/1    Ss+    0:00 l3script
 7701 ?        Ss     0:00 sshd: ivan [priv]
 7703 ?        S      0:00 sshd: ivan@pts/4
 7704 pts/4    Ss+    0:00 -bash
 7894 ?        Ss     0:00 sshd: root@pts/5
 7896 pts/5    Ss     0:00 -bash
 7941 pts/5    S+     0:00 script -f -c l3script -q /root/.lilalo//28749221202138130065-1511859579.script
 7972 pts/5    S+     0:00 script -f -c l3script -q /root/.lilalo//28749221202138130065-1511859579.script
 7973 pts/6    Ss     0:00 l3script
 8605 pts/6    R+     0:00 ps ax
11:25:36
#ps ax | wc -l
68
11:26:45
#echo $[$(ps ax | wc -l)-4]
65
11:27:00
#echo $(($(ps ax | wc -l)-4))
65
11:28:19
#zsh

11:29:43
#cat install
#!/bin/sh
hostname=`hostname`
uname -a | egrep -qi '(freebsd|darwin)' || hostname=`hostname -f`
###############################################################################
#
# Set this variables before installation:
lilalo_user=13-10-2014
lab=NT-LNet
install_l3bashrc_for_this_users=${users:-"root user"}  # users who will use l3agent and l3script
lilalo_context="/users/${lilalo_user}/${lab}/${hostname}"
...
step "Downloading l3prompt" ${wget} ${url_l3prompt}
step "Downloading l3-agent" '${wget} ${url_l3agent}; ${wget} ${url_l3config_pm}; ${wget} ${url_l3config}'
step "Downloading perl modules for l3-agent" '{ for i in ${perl_modules}; do ${wget} ${url_perl_modules}/$i.tar.gz; done; }'
step "Installing perl modules for l3-agent" '{ for i in ${perl_modules}; do tar xvfz $i.tar.gz; cd $i*[^z]; perl Makefile.PL; make; make install; cd ..; done; }'
step "Installing l3bashrc to users home directories" install_to_users_homes $install_l3bashrc_for_this_users
step "Adding l3bashrc invocation to ~/.bashrc " install_to_users_bashrc $install_l3bashrc_for_this_users
step "Adding l3-agent invocation to ~/.bash_profile " install_to_users_bash_profile $install_l3bashrc_for_this_users
cd /
rm -rf ${temp_dir}
show_final_message
11:34:42
#cat
Test
Test
Hello world!
Hello world!
^C
11:38:02
#cat
Test
Test
asd
asd
d
d
qwerty
qwerty
11:42:28
#cat
asdasd
asdasd
^Z
[1]+  Stopped                 cat
11:42:51
#cat
asdasdasdas
asdasdasdas
^Z
[2]+  Stopped                 cat
11:42:56
#fg
cat
11:43:14
#fg
cat
11:43:20
#fg
l3script: fg: current: не такой задачи
11:43:22
#tail -f /var/lo
local/ lock/  log/
11:43:22
#tail -f /var/log/
alternatives.log    btmp                debug.4.gz          exim4/              lastlog             messages.4.gz       user.log
alternatives.log.1  btmp.1              dmesg               faillog             lpr.log             news/               user.log.1
apt/                daemon.log          dmesg.0             fsck/               mail.err            syslog              user.log.2.gz
aptitude            daemon.log.1        dmesg.1.gz          installer/          mail.info           syslog.1            user.log.3.gz
aptitude.1.gz       daemon.log.2.gz     dmesg.2.gz          iptraf/             mail.log            syslog.2.gz         wtmp
auth.log            daemon.log.3.gz     dmesg.3.gz          kern.log            mail.warn           syslog.3.gz         wtmp.1
auth.log.1          debug               dmesg.4.gz          kern.log.1          messages            syslog.4.gz
auth.log.2.gz       debug.1             dpkg.log            kern.log.2.gz       messages.1          syslog.5.gz
auth.log.3.gz       debug.2.gz          dpkg.log.1          kern.log.3.gz       messages.2.gz       syslog.6.gz
auth.log.4.gz       debug.3.gz          dpkg.log.2.gz       kern.log.4.gz       messages.3.gz       syslog.7.gz
11:43:22
#tail -f /var/log/
alternatives.log    btmp                debug.4.gz          exim4/              lastlog             messages.4.gz       user.log
alternatives.log.1  btmp.1              dmesg               faillog             lpr.log             news/               user.log.1
apt/                daemon.log          dmesg.0             fsck/               mail.err            syslog              user.log.2.gz
aptitude            daemon.log.1        dmesg.1.gz          installer/          mail.info           syslog.1            user.log.3.gz
aptitude.1.gz       daemon.log.2.gz     dmesg.2.gz          iptraf/             mail.log            syslog.2.gz         wtmp
auth.log            daemon.log.3.gz     dmesg.3.gz          kern.log            mail.warn           syslog.3.gz         wtmp.1
auth.log.1          debug               dmesg.4.gz          kern.log.1          messages            syslog.4.gz
auth.log.2.gz       debug.1             dpkg.log            kern.log.2.gz       messages.1          syslog.5.gz
auth.log.3.gz       debug.2.gz          dpkg.log.1          kern.log.3.gz       messages.2.gz       syslog.6.gz
auth.log.4.gz       debug.3.gz          dpkg.log.2.gz       kern.log.4.gz       messages.3.gz       syslog.7.gz
11:43:22
#tail -f /var/log/syslog
syslog       syslog.1     syslog.2.gz  syslog.3.gz  syslog.4.gz  syslog.5.gz  syslog.6.gz  syslog.7.gz
11:43:22
#tail -f /var/log/syslog
syslog       syslog.1     syslog.2.gz  syslog.3.gz  syslog.4.gz  syslog.5.gz  syslog.6.gz  syslog.7.gz
11:43:22
#tail -f /var/log/syslog
Nov 28 06:25:05 debian1 rsyslogd: [origin software="rsyslogd" swVersion="5.8.11" x-pid="1914" x-info="http://www.rsyslog.com"] rsyslogd was HUPed
Nov 28 06:25:06 debian1 rsyslogd: [origin software="rsyslogd" swVersion="5.8.11" x-pid="1914" x-info="http://www.rsyslog.com"] rsyslogd was HUPed
Nov 28 07:17:01 debian1 /USR/SBIN/CRON[6698]: (root) CMD (   cd / && run-parts --report /etc/cron.hourly)
Nov 28 08:17:01 debian1 /USR/SBIN/CRON[6705]: (root) CMD (   cd / && run-parts --report /etc/cron.hourly)
Nov 28 09:17:01 debian1 /USR/SBIN/CRON[6712]: (root) CMD (   cd / && run-parts --report /etc/cron.hourly)
Nov 28 10:17:01 debian1 /USR/SBIN/CRON[7698]: (root) CMD (   cd / && run-parts --report /etc/cron.hourly)
Nov 28 11:17:01 debian1 /USR/SBIN/CRON[8145]: (root) CMD (   cd / && run-parts --report /etc/cron.hourly)
Nov 28 12:17:01 debian1 /USR/SBIN/CRON[8541]: (root) CMD (   cd / && run-parts --report /etc/cron.hourly)
^C
11:44:27
#find /home -mtime -1 -user ivan
/home/ivan
/home/ivan/.bashrc
/home/ivan/.bash_history
/home/ivan/.viminfo
11:48:28
#find /home -mtime -1 -user ivan > files.txt

11:49:29
#man tee
11:49:49
#man tee
11:50:08
#su - ivan
ivan@debian1:~$ find /home -mtime -1 -user ivan > files.txt
find: `/home/user/.aptitude': Отказано в доступе
ivan@debian1:~$ find / -mtime -1 -user ivan > files.txt
find: `/etc/ssl/private': Отказано в доступе
find: `/lost+found': Отказано в доступе
find: `/tmp/aptitude-user.4749:2erJv7': Отказано в доступе
find: `/var/cache/ldconfig': Отказано в доступе
find: `/var/spool/exim4': Отказано в доступе
find: `/var/spool/cron/crontabs': Отказано в доступе
find: `/var/log/exim4': Отказано в доступе
...
/proc/8915/cgroup
/proc/8915/oom_score
/proc/8915/oom_adj
/proc/8915/oom_score_adj
/proc/8915/loginuid
/proc/8915/sessionid
/proc/8915/coredump_filter
/proc/8915/io
ivan@debian1:~$ exit
logout
прошло 56 минут
12:46:20
#shopt
autocd          off
cdable_vars     off
cdspell         off
checkhash       off
checkjobs       off
checkwinsize    on
cmdhist         on
compat31        off
compat32        off
compat40        off
...
no_empty_cmd_completion off
nocaseglob      off
nocasematch     off
nullglob        off
progcomp        on
promptvars      on
restricted_shell        off
shift_verbose   off
sourcepath      on
xpg_echo        off
12:46:48
#set -o
allexport       off
braceexpand     on
emacs           on
errexit         off
errtrace        off
functrace       off
hashall         on
histexpand      on
history         on
ignoreeof       off
...
notify          off
nounset         off
onecmd          off
physical        off
pipefail        off
posix           off
privileged      off
verbose         off
vi              off
xtrace          off
12:46:59
#set -o noclobber

12:48:11
#set -o
allexport       off
braceexpand     on
emacs           on
errexit         off
errtrace        off
functrace       off
hashall         on
histexpand      on
history         on
ignoreeof       off
...
notify          off
nounset         off
onecmd          off
physical        off
pipefail        off
posix           off
privileged      off
verbose         off
vi              off
xtrace          off
12:48:29
#date >> install

12:48:43
#date
Втр Ноя 28 13:48:50 EET 2017
12:48:50
#tail install
step "Installing perl modules for l3-agent" '{ for i in ${perl_modules}; do tar xvfz $i.tar.gz; cd $i*[^z]; perl Makefile.PL; make; make install; cd ..; done; }'
step "Installing l3bashrc to users home directories" install_to_users_homes $install_l3bashrc_for_this_users
step "Adding l3bashrc invocation to ~/.bashrc " install_to_users_bashrc $install_l3bashrc_for_this_users
step "Adding l3-agent invocation to ~/.bash_profile " install_to_users_bash_profile $install_l3bashrc_for_this_users
cd /
rm -rf ${temp_dir}
show_final_message
Втр Ноя 28 13:48:43 EET 2017
12:48:59
#set -o noclobber

12:49:32
#set -o
allexport       off
braceexpand     on
emacs           on
errexit         off
errtrace        off
functrace       off
hashall         on
histexpand      on
history         on
ignoreeof       off
...
notify          off
nounset         off
onecmd          off
physical        off
pipefail        off
posix           off
privileged      off
verbose         off
vi              off
xtrace          off
12:49:35
#set +o noclobber

12:49:47
#set -o
allexport       off
braceexpand     on
emacs           on
errexit         off
errtrace        off
functrace       off
hashall         on
histexpand      on
history         on
ignoreeof       off
...
notify          off
nounset         off
onecmd          off
physical        off
pipefail        off
posix           off
privileged      off
verbose         off
vi              off
xtrace          off
12:49:49
#lsattr install
-------------e-- install
12:50:48
#cha
chage    chardet  chattr
12:50:48
#chattr +a install

12:51:45
#lsattr install
-----a-------e-- install
12:51:46
#date > install
l3script: install: Операция не позволяется
12:52:14
#date >> install

12:52:26
#chattr -a install

12:53:16
#chattr +i install

12:53:20
#lsattr install
----i--------e-- install
12:53:24
#date >> install
l3script: install: Отказано в доступе
12:53:54
#mv install install2
mv: невозможно переместить «install» в «install2»: Операция не позволяется
12:54:05
#rm install
rm: невозможно удалить «install»: Операция не позволяется
12:54:11
#chattr -i install

Файлы

  • .bashrc
  • cat
  • install
  • .bashrc
    >
    # ~/.bashrc: executed by bash(1) for non-login shells.
    # Note: PS1 and umask are already set in /etc/profile. You should not
    # need this unless you want different defaults for root.
    # PS1='${debian_chroot:+($debian_chroot)}\h:\w\$ '
    # umask 022
    # You may uncomment the following lines if you want `ls' to be colorized:
    # export LS_OPTIONS='--color=auto'
    # eval "`dircolors`"
    # alias ls='ls $LS_OPTIONS'
    # alias ll='ls $LS_OPTIONS -l'
    # alias l='ls $LS_OPTIONS -lA'
    #
    # Some more alias to avoid making mistakes:
    # alias rm='rm -i'
    # alias cp='cp -i'
    # alias mv='mv -i'
    [ $0 == l3script ] && . /root/.lilalo/l3bashrc && _l3_start
    shopt | grep ext*
    
    cat
    >
    Test
    Test
    asd
    asd
    d
    d
    qwerty
    qwerty
    
    install
    >
    #!/bin/sh
    hostname=`hostname`
    uname -a | egrep -qi '(freebsd|darwin)' || hostname=`hostname -f`
    ###############################################################################
    #
    # Set this variables before installation:
    lilalo_user=13-10-2014
    lab=NT-LNet
    install_l3bashrc_for_this_users=${users:-"root user"}  # users who will use l3agent and l3script
    lilalo_context="/users/${lilalo_user}/${lab}/${hostname}"
    #
    ###############################################################################
    lilalo_rc=.l3rc
    lilalo_home=.lilalo
    url_lilalo="http://xgu.ru/lilalo"
    url_l3bashrc="${url_lilalo}"/l3bashrc
    url_l3agent="${url_lilalo}"/l3-agent
    url_l3config_pm="${url_lilalo}"/l3config.pm
    url_l3config="${url_lilalo}"/l3-config
    url_l3prompt="${url_lilalo}"/l3prompt
    url_perl_modules=${url_lilalo}/
    perl_modules="Term-VT102 Text-Iconv"
    apt_get_install_this="perl make libmodule-build-perl libc6-dev gcc"
    wget=wget
    uname -a | egrep -qi '(bsd|darwin)' && wget=fetch
    normC='\033[0;39m'
    whiteC='\033[1;37m'
    redC='\033[0;31m'
    greenC='\033[0;32m'
    apt_get_install_deps()
    {
        return 0
        if which apt-get >& /dev/null
        then
            apt-get install -y $apt_get_install_this
        else
            echo "Please install this dependencies manually:"
            echo $apt_get_install_this
            echo "Have you installed this already (y/n)?"
            echo y | read answer
            if echo $answer | grep -q ^[yY]
            then
                true
            else
                echo Please install the dependencies and rerun the script
                exit 1
            fi
        fi
    }
    step()
    {
        msg="$1"
        shift
        printf "${whiteC}""$msg""...${normC}\n"
    #    eval "$@" 2>&1 | sed 's/^/|\ \ \ /' && printf "Ok\n" || printf "Failed\n"
        eval "$@" 2>&1 > log 2>&1 && \
        {
              cat log | sed 's/^/|\ \ \ /'
              printf "${greenC}""Ok\n""${normC}"
        } || \
        {
            cat log | sed 's/^/|\ \ \ /'
            printf "${redC}""Failed\n""${normC}"
        }
    }
    get_user_home()
    {
        uname -a | egrep -qi '(freebsd|darwin)' && pw user show "$@"| awk -F: '{print $9}' || getent passwd "$@"| awk -F: '{print $6}'
    }
    install_to_users_homes()
    {
        . l3bashrc
        users="$@"
        set -x
        for user in $users
        do
            user_home=`get_user_home "$user"`
            mkdir -p ${user_home}/${lilalo_home}
            mkdir /etc/lilalo/
            cp l3config.pm /etc/lilalo/
            cp l3-agent /usr/local/bin
            cp l3-config /usr/local/bin
            ln -s `which bash` /usr/local/bin/l3script
            chmod 755 /usr/local/bin/l3-{agent,config}
            cp l3bashrc ${user_home}/${lilalo_home}
            cp l3prompt ${user_home}/${lilalo_home}
            chmod 755 ${user_home}/${lilalo_home}/l3prompt
            chown -R $user ${user_home}/${lilalo_home}
            echo l3cd=${lilalo_context}/$user > ${user_home}/${lilalo_rc}
            chown -R $user ${user_home}/${lilalo_rc}
        done
        set +x
    }
    install_to_users_bashrc()
    {
        users="$@"
        for user in $users
        do
            user_home=`get_user_home "$user"`
            grep -q lilalo ${user_home}/.bashrc 2> /dev/null\
            || echo "[ \$0 == l3script ] && . ${user_home}/.lilalo/l3bashrc && _l3_start" >> ${user_home}/.bashrc; chown -R ${user} ${user_home}/.bashrc
        done
    }
    install_to_users_bash_profile()
    {
        users="$@"
        for user in $users
        do
            user_home=`get_user_home "$user"`
            grep -q l3-agent ${user_home}/.bash_profile 2> /dev/null \
            || { echo >> ${user_home}/.bash_profile ; cat ${user_home}/.bash_profile | sed '1s/^/l3-agentX/' | tr X '\n' > /tmp/$$$$l3 ; mv /tmp/$$$$l3 ${user_home}/.bash_profile; chown -R ${user} ${user_home}/.bash_profile; }
        done
    }
    show_usage()
    {
        cat <<USAGE
    Usage:
        $0
    USAGE
    }
    show_final_message()
    {
        cat <<FINAL_MESSAGE
    Installation is successfully completed.
    Now restart your shell or relogin
    to start script writing.
    Your current lilalo context is ${lilalo_context}/USER
    If you use xgu.ru backend, your labs will be available at
    http://xgu.ru/l3/${lilalo_context}
    Use commands
     $ l3cd ${lilalo_context%/*/*}/MY-NEW-CONTEXT/${hostname}/USER
     $ l3pwd
    to change and to know your current context.
    For further information see http://xgu.ru/lilalo/ (in Russian).
    Thank you gor using LiLaLo.
    Happy Labbing!
    (don't forget to restart bash or relogin)
    FINAL_MESSAGE
    }
    temp_dir=/tmp/lilalo-install-temp-$$
    mkdir -p ${temp_dir}
    cd ${temp_dir}
    step "Installing dependencies" apt_get_install_deps
    step "Downloading l3bashrc" ${wget} ${url_l3bashrc}
    step "Downloading l3prompt" ${wget} ${url_l3prompt}
    step "Downloading l3-agent" '${wget} ${url_l3agent}; ${wget} ${url_l3config_pm}; ${wget} ${url_l3config}'
    step "Downloading perl modules for l3-agent" '{ for i in ${perl_modules}; do ${wget} ${url_perl_modules}/$i.tar.gz; done; }'
    step "Installing perl modules for l3-agent" '{ for i in ${perl_modules}; do tar xvfz $i.tar.gz; cd $i*[^z]; perl Makefile.PL; make; make install; cd ..; done; }'
    step "Installing l3bashrc to users home directories" install_to_users_homes $install_l3bashrc_for_this_users
    step "Adding l3bashrc invocation to ~/.bashrc " install_to_users_bashrc $install_l3bashrc_for_this_users
    step "Adding l3-agent invocation to ~/.bash_profile " install_to_users_bash_profile $install_l3bashrc_for_this_users
    cd /
    rm -rf ${temp_dir}
    show_final_message
    

    Статистика

    Время первой команды журнала10:14:12 2017-11-28
    Время последней команды журнала12:54:11 2017-11-28
    Количество командных строк в журнале101
    Процент команд с ненулевым кодом завершения, %15.84
    Процент синтаксически неверно набранных команд, % 0.00
    Суммарное время работы с терминалом *, час 1.73
    Количество командных строк в единицу времени, команда/мин 0.97
    Частота использования команд
    ls16|============| 12.12%
    >12|=========| 9.09%
    cat8|======| 6.06%
    set7|=====| 5.30%
    echo7|=====| 5.30%
    tail7|=====| 5.30%
    shopt7|=====| 5.30%
    man6|====| 4.55%
    wc6|====| 4.55%
    grep5|===| 3.79%
    date5|===| 3.79%
    ps4|===| 3.03%
    install4|===| 3.03%
    chattr4|===| 3.03%
    fg3|==| 2.27%
    lsattr3|==| 2.27%
    find2|=| 1.52%
    touch2|=| 1.52%
    files.txt1|| 0.76%
    .bashrc1|| 0.76%
    awk1|| 0.76%
    78asd1|| 0.76%
    zsh1|| 0.76%
    cd1|| 0.76%
    rm1|| 0.76%
    1231|| 0.76%
    help1|| 0.76%
    789851|| 0.76%
    mv1|| 0.76%
    256j1|| 0.76%
    top1|| 0.76%
    23451|| 0.76%
    12345123231|| 0.76%
    xargs1|| 0.76%
    sho1|| 0.76%
    vi1|| 0.76%
    who1|| 0.76%
    3sdfs5671|| 0.76%
    783451|| 0.76%
    cha1|| 0.76%
    which1|| 0.76%
    su1|| 0.76%
    ____
    *) Интервалы неактивности длительностью 30 минут и более не учитываются

    Справка

    Для того чтобы использовать LiLaLo, не нужно знать ничего особенного: всё происходит само собой. Однако, чтобы ведение и последующее использование журналов было как можно более эффективным, желательно иметь в виду следующее:
    1. В журнал автоматически попадают все команды, данные в любом терминале системы.

    2. Для того чтобы убедиться, что журнал на текущем терминале ведётся, и команды записываются, дайте команду w. В поле WHAT, соответствующем текущему терминалу, должна быть указана программа script.

    3. Команды, при наборе которых были допущены синтаксические ошибки, выводятся перечёркнутым текстом:
      $ l s-l
      bash: l: command not found
      

    4. Если код завершения команды равен нулю, команда была выполнена без ошибок. Команды, код завершения которых отличен от нуля, выделяются цветом.
      $ test 5 -lt 4
      Обратите внимание на то, что код завершения команды может быть отличен от нуля не только в тех случаях, когда команда была выполнена с ошибкой. Многие команды используют код завершения, например, для того чтобы показать результаты проверки

    5. Команды, ход выполнения которых был прерван пользователем, выделяются цветом.
      $ find / -name abc
      find: /home/devi-orig/.gnome2: Keine Berechtigung
      find: /home/devi-orig/.gnome2_private: Keine Berechtigung
      find: /home/devi-orig/.nautilus/metafiles: Keine Berechtigung
      find: /home/devi-orig/.metacity: Keine Berechtigung
      find: /home/devi-orig/.inkscape: Keine Berechtigung
      ^C
      

    6. Команды, выполненные с привилегиями суперпользователя, выделяются слева красной чертой.
      # id
      uid=0(root) gid=0(root) Gruppen=0(root)
      

    7. Изменения, внесённые в текстовый файл с помощью редактора, запоминаются и показываются в журнале в формате ed. Строки, начинающиеся символом "<", удалены, а строки, начинающиеся символом ">" -- добавлены.
      $ vi ~/.bashrc
      2a3,5
      >    if [ -f /usr/local/etc/bash_completion ]; then
      >         . /usr/local/etc/bash_completion
      >        fi
      

    8. Для того чтобы изменить файл в соответствии с показанными в диффшоте изменениями, можно воспользоваться командой patch. Нужно скопировать изменения, запустить программу patch, указав в качестве её аргумента файл, к которому применяются изменения, и всавить скопированный текст:
      $ patch ~/.bashrc
      В данном случае изменения применяются к файлу ~/.bashrc

    9. Для того чтобы получить краткую справочную информацию о команде, нужно подвести к ней мышь. Во всплывающей подсказке появится краткое описание команды.

      Если справочная информация о команде есть, команда выделяется голубым фоном, например: vi. Если справочная информация отсутствует, команда выделяется розовым фоном, например: notepad.exe. Справочная информация может отсутствовать в том случае, если (1) команда введена неверно; (2) если распознавание команды LiLaLo выполнено неверно; (3) если информация о команде неизвестна LiLaLo. Последнее возможно для редких команд.

    10. Большие, в особенности многострочные, всплывающие подсказки лучше всего показываются браузерами KDE Konqueror, Apple Safari и Microsoft Internet Explorer. В браузерах Mozilla и Firefox они отображаются не полностью, а вместо перевода строки выводится специальный символ.

    11. Время ввода команды, показанное в журнале, соответствует времени начала ввода командной строки, которое равно тому моменту, когда на терминале появилось приглашение интерпретатора

    12. Имя терминала, на котором была введена команда, показано в специальном блоке. Этот блок показывается только в том случае, если терминал текущей команды отличается от терминала предыдущей.

    13. Вывод не интересующих вас в настоящий момент элементов журнала, таких как время, имя терминала и других, можно отключить. Для этого нужно воспользоваться формой управления журналом вверху страницы.

    14. Небольшие комментарии к командам можно вставлять прямо из командной строки. Комментарий вводится прямо в командную строку, после символов #^ или #v. Символы ^ и v показывают направление выбора команды, к которой относится комментарий: ^ - к предыдущей, v - к следующей. Например, если в командной строке было введено:

      $ whoami
      
      user
      
      $ #^ Интересно, кто я?
      
      в журнале это будет выглядеть так:
      $ whoami
      
      user
      
      Интересно, кто я?

    15. Если комментарий содержит несколько строк, его можно вставить в журнал следующим образом:

      $ whoami
      
      user
      
      $ cat > /dev/null #^ Интересно, кто я?
      
      Программа whoami выводит имя пользователя, под которым 
      мы зарегистрировались в системе.
      -
      Она не может ответить на вопрос о нашем назначении 
      в этом мире.
      
      В журнале это будет выглядеть так:
      $ whoami
      user
      
      Интересно, кто я?
      Программа whoami выводит имя пользователя, под которым
      мы зарегистрировались в системе.

      Она не может ответить на вопрос о нашем назначении
      в этом мире.
      Для разделения нескольких абзацев между собой используйте символ "-", один в строке.

    16. Комментарии, не относящиеся непосредственно ни к какой из команд, добавляются точно таким же способом, только вместо симолов #^ или #v нужно использовать символы #=

    17. Содержимое файла может быть показано в журнале. Для этого его нужно вывести с помощью программы cat. Если вывод команды отметить симоволами #!, содержимое файла будет показано в журнале в специально отведённой для этого секции.
    18. Для того чтобы вставить скриншот интересующего вас окна в журнал, нужно воспользоваться командой l3shot. После того как команда вызвана, нужно с помощью мыши выбрать окно, которое должно быть в журнале.
    19. Команды в журнале расположены в хронологическом порядке. Если две команды давались одна за другой, но на разных терминалах, в журнале они будут рядом, даже если они не имеют друг к другу никакого отношения.
      1
          2
      3   
          4
      
      Группы команд, выполненных на разных терминалах, разделяются специальной линией. Под этой линией в правом углу показано имя терминала, на котором выполнялись команды. Для того чтобы посмотреть команды только одного сенса, нужно щёкнуть по этому названию.

    О программе

    LiLaLo (L3) расшифровывается как Live Lab Log.
    Программа разработана для повышения эффективности обучения Unix/Linux-системам.
    (c) Игорь Чубин, 2004-2008

    $Id$