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

Содержание

Журнал

Понедельник (07/16/18)

/dev/pts/0
09:05:27
#ls
install
09:06:42
#useradd ivan

09:15:03
#echo $?
0
09:16:24
#echo privet
privet
09:16:45
#useradd ivan
useradd: пользователь «ivan» уже существует
09:19:48
#echo $?
9
09:19:54
#useradd --help
Использование: useradd [параметры] ПОÐ
seradd -D
               useradd -D [параметры]
Параметры:
  -b, --base-dir БАЗ_КАТ        базовый каталог для домашнего каталога новой
                                учётной записи
  -c, --comment КОММЕНТАРИЙ     поле GECOS новой учётной записи
  -d, --home-dir ДОМ_КАТ        домашний каталог новой учётной записи
  -D, --defaults                показать или изменить настройки
                                по умолчанию для useradd
...
  -p, --password ПАРОЇётной записи
  -r, --system                  создать системную учётную запись
  -R, --root КАТ_CHROOT         каталог, в который выполняется chroot
  -s, --shell ОБОРновой
                                учётной записи
  -u, --uid UID                 пользовательский ID новой учётной записи
  -U, --user-group              создать группу с тем же именем что и у
                                пользователя
  -Z, --selinux-user SEUSER     использовать указанного SEUSER для
                                пользовательского сопоставления SELinux
09:21:18
#$LANG
l3script: ru_RU.UTF-8: команда не найдена
09:22:12
#$LANG=en_US.UTF8
l3script: ru_RU.UTF-8=en_US.UTF8: команда не найдена
09:22:24
#LANG='en_US.UTF8'

09:22:36
#useradd --help
Использование: useradd [параметры] ПОÐ
seradd -D
               useradd -D [параметры]
Параметры:
  -b, --base-dir БАЗ_КАТ        базовый каталог для домашнего каталога новой
                                учётной записи
  -c, --comment КОММЕНТАРИЙ     поле GECOS новой учётной записи
  -d, --home-dir ДОМ_КАТ        домашний каталог новой учётной записи
  -D, --defaults                показать или изменить настройки
                                по умолчанию для useradd
...
  -p, --password ПАРОЇётной записи
  -r, --system                  создать системную учётную запись
  -R, --root КАТ_CHROOT         каталог, в который выполняется chroot
  -s, --shell ОБОРновой
                                учётной записи
  -u, --uid UID                 пользовательский ID новой учётной записи
  -U, --user-group              создать группу с тем же именем что и у
                                пользователя
  -Z, --selinux-user SEUSER     использовать указанного SEUSER для
                                пользовательского сопоставления SELinux
09:22:38
#$LANG
l3script: en_US.UTF8: команда не найдена
09:22:43
#echo $LANG
en_US.UTF8
09:22:47
#LANG='en_UK.UTF8'
perl: warning: Setting locale failed.
perl: warning: Please check that your locale settings:
        LANGUAGE = "ru_UA:ru",
        LC_ALL = (unset),
        LANG = "en_UK.UTF8"
    are supported and installed on your system.
perl: warning: Falling back to the standard locale ("C").
09:23:00
#LANG='en_US.UTF8'

09:23:12
#man useradd
09:23:21
#LANG='en_US.UTF'
perl: warning: Setting locale failed.
perl: warning: Please check that your locale settings:
        LANGUAGE = "ru_UA:ru",
        LC_ALL = (unset),
        LANG = "en_US.UTF"
    are supported and installed on your system.
perl: warning: Falling back to the standard locale ("C").
09:23:26
#LANG=''

09:23:34
#man useradd
09:23:38
#useradd --help
Usage: useradd [options] LOGIN
       useradd -D
       useradd -D [options]
Options:
  -b, --base-dir BASE_DIR       base directory for the home directory of the
                                new account
  -c, --comment COMMENT         GECOS field of the new account
  -d, --home-dir HOME_DIR       home directory of the new account
  -D, --defaults                print or change default useradd configuration
  -e, --expiredate EXPIRE_DATE  expiration date of the new account
...
                                the user
  -o, --non-unique              allow to create users with duplicate
                                (non-unique) UID
  -p, --password PASSWORD       encrypted password of the new account
  -r, --system                  create a system account
  -R, --root CHROOT_DIR         directory to chroot into
  -s, --shell SHELL             login shell of the new account
  -u, --uid UID                 user ID of the new account
  -U, --user-group              create a group with the same name as the user
  -Z, --selinux-user SEUSER     use a specific SEUSER for the SELinux user mapping
