Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
N
nghttp2
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Analytics
Analytics
CI / CD
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
Libraries
nghttp2
Commits
c48a1d75
Commit
c48a1d75
authored
Sep 13, 2013
by
Tatsuhiro Tsujikawa
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
nghttpx: Add rate limit options
parent
0f759978
Changes
3
Show whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
86 additions
and
4 deletions
+86
-4
src/shrpx.cc
src/shrpx.cc
+66
-4
src/shrpx_config.cc
src/shrpx_config.cc
+12
-0
src/shrpx_config.h
src/shrpx_config.h
+8
-0
No files found.
src/shrpx.cc
View file @
c48a1d75
...
@@ -400,10 +400,22 @@ void fill_default_config()
...
@@ -400,10 +400,22 @@ void fill_default_config()
mod_config
()
->
downstream_http_proxy_host
=
0
;
mod_config
()
->
downstream_http_proxy_host
=
0
;
mod_config
()
->
downstream_http_proxy_port
=
0
;
mod_config
()
->
downstream_http_proxy_port
=
0
;
mod_config
()
->
downstream_http_proxy_addrlen
=
0
;
mod_config
()
->
downstream_http_proxy_addrlen
=
0
;
mod_config
()
->
rate_limit_cfg
=
mod_config
()
->
rate_limit_cfg
=
nullptr
;
ev_token_bucket_cfg_new
(
1024
*
1024
,
4
*
1024
*
1024
,
mod_config
()
->
read_rate
=
1024
*
1024
;
EV_RATE_LIMIT_MAX
,
EV_RATE_LIMIT_MAX
,
mod_config
()
->
read_burst
=
4
*
1024
*
1024
;
nullptr
);
mod_config
()
->
write_rate
=
0
;
mod_config
()
->
write_burst
=
0
;
}
}
// namespace
namespace
{
size_t
get_rate_limit
(
size_t
rate_limit
)
{
if
(
rate_limit
==
0
)
{
return
EV_RATE_LIMIT_MAX
;
}
else
{
return
rate_limit
;
}
}
}
}
// namespace
}
// namespace
...
@@ -461,6 +473,29 @@ void print_help(std::ostream& out)
...
@@ -461,6 +473,29 @@ void print_help(std::ostream& out)
<<
" Set the number of worker threads.
\n
"
<<
" Set the number of worker threads.
\n
"
<<
" Default: "
<<
" Default: "
<<
get_config
()
->
num_worker
<<
"
\n
"
<<
get_config
()
->
num_worker
<<
"
\n
"
<<
" --read-rate=<RATE> Set maximum average read rate on frontend
\n
"
<<
" connection. Setting 0 to this option means
\n
"
<<
" read rate is unlimited.
\n
"
<<
" Default: "
<<
get_config
()
->
read_rate
<<
"
\n
"
<<
" --read-burst=<SIZE>
\n
"
<<
" Set maximum read burst size on frontend
\n
"
<<
" connection. Setting 0 to this option means
\n
"
<<
" read burst size is unlimited.
\n
"
<<
" Default: "
<<
get_config
()
->
read_burst
<<
"
\n
"
<<
" --write-rate=<RATE>
\n
"
<<
" Set maximum average write rate on frontend
\n
"
<<
" connection. Setting 0 to this option means
\n
"
<<
" write rate is unlimited.
\n
"
<<
" Default: "
<<
get_config
()
->
write_rate
<<
"
\n
"
<<
" --write-burst=<SIZE>
\n
"
<<
" Set maximum write burst size on frontend
\n
"
<<
" connection. Setting 0 to this option means
\n
"
<<
" write burst size is unlimited.
\n
"
<<
" Default: "
<<
get_config
()
->
write_burst
<<
"
\n
"
<<
"
\n
"
<<
"
\n
"
<<
" Timeout:
\n
"
<<
" Timeout:
\n
"
<<
" --frontend-spdy-read-timeout=<SEC>
\n
"
<<
" --frontend-spdy-read-timeout=<SEC>
\n
"
...
@@ -671,6 +706,10 @@ int main(int argc, char **argv)
...
@@ -671,6 +706,10 @@ int main(int argc, char **argv)
{
"backend-tls-sni-field"
,
required_argument
,
&
flag
,
31
},
{
"backend-tls-sni-field"
,
required_argument
,
&
flag
,
31
},
{
"honor-cipher-order"
,
no_argument
,
&
flag
,
32
},
{
"honor-cipher-order"
,
no_argument
,
&
flag
,
32
},
{
"dh-param-file"
,
required_argument
,
&
flag
,
33
},
{
"dh-param-file"
,
required_argument
,
&
flag
,
33
},
{
"read-rate"
,
required_argument
,
&
flag
,
34
},
{
"read-burst"
,
required_argument
,
&
flag
,
35
},
{
"write-rate"
,
required_argument
,
&
flag
,
36
},
{
"write-burst"
,
required_argument
,
&
flag
,
37
},
{
nullptr
,
0
,
nullptr
,
0
}
{
nullptr
,
0
,
nullptr
,
0
}
};
};
int
option_index
=
0
;
int
option_index
=
0
;
...
@@ -854,6 +893,22 @@ int main(int argc, char **argv)
...
@@ -854,6 +893,22 @@ int main(int argc, char **argv)
// --dh-param-file
// --dh-param-file
cmdcfgs
.
push_back
(
std
::
make_pair
(
SHRPX_OPT_DH_PARAM_FILE
,
optarg
));
cmdcfgs
.
push_back
(
std
::
make_pair
(
SHRPX_OPT_DH_PARAM_FILE
,
optarg
));
break
;
break
;
case
34
:
// --read-rate
cmdcfgs
.
push_back
(
std
::
make_pair
(
SHRPX_OPT_READ_RATE
,
optarg
));
break
;
case
35
:
// --read-burst
cmdcfgs
.
push_back
(
std
::
make_pair
(
SHRPX_OPT_READ_BURST
,
optarg
));
break
;
case
36
:
// --write-rate
cmdcfgs
.
push_back
(
std
::
make_pair
(
SHRPX_OPT_WRITE_RATE
,
optarg
));
break
;
case
37
:
// --write-burst
cmdcfgs
.
push_back
(
std
::
make_pair
(
SHRPX_OPT_WRITE_BURST
,
optarg
));
break
;
default:
default:
break
;
break
;
}
}
...
@@ -980,6 +1035,13 @@ int main(int argc, char **argv)
...
@@ -980,6 +1035,13 @@ int main(int argc, char **argv)
mod_config
()
->
use_syslog
=
true
;
mod_config
()
->
use_syslog
=
true
;
}
}
mod_config
()
->
rate_limit_cfg
=
ev_token_bucket_cfg_new
(
get_rate_limit
(
get_config
()
->
read_rate
),
get_rate_limit
(
get_config
()
->
read_burst
),
get_rate_limit
(
get_config
()
->
write_rate
),
get_rate_limit
(
get_config
()
->
write_burst
),
nullptr
);
struct
sigaction
act
;
struct
sigaction
act
;
memset
(
&
act
,
0
,
sizeof
(
struct
sigaction
));
memset
(
&
act
,
0
,
sizeof
(
struct
sigaction
));
act
.
sa_handler
=
SIG_IGN
;
act
.
sa_handler
=
SIG_IGN
;
...
...
src/shrpx_config.cc
View file @
c48a1d75
...
@@ -95,6 +95,10 @@ const char SHRPX_OPT_CACERT[] = "cacert";
...
@@ -95,6 +95,10 @@ const char SHRPX_OPT_CACERT[] = "cacert";
const
char
SHRPX_OPT_BACKEND_IPV4
[]
=
"backend-ipv4"
;
const
char
SHRPX_OPT_BACKEND_IPV4
[]
=
"backend-ipv4"
;
const
char
SHRPX_OPT_BACKEND_IPV6
[]
=
"backend-ipv6"
;
const
char
SHRPX_OPT_BACKEND_IPV6
[]
=
"backend-ipv6"
;
const
char
SHRPX_OPT_BACKEND_HTTP_PROXY_URI
[]
=
"backend-http-proxy-uri"
;
const
char
SHRPX_OPT_BACKEND_HTTP_PROXY_URI
[]
=
"backend-http-proxy-uri"
;
const
char
SHRPX_OPT_READ_RATE
[]
=
"read-rate"
;
const
char
SHRPX_OPT_READ_BURST
[]
=
"read-burst"
;
const
char
SHRPX_OPT_WRITE_RATE
[]
=
"write-rate"
;
const
char
SHRPX_OPT_WRITE_BURST
[]
=
"write-burst"
;
namespace
{
namespace
{
Config
*
config
=
0
;
Config
*
config
=
0
;
...
@@ -373,6 +377,14 @@ int parse_config(const char *opt, const char *optarg)
...
@@ -373,6 +377,14 @@ int parse_config(const char *opt, const char *optarg)
LOG
(
ERROR
)
<<
"Could not parse backend-http-proxy-uri"
;
LOG
(
ERROR
)
<<
"Could not parse backend-http-proxy-uri"
;
return
-
1
;
return
-
1
;
}
}
}
else
if
(
util
::
strieq
(
opt
,
SHRPX_OPT_READ_RATE
))
{
mod_config
()
->
read_rate
=
strtoul
(
optarg
,
nullptr
,
10
);
}
else
if
(
util
::
strieq
(
opt
,
SHRPX_OPT_READ_BURST
))
{
mod_config
()
->
read_burst
=
strtoul
(
optarg
,
nullptr
,
10
);
}
else
if
(
util
::
strieq
(
opt
,
SHRPX_OPT_WRITE_RATE
))
{
mod_config
()
->
write_rate
=
strtoul
(
optarg
,
nullptr
,
10
);
}
else
if
(
util
::
strieq
(
opt
,
SHRPX_OPT_WRITE_BURST
))
{
mod_config
()
->
write_burst
=
strtoul
(
optarg
,
nullptr
,
10
);
}
else
if
(
util
::
strieq
(
opt
,
"conf"
))
{
}
else
if
(
util
::
strieq
(
opt
,
"conf"
))
{
LOG
(
WARNING
)
<<
"conf is ignored"
;
LOG
(
WARNING
)
<<
"conf is ignored"
;
}
else
{
}
else
{
...
...
src/shrpx_config.h
View file @
c48a1d75
...
@@ -86,6 +86,10 @@ extern const char SHRPX_OPT_BACKEND_IPV4[];
...
@@ -86,6 +86,10 @@ extern const char SHRPX_OPT_BACKEND_IPV4[];
extern
const
char
SHRPX_OPT_BACKEND_IPV6
[];
extern
const
char
SHRPX_OPT_BACKEND_IPV6
[];
extern
const
char
SHRPX_OPT_BACKEND_HTTP_PROXY_URI
[];
extern
const
char
SHRPX_OPT_BACKEND_HTTP_PROXY_URI
[];
extern
const
char
SHRPX_OPT_BACKEND_TLS_SNI_FIELD
[];
extern
const
char
SHRPX_OPT_BACKEND_TLS_SNI_FIELD
[];
extern
const
char
SHRPX_OPT_READ_RATE
[];
extern
const
char
SHRPX_OPT_READ_BURST
[];
extern
const
char
SHRPX_OPT_WRITE_RATE
[];
extern
const
char
SHRPX_OPT_WRITE_BURST
[];
union
sockaddr_union
{
union
sockaddr_union
{
sockaddr
sa
;
sockaddr
sa
;
...
@@ -170,6 +174,10 @@ struct Config {
...
@@ -170,6 +174,10 @@ struct Config {
size_t
downstream_http_proxy_addrlen
;
size_t
downstream_http_proxy_addrlen
;
// Rate limit configuration
// Rate limit configuration
ev_token_bucket_cfg
*
rate_limit_cfg
;
ev_token_bucket_cfg
*
rate_limit_cfg
;
size_t
read_rate
;
size_t
read_burst
;
size_t
write_rate
;
size_t
write_burst
;
};
};
const
Config
*
get_config
();
const
Config
*
get_config
();
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment