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

Содержание

Журнал

Вторник (11/03/20)

/dev/pts/0
08:57:03
#ls
1121233-11223  232343534  2823811g  9329129011  d1  d2  f1  install  -r
08:57:05
#rm -/-r
rm: неверный ключ -- /
Попробуйте «rm --help» для получения более подробного описания.
08:57:57
#rm -- -r

-- no options - no args
08:58:52
#ls +([0-9])
l3script: syntax error near unexpected token `('
09:00:33
#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
09:00:54
#shopt -s extglob

09:01:37
#ls +([0-9])
232343534  9329129011
09:01:44
#ls +([0-Z])
232343534  2823811g  9329129011  f1  install
d1:
d2
d2:
d3  f2
09:03:47
#ls +([0-9])[a-z]
2823811g
09:04:31
#ls +([0-9])+[a-z]+([0-9])
ls: невозможно получить доступ к +([0-9])+[a-z]+([0-9]): Нет такого файла или каталога
09:05:09
#ls +([0-9])+[a-z]
ls: невозможно получить доступ к +([0-9])+[a-z]: Нет такого файла или каталога
09:05:19
#ls +([0-9])+([a-z])+([0-9])
ls: невозможно получить доступ к +([0-9])+([a-z])+([0-9]): Нет такого файла или каталога
09:05:35
#ls +([0-9])+([a-z])
2823811g
09:05:40
#ls +([0-9])*([a-z])
232343534  2823811g  9329129011
09:07:03
#echo $[2+2]
4
прошло 40 минут
09:47:55
#echo $((2+2))
4
09:48:19
#LANG=''

09:48:50
#ps ax
  PID TTY      STAT   TIME COMMAND
    1 ?        Ss     0:05 init [2]
    2 ?        S      0:00 [kthreadd]
    3 ?        S      0:00 [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]
...
 7094 ?        Ss     0:00 sshd: petr [priv]
 7096 ?        S      0:00 sshd: petr@pts/3
 7097 pts/3    Ss+    0:00 -bash
 7178 ?        Ss     0:00 sshd: user [priv]
 7180 ?        S      0:00 sshd: user@pts/4
 7181 pts/4    Ss     0:00 -bash
 7226 pts/4    S+     0:00 script -f -c l3script -q /home/user/.lilalo//22808282172789924041-1604388753.script
 7297 pts/4    S+     0:00 script -f -c l3script -q /home/user/.lilalo//22808282172789924041-1604388753.script
 7298 pts/5    Ss+    0:00 l3script
 7749 pts/1    R+     0:00 ps ax
09:48:58
#ps u -u ivan
USER       PID %CPU %MEM    VSZ   RSS TTY      STAT START   TIME COMMAND
ivan      6794  0.0  0.3  71288  1872 ?        S    09:25   0:00 sshd: ivan@pts/2
ivan      6795  0.0  0.6  22600  3268 pts/2    Ss+  09:25   0:00 -bash
09:49:36
#ps ax | wc -l
65
09:51:32
#echo $[$(ps ax | wc -l)-4]
62
count number of processes without header, ps ax, echo and?
09:58:32
#ps ax | awk '{print $5, "\t", $1}'
COMMAND          PID
init     1
[kthreadd]       2
[ksoftirqd/0]    3
[kworker/u:0]    5
[migration/0]    6
[watchdog/0]     7
[cpuset]         8
[khelper]        9
[kdevtmpfs]      10
...
sshd:    7096
-bash    7097
sshd:    7178
sshd:    7180
-bash    7181
script   7226
script   7297
l3script         7298
ps       7793
awk      7794
09:59:58
#ps ax | awk '{print $5, "\t", $1}' | expand -t 1, 20
expand: 20: No such file or directory
10:06:39
#ps ax | awk '{print $5,"\t",$1}' | expand -t 1,20
COMMAND              PID
init                 1
[kthreadd]           2
[ksoftirqd/0]        3
[kworker/u:0]        5
[migration/0]        6
[watchdog/0]         7
[cpuset]             8
[khelper]            9
[kdevtmpfs]          10
...
-bash                7097
sshd:                7178
sshd:                7180
-bash                7181
script               7226
script               7297
l3script             7298
ps                   7812
awk                  7813
expand               7814
10:07:20
#touch f{1,2,2}

10:09:44
#ls
1121233-11223  232343534  2823811g  9329129011  d1  d2  f1  f2  install
10:09:45
#ls +([0-9])*([a-z])
232343534  2823811g  9329129011
10:10:09
#rm +([0-9])*([a-z])

10:10:39
#ls
1121233-11223  d1  d2  f1  f2  install
10:10:43
#rm +([0-9])*([0-9])
rm: cannot remove `+([0-9])*([0-9])': No such file or directory
10:11:22
#rm +([0-9])*+([0-9])

