Перейти из форума на сайт.

НовостиФайловые архивы
ПоискАктивные темыТоп лист
ПравилаКто в on-line?
Вход Забыли пароль? Первый раз на этом сайте? Регистрация
Компьютерный форум Ru.Board » Операционные системы » UNIX » UNIX Shell: sh, bash, zsh; Coreutils и ко.; sed, awk, perl;

Модерирует : ShriEkeR

 Версия для печати • ПодписатьсяДобавить в закладки
Страницы: 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153

Открыть новую тему     Написать ответ в эту тему

digital422

Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
Товарищи вопрошающие! Если ваша система отлична от ГНУ, и в то же время вы желаете обойтись только дефолтными средствами, указывайте и то и другое сразу, пожалуйста.


UNIX Shell

 
   Это глобальная тема по юниксовой командной оболочке, как по интерактивной работе в командной строке, так и по шелл-скриптам. Ключевые слова: sh, bash, zsh, tcsh, busybox, readline, coreutils, cp, mv, ln, rm, ls, readlink, mkdir, touch, stat, date, test, sleep, chown, chmod, chattr, dd, df, du, env, echo, cat, less, man, grep, sort, findutils, find, locate, xargs, md5sum, cmp, diff, patch, ps, kill, killall, tar, gzip, bzip2, xz, mount, fdisk, parted, mkfs, fsck, e2fsprogs, mtools, ss, netcat, netstat, rsync, ssh, scp, sftp, lftp, ncftp, time, strace.
   Неинтерактивная обработка текста (sed, awk, perl) пока тоже здесь.
   Смотри в других ветках: wget, convert, montage, mogrify и др., gs, git, 7z, p7zip, soffice, mplayer, mencoder, vlc, vim, mc, mcedit, kioclient.
 
 

Hint! Русские маны (подустаревшие, не всегда полные и не всегда для вашей системы) можно попытаться найти на Опеннете, к примеру: bash, tar, grep.

 
Готовые решения:
  • commandlinefu.com
    Крупнейшая база полезных однострочников на командной оболочке с ранжированием на основе пользовательского голосования.
     
  • shell-fu.org
    Аналогично, но поменьше и формат записей более свободный, поэтому встречаются и однострочники, и развернутые скрипты, и просто советы.
     
  • Useful one-line scripts for sed
    Почти исчерпывающий список решений для тех случаев, когда sed незаменим. Более сложные скрипты с sed.sf.net — только для тех, кто знает толк... :)

 
Учебная литература:
  • Greg’s Wiki (http://mywiki.wooledge.org)
    Наиболее обширный авторский сборник постоянно обновляющихся материалов по Башу.

    1. Bash Pitfalls
      (Частые ошибки программирования на Баше: [1], [2], [3], [4], [5] — пер. на русский по сост. на дек. 2008 г.).
      Рассмотрены преимущественно ошибки, возникающие из-за непонимания отличия шелла от «нормальных» скриптовых языков. Если вы уже владеете, например, Перлом, то это вполне может быть ваше первое руководство для ознакомления с Башем.
    2. Bash FAQ
    3. Bash Guide
    4. Bash Reference Sheet
      Шпаргалка по частым синтаксическим оборотам.

 
Классическая учебная литература:
С одной стороны не упомянуть эти издания нельзя, с другой — они настолько устарели, что едва ли их можно рекомендовать в роли учебника.

 

Смело правьте и дополняйте шапку, однако не забывайте отписываться об исправлениях и сохранять исходный вариант под #.
Первый пост темы имел вид...

Всего записей: 354 | Зарегистр. 19-04-2003 | Отправлено: 18:51 16-05-2008 | Исправлено: qw12, 09:42 24-03-2020
MAGNet



Silver Member
Редактировать | Профиль | Сообщение | ICQ | Цитировать | Сообщить модератору

Цитата:
Батник теперь у меня как и обрабатываемый файл - одного формата, всё работает как надо.

Всего записей: 2074 | Зарегистр. 31-03-2004 | Отправлено: 13:11 11-10-2018
Victor_VG



Tracker Mod
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
Вчера cURL обновили до версии 7.62.0.Из новых свойств появилась поддержка DOH - DNS-other-HTTPS, исправлено много ошибок. Официальная сборка для Win32/Win64 собрана в MinGW64 с поддержкой OpenSSL 1.1.1 и WinSSL, обновлены некоторые библиотеки:
 
curl 7.62.0 Win32/Win64 MinGW-w64 standalone build by Viktor Szakets
 
Release date: 2018-10-31
 
Libs:
 
  libcurl/7.62.0 OpenSSL/1.1.1 (WinSSL) zlib/1.2.11 brotli/1.0.7 WinIDN libssh2/1.8.0 nghttp2/1.34.0
 
Protocols:
 
  dict file ftp ftps gopher http https imap imaps ldap ldaps pop3 pop3s rtsp scp sftp smb smbs smtp smtps telnet tftp
 
Features:
 
  AsynchDNS IDN IPv6 Largefile SSPI Kerberos SPNEGO NTLM SSL libz brotli TLS-SRP HTTP2 HTTPS-proxy MultiSSL

 
первые впечатления хорошие, на UNIX я её еще не собирал - приятель как обычно обещал прислать оптимизированные под наше железо патчи под Tru64 UNIX AXP и демона. С ними и посмотрю.

----------
Жив курилка! (Р. Ролан, "Кола Брюньон")
Xeon E5 2697v2/C602/128 GB PC3-14900L/GTX 1660 Ti, Xeon E5-2697v2/C602J/128 Gb PC3-14900L/GTX 1660 Ti

Всего записей: 33409 | Зарегистр. 31-07-2002 | Отправлено: 12:57 01-11-2018
dvk54

Junior Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
Товарищи, может я какую чушь спрашиваю или элементарщину - ну вот не знаю.
Freebsd, оболочка - sh.
Надо зайти из хост1 на хост2 по ssh, запустить там, допустим, /usr/abcd.sh, и отключиться, но чтобы /usr/abcd.sh продолжал выполнятся. аутентификация ssh - по ключам.
Интерактивно, в принципе, я это могу сделать - через запуск screen (при этом ещё и сам screen останется висеть).
Но надо, чтобы это делалось по расписанию. Желательно - сугубо средствами ОС, без доппакетов.
Возможно?

Всего записей: 178 | Зарегистр. 18-06-2005 | Отправлено: 07:44 03-11-2018
U235

Advanced Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору

Код:
$ ssh root@192.168.1.1  'bash -s /usr/abcd.sh&'

Не уверен, но возможно как-то так..
Если надо по расписанию, то может имеет смысл использовать cron на хосте2?

Всего записей: 908 | Зарегистр. 14-12-2005 | Отправлено: 08:35 03-11-2018 | Исправлено: U235, 08:36 03-11-2018
dvk54

Junior Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
cron нельзя, в параметрах выполнения передаётся генерируемый хостом 1 пароль, а хост 2 крутится на внешнем хостинге.
sh -s не подходит, он запускает ДОЧЕРНИЙ процесс.  
А надо типа как запустил форк, отключился от него, самоубился. А форк продолжает крутится.
но как это в шелле реализовать - не знаю..
 
Добавлено:
Поправочка: невнимательно прочёл ответ U235.
Вроде работает, но как-то странно..

Всего записей: 178 | Зарегистр. 18-06-2005 | Отправлено: 12:09 03-11-2018
Alukardd



Gold Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
dvk54
Я давно, конечно фрю не видел, но nohup ещё ни кто не отменял.
 
ssh host2 "nohup /my/super/command >>/var/log/mysuppercommand.log 2>&1 &"

----------
Microsoft gives you windows, linuх gives you the whole house...
I've been using Vim for about 4 years now, mostly because I can't figure out how to exit it.

Всего записей: 6565 | Зарегистр. 28-08-2008 | Отправлено: 13:30 03-11-2018
dvk54

Junior Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
Alukardd
почитал про nohup, но приведённый Вами пример не работает:
 
#ssh host2 "nohup /root/u.sh>/var/log/test.log 2>&1 &"
"Неоднозначное перенаправление вывода."
 
#ssh host2 "nohup /root/u.sh>/var/log/test.log &"
- нормально, так, как и надо.
 
З.Ы.Я фрю вижу каждый день уже давно, но всего в ней не знаю. Она велика.
З.Ы.2 Спасибо!

Всего записей: 178 | Зарегистр. 18-06-2005 | Отправлено: 16:13 03-11-2018 | Исправлено: dvk54, 16:14 03-11-2018
Alukardd



Gold Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
dvk54
Если там есть bash, то там сокращённо перенаправлять так: &>>/var/log/log.log
 
Ещё хочу обратить Ваше внимание на то, что Вы изменили перенаправление с дозаписью в файл в его перетирание: > vs >>

----------
Microsoft gives you windows, linuх gives you the whole house...
I've been using Vim for about 4 years now, mostly because I can't figure out how to exit it.

Всего записей: 6565 | Зарегистр. 28-08-2008 | Отправлено: 18:06 03-11-2018 | Исправлено: Alukardd, 18:06 03-11-2018
dvk54

Junior Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
Alukardd
bash а нету.
перетирание вместо дозаписи - не критично, это я по-разному запускать пробовал.
1.Меня всё ещё интересует, как переписать ваш Ваш пример, чтобы он работал с sh
теперь по опытам.
выполняю из хост1:

Код:
 
ssh host2 'nohup /usr/local/etc/ar.sh 123 &'
 

ar.sh:

Код:
#!/bin/sh
portsdb -u
/usr/local/bin/rar a -inul -r -m5 -agYYYY-MM-DD_HHmm -p$1 /var/r.rar /usr/local &
 

 
2. запуск из u.sh portsdb -u - не работает. Пробовал и так
/usr/local/sbin/portsdb -u
и так
/usr/local/bin/ruby24 /usr/local/sbin/portsdb -u
3. запуск rar из u.sh - тоже не работает. Вывод rar блокирует закрытие сессии. Правда, если закрыть по ctl-c - продолжает выполнятся.
 

Всего записей: 178 | Зарегистр. 18-06-2005 | Отправлено: 09:57 04-11-2018 | Исправлено: dvk54, 09:58 04-11-2018
Alukardd



Gold Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
dvk54
Во-первых, & внутри скрипта уже лишний.
Во-вторых, Что значит "не работает? В лог-то хоть что-то попадает? Ну или вам в консоль, хотя бы.
В-третьих, вообще-то, переписывать ни чего не надо, всё и так должно работать, будь то sh или bash.

----------
Microsoft gives you windows, linuх gives you the whole house...
I've been using Vim for about 4 years now, mostly because I can't figure out how to exit it.

Всего записей: 6565 | Зарегистр. 28-08-2008 | Отправлено: 19:45 04-11-2018
dvk54

Junior Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
Alukardd
"во-первых" - я уже пробовал разные варианты...
"во-вторых" - вот как это выглядит:

Код:
 
root@host1:~ # ssh host2 'nohup /bin/sh -s /root/u.sh >> /var/log/test.log 2>&1 &'
Неоднозначное перенаправление вывода.
root@host1:~ # ssh host2 "nohup /bin/sh -s /root/u.sh >> /var/log/test.log 2>&1 &"
Неоднозначное перенаправление вывода.
root@host1:~ #
 

"В-третьих" - ну вот не работает...
 
а portsdb отрабатывает вот как:
root@host1:~ # ssh host2 '"nohup cd /usr/ports&&portsdb -uU &"'
на хосте2 в htop, на пару секунд возникает картина:

Код:
 
  PID USER      PRI  NI  VIRT   RES S CPU% MEM%   TIME+  Command
    0 root      -16   0     0   272 S  0.0  0.0  4:01.50 kernel
    1 root       52   0  5428  1152 S  0.0  0.1  0:00.04 L- /sbin/init --
 7880 root       52   0  7484  3460 S  1.5  0.2  0:00.00    +- csh -c nohup cd /usr/ports&&portsdb -uU &
 7882 root       72   0 14944  9136 R  4.9  0.5  0:00.15    ¦  L- /usr/local/bin/ruby24 /usr/local/sbin/portsdb -uU
 

и всё. в логах ничего нет. на консоли host2 - ничего не выводится.
я чего-то главного не понимаю, похоже

Всего записей: 178 | Зарегистр. 18-06-2005 | Отправлено: 20:15 04-11-2018 | Исправлено: dvk54, 20:27 04-11-2018
Alukardd



Gold Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
dvk54
А зачем вы по ssh ещё дополнительно вызываете /bin/sh?
Да ещё и зачем-то с ключлм -s, это же stdin читать, а  у Вас его нету.

----------
Microsoft gives you windows, linuх gives you the whole house...
I've been using Vim for about 4 years now, mostly because I can't figure out how to exit it.

Всего записей: 6565 | Зарегистр. 28-08-2008 | Отправлено: 21:42 04-11-2018
CKOPnuOH



Member
Редактировать | Профиль | Сообщение | ICQ | Цитировать | Сообщить модератору
Здравствуйте уважаемые Гуру!
 
ASE_DAG

Цитата:
> Скрипт снял с меня рутиную работу ... анализировать логи и добавлять нарушителей в конфиг. В принципе большего пока от него не требуется.
> Думаю, тех знаний, которые я получил, ... мне теперь вполне хватит.  
 
Ну и славненько! Обращайтесь, если что.

 
И снова я
Прошло не мало времени и наш с Вами написанный скрипт исправно работает по сей день.
 
Параллельно ему трудился еще один скрипт но на sh:

Код:
 
#!/bin/sh
 
DIR=/usr/local/etc
RCFG=/usr/local/etc/rinetd.conf
 
ping -n -c 1 -s 1 172.17.2.10 >/dev/null 2>&1
    if [ $? -ne 0 ]; then
    ping -n -c 1 -s 1 172.17.2.11 >/dev/null 2>&1
    if [ $? -ne 0 ]; then
        if [ -f $DIR/.default.key ]; then
        rm $DIR/.default.key
        fi
        if [ -f $DIR/.reserve.key ]; then
        rm $DIR/.reserve.key
        fi
        date | xargs echo >> $DIR/vpn_error.log
    else
        if [ -f $DIR/.default.key ]; then
        rm $DIR/.default.key
        fi
        if [ -f $DIR/.reserve.key ]; then
        else
        echo > $RCFG
        echo logfile /var/log/rinetd.log >> $RCFG
        echo >> $RCFG
        echo 0.0.0.0 3389    172.17.2.11    50000 >> $RCFG
        echo >> $RCFG
        service rinetd restart
        date | xargs echo > $DIR/.reserve.key
        fi
    fi
    else
    if [ -f $DIR/.reserve.key ]; then
        rm $DIR/.reserve.key
    fi
    if [ -f $DIR/.default.key ]; then
    else
        echo > $RCFG
        echo logfile /var/log/rinetd.log >> $RCFG
        echo >> $RCFG
        echo 0.0.0.0 3389    172.17.2.10    50000 >> $RCFG
        echo >> $RCFG
        service rinetd restart
        date | xargs echo > $DIR/.default.key
    fi
    fi
 
 

 
Который проверял наличия пинга двух тунелей и в зависимости от их работоспособности конфигурировал rinetd.
 
Вообщем в последнее время второй скрипт стал себя как-то странно вести. ОЧЕНЬ! МНОГО!! ложных срабатываний.
И решил я его переписать на что-то новое по типу Вашей серии:

Код:
 
if ping -c "$c" "$host" \
| awk -v c="$c" \
'$3 == "transmitted," && c == $1 && $1 == $4 { success = 1 }
END { if (!success) exit 3 }'
then
echo 'OK'
else
echo 'FAIL'
fi  
 

Но так как мои знания awk скудны - прошу помочь перевести скрипт из sh в скрипт awk который был написан ранее.
 
ADD. Имеется ввиду объединить оба скрипта в один.  
 
Добавлено:
Сами print-ы да передергивания rinetd я переписать то смогу, а вот как правильно и в каком месте того скрипта прописать проверку пинга на подобие Вашего скрипта - что-то собразить не получается.

Всего записей: 339 | Зарегистр. 28-05-2004 | Отправлено: 08:55 06-11-2018 | Исправлено: CKOPnuOH, 08:59 06-11-2018
redson



Advanced Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
Как реализовать в bash скрипте логирование ошибок (плохих errorlevel) при выполнение команд. Например при выполнение команды, произошла ошибка, нужно сохранить ошибку в error.log
 
Например сейчас я после каждой команды, пишу условие:
 
#если errorlevel больше 0, то пишем в лог ошибок
if [[ $? -gt 0 ]];then
echo -e >> $ERROR_LOG
echo -e "Erorr!!! Problem ! (`date +%Y_%m_%d-%H_%M_%S`)" >> $ERROR_LOG
 
все работает отлично, но в скрипте получается много строк, хочется как то по компактней

Всего записей: 1336 | Зарегистр. 23-04-2007 | Отправлено: 10:04 07-11-2018 | Исправлено: redson, 10:07 07-11-2018
Alukardd



Gold Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
redson
ну начнём с того что сам stderr команды надо писать в лог.
Это просто exec 2>"$ERROR_LOG" в начале скрипта.
 
А вообще можете что-то типа такого использовать

Код:
 

#!/bin/bash
 
ERROR_LOG="/tmp/errlog"
 
exec 2>>"$ERROR_LOG"
 
function err() {
  echo -e "[$(date +%Y_%m_%d-%H_%M_%S)] ERROR: $*" >&2
}
 
function run() {
  $*
  if [[ $? -ne 0 ]]; then
    err "Command failed: '$*'"
  fi
}
 
run true
run false
run ls -l
run false 2

 


----------
Microsoft gives you windows, linuх gives you the whole house...
I've been using Vim for about 4 years now, mostly because I can't figure out how to exit it.

Всего записей: 6565 | Зарегистр. 28-08-2008 | Отправлено: 18:12 07-11-2018
Alukardd



Gold Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
А вообще, если забить на exit_code, то просто красиво ловить stderr и писать можно так

Код:

ERROR_LOG="/tmp/errlog2"
exec 2> >( cat | xargs -I {} echo -e "[$(date +%Y_%m_%d-%H_%M_%S)] ERROR: {}" >>"$ERROR_LOG"; )


----------
Microsoft gives you windows, linuх gives you the whole house...
I've been using Vim for about 4 years now, mostly because I can't figure out how to exit it.

Всего записей: 6565 | Зарегистр. 28-08-2008 | Отправлено: 00:26 08-11-2018
los

Gold Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
Возможно кто-нибудь подскажет: как скачать при помощи curl?
https://urlhaus.abuse.ch/downloads/csv/
https://urlhaus.abuse.ch/downloads/text/

Всего записей: 7436 | Зарегистр. 08-09-2001 | Отправлено: 14:30 14-12-2018
karavan



Advanced Member
Редактировать | Профиль | Сообщение | ICQ | Цитировать | Сообщить модератору
los

Код:
curl -s https://urlhaus.abuse.ch/downloads/text/ > urlhaus.abuse.ch.txt

Всего записей: 1962 | Зарегистр. 02-12-2011 | Отправлено: 14:45 14-12-2018
los

Gold Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
karavan,
Спасибо. Буду со своим curlrc разбираться, ибо с ним не работает.

Всего записей: 7436 | Зарегистр. 08-09-2001 | Отправлено: 15:36 14-12-2018
mithridat1



Silver Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
Выпуск GNU Grep 3.2 и Sed 4.6

Всего записей: 4969 | Зарегистр. 05-01-2006 | Отправлено: 09:20 22-12-2018
Открыть новую тему     Написать ответ в эту тему

Страницы: 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153

Компьютерный форум Ru.Board » Операционные системы » UNIX » UNIX Shell: sh, bash, zsh; Coreutils и ко.; sed, awk, perl;


Реклама на форуме Ru.Board.

Powered by Ikonboard "v2.1.7b" © 2000 Ikonboard.com
Modified by Ru.B0ard
© Ru.B0ard 2000-2024

BitCoin: 1NGG1chHtUvrtEqjeerQCKDMUi6S6CG4iC

Рейтинг.ru