И выскочка и systemd являются попытками решить некоторые проблемы с ограничениями традиционной системы SysV init. Например, некоторые сервисы должны запуститься после других служб (например, Вы не можете смонтировать файловые системы NFS, пока сеть не работает), но единственный путь в SysV для обработки, который должен установить ссылки в rc#.d каталоге, таким образом, что каждый перед другим. Добавьте к этому, Вы, возможно, должны были бы перенумеровать все позже, когда зависимости добавляются или изменяются. Upstart и Systemd имеют более интеллектуальные настройки для определения требований. Кроме того, существует проблема с тем, что все - какой-то сценарий оболочки, и не все пишет лучшие init сценарии. Это также влияет на скорость запуска.
Некоторые преимущества systemd I видят:
Один недостаток, о котором я знаю, - то, что для использования в своих интересах socket/FH предварительного выделения systemd многие демоны должны будут быть исправлены, чтобы передать FH им systemd.
На Mac OS X и BSD:
$ date -r 1282368345
Sat Aug 21 07:25:45 CEST 2010
$ date -r 1282368345 +%Y-%m-%d
2010-08-21
с инструментами ядра GNU (необходимо вырыть через информационный файл для того):
$ date -d @1282368345
Sat Aug 21 07:25:45 CEST 2010
$ date -d @1282368345 --rfc-3339=date
2010-08-21
С также, добавьте -u
(стандартная) опция или передача a TZ=UTC0
переменная среды, чтобы иметь дату UTC (TZ=UTC0
определяет названный часовой пояс UTC
со смещением 0 от UTC, в то время как поведение для TZ=UTC
(без смещения), является неуказанным (хотя в большинстве систем относился бы к определенному системой часовому поясу, также названному UTC
со смещением 0 от UTC)).
После некоторого поиска с помощью Google я нашел способ сделать это с date
команда только:
$ date --date "Jan 1, 1970 00:00:00 +0000 + 1282367908 seconds"
Sat Aug 21 09:18:28 MSD 2010
date -d @xxx
не был добавлен до coreutils 5.3 в 2005. Это - то, как необходимо было сделать это перед этим.
– Stéphane Chazelas
07.10.2016, 09:27
Эта острота жемчуга сделает это:
$ perl -e 'print scalar localtime $ARGV[0]' 1282367908
Sat Aug 21 09:18:28 2010
Другой аккуратный пример богатого наследия современного Unix. Это действительно возможно под большинством вариантов BSD:
$ TZ=UTC date -r 1282368345
Sat Aug 21 05:25:45 UTC 2010
(BTW Ваш пример, кажется, выключен на одну секунду),
Ответ на старый вопрос, но я думаю, что это могло бы быть улучшением, если кто-то еще будет это искать. Эта функция Bash работает как в Linux, так и в OS X. Я не тестировал другие системы BSD. Передайте время эпохи в качестве аргумента этой функции, и она распечатает формат времени RFC-3339.
epochtorfc3339 ()
{
RFC3339_FORMAT="+%FT%T:::%z"
EPOCH=$(echo $@ | sed -n "s/.*\([0-9]\{10\}\).*/\1/p");
if date --version >/dev/null 2>/dev/null; then
# Linux
date ${RFC3339_FORMAT} -d "1970-01-01 UTC ${EPOCH} seconds"
#date -d @${EPOCH} --rfc-3339=seconds
else
# OS X/BSD
date -r ${EPOCH} ${RFC3339_FORMAT}
fi
}
Со встроенными командами оболочки:
zsh
(4.1.1 (2003) и выше):
$ zmodload zsh / datetime
$ TZ = UTC0 strftime% c 1282368345 {{1} } Сб, 21 августа 2010 г., 05:25:45 UTC
ksh93
( ksh93i
(2000) и выше):
$ TZ = UTC0 printf '% (% c) T \ n '' # 1282368345 '
Сб 21 августа 05:25:45 2010
bash
(4.2 (2010) и выше):
$ TZ = UTC0 printf '% (% c) T \ n' 1282368345
Сб, 21 августа 2010 г., 05:25:45 UTC
Во всех этих случаях замените % c
в желаемом формате strftime ()
.
Для среды, подобной Unix -, будет работать следующее.
# Current UNIXTIME
unixtime() {
datetime2unixtime "$(date -u +'%Y-%m-%d %H:%M:%S')"
}
# From DateTime(%Y-%m-%d %H:%M:%S)to UNIXTIME
datetime2unixtime() {
set -- "${1%% *}" "${1##* }"
set -- "${1%%-*}" "${1#*-}" "${2%%:*}" "${2#*:}"
set -- "$1" "${2%%-*}" "${2#*-}" "$3" "${4%%:*}" "${4#*:}"
set -- "$1" "${2#0}" "${3#0}" "${4#0}" "${5#0}" "${6#0}"
[ "$2" -lt 3 ] && set -- $(( $1-1 )) $(( $2+12 )) "$3" "$4" "$5" "$6"
set -- $(( (365*$1)+($1/4)-($1/100)+($1/400) )) "$2" "$3" "$4" "$5" "$6"
set -- "$1" $(( (306*($2+1)/10)-428 )) "$3" "$4" "$5" "$6"
set -- $(( ($1+$2+$3-719163)*86400+$4*3600+$5*60+$6 ))
echo "$1"
}
# From UNIXTIME to DateTime format(%Y-%m-%d %H:%M:%S)
unixtime2datetime() {
set -- $(( $1%86400 )) $(( $1/86400+719468 )) 146097 36524 1461
set -- "$1" "$2" $(( $2-(($2+2+3*$2/$3)/$5)+($2-$2/$3)/$4-(($2+1)/$3) ))
set -- "$1" "$2" $(( $3/365 ))
set -- "$@" $(( $2-( (365*$3)+($3/4)-($3/100)+($3/400) ) ))
set -- "$@" $(( ($4-($4+20)/50)/30 ))
set -- "$@" $(( 12*$3+$5+2 ))
set -- "$1" $(( $6/12 )) $(( $6%12+1 )) $(( $4-(30*$5+3*($5+4)/5-2)+1 ))
set -- "$2" "$3" "$4" $(( $1/3600 )) $(( $1%3600 ))
set -- "$1" "$2" "$3" "$4" $(( $5/60 )) $(( $5%60 ))
printf "%04d-%02d-%02d %02d:%02d:%02d\n" "$@"
}
# Examples
unixtime # => Current UNIXTIME
date +%s # Linux command
datetime2unixtime "2020-07-01 09:03:13" # => 1593594193
date -u +%s --date "2020-07-01 09:03:13" # Linux command
unixtime2datetime "1593594193" # => 2020-07-01 09:03:13
date -u --date @1593594193 +"%Y-%m-%d %H:%M:%S" # Linux command
info coreutils date
немного более тщательно. – Umang 21.08.2010, 11:27date -r 1447264553943
результаты вWed Dec 28 01:39:03 BRST 47831
, когда это на самом деле11/11/2015, 3:55:53 PM GMT-2:00
. – falmp 11.11.2015, 20:01mv
файл Вы сохраняете, или по крайней мереcp -p
, иawk
может сделать выбор сначала:find foo -type f | awk -F/ -vOFS=/ '{path=$0;file=$NF;NF--} !already[$0]++ {system("mv "path" "$0"_"file"); system("rm -r "$0)}'
---------121 операция в секунду--------153159----@hop, должен был фигурировать с годом, будучи 47831, но то число было так высоко, я пропустил его.Спасибо! – falmp 13.11.2015, 00:25