10:11:35
#ls
d1  d2  f1  f2  install
10:11:46
#touch f{1,2,3}

10:13:46
#ls
d1  d2  f1  f2  f3  install
10:13:52
#touch f{1,2,3}

10:15:56
#^f^d
touch d{1,2,3}
10:16:09
#ls
d1  d2  d3  f1  f2  f3  install
10:16:11
#who
root     pts/0        Nov  3 09:19 (192.168.15.129)
ivan     pts/2        Nov  3 09:25 (192.168.15.129)
petr     pts/3        Nov  3 09:30 (192.168.15.129)
user     pts/4        Nov  3 09:32 (192.168.15.129)
10:22:00
#who > who.txt

10:22:43
#who >> who.txt

10:22:50
#who
root     pts/0        Nov  3 09:19 (192.168.15.129)
ivan     pts/2        Nov  3 09:25 (192.168.15.129)
petr     pts/3        Nov  3 09:30 (192.168.15.129)
user     pts/4        Nov  3 09:32 (192.168.15.129)
10:23:03
#tty
/dev/pts/0
10:23:20
#who 1> who.txt

10:23:56
#who
root     pts/0        Nov  3 09:19 (192.168.15.129)
ivan     pts/2        Nov  3 09:25 (192.168.15.129)
petr     pts/3        Nov  3 09:30 (192.168.15.129)
user     pts/4        Nov  3 09:32 (192.168.15.129)
10:23:59
#zzxc 2> error.txt

10:24:47
#command1 &> /dev/null

10:28:09
#ls
d1  d2  d3  error.txt  f1  f2  f3  install  who.txt
10:29:00
#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:29:52
#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
10:30:03
#set -o noclobber

10:31:46
#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
10:31:52
#who 1> who.txt
l3script: who.txt: cannot overwrite existing file
10:32:06
#who 1>| who.txt

10:32:40
#cat who.txt
root     pts/0        Nov  3 09:19 (192.168.15.129)
ivan     pts/2        Nov  3 09:25 (192.168.15.129)
petr     pts/3        Nov  3 09:30 (192.168.15.129)
user     pts/4        Nov  3 09:32 (192.168.15.129)
10:32:52
#lsattr who.txt
-------------e-- who.txt
10:33:57
#chattr +a who.txt

10:34:46
#who 1>| who.txt
l3script: who.txt: Operation not permitted
10:34:57
#set +o noclobber

10:35:10
#who 1>| who.txt
l3script: who.txt: Operation not permitted
10:35:12
#lsattr who.txt
-----a-------e-- who.txt
10:35:24
#chattr +i who.txt

10:37:03
#lsattr who.txt
----ia-------e-- who.txt
10:37:06
#cat who.txt
root     pts/0        Nov  3 09:19 (192.168.15.129)
ivan     pts/2        Nov  3 09:25 (192.168.15.129)
petr     pts/3        Nov  3 09:30 (192.168.15.129)
user     pts/4        Nov  3 09:32 (192.168.15.129)
10:37:24
#who 1>| who.txt
l3script: who.txt: Permission denied
attr i = immunity
10:38:35
#lsattr who.txt
----ia-------e-- who.txt
10:38:46
#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
прошло >2 часов
12:40:50
#vi ip.txt
--- /dev/null	2020-10-30 12:26:02.112000001 +0200
+++ ip.txt	2020-11-03 13:43:32.412011837 +0200
@@ -0,0 +1,3 @@
+p
+q
+
12:43:32
#vi ip.txt
--- /tmp/l3-saved-6675.9112.28350	2020-11-03 13:43:35.119994951 +0200
+++ ip.txt	2020-11-03 13:48:38.328001579 +0200
@@ -1,3 +1,10 @@
-p
-q
-
+10.1.102.55
+qq.qqq.rr.gf
+122.234.256.12
+123.15.54.1
+8.8.8.8
+345.678.1.2
+8.8.8.a
+8.8.8.300
+10.1.103.45.5
+7.1.-1.1
12:48:38
#cat ip.txt
10.1.102.55
qq.qqq.rr.gf
122.234.256.12
123.15.54.1
8.8.8.8
345.678.1.2
8.8.8.a
8.8.8.300
10.1.103.45.5
7.1.-1.1
12:48:51
#cat ip.txt | egrep '^(^C0-9]{1,2}|1[0-9]{2}|2[0-4][0-9]|25[0-5])\.){3}$'

