Updated rst docs to include threading model.
Change-Id: Id12cd6584dfd22fe32097cfddf0247c0cc115ac0
This commit is contained in:
		@@ -35,6 +35,7 @@ Background Concepts for Nova
 | 
			
		||||
.. toctree::
 | 
			
		||||
   :maxdepth: 3
 | 
			
		||||
 | 
			
		||||
   threading
 | 
			
		||||
   distributed_scheduler
 | 
			
		||||
   multinic
 | 
			
		||||
   zone
 | 
			
		||||
 
 | 
			
		||||
							
								
								
									
										17
									
								
								doc/source/devref/threading.rst
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										17
									
								
								doc/source/devref/threading.rst
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,17 @@
 | 
			
		||||
Threading model
 | 
			
		||||
===============
 | 
			
		||||
 | 
			
		||||
All OpenStack services use *green thread* model of threading, implemented 
 | 
			
		||||
through using the Python `eventlet <http://eventlet.net/>`_ and 
 | 
			
		||||
`greenlet <http://packages.python.org/greenlet/>`_ libraries.
 | 
			
		||||
 | 
			
		||||
Green threads use a cooperative model of threading: thread context 
 | 
			
		||||
switches can only occur when specific eventlet or greenlet library calls are 
 | 
			
		||||
made (e.g., sleep, certain I/O calls). From the operating system's point of 
 | 
			
		||||
view, each OpenStack service runs in a single thread. 
 | 
			
		||||
 | 
			
		||||
The use of green threads reduces the likelihood of race conditions, but does
 | 
			
		||||
not completely eliminate them. In some cases, you may need to use the 
 | 
			
		||||
``@utils.synchronized(...)`` decorator to avoid races.
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
		Reference in New Issue
	
	Block a user