times 5.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113
  1. More number for the questions about SSL overheads....
  2. The following numbers were generated on a Pentium pro 200, running Linux.
  3. They give an indication of the SSL protocol and encryption overheads.
  4. The program that generated them is an unreleased version of ssl/ssltest.c
  5. which is the SSLeay ssl protocol testing program. It is a single process that
  6. talks both sides of the SSL protocol via a non-blocking memory buffer
  7. interface.
  8. How do I read this? The protocol and cipher are reasonable obvious.
  9. The next number is the number of connections being made. The next is the
  10. number of bytes exchanged between the client and server side of the protocol.
  11. This is the number of bytes that the client sends to the server, and then
  12. the server sends back. Because this is all happening in one process,
  13. the data is being encrypted, decrypted, encrypted and then decrypted again.
  14. It is a round trip of that many bytes. Because the one process performs
  15. both the client and server sides of the protocol and it sends this many bytes
  16. each direction, multiply this number by 4 to generate the number
  17. of bytes encrypted/decrypted/MACed. The first time value is how many seconds
  18. elapsed doing a full SSL handshake, the second is the cost of one
  19. full handshake and the rest being session-id reuse.
  20. SSLv2 RC4-MD5 1000 x 1 12.83s 0.70s
  21. SSLv3 NULL-MD5 1000 x 1 14.35s 1.47s
  22. SSLv3 RC4-MD5 1000 x 1 14.46s 1.56s
  23. SSLv3 RC4-MD5 1000 x 1 51.93s 1.62s 1024bit RSA
  24. SSLv3 RC4-SHA 1000 x 1 14.61s 1.83s
  25. SSLv3 DES-CBC-SHA 1000 x 1 14.70s 1.89s
  26. SSLv3 DES-CBC3-SHA 1000 x 1 15.16s 2.16s
  27. SSLv2 RC4-MD5 1000 x 1024 13.72s 1.27s
  28. SSLv3 NULL-MD5 1000 x 1024 14.79s 1.92s
  29. SSLv3 RC4-MD5 1000 x 1024 52.58s 2.29s 1024bit RSA
  30. SSLv3 RC4-SHA 1000 x 1024 15.39s 2.67s
  31. SSLv3 DES-CBC-SHA 1000 x 1024 16.45s 3.55s
  32. SSLv3 DES-CBC3-SHA 1000 x 1024 18.21s 5.38s
  33. SSLv2 RC4-MD5 1000 x 10240 18.97s 6.52s
  34. SSLv3 NULL-MD5 1000 x 10240 17.79s 5.11s
  35. SSLv3 RC4-MD5 1000 x 10240 20.25s 7.90s
  36. SSLv3 RC4-MD5 1000 x 10240 58.26s 8.08s 1024bit RSA
  37. SSLv3 RC4-SHA 1000 x 10240 22.96s 11.44s
  38. SSLv3 DES-CBC-SHA 1000 x 10240 30.65s 18.41s
  39. SSLv3 DES-CBC3-SHA 1000 x 10240 47.04s 34.53s
  40. SSLv2 RC4-MD5 1000 x 102400 70.22s 57.74s
  41. SSLv3 NULL-MD5 1000 x 102400 43.73s 31.03s
  42. SSLv3 RC4-MD5 1000 x 102400 71.32s 58.83s
  43. SSLv3 RC4-MD5 1000 x 102400 109.66s 59.20s 1024bit RSA
  44. SSLv3 RC4-SHA 1000 x 102400 95.88s 82.21s
  45. SSLv3 DES-CBC-SHA 1000 x 102400 173.22s 160.55s
  46. SSLv3 DES-CBC3-SHA 1000 x 102400 336.61s 323.82s
  47. What does this all mean? Well for a server, with no session-id reuse, with
  48. a transfer size of 10240 bytes, using RC4-MD5 and a 512bit server key,
  49. a Pentium pro 200 running Linux can handle the SSLv3 protocol overheads of
  50. about 49 connections a second. Reality will be quite different :-).
  51. Remember the first number is 1000 full ssl handshakes, the second is
  52. 1 full and 999 with session-id reuse. The RSA overheads for each exchange
  53. would be one public and one private operation, but the protocol/MAC/cipher
  54. cost would be quite similar in both the client and server.
  55. eric (adding numbers to speculation)
  56. --- Appendix ---
  57. - The time measured is user time but these number a very rough.
  58. - Remember this is the cost of both client and server sides of the protocol.
  59. - The TCP/kernel overhead of connection establishment is normally the
  60. killer in SSL. Often delays in the TCP protocol will make session-id
  61. reuse look slower that new sessions, but this would not be the case on
  62. a loaded server.
  63. - The TCP round trip latencies, while slowing individual connections,
  64. would have minimal impact on throughput.
  65. - Instead of sending one 102400 byte buffer, one 8k buffer is sent until
  66. - the required number of bytes are processed.
  67. - The SSLv3 connections were actually SSLv2 compatible SSLv3 headers.
  68. - A 512bit server key was being used except where noted.
  69. - No server key verification was being performed on the client side of the
  70. protocol. This would slow things down very little.
  71. - The library being used is SSLeay 0.8.x.
  72. - The normal measuring system was commands of the form
  73. time ./ssltest -num 1000 -bytes 102400 -cipher DES-CBC-SHA -reuse
  74. This modified version of ssltest should be in the next public release of
  75. SSLeay.
  76. The general cipher performance number for this platform are
  77. SSLeay 0.8.2a 04-Sep-1997
  78. built on Fri Sep 5 17:37:05 EST 1997
  79. options:bn(64,32) md2(int) rc4(idx,int) des(ptr,risc1,16,long) idea(int) blowfish(ptr2)
  80. C flags:gcc -DL_ENDIAN -DTERMIO -O3 -fomit-frame-pointer -m486 -Wall -Wuninitialized
  81. The 'numbers' are in 1000s of bytes per second processed.
  82. type 8 bytes 64 bytes 256 bytes 1024 bytes 8192 bytes
  83. md2 131.02k 368.41k 500.57k 549.21k 566.09k
  84. mdc2 535.60k 589.10k 595.88k 595.97k 594.54k
  85. md5 1801.53k 9674.77k 17484.03k 21849.43k 23592.96k
  86. sha 1261.63k 5533.25k 9285.63k 11187.88k 11913.90k
  87. sha1 1103.13k 4782.53k 7933.78k 9472.34k 10070.70k
  88. rc4 10722.53k 14443.93k 15215.79k 15299.24k 15219.59k
  89. des cbc 3286.57k 3827.73k 3913.39k 3931.82k 3926.70k
  90. des ede3 1443.50k 1549.08k 1561.17k 1566.38k 1564.67k
  91. idea cbc 2203.64k 2508.16k 2538.33k 2543.62k 2547.71k
  92. rc2 cbc 1430.94k 1511.59k 1524.82k 1527.13k 1523.33k
  93. blowfish cbc 4716.07k 5965.82k 6190.17k 6243.67k 6234.11k
  94. sign verify
  95. rsa 512 bits 0.0100s 0.0011s
  96. rsa 1024 bits 0.0451s 0.0012s
  97. rsa 2048 bits 0.2605s 0.0086s
  98. rsa 4096 bits 1.6883s 0.0302s