passenger 3.0.5 → 3.0.6

Sign up to get free protection for your applications and to get access to all the features.

Potentially problematic release.


This version of passenger might be problematic. Click here for more details.

Files changed (198) hide show
  1. data/NEWS +19 -1
  2. data/build/packaging.rb +0 -1
  3. data/doc/cxxapi/Constants_8h_source.html +1 -1
  4. data/doc/cxxapi/Logging_8h_source.html +3 -3
  5. data/doc/cxxapi/MessageChannel_8h_source.html +2 -2
  6. data/doc/cxxapi/Utils_8h_source.html +407 -397
  7. data/doc/cxxapi/namespacePassenger.html +32 -0
  8. data/doc/cxxapi/namespacemembers.html +56 -1
  9. data/doc/cxxapi/namespacemembers_func.html +3 -0
  10. data/doc/cxxapi/ngx__http__passenger__module_8h_source.html +5 -5
  11. data/ext/apache2/Hooks.cpp +1 -1
  12. data/ext/common/AgentBase.cpp +86 -11
  13. data/ext/common/Constants.h +1 -1
  14. data/ext/common/Logging.h +3 -3
  15. data/ext/common/LoggingAgent/FilterSupport.h +1 -0
  16. data/ext/common/LoggingAgent/Main.cpp +8 -1
  17. data/ext/common/MessageChannel.h +2 -2
  18. data/ext/common/Utils.cpp +27 -3
  19. data/ext/common/Utils.h +10 -0
  20. data/ext/common/Watchdog.cpp +27 -1
  21. data/ext/nginx/HelperAgent.cpp +8 -8
  22. data/ext/oxt/thread.hpp +2 -2
  23. data/lib/phusion_passenger.rb +1 -1
  24. data/lib/phusion_passenger/abstract_installer.rb +6 -0
  25. data/lib/phusion_passenger/abstract_request_handler.rb +13 -2
  26. data/lib/phusion_passenger/analytics_logger.rb +15 -4
  27. data/lib/phusion_passenger/dependencies.rb +11 -26
  28. data/lib/phusion_passenger/platform_info.rb +96 -5
  29. data/lib/phusion_passenger/platform_info/apache.rb +13 -3
  30. data/lib/phusion_passenger/platform_info/compiler.rb +5 -0
  31. data/lib/phusion_passenger/rack/application_spawner.rb +3 -2
  32. data/lib/phusion_passenger/standalone/runtime_installer.rb +0 -1
  33. data/lib/phusion_passenger/standalone/start_command.rb +15 -8
  34. data/lib/phusion_passenger/templates/standalone/config.erb +1 -0
  35. metadata +5 -182
  36. data/doc/rdoc/classes/ConditionVariable.html +0 -215
  37. data/doc/rdoc/classes/Exception.html +0 -120
  38. data/doc/rdoc/classes/GC.html +0 -113
  39. data/doc/rdoc/classes/IO.html +0 -221
  40. data/doc/rdoc/classes/PhusionPassenger.html +0 -397
  41. data/doc/rdoc/classes/PhusionPassenger/AbstractInstaller.html +0 -180
  42. data/doc/rdoc/classes/PhusionPassenger/AbstractRequestHandler.html +0 -647
  43. data/doc/rdoc/classes/PhusionPassenger/AbstractServer.html +0 -654
  44. data/doc/rdoc/classes/PhusionPassenger/AbstractServer/InvalidPassword.html +0 -92
  45. data/doc/rdoc/classes/PhusionPassenger/AbstractServer/ServerAlreadyStarted.html +0 -97
  46. data/doc/rdoc/classes/PhusionPassenger/AbstractServer/ServerError.html +0 -96
  47. data/doc/rdoc/classes/PhusionPassenger/AbstractServer/ServerNotStarted.html +0 -97
  48. data/doc/rdoc/classes/PhusionPassenger/AbstractServer/UnknownMessage.html +0 -96
  49. data/doc/rdoc/classes/PhusionPassenger/AbstractServerCollection.html +0 -619
  50. data/doc/rdoc/classes/PhusionPassenger/AdminTools.html +0 -142
  51. data/doc/rdoc/classes/PhusionPassenger/AdminTools/MemoryStats.html +0 -368
  52. data/doc/rdoc/classes/PhusionPassenger/AdminTools/MemoryStats/Process.html +0 -231
  53. data/doc/rdoc/classes/PhusionPassenger/AdminTools/ServerInstance.html +0 -588
  54. data/doc/rdoc/classes/PhusionPassenger/AdminTools/ServerInstance/CorruptedDirectoryError.html +0 -92
  55. data/doc/rdoc/classes/PhusionPassenger/AdminTools/ServerInstance/GenerationsAbsentError.html +0 -92
  56. data/doc/rdoc/classes/PhusionPassenger/AdminTools/ServerInstance/Group.html +0 -147
  57. data/doc/rdoc/classes/PhusionPassenger/AdminTools/ServerInstance/Process.html +0 -279
  58. data/doc/rdoc/classes/PhusionPassenger/AdminTools/ServerInstance/RoleDeniedError.html +0 -92
  59. data/doc/rdoc/classes/PhusionPassenger/AdminTools/ServerInstance/StaleDirectoryError.html +0 -92
  60. data/doc/rdoc/classes/PhusionPassenger/AdminTools/ServerInstance/Stats.html +0 -123
  61. data/doc/rdoc/classes/PhusionPassenger/AdminTools/ServerInstance/UnsupportedGenerationStructureVersionError.html +0 -92
  62. data/doc/rdoc/classes/PhusionPassenger/AnalyticsLogger.html +0 -368
  63. data/doc/rdoc/classes/PhusionPassenger/AnalyticsLogger/Lock.html +0 -194
  64. data/doc/rdoc/classes/PhusionPassenger/AnalyticsLogger/Log.html +0 -299
  65. data/doc/rdoc/classes/PhusionPassenger/AnalyticsLogger/SharedData.html +0 -206
  66. data/doc/rdoc/classes/PhusionPassenger/AppInitError.html +0 -155
  67. data/doc/rdoc/classes/PhusionPassenger/AppProcess.html +0 -367
  68. data/doc/rdoc/classes/PhusionPassenger/ClassicRails.html +0 -95
  69. data/doc/rdoc/classes/PhusionPassenger/ClassicRails/ApplicationSpawner.html +0 -351
  70. data/doc/rdoc/classes/PhusionPassenger/ClassicRails/ApplicationSpawner/Error.html +0 -98
  71. data/doc/rdoc/classes/PhusionPassenger/ClassicRails/CGIFixed.html +0 -200
  72. data/doc/rdoc/classes/PhusionPassenger/ClassicRails/FrameworkSpawner.html +0 -410
  73. data/doc/rdoc/classes/PhusionPassenger/ClassicRails/FrameworkSpawner/Error.html +0 -98
  74. data/doc/rdoc/classes/PhusionPassenger/ClassicRails/RequestHandler.html +0 -156
  75. data/doc/rdoc/classes/PhusionPassenger/ClassicRailsExtensions.html +0 -115
  76. data/doc/rdoc/classes/PhusionPassenger/ClassicRailsExtensions/AnalyticsLogging.html +0 -202
  77. data/doc/rdoc/classes/PhusionPassenger/ConsoleTextTemplate.html +0 -172
  78. data/doc/rdoc/classes/PhusionPassenger/DebugLogging.html +0 -273
  79. data/doc/rdoc/classes/PhusionPassenger/FrameworkInitError.html +0 -145
  80. data/doc/rdoc/classes/PhusionPassenger/HTMLTemplate.html +0 -162
  81. data/doc/rdoc/classes/PhusionPassenger/InitializationError.html +0 -141
  82. data/doc/rdoc/classes/PhusionPassenger/InvalidPath.html +0 -92
  83. data/doc/rdoc/classes/PhusionPassenger/MessageChannel.html +0 -673
  84. data/doc/rdoc/classes/PhusionPassenger/MessageChannel/InvalidHashError.html +0 -92
  85. data/doc/rdoc/classes/PhusionPassenger/MessageClient.html +0 -415
  86. data/doc/rdoc/classes/PhusionPassenger/NativeSupportLoader.html +0 -134
  87. data/doc/rdoc/classes/PhusionPassenger/Packaging.html +0 -129
  88. data/doc/rdoc/classes/PhusionPassenger/PlatformInfo.html +0 -1972
  89. data/doc/rdoc/classes/PhusionPassenger/Plugin.html +0 -237
  90. data/doc/rdoc/classes/PhusionPassenger/Rack.html +0 -91
  91. data/doc/rdoc/classes/PhusionPassenger/Rack/ApplicationSpawner.html +0 -312
  92. data/doc/rdoc/classes/PhusionPassenger/Rack/ApplicationSpawner/Error.html +0 -98
  93. data/doc/rdoc/classes/PhusionPassenger/Rack/RequestHandler.html +0 -218
  94. data/doc/rdoc/classes/PhusionPassenger/Rails3Extensions.html +0 -114
  95. data/doc/rdoc/classes/PhusionPassenger/Rails3Extensions/AnalyticsLogging.html +0 -259
  96. data/doc/rdoc/classes/PhusionPassenger/Rails3Extensions/AnalyticsLogging/ACExtension.html +0 -139
  97. data/doc/rdoc/classes/PhusionPassenger/Rails3Extensions/AnalyticsLogging/ASBenchmarkableExtension.html +0 -118
  98. data/doc/rdoc/classes/PhusionPassenger/Rails3Extensions/AnalyticsLogging/ExceptionLogger.html +0 -135
  99. data/doc/rdoc/classes/PhusionPassenger/SpawnManager.html +0 -378
  100. data/doc/rdoc/classes/PhusionPassenger/Standalone.html +0 -111
  101. data/doc/rdoc/classes/PhusionPassenger/Standalone/AppFinder.html +0 -252
  102. data/doc/rdoc/classes/PhusionPassenger/Standalone/Command.html +0 -161
  103. data/doc/rdoc/classes/PhusionPassenger/Standalone/ConfigFile.html +0 -368
  104. data/doc/rdoc/classes/PhusionPassenger/Standalone/ConfigFile/DisallowedContextError.html +0 -132
  105. data/doc/rdoc/classes/PhusionPassenger/Standalone/HelpCommand.html +0 -151
  106. data/doc/rdoc/classes/PhusionPassenger/Standalone/Main.html +0 -189
  107. data/doc/rdoc/classes/PhusionPassenger/Standalone/PackageRuntimeCommand.html +0 -177
  108. data/doc/rdoc/classes/PhusionPassenger/Standalone/RuntimeInstaller.html +0 -341
  109. data/doc/rdoc/classes/PhusionPassenger/Standalone/StartCommand.html +0 -203
  110. data/doc/rdoc/classes/PhusionPassenger/Standalone/StatusCommand.html +0 -156
  111. data/doc/rdoc/classes/PhusionPassenger/Standalone/StopCommand.html +0 -168
  112. data/doc/rdoc/classes/PhusionPassenger/Standalone/Utils.html +0 -86
  113. data/doc/rdoc/classes/PhusionPassenger/Standalone/VersionCommand.html +0 -135
  114. data/doc/rdoc/classes/PhusionPassenger/UnknownError.html +0 -125
  115. data/doc/rdoc/classes/PhusionPassenger/Utils.html +0 -1543
  116. data/doc/rdoc/classes/PhusionPassenger/Utils/FileSystemWatcher.html +0 -204
  117. data/doc/rdoc/classes/PhusionPassenger/Utils/FileSystemWatcher/DirInfo.html +0 -171
  118. data/doc/rdoc/classes/PhusionPassenger/Utils/FileSystemWatcher/FileInfo.html +0 -140
  119. data/doc/rdoc/classes/PhusionPassenger/Utils/HostsFileParser.html +0 -260
  120. data/doc/rdoc/classes/PhusionPassenger/Utils/PseudoIO.html +0 -194
  121. data/doc/rdoc/classes/PhusionPassenger/Utils/RewindableInput.html +0 -265
  122. data/doc/rdoc/classes/PhusionPassenger/Utils/RewindableInput/Tempfile.html +0 -120
  123. data/doc/rdoc/classes/PhusionPassenger/Utils/UnseekableSocket.html +0 -561
  124. data/doc/rdoc/classes/PhusionPassenger/VersionNotFound.html +0 -140
  125. data/doc/rdoc/classes/PhusionPassenger/WSGI.html +0 -89
  126. data/doc/rdoc/classes/PhusionPassenger/WSGI/ApplicationSpawner.html +0 -182
  127. data/doc/rdoc/classes/Process.html +0 -115
  128. data/doc/rdoc/classes/Signal.html +0 -139
  129. data/doc/rdoc/created.rid +0 -1
  130. data/doc/rdoc/files/DEVELOPERS_TXT.html +0 -280
  131. data/doc/rdoc/files/README.html +0 -157
  132. data/doc/rdoc/files/lib/phusion_passenger/abstract_installer_rb.html +0 -130
  133. data/doc/rdoc/files/lib/phusion_passenger/abstract_request_handler_rb.html +0 -135
  134. data/doc/rdoc/files/lib/phusion_passenger/abstract_server_collection_rb.html +0 -126
  135. data/doc/rdoc/files/lib/phusion_passenger/abstract_server_rb.html +0 -128
  136. data/doc/rdoc/files/lib/phusion_passenger/admin_tools/memory_stats_rb.html +0 -126
  137. data/doc/rdoc/files/lib/phusion_passenger/admin_tools/server_instance_rb.html +0 -132
  138. data/doc/rdoc/files/lib/phusion_passenger/admin_tools_rb.html +0 -122
  139. data/doc/rdoc/files/lib/phusion_passenger/analytics_logger_rb.html +0 -129
  140. data/doc/rdoc/files/lib/phusion_passenger/app_process_rb.html +0 -127
  141. data/doc/rdoc/files/lib/phusion_passenger/classic_rails/application_spawner_rb.html +0 -141
  142. data/doc/rdoc/files/lib/phusion_passenger/classic_rails/cgi_fixed_rb.html +0 -126
  143. data/doc/rdoc/files/lib/phusion_passenger/classic_rails/framework_spawner_rb.html +0 -146
  144. data/doc/rdoc/files/lib/phusion_passenger/classic_rails/request_handler_rb.html +0 -125
  145. data/doc/rdoc/files/lib/phusion_passenger/classic_rails_extensions/init_rb.html +0 -132
  146. data/doc/rdoc/files/lib/phusion_passenger/console_text_template_rb.html +0 -126
  147. data/doc/rdoc/files/lib/phusion_passenger/constants_rb.html +0 -122
  148. data/doc/rdoc/files/lib/phusion_passenger/debug_logging_rb.html +0 -122
  149. data/doc/rdoc/files/lib/phusion_passenger/dependencies_rb.html +0 -147
  150. data/doc/rdoc/files/lib/phusion_passenger/exceptions_rb.html +0 -122
  151. data/doc/rdoc/files/lib/phusion_passenger/html_template_rb.html +0 -127
  152. data/doc/rdoc/files/lib/phusion_passenger/message_channel_rb.html +0 -120
  153. data/doc/rdoc/files/lib/phusion_passenger/message_client_rb.html +0 -127
  154. data/doc/rdoc/files/lib/phusion_passenger/native_support_rb.html +0 -132
  155. data/doc/rdoc/files/lib/phusion_passenger/packaging_rb.html +0 -122
  156. data/doc/rdoc/files/lib/phusion_passenger/platform_info/apache_rb.html +0 -127
  157. data/doc/rdoc/files/lib/phusion_passenger/platform_info/binary_compatibility_rb.html +0 -129
  158. data/doc/rdoc/files/lib/phusion_passenger/platform_info/compiler_rb.html +0 -127
  159. data/doc/rdoc/files/lib/phusion_passenger/platform_info/curl_rb.html +0 -126
  160. data/doc/rdoc/files/lib/phusion_passenger/platform_info/documentation_tools_rb.html +0 -126
  161. data/doc/rdoc/files/lib/phusion_passenger/platform_info/linux_rb.html +0 -126
  162. data/doc/rdoc/files/lib/phusion_passenger/platform_info/operating_system_rb.html +0 -127
  163. data/doc/rdoc/files/lib/phusion_passenger/platform_info/ruby_rb.html +0 -128
  164. data/doc/rdoc/files/lib/phusion_passenger/platform_info/zlib_rb.html +0 -126
  165. data/doc/rdoc/files/lib/phusion_passenger/platform_info_rb.html +0 -122
  166. data/doc/rdoc/files/lib/phusion_passenger/plugin_rb.html +0 -127
  167. data/doc/rdoc/files/lib/phusion_passenger/public_api_rb.html +0 -127
  168. data/doc/rdoc/files/lib/phusion_passenger/rack/application_spawner_rb.html +0 -137
  169. data/doc/rdoc/files/lib/phusion_passenger/rack/request_handler_rb.html +0 -125
  170. data/doc/rdoc/files/lib/phusion_passenger/rails3_extensions/init_rb.html +0 -127
  171. data/doc/rdoc/files/lib/phusion_passenger/simple_benchmarking_rb.html +0 -122
  172. data/doc/rdoc/files/lib/phusion_passenger/spawn_manager_rb.html +0 -160
  173. data/doc/rdoc/files/lib/phusion_passenger/standalone/app_finder_rb.html +0 -127
  174. data/doc/rdoc/files/lib/phusion_passenger/standalone/command_rb.html +0 -136
  175. data/doc/rdoc/files/lib/phusion_passenger/standalone/config_file_rb.html +0 -126
  176. data/doc/rdoc/files/lib/phusion_passenger/standalone/help_command_rb.html +0 -126
  177. data/doc/rdoc/files/lib/phusion_passenger/standalone/main_rb.html +0 -126
  178. data/doc/rdoc/files/lib/phusion_passenger/standalone/package_runtime_command_rb.html +0 -127
  179. data/doc/rdoc/files/lib/phusion_passenger/standalone/runtime_installer_rb.html +0 -133
  180. data/doc/rdoc/files/lib/phusion_passenger/standalone/start_command_rb.html +0 -136
  181. data/doc/rdoc/files/lib/phusion_passenger/standalone/status_command_rb.html +0 -126
  182. data/doc/rdoc/files/lib/phusion_passenger/standalone/stop_command_rb.html +0 -126
  183. data/doc/rdoc/files/lib/phusion_passenger/standalone/utils_rb.html +0 -126
  184. data/doc/rdoc/files/lib/phusion_passenger/standalone/version_command_rb.html +0 -127
  185. data/doc/rdoc/files/lib/phusion_passenger/utils/file_system_watcher_rb.html +0 -126
  186. data/doc/rdoc/files/lib/phusion_passenger/utils/hosts_file_parser_rb.html +0 -120
  187. data/doc/rdoc/files/lib/phusion_passenger/utils/rewindable_input_rb.html +0 -100
  188. data/doc/rdoc/files/lib/phusion_passenger/utils/tmpdir_rb.html +0 -122
  189. data/doc/rdoc/files/lib/phusion_passenger/utils/unseekable_socket_rb.html +0 -126
  190. data/doc/rdoc/files/lib/phusion_passenger/utils_rb.html +0 -179
  191. data/doc/rdoc/files/lib/phusion_passenger/wsgi/application_spawner_rb.html +0 -132
  192. data/doc/rdoc/fr_class_index.html +0 -139
  193. data/doc/rdoc/fr_file_index.html +0 -108
  194. data/doc/rdoc/fr_method_index.html +0 -439
  195. data/doc/rdoc/index.html +0 -26
  196. data/doc/rdoc/rdoc-style.css +0 -187
  197. data/ext/common/libboost_oxt/aggregate.cpp +0 -10
  198. data/ext/common/libpassenger_common/aggregate.cpp +0 -16