09:24:10
#man useradd
09:26:31
#cat /etc/passwd | grep man
man:x:6:12:man:/var/cache/man:/bin/sh
09:26:40
#man useradd
09:30:56
#userdel ivan

09:34:44
#useradd --help
Usage: useradd [options] LOGIN
       useradd -D
       useradd -D [options]
Options:
  -b, --base-dir BASE_DIR       base directory for the home directory of the
                                new account
  -c, --comment COMMENT         GECOS field of the new account
  -d, --home-dir HOME_DIR       home directory of the new account
  -D, --defaults                print or change default useradd configuration
  -e, --expiredate EXPIRE_DATE  expiration date of the new account
...
                                the user
  -o, --non-unique              allow to create users with duplicate
                                (non-unique) UID
  -p, --password PASSWORD       encrypted password of the new account
  -r, --system                  create a system account
  -R, --root CHROOT_DIR         directory to chroot into
  -s, --shell SHELL             login shell of the new account
  -u, --uid UID                 user ID of the new account
  -U, --user-group              create a group with the same name as the user
  -Z, --selinux-user SEUSER     use a specific SEUSER for the SELinux user mapping
09:36:39
#useradd -ms /bin/bash ivan

09:39:48
#passwd ivan
Enter new UNIX password:
Retype new UNIX password:
passwd: password updated successfully
09:41:31
#useradd -m -s /bin/bash petr

