답변:
스크립트에 무언가를 추가 할 필요가 없습니다. 쉘은 그러한 기능을 허용합니다.
T
있고 중지되었습니다)jobs
터미널을 입력 하거나 중지 된 모든 작업을 나열하십시오.fg
(전경)을 입력하십시오 . 작업을 포 그라운드 프로세스 그룹으로 다시 시작하고 작업이 계속 실행됩니다.예를보십시오 :
root@host:~$ sleep 10 # sleep for 10 seconds
^Z
[1]+ Stopped sleep 10
root@host:~$ jobs # list all stopped jobs
[1]+ Stopped sleep 10
root@host:~$ fg # continue the job
sleep 10
root@host:~$ # job has finished
cmd; cmd; cmd;
는 글쓰기 와 같습니다 cmd <newline> cmd <newline> ...
. 대안으로 여러분이 작성할 수있는 스크립트는 스크립트 ( cmd; cmd; cmd; )
처럼 작동 할 것입니다.(
sleep 10
. 3 초 후에 CTRL + Z를 누르고 몇 초 후에 다시 시작한 후 수면 명령이 7 초 이내에 죽었다는 것을 알았습니다. 명령이 멈추지 않기 때문에 백그라운드에서 실행됩니다.
strace
는 D sleep
명령을 사용 된 시스템 호출 인 것을 알아 냈다 nanosleep()
. 시스템 콜의 정의 된 행동 인 것 같습니다 nanosleep
. restart_syscall()
이미 경과 한 시간 (신호에 의해 프로세스가 중지 된 시간 포함)을 고려하여 적절히 조정 된 시간 인수를 사용하여 인터럽트 된 시스템 호출을 다시 시작합니다. 맨 페이지를 읽으십시오 : man7.org/linux/man-pages/man2/restart_syscall.2.html
fg %1
또는 배경) (예 : bg %1
). (예시 혼돈에서 보여준 것처럼, 작업이 1 개의 숫자, 즉 1 개의 정지 된 프로세스 만 제공하는 경우 : 단지 [1]+ stopped sleep 10
, %n
파트를 생략 할 수 있습니다 . 여러 백그라운드 프로세스 (실행 또는 중지)가있는 경우 원하는 프로세스를 지정해야합니다. with : %n
(예 : fg %2
포 그라운드에서 % 2의 이력서를 가지려면)
스크립트 안에 남아있는 동안 스크립트를 일시 중지하려면 절전 모드 대신 읽기를 사용할 수 있습니다.
당신이 사용할 수있는
read -t
read -n
읽기가 한 문자를 읽을 수 있는 시간 초과를 설정하려면 (실제로 아무 키나 누름) 스크립트를 계속하십시오
코드를 제공하지 않았으므로 다음은 코드 사용 방법의 예입니다.
q를 누르면 read -n1
키를 누를 때까지 스크립트가 계속 진행되지 않습니다.
키를 누르면 확인이 재설정되고 스크립트는 정상적으로 루프에서 계속됩니다.
while [[ true ]]; do
read -t2 -n1 check
if [[ $check == "q" ]];then
echo "pressed"
read -n1
check=""
else
echo "not pressed"
fi
echo "Doing Something"
done
입력이 화면 출력을 엉망으로 만들지 않도록 stty -echo
섹션의 시작과 stty echo
끝에 추가 할 수도 있습니다.
함께 dd
하면 안정적으로 파일로부터 1 바이트를 읽을 수 있습니다. 을 사용 stty
하면 min
터미널 읽기 및 time
10 분의 1 초의 출력 을 규정 할 바이트 수를 설정할 수 있습니다 . 이 두 가지를 결합하면 sleep
완전히 없이 할 수 있다고 생각합니다. 단말기의 읽기 시간 초과가 작업을 수행하도록하십시오.
s=$(stty -g </dev/tty)
(while stty raw -echo isig time 20 min 0;test -z "$(
dd bs=1 count=1 2>/dev/null; stty "$s")" || (exec sh)
do echo "$SECONDS:" do your stuff here maybe
echo no sleep necessary, I think
[ "$((i+=1))" -gt 10 ] && exit
done
) </dev/tty
그것은 while
당신이 시험해보기 위해 조롱 한 작은 예제 루프입니다. 2 초마다는 dd
그 시도의 읽기에 시간이 초과 stdin
에서 재 - /dev/tty
- 그리고 while
루프 루프. 즉, 또는 dd
하지 않습니다 타임 아웃 당신이 키를 누릅니다 때문에 -이 경우 대화 형 쉘이 호출됩니다.
테스트 실행은 다음과 같습니다. 각 행의 헤드에 인쇄 된 숫자는 쉘 변수의 값입니다 $SECONDS
.
273315: do your stuff here maybe
no sleep necessary, I think
273317: do your stuff here maybe
no sleep necessary, I think
273319: do your stuff here maybe
no sleep necessary, I think
273321: do your stuff here maybe
no sleep necessary, I think
sh-4.3$ : if you press a key you get an interactive shell
sh-4.3$ : this example loop quits after ten iterations
sh-4.3$ : or if this shell exits with a non-zero exit status
sh-4.3$ : and speaking of which, to do so you just...
sh-4.3$ exit
exit
273385: do your stuff here maybe
no sleep necessary, I think
273387: do your stuff here maybe
no sleep necessary, I think
273389: do your stuff here maybe
no sleep necessary, I think
273391: do your stuff here maybe
no sleep necessary, I think
273393: do your stuff here maybe
no sleep necessary, I think
273395: do your stuff here maybe
no sleep necessary, I think
273397: do your stuff here maybe
no sleep necessary, I think
s=$(stty -g </dev/tty)
. 전화 한 후 즉시 dd
로 복원하십시오 stty "$s"
. 터미널 상태는 서브 쉘에 신경 쓰지 않으므로 이러한 설정은 부모 쉘에 관계없이 고정됩니다. stty sane
반드시 당신이하고 싶은 일이 아닙니다-상태가 sane
그 시점 에 있다고 가정하는 것보다 상태를 찾은 방식으로 복원하는 것이 좋습니다 . 내가 그것을 복원하지 않았다면 그 echo
s는 도처에있을 것입니다. 내가 늦게 온 이유를 부분적으로 알아 낸 것입니다. 테스트를 시작할 때 귀하의 답변이 여기에 없었습니다.
sleep 10; notify-send hello
CTRL + Z를 눌러 멈 추면notify-send hello
실행됩니다. 두 번째 명령이 실행되면 첫 번째 프로세스가 어떻게 중지됩니까? 그 후fg
내가 타입을 볼 수 없다면 , 두 번째 명령이 이미 실행되었으므로 명백하다.