1
0
mirror of https://github.com/wg/wrk synced 2025-01-08 23:32:54 +08:00

send hostname in TLS SNI extension

This commit is contained in:
Will 2016-03-26 09:18:07 +09:00
parent 040db59768
commit 50305ed1d8
7 changed files with 44 additions and 6 deletions

View File

@ -1,3 +1,8 @@
wrk 4.0.2
* Send hostname using TLS SNI.
* Add optional WITH_OPENSSL and WITH_LUAJIT to use system libs.
* Bundle OpenSSL 1.0.2.
* delay() can return milliseconds to delay sending next request. * delay() can return milliseconds to delay sending next request.
wrk 4.0.0 wrk 4.0.0

29
INSTALL Normal file
View File

@ -0,0 +1,29 @@
Overview
wrk should build on most UNIX-like operating systems and
architectures that have GNU make and are supported by LuaJIT and
OpenSSL. Some systems may require additional CFLAGS or LDFLAGS,
see the top of the Makefile for examples
In many cases simply running `make` (often `gmake` on *BSD) will
do the trick.
Dependencies
wrk requires LuaJIT and OpenSSL and is distributed with appropriate
versions that will be unpacked and built as necessary.
If you are building wrk packages for an OS distribution or otherwise
prefer to use system versions of dependencies you may specify their
location when invoking make with one or more of:
WITH_LUAJIT
WITH_OPENSSL
For example to use the system version of both libraries on Linux:
make WITH_LUAJIT=/usr WITH_OPENSSL=/usr
Or to use the Homebrew version of OpenSSL on Mac OS X:
make WITH_OPENSSL=/usr/local/opt/openssl

View File

@ -6,7 +6,7 @@
#include "net.h" #include "net.h"
status sock_connect(connection *c) { status sock_connect(connection *c, char *host) {
return OK; return OK;
} }

View File

@ -13,14 +13,14 @@ typedef enum {
} status; } status;
struct sock { struct sock {
status ( *connect)(connection *); status ( *connect)(connection *, char *);
status ( *close)(connection *); status ( *close)(connection *);
status ( *read)(connection *, size_t *); status ( *read)(connection *, size_t *);
status ( *write)(connection *, char *, size_t, size_t *); status ( *write)(connection *, char *, size_t, size_t *);
size_t (*readable)(connection *); size_t (*readable)(connection *);
}; };
status sock_connect(connection *); status sock_connect(connection *, char *);
status sock_close(connection *); status sock_close(connection *);
status sock_read(connection *, size_t *); status sock_read(connection *, size_t *);
status sock_write(connection *, char *, size_t, size_t *); status sock_write(connection *, char *, size_t, size_t *);

View File

@ -49,9 +49,10 @@ SSL_CTX *ssl_init() {
return ctx; return ctx;
} }
status ssl_connect(connection *c) { status ssl_connect(connection *c, char *host) {
int r; int r;
SSL_set_fd(c->ssl, c->fd); SSL_set_fd(c->ssl, c->fd);
SSL_set_tlsext_host_name(c->ssl, host);
if ((r = SSL_connect(c->ssl)) != 1) { if ((r = SSL_connect(c->ssl)) != 1) {
switch (SSL_get_error(c->ssl, r)) { switch (SSL_get_error(c->ssl, r)) {
case SSL_ERROR_WANT_READ: return RETRY; case SSL_ERROR_WANT_READ: return RETRY;

View File

@ -5,7 +5,7 @@
SSL_CTX *ssl_init(); SSL_CTX *ssl_init();
status ssl_connect(connection *); status ssl_connect(connection *, char *);
status ssl_close(connection *); status ssl_close(connection *);
status ssl_read(connection *, size_t *); status ssl_read(connection *, size_t *);
status ssl_write(connection *, char *, size_t, size_t *); status ssl_write(connection *, char *, size_t, size_t *);

View File

@ -13,6 +13,7 @@ static struct config {
bool delay; bool delay;
bool dynamic; bool dynamic;
bool latency; bool latency;
char *host;
char *script; char *script;
SSL_CTX *ctx; SSL_CTX *ctx;
} cfg; } cfg;
@ -98,6 +99,8 @@ int main(int argc, char **argv) {
exit(1); exit(1);
} }
cfg.host = host;
for (uint64_t i = 0; i < cfg.threads; i++) { for (uint64_t i = 0; i < cfg.threads; i++) {
thread *t = &threads[i]; thread *t = &threads[i];
t->loop = aeCreateEventLoop(10 + cfg.connections * 3); t->loop = aeCreateEventLoop(10 + cfg.connections * 3);
@ -359,7 +362,7 @@ static int response_complete(http_parser *parser) {
static void socket_connected(aeEventLoop *loop, int fd, void *data, int mask) { static void socket_connected(aeEventLoop *loop, int fd, void *data, int mask) {
connection *c = data; connection *c = data;
switch (sock.connect(c)) { switch (sock.connect(c, cfg.host)) {
case OK: break; case OK: break;
case ERROR: goto error; case ERROR: goto error;
case RETRY: return; case RETRY: return;