These are leftover from opendev migration and without this fix the links results into Not Found. Mainly need to use "src" in place of "tree" to get these links working with opendev.org. Also used git tags where line references are used as branched references do not persist. And for line references use #L in place of #n as that's where it get's redirected. Also update references for zuul and use of devstack-vm-gate-wrap.sh in neutron functional jobs. Change-Id: I92d11c99a17dab80d4b91da49f341f9ba202bcfe
2.9 KiB
Neutron WSGI/HTTP API layer
This section will cover the internals of Neutron's HTTP API, and the classes in Neutron that can be used to create Extensions to the Neutron API.
Python web applications interface with webservers through the Python Web Server Gateway Interface (WSGI) - defined in PEP 333
Startup
Neutron's WSGI server is started from the server module and the entry point serve_wsgi is called to build an instance of the NeutronApiService, which is then returned to the server module, which spawns a Eventlet GreenPool that will run the WSGI application and respond to requests from clients.
WSGI Application
During the building of the NeutronApiService, the _run_wsgi function creates a WSGI application using the load_paste_app function inside config.py - which parses api-paste.ini - in order to create a WSGI app using Paste's deploy.
The api-paste.ini file defines the WSGI applications and routes - using the Paste INI file format.
The INI file directs paste to instantiate the APIRouter class of Neutron, which contains several methods that map Neutron resources (such as Ports, Networks, Subnets) to URLs, and the controller for each resource.