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

Содержание

Журнал

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

/dev/pts/0
09:05:53
#ls
install
09:06:45
#useradd ivan

09:15:06
#echo $?
0
09:16:22
#useradd ivan
useradd: пользователь «ivan» уже существует
09:19:48
#echo $?
9
09:19:59
#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

09:22:23
#LANG=``

09:24:10
#$$LANG=``
l3script: 2375LANG=: command not found
09:24:37
#man useradd
09:28:19
#passwd ivan
Enter new UNIX password:
Retype new UNIX password:
passwd: password updated successfully
09:30:58
#userdel ivan

09:34:45
#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 -m -s /bin/bash ivan

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

09:50:00
#passwd petr
Enter new UNIX password:
Retype new UNIX password:
passwd: password updated successfully
09:50:27
#useradd -m -s /bin/bash petr
useradd: user 'petr' already exists
09:50:32
#cd /

09:59:44
#cd ..

10:00:18
#cd ivan
l3script: cd: ivan: No such file or directory
10:00:24
#cd root

10:00:38
#cd ..

10:00:55
#cd home

10:01:15
#cd ivan

10:01:33
#cd home/ivan
l3script: cd: home/ivan: No such file or directory
10:02:06
#cd ivan
l3script: cd: ivan: No such file or directory
10:02:14
#cd

10:02:18
#cd /home/ivan

10:03:33
#cd

