Ну, я решил cpipe
, патч вы можете найти здесь: cpipe-3.0.1-singlebyte.patch ; это относится к текущему ' apt-get source cpipe
' в Lucid (который получает меня cpipe_3.0.1.orig.tar.gz и cpipe_3.0.1-1.diff.gz); Когда источник загрузит и cpipe-3.0.1
, просто выполните:
$ cp -a cpipe-3.0.1 cpipe-3.0.1B
$ cd cpipe-3.0.1B
$ patch -p1 < /path/to/cpipe-3.0.1-singlebyte.patch
$ make
Добавлен параметр командной строки -bs для 'байтового одиночного', который теперь может поддерживать однобайтовую запись до 1 Bps; так что теперь можно сделать:
$ echo "hello" | ./cpipe -vt -vw -bs 1 | cat
./cpipe: period 1 sec, 1000.000000 ms, 1000000000 ns, 0.000000 nsrem
h out: 1000.122ms at 0B/s ( 6B/s avg) 6B
e out: 2000.343ms at 0B/s ( 2B/s avg) 6B
l out: 3000.536ms at 1B/s ( 1B/s avg) 6B
l out: 4000.730ms at 1B/s ( 1B/s avg) 6B
o out: 5000.925ms at 1B/s ( 0B/s avg) 6B
out: 6001.100ms at 1B/s ( 0B/s avg) 6B
out: 6001.155ms at 1B/s ( 0B/s avg) 6B
thru: 6001.209ms at 1B/s ( 1B/s avg) 6B
$ echo "hello" | ./cpipe -vt -vw -bs 5 > /dev/null
./cpipe: period 0 sec, 200.000000 ms, 200000000 ns, 200000000.000000 nsrem
out: 200.120ms at 0B/s ( 30B/s avg) 6B
out: 400.323ms at 2B/s ( 10B/s avg) 6B
out: 600.507ms at 3B/s ( 5B/s avg) 6B
out: 800.690ms at 4B/s ( 3B/s avg) 6B
out: 1000.870ms at 4B/s ( 2B/s avg) 6B
out: 1201.049ms at 4B/s ( 1B/s avg) 6B
out: 1201.098ms at 5B/s ( 1B/s avg) 6B
thru: 1201.142ms at 5B/s ( 5B/s avg) 6B
... однако, это не будет работать слишком хорошо для более высоких скоростей кБ / с - так что в этом случае лучше использовать обычную буферизованную технику cpipe
-s
...
$ cat /etc/X11/rgb.txt | ./cpipe -vt -vw -bs 102400 > /dev/null
....
out: 2675.206ms at 6.3kB/s ( 1B/s avg) 17.0kB
out: 2675.240ms at 6.3kB/s ( 1B/s avg) 17.0kB
thru: 2675.832ms at 6.3kB/s ( 6.3kB/s avg) 17.0kB
$ cat /etc/X11/rgb.txt | ./cpipe -vt -vw -s 100 > /dev/null
out: 0.011ms at 1.5GB/s ( 1.5GB/s avg) 17.0kB
thru: 166.630ms at 101.9kB/s ( 101.9kB/s avg) 17.0kB
... как говорится в man cpipe
:
Поскольку в большинстве систем существует определенное минимальное время ожидания usleep(), например 0,01 с, невозможно достичь высоких пределов с небольшим размером буфера
Ну .. надеюсь услышать, что есть лучший способ контролировать это,
Ура!