Skip to content
Projects
Groups
Snippets
Help
Loading...
Sign in / Register
Toggle navigation
M
mongoose
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Packages
Packages
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
submodule
mongoose
Commits
04de3bb2
Commit
04de3bb2
authored
Jan 07, 2014
by
Sergey Lyubka
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Updated docs
parent
86da250e
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
39 additions
and
18 deletions
+39
-18
API.md
docs/API.md
+2
-2
Internals.md
docs/Internals.md
+37
-16
No files found.
docs/API.md
View file @
04de3bb2
...
@@ -51,8 +51,8 @@ is serving, in between `mg_poll_server()` calls.
...
@@ -51,8 +51,8 @@ is serving, in between `mg_poll_server()` calls.
void mg_poll_server(struct mg_server *server, int milliseconds);
void mg_poll_server(struct mg_server *server, int milliseconds);
This function performs one iteration of IO loop by iterating over all
This function performs one iteration of IO loop by iterating over all
active connections, performing
`select()`
syscall on all sockets
, and sleeping
active connections, performing
`select()`
syscall on all sockets
with a timeout
for
`milliseconds`
number of milliseconds. When
`select()`
returns, Mongoose
of
`milliseconds`
number of milliseconds. When
`select()`
returns, Mongoose
does an IO for each socket that has data to be sent or received. Application
does an IO for each socket that has data to be sent or received. Application
code must call
`mg_poll_server()`
in a loop. It is an error to have more then
code must call
`mg_poll_server()`
in a loop. It is an error to have more then
one thread calling
`mg_poll_server()`
,
`mg_set_option()`
or any other function
one thread calling
`mg_poll_server()`
,
`mg_set_option()`
or any other function
...
...
docs/Internals.md
View file @
04de3bb2
# Mongoose Internals
# Mongoose Internals
Mongoose has single-threaded, event-driven, asynchronous, non-blocking core.
Mongoose has single-threaded, event-driven, asynchronous, non-blocking core.
When mongoose server instance is created, it contains an information about
`mg_create_server()`
creates a web server instance. An instance is a container
the configuration and the state of each connection:
for the config options and list of active connections. To do the actual
serving, user must call
`mg_poll_server()`
, which iterates over all
active connections, performing
`select()`
syscall on all sockets with a
timeout of specified number of milliseconds. When
`select()`
returns, Mongoose
does an IO for each socket that has data to be sent or received. Application
code must call
`mg_poll_server()`
in a loop.
struct mg_server {
Mongoose server instance is designed to be used by a single thread.
sock_t listening_sock; // Listening socket
It is an error to have more then
union socket_address lsa; // Listening socket address
one thread calling
`mg_poll_server()`
,
`mg_set_option()`
or any other function
struct linked_list_link active_connections;
that take
`struct mg_server *`
parameter. Mongoose does not
struct linked_list_link uri_handlers;
mutex-protect
`struct mg_server *`
, therefore the best practice is
char *config_options[NUM_OPTIONS];
to call server management functions from the same thread (an IO thread).
...
};
A server instance is capable on listening on only one port. After creation,
a server instance has a list
It is an error to pass and store
`struct mg_connection *`
pointers for
of active connections, initially empty. It has a list of URI handlers,
later use to send data. The reason is that they can be invalidated by the
initially empty, and configuration parameters. Configuration can be
next
`mg_poll_server()`
call. For such a task,
altered by
`mg_set_option()`
, and new URI handlers could be added by
there is
`mg_iterate_over_connections()`
API
`mg_add_uri_handler()`
.
exists, which sends a callback function to the IO thread, then IO thread
calls specified function for all active connection.
When mongoose buffers in HTTP request and successfully parses it, it calls
appropriate URI handler immediately for GET requests. For POST requests,
Mongoose delays the call until the whole POST request is buffered in memory.
POST data is available to the callback as
`struct mg_connection::content`
,
and POST data length is in
`struct mg_connection::content_len`
.
Note that websocket connections are treated the same way. Mongoose buffers
websocket frame in memory, and calls URI handler when frame is fully
buffered. Frame data is available
`struct mg_connection::content`
, and
data length is in
`struct mg_connection::content_len`
, i.e. very similar to
the POST request.
`struct mg_connection::is_websocket`
flag indicates
whether the request is websocket or not. Also, for websocket requests,
there is
`struct mg_connection::wsbits`
field which contains first byte
of the websocket frame which URI handler can examine. Note that to
reply to the websocket client,
`mg_websocket_write()`
should be used.
To reply to the plain HTTP client,
`mg_write()`
should be used.
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