如果我运行下面的命令,只有out1
输出,out2
和out3
为空。
# this is just to generate a self-signed certificate
openssl genrsa -out /tmp/ssl.key 2048
openssl req -sha256 -new -key /tmp/ssl.key -out /tmp/ssl.csr -subj /CN=localhost
openssl x509 -req -days 365 -in /tmp/ssl.csr -signkey /tmp/ssl.key -out /tmp/ssl.crt
# works
openssl s_server -cert /tmp/ssl.crt -key /tmp/ssl.key -accept 444 > out1
# does not work, but if I run without '> out2' it works
openssl s_server -cert /tmp/ssl.crt -key /tmp/ssl.key -accept 446 | sed "s/ACCEPT/ACCEPT445/g" > out2
# does not work, but if I run without '> out3' it works
openssl s_server -cert /tmp/ssl.crt -key /tmp/ssl.key -accept 447 | grep ACCEPT > out3
为什么从 sed 或 grep 重定向 stdout 会失败,但在不重定向的情况下运行却可以?
答案1
尝试sed -u
(-l
在 BSD/Mac OSX 系统上)和grep --line-buffered
选项。
答案2
您似乎期望out2
和out3
被实时写入,但sed
和grep
在管道中等待 EOF。这里没有任何失败。
从另一个控制台杀死并检查和openssl
中是否有正确的结果。out2
out3