@@ -1,139 +0,0 @@
1
- <?xml version="1.0" encoding="iso-8859-1"?>
2
- <!DOCTYPE html
3
- PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
4
- "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
5
- <html>
6
- <head>
7
- <title>Module: PhusionPassenger::Rails3Extensions::AnalyticsLogging::ACExtension</title>
8
- <meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1" />
9
- <link rel="stylesheet" href="../../../.././rdoc-style.css" type="text/css" media="screen" />
10
-
11
- <script language="JavaScript" type="text/javascript">
12
- // <![CDATA[
13
-
14
- function toggleSource( id )
15
- {
16
- var elem
17
- var link
18
-
19
- if( document.getElementById )
20
- {
21
- elem = document.getElementById( id )
22
- link = document.getElementById( "l_" + id )
23
- }
24
- else if ( document.all )
25
- {
26
- elem = eval( "document.all." + id )
27
- link = eval( "document.all.l_" + id )
28
- }
29
- else
30
- return false;
31
-
32
- if( elem.style.display == "block" )
33
- {
34
- elem.style.display = "none"
35
- link.innerHTML = "show source"
36
- }
37
- else
38
- {
39
- elem.style.display = "block"
40
- link.innerHTML = "hide source"
41
- }
42
- }
43
-
44
- function openCode( url )
45
- {
46
- window.open( url, "SOURCE_CODE", "resizable=yes,scrollbars=yes,toolbar=no,status=no,height=480,width=750" ).focus();
47
- }
48
- // ]]>
49
- </script>
50
- </head>
51
-
52
- <body>
53
- <table width="100%" border='0' cellpadding='0' cellspacing='0' class='banner'><tr>
54
- <td class="file-title"><span class="file-title-prefix">Module</span><br />PhusionPassenger::Rails3Extensions::AnalyticsLogging::ACExtension</td>
55
- <td align="right">
56
- <table cellspacing="0" cellpadding="2">
57
- <tr valign="top">
58
- <td>In:</td>
59
- <td>
60
- <a href="../../../../files/lib/phusion_passenger/rails3_extensions/init_rb.html">lib/phusion_passenger/rails3_extensions/init.rb</a>
61
- </td>
62
- </tr>
63
- </table>
64
- </td>
65
- </tr>
66
- </table>
67
- <!-- banner header -->
68
-
69
- <div id="bodyContent">
70
- <div id="content">
71
-
72
-
73
-
74
-
75
- <div class="sectiontitle">Methods</div>
76
- <ul>
77
- <li><a href="#M000178">process_action</a></li>
78
- <li><a href="#M000179">render</a></li>
79
- </ul>
80
-
81
-
82
-
83
-
84
-
85
-
86
- <div class="sectiontitle">Public Instance methods</div>
87
- <div class="method">
88
- <div class="title">
89
- <a name="M000178"></a><b>process_action</b>(action, *args)
90
- </div>
91
- <div class="sourcecode">
92
- <p class="source-link">[ <a href="javascript:toggleSource('M000178_source')" id="l_M000178_source">show source</a> ]</p>
93
- <div id="M000178_source" class="dyn-source">
94
- <pre>
95
- <span class="ruby-comment cmt"># File lib/phusion_passenger/rails3_extensions/init.rb, line 164</span>
96
- 164: <span class="ruby-keyword kw">def</span> <span class="ruby-identifier">process_action</span>(<span class="ruby-identifier">action</span>, <span class="ruby-operator">*</span><span class="ruby-identifier">args</span>)
97
- 165: <span class="ruby-identifier">log</span> = <span class="ruby-identifier">request</span>.<span class="ruby-identifier">env</span>[<span class="ruby-constant">PASSENGER_ANALYTICS_WEB_LOG</span>]
98
- 166: <span class="ruby-keyword kw">if</span> <span class="ruby-identifier">log</span>
99
- 167: <span class="ruby-identifier">log</span>.<span class="ruby-identifier">message</span>(<span class="ruby-node">&quot;Controller action: #{self.class.name}##{action_name}&quot;</span>)
100
- 168: <span class="ruby-identifier">log</span>.<span class="ruby-identifier">measure</span>(<span class="ruby-value str">&quot;framework request processing&quot;</span>) <span class="ruby-keyword kw">do</span>
101
- 169: <span class="ruby-keyword kw">super</span>
102
- 170: <span class="ruby-keyword kw">end</span>
103
- 171: <span class="ruby-keyword kw">else</span>
104
- 172: <span class="ruby-keyword kw">super</span>
105
- 173: <span class="ruby-keyword kw">end</span>
106
- 174: <span class="ruby-keyword kw">end</span>
107
- </pre>
108
- </div>
109
- </div>
110
- </div>
111
- <div class="method">
112
- <div class="title">
113
- <a name="M000179"></a><b>render</b>(*args)
114
- </div>
115
- <div class="sourcecode">
116
- <p class="source-link">[ <a href="javascript:toggleSource('M000179_source')" id="l_M000179_source">show source</a> ]</p>
117
- <div id="M000179_source" class="dyn-source">
118
- <pre>
119
- <span class="ruby-comment cmt"># File lib/phusion_passenger/rails3_extensions/init.rb, line 176</span>
120
- 176: <span class="ruby-keyword kw">def</span> <span class="ruby-identifier">render</span>(<span class="ruby-operator">*</span><span class="ruby-identifier">args</span>)
121
- 177: <span class="ruby-identifier">log</span> = <span class="ruby-identifier">request</span>.<span class="ruby-identifier">env</span>[<span class="ruby-constant">PASSENGER_ANALYTICS_WEB_LOG</span>]
122
- 178: <span class="ruby-keyword kw">if</span> <span class="ruby-identifier">log</span>
123
- 179: <span class="ruby-identifier">log</span>.<span class="ruby-identifier">measure</span>(<span class="ruby-value str">&quot;view rendering&quot;</span>) <span class="ruby-keyword kw">do</span>
124
- 180: <span class="ruby-keyword kw">super</span>
125
- 181: <span class="ruby-keyword kw">end</span>
126
- 182: <span class="ruby-keyword kw">else</span>
127
- 183: <span class="ruby-keyword kw">super</span>
128
- 184: <span class="ruby-keyword kw">end</span>
129
- 185: <span class="ruby-keyword kw">end</span>
130
- </pre>
131
- </div>
132
- </div>
133
- </div>
134
- </div>
135
-
136
- </div>
137
-
138
- </body>
139
- </html>
@@ -1,118 +0,0 @@
1
- <?xml version="1.0" encoding="iso-8859-1"?>
2
- <!DOCTYPE html
3
- PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
4
- "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
5
- <html>
6
- <head>
7
- <title>Module: PhusionPassenger::Rails3Extensions::AnalyticsLogging::ASBenchmarkableExtension</title>
8
- <meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1" />
9
- <link rel="stylesheet" href="../../../.././rdoc-style.css" type="text/css" media="screen" />
10
-
11
- <script language="JavaScript" type="text/javascript">
12
- // <![CDATA[
13
-
14
- function toggleSource( id )
15
- {
16
- var elem
17
- var link
18
-
19
- if( document.getElementById )
20
- {
21
- elem = document.getElementById( id )
22
- link = document.getElementById( "l_" + id )
23
- }
24
- else if ( document.all )
25
- {
26
- elem = eval( "document.all." + id )
27
- link = eval( "document.all.l_" + id )
28
- }
29
- else
30
- return false;
31
-
32
- if( elem.style.display == "block" )
33
- {
34
- elem.style.display = "none"
35
- link.innerHTML = "show source"
36
- }
37
- else
38
- {
39
- elem.style.display = "block"
40
- link.innerHTML = "hide source"
41
- }
42
- }
43
-
44
- function openCode( url )
45
- {
46
- window.open( url, "SOURCE_CODE", "resizable=yes,scrollbars=yes,toolbar=no,status=no,height=480,width=750" ).focus();
47
- }
48
- // ]]>
49
- </script>
50
- </head>
51
-
52
- <body>
53
- <table width="100%" border='0' cellpadding='0' cellspacing='0' class='banner'><tr>
54
- <td class="file-title"><span class="file-title-prefix">Module</span><br />PhusionPassenger::Rails3Extensions::AnalyticsLogging::ASBenchmarkableExtension</td>
55
- <td align="right">
56
- <table cellspacing="0" cellpadding="2">
57
- <tr valign="top">
58
- <td>In:</td>
59
- <td>
60
- <a href="../../../../files/lib/phusion_passenger/rails3_extensions/init_rb.html">lib/phusion_passenger/rails3_extensions/init.rb</a>
61
- </td>
62
- </tr>
63
- </table>
64
- </td>
65
- </tr>
66
- </table>
67
- <!-- banner header -->
68
-
69
- <div id="bodyContent">
70
- <div id="content">
71
-
72
-
73
-
74
-
75
- <div class="sectiontitle">Methods</div>
76
- <ul>
77
- <li><a href="#M000180">benchmark_with_passenger</a></li>
78
- </ul>
79
-
80
-
81
-
82
-
83
-
84
-
85
- <div class="sectiontitle">Public Instance methods</div>
86
- <div class="method">
87
- <div class="title">
88
- <a name="M000180"></a><b>benchmark_with_passenger</b>(message = &quot;Benchmarking&quot;, *args) {|| ...}
89
- </div>
90
- <div class="sourcecode">
91
- <p class="source-link">[ <a href="javascript:toggleSource('M000180_source')" id="l_M000180_source">show source</a> ]</p>
92
- <div id="M000180_source" class="dyn-source">
93
- <pre>
94
- <span class="ruby-comment cmt"># File lib/phusion_passenger/rails3_extensions/init.rb, line 189</span>
95
- 189: <span class="ruby-keyword kw">def</span> <span class="ruby-identifier">benchmark_with_passenger</span>(<span class="ruby-identifier">message</span> = <span class="ruby-value str">&quot;Benchmarking&quot;</span>, <span class="ruby-operator">*</span><span class="ruby-identifier">args</span>)
96
- 190: <span class="ruby-identifier">log</span> = <span class="ruby-constant">Thread</span>.<span class="ruby-identifier">current</span>[<span class="ruby-constant">PASSENGER_ANALYTICS_WEB_LOG</span>]
97
- 191: <span class="ruby-keyword kw">if</span> <span class="ruby-identifier">log</span>
98
- 192: <span class="ruby-identifier">log</span>.<span class="ruby-identifier">measure</span>(<span class="ruby-node">&quot;BENCHMARK: #{message}&quot;</span>) <span class="ruby-keyword kw">do</span>
99
- 193: <span class="ruby-identifier">benchmark_without_passenger</span>(<span class="ruby-identifier">message</span>, <span class="ruby-operator">*</span><span class="ruby-identifier">args</span>) <span class="ruby-keyword kw">do</span>
100
- 194: <span class="ruby-keyword kw">yield</span>
101
- 195: <span class="ruby-keyword kw">end</span>
102
- 196: <span class="ruby-keyword kw">end</span>
103
- 197: <span class="ruby-keyword kw">else</span>
104
- 198: <span class="ruby-identifier">benchmark_without_passenger</span>(<span class="ruby-identifier">message</span>, <span class="ruby-operator">*</span><span class="ruby-identifier">args</span>) <span class="ruby-keyword kw">do</span>
105
- 199: <span class="ruby-keyword kw">yield</span>
106
- 200: <span class="ruby-keyword kw">end</span>
107
- 201: <span class="ruby-keyword kw">end</span>
108
- 202: <span class="ruby-keyword kw">end</span>
109
- </pre>
110
- </div>
111
- </div>
112
- </div>
113
- </div>
114
-
115
- </div>
116
-
117
- </body>
118
- </html>
@@ -1,135 +0,0 @@
1
- <?xml version="1.0" encoding="iso-8859-1"?>
2
- <!DOCTYPE html
3
- PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
4
- "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
5
- <html>
6
- <head>
7
- <title>Class: PhusionPassenger::Rails3Extensions::AnalyticsLogging::ExceptionLogger</title>
8
- <meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1" />
9
- <link rel="stylesheet" href="../../../.././rdoc-style.css" type="text/css" media="screen" />
10
-
11
- <script language="JavaScript" type="text/javascript">
12
- // <![CDATA[
13
-
14
- function toggleSource( id )
15
- {
16
- var elem
17
- var link
18
-
19
- if( document.getElementById )
20
- {
21
- elem = document.getElementById( id )
22
- link = document.getElementById( "l_" + id )
23
- }
24
- else if ( document.all )
25
- {
26
- elem = eval( "document.all." + id )
27
- link = eval( "document.all.l_" + id )
28
- }
29
- else
30
- return false;
31
-
32
- if( elem.style.display == "block" )
33
- {
34
- elem.style.display = "none"
35
- link.innerHTML = "show source"
36
- }
37
- else
38
- {
39
- elem.style.display = "block"
40
- link.innerHTML = "hide source"
41
- }
42
- }
43
-
44
- function openCode( url )
45
- {
46
- window.open( url, "SOURCE_CODE", "resizable=yes,scrollbars=yes,toolbar=no,status=no,height=480,width=750" ).focus();
47
- }
48
- // ]]>
49
- </script>
50
- </head>
51
-
52
- <body>
53
- <table width="100%" border='0' cellpadding='0' cellspacing='0' class='banner'><tr>
54
- <td class="file-title"><span class="file-title-prefix">Class</span><br />PhusionPassenger::Rails3Extensions::AnalyticsLogging::ExceptionLogger</td>
55
- <td align="right">
56
- <table cellspacing="0" cellpadding="2">
57
- <tr valign="top">
58
- <td>In:</td>
59
- <td>
60
- <a href="../../../../files/lib/phusion_passenger/rails3_extensions/init_rb.html">lib/phusion_passenger/rails3_extensions/init.rb</a>
61
- </td>
62
- </tr>
63
- <tr>
64
- <td>Parent:</td>
65
- <td>
66
- Object
67
- </td>
68
- </tr>
69
- </table>
70
- </td>
71
- </tr>
72
- </table>
73
- <!-- banner header -->
74
-
75
- <div id="bodyContent">
76
- <div id="content">
77
-
78
-
79
-
80
-
81
- <div class="sectiontitle">Methods</div>
82
- <ul>
83
- <li><a href="#M000182">call</a></li>
84
- <li><a href="#M000181">new</a></li>
85
- </ul>
86
-
87
-
88
-
89
-
90
-
91
-
92
- <div class="sectiontitle">Public Class methods</div>
93
- <div class="method">
94
- <div class="title">
95
- <a name="M000181"></a><b>new</b>(app, analytics_logger)
96
- </div>
97
- <div class="sourcecode">
98
- <p class="source-link">[ <a href="javascript:toggleSource('M000181_source')" id="l_M000181_source">show source</a> ]</p>
99
- <div id="M000181_source" class="dyn-source">
100
- <pre>
101
- <span class="ruby-comment cmt"># File lib/phusion_passenger/rails3_extensions/init.rb, line 116</span>
102
- 116: <span class="ruby-keyword kw">def</span> <span class="ruby-identifier">initialize</span>(<span class="ruby-identifier">app</span>, <span class="ruby-identifier">analytics_logger</span>)
103
- 117: <span class="ruby-ivar">@app</span> = <span class="ruby-identifier">app</span>
104
- 118: <span class="ruby-ivar">@analytics_logger</span> = <span class="ruby-identifier">analytics_logger</span>
105
- 119: <span class="ruby-keyword kw">end</span>
106
- </pre>
107
- </div>
108
- </div>
109
- </div>
110
- <div class="sectiontitle">Public Instance methods</div>
111
- <div class="method">
112
- <div class="title">
113
- <a name="M000182"></a><b>call</b>(env)
114
- </div>
115
- <div class="sourcecode">
116
- <p class="source-link">[ <a href="javascript:toggleSource('M000182_source')" id="l_M000182_source">show source</a> ]</p>
117
- <div id="M000182_source" class="dyn-source">
118
- <pre>
119
- <span class="ruby-comment cmt"># File lib/phusion_passenger/rails3_extensions/init.rb, line 121</span>
120
- 121: <span class="ruby-keyword kw">def</span> <span class="ruby-identifier">call</span>(<span class="ruby-identifier">env</span>)
121
- 122: <span class="ruby-ivar">@app</span>.<span class="ruby-identifier">call</span>(<span class="ruby-identifier">env</span>)
122
- 123: <span class="ruby-keyword kw">rescue</span> <span class="ruby-constant">Exception</span> =<span class="ruby-operator">&gt;</span> <span class="ruby-identifier">e</span>
123
- 124: <span class="ruby-identifier">log_analytics_exception</span>(<span class="ruby-identifier">env</span>, <span class="ruby-identifier">e</span>) <span class="ruby-keyword kw">if</span> <span class="ruby-identifier">env</span>[<span class="ruby-constant">PASSENGER_TXN_ID</span>]
124
- 125: <span class="ruby-identifier">raise</span> <span class="ruby-identifier">e</span>
125
- 126: <span class="ruby-keyword kw">end</span>
126
- </pre>
127
- </div>
128
- </div>
129
- </div>
130
- </div>
131
-
132
- </div>
133
-
134
- </body>
135
- </html>
@@ -1,378 +0,0 @@
1
- <?xml version="1.0" encoding="iso-8859-1"?>
2
- <!DOCTYPE html
3
- PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
4
- "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
5
- <html>
6
- <head>
7
- <title>Class: PhusionPassenger::SpawnManager</title>
8
- <meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1" />
9
- <link rel="stylesheet" href="../.././rdoc-style.css" type="text/css" media="screen" />
10
-
11
- <script language="JavaScript" type="text/javascript">
12
- // <![CDATA[
13
-
14
- function toggleSource( id )
15
- {
16
- var elem
17
- var link
18
-
19
- if( document.getElementById )
20
- {
21
- elem = document.getElementById( id )
22
- link = document.getElementById( "l_" + id )
23
- }
24
- else if ( document.all )
25
- {
26
- elem = eval( "document.all." + id )
27
- link = eval( "document.all.l_" + id )
28
- }
29
- else
30
- return false;
31
-
32
- if( elem.style.display == "block" )
33
- {
34
- elem.style.display = "none"
35
- link.innerHTML = "show source"
36
- }
37
- else
38
- {
39
- elem.style.display = "block"
40
- link.innerHTML = "hide source"
41
- }
42
- }
43
-
44
- function openCode( url )
45
- {
46
- window.open( url, "SOURCE_CODE", "resizable=yes,scrollbars=yes,toolbar=no,status=no,height=480,width=750" ).focus();
47
- }
48
- // ]]>
49
- </script>
50
- </head>
51
-
52
- <body>
53
- <table width="100%" border='0' cellpadding='0' cellspacing='0' class='banner'><tr>
54
- <td class="file-title"><span class="file-title-prefix">Class</span><br />PhusionPassenger::SpawnManager</td>
55
- <td align="right">
56
- <table cellspacing="0" cellpadding="2">
57
- <tr valign="top">
58
- <td>In:</td>
59
- <td>
60
- <a href="../../files/lib/phusion_passenger/spawn_manager_rb.html">lib/phusion_passenger/spawn_manager.rb</a>
61
- </td>
62
- </tr>
63
- <tr>
64
- <td>Parent:</td>
65
- <td>
66
- <a href="AbstractServer.html">
67
- AbstractServer
68
- </a>
69
- </td>
70
- </tr>
71
- </table>
72
- </td>
73
- </tr>
74
- </table>
75
- <!-- banner header -->
76
-
77
- <div id="bodyContent">
78
- <div id="content">
79
-
80
- <div class="description"><p>
81
- The spawn manager is capable of spawning Ruby on Rails or <a
82
- href="Rack.html">Rack</a> application instances. It acts like a simple
83
- fascade for the rest of the spawn manager system.
84
- </p>
85
- <p>
86
- <b>Note</b>: <a href="SpawnManager.html">SpawnManager</a> may only be
87
- started synchronously with <a
88
- href="AbstractServer.html#M000335">AbstractServer#start_synchronously</a>.
89
- Starting asynchronously has not been tested. Don&#8216;t forget to call <a
90
- href="SpawnManager.html#M000374">cleanup</a> after the server&#8216;s main
91
- loop has finished.
92
- </p>
93
- <h2>Ruby on Rails optimizations</h2>
94
- <p>
95
- Spawning a Ruby on Rails application is usually slow. But <a
96
- href="SpawnManager.html">SpawnManager</a> will preload and cache Ruby on
97
- Rails frameworks, as well as application code, so subsequent spawns will be
98
- very fast.
99
- </p>
100
- <p>
101
- Internally, <a href="SpawnManager.html">SpawnManager</a> uses <a
102
- href="ClassicRails/FrameworkSpawner.html">ClassicRails::FrameworkSpawner</a>
103
- to preload and cache Ruby on Rails frameworks. <a
104
- href="ClassicRails/FrameworkSpawner.html">ClassicRails::FrameworkSpawner</a>,
105
- in turn, uses <a
106
- href="ClassicRails/ApplicationSpawner.html">ClassicRails::ApplicationSpawner</a>
107
- to preload and cache application code.
108
- </p>
109
- <p>
110
- In case you&#8216;re wondering why the namespace is &quot;<a
111
- href="ClassicRails.html">ClassicRails</a>&quot; and not &quot;Rails&quot;:
112
- it&#8216;s to work around an obscure bug in ActiveSupport&#8216;s
113
- Dispatcher.
114
- </p>
115
- </div>
116
-
117
-
118
-
119
- <div class="sectiontitle">Methods</div>
120
- <ul>
121
- <li><a href="#M000374">cleanup</a></li>
122
- <li><a href="#M000371">new</a></li>
123
- <li><a href="#M000373">reload</a></li>
124
- <li><a href="#M000372">spawn_application</a></li>
125
- </ul>
126
-
127
- <div class="sectiontitle">Included Modules</div>
128
- <ul>
129
- <li><a href="Utils.html">Utils</a></li>
130
- </ul>
131
-
132
-
133
-
134
-
135
-
136
- <div class="sectiontitle">Public Class methods</div>
137
- <div class="method">
138
- <div class="title">
139
- <a name="M000371"></a><b>new</b>(options = {})
140
- </div>
141
- <div class="sourcecode">
142
- <p class="source-link">[ <a href="javascript:toggleSource('M000371_source')" id="l_M000371_source">show source</a> ]</p>
143
- <div id="M000371_source" class="dyn-source">
144
- <pre>
145
- <span class="ruby-comment cmt"># File lib/phusion_passenger/spawn_manager.rb, line 62</span>
146
- 62: <span class="ruby-keyword kw">def</span> <span class="ruby-identifier">initialize</span>(<span class="ruby-identifier">options</span> = {})
147
- 63: <span class="ruby-keyword kw">super</span>(<span class="ruby-value str">&quot;&quot;</span>, <span class="ruby-value str">&quot;&quot;</span>)
148
- 64: <span class="ruby-ivar">@options</span> = <span class="ruby-identifier">options</span>
149
- 65: <span class="ruby-ivar">@spawners</span> = <span class="ruby-constant">AbstractServerCollection</span>.<span class="ruby-identifier">new</span>
150
- 66: <span class="ruby-identifier">define_message_handler</span>(<span class="ruby-identifier">:spawn_application</span>, <span class="ruby-identifier">:handle_spawn_application</span>)
151
- 67: <span class="ruby-identifier">define_message_handler</span>(<span class="ruby-identifier">:reload</span>, <span class="ruby-identifier">:handle_reload</span>)
152
- 68: <span class="ruby-identifier">define_signal_handler</span>(<span class="ruby-value str">'SIGHUP'</span>, <span class="ruby-identifier">:reload</span>)
153
- 69:
154
- 70: <span class="ruby-comment cmt"># Start garbage collector in order to free up some existing</span>
155
- 71: <span class="ruby-comment cmt"># heap slots. This prevents the heap from growing unnecessarily</span>
156
- 72: <span class="ruby-comment cmt"># during the startup phase.</span>
157
- 73: <span class="ruby-constant">GC</span>.<span class="ruby-identifier">start</span>
158
- 74: <span class="ruby-keyword kw">if</span> <span class="ruby-constant">GC</span>.<span class="ruby-identifier">copy_on_write_friendly?</span>
159
- 75: <span class="ruby-comment cmt"># Preload libraries for copy-on-write semantics.</span>
160
- 76: <span class="ruby-identifier">require</span> <span class="ruby-value str">'base64'</span>
161
- 77: <span class="ruby-identifier">require</span> <span class="ruby-value str">'phusion_passenger/app_process'</span>
162
- 78: <span class="ruby-identifier">require</span> <span class="ruby-value str">'phusion_passenger/classic_rails/framework_spawner'</span>
163
- 79: <span class="ruby-identifier">require</span> <span class="ruby-value str">'phusion_passenger/classic_rails/application_spawner'</span>
164
- 80: <span class="ruby-identifier">require</span> <span class="ruby-value str">'phusion_passenger/rack/application_spawner'</span>
165
- 81: <span class="ruby-identifier">require</span> <span class="ruby-value str">'phusion_passenger/html_template'</span>
166
- 82: <span class="ruby-identifier">require</span> <span class="ruby-value str">'phusion_passenger/platform_info'</span>
167
- 83: <span class="ruby-identifier">require</span> <span class="ruby-value str">'phusion_passenger/exceptions'</span>
168
- 84: <span class="ruby-keyword kw">end</span>
169
- 85: <span class="ruby-keyword kw">end</span>
170
- </pre>
171
- </div>
172
- </div>
173
- </div>
174
- <div class="sectiontitle">Public Instance methods</div>
175
- <div class="method">
176
- <div class="title">
177
- <a name="M000374"></a><b>cleanup</b>()
178
- </div>
179
- <div class="description">
180
- <p>
181
- Cleanup resources. Should be called when this <a
182
- href="SpawnManager.html">SpawnManager</a> is no longer needed.
183
- </p>
184
- </div>
185
- <div class="sourcecode">
186
- <p class="source-link">[ <a href="javascript:toggleSource('M000374_source')" id="l_M000374_source">show source</a> ]</p>
187
- <div id="M000374_source" class="dyn-source">
188
- <pre>
189
- <span class="ruby-comment cmt"># File lib/phusion_passenger/spawn_manager.rb, line 180</span>
190
- 180: <span class="ruby-keyword kw">def</span> <span class="ruby-identifier">cleanup</span>
191
- 181: <span class="ruby-ivar">@spawners</span>.<span class="ruby-identifier">cleanup</span>
192
- 182: <span class="ruby-keyword kw">end</span>
193
- </pre>
194
- </div>
195
- </div>
196
- </div>
197
- <div class="method">
198
- <div class="title">
199
- <a name="M000373"></a><b>reload</b>(app_group_name = nil)
200
- </div>
201
- <div class="description">
202
- <p>
203
- Remove the cached application instances at the given group name. If nil is
204
- specified as group name, then all cached application instances will be
205
- removed, no matter the group name.
206
- </p>
207
- <p>
208
- <b>Long description:</b> Application code might be cached in memory. But
209
- once it a while, it will be necessary to <a
210
- href="SpawnManager.html#M000373">reload</a> the code for an application,
211
- such as after deploying a <a href="SpawnManager.html#M000371">new</a>
212
- version of the application. This method makes sure that any cached
213
- application code is removed, so that the next time an application instance
214
- is spawned, the application code will be freshly loaded into memory.
215
- </p>
216
- <p>
217
- Raises AbstractServer::SpawnError if something went wrong.
218
- </p>
219
- </div>
220
- <div class="sourcecode">
221
- <p class="source-link">[ <a href="javascript:toggleSource('M000373_source')" id="l_M000373_source">show source</a> ]</p>
222
- <div id="M000373_source" class="dyn-source">
223
- <pre>
224
- <span class="ruby-comment cmt"># File lib/phusion_passenger/spawn_manager.rb, line 161</span>
225
- 161: <span class="ruby-keyword kw">def</span> <span class="ruby-identifier">reload</span>(<span class="ruby-identifier">app_group_name</span> = <span class="ruby-keyword kw">nil</span>)
226
- 162: <span class="ruby-ivar">@spawners</span>.<span class="ruby-identifier">synchronize</span> <span class="ruby-keyword kw">do</span>
227
- 163: <span class="ruby-keyword kw">if</span> <span class="ruby-identifier">app_group_name</span>
228
- 164: <span class="ruby-comment cmt"># Stop and delete associated ApplicationSpawner.</span>
229
- 165: <span class="ruby-ivar">@spawners</span>.<span class="ruby-identifier">delete</span>(<span class="ruby-node">&quot;app:#{app_group_name}&quot;</span>)
230
- 166: <span class="ruby-comment cmt"># Propagate reload command to associated FrameworkSpawner.</span>
231
- 167: <span class="ruby-ivar">@spawners</span>.<span class="ruby-identifier">each</span> <span class="ruby-keyword kw">do</span> <span class="ruby-operator">|</span><span class="ruby-identifier">spawner</span><span class="ruby-operator">|</span>
232
- 168: <span class="ruby-keyword kw">if</span> <span class="ruby-identifier">spawner</span>.<span class="ruby-identifier">respond_to?</span>(<span class="ruby-identifier">:reload</span>)
233
- 169: <span class="ruby-identifier">spawner</span>.<span class="ruby-identifier">reload</span>(<span class="ruby-identifier">app_group_name</span>)
234
- 170: <span class="ruby-keyword kw">end</span>
235
- 171: <span class="ruby-keyword kw">end</span>
236
- 172: <span class="ruby-keyword kw">else</span>
237
- 173: <span class="ruby-comment cmt"># Stop and delete all spawners.</span>
238
- 174: <span class="ruby-ivar">@spawners</span>.<span class="ruby-identifier">clear</span>
239
- 175: <span class="ruby-keyword kw">end</span>
240
- 176: <span class="ruby-keyword kw">end</span>
241
- 177: <span class="ruby-keyword kw">end</span>
242
- </pre>
243
- </div>
244
- </div>
245
- </div>
246
- <div class="method">
247
- <div class="title">
248
- <a name="M000372"></a><b>spawn_application</b>(options)
249
- </div>
250
- <div class="description">
251
- <p>
252
- Spawns an application with the given spawn options. When successful, an <a
253
- href="AppProcess.html">AppProcess</a> object will be returned, which
254
- represents the spawned application process.
255
- </p>
256
- <p>
257
- Most options are explained in PoolOptions.h.
258
- </p>
259
- <p>
260
- Mandatory options:
261
- </p>
262
- <ul>
263
- <li>&#8216;app_root&#8216;
264
-
265
- </li>
266
- </ul>
267
- <p>
268
- Optional options:
269
- </p>
270
- <ul>
271
- <li>&#8216;app_type&#8216;
272
-
273
- </li>
274
- <li>&#8216;environment&#8216;
275
-
276
- </li>
277
- <li>&#8216;spawn_method&#8216;
278
-
279
- </li>
280
- <li>&#8216;user&#8217;,
281
-
282
- </li>
283
- <li>&#8216;group&#8216;
284
-
285
- </li>
286
- <li>&#8216;default_user&#8216;
287
-
288
- </li>
289
- <li>&#8216;default_group&#8216;
290
-
291
- </li>
292
- <li>&#8216;framework_spawner_timeout&#8216;
293
-
294
- </li>
295
- <li>&#8216;app_spawner_timeout&#8216;
296
-
297
- </li>
298
- <li>&#8216;environment_variables&#8217;: Environment variables which should be
299
- passed to the spawned application process. This is NULL-seperated string of
300
- key-value pairs, encoded in base64. The last byte in the unencoded data
301
- must be a NULL.
302
-
303
- </li>
304
- <li>&#8216;base_uri&#8216;
305
-
306
- </li>
307
- <li>&#8216;print_exceptions&#8216;
308
-
309
- </li>
310
- </ul>
311
- <p>
312
- <b>Exceptions:</b>
313
- </p>
314
- <ul>
315
- <li><a href="InvalidPath.html">InvalidPath</a>: <tt>app_root</tt> doesn&#8216;t
316
- appear to be a valid Ruby on Rails application root.
317
-
318
- </li>
319
- <li><a href="VersionNotFound.html">VersionNotFound</a>: The Ruby on Rails
320
- framework version that the given application requires is not installed.
321
-
322
- </li>
323
- <li><a href="AbstractServer/ServerError.html">AbstractServer::ServerError</a>:
324
- One of the server processes exited unexpectedly.
325
-
326
- </li>
327
- <li><a href="FrameworkInitError.html">FrameworkInitError</a>: The Ruby on Rails
328
- framework that the application requires could not be loaded.
329
-
330
- </li>
331
- <li><a href="AppInitError.html">AppInitError</a>: The application raised an
332
- exception or called exit() during startup.
333
-
334
- </li>
335
- </ul>
336
- </div>
337
- <div class="sourcecode">
338
- <p class="source-link">[ <a href="javascript:toggleSource('M000372_source')" id="l_M000372_source">show source</a> ]</p>
339
- <div id="M000372_source" class="dyn-source">
340
- <pre>
341
- <span class="ruby-comment cmt"># File lib/phusion_passenger/spawn_manager.rb, line 120</span>
342
- 120: <span class="ruby-keyword kw">def</span> <span class="ruby-identifier">spawn_application</span>(<span class="ruby-identifier">options</span>)
343
- 121: <span class="ruby-keyword kw">if</span> <span class="ruby-operator">!</span><span class="ruby-identifier">options</span>[<span class="ruby-value str">&quot;app_root&quot;</span>]
344
- 122: <span class="ruby-identifier">raise</span> <span class="ruby-constant">ArgumentError</span>, <span class="ruby-value str">&quot;The 'app_root' option must be given.&quot;</span>
345
- 123: <span class="ruby-keyword kw">end</span>
346
- 124: <span class="ruby-identifier">options</span> = <span class="ruby-identifier">sanitize_spawn_options</span>(<span class="ruby-identifier">options</span>)
347
- 125:
348
- 126: <span class="ruby-keyword kw">case</span> <span class="ruby-identifier">options</span>[<span class="ruby-value str">&quot;app_type&quot;</span>]
349
- 127: <span class="ruby-keyword kw">when</span> <span class="ruby-value str">&quot;rails&quot;</span>
350
- 128: <span class="ruby-keyword kw">if</span> <span class="ruby-operator">!</span><span class="ruby-keyword kw">defined?</span>(<span class="ruby-constant">ClassicRails</span><span class="ruby-operator">::</span><span class="ruby-constant">FrameworkSpawner</span>)
351
- 129: <span class="ruby-identifier">require</span> <span class="ruby-value str">'phusion_passenger/classic_rails/framework_spawner'</span>
352
- 130: <span class="ruby-identifier">require</span> <span class="ruby-value str">'phusion_passenger/classic_rails/application_spawner'</span>
353
- 131: <span class="ruby-keyword kw">end</span>
354
- 132: <span class="ruby-keyword kw">return</span> <span class="ruby-identifier">spawn_rails_application</span>(<span class="ruby-identifier">options</span>)
355
- 133: <span class="ruby-keyword kw">when</span> <span class="ruby-value str">&quot;rack&quot;</span>
356
- 134: <span class="ruby-keyword kw">if</span> <span class="ruby-operator">!</span><span class="ruby-keyword kw">defined?</span>(<span class="ruby-constant">Rack</span><span class="ruby-operator">::</span><span class="ruby-constant">ApplicationSpawner</span>)
357
- 135: <span class="ruby-identifier">require</span> <span class="ruby-value str">'phusion_passenger/rack/application_spawner'</span>
358
- 136: <span class="ruby-keyword kw">end</span>
359
- 137: <span class="ruby-keyword kw">return</span> <span class="ruby-identifier">spawn_rack_application</span>(<span class="ruby-identifier">options</span>)
360
- 138: <span class="ruby-keyword kw">when</span> <span class="ruby-value str">&quot;wsgi&quot;</span>
361
- 139: <span class="ruby-keyword kw">if</span> <span class="ruby-operator">!</span><span class="ruby-keyword kw">defined?</span>(<span class="ruby-constant">WSGI</span><span class="ruby-operator">::</span><span class="ruby-constant">ApplicationSpawner</span>)
362
- 140: <span class="ruby-identifier">require</span> <span class="ruby-value str">'phusion_passenger/wsgi/application_spawner'</span>
363
- 141: <span class="ruby-keyword kw">end</span>
364
- 142: <span class="ruby-keyword kw">return</span> <span class="ruby-constant">WSGI</span><span class="ruby-operator">::</span><span class="ruby-constant">ApplicationSpawner</span>.<span class="ruby-identifier">spawn_application</span>(<span class="ruby-identifier">options</span>)
365
- 143: <span class="ruby-keyword kw">else</span>
366
- 144: <span class="ruby-identifier">raise</span> <span class="ruby-constant">ArgumentError</span>, <span class="ruby-node">&quot;Unknown 'app_type' value '#{options[&quot;app_type&quot;]}'.&quot;</span>
367
- 145: <span class="ruby-keyword kw">end</span>
368
- 146: <span class="ruby-keyword kw">end</span>
369
- </pre>
370
- </div>
371
- </div>
372
- </div>
373
- </div>
374
-
375
- </div>
376
-
377
- </body>
378
- </html>