прошло 11 минут
13:00:41
#cat ip.txt | egrep '^(^C0-9]{1,2}|1[0-9]{2}|2[0-4][0-9]|25[0-5])\.){3}$'
egrep: Unmatched ) or \)
13:01:25
#cat ip.txt | egrep '^((^C0-9]{1,2}|1[0-9]{2}|2[0-4][0-9]|25[0-5])\.{3}(^C0-9]{1,2}|1[0-9]{2}|2[0-4][0-9]|25[0-5])

13:01:25
#cat ip.txt | egrep '^((^C0-9]{1,2}|1[0-9]{2}|2[0-4][0-9]|25[0-5])\.{3}(^C0-9]{1,2}|1[0-9]{2}|2[0-4][0-9]|25[0-5])
egrep: Unmatched ( or \(
13:02:55
#cat ip.txt | egrep '^((^C0-9]{1,2}|1[0-9]{2}|2[0-4][0-9]|25[0-5])\.){3}(^C0-9]{1,2}|1[0-9]{2}|2[0-4][0-9]|25[0-5])$'

13:03:28
#cat ip.txt | egrep '^((^[0-9]{1,2}|1[0-9]{2}|2[0-4][0-9]|25[0-5])\.){3}(^[0-9]{1,2}|1[0-9]{2}|2[0-4][0-9]|25[0-5])$'

13:04:08
#cat ip.txt | egrep '^(([0-9]{1,2}|1[0-9]{2}|2[0-4][0-9]|25[0-5])\.){3}([0-9]{1,2}|1[0-9]{2}|2[0-4][0-9]|25[0-5])$'
10.1.102.55
123.15.54.1
8.8.8.8
13:04:33
#ifconfig
eth0      Link encap:Ethernet  HWaddr 00:16:3e:00:00:03
          inet addr:192.168.13.3  Bcast:192.168.13.255  Mask:255.255.255.0
          inet6 addr: fe80::216:3eff:fe00:3/64 Scope:Link
          UP BROADCAST RUNNING MULTICAST  MTU:1500  Metric:1
          RX packets:36856 errors:0 dropped:0 overruns:0 frame:0
          TX packets:29266 errors:0 dropped:0 overruns:0 carrier:0
          collisions:0 txqueuelen:1000
          RX bytes:2981888 (2.8 MiB)  TX bytes:4700420 (4.4 MiB)
          Interrupt:72
lo        Link encap:Local Loopback
          inet addr:127.0.0.1  Mask:255.0.0.0
          inet6 addr: ::1/128 Scope:Host
          UP LOOPBACK RUNNING  MTU:16436  Metric:1
          RX packets:0 errors:0 dropped:0 overruns:0 frame:0
          TX packets:0 errors:0 dropped:0 overruns:0 carrier:0
          collisions:0 txqueuelen:0
          RX bytes:0 (0.0 B)  TX bytes:0 (0.0 B)
прошло 50 минут
13:55:12
#netstat -tn
Active Internet connections (w/o servers)
Proto Recv-Q Send-Q Local Address           Foreign Address         State
tcp        0      0 192.168.13.3:22         192.168.15.129:50048    ESTABLISHED
tcp        0      0 192.168.13.3:22         192.168.15.129:50050    ESTABLISHED
tcp        0    432 192.168.13.3:22         192.168.15.129:50046    ESTABLISHED
tcp        0      0 192.168.13.3:22         192.168.15.129:50051    ESTABLISHED
13:59:01
#netstat -tn | awk '{print $5}'
servers)
Address
192.168.15.129:50048
192.168.15.129:50050
192.168.15.129:50046
5.9.243.178:18030
192.168.15.129:50051
13:59:38
#netstat -tn | awk '{print $5}' | sed '1,2d'
192.168.15.129:50048
192.168.15.129:50050
192.168.15.129:50046
192.168.15.129:50051
14:00:42
#netstat -tn | awk '{print $5}' | sed '1,2d' | cut -d: -f1
192.168.15.129
192.168.15.129
192.168.15.129
5.9.243.178
192.168.15.129
14:01:24
#netstat -tn | awk '{print $5}' | sed '1,2d' | cut -d: -f1 | sort
192.168.15.129
192.168.15.129
192.168.15.129
192.168.15.129
5.9.243.178
14:01:34
#netstat -tn | awk '{print $5}' | sed '1,2d' | cut -d: -f1 | sort | uniq
192.168.15.129
5.9.243.178
14:01:52
#netstat -tn | awk '{print $5}' | sed '1,2d' | cut -d: -f1 | sort | uniq -c
      4 192.168.15.129
      2 5.9.243.178
14:01:59
#netstat -tn | awk '{print $5}' | sed '1,2d' | cut -d: -f1 | sort | uniq -c | sort -r -n
      4 192.168.15.129
      3 5.9.243.178
14:02:24
#netstat -tn | awk '{print $5}' | sed '1,2d' | cut -d: -f1 | sort | uniq -c | sort -r -n | awk '$1>3'
      4 192.168.15.129
14:03:18
#netstat -tn | awk '{print $5}' | sed '1,2d' | cut -d: -f1 | sort | uniq -c | sort -r -n | awk '$1>3'

14:03:18
#netstat -tn | awk '{print $5}' | sed '1,2d' | cut -d: -f1 | sort | uniq -c | sort -r -n | awk '$1>3'
      4 192.168.15.129
14:04:32
#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
14:08:10
#cat install | tr '[:punct:]' ''
tr: when not truncating set1, string2 must be non-empty
14:10:26
#cat install | tr '[:punct:]' ' '
   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
...
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
14:10:36
#cat install | tr '[:punct:]' ' ' | tr -s ' ' | tr ' ' '\n'
bin
sh
hostname
hostname
uname
a
egrep
qi
freebsd
darwin
...
this
users
cd
rm
rf
temp
dir
show
final
message
14:11:41
#cat install | tr '[:punct:]' ' ' | tr -s ' ' | tr ' ' '\n' | grep -v '^$'
bin
sh
hostname
hostname
uname
a
egrep
qi
freebsd
darwin
...
this
users
cd
rm
rf
temp
dir
show
final
message
14:12:19
#cat install | tr '[:punct:]' ' ' | tr -s ' ' | tr ' ' '\n' | grep -v '^$' | tr [:upper:] [:lower:] | sort | uniq
0
033
1
10
13
1s
2
2014
31m
32m
...
will
writing
x
xgu
xvfz
y
you
your
yy
z
14:15:17
#cd /tmp

прошла 91 минута
15:46:40
#ls
NewNames  dirlist  etccopy  test
15:46:46
#vi newnames
15:47:05
#vi NewNames

Файлы

  • install
  • ip.txt
  • who.txt
  • 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
    
    ip.txt
    >
    10.1.102.55
    qq.qqq.rr.gf
    122.234.256.12
    123.15.54.1
    8.8.8.8
    345.678.1.2
    8.8.8.a
    8.8.8.300
    10.1.103.45.5
    7.1.-1.1
    
    who.txt
    >
    root     pts/0        Nov  3 09:19 (192.168.15.129)
    ivan     pts/2        Nov  3 09:25 (192.168.15.129)
    petr     pts/3        Nov  3 09:30 (192.168.15.129)
    user     pts/4        Nov  3 09:32 (192.168.15.129)
    

    Статистика

    Время первой команды журнала08:57:03 2020-11- 3
    Время последней команды журнала15:47:05 2020-11- 3
    Количество командных строк в журнале98
    Процент команд с ненулевым кодом завершения, %21.43
    Процент синтаксически неверно набранных команд, % 2.04
    Суммарное время работы с терминалом *, час 1.75
    Количество командных строк в единицу времени, команда/мин 0.93
    Частота использования команд
    ls18|========| 8.78%
    cat17|========| 8.29%
    awk13|======| 6.34%
    netstat11|=====| 5.37%
    who11|=====| 5.37%
    sed9|====| 4.39%
    sort8|===| 3.90%
    cut8|===| 3.90%
    who.txt8|===| 3.90%
    uniq7|===| 3.41%
    egrep7|===| 3.41%
    1[0-9]{2}7|===| 3.41%
    2[0-4][0-9]7|===| 3.41%
    ps6|==| 2.93%
    rm5|==| 2.44%
    tr5|==| 2.44%
    lsattr4|=| 1.95%
    set4|=| 1.95%
    vi4|=| 1.95%
    echo3|=| 1.46%
    #^3|=| 1.46%
    touch3|=| 1.46%
    3'3|=| 1.46%
    25[0-5])$'3|=| 1.46%
    shopt3|=| 1.46%
    expand2|| 0.98%
    wc2|| 0.98%
    25[0-5])2|| 0.98%
    25[0-5])\.){3}$'2|| 0.98%
    25[0-5])\.{3}(^C0-9]{1,2}2|| 0.98%
    >2|| 0.98%
    grep2|| 0.98%
    chattr2|| 0.98%
    Частота использования этих команд < 0.5%ifconfig1 , 25[0-5])\.){3}(^[0-9]{1,2}1 , cd1 , ^f^d1 , LANG=''1 , zzxc1 , null1 , 25[0-5])\.){3}([0-9]{1,2}1 , 25[0-5])\.){3}(^C0-9]{1,2}1 , error.txt1 , tty1 , command11
    ____
    *) Интервалы неактивности длительностью 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$