10:04:10
#ls -l
total 8
-rw-r--r-- 1 root root 5268 Oct 13  2014 install
прошла 21 минута
10:26:08
#ls -la
total 56
drwx------  5 root root 4096 Jul 16 10:01 .
drwxr-xr-x 24 root root 4096 Oct 15  2014 ..
drwx------  2 root root 4096 Jun 27  2014 .aptitude
-rw-------  1 root root 1896 Oct 15  2014 .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:53 .l3rc
drwxr-xr-x  2 root root 4096 Jul 16 10:06 .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 5369 Jul 16 10:01 .viminfo
-rw-r--r--  1 root root 5268 Oct 13  2014 install
10:28:45
#ls -la --colot
ls: unrecognized option '--colot'
Try `ls --help' for more information.
10:32:22
#ls -la --color
total 56
drwx------  5 root root 4096 Jul 16 10:01 .
drwxr-xr-x 24 root root 4096 Oct 15  2014 ..
drwx------  2 root root 4096 Jun 27  2014 .aptitude
-rw-------  1 root root 1896 Oct 15  2014 .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:53 .l3rc
drwxr-xr-x  2 root root 4096 Jul 16 10:06 .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 5369 Jul 16 10:01 .viminfo
-rw-r--r--  1 root root 5268 Oct 13  2014 install
10:32:26
#alias ls=`ls --color
> alias ls=`ls --color`
> alias ls=`ls --color
alias ls='ls --color'
l3script: alias: --colorls: not found
l3script: alias: --color: not found
10:34:42
#alias
alias ls='ls --color'
10:35:08
#who
root     pts/0        Jul 16 09:55 (192.168.15.124)
ivan     pts/2        Jul 16 10:42 (192.168.15.124)
user     pts/3        Jul 16 10:51 (192.168.15.124)
прошло 11 минут
10:46:48
#echo privet >/dev/pts/2

10:47:46
#ls
install
10:49:54
#mailq

10:50:12
#who
root     pts/0        Jul 16 09:55 (192.168.15.124)
ivan     pts/2        Jul 16 10:42 (192.168.15.124)
user     pts/3        Jul 16 10:51 (192.168.15.124)
10:50:47
#which who
/usr/bin/who
10:51:07
#ls-l /usr/bin/who
l3script: ls-l: command not found
10:52:35
#ls -l /usr/bin/who
-rwxr-xr-x 1 root root 55888 Jan 26  2013 /usr/bin/who
10:52:55
#wich mailq
l3script: wich: command not found
10:53:25
#wich maailq
l3script: wich: command not found
10:53:40
#wich mailq
l3script: wich: command not found
10:54:03
#which mailq
/usr/bin/mailq
10:54:23
#ls -l /usr/sbin/exim4
-rwsr-xr-x 1 root root 973824 Jan  2  2013 /usr/sbin/exim4
10:55:02
#ls -l /dev/cdrom1
lrwxrwxrwx 1 root root 3 Jul 16 08:39 /dev/cdrom1 -> sr0
10:57:08
#ls -l /dev/sr0
brw-rw---T 1 root cdrom 11, 0 Jul 16 08:39 /dev/sr0
10:57:42
#mkfifo /tmp/test

11:03:06
#ls -l /tmp/test
prw-r--r-- 1 root root 0 Jul 16 12:03 /tmp/test
11:03:30
#echo privet > /tmp/test
ls -l /dev/log
who
cd
netstat
^Cl3script: /tmp/test: Interrupted system call
11:10:56
#echo privet > /tmp/test

11:11:51
#netstat
Active Internet connections (w/o servers)
Proto Recv-Q Send-Q Local Address           Foreign Address         State
tcp        0      0 debian5.net.nt:ssh      192.168.15.124:49364    ESTABLISHED
tcp        0    432 debian5.net.nt:ssh      192.168.15.124:49187    ESTABLISHED
tcp        0      0 debian5.net.nt:ssh      192.168.15.124:49363    ESTABLISHED
Active UNIX domain sockets (w/o servers)
Proto RefCnt Flags       Type       State         I-Node   Path
unix  6      [ ]         DGRAM                    5065     /dev/log
unix  3      [ ]         STREAM     CONNECTED     7073
unix  3      [ ]         STREAM     CONNECTED     7072
unix  2      [ ]         DGRAM                    7071
unix  3      [ ]         STREAM     CONNECTED     6788
unix  3      [ ]         STREAM     CONNECTED     6787
unix  2      [ ]         DGRAM                    6786
unix  2      [ ]         DGRAM                    5473
unix  2      [ ]         DGRAM                    5113
unix  3      [ ]         DGRAM                    3249
unix  3      [ ]         DGRAM                    3248
11:12:09
#cd /home/ivan

11:12:38
#cd /home/petr

11:12:55
#cd -
/home/ivan
11:13:02
#cd -
/home/petr
11:13:10
#cd -
/home/ivan
11:15:57
#cd -
/home/petr
11:15:59
#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 (347 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) ...
прошло 23 минуты
11:39:01
#cd

прошло 63 минуты
12:42:14
#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:24
#more install
12:43:22
#less install
12:44:07
#less install
12:45:05
#Pattern not found (press RETURN)
#!/bin/sh
hostname=`hostname`
uname -a | egrep -qi '(freebsd|darwin)' || hostname=`hostname -f`
###############################################################################
#
# Set this variables before installation:
lilalo_user=13-10-2014
12:46:44
#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:30
#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:49:02
#tail -f /var/log/auth.log
Jul 16 10:50:27 debian5 passwd[2656]: pam_unix(passwd:chauthtok): password changed for petr
Jul 16 10:50:32 debian5 useradd[2664]: failed adding user 'petr', data deleted
Jul 16 10:51:29 debian5 sshd[2672]: Accepted password for user from 192.168.15.124 port 49364 ssh2
Jul 16 10:51:29 debian5 sshd[2672]: pam_unix(sshd:session): session opened for user user by (uid=0)
Jul 16 11:17:01 debian5 CRON[2937]: pam_unix(cron:session): session opened for user root by (uid=0)
Jul 16 11:17:01 debian5 CRON[2937]: pam_unix(cron:session): session closed for user root
Jul 16 12:17:01 debian5 CRON[3211]: pam_unix(cron:session): session opened for user root by (uid=0)
Jul 16 12:17:01 debian5 CRON[3211]: pam_unix(cron:session): session closed for user root
Jul 16 13:17:01 debian5 CRON[3472]: pam_unix(cron:session): session opened for user root by (uid=0)
Jul 16 13:17:01 debian5 CRON[3472]: pam_unix(cron:session): session closed for user root
^C
12:51:48
#cp install test

прошло 90 минут
14:22:42
#ls
install  test
14:22:48
#wich vi
l3script: wich: command not found
14:23:31
#ls -l/usr/bin/vi
ls: invalid option -- '/'
Try `ls --help' for more information.
14:24:06
#install installH test
install: cannot stat `installH': No such file or directory
14:24:32
#vi test
прошло 48 минут
15:13:04
# 62 step()

15:13:19
#.vimrc
l3script: .vimrc: command not found
15:14:52
#vi .vimrc
--- /tmp/l3-saved-2375.29939.257	2018-07-16 16:16:13.428088036 +0300
+++ .vimrc	2018-07-16 16:21:46.552077823 +0300
@@ -0,0 +1,8 @@
+:syntax on
+:set number
+:set mouse=a
+:set nowrap colorsheme elflord
+:set number
+:ws
+
+
15:21:46
#vi .vimrc

Вторник (07/17/18)

/dev/pts/2
08:19:40
#cat /etc/shells
# /etc/shells: valid login shells
/bin/sh
/bin/dash
/bin/bash
/bin/rbash
/usr/bin/screen
/bin/zsh
/usr/bin/zsh
08:20:49
#alias

08:22:32
#ls
install  test
08:23:09
#vi .bashrc
--- /tmp/l3-saved-5292.3692.29093	2018-07-17 09:28:15.476147527 +0300
+++ .bashrc	2018-07-17 09:30:49.484087990 +0300
@@ -17,3 +17,5 @@
 # alias cp='cp -i'
 # alias mv='mv -i'
 [ $0 == l3script ] && . /root/.lilalo/l3bashrc && _l3_start
+
+alias ls='ls --color' 
08:30:49
#ls
install  test
08:31:27
#ls -a
.  ..  .aptitude  .bash_history  .bash_profile  .bashrc  install  .l3rc  .lesshst  .lilalo  .profile  test  .vim  .viminfo  .vimrc
08:31:30
#bash
root@debian5:~# ls -a
.  ..  .aptitude  .bash_history  .bash_profile  .bashrc  install  .l3rc  .lesshst  .lilalo  .profile  test  .vim  .viminfo  .vimrc
root@debian5:~# exit
exit
08:35:02
#source .bashrc

08:36:37
#ls -a
.  ..  .aptitude  .bash_history  .bash_profile  .bashrc  install  .l3rc  .lesshst  .lilalo  .profile  test  .vim  .viminfo  .vimrc
08:36:51
#echo $HIST
$HISTCMD       $HISTFILE      $HISTFILESIZE  $HISTSIZE
08:36:51
#echo $HISTSIZE
500
08:38:28
#echo $HISTFILESIZE
500
08:39:01
#vi /etc/profile
--- /tmp/l3-saved-5292.12459.16712	2018-07-17 09:41:44.116038591 +0300
+++ /etc/profile	2018-07-17 09:49:13.596087280 +0300
@@ -35,3 +35,7 @@
   done
   unset i
 fi
+
+HISTSIZE=2000
+HISTFILESIZE=2000
+export 
прошло 11 минут
/dev/pts/2
08:50:46
#vi /etc/profile
--- /tmp/l3-saved-5519.15059.9767	2018-07-17 09:51:04.416086846 +0300
+++ /etc/profile	2018-07-17 09:52:08.360086923 +0300
@@ -38,4 +38,5 @@
 
 HISTSIZE=2000
 HISTFILESIZE=2000
-export 
+export HISTSIZE HISTFILESIZE 
+
/dev/pts/2
08:52:29
#echo $HISTSIZE
2000
08:53:53
#echo $HISTFILESIZE
2000
прошло 13 минут
/dev/pts/4
09:07:30
#cp ~ivan/.bashrc ~petr

09:08:04
#ls -l ~petr
итого 0

Файлы

  • /etc/shells
  • install
  • /etc/shells
    >
    # /etc/shells: valid login shells
    /bin/sh
    /bin/dash
    /bin/bash
    /bin/rbash
    /usr/bin/screen
    /bin/zsh
    /usr/bin/zsh
    
    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:53 2018- 7-16
    Время последней команды журнала09:08:04 2018- 7-17
    Количество командных строк в журнале100
    Процент команд с ненулевым кодом завершения, % 9.00
    Процент синтаксически неверно набранных команд, % 7.00
    Суммарное время работы с терминалом *, час 3.69
    Количество командных строк в единицу времени, команда/мин 0.45
    Частота использования команд
    cd19|==================| 18.27%
    ls18|=================| 17.31%
    echo10|=========| 9.62%
    useradd7|======| 6.73%
    vi6|=====| 5.77%
    wich4|===| 3.85%
    passwd3|==| 2.88%
    alias3|==| 2.88%
    tail3|==| 2.88%
    cp2|=| 1.92%
    cat2|=| 1.92%
    who2|=| 1.92%
    less2|=| 1.92%
    which2|=| 1.92%
    test2|=| 1.92%
    more1|| 0.96%
    621|| 0.96%
    man1|| 0.96%
    nl1|| 0.96%
    ls-l1|| 0.96%
    mkfifo1|| 0.96%
    netstat1|| 0.96%
    apt-get1|| 0.96%
    $$LANG=``1|| 0.96%
    Pattern1|| 0.96%
    source1|| 0.96%
    LANG=``1|| 0.96%
    userdel1|| 0.96%
    install1|| 0.96%
    mailq1|| 0.96%
    bash1|| 0.96%
    $lang1|| 0.96%
    21|| 0.96%
    .vimrc1|| 0.96%
    ____
    *) Интервалы неактивности длительностью 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$