4

Я бродил, если есть программа для Linux, которая может ограничить пропускную способность канала данных - в реальных байтах в секунду?

Из того, что я понимаю, применимо для этих целей

Я хотел бы иметь возможность указать что-то вроде

cat example.txt | ratelimit -Bps 100 > /dev/ttyUSB0

... и фактически имеет один байт из example.txt, отправляемый каждые 1/100 = 0,01 сек (или 10 мс) для вывода.

4 ответа4

3

Вы можете попробовать mbuffer (не знаю, по умолчанию ли он в Debian):

cat example.txt | mbuffer -R 100 > /dev/ttyUSB0
2

pv также может сделать это. Вот несколько умеренно надуманных примеров:

  • pv --rate-limit 1 /dev/zero > /dev/null
  • pv --quiet --rate-limit 16 /dev/urandom | hd
  • pv --quiet --rate-limit 10485760 /dev/zero | gzip | hd
  • head -c 1000 < /dev/zero | pv --size 1000 --rate-limit 150 | sha1sum
0

Ну, я решил 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 с, невозможно достичь высоких пределов с небольшим размером буфера

Ну .. надеюсь услышать, что есть лучший способ контролировать это,
Ура!

0

Вот также скрипт только для Perl, cratelimit.pl - возможно, не очень точный, но, кажется, что-то помогает (аргумент -r принимает байты в секунду):

cat whatever | ./cratelimit.pl -r=50000

Всё ещё ищете ответ? Посмотрите другие вопросы с метками .