이 프로세스가 왜 끝나지 않습니까?

이 프로세스가 왜 끝나지 않습니까?
 wc -l | sort -t":" -k4,4n | uniq password_demo.txt

인쇄

root:x:0:0:root:/root:/bin/bash
daemon:x:1:1:daemon:/usr/sbin:/usr/sbin/nologin
bin:x:2:2:bin:/bin:/usr/sbin/nologin
sys:x:3:3:sys:/dev:/usr/sbin/nologin
sync:x:4:65534:sync:/bin:/bin/sync
games:x:5:60:games:/usr/games:/usr/sbin/nologin
man:x:6:12:man:/var/cache/man:/usr/sbin/nologin
lp:x:7:7:lp:/var/spool/lpd:/usr/sbin/nologin
mail:x:8:8:mail:/var/mail:/usr/sbin/nologin
news:x:9:9:news:/var/spool/news:/usr/sbin/nologin
uucp:x:10:10:uucp:/var/spool/uucp:/usr/sbin/nologin
proxy:x:13:13:proxy:/bin:/usr/sbin/nologin
www-data:x:33:33:www-data:/var/www:/usr/sbin/nologin
backup:x:34:34:backup:/var/backups:/usr/sbin/nologin
list:x:38:38:Mailing List Manager:/var/list:/usr/sbin/nologin
irc:x:39:39:ircd:/var/run/ircd:/usr/sbin/nologin
gnats:x:41:41:Gnats Bug-Reporting System (admin):/var/lib/gnats:/usr/sbin/nologin
nobody:x:65534:65534:nobody:/nonexistent:/usr/sbin/nologin
systemd-timesync:x:100:102:systemd Time Synchronization,,,:/run/systemd:/bin/false
systemd-network:x:101:103:systemd Network Management,,,:/run/systemd/netif:/bin/false
systemd-resolve:x:102:104:systemd Resolver,,,:/run/systemd/resolve:/bin/false
systemd-bus-proxy:x:103:105:systemd Bus Proxy,,,:/run/systemd:/bin/false
syslog:x:104:108::/home/syslog:/bin/false
_apt:x:105:65534::/nonexistent:/bin/false
messagebus:x:106:110::/var/run/dbus:/bin/false
uuidd:x:107:111::/run/uuidd:/bin/false
lightdm:x:108:114:Light Display Manager:/var/lib/lightdm:/bin/false
whoopsie:x:109:117::/nonexistent:/bin/false
avahi-autoipd:x:110:119:Avahi autoip daemon,,,:/var/lib/avahi-autoipd:/bin/false
avahi:x:111:120:Avahi mDNS daemon,,,:/var/run/avahi-daemon:/bin/false
colord:x:112:123:colord colour management daemon,,,:/var/lib/colord:/bin/false
dnsmasq:x:113:65534:dnsmasq,,,:/var/lib/misc:/bin/false
hplip:x:114:7:HPLIP system user,,,:/var/run/hplip:/bin/false
kernoops:x:115:65534:Kernel Oops Tracking Daemon,,,:/:/bin/false
pulse:x:116:124:PulseAudio daemon,,,:/var/run/pulse:/bin/false
rtkit:x:117:126:RealtimeKit,,,:/proc:/bin/false
saned:x:118:127::/var/lib/saned:/bin/false
usbmux:x:119:46:usbmux daemon,,,:/var/lib/usbmux:/bin/false
speech-dispatcher:x:120:29:Speech Dispatcher,,,:/var/run/speech-dispatcher:/bin/false
user:x:1000:1000:user,,,:/home/user:/bin/bash
sshd:x:121:65534::/var/run/sshd:/usr/sbin/nologin

이는 사실이지만 프로세스는 끝나지 않습니다. 종료하려면 ctrl+c를 눌러야 합니다. 명령줄에서 무엇을 놓치고 있나요?

이전에 질문을 드렸는데, 이 오류로 인해 이전 질문이 틀렸던 것으로 밝혀져 이중고를 겪었습니다.

답변1

파이프라인의 모든 부분이 거의 동시에 시작됩니다. 입력/출력만 파이프라인의 여러 단계를 동기화할 수 있습니다.

파이프라인에서

wc -l | sort -t":" -k4,4n | uniq password_demo.txt

uniqwc -l표준 입력(이 경우 터미널에 입력한 내용)의 입력을 기다리는 동안 지정된 파일에서 입력을 받고 의 sort출력을 기다립니다 wc. 입력이 있으면 프로세스 sort의 출력은 읽혀지지 않습니다. uniq그것.


파일에 있는 고유한 줄 수를 계산하려면 다음을 수행하세요.

sort -u password_demo.txt | wc -l

전체 행에 관심이 있으므로 및 플래그는 필요하지 않습니다 -t. -k-u플래그는 sort고유한 라인만 출력합니다.

네 번째로 구분된 필드에 고유한 값이 몇 개 있는지 계산하려면 :값을 추출하고 정렬해야 합니다.

awk -F ':' '{ print $4 }' password_demo.txt | sort -u | wc -l

또는:

cut -d ':' -f 4 password_demo.txt | sort -u | wc -l

cut이러한 명령에 대한 자세한 내용은 awk시스템 설명서를 참조하세요.

답변2

에서는 파일을 읽고 있습니다(파이프는 무시하고 있습니다) wc -l | sort -t":" -k4,4n | uniq password_demo.txt. 입력(stdin, 터미널에서)을 기다리는 중입니다. 읽을 파일 이름이 지정되지 않았기 때문에 입력( 출력에서)도 기다리고 있습니다. 이를 사용하여 터미널이 입력을 마치고 종료됨을 나타낼 수 있습니다.uniqwcsortwcCtrlDwc

그런 뜻 이었습니까 sort -t":" -k4,4n password_demo.txt | uniq? 또는 sort -t":" -k4,4n -u password_demo.txt? wc -l이게 어떻게 여기에 어울리는지 모르겠어요 .

관련 정보