From 022132c33e4ffb236c6c21e36ce82ddc347fb337 Mon Sep 17 00:00:00 2001 From: antao Date: Thu, 31 Jan 2019 10:23:12 +0800 Subject: [PATCH] Add json format response benchmark --- config.example.json | 74 ++++++++++++++++----------------- drogon_ctl/templates/config.csp | 74 ++++++++++++++++----------------- examples/benchmark/JsonCtrl.cc | 8 ++++ examples/benchmark/JsonCtrl.h | 12 ++++++ lib/src/HttpResponseImpl.cc | 9 ++-- 5 files changed, 100 insertions(+), 77 deletions(-) create mode 100644 examples/benchmark/JsonCtrl.cc create mode 100644 examples/benchmark/JsonCtrl.h diff --git a/config.example.json b/config.example.json index 02fc6cd7..a995f018 100644 --- a/config.example.json +++ b/config.example.json @@ -1,7 +1,7 @@ /* This is a JSON format configuration file */ { - //ssl:the global ssl files setting + //ssl:The global ssl files setting /* "ssl": { "cert": "../../trantor/trantor/tests/server.pem", @@ -9,53 +9,53 @@ }, "listeners": [ { - //address:ip address,0.0.0.0 by default + //address: Ip address,0.0.0.0 by default "address": "0.0.0.0", - //port:port number + //port: Port number "port": 80, - //https:if use https for security,false by default + //https: If true, use https for security,false by default "https": false }, { "address": "0.0.0.0", "port": 443, "https": true, - //cert,key:cert file path and key file path,empty by default, - //if empty,use global setting + //cert,key: Cert file path and key file path, empty by default, + //if empty, use global setting "cert": "", "key": "" } ], "db_clients": [ { - //name:Name of the client,'default' by default + //name: Name of the client,'default' by default //"name":"", - //rdbms:server type, postgresql,mysql or sqlite3, "postgresql" by default + //rdbms: Server type, postgresql,mysql or sqlite3, "postgresql" by default "rdbms": "postgresql", - //filename:sqlite3 db file name + //filename: Sqlite3 db file name //"filename":"", - //host:server address,localhost by default + //host: Server address,localhost by default "host": "127.0.0.1", - //port:server port, 5432 by default + //port: Server port, 5432 by default "port": 5432, - //dbname:Database name + //dbname: Database name "dbname": "test", - //user:'postgres' by default + //user: 'postgres' by default "user": "", - //passwd:'' by default + //passwd: '' by default "passwd": "", - //connection_number:1 by default + //connection_number: 1 by default "connection_number": 1 } ],*/ "app": { - //threads_num:the number of IO threads,1 by default, if the value is set to 0, the number of threads + //threads_num: The number of IO threads,1 by default, if the value is set to 0, the number of threads //will be the number of processors. "threads_num": 1, - //enable_session:false by default + //enable_session: False by default "enable_session": true, "session_timeout": 0, - //document_root:Root path of HTTP document,defaut path is ./ + //document_root: Root path of HTTP document,defaut path is ./ "document_root": "./", //upload_path: The path to save the uploaded file. "uploads" by default. //If the path isn't prefixed with /, ./ or ../, @@ -80,44 +80,44 @@ "cur", "xml" ], - //max_connections:max connections number,100000 by default + //max_connections: Max connections number,100000 by default "max_connections": 100000, - //max_connections_per_ip:max connections number per clinet,0 by default which means no limit + //max_connections_per_ip: Max connections number per clinet,0 by default which means no limit "max_connections_per_ip": 0, - //Load_dynamic_views: false by default, when set to true, drogon will + //Load_dynamic_views: False by default, when set to true, drogon will //compile and load dynamically "CSP View Files" in directories defined //by "dynamic_views_path" "load_dynamic_views":false, - //dynamic_views_path: if the path isn't prefixed with /, ./ or ../, + //dynamic_views_path: If the path isn't prefixed with /, ./ or ../, //it will be relative path of document_root path "dynamic_views_path":["./views"], - //log:set log output,drogon output logs to stdout by default + //log: Set log output, drogon output logs to stdout by default "log": { - //log_path:log file path,empty by default,in which case,log will output to the stdout + //log_path: Log file path,empty by default,in which case,log will output to the stdout //"log_path": "./", - //logfile_base_name:log file base name,empty by default which means drogon will name logfile as + //logfile_base_name: Log file base name,empty by default which means drogon will name logfile as //drogon.log ... "logfile_base_name": "", - //log_size_limit:100000000 bytes by default, + //log_size_limit: 100000000 bytes by default, //When the log file size reaches "log_size_limit", the log file will be switched. "log_size_limit": 100000000, - //log_level:"DEBUG" by default,options:"TRACE","DEBUG","INFO","WARN" + //log_level: "DEBUG" by default,options:"TRACE","DEBUG","INFO","WARN" //The TRACE level is only valid when built in DEBUG mode. - "log_level": "TRACE" + "log_level": "DEBUG" }, - //run_as_daemon:false by default + //run_as_daemon: False by default "run_as_daemon": false, - //relaunch_on_error:false by default,if true,the program will be restart by parent after exit; + //relaunch_on_error: False by default, if true, the program will be restart by the parent after exiting; "relaunch_on_error": false, - //use_sendfile:true by default,if ture,the program will - //use sendfile() system-call to send static file to client; + //use_sendfile: True by default, if ture, the program will + //use sendfile() system-call to send static file to the client; "use_sendfile": true, - //use_gzip:true by default,use gzip to compress the response body's content; + //use_gzip: True by default,use gzip to compress the response body's content; "use_gzip": true, - //static_files_cache_time:5 (seconds) by default,the time in which static file response is cached, - //0 means cache forever,the negative value means no cache + //static_files_cache_time: 5 (seconds) by default,the time in which static file response is cached, + //0 means cache forever, the negative value means no cache "static_files_cache_time": 5, - //simple_controllers_map:Configuring mapping from path to simple controller + //simple_controllers_map: Used to configure mapping from path to simple controller "simple_controllers_map": [ { "path": "/path/name", @@ -131,7 +131,7 @@ ] } ], - //idle_connection_timeout: defaults to 60 seconds, the lifetime + //idle_connection_timeout: Defaults to 60 seconds, the lifetime //of the connection without read or write "idle_connection_timeout": 60 } diff --git a/drogon_ctl/templates/config.csp b/drogon_ctl/templates/config.csp index efc1a438..a995f018 100644 --- a/drogon_ctl/templates/config.csp +++ b/drogon_ctl/templates/config.csp @@ -1,7 +1,7 @@ /* This is a JSON format configuration file */ { - //ssl:the global ssl files setting + //ssl:The global ssl files setting /* "ssl": { "cert": "../../trantor/trantor/tests/server.pem", @@ -9,53 +9,53 @@ }, "listeners": [ { - //address:ip address,0.0.0.0 by default + //address: Ip address,0.0.0.0 by default "address": "0.0.0.0", - //port:port number + //port: Port number "port": 80, - //https:if use https for security,false by default + //https: If true, use https for security,false by default "https": false }, { "address": "0.0.0.0", "port": 443, "https": true, - //cert,key:cert file path and key file path,empty by default, - //if empty,use global setting + //cert,key: Cert file path and key file path, empty by default, + //if empty, use global setting "cert": "", "key": "" } ], "db_clients": [ { - //name:Name of the client,'default' by default + //name: Name of the client,'default' by default //"name":"", - //rdbms:server type, postgresql,mysql or sqlite3, "postgresql" by default + //rdbms: Server type, postgresql,mysql or sqlite3, "postgresql" by default "rdbms": "postgresql", - //filename:sqlite3 db file name + //filename: Sqlite3 db file name //"filename":"", - //host:server address,localhost by default + //host: Server address,localhost by default "host": "127.0.0.1", - //port:server port, 5432 by default + //port: Server port, 5432 by default "port": 5432, - //dbname:Database name + //dbname: Database name "dbname": "test", - //user:'postgres' by default + //user: 'postgres' by default "user": "", - //passwd:'' by default + //passwd: '' by default "passwd": "", - //connection_number:1 by default + //connection_number: 1 by default "connection_number": 1 } ],*/ "app": { - //threads_num:the number of IO threads,1 by default, if the value is set to 0, the number of threads + //threads_num: The number of IO threads,1 by default, if the value is set to 0, the number of threads //will be the number of processors. "threads_num": 1, - //enable_session:false by default - "enable_session": false, + //enable_session: False by default + "enable_session": true, "session_timeout": 0, - //document_root:Root path of HTTP document,defaut path is ./ + //document_root: Root path of HTTP document,defaut path is ./ "document_root": "./", //upload_path: The path to save the uploaded file. "uploads" by default. //If the path isn't prefixed with /, ./ or ../, @@ -80,44 +80,44 @@ "cur", "xml" ], - //max_connections:max connections number,100000 by default + //max_connections: Max connections number,100000 by default "max_connections": 100000, - //max_connections_per_ip:max connections number per clinet,0 by default which means no limit + //max_connections_per_ip: Max connections number per clinet,0 by default which means no limit "max_connections_per_ip": 0, - //Load_dynamic_views: false by default, when set to true, drogon will + //Load_dynamic_views: False by default, when set to true, drogon will //compile and load dynamically "CSP View Files" in directories defined //by "dynamic_views_path" "load_dynamic_views":false, - //dynamic_views_path: if the path isn't prefixed with /, ./ or ../, + //dynamic_views_path: If the path isn't prefixed with /, ./ or ../, //it will be relative path of document_root path "dynamic_views_path":["./views"], - //log:set log output,drogon output logs to stdout by default + //log: Set log output, drogon output logs to stdout by default "log": { - //log_path:log file path,empty by default,in which case,log will output to the stdout + //log_path: Log file path,empty by default,in which case,log will output to the stdout //"log_path": "./", - //logfile_base_name:log file base name,empty by default which means drogon will name logfile as + //logfile_base_name: Log file base name,empty by default which means drogon will name logfile as //drogon.log ... "logfile_base_name": "", - //log_size_limit:100000000 bytes by default, + //log_size_limit: 100000000 bytes by default, //When the log file size reaches "log_size_limit", the log file will be switched. "log_size_limit": 100000000, - //log_level:"DEBUG" by default,options:"TRACE","DEBUG","INFO","WARN" + //log_level: "DEBUG" by default,options:"TRACE","DEBUG","INFO","WARN" //The TRACE level is only valid when built in DEBUG mode. "log_level": "DEBUG" }, - //run_as_daemon:false by default + //run_as_daemon: False by default "run_as_daemon": false, - //relaunch_on_error:false by default,if true,the program will be restart by parent after exit; + //relaunch_on_error: False by default, if true, the program will be restart by the parent after exiting; "relaunch_on_error": false, - //use_sendfile:true by default,if ture,the program will - //use sendfile() system-call to send static file to client; + //use_sendfile: True by default, if ture, the program will + //use sendfile() system-call to send static file to the client; "use_sendfile": true, - //use_gzip:true by default,use gzip to compress the response body's content; + //use_gzip: True by default,use gzip to compress the response body's content; "use_gzip": true, - //static_files_cache_time:5 (seconds) by default,the time in which static file response is cached, - //0 means cache forever,the negative value means no cache + //static_files_cache_time: 5 (seconds) by default,the time in which static file response is cached, + //0 means cache forever, the negative value means no cache "static_files_cache_time": 5, - //simple_controllers_map:Configuring mapping from path to simple controller + //simple_controllers_map: Used to configure mapping from path to simple controller "simple_controllers_map": [ { "path": "/path/name", @@ -131,7 +131,7 @@ ] } ], - //idle_connection_timeout: defaults to 60 seconds, the lifetime + //idle_connection_timeout: Defaults to 60 seconds, the lifetime //of the connection without read or write "idle_connection_timeout": 60 } diff --git a/examples/benchmark/JsonCtrl.cc b/examples/benchmark/JsonCtrl.cc new file mode 100644 index 00000000..1e4102a5 --- /dev/null +++ b/examples/benchmark/JsonCtrl.cc @@ -0,0 +1,8 @@ +#include "JsonCtrl.h" +void JsonCtrl::asyncHandleHttpRequest(const HttpRequestPtr &req, const std::function &callback) +{ + Json::Value ret; + ret["message"] = "Hello, World!"; + auto resp = HttpResponse::newHttpJsonResponse(ret); + callback(resp); +} \ No newline at end of file diff --git a/examples/benchmark/JsonCtrl.h b/examples/benchmark/JsonCtrl.h new file mode 100644 index 00000000..105393c5 --- /dev/null +++ b/examples/benchmark/JsonCtrl.h @@ -0,0 +1,12 @@ +#pragma once +#include +using namespace drogon; +class JsonCtrl : public drogon::HttpSimpleController +{ + public: + virtual void asyncHandleHttpRequest(const HttpRequestPtr &req, const std::function &callback) override; + PATH_LIST_BEGIN + //list path definitions here; + PATH_ADD("/json", Get); + PATH_LIST_END +}; diff --git a/lib/src/HttpResponseImpl.cc b/lib/src/HttpResponseImpl.cc index d2e392ef..8a2d90c0 100755 --- a/lib/src/HttpResponseImpl.cc +++ b/lib/src/HttpResponseImpl.cc @@ -36,12 +36,15 @@ HttpResponsePtr HttpResponse::newHttpResponse() HttpResponsePtr HttpResponse::newHttpJsonResponse(const Json::Value &data) { + static std::once_flag once; + static Json::StreamWriterBuilder builder; + std::call_once(once, []() { + builder["commentStyle"] = "None"; + builder["indentation"] = ""; + }); auto res = std::make_shared(); res->setStatusCode(k200OK); res->setContentTypeCode(CT_APPLICATION_JSON); - Json::StreamWriterBuilder builder; - builder["commentStyle"] = "None"; - builder["indentation"] = ""; res->setBody(writeString(builder, data)); return res; }