09:44:35
#passwd petr
Enter new UNIX password:
Retype new UNIX password:
passwd: password updated successfully
09:44:42
#who
root     pts/0        Jul 16 09:55 (192.168.15.189)
ivan     pts/2        Jul 16 10:43 (192.168.15.189)
petr     pts/3        Jul 16 10:45 (192.168.15.189)
09:45:22
#whoami
root
09:46:02
#netstat -tanp | grep 22
tcp        0      0 0.0.0.0:22              0.0.0.0:*               LISTEN      2230/sshd
tcp        0      0 127.0.0.1:25            0.0.0.0:*               LISTEN      2201/exim4
tcp        0      0 192.168.13.6:22         192.168.15.189:49363    ESTABLISHED 2975/sshd: petr [pr
tcp        0      0 192.168.13.6:22         192.168.15.189:49243    ESTABLISHED 2362/0
tcp        0      0 192.168.13.6:22         192.168.15.189:49362    ESTABLISHED 2871/sshd: ivan [pr
tcp6       0      0 :::22                   :::*                    LISTEN      2230/sshd
tcp6       0      0 ::1:25                  :::*                    LISTEN      2201/exim4
09:46:49
#kill -1 2871

09:47:22
#who
root     pts/0        Jul 16 09:55 (192.168.15.189)
petr     pts/3        Jul 16 10:45 (192.168.15.189)
09:47:38
#whoami
root
09:48:39
#hostname
debian6
09:48:42
#pwd
/root
09:48:45
#echo ~
/root
09:49:23
#echo $HOME
/root
09:49:55
#cd /

09:59:36
#cd ..

10:00:02
#cd ivan
l3script: cd: ivan: No such file or directory
10:00:20
#cd root

10:00:33
#cd ..

10:00:51
#cd home

10:01:06
#cd ivan

10:01:30
#cd /

10:01:44
#cd home/ivan

10:02:05
#cd

10:02:15
#cd home/ivan
l3script: cd: home/ivan: No such file or directory
10:03:02
#cd /home/ivan

10:03:24
#cd

10:04:07
#ls -l
total 8
-rw-r--r-- 1 root root 5268 Oct 13  2014 install
прошла 21 минута
10:26:00
#ls -la
total 56
drwx------  5 root root 4096 Jul 16 10:02 .
drwxr-xr-x 24 root root 4096 Oct 15  2014 ..
drwx------  2 root root 4096 Jun 27  2014 .aptitude
-rw-------  1 root root 2227 Jul 16 09:12 .bash_history
-rw-r--r--  1 root root   10 Jun 27  2014 .bash_profile
-rw-r--r--  1 root root  630 Jun 27  2014 .bashrc
-rw-r--r--  1 root root   51 Jul 13 14:54 .l3rc
drwxr-xr-x  2 root root 4096 Jul 16 10:05 .lilalo
-rw-r--r--  1 root root  140 Nov 19  2007 .profile
drwxr-xr-x  2 root root 4096 Jun 27  2014 .vim
-rw-------  1 root root 5345 Jul 16 10:02 .viminfo
-rw-r--r--  1 root root 5268 Oct 13  2014 install
10:28:43
#ls -la --color
total 56
drwx------  5 root root 4096 Jul 16 10:02 .
drwxr-xr-x 24 root root 4096 Oct 15  2014 ..
drwx------  2 root root 4096 Jun 27  2014 .aptitude
-rw-------  1 root root 2227 Jul 16 09:12 .bash_history
-rw-r--r--  1 root root   10 Jun 27  2014 .bash_profile
-rw-r--r--  1 root root  630 Jun 27  2014 .bashrc
-rw-r--r--  1 root root   51 Jul 13 14:54 .l3rc
drwxr-xr-x  2 root root 4096 Jul 16 10:05 .lilalo
-rw-r--r--  1 root root  140 Nov 19  2007 .profile
drwxr-xr-x  2 root root 4096 Jun 27  2014 .vim
-rw-------  1 root root 5345 Jul 16 10:02 .viminfo
-rw-r--r--  1 root root 5268 Oct 13  2014 install
10:32:21
#alias ls='ls --color'

10:33:24
#ls -la
total 56
drwx------  5 root root 4096 Jul 16 10:02 .
drwxr-xr-x 24 root root 4096 Oct 15  2014 ..
drwx------  2 root root 4096 Jun 27  2014 .aptitude
-rw-------  1 root root 2227 Jul 16 09:12 .bash_history
-rw-r--r--  1 root root   10 Jun 27  2014 .bash_profile
-rw-r--r--  1 root root  630 Jun 27  2014 .bashrc
-rw-r--r--  1 root root   51 Jul 13 14:54 .l3rc
drwxr-xr-x  2 root root 4096 Jul 16 10:05 .lilalo
-rw-r--r--  1 root root  140 Nov 19  2007 .profile
drwxr-xr-x  2 root root 4096 Jun 27  2014 .vim
-rw-------  1 root root 5345 Jul 16 10:02 .viminfo
-rw-r--r--  1 root root 5268 Oct 13  2014 install
10:34:46
#alias
alias ls='ls --color'
10:35:02
#who
root     pts/0        Jul 16 09:55 (192.168.15.189)
ivan     pts/2        Jul 16 10:51 (192.168.15.189)
petr     pts/3        Jul 16 10:45 (192.168.15.189)
user     pts/4        Jul 16 10:51 (192.168.15.189)
прошло 11 минут
10:46:43
#echo privet > /dev/pts/2

10:47:45
#ls
install
10:49:44
#mailq

10:49:59
#who
root     pts/0        Jul 16 09:55 (192.168.15.189)
ivan     pts/2        Jul 16 10:51 (192.168.15.189)
petr     pts/3        Jul 16 10:45 (192.168.15.189)
user     pts/4        Jul 16 10:51 (192.168.15.189)
10:50:42
#which who
/usr/bin/who
10:50:49
#ls -l /usr/bin/who
-rwxr-xr-x 1 root root 55888 Jan 26  2013 /usr/bin/who
10:52:17
#which mailq
/usr/bin/mailq
10:53:16
#ls -l /usr/bin/mailq
lrwxrwxrwx 1 root root 13 Jan  2  2013 /usr/bin/mailq -> ../sbin/exim4
10:53:33
#ls -l /usr/sbin/exim4
-rwsr-xr-x 1 root root 973824 Jan  2  2013 /usr/sbin/exim4
10:54:44
#ls -l /dev/cdrom1
lrwxrwxrwx 1 root root 3 Jul 16 08:37 /dev/cdrom1 -> sr0
10:56:48
#ls -l /dev/sr0
brw-rw---T 1 root cdrom 11, 0 Jul 16 08:37 /dev/sr0
10:57:20
#mkfifo /tmp/test

11:02:49
#ls -l /tmp/test
prw-r--r-- 1 root root 0 Jul 16 12:02 /tmp/test
11:03:19
#echo privet /tmp/test
privet /tmp/test
11:04:00
#echo privet > /tmp/test

11:04:49
#ls -l /dev/log
srw-rw-rw- 1 root root 0 Jul 16 08:37 /dev/log
11:06:29
#man setterm
11:08:23
#terminfo
l3script: terminfo: command not found
11:08:27
#netstat
Active Internet connections (w/o servers)
Proto Recv-Q Send-Q Local Address           Foreign Address         State
tcp        0      0 debian6.net.nt:ssh      192.168.15.189:49363    ESTABLISHED
tcp        0      0 debian6.net.nt:ssh      192.168.15.189:49374    ESTABLISHED
tcp        0    432 debian6.net.nt:ssh      192.168.15.189:49243    ESTABLISHED
tcp        0      0 debian6.net.nt:ssh      192.168.15.189:49375    ESTABLISHED
Active UNIX domain sockets (w/o servers)
Proto RefCnt Flags       Type       State         I-Node   Path
unix  7      [ ]         DGRAM                    5048     /dev/log
unix  3      [ ]         STREAM     CONNECTED     7920
...
unix  3      [ ]         STREAM     CONNECTED     7819
unix  3      [ ]         STREAM     CONNECTED     7818
unix  2      [ ]         DGRAM                    7817
unix  3      [ ]         STREAM     CONNECTED     7300
unix  3      [ ]         STREAM     CONNECTED     7299
unix  2      [ ]         DGRAM                    7298
unix  2      [ ]         DGRAM                    5598
unix  2      [ ]         DGRAM                    5073
unix  3      [ ]         DGRAM                    3250
unix  3      [ ]         DGRAM                    3249
11:09:34
#cd /home/ivan

11:12:30
#cd /home/petr

11:12:47
#cd -
/home/ivan
11:13:01
#cd -
/home/petr
11:13:08
#echo $PWD
/home/petr
11:14:01
#echo $OLDPWD
/home/ivan
11:14:10
#PWD=/root

11:15:10
#echo $OLDPWD
/home/ivan
11:15:23
#cd -
/home/ivan
11:15:50
#apt-get install tree
Reading package lists... Done
Building dependency tree
Reading state information... Done
The following NEW packages will be installed:
  tree
0 upgraded, 1 newly installed, 0 to remove and 0 not upgraded.
Need to get 43.3 kB of archives.
After this operation, 112 kB of additional disk space will be used.
Get:1 http://ftp.ua.debian.org/debian/ wheezy/main tree amd64 1.6.0-1 [43.3 kB]
Fetched 43.3 kB in 0s (538 kB/s)
Selecting previously unselected package tree.
(Reading database ... 28835 files and directories currently installed.)
Unpacking tree (from .../tree_1.6.0-1_amd64.deb) ...
Processing triggers for man-db ...
Setting up tree (1.6.0-1) ...
прошло 22 минуты
11:38:46
#cd

прошло 63 минуты
12:42:01
#ls
install
12:42:06
#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
12:42:11
#more install
12:43:19
#less install
12:46:39
#head -5 install
#!/bin/sh
hostname=`hostname`
uname -a | egrep -qi '(freebsd|darwin)' || hostname=`hostname -f`
12:46:48
#tail install
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
12:48:27
#tail install | nl
     1  step "Downloading perl modules for l3-agent" '{ for i in ${perl_modules}; do ${wget} ${url_perl_modules}/$i.tar.gz; done; }'
     2  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; }'
     3  step "Installing l3bashrc to users home directories" install_to_users_homes $install_l3bashrc_for_this_users
     4  step "Adding l3bashrc invocation to ~/.bashrc " install_to_users_bashrc $install_l3bashrc_for_this_users
     5  step "Adding l3-agent invocation to ~/.bash_profile " install_to_users_bash_profile $install_l3bashrc_for_this_users
     6  cd /
     7  rm -rf ${temp_dir}
     8  show_final_message
12:48:51
#tail -f /var/log/
alternatives.log    dmesg.0             mail.log
alternatives.log.1  dmesg.1.gz          mail.warn
apt/                dmesg.2.gz          messages
aptitude            dmesg.3.gz          messages.1
aptitude.1.gz       dmesg.4.gz          messages.2.gz
auth.log            dpkg.log            messages.3.gz
auth.log.1          dpkg.log.1          messages.4.gz
auth.log.2.gz       dpkg.log.2.gz       news/
auth.log.3.gz       exim4/              syslog
auth.log.4.gz       faillog             syslog.1
btmp                fsck/               syslog.2.gz
btmp.1              installer/          syslog.3.gz
daemon.log          iptraf/             syslog.4.gz
daemon.log.1        kern.log            syslog.5.gz
daemon.log.2.gz     kern.log.1          syslog.6.gz
daemon.log.3.gz     kern.log.2.gz       user.log
debug               kern.log.3.gz       user.log.1
debug.1             lastlog             user.log.2.gz
debug.2.gz          lpr.log             user.log.3.gz
debug.3.gz          mail.err            wtmp
dmesg               mail.info           wtmp.1
12:48:51
#tail -f /var/log/auth.log
Jul 16 10:51:02 debian6 sshd[3139]: Accepted password for ivan from 192.168.15.189 port 49374 ssh2
Jul 16 10:51:02 debian6 sshd[3139]: pam_unix(sshd:session): session opened for user ivan by (uid=0)
Jul 16 10:51:21 debian6 sshd[3223]: Accepted password for user from 192.168.15.189 port 49375 ssh2
Jul 16 10:51:21 debian6 sshd[3223]: pam_unix(sshd:session): session opened for user user by (uid=0)
Jul 16 11:17:01 debian6 CRON[3495]: pam_unix(cron:session): session opened for user root by (uid=0)
Jul 16 11:17:01 debian6 CRON[3495]: pam_unix(cron:session): session closed for user root
Jul 16 12:17:01 debian6 CRON[3789]: pam_unix(cron:session): session opened for user root by (uid=0)
Jul 16 12:17:01 debian6 CRON[3789]: pam_unix(cron:session): session closed for user root
Jul 16 13:17:01 debian6 CRON[4090]: pam_unix(cron:session): session opened for user root by (uid=0)
Jul 16 13:17:01 debian6 CRON[4090]: pam_unix(cron:session): session closed for user root
Jul 16 13:50:58 debian6 sshd[4168]: Accepted password for petr from 192.168.15.147 port 49439 ssh2
Jul 16 13:50:58 debian6 sshd[4168]: pam_unix(sshd:session): session opened for user petr by (uid=0)
Jul 16 13:51:18 debian6 sshd[4168]: pam_unix(sshd:session): session closed for user petr
^C
12:51:41
#tac install
show_final_message
rm -rf ${temp_dir}
cd /
step "Adding l3-agent invocation to ~/.bash_profile " install_to_users_bash_profile $install_l3bashrc_for_this_users
step "Adding l3bashrc invocation to ~/.bashrc " install_to_users_bashrc $install_l3bashrc_for_this_users
step "Installing l3bashrc to users home directories" install_to_users_homes $install_l3bashrc_for_this_users
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 "Downloading perl modules for l3-agent" '{ for i in ${perl_modules}; do ${wget} ${url_perl_modules}/$i.tar.gz; done; }'
step "Downloading l3-agent" '${wget} ${url_l3agent}; ${wget} ${url_l3config_pm}; ${wget} ${url_l3config}'
step "Downloading l3prompt" ${wget} ${url_l3prompt}
...
lilalo_context="/users/${lilalo_user}/${lab}/${hostname}"
install_l3bashrc_for_this_users=${users:-"root user"}  # users who will use l3agent and l3script
lab=NT-LNet
lilalo_user=13-10-2014
# Set this variables before installation:
#
###############################################################################
uname -a | egrep -qi '(freebsd|darwin)' || hostname=`hostname -f`
hostname=`hostname`
#!/bin/sh
12:52:20
#man tac

Файлы

  • install
  • 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
    

    Статистика

    Время первой команды журнала09:05:27 2018- 7-16
    Время последней команды журнала12:52:20 2018- 7-16
    Количество командных строк в журнале100
    Процент команд с ненулевым кодом завершения, % 3.00
    Процент синтаксически неверно набранных команд, % 4.00
    Суммарное время работы с терминалом *, час 2.73
    Количество командных строк в единицу времени, команда/мин 0.61
    Частота использования команд
    cd19|==================| 18.10%
    ls14|=============| 13.33%
    echo12|===========| 11.43%
    useradd8|=======| 7.62%
    man6|=====| 5.71%
    tail4|===| 3.81%
    who4|===| 3.81%
    passwd2|=| 1.90%
    whoami2|=| 1.90%
    netstat2|=| 1.90%
    cat2|=| 1.90%
    $LANG2|=| 1.90%
    alias2|=| 1.90%
    LANG='en_US.UTF8'2|=| 1.90%
    grep2|=| 1.90%
    which2|=| 1.90%
    more1|| 0.95%
    LANG='en_US.UTF'1|| 0.95%
    $LANG=en_US.UTF81|| 0.95%
    nl1|| 0.95%
    mkfifo1|| 0.95%
    root1|| 0.95%
    apt-get1|| 0.95%
    LANG='en_UK.UTF8'1|| 0.95%
    pwd1|| 0.95%
    LANG=''1|| 0.95%
    tac1|| 0.95%
    userdel1|| 0.95%
    terminfo1|| 0.95%
    head1|| 0.95%
    mailq1|| 0.95%
    less1|| 0.95%
    21|| 0.95%
    kill1|| 0.95%
    hostname1|| 0.95%
    test1|| 0.95%
    ____
    *) Интервалы неактивности длительностью 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$