passenger 4.0.5 → 4.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.
- data.tar.gz.asc +7 -7
- data/.travis.yml +1 -2
- data/CONTRIBUTING.md +20 -5
- data/CONTRIBUTORS +67 -0
- data/LICENSE +1 -1
- data/NEWS +48 -0
- data/Rakefile +2 -2
- data/bin/passenger-config +18 -0
- data/bin/passenger-install-apache2-module +2 -0
- data/bin/passenger-install-nginx-module +11 -12
- data/bin/passenger-memory-stats +2 -0
- data/bin/passenger-status +152 -69
- data/build/agents.rb +1 -5
- data/build/basics.rb +26 -13
- data/build/cplusplus_support.rb +9 -0
- data/build/debian.rb +129 -0
- data/build/documentation.rb +6 -2
- data/build/integration_tests.rb +13 -2
- data/build/misc.rb +16 -0
- data/build/packaging.rb +67 -51
- data/build/preprocessor.rb +314 -0
- data/build/test_basics.rb +1 -0
- data/{debian → debian.template}/README.Debian +0 -0
- data/{debian → debian.template}/changelog +131 -0
- data/debian.template/compat +1 -0
- data/debian.template/control +71 -0
- data/debian.template/copyright +385 -0
- data/debian.template/libapache2-mod-passenger.install +3 -0
- data/{debian → debian.template}/libapache2-mod-passenger.postinst +0 -0
- data/{debian → debian.template}/libapache2-mod-passenger.prerm +0 -0
- data/debian.template/locations.ini +12 -0
- data/debian.template/passenger.conf +4 -0
- data/{debian → debian.template}/passenger.load +0 -0
- data/debian.template/patches/series +0 -0
- data/debian.template/repack.sh +42 -0
- data/debian.template/ruby-passenger-dev.install +3 -0
- data/debian.template/ruby-passenger-doc.install +2 -0
- data/debian.template/ruby-passenger.docs +4 -0
- data/debian.template/ruby-passenger.install +11 -0
- data/debian.template/ruby-passenger.manpages +4 -0
- data/debian.template/rules.template +35 -0
- data/debian.template/source/format +1 -0
- data/debian.template/watch +3 -0
- data/dev/run_travis.sh +46 -46
- data/doc/Architectural overview.html +2 -2
- data/doc/Packaging.html +27 -18
- data/doc/Packaging.txt.md +27 -18
- data/doc/Security of user switching support.html +2 -2
- data/doc/Users guide Apache.html +881 -95
- data/doc/Users guide Apache.idmap.txt +48 -6
- data/doc/Users guide Apache.txt +13 -1
- data/doc/Users guide Nginx.html +1063 -190
- data/doc/Users guide Nginx.idmap.txt +89 -45
- data/doc/Users guide Nginx.txt +45 -0
- data/doc/Users guide Standalone.html +7 -7
- data/doc/users_guide_snippets/alternative_for_flying_passenger.txt +1 -0
- data/doc/users_guide_snippets/environment_variables.txt +221 -0
- data/doc/users_guide_snippets/installation.txt +66 -17
- data/doc/users_guide_snippets/support_information.txt +3 -3
- data/doc/users_guide_snippets/tips.txt +352 -40
- data/ext/common/Account.h +4 -3
- data/ext/common/AccountsDatabase.h +6 -6
- data/ext/common/AgentsStarter.h +1 -13
- data/ext/common/ApplicationPool2/DirectSpawner.h +4 -4
- data/ext/common/ApplicationPool2/DummySpawner.h +1 -1
- data/ext/common/ApplicationPool2/Group.h +9 -4
- data/ext/common/ApplicationPool2/Implementation.cpp +6 -1
- data/ext/common/ApplicationPool2/Options.h +65 -37
- data/ext/common/ApplicationPool2/Pool.h +91 -41
- data/ext/common/ApplicationPool2/Process.h +6 -6
- data/ext/common/ApplicationPool2/SmartSpawner.h +14 -14
- data/ext/common/ApplicationPool2/Socket.h +1 -1
- data/ext/common/ApplicationPool2/Spawner.h +24 -16
- data/ext/common/ApplicationPool2/SpawnerFactory.h +9 -1
- data/ext/common/ApplicationPool2/SuperGroup.h +1 -1
- data/ext/common/Constants.h +1 -1
- data/ext/common/Logging.cpp +12 -7
- data/ext/common/MessageServer.h +7 -12
- data/ext/common/MultiLibeio.cpp +5 -5
- data/ext/common/ResourceLocator.h +2 -6
- data/ext/common/ServerInstanceDir.h +37 -10
- data/ext/common/UnionStation.h +10 -10
- data/ext/common/Utils.cpp +30 -4
- data/ext/common/Utils.h +7 -0
- data/ext/common/Utils/BlockingQueue.h +2 -2
- data/ext/common/Utils/Lock.h +2 -2
- data/ext/common/Utils/MessagePassing.h +2 -2
- data/ext/common/Utils/Timer.h +4 -4
- data/ext/common/agents/HelperAgent/AgentOptions.h +2 -0
- data/ext/common/agents/HelperAgent/Main.cpp +57 -16
- data/ext/common/agents/HelperAgent/RequestHandler.h +4 -1
- data/ext/common/agents/LoggingAgent/AdminController.h +91 -0
- data/ext/common/agents/LoggingAgent/LoggingServer.h +46 -29
- data/ext/common/agents/LoggingAgent/Main.cpp +43 -16
- data/ext/common/agents/LoggingAgent/RemoteSender.h +7 -7
- data/ext/common/agents/Watchdog/AgentWatcher.cpp +11 -11
- data/ext/common/agents/Watchdog/LoggingAgentWatcher.cpp +3 -1
- data/ext/common/agents/Watchdog/Main.cpp +62 -0
- data/ext/libeio/config.guess +206 -167
- data/ext/libeio/config.sub +142 -68
- data/ext/libev/config.guess +304 -290
- data/ext/libev/config.sub +198 -77
- data/ext/nginx/config +4 -0
- data/ext/nginx/ngx_http_passenger_module.c +1 -0
- data/ext/oxt/implementation.cpp +4 -4
- data/lib/phusion_passenger.rb +14 -5
- data/lib/phusion_passenger/abstract_installer.rb +41 -0
- data/lib/phusion_passenger/admin_tools/server_instance.rb +48 -39
- data/lib/phusion_passenger/message_client.rb +31 -7
- data/lib/phusion_passenger/native_support.rb +35 -12
- data/lib/phusion_passenger/packaging.rb +16 -2
- data/lib/phusion_passenger/platform_info/binary_compatibility.rb +6 -31
- data/lib/phusion_passenger/platform_info/operating_system.rb +1 -1
- data/lib/phusion_passenger/preloader_shared_helpers.rb +3 -1
- data/lib/phusion_passenger/request_handler.rb +1 -1
- data/lib/phusion_passenger/standalone/command.rb +6 -6
- data/lib/phusion_passenger/standalone/main.rb +23 -8
- data/lib/phusion_passenger/standalone/package_runtime_command.rb +9 -5
- data/lib/phusion_passenger/standalone/runtime_installer.rb +9 -10
- data/lib/phusion_passenger/standalone/start_command.rb +20 -4
- data/resources/templates/installer_common/freebsd9_broken_cxx_runtime.txt.erb +19 -0
- data/resources/templates/installer_common/low_amount_of_memory_warning.txt.erb +22 -0
- data/resources/templates/standalone/config.erb +3 -2
- data/test/cxx/ApplicationPool2/DirectSpawnerTest.cpp +4 -4
- data/test/cxx/ApplicationPool2/PoolTest.cpp +1 -1
- data/test/cxx/ApplicationPool2/SmartSpawnerTest.cpp +7 -7
- data/test/cxx/ApplicationPool2/SpawnerTestCases.cpp +9 -9
- data/test/cxx/EventedBufferedInputTest.cpp +17 -17
- data/test/cxx/RequestHandlerTest.cpp +5 -5
- data/test/cxx/ServerInstanceDirTest.cpp +3 -1
- data/test/cxx/TestSupport.h +4 -4
- data/test/cxx/UnionStationTest.cpp +3 -1
- data/test/cxx/UtilsTest.cpp +2 -0
- data/test/integration_tests/apache2_tests.rb +2 -2
- data/test/integration_tests/native_packaging_spec.rb +170 -0
- data/test/ruby/spec_helper.rb +0 -1
- data/test/stub/apache2/httpd.conf.erb +1 -1
- data/test/stub/nginx/nginx.conf.erb +1 -0
- data/test/support/apache2_controller.rb +1 -1
- data/test/support/placebo-preloader.rb +1 -1
- data/test/support/test_helper.rb +5 -2
- metadata +32 -26
- metadata.gz.asc +7 -7
- data/debian/compat +0 -1
- data/debian/control +0 -49
- data/debian/copyright +0 -20
- data/debian/libapache2-mod-passenger.install +0 -1
- data/debian/passenger-common.install +0 -4
- data/debian/passenger.conf +0 -4
- data/debian/prerm +0 -2
- data/debian/rules +0 -37
- data/debian/watch +0 -3
- data/dev/googlecode_upload.py +0 -265
- data/ext/common/agents/HelperAgent/BacktracesServer.h +0 -60
- data/resources/templates/nginx/not_available_when_natively_packaged.txt.erb +0 -8
- data/test/stub/rails3.1/app/assets/javascripts/application.js +0 -9
- data/test/stub/rails3.2/app/assets/javascripts/application.js +0 -15
- data/test/stub/rails_apps/2.3/mycook/public/javascripts/application.js +0 -2
- data/test/stub/rails_apps/2.3/mycook/public/javascripts/controls.js +0 -963
- data/test/stub/rails_apps/2.3/mycook/public/javascripts/dragdrop.js +0 -973
- data/test/stub/rails_apps/2.3/mycook/public/javascripts/effects.js +0 -1128
- data/test/stub/rails_apps/2.3/mycook/public/javascripts/prototype.js +0 -4320
File without changes
|
File without changes
|
@@ -0,0 +1,12 @@
|
|
1
|
+
[locations]
|
2
|
+
natively_packaged=true
|
3
|
+
bin=/usr/bin
|
4
|
+
agents=/usr/lib/passenger/agents
|
5
|
+
libdir=/usr/lib/passenger
|
6
|
+
helper_scripts=/usr/share/passenger/helper-scripts
|
7
|
+
resources=/usr/share/passenger
|
8
|
+
includedir=/usr/share/passenger/include
|
9
|
+
doc=/usr/share/doc/ruby-passenger
|
10
|
+
rubylibdir=/usr/lib/ruby/vendor_ruby
|
11
|
+
apache2_module=/usr/lib/apache2/modules/mod_passenger.so
|
12
|
+
ruby_extension_source=/usr/share/passenger/ruby_extension_source
|
File without changes
|
File without changes
|
@@ -0,0 +1,42 @@
|
|
1
|
+
#!/bin/sh
|
2
|
+
# Repackage upstream source to exclude non-distributable files
|
3
|
+
# should be called as "repack.sh --upstream-source <ver> <downloaded file>
|
4
|
+
# (for example, via uscan)
|
5
|
+
|
6
|
+
set -e
|
7
|
+
set -u
|
8
|
+
|
9
|
+
VER="$2debian"
|
10
|
+
FILE="$3"
|
11
|
+
PKG=`dpkg-parsechangelog|grep ^Source:|sed 's/^Source: //'`
|
12
|
+
|
13
|
+
REPACK_DIR="$PKG-$VER.orig" # DevRef § 6.7.8.2
|
14
|
+
|
15
|
+
echo -e "\nRepackaging $FILE\n"
|
16
|
+
|
17
|
+
DIR=`mktemp -d ./tmpRepackXXXXXX`
|
18
|
+
trap "rm -rf \"$DIR\"" QUIT INT EXIT
|
19
|
+
|
20
|
+
# Create an extra directory to cope with rootless tarballs
|
21
|
+
UP_BASE="$DIR/unpack"
|
22
|
+
mkdir "$UP_BASE"
|
23
|
+
tar xzf "$FILE" -C "$UP_BASE"
|
24
|
+
|
25
|
+
if [ `ls -1 "$UP_BASE" | wc -l` -eq 1 ]; then
|
26
|
+
# Tarball does contain a root directory
|
27
|
+
UP_BASE="$UP_BASE/`ls -1 "$UP_BASE"`"
|
28
|
+
fi
|
29
|
+
|
30
|
+
## Remove stuff
|
31
|
+
rm -vfr $UP_BASE/test/support/valgrind.h
|
32
|
+
rm -vfr $UP_BASE/debian
|
33
|
+
|
34
|
+
mv "$UP_BASE" "$DIR/$REPACK_DIR"
|
35
|
+
|
36
|
+
# Using a pipe hides tar errors!
|
37
|
+
tar cfC "$DIR/repacked.tar" "$DIR" "$REPACK_DIR"
|
38
|
+
gzip -9 < "$DIR/repacked.tar" > "$DIR/repacked.tar.gz"
|
39
|
+
FILE="../${PKG}_${VER}.orig.tar.gz"
|
40
|
+
mv "$DIR/repacked.tar.gz" "$FILE"
|
41
|
+
|
42
|
+
echo "*** $FILE repackaged"
|
@@ -0,0 +1,11 @@
|
|
1
|
+
usr/lib/passenger/agents/
|
2
|
+
usr/share/passenger/helper-scripts/
|
3
|
+
usr/share/passenger/templates/
|
4
|
+
usr/share/passenger/standalone_default_root/
|
5
|
+
usr/share/passenger/ruby_extension_source/
|
6
|
+
usr/share/passenger/*.types
|
7
|
+
usr/share/passenger/*.crt
|
8
|
+
usr/lib/ruby/
|
9
|
+
debian/locations.ini usr/lib/ruby/vendor_ruby/phusion_passenger/
|
10
|
+
usr/sbin/
|
11
|
+
usr/bin/
|
@@ -0,0 +1,35 @@
|
|
1
|
+
#!/usr/bin/make -f
|
2
|
+
# export DH_VERBOSE=1
|
3
|
+
|
4
|
+
export USE_VENDORED_LIBEV=false
|
5
|
+
|
6
|
+
#if ['1', 'true', 'on', 'yes'].include?(ENV['USE_CCACHE'])
|
7
|
+
export USE_CCACHE=1
|
8
|
+
#endif
|
9
|
+
|
10
|
+
%:
|
11
|
+
dh $@
|
12
|
+
|
13
|
+
override_dh_auto_configure:
|
14
|
+
# Do nothing
|
15
|
+
|
16
|
+
override_dh_auto_build:
|
17
|
+
/usr/bin/ruby1.8 /usr/bin/rake fakeroot
|
18
|
+
mv pkg/fakeroot pkg/fakeroot1.8
|
19
|
+
/usr/bin/ruby1.9.1 /usr/bin/rake fakeroot
|
20
|
+
mv pkg/fakeroot pkg/fakeroot1.9.1
|
21
|
+
|
22
|
+
override_dh_auto_install:
|
23
|
+
mkdir debian/tmp/
|
24
|
+
# Merge Ruby 1.8 and 1.9 files into a single directory.
|
25
|
+
cp -a pkg/fakeroot1.8/* debian/tmp/
|
26
|
+
cp -a pkg/fakeroot1.9.1/* debian/tmp/
|
27
|
+
# Do not package Passenger Standalone.
|
28
|
+
rm -rf debian/tmp/usr/bin/passenger
|
29
|
+
|
30
|
+
override_dh_auto_clean:
|
31
|
+
/usr/bin/rake clean CLEAN_DOCS=false
|
32
|
+
rm -rf pkg/fakeroot1.8
|
33
|
+
rm -rf pkg/fakeroot1.9.1
|
34
|
+
# Hack to prevent HTML files from being renegerated
|
35
|
+
touch doc/*.html
|
@@ -0,0 +1 @@
|
|
1
|
+
3.0 (quilt)
|
data/dev/run_travis.sh
CHANGED
@@ -15,70 +15,70 @@ sudo sh -c 'cat >> /etc/hosts' <<EOF
|
|
15
15
|
127.0.0.1 7.passenger.test 8.passenger.test 9.passenger.test
|
16
16
|
EOF
|
17
17
|
|
18
|
+
function run()
|
19
|
+
{
|
20
|
+
echo "$ $@"
|
21
|
+
"$@"
|
22
|
+
}
|
23
|
+
|
18
24
|
if [[ "$TEST_RUBY_VERSION" != "" ]]; then
|
19
25
|
echo "$ rvm use $TEST_RUBY_VERSION"
|
20
|
-
|
26
|
+
if [[ -f ~/.rvm/scripts/rvm ]]; then
|
27
|
+
source ~/.rvm/scripts/rvm
|
28
|
+
else
|
29
|
+
source /usr/local/rvm/scripts/rvm
|
30
|
+
fi
|
21
31
|
rvm use $TEST_RUBY_VERSION
|
22
32
|
if [[ "$TEST_RUBYGEMS_VERSION" = "" ]]; then
|
23
|
-
|
24
|
-
gem --version
|
33
|
+
run gem --version
|
25
34
|
fi
|
26
35
|
fi
|
27
36
|
|
28
37
|
if [[ "$TEST_RUBYGEMS_VERSION" != "" ]]; then
|
29
|
-
|
30
|
-
|
31
|
-
echo "$ gem --version"
|
32
|
-
gem --version
|
33
|
-
fi
|
34
|
-
|
35
|
-
if [[ "$TEST_FULL_COMPILE" = 1 ]]; then
|
36
|
-
echo "$ gem install rack --no-rdoc --no-ri"
|
37
|
-
gem install rack --no-rdoc --no-ri
|
38
|
-
echo "$ ./bin/passenger-install-apache2-module --auto"
|
39
|
-
./bin/passenger-install-apache2-module --auto
|
40
|
-
echo "$ rake nginx"
|
41
|
-
rake nginx
|
42
|
-
echo "$ rake test/cxx/CxxTestMain"
|
43
|
-
rake test/cxx/CxxTestMain
|
44
|
-
echo "$ rake test/oxt/oxt_test_main"
|
45
|
-
rake test/oxt/oxt_test_main
|
38
|
+
run rvm install rubygems $TEST_RUBYGEMS_VERSION
|
39
|
+
run gem --version
|
46
40
|
fi
|
47
41
|
|
48
42
|
if [[ "$TEST_CXX" = 1 ]]; then
|
49
|
-
|
50
|
-
rake test:
|
51
|
-
|
52
|
-
rake test:cxx
|
53
|
-
echo "$ rake test:oxt"
|
54
|
-
rake test:oxt
|
43
|
+
run rake test:install_deps RAILS_BUNDLES=no DOCTOOLS=no
|
44
|
+
run rake test:cxx
|
45
|
+
run rake test:oxt
|
55
46
|
fi
|
56
47
|
|
57
48
|
if [[ "$TEST_RUBY" = 1 ]]; then
|
58
|
-
|
59
|
-
rake test:
|
60
|
-
echo "$ rake test:ruby"
|
61
|
-
rake test:ruby
|
49
|
+
run rake test:install_deps DOCTOOLS=no
|
50
|
+
run rake test:ruby
|
62
51
|
fi
|
63
52
|
|
64
53
|
if [[ "$TEST_NGINX" = 1 ]]; then
|
65
|
-
|
66
|
-
|
67
|
-
|
68
|
-
|
69
|
-
echo "$ ./bin/passenger-install-nginx-module --auto --prefix=/tmp/nginx --auto-download"
|
70
|
-
./bin/passenger-install-nginx-module --auto --prefix=/tmp/nginx --auto-download
|
71
|
-
echo "$ rake test:integration:nginx"
|
72
|
-
rake test:integration:nginx
|
54
|
+
run rake test:install_deps RAILS_BUNDLES=no DOCTOOLS=no
|
55
|
+
run gem install rack daemon_controller --no-rdoc --no-ri
|
56
|
+
run ./bin/passenger-install-nginx-module --auto --prefix=/tmp/nginx --auto-download
|
57
|
+
run rake test:integration:nginx
|
73
58
|
fi
|
74
59
|
|
75
60
|
if [[ "$TEST_APACHE2" = 1 ]]; then
|
76
|
-
|
77
|
-
|
78
|
-
|
79
|
-
gem install rack --no-rdoc --no-ri
|
80
|
-
|
81
|
-
rake apache2
|
82
|
-
|
83
|
-
|
61
|
+
run sudo apt-get install -y --no-install-recommends \
|
62
|
+
apache2-mpm-worker apache2-threaded-dev
|
63
|
+
run rake test:install_deps RAILS_BUNDLES=no DOCTOOLS=no
|
64
|
+
run gem install rack --no-rdoc --no-ri
|
65
|
+
run ./bin/passenger-install-apache2-module --auto
|
66
|
+
run rake test:integration:apache2
|
67
|
+
fi
|
68
|
+
|
69
|
+
if [[ "$TEST_DEBIAN_PACKAGING" = 1 ]]; then
|
70
|
+
run sudo apt-get install -y --no-install-recommends \
|
71
|
+
devscripts debhelper rake apache2-mpm-worker apache2-threaded-dev \
|
72
|
+
ruby1.8 ruby1.8-dev ruby1.9.1 ruby1.9.1-dev libev-dev gdebi-core \
|
73
|
+
source-highlight
|
74
|
+
run rake test:install_deps RAILS_BUNDLES=no
|
75
|
+
run rake debian:dev
|
76
|
+
run sudo gdebi -n pkg/ruby-passenger_*.deb
|
77
|
+
run sudo gdebi -n pkg/ruby-passenger-dev_*.deb
|
78
|
+
run sudo gdebi -n pkg/ruby-passenger-doc_*.deb
|
79
|
+
run sudo gdebi -n pkg/libapache2-mod-passenger_*.deb
|
80
|
+
run rvmsudo env LOCATIONS_INI=/usr/lib/ruby/vendor_ruby/phusion_passenger/locations.ini \
|
81
|
+
rspec -f s -c test/integration_tests/native_packaging_spec.rb
|
82
|
+
run env PASSENGER_LOCATION_CONFIGURATION_FILE=/usr/lib/ruby/vendor_ruby/phusion_passenger/locations.ini \
|
83
|
+
rake test:integration:apache2
|
84
84
|
fi
|
@@ -1059,8 +1059,8 @@ pre {
|
|
1059
1059
|
<body class="article">
|
1060
1060
|
<div id="topbar" style="display: none">
|
1061
1061
|
<div class="title">
|
1062
|
-
|
1063
|
-
<a href="javascript:void(Mizuho.smoothlyScrollToToc())">Phusion Passenger design & architecture</a>
|
1062
|
+
<!-- Don't put a space between the img and a. That will break the hover layout. -->
|
1063
|
+
<img src="" width="11" height="10" alt=""><a href="javascript:void(Mizuho.smoothlyScrollToToc())">Phusion Passenger design & architecture</a>
|
1064
1064
|
</div>
|
1065
1065
|
<a href="javascript:void(0)" id="current_section"></a>
|
1066
1066
|
</div>
|
data/doc/Packaging.html
CHANGED
@@ -481,28 +481,35 @@ button.btn.btn-mini,input[type="submit"].btn.btn-mini{*padding-top:1px;*padding-
|
|
481
481
|
|
482
482
|
<h1>Introduction</h1>
|
483
483
|
|
484
|
+
<p>This document describes how packagers can package Phusion Passenger binaries
|
485
|
+
for their operating system.</p>
|
486
|
+
|
484
487
|
<p>Phusion Passenger can be configured in 2 ways, the "originally packaged"
|
485
|
-
configuration
|
486
|
-
|
487
|
-
in a
|
488
|
+
configuration where everything is in the same directory, and the
|
489
|
+
"natively packaged" configuration where files are scattered across the
|
490
|
+
filesystem, e.g. in a FHS-compliant configuration. This document describes
|
491
|
+
how you can configure Phusion Passenger to locate its own files when they're
|
492
|
+
scattered across the filesystem.</p>
|
493
|
+
|
494
|
+
<p>Phusion Passenger files are also called <em>assets</em> in this document.</p>
|
488
495
|
|
489
496
|
<h2>Originally packaged</h2>
|
490
497
|
|
491
498
|
<p>This is the configuration you get when you checkout Phusion Passenger from git,
|
492
|
-
when you install Phusion Passenger from a gem or when you extract it from a
|
493
|
-
All the original files are stored in a single directory tree, which we
|
494
|
-
<em>source root</em>.</p>
|
499
|
+
when you install Phusion Passenger from a gem or when you extract it from a
|
500
|
+
tarball. All the original files are stored in a single directory tree, which we
|
501
|
+
call the <em>source root</em>.</p>
|
495
502
|
|
496
|
-
<p>
|
497
|
-
|
498
|
-
|
499
|
-
|
503
|
+
<p>The git repository, gems and tarballs do not come with any binaries; they have
|
504
|
+
to be compiled by the user. Phusion Passenger looks for binaries in, and (if
|
505
|
+
the user initiates the compilation process) stores binaries in, the following
|
506
|
+
directories:</p>
|
500
507
|
|
501
508
|
<ul>
|
502
|
-
<li>
|
503
|
-
|
504
|
-
<li><p>Phusion Passenger Standalone does things a little differently.
|
505
|
-
|
509
|
+
<li>Normally, binaries are to be located in the <code>agents</code> and <code>libout</code>
|
510
|
+
subdirectories under the source root.</li>
|
511
|
+
<li><p>Phusion Passenger Standalone does things a little differently. Binaries are
|
512
|
+
to be located in one of the following directories, whichever it finds first:</p>
|
506
513
|
|
507
514
|
<ul>
|
508
515
|
<li><code>~/.passenger/standalone/<VERSION>/<TYPE-AND-ARCH></code> (a)</li>
|
@@ -510,9 +517,9 @@ its binaries in one of these places, whichever first exists:</p>
|
|
510
517
|
</ul>
|
511
518
|
|
512
519
|
|
513
|
-
<p>If neither directories exist, then Passenger Standalone compiles the
|
514
|
-
stores them in (b) (when running as root) or in (a). It still
|
515
|
-
else (like the .rb files) in the source root.</p></li>
|
520
|
+
<p>If neither directories exist, then Passenger Standalone compiles the
|
521
|
+
binaries and stores them in (b) (when running as root) or in (a). It still
|
522
|
+
looks for everything else (like the .rb files) in the source root.</p></li>
|
516
523
|
</ul>
|
517
524
|
|
518
525
|
|
@@ -718,7 +725,9 @@ print an example configuration snippet.</p>
|
|
718
725
|
<li><p><code>ruby_extension_source</code></p>
|
719
726
|
|
720
727
|
<p>The directory that contains the source code for the Phusion Passenger Ruby
|
721
|
-
extension
|
728
|
+
extension. Phusion Passenger uses these sources to build a Ruby extension,
|
729
|
+
when it detects that the user is using a new Ruby interpeter for which
|
730
|
+
no Ruby extension has been compiled.</p>
|
722
731
|
|
723
732
|
<p>Value when originally packaged: <code><SOURCE_ROOT>/ext/ruby</code>.</p></li>
|
724
733
|
</ul>
|
data/doc/Packaging.txt.md
CHANGED
@@ -1,33 +1,40 @@
|
|
1
1
|
# Introduction
|
2
2
|
|
3
|
+
This document describes how packagers can package Phusion Passenger binaries
|
4
|
+
for their operating system.
|
5
|
+
|
3
6
|
Phusion Passenger can be configured in 2 ways, the "originally packaged"
|
4
|
-
configuration
|
5
|
-
|
6
|
-
in a
|
7
|
+
configuration where everything is in the same directory, and the
|
8
|
+
"natively packaged" configuration where files are scattered across the
|
9
|
+
filesystem, e.g. in a FHS-compliant configuration. This document describes
|
10
|
+
how you can configure Phusion Passenger to locate its own files when they're
|
11
|
+
scattered across the filesystem.
|
12
|
+
|
13
|
+
Phusion Passenger files are also called _assets_ in this document.
|
7
14
|
|
8
15
|
## Originally packaged
|
9
16
|
|
10
17
|
This is the configuration you get when you checkout Phusion Passenger from git,
|
11
|
-
when you install Phusion Passenger from a gem or when you extract it from a
|
12
|
-
All the original files are stored in a single directory tree, which we
|
13
|
-
_source root_.
|
18
|
+
when you install Phusion Passenger from a gem or when you extract it from a
|
19
|
+
tarball. All the original files are stored in a single directory tree, which we
|
20
|
+
call the _source root_.
|
14
21
|
|
15
|
-
|
16
|
-
|
17
|
-
|
18
|
-
|
22
|
+
The git repository, gems and tarballs do not come with any binaries; they have
|
23
|
+
to be compiled by the user. Phusion Passenger looks for binaries in, and (if
|
24
|
+
the user initiates the compilation process) stores binaries in, the following
|
25
|
+
directories:
|
19
26
|
|
20
|
-
*
|
21
|
-
|
22
|
-
* Phusion Passenger Standalone does things a little differently.
|
23
|
-
|
27
|
+
* Normally, binaries are to be located in the `agents` and `libout`
|
28
|
+
subdirectories under the source root.
|
29
|
+
* Phusion Passenger Standalone does things a little differently. Binaries are
|
30
|
+
to be located in one of the following directories, whichever it finds first:
|
24
31
|
|
25
32
|
- `~/.passenger/standalone/<VERSION>/<TYPE-AND-ARCH>` (a)
|
26
33
|
- `/var/lib/passenger-standalone/<VERSION-AND-ARCH>` (b)
|
27
34
|
|
28
|
-
If neither directories exist, then Passenger Standalone compiles the
|
29
|
-
stores them in (b) (when running as root) or in (a). It still
|
30
|
-
else (like the .rb files) in the source root.
|
35
|
+
If neither directories exist, then Passenger Standalone compiles the
|
36
|
+
binaries and stores them in (b) (when running as root) or in (a). It still
|
37
|
+
looks for everything else (like the .rb files) in the source root.
|
31
38
|
|
32
39
|
## Natively packaged
|
33
40
|
|
@@ -229,7 +236,9 @@ a list of all possible assets and asset directories.
|
|
229
236
|
* `ruby_extension_source`
|
230
237
|
|
231
238
|
The directory that contains the source code for the Phusion Passenger Ruby
|
232
|
-
extension.
|
239
|
+
extension. Phusion Passenger uses these sources to build a Ruby extension,
|
240
|
+
when it detects that the user is using a new Ruby interpeter for which
|
241
|
+
no Ruby extension has been compiled.
|
233
242
|
|
234
243
|
Value when originally packaged: `<SOURCE_ROOT>/ext/ruby`.
|
235
244
|
|
@@ -1059,8 +1059,8 @@ pre {
|
|
1059
1059
|
<body class="article">
|
1060
1060
|
<div id="topbar" style="display: none">
|
1061
1061
|
<div class="title">
|
1062
|
-
|
1063
|
-
<a href="javascript:void(Mizuho.smoothlyScrollToToc())">Security of user switching support in Passenger</a>
|
1062
|
+
<!-- Don't put a space between the img and a. That will break the hover layout. -->
|
1063
|
+
<img src="" width="11" height="10" alt=""><a href="javascript:void(Mizuho.smoothlyScrollToToc())">Security of user switching support in Passenger</a>
|
1064
1064
|
</div>
|
1065
1065
|
<a href="javascript:void(0)" id="current_section"></a>
|
1066
1066
|
</div>
|
data/doc/Users guide Apache.html
CHANGED
@@ -1059,8 +1059,8 @@ pre {
|
|
1059
1059
|
<body class="article">
|
1060
1060
|
<div id="topbar" style="display: none">
|
1061
1061
|
<div class="title">
|
1062
|
-
|
1063
|
-
<a href="javascript:void(Mizuho.smoothlyScrollToToc())">Phusion Passenger users guide, Apache version</a>
|
1062
|
+
<!-- Don't put a space between the img and a. That will break the hover layout. -->
|
1063
|
+
<img src="" width="11" height="10" alt=""><a href="javascript:void(Mizuho.smoothlyScrollToToc())">Phusion Passenger users guide, Apache version</a>
|
1064
1064
|
</div>
|
1065
1065
|
<a href="javascript:void(0)" id="current_section"></a>
|
1066
1066
|
</div>
|
@@ -1111,7 +1111,7 @@ using the command line.</p></div>
|
|
1111
1111
|
<div class="foo toclevel3"><a href="#_synopsis">2.1. Synopsis</a></div>
|
1112
1112
|
<div class="foo toclevel3"><a href="#rubygems_generic_install">2.2. Generic installation, upgrade and downgrade method: via RubyGems</a></div>
|
1113
1113
|
<div class="foo toclevel3"><a href="#tarball_generic_install">2.3. Generic installation, upgrade and downgrade method: via tarball</a></div>
|
1114
|
-
<div class="foo toclevel3"><a href="#
|
1114
|
+
<div class="foo toclevel3"><a href="#install_on_debian_ubuntu">2.4. Installing or upgrading on Debian 6 or Ubuntu</a></div>
|
1115
1115
|
<div class="foo toclevel3"><a href="#_installing_or_upgrading_on_red_hat_fedora_centos_or_scientificlinux">2.5. Installing or upgrading on Red Hat, Fedora, CentOS or ScientificLinux</a></div>
|
1116
1116
|
<div class="foo toclevel3"><a href="#_upgrading_from_open_source_to_enterprise">2.6. Upgrading from open source to Enterprise</a></div>
|
1117
1117
|
<div class="foo toclevel3"><a href="#_cryptographic_verification_of_installation_files">2.7. Cryptographic verification of installation files</a></div>
|
@@ -1126,7 +1126,7 @@ using the command line.</p></div>
|
|
1126
1126
|
<div class="foo toclevel3"><a href="#_customizing_the_compilation_process">2.9. Customizing the compilation process</a></div>
|
1127
1127
|
<div class="foo toclevel4"><a href="#_setting_the_compiler">2.9.1. Setting the compiler</a></div>
|
1128
1128
|
<div class="foo toclevel4"><a href="#_adding_additional_compiler_or_linker_flags">2.9.2. Adding additional compiler or linker flags</a></div>
|
1129
|
-
<div class="foo toclevel4"><a href="#
|
1129
|
+
<div class="foo toclevel4"><a href="#_forcing_location_of_command_line_tools_and_dependencies">2.9.3. Forcing location of command line tools and dependencies</a></div>
|
1130
1130
|
<div class="foo toclevel3"><a href="#working_with_apache_conf">2.10. Working with the Apache configuration file</a></div>
|
1131
1131
|
<div class="foo toclevel3"><a href="#_disabling_without_uninstalling">2.11. Disabling without uninstalling</a></div>
|
1132
1132
|
<div class="foo toclevel3"><a href="#uninstalling">2.12. Uninstalling</a></div>
|
@@ -1155,7 +1155,7 @@ using the command line.</p></div>
|
|
1155
1155
|
<div class="foo toclevel3"><a href="#_redeploying_restarting_the_wsgi_application">5.3. Redeploying (restarting the WSGI application)</a></div>
|
1156
1156
|
<div class="foo toclevel2"><a href="#_configuring_phusion_passenger">6. Configuring Phusion Passenger</a></div>
|
1157
1157
|
<div class="foo toclevel3"><a href="#_passengerroot_lt_directory_gt">6.1. PassengerRoot <directory></a></div>
|
1158
|
-
<div class="foo toclevel3"><a href="#PassengerDefaultRuby">6.2. PassengerDefaultRuby
|
1158
|
+
<div class="foo toclevel3"><a href="#PassengerDefaultRuby">6.2. PassengerDefaultRuby <filename></a></div>
|
1159
1159
|
<div class="foo toclevel3"><a href="#PassengerRuby">6.3. PassengerRuby <filename></a></div>
|
1160
1160
|
<div class="foo toclevel3"><a href="#_passengerpython_lt_filename_gt">6.4. PassengerPython <filename></a></div>
|
1161
1161
|
<div class="foo toclevel3"><a href="#PassengerAppRoot">6.5. PassengerAppRoot <path/to/root></a></div>
|
@@ -1169,11 +1169,11 @@ using the command line.</p></div>
|
|
1169
1169
|
<div class="foo toclevel3"><a href="#_passengerresistdeploymenterrors_lt_on_off_gt">6.13. PassengerResistDeploymentErrors <on|off></a></div>
|
1170
1170
|
<div class="foo toclevel3"><a href="#_security_options">6.14. Security options</a></div>
|
1171
1171
|
<div class="foo toclevel4"><a href="#PassengerUserSwitching">6.14.1. PassengerUserSwitching <on|off></a></div>
|
1172
|
-
<div class="foo toclevel4"><a href="#
|
1173
|
-
<div class="foo toclevel4"><a href="#
|
1172
|
+
<div class="foo toclevel4"><a href="#PassengerUser">6.14.2. PassengerUser <username></a></div>
|
1173
|
+
<div class="foo toclevel4"><a href="#PassengerGroup">6.14.3. PassengerGroup <group name></a></div>
|
1174
1174
|
<div class="foo toclevel4"><a href="#PassengerDefaultUser">6.14.4. PassengerDefaultUser <username></a></div>
|
1175
1175
|
<div class="foo toclevel4"><a href="#PassengerDefaultGroup">6.14.5. PassengerDefaultGroup <group name></a></div>
|
1176
|
-
<div class="foo toclevel4"><a href="#
|
1176
|
+
<div class="foo toclevel4"><a href="#PassengerFriendlyErrorPages">6.14.6. PassengerFriendlyErrorPages <on|off></a></div>
|
1177
1177
|
<div class="foo toclevel3"><a href="#_resource_control_and_optimization_options">6.15. Resource control and optimization options</a></div>
|
1178
1178
|
<div class="foo toclevel4"><a href="#_passengermaxpoolsize_lt_integer_gt">6.15.1. PassengerMaxPoolSize <integer></a></div>
|
1179
1179
|
<div class="foo toclevel4"><a href="#PassengerMinInstances">6.15.2. PassengerMinInstances <integer></a></div>
|
@@ -1193,7 +1193,7 @@ using the command line.</p></div>
|
|
1193
1193
|
<div class="foo toclevel4"><a href="#PassengerResolveSymlinksInDocumentRoot">6.16.1. PassengerResolveSymlinksInDocumentRoot <on|off></a></div>
|
1194
1194
|
<div class="foo toclevel4"><a href="#_passengerallowencodedslashes_lt_on_off_gt">6.16.2. PassengerAllowEncodedSlashes <on|off></a></div>
|
1195
1195
|
<div class="foo toclevel3"><a href="#_logging_and_debugging_options">6.17. Logging and debugging options</a></div>
|
1196
|
-
<div class="foo toclevel4"><a href="#
|
1196
|
+
<div class="foo toclevel4"><a href="#PassengerLogLevel">6.17.1. PassengerLogLevel <integer></a></div>
|
1197
1197
|
<div class="foo toclevel4"><a href="#_passengerdebuglogfile_lt_filename_gt">6.17.2. PassengerDebugLogFile <filename></a></div>
|
1198
1198
|
<div class="foo toclevel4"><a href="#_passengerdebugger_lt_on_off_gt">6.17.3. PassengerDebugger <on|off></a></div>
|
1199
1199
|
<div class="foo toclevel3"><a href="#_classic_ruby_on_rails_8656_2_x_specific_options">6.18. Classic Ruby on Rails (⇐ 2.x)-specific options</a></div>
|
@@ -1240,16 +1240,27 @@ using the command line.</p></div>
|
|
1240
1240
|
<div class="foo toclevel3"><a href="#_accessing_individual_application_processes">8.4. Accessing individual application processes</a></div>
|
1241
1241
|
<div class="foo toclevel3"><a href="#_attaching_an_irb_console_to_an_application_process">8.5. Attaching an IRB console to an application process</a></div>
|
1242
1242
|
<div class="foo toclevel2"><a href="#_tips">9. Tips</a></div>
|
1243
|
-
<div class="foo toclevel3"><a href="#user_switching">9.1. User
|
1244
|
-
<div class="foo
|
1243
|
+
<div class="foo toclevel3"><a href="#user_switching">9.1. User Switching (security feature)</a></div>
|
1244
|
+
<div class="foo toclevel4"><a href="#_requirements">9.1.1. Requirements</a></div>
|
1245
|
+
<div class="foo toclevel4"><a href="#_effects">9.1.2. Effects</a></div>
|
1246
|
+
<div class="foo toclevel4"><a href="#_caveats_amp_troubleshooting">9.1.3. Caveats & troubleshooting</a></div>
|
1247
|
+
<div class="foo toclevel4"><a href="#finding_out_app_user">9.1.4. Finding out what user an application is running as</a></div>
|
1248
|
+
<div class="foo toclevel3"><a href="#reducing_memory_usage">9.2. Copy-on-write memory support (reducing memory consumption of Ruby applications)</a></div>
|
1245
1249
|
<div class="foo toclevel3"><a href="#capistrano">9.3. Capistrano recipe</a></div>
|
1246
1250
|
<div class="foo toclevel3"><a href="#bundler_support">9.4. Bundler support</a></div>
|
1251
|
+
<div class="foo toclevel4"><a href="#add_passenger_to_gemfile">9.4.1. Does Phusion Passenger itself need to be added to the Gemfile?</a></div>
|
1247
1252
|
<div class="foo toclevel3"><a href="#_installing_multiple_ruby_on_rails_versions">9.5. Installing multiple Ruby on Rails versions</a></div>
|
1248
1253
|
<div class="foo toclevel3"><a href="#_making_the_application_restart_after_each_request">9.6. Making the application restart after each request</a></div>
|
1249
1254
|
<div class="foo toclevel3"><a href="#sub_uri_deployment_uri_fix">9.7. How to fix broken images/CSS/JavaScript URIs in sub-URI deployments</a></div>
|
1250
1255
|
<div class="foo toclevel3"><a href="#_out_of_band_garbage_work_and_out_of_band_garbage_collection">9.8. Out-of-Band Garbage Work and Out-of-Band Garbage Collection</a></div>
|
1251
|
-
<div class="foo toclevel3"><a href="#
|
1252
|
-
<div class="foo
|
1256
|
+
<div class="foo toclevel3"><a href="#flying_passenger">9.9. Flying Passenger</a></div>
|
1257
|
+
<div class="foo toclevel4"><a href="#_requirements_2">9.9.1. Requirements</a></div>
|
1258
|
+
<div class="foo toclevel4"><a href="#_basic_usage">9.9.2. Basic usage</a></div>
|
1259
|
+
<div class="foo toclevel4"><a href="#configuring_flying_passenger">9.9.3. Configuring Flying Passenger</a></div>
|
1260
|
+
<div class="foo toclevel4"><a href="#_managing_the_flying_passenger_daemon">9.9.4. Managing the Flying Passenger daemon</a></div>
|
1261
|
+
<div class="foo toclevel4"><a href="#flying_passenger_caveats">9.9.5. Caveats and limitations</a></div>
|
1262
|
+
<div class="foo toclevel3"><a href="#_x_sendfile_support">9.10. X-Sendfile support</a></div>
|
1263
|
+
<div class="foo toclevel3"><a href="#_upload_progress">9.11. Upload progress</a></div>
|
1253
1264
|
<div class="foo toclevel2"><a href="#_under_the_hood">10. Under the hood</a></div>
|
1254
1265
|
<div class="foo toclevel3"><a href="#_static_assets_serving">10.1. Static assets serving</a></div>
|
1255
1266
|
<div class="foo toclevel3"><a href="#_page_caching_support">10.2. Page caching support</a></div>
|
@@ -1269,6 +1280,16 @@ using the command line.</p></div>
|
|
1269
1280
|
<div class="foo toclevel4"><a href="#_example_2_log_file_sharing_not_harmful">13.3.2. Example 2: Log file sharing (not harmful)</a></div>
|
1270
1281
|
<div class="foo toclevel3"><a href="#_smart_spawning_gotcha_2_the_need_to_revive_threads">13.4. Smart spawning gotcha #2: the need to revive threads</a></div>
|
1271
1282
|
<div class="foo toclevel3"><a href="#_smart_spawning_gotcha_3_code_load_order">13.5. Smart spawning gotcha #3: code load order</a></div>
|
1283
|
+
<div class="foo toclevel2"><a href="#about_environment_variables">14. Appendix D: About environment variables</a></div>
|
1284
|
+
<div class="foo toclevel3"><a href="#_working_with_environment_variables">14.1. Working with environment variables</a></div>
|
1285
|
+
<div class="foo toclevel3"><a href="#_the_path_environment_variable">14.2. The PATH environment variable</a></div>
|
1286
|
+
<div class="foo toclevel3"><a href="#_making_environment_variables_permanent">14.3. Making environment variables permanent</a></div>
|
1287
|
+
<div class="foo toclevel4"><a href="#_bash">14.3.1. bash</a></div>
|
1288
|
+
<div class="foo toclevel4"><a href="#_apache">14.3.2. Apache</a></div>
|
1289
|
+
<div class="foo toclevel4"><a href="#_nginx">14.3.3. Nginx</a></div>
|
1290
|
+
<div class="foo toclevel4"><a href="#_cron">14.3.4. cron</a></div>
|
1291
|
+
<div class="foo toclevel4"><a href="#env_vars_passenger_apps">14.3.5. Phusion Passenger-served apps</a></div>
|
1292
|
+
<div class="foo toclevel3"><a href="#env_vars_and_sudo">14.4. Environment variables and sudo</a></div>
|
1272
1293
|
</div>
|
1273
1294
|
</div>
|
1274
1295
|
<div id="content">
|
@@ -1295,14 +1316,14 @@ if it doesn’t work on your POSIX-compliant operating system.</p></div>
|
|
1295
1316
|
<div class="ulist"><ul>
|
1296
1317
|
<li>
|
1297
1318
|
<p>
|
1298
|
-
<a href="http://
|
1299
|
-
|
1319
|
+
<a href="http://groups.google.com/group/phusion-passenger">Discussion forum</a> - post a
|
1320
|
+
message here if you’re experiencing problems. Support on this forum is provided by the community on a best-effort basis, so a (timely) response is not guaranteed.
|
1300
1321
|
</p>
|
1301
1322
|
</li>
|
1302
1323
|
<li>
|
1303
1324
|
<p>
|
1304
|
-
<a href="http://
|
1305
|
-
|
1325
|
+
<a href="http://code.google.com/p/phusion-passenger/issues/list">Issue tracker</a> - report
|
1326
|
+
bugs here.
|
1306
1327
|
</p>
|
1307
1328
|
</li>
|
1308
1329
|
<li>
|
@@ -1317,7 +1338,7 @@ Email <a href="mailto:support@phusion.nl">support@phusion.nl</a> if you are a <a
|
|
1317
1338
|
</li>
|
1318
1339
|
<li>
|
1319
1340
|
<p>
|
1320
|
-
Report security vulnerabilities to <a href="mailto:
|
1341
|
+
Report security vulnerabilities to <a href="mailto:security@phusion.nl">security@phusion.nl</a>. We will do our best to respond to you as quickly as we can, so please do not disclose the vulnerability until then.
|
1321
1342
|
</p>
|
1322
1343
|
</li>
|
1323
1344
|
</ul></div>
|
@@ -1478,7 +1499,21 @@ chmod o+x /home/phusion</pre>
|
|
1478
1499
|
configuration file. However, it doesn’t copy any files to outside the Phusion Passenger source directory.</p>
|
1479
1500
|
</div>
|
1480
1501
|
<div class="paragraph"><p><span class="monospaced">passenger-install-apache2-module</span> is actually just a user-friendly frontend around the command <span class="monospaced">rake apache2</span>, which performs the actual compilation of Phusion Passenger.</p></div>
|
1481
|
-
<span class="anchor_helper" id="
|
1502
|
+
<span class="anchor_helper" id="_step_6_restarting_the_flying_passenger_daemon"></span><h4 class="float" data-anchor="_step_6_restarting_the_flying_passenger_daemon">Step 6: Restarting the Flying Passenger daemon</h4>
|
1503
|
+
<div class="paragraph"><p>If you are using <a href="#flying_passenger">Flying Passenger</a> then you must restart the Flying Passenger daemon by sending it the SIGTERM signal:</p></div>
|
1504
|
+
<div class="listingblock">
|
1505
|
+
<div class="content monospaced">
|
1506
|
+
<pre>kill `cat /path-to/flying-passenger.pid`</pre>
|
1507
|
+
</div>
|
1508
|
+
</div>
|
1509
|
+
<div class="paragraph"><p>Or, if Flying Passenger is not running with a PID file, look up its PID us <span class="monospaced">ps</span> and then send it SIGTERM:</p></div>
|
1510
|
+
<div class="listingblock">
|
1511
|
+
<div class="content monospaced">
|
1512
|
+
<pre>ps auxw | grep flying-passenger
|
1513
|
+
kill PID_OF_FLYING_PASSENGER</pre>
|
1514
|
+
</div>
|
1515
|
+
</div>
|
1516
|
+
<span class="anchor_helper" id="verify_passenger_running"></span><h4 class="float" data-anchor="verify_passenger_running">Step 7: Verifying that Phusion Passenger is running</h4>
|
1482
1517
|
<div class="paragraph"><p>Restart your web server and run:</p></div>
|
1483
1518
|
<div class="listingblock">
|
1484
1519
|
<div class="content monospaced">
|
@@ -1491,24 +1526,7 @@ configuration file. However, it doesn’t copy any files to outside the Phusion
|
|
1491
1526
|
<div class="sect2">
|
1492
1527
|
<a href="javascript:void(0)" class="comments empty" title="Add a comment"><span class="count"></span></a><span class="anchor_helper" id="tarball_generic_install"></span><h3 data-comment-topic="installing-via-the-source-tarball-1cgxrqc" data-anchor="tarball_generic_install">2.3. Generic installation, upgrade and downgrade method: via tarball</h3>
|
1493
1528
|
<span class="anchor_helper" id="_step_1_download_and_extract_the_tarball"></span><h4 class="float" data-anchor="_step_1_download_and_extract_the_tarball">Step 1: download and extract the tarball</h4>
|
1494
|
-
<div class="paragraph"><p>Download the open source Phusion Passenger tarball from <a href="https://www.phusionpassenger.com/download#open_source">the Phusion Passenger website</a>.
|
1495
|
-
<div class="ulist"><ul>
|
1496
|
-
<li>
|
1497
|
-
<p>
|
1498
|
-
All versions starting from 4.0.0 can be found on <a href="https://code.google.com/p/phusion-passenger/downloads/list">Google Code</a>.
|
1499
|
-
</p>
|
1500
|
-
</li>
|
1501
|
-
<li>
|
1502
|
-
<p>
|
1503
|
-
All versions prior to 4.0.0, except for beta releases and Release Candidates, can be found on <a href="http://rubyforge.org/frs/?group_id=5873&release_id=46919">RubyForge</a>.
|
1504
|
-
</p>
|
1505
|
-
</li>
|
1506
|
-
<li>
|
1507
|
-
<p>
|
1508
|
-
All beta releases and Release Candidates prior to 4.0.0 beta 1 can be found on <a href="https://code.google.com/p/phusion-passenger/downloads/list">Google Code</a>.
|
1509
|
-
</p>
|
1510
|
-
</li>
|
1511
|
-
</ul></div>
|
1529
|
+
<div class="paragraph"><p>Download the open source Phusion Passenger tarball from <a href="https://www.phusionpassenger.com/download#open_source">the Phusion Passenger website</a>. Older versions can be found on <a href="https://www.phusionpassenger.com/file_releases">the release archive</a>.</p></div>
|
1512
1530
|
<div class="paragraph"><p>If you a <a href="https://www.phusionpassenger.com/enterprise">Phusion Passenger Enterprise</a> customer, download the Phusion Passenger Enterprise tarball from the <a href="https://www.phusionpassenger.com/orders">Customer Area</a>. Also be sure to download the <strong>license key</strong> and save it as <em>/etc/passenger-enterprise-license</em>.</p></div>
|
1513
1531
|
<div class="paragraph"><p>Once you have downloaded the tarball, pick a location to extract it to. You can pick any location. A good location is <em>/opt/passenger</em>. Let’s call this location <span class="monospaced">$PREFIX</span>. Create this directory and extract the tarball as follows:</p></div>
|
1514
1532
|
<div class="listingblock">
|
@@ -1601,11 +1619,25 @@ sudo apt-get update</pre>
|
|
1601
1619
|
<span class="anchor_helper" id="_step_5_run_the_phusion_passenger_installer"></span><h4 class="float" data-anchor="_step_5_run_the_phusion_passenger_installer">Step 5: run the Phusion Passenger installer</h4>
|
1602
1620
|
<div class="paragraph"><p>Please refer to <a href="#run_passenger_installer">this section</a>.
|
1603
1621
|
Note that the <span class="monospaced">passenger-install-apache2-module</span> command is inside the <em>bin</em> subdirectory of the Phusion Passenger source directory, so you would have to run something like <em>/opt/passenger/passenger-x.x.x/bin/passenger-install-apache2-module</em>.</p></div>
|
1604
|
-
<span class="anchor_helper" id="
|
1622
|
+
<span class="anchor_helper" id="_step_6_restarting_the_flying_passenger_daemon_2"></span><h4 class="float" data-anchor="_step_6_restarting_the_flying_passenger_daemon_2">Step 6: Restarting the Flying Passenger daemon</h4>
|
1623
|
+
<div class="paragraph"><p>If you are using <a href="#flying_passenger">Flying Passenger</a> then you must restart the Flying Passenger daemon by sending it the SIGTERM signal:</p></div>
|
1624
|
+
<div class="listingblock">
|
1625
|
+
<div class="content monospaced">
|
1626
|
+
<pre>kill `cat /path-to/flying-passenger.pid`</pre>
|
1627
|
+
</div>
|
1628
|
+
</div>
|
1629
|
+
<div class="paragraph"><p>Or, if Flying Passenger is not running with a PID file, look up its PID us <span class="monospaced">ps</span> and then send it SIGTERM:</p></div>
|
1630
|
+
<div class="listingblock">
|
1631
|
+
<div class="content monospaced">
|
1632
|
+
<pre>ps auxw | grep flying-passenger
|
1633
|
+
kill PID_OF_FLYING_PASSENGER</pre>
|
1634
|
+
</div>
|
1635
|
+
</div>
|
1636
|
+
<span class="anchor_helper" id="_step_7_verifying_that_phusion_passenger_is_running"></span><h4 class="float" data-anchor="_step_7_verifying_that_phusion_passenger_is_running">Step 7: Verifying that Phusion Passenger is running</h4>
|
1605
1637
|
<div class="paragraph"><p>Please refer to <a href="#verify_passenger_running">this section</a>. Note that all Phusion Passenger administration scripts are located inside the <em>bin</em> subdirectory of the Phusion Passenger source directory, so you would have to run something like <em>/opt/passenger/passenger-x.x.x/bin/passenger-memory-stats</em>.</p></div>
|
1606
1638
|
</div>
|
1607
1639
|
<div class="sect2">
|
1608
|
-
<a href="javascript:void(0)" class="comments empty" title="Add a comment"><span class="count"></span></a><span class="anchor_helper" id="
|
1640
|
+
<a href="javascript:void(0)" class="comments empty" title="Add a comment"><span class="count"></span></a><span class="anchor_helper" id="install_on_debian_ubuntu"></span><h3 data-comment-topic="installing-or-upgrading-on-ubuntu-1xg22xs" data-anchor="install_on_debian_ubuntu">2.4. Installing or upgrading on Debian 6 or Ubuntu</h3>
|
1609
1641
|
<div class="paragraph"><p>John Leach from Brightbox has kindly provided Ubuntu packages for Phusion Passenger. The Ubuntu Lucid packages are compatible with Debian 6. The packages are available from the <a href="http://wiki.brightbox.co.uk/docs:phusion-passenger">Brightbox repository</a>. Only packages for the open source version of Phusion Passenger are provided. <a href="https://www.phusionpassenger.com/enterprise">Phusion Passenger Enterprise</a> customers should use the <a href="#rubygems_generic_install">generic RubyGems installation method</a> or <a href="#tarball_generic_install">the generic tarball installation method</a> instead.</p></div>
|
1610
1642
|
<div class="paragraph"><p>If you use these packages to install Phusion Passenger then you do not need to run <span class="monospaced">passenger-install-apache2-module</span> or <span class="monospaced">passenger-install-nginx-module</span>. These packages contain all the binaries that you need.</p></div>
|
1611
1643
|
<div class="paragraph">
|
@@ -1614,7 +1646,7 @@ Note that the <span class="monospaced">passenger-install-apache2-module</span> c
|
|
1614
1646
|
</div>
|
1615
1647
|
<div class="listingblock">
|
1616
1648
|
<div class="content monospaced">
|
1617
|
-
<pre>sudo apt-add-repository ppa:brightbox/passenger
|
1649
|
+
<pre>sudo apt-add-repository ppa:brightbox/passenger-experimental
|
1618
1650
|
sudo apt-get update</pre>
|
1619
1651
|
</div>
|
1620
1652
|
</div>
|
@@ -1622,7 +1654,7 @@ sudo apt-get update</pre>
|
|
1622
1654
|
<div class="paragraph"><p>Debian 6:</p></div>
|
1623
1655
|
<div class="listingblock">
|
1624
1656
|
<div class="content monospaced">
|
1625
|
-
<pre>sudo sh -c 'echo "deb http://ppa.launchpad.net/brightbox/passenger/ubuntu lucid main" > /etc/apt/sources.list.d/brightbox-passenger.list'
|
1657
|
+
<pre>sudo sh -c 'echo "deb http://ppa.launchpad.net/brightbox/passenger-experimental/ubuntu lucid main" > /etc/apt/sources.list.d/brightbox-passenger.list'
|
1626
1658
|
sudo apt-key adv --keyserver keyserver.ubuntu.com --recv-keys C3173AA6
|
1627
1659
|
sudo apt-get update</pre>
|
1628
1660
|
</div>
|
@@ -1630,7 +1662,7 @@ sudo apt-get update</pre>
|
|
1630
1662
|
<div class="paragraph"><p>Ubuntu 8.04 Hardy:</p></div>
|
1631
1663
|
<div class="listingblock">
|
1632
1664
|
<div class="content monospaced">
|
1633
|
-
<pre>sudo sh -c 'echo "deb http://ppa.launchpad.net/brightbox/passenger/ubuntu hardy main" > /etc/apt/sources.list.d/brightbox-passenger.list'
|
1665
|
+
<pre>sudo sh -c 'echo "deb http://ppa.launchpad.net/brightbox/passenger-experimental/ubuntu hardy main" > /etc/apt/sources.list.d/brightbox-passenger.list'
|
1634
1666
|
sudo apt-key adv --keyserver keyserver.ubuntu.com --recv-keys C3173AA6
|
1635
1667
|
sudo apt-get update</pre>
|
1636
1668
|
</div>
|
@@ -1648,7 +1680,7 @@ sudo apt-get update</pre>
|
|
1648
1680
|
</div>
|
1649
1681
|
<div class="listingblock">
|
1650
1682
|
<div class="content monospaced">
|
1651
|
-
<pre>sudo apt-add-repository ppa:brightbox/passenger-
|
1683
|
+
<pre>sudo apt-add-repository ppa:brightbox/passenger-experimental
|
1652
1684
|
sudo apt-get update</pre>
|
1653
1685
|
</div>
|
1654
1686
|
</div>
|
@@ -1656,7 +1688,7 @@ sudo apt-get update</pre>
|
|
1656
1688
|
<div class="paragraph"><p>Debian 6:</p></div>
|
1657
1689
|
<div class="listingblock">
|
1658
1690
|
<div class="content monospaced">
|
1659
|
-
<pre>sudo sh -c 'echo "deb http://ppa.launchpad.net/brightbox/passenger-
|
1691
|
+
<pre>sudo sh -c 'echo "deb http://ppa.launchpad.net/brightbox/passenger-experimental/ubuntu lucid main" > /etc/apt/sources.list.d/brightbox-passenger-nginx.list'
|
1660
1692
|
sudo apt-key adv --keyserver keyserver.ubuntu.com --recv-keys C3173AA6
|
1661
1693
|
sudo apt-get update</pre>
|
1662
1694
|
</div>
|
@@ -1664,7 +1696,7 @@ sudo apt-get update</pre>
|
|
1664
1696
|
<div class="paragraph"><p>Ubuntu 8.04 Hardy:</p></div>
|
1665
1697
|
<div class="listingblock">
|
1666
1698
|
<div class="content monospaced">
|
1667
|
-
<pre>sudo sh -c 'echo "deb http://ppa.launchpad.net/brightbox/passenger/ubuntu hardy main" > /etc/apt/sources.list.d/brightbox-passenger-nginx.list'
|
1699
|
+
<pre>sudo sh -c 'echo "deb http://ppa.launchpad.net/brightbox/passenger-experimental/ubuntu hardy main" > /etc/apt/sources.list.d/brightbox-passenger-nginx.list'
|
1668
1700
|
sudo apt-key adv --keyserver keyserver.ubuntu.com --recv-keys C3173AA6
|
1669
1701
|
sudo apt-get update</pre>
|
1670
1702
|
</div>
|
@@ -1889,16 +1921,29 @@ gpg --refresh-keys --keyserver keyserver.ubuntu.com</pre>
|
|
1889
1921
|
</div>
|
1890
1922
|
<div class="sect2">
|
1891
1923
|
<a href="javascript:void(0)" class="comments empty" title="Add a comment"><span class="count"></span></a><span class="anchor_helper" id="_customizing_the_compilation_process"></span><h3 data-comment-topic="customizing-the-compilation-process-1sds3od" data-anchor="_customizing_the_compilation_process">2.9. Customizing the compilation process</h3>
|
1924
|
+
<div class="paragraph"><p>The Phusion Passenger compilation process can be customized with environment variables. You can learn more about environment variables in <a href="#about_environment_variables">About environment variables</a>.</p></div>
|
1892
1925
|
<div class="sect3">
|
1893
1926
|
<a href="javascript:void(0)" class="comments empty" title="Add a comment"><span class="count"></span></a><span class="anchor_helper" id="_setting_the_compiler"></span><h4 data-comment-topic="setting-the-compiler-1symq7h" data-anchor="_setting_the_compiler">2.9.1. Setting the compiler</h4>
|
1894
1927
|
<div class="paragraph"><p>You can force the Phusion Passenger build system to use a specific C or C++ compiler by setting the <span class="monospaced">CC</span> and <span class="monospaced">CXX</span> environment variables. These may be set to any arbitrary shell commands.</p></div>
|
1895
1928
|
<div class="paragraph"><p>For example, contributors who want to hack on Phusion Passenger may want to use Clang for faster compilation and <a href="http://ccache.samba.org/">ccache</a> for faster recompilation, and may want to enable more error-catching compilation flags:</p></div>
|
1896
1929
|
<div class="listingblock">
|
1897
|
-
<div class="content
|
1898
|
-
|
1899
|
-
|
1930
|
+
<div class="content">
|
1931
|
+
<!-- Generator: GNU source-highlight 2.11.1
|
1932
|
+
by Lorenzo Bettini
|
1933
|
+
http://www.lorenzobettini.it
|
1934
|
+
http://www.gnu.org/software/src-highlite -->
|
1935
|
+
<pre><tt><span style="font-weight: bold"><span style="color: #0000FF">export</span></span> <span style="color: #009900">CC</span><span style="color: #990000">=</span><span style="color: #FF0000">'ccache clang -fcolor-diagnostics -Qunused-arguments -fcatch-undefined-behavior -ftrapv'</span>
|
1936
|
+
<span style="font-weight: bold"><span style="color: #0000FF">export</span></span> <span style="color: #009900">CXX</span><span style="color: #990000">=</span><span style="color: #FF0000">'ccache clang++ -fcolor-diagnostics -Qunused-arguments -fcatch-undefined-behavior -ftrapv'</span></tt></pre>
|
1900
1937
|
</div>
|
1901
1938
|
</div>
|
1939
|
+
<div class="admonitionblock">
|
1940
|
+
<table><tr>
|
1941
|
+
<td class="icon">
|
1942
|
+
<img src="./images/icons/note.png" alt="Note">
|
1943
|
+
</td>
|
1944
|
+
<td class="content">If you run the installer with <span class="monospaced">sudo</span> then environment variables may not be passed properly. Learn more at <a href="#env_vars_and_sudo">Environment variables and sudo</a>.</td>
|
1945
|
+
</tr></table>
|
1946
|
+
</div>
|
1902
1947
|
</div>
|
1903
1948
|
<div class="sect3">
|
1904
1949
|
<a href="javascript:void(0)" class="comments empty" title="Add a comment"><span class="count"></span></a><span class="anchor_helper" id="_adding_additional_compiler_or_linker_flags"></span><h4 data-comment-topic="adding-additional-compiler-or-linker-flags-wzu0ey" data-anchor="_adding_additional_compiler_or_linker_flags">2.9.2. Adding additional compiler or linker flags</h4>
|
@@ -1953,11 +1998,19 @@ export CXX='ccache clang++ -fcolor-diagnostics -Qunused-arguments -fcatch-undefi
|
|
1953
1998
|
</p>
|
1954
1999
|
</dd>
|
1955
2000
|
</dl></div>
|
2001
|
+
<div class="admonitionblock">
|
2002
|
+
<table><tr>
|
2003
|
+
<td class="icon">
|
2004
|
+
<img src="./images/icons/note.png" alt="Note">
|
2005
|
+
</td>
|
2006
|
+
<td class="content">If you run the installer with <span class="monospaced">sudo</span> then environment variables may not be passed properly. Learn more at <a href="#env_vars_and_sudo">Environment variables and sudo</a>.</td>
|
2007
|
+
</tr></table>
|
2008
|
+
</div>
|
1956
2009
|
</div>
|
1957
2010
|
<div class="sect3">
|
1958
|
-
<a href="javascript:void(0)" class="comments empty" title="Add a comment"><span class="count"></span></a><span class="anchor_helper" id="
|
2011
|
+
<a href="javascript:void(0)" class="comments empty" title="Add a comment"><span class="count"></span></a><span class="anchor_helper" id="_forcing_location_of_command_line_tools_and_dependencies"></span><h4 data-comment-topic="forcing-location-of-certain-command-line-tools-1hym30u" data-anchor="_forcing_location_of_command_line_tools_and_dependencies">2.9.3. Forcing location of command line tools and dependencies</h4>
|
1959
2012
|
<div class="paragraph"><p>The Phusion Passenger build system attempts to autodetect many things by locating relevant helper tools. For example, to find out which compiler flags it should use for compiling Apache modules, it locates the <span class="monospaced">apxs2</span> command and queries it. To find out which compiler flags it should use for libcurl, it queries the <span class="monospaced">curl-config</span> command. These commands may not be in <span class="monospaced">$PATH</span>, or even when they are you may want to use a different one.</p></div>
|
1960
|
-
<div class="paragraph"><p>You can
|
2013
|
+
<div class="paragraph"><p>You can force the build to find certain command line tools at certain locations by using the following environment variables:</p></div>
|
1961
2014
|
<div class="dlist"><dl>
|
1962
2015
|
<dt class="hdlist1">
|
1963
2016
|
<span class="monospaced">HTTPD</span>
|
@@ -1972,8 +2025,18 @@ export CXX='ccache clang++ -fcolor-diagnostics -Qunused-arguments -fcatch-undefi
|
|
1972
2025
|
</dt>
|
1973
2026
|
<dd>
|
1974
2027
|
<p>
|
1975
|
-
The location of the <span class="monospaced">apxs2</span> executable (the Apache module developer tool).
|
2028
|
+
The location of the <span class="monospaced">apxs2</span> executable (the Apache module developer tool). Only used by <span class="monospaced">passenger-install-apache2-module</span>.
|
1976
2029
|
</p>
|
2030
|
+
<div class="paragraph"><p>This environment variable, together with <span class="monospaced">HTTPD</span>, are what you need to customize if you have multiple Apache installations on your system, or if your Apache is located in a non-standard location which Phusion Passenger cannot detect. By setting <span class="monospaced">APXS2</span> and <span class="monospaced">HTTP</span> to the right paths, you can force Phusion Passenger to be compiled against that specific Apache installation.</p></div>
|
2031
|
+
<div class="paragraph"><p>For example, if your Apache installation is located in <span class="monospaced">/opt/lamp/apache2</span>, then you can run the installer as follows:</p></div>
|
2032
|
+
<div class="listingblock">
|
2033
|
+
<div class="content monospaced">
|
2034
|
+
<pre>$ sudo bash
|
2035
|
+
# export HTTPD=/opt/lampp/apache2/bin/apache
|
2036
|
+
# export APXS2=/opt/lampp/apache2/bin/apxs
|
2037
|
+
# passenger-install-apache2-module</pre>
|
2038
|
+
</div>
|
2039
|
+
</div>
|
1977
2040
|
</dd>
|
1978
2041
|
<dt class="hdlist1">
|
1979
2042
|
<span class="monospaced">APR_CONFIG</span>
|
@@ -2008,6 +2071,14 @@ export CXX='ccache clang++ -fcolor-diagnostics -Qunused-arguments -fcatch-undefi
|
|
2008
2071
|
</p>
|
2009
2072
|
</dd>
|
2010
2073
|
</dl></div>
|
2074
|
+
<div class="admonitionblock">
|
2075
|
+
<table><tr>
|
2076
|
+
<td class="icon">
|
2077
|
+
<img src="./images/icons/note.png" alt="Note">
|
2078
|
+
</td>
|
2079
|
+
<td class="content">If you run the installer with <span class="monospaced">sudo</span> then environment variables may not be passed properly. Learn more at <a href="#env_vars_and_sudo">Environment variables and sudo</a>.</td>
|
2080
|
+
</tr></table>
|
2081
|
+
</div>
|
2011
2082
|
</div>
|
2012
2083
|
</div>
|
2013
2084
|
<div class="sect2">
|
@@ -2109,7 +2180,7 @@ done this, you need to remove the Phusion Passenger files.</p></div>
|
|
2109
2180
|
<div class="ulist"><ul>
|
2110
2181
|
<li>
|
2111
2182
|
<p>
|
2112
|
-
If you installed Phusion Passenger via a Ruby gem, then run <span class="monospaced">gem uninstall passenger</span> (or, if you’re
|
2183
|
+
If you installed Phusion Passenger via a Ruby gem, then run <span class="monospaced">gem uninstall passenger</span> (or, if you’re a <a href="https://www.phusionpassenger.com/enterprise">Phusion Passenger Enterprise</a> user, <span class="monospaced">gem uninstall passenger-enterprise-server</span>).
|
2113
2184
|
You <a href="#is_ruby_home_or_system_wide_installed">might have to run this as root</a>.
|
2114
2185
|
</p>
|
2115
2186
|
</li>
|
@@ -2879,7 +2950,7 @@ this option as well. Please read
|
|
2879
2950
|
<div class="paragraph"><p>This required option may only occur once, in the global server configuration.</p></div>
|
2880
2951
|
</div>
|
2881
2952
|
<div class="sect2">
|
2882
|
-
<a href="javascript:void(0)" class="comments empty" title="Add a comment"><span class="count"></span></a><span class="anchor_helper" id="PassengerDefaultRuby"></span><h3 data-comment-topic="passengerdefaultruby-and-passengerruby-7zblp8" data-anchor="PassengerDefaultRuby">6.2. PassengerDefaultRuby
|
2953
|
+
<a href="javascript:void(0)" class="comments empty" title="Add a comment"><span class="count"></span></a><span class="anchor_helper" id="PassengerDefaultRuby"></span><h3 data-comment-topic="passengerdefaultruby-and-passengerruby-7zblp8" data-anchor="PassengerDefaultRuby">6.2. PassengerDefaultRuby <filename></h3>
|
2883
2954
|
<div class="paragraph"><p><strong>Introduced in version 4.0.0.</strong></p></div>
|
2884
2955
|
<div class="paragraph"><p>This option specifies the default Ruby interpreter to use for web apps as well as for all sorts of internal Phusion Passenger helper scripts, e.g. the one used by <a href="#PassengerPreStart">PassengerPreStart</a>. Please see <a href="#PassengerRuby">PassengerRuby</a> for more information, as well as how it relates to <a href="#PassengerRuby">PassengerRuby</a>.</p></div>
|
2885
2956
|
<div class="paragraph"><p>This option may occur in the global server configuration. The default value is <em>ruby</em>, meaning that the Ruby interpreter will be looked up according to the <span class="monospaced">PATH</span> environment variable.</p></div>
|
@@ -3559,7 +3630,7 @@ In <em>.htaccess</em>, if <span class="monospaced">AllowOverride Options</span>
|
|
3559
3630
|
The default value is <em>on</em>.</p></div>
|
3560
3631
|
</div>
|
3561
3632
|
<div class="sect3">
|
3562
|
-
<a href="javascript:void(0)" class="comments empty" title="Add a comment"><span class="count"></span></a><span class="anchor_helper" id="
|
3633
|
+
<a href="javascript:void(0)" class="comments empty" title="Add a comment"><span class="count"></span></a><span class="anchor_helper" id="PassengerUser"></span><h4 data-comment-topic="passengeruser" data-anchor="PassengerUser">6.14.2. PassengerUser <username></h4>
|
3563
3634
|
<div class="paragraph"><p>If <a href="#user_switching">user switching support</a> is enabled, then Phusion Passenger will
|
3564
3635
|
by default run the web application as the owner of the file <em>config/environment.rb</em>
|
3565
3636
|
(for Rails apps) or <em>config.ru</em> (for Rack apps). This option allows you to override
|
@@ -3586,7 +3657,7 @@ In a <span class="monospaced"><Directory></span> or <span class="monospace
|
|
3586
3657
|
<div class="paragraph"><p>In each place, it may be specified at most once.</p></div>
|
3587
3658
|
</div>
|
3588
3659
|
<div class="sect3">
|
3589
|
-
<a href="javascript:void(0)" class="comments empty" title="Add a comment"><span class="count"></span></a><span class="anchor_helper" id="
|
3660
|
+
<a href="javascript:void(0)" class="comments empty" title="Add a comment"><span class="count"></span></a><span class="anchor_helper" id="PassengerGroup"></span><h4 data-comment-topic="passengergroup" data-anchor="PassengerGroup">6.14.3. PassengerGroup <group name></h4>
|
3590
3661
|
<div class="paragraph"><p>If <a href="#user_switching">user switching support</a> is enabled, then Phusion Passenger will
|
3591
3662
|
by default run the web application as the primary group of the owner of the file
|
3592
3663
|
<em>config/environment.rb</em> (for Rails apps) or <em>config.ru</em> (for Rack apps). This option
|
@@ -3632,7 +3703,7 @@ The default value is the primary group of the user specifified by
|
|
3632
3703
|
<a href="#PassengerDefaultUser">PassengerDefaultUser</a>.</p></div>
|
3633
3704
|
</div>
|
3634
3705
|
<div class="sect3">
|
3635
|
-
<a href="javascript:void(0)" class="comments empty" title="Add a comment"><span class="count"></span></a><span class="anchor_helper" id="
|
3706
|
+
<a href="javascript:void(0)" class="comments empty" title="Add a comment"><span class="count"></span></a><span class="anchor_helper" id="PassengerFriendlyErrorPages"></span><h4 data-comment-topic="passengerfriendlyerrorpages" data-anchor="PassengerFriendlyErrorPages">6.14.6. PassengerFriendlyErrorPages <on|off></h4>
|
3636
3707
|
<div class="paragraph"><p>Phusion Passenger can display friendly error pages whenever an application fails
|
3637
3708
|
to start. This friendly error page presents the startup error message, some
|
3638
3709
|
suggestions for solving the problem, and a backtrace. This feature is very useful
|
@@ -4080,6 +4151,17 @@ measure to avoid freezing applications.</p></div>
|
|
4080
4151
|
</td>
|
4081
4152
|
</tr></table>
|
4082
4153
|
</div>
|
4154
|
+
<div class="admonitionblock">
|
4155
|
+
<table><tr>
|
4156
|
+
<td class="icon">
|
4157
|
+
<img src="./images/icons/note.png" alt="Note">
|
4158
|
+
</td>
|
4159
|
+
<td class="content">
|
4160
|
+
<div class="paragraph"><p>This option is currently only available for Ruby apps. It is not yet available
|
4161
|
+
for Python and Node.js.</p></div>
|
4162
|
+
</td>
|
4163
|
+
</tr></table>
|
4164
|
+
</div>
|
4083
4165
|
</div>
|
4084
4166
|
<div class="sect3">
|
4085
4167
|
<a href="javascript:void(0)" class="comments empty" title="Add a comment"><span class="count"></span></a><span class="anchor_helper" id="PassengerMemoryLimit"></span><h4 data-comment-topic="passengermemorylimit-integer--18irza1" data-anchor="PassengerMemoryLimit">6.15.11. PassengerMemoryLimit <integer></h4>
|
@@ -4623,7 +4705,7 @@ displaying maintenance.html will work fine even for URLs starting with "/users".
|
|
4623
4705
|
<div class="sect2">
|
4624
4706
|
<a href="javascript:void(0)" class="comments empty" title="Add a comment"><span class="count"></span></a><span class="anchor_helper" id="_logging_and_debugging_options"></span><h3 data-comment-topic="logging-and-debugging-options-el2cuc" data-anchor="_logging_and_debugging_options">6.17. Logging and debugging options</h3>
|
4625
4707
|
<div class="sect3">
|
4626
|
-
<a href="javascript:void(0)" class="comments empty" title="Add a comment"><span class="count"></span></a><span class="anchor_helper" id="
|
4708
|
+
<a href="javascript:void(0)" class="comments empty" title="Add a comment"><span class="count"></span></a><span class="anchor_helper" id="PassengerLogLevel"></span><h4 data-comment-topic="passengerloglevel-integer--s3kbil" data-anchor="PassengerLogLevel">6.17.1. PassengerLogLevel <integer></h4>
|
4627
4709
|
<div class="paragraph"><p>This option allows one to specify how much information Phusion Passenger should
|
4628
4710
|
write to the Apache error log file. A higher log level value means that more
|
4629
4711
|
information will be logged.</p></div>
|
@@ -5670,51 +5752,199 @@ through the <em>X-Passenger-Connect-Password</em> HTTP header, like this:</p></d
|
|
5670
5752
|
<a href="javascript:void(0)" class="comments empty" title="Add a comment"><span class="count"></span></a><span class="anchor_helper" id="_tips"></span><h2 data-comment-topic="tips-19cwwf7" data-anchor="_tips">9. Tips</h2>
|
5671
5753
|
<div class="sectionbody">
|
5672
5754
|
<div class="sect2">
|
5673
|
-
<a href="javascript:void(0)" class="comments empty" title="Add a comment"><span class="count"></span></a><span class="anchor_helper" id="user_switching"></span><h3 data-comment-topic="user-switching-security--8njx1x" data-anchor="user_switching">9.1. User
|
5674
|
-
<div class="paragraph"><p>
|
5755
|
+
<a href="javascript:void(0)" class="comments empty" title="Add a comment"><span class="count"></span></a><span class="anchor_helper" id="user_switching"></span><h3 data-comment-topic="user-switching-security--8njx1x" data-anchor="user_switching">9.1. User Switching (security feature)</h3>
|
5756
|
+
<div class="paragraph"><p>Phusion Passenger supports automatic <em>user switching</em>: by default, it attempts to run applications as the "right" user, instead of running all applications as the same user.</p></div>
|
5757
|
+
<div class="paragraph"><p>To better understand the problem, let us consider the situation with PHP.
|
5758
|
+
There is a problem that plagues most PHP web hosts, namely the fact that all PHP
|
5675
5759
|
applications are run in the same user context as the web server. So for
|
5676
5760
|
example, Joe’s PHP application will be able to read Jane’s PHP application’s
|
5677
5761
|
passwords. This is obviously undesirable on many servers.</p></div>
|
5678
|
-
<div class="paragraph"><p>Phusion Passenger
|
5679
|
-
|
5680
|
-
|
5681
|
-
|
5682
|
-
|
5683
|
-
<
|
5684
|
-
|
5762
|
+
<div class="paragraph"><p>Phusion Passenger’s <em>user switching</em> feature solves this problem. Applications are
|
5763
|
+
run as the owner of their "startup file". For Ruby apps, the startup file is
|
5764
|
+
<span class="monospaced">config.ru</span> (Rack and Rails >= 3) or <span class="monospaced">config/environment.rb</span> (Rails 1 and 2). For
|
5765
|
+
Python apps, the startup file is <span class="monospaced">passenger_wsgi.py</span>. So suppose that <span class="monospaced">config.ru</span>
|
5766
|
+
is owned by user <em>joe</em>, then Phusion Passenger will spawn the corresponding
|
5767
|
+
application as <em>joe</em> as well. The exact rules are a little bit more complicated,
|
5768
|
+
and they’re explained further down in this section.</p></div>
|
5769
|
+
<div class="sect3">
|
5770
|
+
<a href="javascript:void(0)" class="comments empty" title="Add a comment"><span class="count"></span></a><span class="anchor_helper" id="_requirements"></span><h4 data-comment-topic="requirements-yxvtxo" data-anchor="_requirements">9.1.1. Requirements</h4>
|
5771
|
+
<div class="paragraph"><p>User switching is only enabled when all of the following conditions are met:</p></div>
|
5772
|
+
<div class="ulist"><ul>
|
5773
|
+
<li>
|
5774
|
+
<p>
|
5775
|
+
When not using <a href="#flying_passenger">Flying Passenger</a> (this is probably the case):
|
5776
|
+
</p>
|
5777
|
+
<div class="ulist"><ul>
|
5778
|
+
<li>
|
5779
|
+
<p>
|
5780
|
+
The
|
5781
|
+
<a href="#PassengerUserSwitching">PassengerUserSwitching</a>
|
5782
|
+
option must be enabled.
|
5783
|
+
</p>
|
5784
|
+
</li>
|
5785
|
+
<li>
|
5786
|
+
<p>
|
5787
|
+
The web server’s control process must have root privileges. This is the case on most installations.
|
5788
|
+
</p>
|
5789
|
+
</li>
|
5790
|
+
</ul></div>
|
5791
|
+
</li>
|
5792
|
+
<li>
|
5793
|
+
<p>
|
5794
|
+
When using <a href="#flying_passenger">Flying Passenger</a>:
|
5795
|
+
</p>
|
5685
5796
|
<div class="ulist"><ul>
|
5686
5797
|
<li>
|
5687
5798
|
<p>
|
5688
|
-
The
|
5689
|
-
root directory, and read/write access to the application’s <em>logs</em> directory.
|
5799
|
+
The Flying Passenger daemon must be run with root privileges.
|
5690
5800
|
</p>
|
5691
5801
|
</li>
|
5802
|
+
</ul></div>
|
5803
|
+
</li>
|
5804
|
+
</ul></div>
|
5805
|
+
</div>
|
5806
|
+
<div class="sect3">
|
5807
|
+
<a href="javascript:void(0)" class="comments empty" title="Add a comment"><span class="count"></span></a><span class="anchor_helper" id="_effects"></span><h4 data-comment-topic="effects-1lko7vo" data-anchor="_effects">9.1.2. Effects</h4>
|
5808
|
+
<div class="paragraph"><p>When not using Flying Passenger, the following table illustrates the effect for different combinations of the requirements.</p></div>
|
5809
|
+
<table class="tableblock frame-all grid-all" style="
|
5810
|
+
width:100%;
|
5811
|
+
">
|
5812
|
+
<col style="width:33%;">
|
5813
|
+
<col style="width:33%;">
|
5814
|
+
<col style="width:33%;">
|
5815
|
+
<tbody>
|
5816
|
+
<tr>
|
5817
|
+
<td class="tableblock halign-left valign-top"><p class="tableblock"></p></td>
|
5818
|
+
<td class="tableblock halign-left valign-top"><p class="tableblock"><strong>PassengerUserSwitching on</strong></p></td>
|
5819
|
+
<td class="tableblock halign-left valign-top"><p class="tableblock"><strong>PassengerUserSwitching off</strong></p></td>
|
5820
|
+
</tr>
|
5821
|
+
<tr>
|
5822
|
+
<td class="tableblock halign-left valign-top"><p class="tableblock"><strong>Web server has root privileges</strong></p></td>
|
5823
|
+
<td class="tableblock halign-left valign-top"><p class="tableblock">User switching enabled.</p></td>
|
5824
|
+
<td class="tableblock halign-left valign-top"><p class="tableblock">User switching disabled. Apps are run as
|
5825
|
+
<a href="#PassengerDefaultUser">PassengerDefaultUser</a> and
|
5826
|
+
<a href="#PassengerDefaultGroup">PassengerDefaultGroup</a>.</p></td>
|
5827
|
+
</tr>
|
5828
|
+
<tr>
|
5829
|
+
<td class="tableblock halign-left valign-top"><p class="tableblock"><strong>Web server has no root privileges</strong></p></td>
|
5830
|
+
<td class="tableblock halign-left valign-top"><p class="tableblock">User switching disabled. Apps are run as the web server’s user.</p></td>
|
5831
|
+
<td class="tableblock halign-left valign-top"><p class="tableblock">User switching disabled. Apps are run as the web server’s user.</p></td>
|
5832
|
+
</tr>
|
5833
|
+
</tbody>
|
5834
|
+
</table>
|
5835
|
+
<div class="paragraph"><p>When using Flying Passenger, the effect is as follows:</p></div>
|
5836
|
+
<table class="tableblock frame-all grid-all" style="
|
5837
|
+
width:100%;
|
5838
|
+
">
|
5839
|
+
<col style="width:50%;">
|
5840
|
+
<col style="width:50%;">
|
5841
|
+
<tbody>
|
5842
|
+
<tr>
|
5843
|
+
<td class="tableblock halign-left valign-top"><p class="tableblock"><strong>Daemon run with root privileges</strong></p></td>
|
5844
|
+
<td class="tableblock halign-left valign-top"><p class="tableblock">User switching enabled.</p></td>
|
5845
|
+
</tr>
|
5846
|
+
<tr>
|
5847
|
+
<td class="tableblock halign-left valign-top"><p class="tableblock"><strong>Daemon run without root privileges</strong></p></td>
|
5848
|
+
<td class="tableblock halign-left valign-top"><p class="tableblock">User switching disabled. Apps are run as the daemon’s user.</p></td>
|
5849
|
+
</tr>
|
5850
|
+
</tbody>
|
5851
|
+
</table>
|
5852
|
+
<div class="paragraph"><p>When user switching is enabled, the following rules are followed to determine what user an application should be run as. The first matching rule is the rule that will be followed.</p></div>
|
5853
|
+
<div class="olist arabic"><ol class="arabic">
|
5692
5854
|
<li>
|
5693
5855
|
<p>
|
5694
|
-
|
5695
|
-
|
5856
|
+
If
|
5857
|
+
<a href="#PassengerUser">PassengerUser</a> or
|
5858
|
+
<a href="#PassengerGroup">PassengerGroup</a>
|
5859
|
+
are set, then the application will be run as the specified user/group. Thus, these options are a good way to override user switching settings.
|
5696
5860
|
</p>
|
5697
5861
|
</li>
|
5698
5862
|
<li>
|
5699
5863
|
<p>
|
5700
|
-
|
5701
|
-
<em>environment.rb</em>/<em>config.ru</em> is owned as root or by an unknown user, then the
|
5702
|
-
Rails/Rack application will run as the user specified by
|
5864
|
+
If the startup file is owned by root or an unknown user, then the application will run as the user specified by
|
5703
5865
|
<a href="#PassengerDefaultUser">PassengerDefaultUser</a> and
|
5704
5866
|
<a href="#PassengerDefaultGroup">PassengerDefaultGroup</a>.
|
5705
5867
|
</p>
|
5706
5868
|
</li>
|
5869
|
+
<li>
|
5870
|
+
<p>
|
5871
|
+
Otherwise, the application is run as the owner of the startup file.
|
5872
|
+
</p>
|
5873
|
+
</li>
|
5874
|
+
</ol></div>
|
5875
|
+
</div>
|
5876
|
+
<div class="sect3">
|
5877
|
+
<a href="javascript:void(0)" class="comments empty" title="Add a comment"><span class="count"></span></a><span class="anchor_helper" id="_caveats_amp_troubleshooting"></span><h4 data-comment-topic="caveats-troubleshooting-161hgge" data-anchor="_caveats_amp_troubleshooting">9.1.3. Caveats & troubleshooting</h4>
|
5878
|
+
<div class="paragraph"><p>If your application regularly encounters permission errors or fails to find certain files, then this is an indication that your application is started as a user that you did not intent it to be run as. Other symptoms include:</p></div>
|
5879
|
+
<div class="ulist"><ul>
|
5880
|
+
<li>
|
5881
|
+
<p>
|
5882
|
+
The application fails to start because Bundler complains that it cannot find gems. This probably indicates that Bundler does not have read access to the directory that contains Bundler-installed gems.
|
5883
|
+
</p>
|
5884
|
+
</li>
|
5885
|
+
<li>
|
5886
|
+
<p>
|
5887
|
+
The application fails to start and its error message mentions the path <em>/nonexistent</em>. This probably indicates that your application is started as the <em>nobody</em> user. This is because on many systems, the <em>nobody</em> user’s home directory is <em>/nonexistent</em>.
|
5888
|
+
</p>
|
5889
|
+
</li>
|
5707
5890
|
</ul></div>
|
5708
|
-
<div class="paragraph"><p>
|
5709
|
-
<
|
5710
|
-
|
5891
|
+
<div class="paragraph"><p>To check whether it is indeed the case that your application is started as a different user than you intended to, see <a href="#finding_out_app_user">Finding out what user an application is running as</a>.</p></div>
|
5892
|
+
<div class="paragraph"><p>The most likely reason why your application is started as <em>nobody</em> is probably because your startup file is owned by <em>root</em>, by <em>nobody</em> or by an unknown user. To fix this, change the owner of the startup file to the owner that you want to run the application as.</p></div>
|
5893
|
+
<div class="paragraph"><p>Whatever user your application runs as, it must have read access to the <a href="#application_root">application root</a>, and read/write access to the application’s <em>logs</em> directory.</p></div>
|
5894
|
+
</div>
|
5895
|
+
<div class="sect3">
|
5896
|
+
<a href="javascript:void(0)" class="comments empty" title="Add a comment"><span class="count"></span></a><span class="anchor_helper" id="finding_out_app_user"></span><h4 data-comment-topic="finding-out-what-user-an-application-is-running-as-7uwrol" data-anchor="finding_out_app_user">9.1.4. Finding out what user an application is running as</h4>
|
5897
|
+
<div class="paragraph"><p>To find our what user an application is started as, first access its URL in your browser so that Phusion Passenger starts the application. For example:</p></div>
|
5898
|
+
<div class="listingblock">
|
5899
|
+
<div class="content monospaced">
|
5900
|
+
<pre>http://www.example.local/</pre>
|
5901
|
+
</div>
|
5902
|
+
</div>
|
5903
|
+
<div class="paragraph"><p>The application will now either successfully start or fail to start. If it fails to start then you will see an error page that tells you what user the application was being started as. If you do not see the error page in the browser then set
|
5904
|
+
<a href="#PassengerFriendlyErrorPages">PassengerFriendlyErrorPages</a>
|
5905
|
+
on.</p></div>
|
5906
|
+
<div class="paragraph"><p>If the application successfully started, then run <span class="monospaced">passenger-status</span> to find the process’s PID:</p></div>
|
5907
|
+
<div class="listingblock">
|
5908
|
+
<div class="content monospaced">
|
5909
|
+
<pre>.---------- General information -----------
|
5910
|
+
Max pool size : 6
|
5911
|
+
Processes : 1
|
5912
|
+
Requests in top-level queue : 0
|
5913
|
+
|
5914
|
+
.---------- Application groups -----------
|
5915
|
+
/webapps/example.local#default:
|
5916
|
+
App root: /webapps/example.local
|
5917
|
+
Requests in queue: 0
|
5918
|
+
* PID: 16915 Sessions: 0 Processed: 1 Uptime: 2s
|
5919
|
+
CPU: 0% Memory : 9M Last used: 2s ago</pre>
|
5920
|
+
</div>
|
5921
|
+
</div>
|
5922
|
+
<div class="paragraph"><p>In the above example we see that the PID is 16915. Next, use <em>ps</em> to find out the user that it is running as:</p></div>
|
5923
|
+
<div class="listingblock">
|
5924
|
+
<div class="content monospaced">
|
5925
|
+
<pre># ps -o pid,user,comm -p 16915
|
5926
|
+
PID USER COMM
|
5927
|
+
16915 phusion Passenger RackApp: /webapps/example.local</pre>
|
5928
|
+
</div>
|
5929
|
+
</div>
|
5930
|
+
<div class="paragraph"><p>As you can see, the application in this example is being run as user <em>phusion</em>.</p></div>
|
5931
|
+
</div>
|
5711
5932
|
</div>
|
5712
5933
|
<div class="sect2">
|
5713
|
-
<a href="javascript:void(0)" class="comments empty" title="Add a comment"><span class="count"></span></a><span class="anchor_helper" id="reducing_memory_usage"></span><h3 data-comment-topic="reducing-memory-consumption-of-ruby-on-rails-applications-by-33--1ubxnq0" data-anchor="reducing_memory_usage">9.2.
|
5714
|
-
<div class="paragraph"><p>
|
5715
|
-
|
5716
|
-
|
5717
|
-
<
|
5934
|
+
<a href="javascript:void(0)" class="comments empty" title="Add a comment"><span class="count"></span></a><span class="anchor_helper" id="reducing_memory_usage"></span><h3 data-comment-topic="reducing-memory-consumption-of-ruby-on-rails-applications-by-33--1ubxnq0" data-anchor="reducing_memory_usage">9.2. Copy-on-write memory support (reducing memory consumption of Ruby applications)</h3>
|
5935
|
+
<div class="paragraph"><p>Phusion Passenger automatically leverages operating system virtual memory copy-on-write features in order to reduce the memory usage of Ruby applications. Experience has shown that this reduces memory usage by 33% on average. For this mechanism to work, a Ruby interpreter with a copy-on-write friendly garbage collector is required. The following Ruby interpreters have copy-on-write friendly garbage collectors:</p></div>
|
5936
|
+
<div class="ulist"><ul>
|
5937
|
+
<li>
|
5938
|
+
<p>
|
5939
|
+
MRI Ruby >= 2.0. Versions prior to 2.0 did not have a copy-on-write friendly garbage collector.
|
5940
|
+
</p>
|
5941
|
+
</li>
|
5942
|
+
<li>
|
5943
|
+
<p>
|
5944
|
+
<a href="http://www.rubyenterpriseedition.com/">Ruby Enterprise Edition</a>, which was Phusion’s branch of MRI Ruby 1.8 with a copy-on-write friendly garbage collector and other enhancement. It has reached End-Of-Life as of 2012, but remains available for legacy systems.
|
5945
|
+
</p>
|
5946
|
+
</li>
|
5947
|
+
</ul></div>
|
5718
5948
|
</div>
|
5719
5949
|
<div class="sect2">
|
5720
5950
|
<a href="javascript:void(0)" class="comments empty" title="Add a comment"><span class="count"></span></a><span class="anchor_helper" id="capistrano"></span><h3 data-comment-topic="capistrano-recipe-syzgo7" data-anchor="capistrano">9.3. Capistrano recipe</h3>
|
@@ -5754,7 +5984,9 @@ end</pre>
|
|
5754
5984
|
<div class="sect2">
|
5755
5985
|
<a href="javascript:void(0)" class="comments empty" title="Add a comment"><span class="count"></span></a><span class="anchor_helper" id="bundler_support"></span><h3 data-comment-topic="bundler-support-cf72ih" data-anchor="bundler_support">9.4. Bundler support</h3>
|
5756
5986
|
<div class="paragraph"><p>Phusion Passenger has automatic support for <a href="http://gembundler.com/git.html">Bundler</a>.
|
5757
|
-
|
5987
|
+
The support consists of loading your application under the environment defined by your
|
5988
|
+
Gemfile. In other words, Phusion Passenger loads your application as if <em>bundle exec</em> was used.</p></div>
|
5989
|
+
<div class="paragraph"><p>The Bundler support works as follows:</p></div>
|
5758
5990
|
<div class="ulist"><ul>
|
5759
5991
|
<li>
|
5760
5992
|
<p>
|
@@ -5779,10 +6011,22 @@ have any negative effects.</p></div>
|
|
5779
6011
|
<div class="paragraph"><p>Phusion Passenger assumes that you’re using Bundler >= 0.9.5. If you don’t want Phusion
|
5780
6012
|
Passenger to run its Bundler support code, e.g. because you need to use an older version
|
5781
6013
|
of Bundler with an incompatible API or because you use a system other than Bundler, then
|
5782
|
-
you can override Phusion Passenger’s Bundler support code by creating
|
6014
|
+
you can override Phusion Passenger’s Bundler support code by creating an empty file
|
5783
6015
|
<em>config/setup_load_paths.rb</em>. If this file exists then it will be required before loading
|
5784
6016
|
the application startup file. In this file you can do whatever you need to setup Bundler
|
5785
6017
|
or a similar system.</p></div>
|
6018
|
+
<div class="sect3">
|
6019
|
+
<a href="javascript:void(0)" class="comments empty" title="Add a comment"><span class="count"></span></a><span class="anchor_helper" id="add_passenger_to_gemfile"></span><h4 data-comment-topic="does-phusion-passenger-itself-need-to-be-added-to-the-gemfile--17whimp" data-anchor="add_passenger_to_gemfile">9.4.1. Does Phusion Passenger itself need to be added to the Gemfile?</h4>
|
6020
|
+
<div class="paragraph"><p>It is never necessary to add Phusion Passenger to the application’s Gemfile. In case of Phusion Passenger Standalone, it is not necessary to execute the <span class="monospaced">passenger</span> command through <span class="monospaced">bundle exec</span>. The reason for this is because Phusion Passenger automatically loads the Gemfile environment. Most other Ruby application servers do not automatically load the Gemfile environment, which is why they must be added to the Gemfile and be executed with <span class="monospaced">bundle exec</span>.</p></div>
|
6021
|
+
<div class="paragraph"><p>Even when your application uses any of the Phusion Passenger APIs, you still do not need to add Phusion Passenger to the Gemfile. The only thing you need to do is to put Phusion Passenger API calls inside <span class="monospaced">if</span> blocks that check whether Phusion Passenger is active, by checking whether the <span class="monospaced">PhusionPassenger</span> namespace is defined:</p></div>
|
6022
|
+
<div class="listingblock">
|
6023
|
+
<div class="content monospaced">
|
6024
|
+
<pre><strong>if</strong> defined?(PhusionPassenger)
|
6025
|
+
...
|
6026
|
+
<strong>end</strong></pre>
|
6027
|
+
</div>
|
6028
|
+
</div>
|
6029
|
+
</div>
|
5786
6030
|
</div>
|
5787
6031
|
<div class="sect2">
|
5788
6032
|
<a href="javascript:void(0)" class="comments empty" title="Add a comment"><span class="count"></span></a><span class="anchor_helper" id="_installing_multiple_ruby_on_rails_versions"></span><h3 data-comment-topic="installing-multiple-ruby-on-rails-versions-mi5j14" data-anchor="_installing_multiple_ruby_on_rails_versions">9.5. Installing multiple Ruby on Rails versions</h3>
|
@@ -5894,7 +6138,7 @@ You can actually perform out-of-band work when you receive a <span class="monosp
|
|
5894
6138
|
</li>
|
5895
6139
|
</ol></div>
|
5896
6140
|
<div class="paragraph"><p>Note that even though you can request out-of-band work, there’s no guarantee that Phusion Passenger will send an <span class="monospaced">oob_work</span> event in a timely manner, if at all. It is also possible that Phusion Passenger sends an <span class="monospaced">oob_work</span> event without you ever having requested one. This latter could for example happen if the OOB work is administrator-initiated. Do not make any assumptions in your code.</p></div>
|
5897
|
-
<div class="paragraph"><p>Here’s an example which implements out-of-band garbage collection using the Out-of-Band framework
|
6141
|
+
<div class="paragraph"><p>Here’s an example which implements out-of-band garbage collection using the Out-of-Band framework. This example code doesn’t do anything when the code is not being run in Phusion Passenger, thanks to the <span class="monospaced">if</span> block.</p></div>
|
5898
6142
|
<div class="listingblock">
|
5899
6143
|
<div class="content">
|
5900
6144
|
<!-- Generator: GNU source-highlight 2.11.1
|
@@ -5906,27 +6150,32 @@ http://www.gnu.org/software/src-highlite -->
|
|
5906
6150
|
response<span style="color: #990000">.</span>headers<span style="color: #990000">[</span><span style="color: #FF0000">"X-Passenger-Request-OOB-Work"</span><span style="color: #990000">]</span> <span style="color: #990000">=</span> <span style="color: #FF0000">"true"</span>
|
5907
6151
|
|
5908
6152
|
<span style="font-style: italic"><span style="color: #9A1900"># Somewhere during application initialization:</span></span>
|
5909
|
-
|
5910
|
-
|
5911
|
-
|
5912
|
-
|
5913
|
-
|
6153
|
+
<span style="font-weight: bold"><span style="color: #0000FF">if</span></span> <span style="font-weight: bold"><span style="color: #0000FF">defined</span></span><span style="color: #990000">?(</span>PhusionPassenger<span style="color: #990000">)</span>
|
6154
|
+
PhusionPassenger<span style="color: #990000">.</span>on_event<span style="color: #990000">(:</span>oob_work<span style="color: #990000">)</span> <span style="font-weight: bold"><span style="color: #0000FF">do</span></span>
|
6155
|
+
<span style="font-style: italic"><span style="color: #9A1900"># Phusion Passenger has told us that we're ready to perform OOB work.</span></span>
|
6156
|
+
t0 <span style="color: #990000">=</span> Time<span style="color: #990000">.</span>now
|
6157
|
+
GC<span style="color: #990000">.</span>start
|
6158
|
+
Rails<span style="color: #990000">.</span>logger<span style="color: #990000">.</span>info <span style="color: #FF0000">"Out-Of-Bound GC finished in #{Time.now - t0} sec"</span>
|
6159
|
+
<span style="font-weight: bold"><span style="color: #0000FF">end</span></span>
|
5914
6160
|
<span style="font-weight: bold"><span style="color: #0000FF">end</span></span></tt></pre>
|
5915
6161
|
</div>
|
5916
6162
|
</div>
|
5917
|
-
<div class="paragraph"><p>For your convenience, Phusion Passenger provides a Rack middleware for out-of-band garbage collection. Add
|
6163
|
+
<div class="paragraph"><p>For your convenience, Phusion Passenger provides a Rack middleware for out-of-band garbage collection. Add the following to your <span class="monospaced">config.ru</span>. Likewise, this example code doesn’t do anything when the code is not being run in Phusion Passenger, thanks to the <span class="monospaced">if</span> block.</p></div>
|
5918
6164
|
<div class="listingblock">
|
5919
6165
|
<div class="content">
|
5920
6166
|
<!-- Generator: GNU source-highlight 2.11.1
|
5921
6167
|
by Lorenzo Bettini
|
5922
6168
|
http://www.lorenzobettini.it
|
5923
6169
|
http://www.gnu.org/software/src-highlite -->
|
5924
|
-
<pre><tt><span style="font-weight: bold"><span style="color: #
|
6170
|
+
<pre><tt><span style="font-weight: bold"><span style="color: #0000FF">if</span></span> <span style="font-weight: bold"><span style="color: #0000FF">defined</span></span><span style="color: #990000">?(</span>PhusionPassenger<span style="color: #990000">)</span>
|
6171
|
+
<span style="font-weight: bold"><span style="color: #000080">require</span></span> <span style="color: #FF0000">'phusion_passenger/rack/out_of_band_gc'</span>
|
5925
6172
|
|
5926
|
-
<span style="font-style: italic"><span style="color: #9A1900"># Trigger out-of-band GC every 5 requests.</span></span>
|
5927
|
-
use PhusionPassenger<span style="color: #990000">::</span>Rack<span style="color: #990000">::</span>OutOfBandGc<span style="color: #990000">,</span> <span style="color: #993399">5</span
|
6173
|
+
<span style="font-style: italic"><span style="color: #9A1900"># Trigger out-of-band GC every 5 requests.</span></span>
|
6174
|
+
use PhusionPassenger<span style="color: #990000">::</span>Rack<span style="color: #990000">::</span>OutOfBandGc<span style="color: #990000">,</span> <span style="color: #993399">5</span>
|
6175
|
+
<span style="font-weight: bold"><span style="color: #0000FF">end</span></span></tt></pre>
|
5928
6176
|
</div>
|
5929
6177
|
</div>
|
6178
|
+
<div class="paragraph"><p>It should be noted that, although the application uses the Phusion Passenger API, it is <a href="#add_passenger_to_gemfile"><strong>not</strong> necessary to add Phusion Passenger to the Gemfile</a>.</p></div>
|
5930
6179
|
<div class="paragraph"><p>References:</p></div>
|
5931
6180
|
<div class="ulist"><ul>
|
5932
6181
|
<li>
|
@@ -5937,12 +6186,223 @@ use PhusionPassenger<span style="color: #990000">::</span>Rack<span style="color
|
|
5937
6186
|
</ul></div>
|
5938
6187
|
</div>
|
5939
6188
|
<div class="sect2">
|
5940
|
-
<a href="javascript:void(0)" class="comments empty" title="Add a comment"><span class="count"></span></a><span class="anchor_helper" id="
|
6189
|
+
<a href="javascript:void(0)" class="comments empty" title="Add a comment"><span class="count"></span></a><span class="anchor_helper" id="flying_passenger"></span><h3 data-comment-topic="flying-passenger-q916f7" data-anchor="flying_passenger">9.9. Flying Passenger</h3>
|
6190
|
+
<div class="paragraph"><p><strong>This feature is only available in <a href="https://www.phusionpassenger.com/enterprise">Phusion Passenger Enterprise</a>. It was introduced in version 4.0.6. <a href="https://www.phusionpassenger.com/download">Buy Phusion Passenger Enterprise here.</a></strong></p></div>
|
6191
|
+
<div class="paragraph"><p>Flying Passenger allows one to decouple Phusion Passenger’s life time from the web server’s life time, so that the web server can be independently restarted from Phusion Passenger, and from any of the application processes served by Phusion Passenger.</p></div>
|
6192
|
+
<div class="paragraph"><p>Normally, Phusion Passenger starts together with the web server, and shuts down together with the web server. The advantages of this default behavior is that it makes Phusion Passenger easy to administer: one only has to deal with the web server process and can expect all relevant processes to be cleaned up after a web server shut down. However this also brings about a disadvantage: every time one restarts the web server (e.g. to make a minor configuration change), Phusion Passenger and all its application processes also get restarted.</p></div>
|
6193
|
+
<div class="paragraph"><p>This problem is solved by <em>Flying Passenger</em>, which is an advanced mode of operation in Phusion Passenger that allows the web server to be indepedently restarted from Phusion Passenger. When this mode is enabled:</p></div>
|
6194
|
+
<div class="ulist"><ul>
|
6195
|
+
<li>
|
6196
|
+
<p>
|
6197
|
+
One must start Phusion Passenger separately from the web server, namely by starting the Flying Passenger daemon. This daemon must - to an extent - be separately configured and managed from the web server.
|
6198
|
+
</p>
|
6199
|
+
</li>
|
6200
|
+
<li>
|
6201
|
+
<p>
|
6202
|
+
The web server must be configured to forward requests to the Flying Passenger daemon.
|
6203
|
+
</p>
|
6204
|
+
</li>
|
6205
|
+
<li>
|
6206
|
+
<p>
|
6207
|
+
You should beware of the <a href="#flying_passenger_caveats">caveats and limitations</a>.
|
6208
|
+
</p>
|
6209
|
+
</li>
|
6210
|
+
</ul></div>
|
6211
|
+
<div class="sect3">
|
6212
|
+
<a href="javascript:void(0)" class="comments empty" title="Add a comment"><span class="count"></span></a><span class="anchor_helper" id="_requirements_2"></span><h4 data-comment-topic="requirements-1ntkin3" data-anchor="_requirements_2">9.9.1. Requirements</h4>
|
6213
|
+
<div class="paragraph"><p>At this time, this feature is <strong>only available in the Enterprise version of Phusion Passenger for Nginx</strong>. You must have Phusion Passenger for Nginx properly installed.</p></div>
|
6214
|
+
</div>
|
6215
|
+
<div class="sect3">
|
6216
|
+
<a href="javascript:void(0)" class="comments empty" title="Add a comment"><span class="count"></span></a><span class="anchor_helper" id="_basic_usage"></span><h4 data-comment-topic="basic-usage-joifsk" data-anchor="_basic_usage">9.9.2. Basic usage</h4>
|
6217
|
+
<div class="paragraph"><p>Start the Flying Passenger daemon by invoking the <span class="monospaced">flying-passenger</span> command. The only required option is <span class="monospaced">--socket-file</span>. Depending on whether you wish to enable <a href="#user_switching">User Switching</a>, you have to start <span class="monospaced">flying-passenger</span> with root privileges or not.</p></div>
|
6218
|
+
<div class="listingblock">
|
6219
|
+
<div class="content monospaced">
|
6220
|
+
<pre>$ sudo flying-passenger --socket-file=/var/run/flying-passenger.sock
|
6221
|
+
I, [2013-06-14T09:10:13.095339 #77179] INFO -- : Welcome to Flying Passenger 4.1.0
|
6222
|
+
I, [2013-06-14T09:10:13.095339 #77179] INFO -- : Starting PassengerWatchdog...
|
6223
|
+
I, [2013-06-14T09:10:13.097036 #77179] INFO -- : PassengerWatchdog started on PID 77181
|
6224
|
+
...
|
6225
|
+
I, [2013-06-14T09:10:13.129017 #77179] INFO -- : PassengerWatchdog initialized properly
|
6226
|
+
I, [2013-06-14T09:10:13.129127 #77179] INFO -- : Flying Passenger up and listening on /var/run/flying-passenger.sock!</pre>
|
6227
|
+
</div>
|
6228
|
+
</div>
|
6229
|
+
<div class="paragraph"><p>Now configure Phusion Passenger for Nginx to make use of the Flying Passenger daemon, by setting the <span class="monospaced">passenger_fly_with</span> option to the socket filename:</p></div>
|
6230
|
+
<div class="listingblock">
|
6231
|
+
<div class="content monospaced">
|
6232
|
+
<pre>http {
|
6233
|
+
...
|
6234
|
+
passenger_fly_with /var/run/flying-passenger.sock;
|
6235
|
+
...
|
6236
|
+
}</pre>
|
6237
|
+
</div>
|
6238
|
+
</div>
|
6239
|
+
<div class="paragraph"><p>After (re)starting Nginx, Nginx + Flying Passenger is fully operational:</p></div>
|
6240
|
+
<div class="listingblock">
|
6241
|
+
<div class="content monospaced">
|
6242
|
+
<pre>$ sudo /path-to/nginx</pre>
|
6243
|
+
</div>
|
6244
|
+
</div>
|
6245
|
+
<div class="paragraph"><p>You can test it by adding a virtual host for a web app:</p></div>
|
6246
|
+
<div class="listingblock">
|
6247
|
+
<div class="content monospaced">
|
6248
|
+
<pre>http {
|
6249
|
+
...
|
6250
|
+
|
6251
|
+
server {
|
6252
|
+
listen 80;
|
6253
|
+
server_name www.foo.local;
|
6254
|
+
root /webapps/foo/public;
|
6255
|
+
passenger_enabled on;
|
6256
|
+
}
|
6257
|
+
}</pre>
|
6258
|
+
</div>
|
6259
|
+
</div>
|
6260
|
+
<div class="paragraph"><p>Verify that it works by making an HTTP request to it:</p></div>
|
6261
|
+
<div class="listingblock">
|
6262
|
+
<div class="content monospaced">
|
6263
|
+
<pre>$ curl http://www.foo.local/</pre>
|
6264
|
+
</div>
|
6265
|
+
</div>
|
6266
|
+
<div class="paragraph"><p>Now let’s verify that restarting the web server does not restart the just-spawned application process. Run <span class="monospaced">passenger-status</span> to obtain the PID of the application process:</p></div>
|
6267
|
+
<div class="listingblock">
|
6268
|
+
<div class="content monospaced">
|
6269
|
+
<pre>$ sudo passenger-status
|
6270
|
+
Version: 4.1.0
|
6271
|
+
Date : 2013-06-14 09:21:51 -0400
|
6272
|
+
.---------- General information -----------
|
6273
|
+
Max pool size : 6
|
6274
|
+
Processes : 1
|
6275
|
+
Requests in top-level queue : 0
|
6276
|
+
|
6277
|
+
.---------- Application groups -----------
|
6278
|
+
/webapps/foo#default:
|
6279
|
+
App root: /webapps/foo
|
6280
|
+
Requests in queue: 0
|
6281
|
+
* PID: 77283 Sessions: 0 Processed: 1 Uptime: 2s
|
6282
|
+
CPU: 1% Memory : 8M Last used: 2s ago</pre>
|
6283
|
+
</div>
|
6284
|
+
</div>
|
6285
|
+
<div class="paragraph"><p>As you can see, the PID of the application process is <strong>77283</strong>. Now let’s see what happens if we restart Nginx:</p></div>
|
6286
|
+
<div class="listingblock">
|
6287
|
+
<div class="content monospaced">
|
6288
|
+
<pre>$ sudo /path-to/nginx -s stop
|
6289
|
+
$ sudo /path-to/nginx
|
6290
|
+
$ sudo passenger-status</pre>
|
6291
|
+
</div>
|
6292
|
+
</div>
|
6293
|
+
<div class="paragraph"><p>The application process should remain there, unchanged:</p></div>
|
6294
|
+
<div class="listingblock">
|
6295
|
+
<div class="content monospaced">
|
6296
|
+
<pre>$ sudo passenger-status
|
6297
|
+
Version: 4.1.0
|
6298
|
+
Date : 2013-06-14 09:21:51 -0400
|
6299
|
+
.---------- General information -----------
|
6300
|
+
Max pool size : 6
|
6301
|
+
Processes : 1
|
6302
|
+
Requests in top-level queue : 0
|
6303
|
+
|
6304
|
+
.---------- Application groups -----------
|
6305
|
+
/webapps/foo#default:
|
6306
|
+
App root: /webapps/foo
|
6307
|
+
Requests in queue: 0
|
6308
|
+
* PID: 77283 Sessions: 0 Processed: 1 Uptime: 18s
|
6309
|
+
CPU: 1% Memory : 8M Last used: 18s ago</pre>
|
6310
|
+
</div>
|
6311
|
+
</div>
|
6312
|
+
</div>
|
6313
|
+
<div class="sect3">
|
6314
|
+
<a href="javascript:void(0)" class="comments empty" title="Add a comment"><span class="count"></span></a><span class="anchor_helper" id="configuring_flying_passenger"></span><h4 data-comment-topic="configuring-flying-passenger-1v35vgg" data-anchor="configuring_flying_passenger">9.9.3. Configuring Flying Passenger</h4>
|
6315
|
+
<div class="paragraph"><p>Flying Passenger gets <strong>some</strong> configuration from the web server, but not all. In particular, most web server directives that are only valid in the <span class="monospaced">http</span> context, e.g. <a href="#PassengerLogLevel">passenger_log_level</a>, have no effect when using Flying Passenger. Instead, you are supposed to pass these configuration directives through command line options to the Flying Passenger daemon. Configuration directives that have no effect on Flying Passenger are documented as such. You can assume that configuration directives that are not documented as such, work fine on Flying Passenger.</p></div>
|
6316
|
+
<div class="paragraph"><p>For example, to achieve the same effect as setting passenger_log_level to 2, run the Flying Passenger daemon as follows:</p></div>
|
6317
|
+
<div class="listingblock">
|
6318
|
+
<div class="content monospaced">
|
6319
|
+
<pre>$ sudo flying-passenger --socket-file=/var/run/flying-passenger.sock --log-level=2</pre>
|
6320
|
+
</div>
|
6321
|
+
</div>
|
6322
|
+
<div class="paragraph"><p>Currently, not all configuration directives have a Flying Passenger equivalent. Run the following command to see an overview of available options:</p></div>
|
6323
|
+
<div class="listingblock">
|
6324
|
+
<div class="content monospaced">
|
6325
|
+
<pre>$ flying-passenger --help</pre>
|
6326
|
+
</div>
|
6327
|
+
</div>
|
6328
|
+
</div>
|
6329
|
+
<div class="sect3">
|
6330
|
+
<a href="javascript:void(0)" class="comments empty" title="Add a comment"><span class="count"></span></a><span class="anchor_helper" id="_managing_the_flying_passenger_daemon"></span><h4 data-comment-topic="managing-the-flying-passenger-daemon-1bng2bu" data-anchor="_managing_the_flying_passenger_daemon">9.9.4. Managing the Flying Passenger daemon</h4>
|
6331
|
+
<div class="paragraph"><p>The Flying Passenger daemon runs in the foreground by default. This is undesirable on server environments. You can make it go into the background by passing <span class="monospaced">--daemonize</span>, <span class="monospaced">--log-file</span> and <span class="monospaced">--pid-file</span>:</p></div>
|
6332
|
+
<div class="listingblock">
|
6333
|
+
<div class="content monospaced">
|
6334
|
+
<pre>$ sudo flying-passenger --socket-file=/var/run/flying-passenger.sock \
|
6335
|
+
--daemonize --log-file=/var/log/flying-passenger.log \
|
6336
|
+
--pid-file=/var/run/flying-passenger.pid</pre>
|
6337
|
+
</div>
|
6338
|
+
</div>
|
6339
|
+
<div class="paragraph"><p>You can shut down a Flying Passenger daemon by sending SIGINT or SIGTERM to it:</p></div>
|
6340
|
+
<div class="listingblock">
|
6341
|
+
<div class="content monospaced">
|
6342
|
+
<pre>$ kill `cat /var/run/flying-passenger.pid`</pre>
|
6343
|
+
</div>
|
6344
|
+
</div>
|
6345
|
+
<div class="paragraph"><p>We recommend using <a href="http://cr.yp.to/daemontools.html">daemontools</a> or <a href="http://smarden.org/runit/">runit</a> for managing the Flying Passenger daemon. These tools will allow automatically starting the Flying Passenger daemon at boot, and will automatically restart the daemon if it crashes. You can create and enable a daemontools/runit service as folows:</p></div>
|
6346
|
+
<div class="listingblock">
|
6347
|
+
<div class="content monospaced">
|
6348
|
+
<pre>$ sudo mkdir /etc/service/flying-passenger
|
6349
|
+
$ sudo nano /etc/service/flying-passenger/run
|
6350
|
+
#!/bin/sh
|
6351
|
+
exec /path-to/flying-passenger \
|
6352
|
+
--socket-file=/var/run/flying-passenger.sock \
|
6353
|
+
--log-file=/var/log/flying-passenger.log \
|
6354
|
+
--pid-file=/var/run/flying-passenger.pid</pre>
|
6355
|
+
</div>
|
6356
|
+
</div>
|
6357
|
+
<div class="paragraph"><p>Immediately after creating the <span class="monospaced">run</span> file, daemontools/runit automatically runs it to start the daemon. Note that the location (<span class="monospaced">/etc/service</span>) depends on the OS or Linux distros. Sometimes it’s <span class="monospaced">/service</span>. Also note that we start the Flying Passenger daemon without <span class="monospaced">--daemonize</span>.</p></div>
|
6358
|
+
<div class="paragraph"><p>To shut down a daemontools/runit-managed daemon, you need to use <span class="monospaced">svc -d /etc/service/flying-passenger</span> (daemontools) or <span class="monospaced">sv stop /etc/service/flying-passenger</span> (runit) instead of sending a signal to the process.</p></div>
|
6359
|
+
</div>
|
6360
|
+
<div class="sect3">
|
6361
|
+
<a href="javascript:void(0)" class="comments empty" title="Add a comment"><span class="count"></span></a><span class="anchor_helper" id="flying_passenger_caveats"></span><h4 data-comment-topic="caveats-and-limitations-lz3rbb" data-anchor="flying_passenger_caveats">9.9.5. Caveats and limitations</h4>
|
6362
|
+
<div class="paragraph"><p>Beware of the following caveats and limitations when using Flying Passenger:</p></div>
|
6363
|
+
<div class="ulist"><ul>
|
6364
|
+
<li>
|
6365
|
+
<p>
|
6366
|
+
The Nginx executable <strong>must</strong> be compiled with the same version of Phusion Passenger as the Flying Passenger daemon. Failing to meet this requirement may result in cryptic errors, or may result in certain features not working, until you’ve fixed the situation. When upgrading Phusion Passenger, you must restart both Nginx and the Flying Passenger daemon.
|
6367
|
+
</p>
|
6368
|
+
</li>
|
6369
|
+
<li>
|
6370
|
+
<p>
|
6371
|
+
The <a href="#PassengerRoot">passenger_root</a> directive has no effect. When using Flying Passenger, you are not supposed to set <span class="monospaced">passenger_root</span>.
|
6372
|
+
</p>
|
6373
|
+
</li>
|
6374
|
+
<li>
|
6375
|
+
<p>
|
6376
|
+
When you add a new application to the web server configuration, Flying Passenger will automatically pick up the application’s settings and spawn this new application upon the first request to it. However it is not capable of automatically starting the new app before a request has been sent to it (i.e. <a href="#PassengerPreStart">passenger_pre_start</a>-like behavior is not available in this case). As a workaround, you can send an HTTP request to your application after starting the daemon, which forces it to spawn application processes.
|
6377
|
+
</p>
|
6378
|
+
</li>
|
6379
|
+
<li>
|
6380
|
+
<p>
|
6381
|
+
When you remove an application from the web server configuration, Flying Passenger will not detect the removal and will not shut down the associated application processes. Killing the application processes will also not help, because Flying Passenger will restart them per the (now-removed, but still in the Flying Passenger daemon’s memory) <a href="#PassengerMinInstances">passenger_min_instances</a> settings. At the moment, there are two ways to get rid of those processes:
|
6382
|
+
</p>
|
6383
|
+
<div class="ulist"><ul>
|
6384
|
+
<li>
|
6385
|
+
<p>
|
6386
|
+
Before removing the application from the web server configuration, explicitly set its <span class="monospaced">passenger_min_instances</span> to 0. Next, send a request to it, which will cause the Flying Passenger daemon to take over the new <span class="monospaced">passenger_min_instances 0</span> option. You can then proceed with removing the application from the web server configuration, and restarting the web server. Finally, kill the PIDs associated to those application processes and remove the application configuration.
|
6387
|
+
</p>
|
6388
|
+
</li>
|
6389
|
+
<li>
|
6390
|
+
<p>
|
6391
|
+
Restart the Flying Passenger daemon.
|
6392
|
+
</p>
|
6393
|
+
</li>
|
6394
|
+
</ul></div>
|
6395
|
+
</li>
|
6396
|
+
</ul></div>
|
6397
|
+
</div>
|
6398
|
+
</div>
|
6399
|
+
<div class="sect2">
|
6400
|
+
<a href="javascript:void(0)" class="comments empty" title="Add a comment"><span class="count"></span></a><span class="anchor_helper" id="_x_sendfile_support"></span><h3 data-comment-topic="x-sendfile-support-1cgyykw" data-anchor="_x_sendfile_support">9.10. X-Sendfile support</h3>
|
5941
6401
|
<div class="paragraph"><p>Phusion Passenger does not provide X-Sendfile support by itself. Please install
|
5942
6402
|
<a href="http://tn123.ath.cx/mod_xsendfile/">mod_xsendfile</a> for X-Sendfile support.</p></div>
|
5943
6403
|
</div>
|
5944
6404
|
<div class="sect2">
|
5945
|
-
<a href="javascript:void(0)" class="comments empty" title="Add a comment"><span class="count"></span></a><span class="anchor_helper" id="_upload_progress"></span><h3 data-comment-topic="upload-progress-71cyl7" data-anchor="_upload_progress">9.
|
6405
|
+
<a href="javascript:void(0)" class="comments empty" title="Add a comment"><span class="count"></span></a><span class="anchor_helper" id="_upload_progress"></span><h3 data-comment-topic="upload-progress-71cyl7" data-anchor="_upload_progress">9.11. Upload progress</h3>
|
5946
6406
|
<div class="paragraph"><p>Phusion Passenger does not provide upload progress support by itself. Please
|
5947
6407
|
try drogus’s <a href="http://github.com/drogus/apache-upload-progress-module/tree/master">
|
5948
6408
|
Apache upload progress module</a> instead.</p></div>
|
@@ -6457,6 +6917,332 @@ has no effect.</p></div>
|
|
6457
6917
|
</div>
|
6458
6918
|
</div>
|
6459
6919
|
</div>
|
6920
|
+
<div class="sect1">
|
6921
|
+
<a href="javascript:void(0)" class="comments empty" title="Add a comment"><span class="count"></span></a><span class="anchor_helper" id="about_environment_variables"></span><h2 data-comment-topic="appendix-d-about-environment-variables-1lebv1u" data-anchor="about_environment_variables">14. Appendix D: About environment variables</h2>
|
6922
|
+
<div class="sectionbody">
|
6923
|
+
<div class="paragraph"><p>The Phusion Passenger compilation process can be customized with environment variables.</p></div>
|
6924
|
+
<div class="paragraph"><p>Environment variables are named values that affect how the system works. For example they tell the system where to look for commands (the <span class="monospaced">PATH</span> variable) or where to look for libraries (<span class="monospaced">LD_LIBRARY_PATH</span>). Their names are often in all-uppercase. Sometimes people refer to an environment variable with a dollar sign <span class="monospaced">$</span> in front, but that’s the same thing: when people say "the $PATH environment variable" they mean "the PATH environment variable". This is because the dollar sign <span class="monospaced">$</span> is a shell syntax for refering to an environment variable, as you will learn later.</p></div>
|
6925
|
+
<div class="paragraph"><p>Environment variables are set on a <strong>per-process</strong> basis, but they are <strong>inherited</strong> by child processes. This means that if you set environment variables in process A, another already running process B will not see these new environment variables. But if A spawns a child process C, then C will have all environment variables that A had. If you once again change the environment variables in A, then C will not see the changes.</p></div>
|
6926
|
+
<div class="paragraph"><p>The per-process nature of environment variables some implications. When you set environment variables in your <span class="monospaced">bashrc</span> or other bash startup files…</p></div>
|
6927
|
+
<div class="ulist"><ul>
|
6928
|
+
<li>
|
6929
|
+
<p>
|
6930
|
+
…only newly spawned bash shells see them.
|
6931
|
+
</p>
|
6932
|
+
</li>
|
6933
|
+
<li>
|
6934
|
+
<p>
|
6935
|
+
…the web server usually does not see them, because the web server tends to be started from init scripts, not from bash.
|
6936
|
+
</p>
|
6937
|
+
</li>
|
6938
|
+
<li>
|
6939
|
+
<p>
|
6940
|
+
…cron jobs do not see them, because cron jobs' environment variables are entirely dictated by their crontabs.
|
6941
|
+
</p>
|
6942
|
+
</li>
|
6943
|
+
</ul></div>
|
6944
|
+
<div class="admonitionblock">
|
6945
|
+
<table><tr>
|
6946
|
+
<td class="icon">
|
6947
|
+
<img src="./images/icons/note.png" alt="Note">
|
6948
|
+
</td>
|
6949
|
+
<td class="content">Because this chapter is meant for beginners, it assumes that the reader uses the bash shell. This chapter does not describe instructions for zsh, csh or other shells. We assume that users of other shells are familiar with the Bourne shell syntax, and know how to apply the instructions in this chapter in their shells' native syntaxes.</td>
|
6950
|
+
</tr></table>
|
6951
|
+
</div>
|
6952
|
+
<div class="sect2">
|
6953
|
+
<a href="javascript:void(0)" class="comments empty" title="Add a comment"><span class="count"></span></a><span class="anchor_helper" id="_working_with_environment_variables"></span><h3 data-comment-topic="working-with-environment-variables-85e6aa" data-anchor="_working_with_environment_variables">14.1. Working with environment variables</h3>
|
6954
|
+
<div class="paragraph"><p>You can see all environment variables in your shell by running the following command:</p></div>
|
6955
|
+
<div class="listingblock">
|
6956
|
+
<div class="content">
|
6957
|
+
<!-- Generator: GNU source-highlight 2.11.1
|
6958
|
+
by Lorenzo Bettini
|
6959
|
+
http://www.lorenzobettini.it
|
6960
|
+
http://www.gnu.org/software/src-highlite -->
|
6961
|
+
<pre><tt>env</tt></pre>
|
6962
|
+
</div>
|
6963
|
+
</div>
|
6964
|
+
<div class="paragraph"><p>You can set an evironment variable with the syntax <span class="monospaced">export <NAME>=<VALUE></span>. For example, to set the <span class="monospaced">APXS2</span> variable to the value <span class="monospaced">/usr/sbin/apxs2</span>:</p></div>
|
6965
|
+
<div class="listingblock">
|
6966
|
+
<div class="content">
|
6967
|
+
<!-- Generator: GNU source-highlight 2.11.1
|
6968
|
+
by Lorenzo Bettini
|
6969
|
+
http://www.lorenzobettini.it
|
6970
|
+
http://www.gnu.org/software/src-highlite -->
|
6971
|
+
<pre><tt><span style="font-weight: bold"><span style="color: #0000FF">export</span></span> <span style="color: #009900">APXS2</span><span style="color: #990000">=</span>/usr/sbin/apxs<span style="color: #993399">2</span></tt></pre>
|
6972
|
+
</div>
|
6973
|
+
</div>
|
6974
|
+
<div class="paragraph"><p>Any process that you run from your shell from that point on will have said environment variable:</p></div>
|
6975
|
+
<div class="listingblock">
|
6976
|
+
<div class="content">
|
6977
|
+
<!-- Generator: GNU source-highlight 2.11.1
|
6978
|
+
by Lorenzo Bettini
|
6979
|
+
http://www.lorenzobettini.it
|
6980
|
+
http://www.gnu.org/software/src-highlite -->
|
6981
|
+
<pre><tt><span style="font-weight: bold"><span style="color: #0000FF">export</span></span> <span style="color: #009900">APXS2</span><span style="color: #990000">=</span>/usr/sbin/apxs<span style="color: #993399">2</span>
|
6982
|
+
ruby -e <span style="color: #FF0000">'p ENV["APXS2"]'</span>
|
6983
|
+
<span style="font-style: italic"><span style="color: #9A1900"># => "/usr/sbin/apxs2"</span></span></tt></pre>
|
6984
|
+
</div>
|
6985
|
+
</div>
|
6986
|
+
<div class="admonitionblock">
|
6987
|
+
<table><tr>
|
6988
|
+
<td class="icon">
|
6989
|
+
<img src="./images/icons/note.png" alt="Note">
|
6990
|
+
</td>
|
6991
|
+
<td class="content">
|
6992
|
+
<div class="title">The "export" keyword is important</div>
|
6993
|
+
<div class="paragraph"><p>You <strong>must</strong> set the <span class="monospaced">export</span> keyword. If you omit the <span class="monospaced">export</span> keyword then the environment variable will not be visible to other processes:</p></div>
|
6994
|
+
<div class="listingblock">
|
6995
|
+
<div class="content">
|
6996
|
+
<!-- Generator: GNU source-highlight 2.11.1
|
6997
|
+
by Lorenzo Bettini
|
6998
|
+
http://www.lorenzobettini.it
|
6999
|
+
http://www.gnu.org/software/src-highlite -->
|
7000
|
+
<pre><tt><span style="color: #009900">APXS2</span><span style="color: #990000">=</span>/usr/sbin/apxs<span style="color: #993399">2</span>
|
7001
|
+
ruby -e <span style="color: #FF0000">'p ENV["APXS2"]'</span>
|
7002
|
+
<span style="font-style: italic"><span style="color: #9A1900"># => nil</span></span></tt></pre>
|
7003
|
+
</div>
|
7004
|
+
</div>
|
7005
|
+
</td>
|
7006
|
+
</tr></table>
|
7007
|
+
</div>
|
7008
|
+
<div class="paragraph"><p>You can reference an environment variable in your shell by typing the <span class="monospaced">$</span> sign followed by the environment variable’s name. For example, to see the value of the <span class="monospaced">PATH</span> variable:</p></div>
|
7009
|
+
<div class="listingblock">
|
7010
|
+
<div class="content">
|
7011
|
+
<!-- Generator: GNU source-highlight 2.11.1
|
7012
|
+
by Lorenzo Bettini
|
7013
|
+
http://www.lorenzobettini.it
|
7014
|
+
http://www.gnu.org/software/src-highlite -->
|
7015
|
+
<pre><tt>echo <span style="color: #009900">$PATH</span></tt></pre>
|
7016
|
+
</div>
|
7017
|
+
</div>
|
7018
|
+
<div class="paragraph"><p>You can also use this trick to extend the value of an environment variable:</p></div>
|
7019
|
+
<div class="listingblock">
|
7020
|
+
<div class="content">
|
7021
|
+
<!-- Generator: GNU source-highlight 2.11.1
|
7022
|
+
by Lorenzo Bettini
|
7023
|
+
http://www.lorenzobettini.it
|
7024
|
+
http://www.gnu.org/software/src-highlite -->
|
7025
|
+
<pre><tt><span style="font-weight: bold"><span style="color: #0000FF">export</span></span> <span style="color: #009900">PATH</span><span style="color: #990000">=</span>/usr/bin
|
7026
|
+
|
7027
|
+
<span style="font-style: italic"><span style="color: #9A1900"># Prepends '/opt/local/bin', so that it becomes /opt/local/bin:/usr/bin</span></span>
|
7028
|
+
<span style="font-weight: bold"><span style="color: #0000FF">export</span></span> <span style="color: #009900">PATH</span><span style="color: #990000">=</span>/opt/local/bin<span style="color: #990000">:</span><span style="color: #009900">$PATH</span>
|
7029
|
+
<span style="font-style: italic"><span style="color: #9A1900"># Appends '/usr/local/bin', so that it becomes /opt/local/bin:/usr/bin:/usr/local/bin</span></span>
|
7030
|
+
<span style="font-weight: bold"><span style="color: #0000FF">export</span></span> <span style="color: #009900">PATH</span><span style="color: #990000">=</span><span style="color: #009900">$PATH</span><span style="color: #990000">:</span>/usr/local/bin</tt></pre>
|
7031
|
+
</div>
|
7032
|
+
</div>
|
7033
|
+
</div>
|
7034
|
+
<div class="sect2">
|
7035
|
+
<a href="javascript:void(0)" class="comments empty" title="Add a comment"><span class="count"></span></a><span class="anchor_helper" id="_the_path_environment_variable"></span><h3 data-comment-topic="the-path-environment-variable-p8e32r" data-anchor="_the_path_environment_variable">14.2. The PATH environment variable</h3>
|
7036
|
+
<div class="paragraph"><p>The <span class="monospaced">PATH</span> environment variable dictates where the system looks for command. It is a colon-separated list of directories. If you get a "command not found" error while you know that the command is installed, then setting <span class="monospaced">PATH</span> will help. For example suppose that the command <span class="monospaced">frobnicator</span> is in <span class="monospaced">/opt/local/bin</span>:</p></div>
|
7037
|
+
<div class="listingblock">
|
7038
|
+
<div class="content">
|
7039
|
+
<!-- Generator: GNU source-highlight 2.11.1
|
7040
|
+
by Lorenzo Bettini
|
7041
|
+
http://www.lorenzobettini.it
|
7042
|
+
http://www.gnu.org/software/src-highlite -->
|
7043
|
+
<pre><tt>user@localhost bash$ frobnicator
|
7044
|
+
bash<span style="color: #990000">:</span> frobnicator<span style="color: #990000">:</span> <span style="font-weight: bold"><span style="color: #0000FF">command</span></span> not found</tt></pre>
|
7045
|
+
</div>
|
7046
|
+
</div>
|
7047
|
+
<div class="paragraph"><p>We verify that <span class="monospaced">/opt/local/bin</span> is not in <span class="monospaced">PATH</span>:</p></div>
|
7048
|
+
<div class="listingblock">
|
7049
|
+
<div class="content">
|
7050
|
+
<!-- Generator: GNU source-highlight 2.11.1
|
7051
|
+
by Lorenzo Bettini
|
7052
|
+
http://www.lorenzobettini.it
|
7053
|
+
http://www.gnu.org/software/src-highlite -->
|
7054
|
+
<pre><tt>user@localhost bash$ echo <span style="color: #009900">$PATH</span>
|
7055
|
+
/bin<span style="color: #990000">:</span>/usr/bin<span style="color: #990000">:</span>/usr/local/bin</tt></pre>
|
7056
|
+
</div>
|
7057
|
+
</div>
|
7058
|
+
<div class="paragraph"><p>We can run <span class="monospaced">frobnicator</span> through it’s full path…</p></div>
|
7059
|
+
<div class="listingblock">
|
7060
|
+
<div class="content">
|
7061
|
+
<!-- Generator: GNU source-highlight 2.11.1
|
7062
|
+
by Lorenzo Bettini
|
7063
|
+
http://www.lorenzobettini.it
|
7064
|
+
http://www.gnu.org/software/src-highlite -->
|
7065
|
+
<pre><tt>user@localhost bash$ /opt/local/bin/frobnicator
|
7066
|
+
<span style="font-style: italic"><span style="color: #9A1900"># => success!</span></span></tt></pre>
|
7067
|
+
</div>
|
7068
|
+
</div>
|
7069
|
+
<div class="paragraph"><p>…or we can add <span class="monospaced">/opt/local/bin</span> to <span class="monospaced">PATH</span>.</p></div>
|
7070
|
+
<div class="listingblock">
|
7071
|
+
<div class="content">
|
7072
|
+
<!-- Generator: GNU source-highlight 2.11.1
|
7073
|
+
by Lorenzo Bettini
|
7074
|
+
http://www.lorenzobettini.it
|
7075
|
+
http://www.gnu.org/software/src-highlite -->
|
7076
|
+
<pre><tt>user@localhost bash$ <span style="font-weight: bold"><span style="color: #0000FF">export</span></span> <span style="color: #009900">PATH</span><span style="color: #990000">=</span><span style="color: #009900">$PATH</span><span style="color: #990000">:</span>/opt/local/bin
|
7077
|
+
user@localhost bash$ frobnicator
|
7078
|
+
<span style="font-style: italic"><span style="color: #9A1900"># => success!</span></span></tt></pre>
|
7079
|
+
</div>
|
7080
|
+
</div>
|
7081
|
+
</div>
|
7082
|
+
<div class="sect2">
|
7083
|
+
<a href="javascript:void(0)" class="comments empty" title="Add a comment"><span class="count"></span></a><span class="anchor_helper" id="_making_environment_variables_permanent"></span><h3 data-comment-topic="making-environment-variables-permanent-13x0l4h" data-anchor="_making_environment_variables_permanent">14.3. Making environment variables permanent</h3>
|
7084
|
+
<div class="paragraph"><p>When you exit your shell, the evironment variable changes are lost. There is no standard method to set environment variables system-wide, so you have to set them in different configuration files for different services.</p></div>
|
7085
|
+
<div class="sect3">
|
7086
|
+
<a href="javascript:void(0)" class="comments empty" title="Add a comment"><span class="count"></span></a><span class="anchor_helper" id="_bash"></span><h4 data-comment-topic="bash-1pktn63" data-anchor="_bash">14.3.1. bash</h4>
|
7087
|
+
<div class="paragraph"><p>To make environment variables permanent for future bash sessions <strong>for the current user</strong>, add them to your <span class="monospaced">~/.bashrc</span>:</p></div>
|
7088
|
+
<div class="listingblock">
|
7089
|
+
<div class="content">
|
7090
|
+
<!-- Generator: GNU source-highlight 2.11.1
|
7091
|
+
by Lorenzo Bettini
|
7092
|
+
http://www.lorenzobettini.it
|
7093
|
+
http://www.gnu.org/software/src-highlite -->
|
7094
|
+
<pre><tt>echo <span style="color: #FF0000">'export FOO=bar'</span> <span style="color: #990000">>></span> <span style="color: #990000">~/.</span>bashrc
|
7095
|
+
echo <span style="color: #FF0000">'export PATH=/usr/local/bin:$PATH'</span> <span style="color: #990000">>></span> <span style="color: #990000">~/.</span>bashrc</tt></pre>
|
7096
|
+
</div>
|
7097
|
+
</div>
|
7098
|
+
<div class="paragraph"><p>To make them permanent for future bash sessions <strong>for all users</strong>, add them to <span class="monospaced">/etc/bashrc</span>.</p></div>
|
7099
|
+
<div class="admonitionblock">
|
7100
|
+
<table><tr>
|
7101
|
+
<td class="icon">
|
7102
|
+
<img src="./images/icons/note.png" alt="Note">
|
7103
|
+
</td>
|
7104
|
+
<td class="content">Depending on the system, the bashrc file may have a different filename. On Debian and Ubuntu, it’s <span class="monospaced">/etc/bash.bashrc</span>.</td>
|
7105
|
+
</tr></table>
|
7106
|
+
</div>
|
7107
|
+
</div>
|
7108
|
+
<div class="sect3">
|
7109
|
+
<a href="javascript:void(0)" class="comments empty" title="Add a comment"><span class="count"></span></a><span class="anchor_helper" id="_apache"></span><h4 data-comment-topic="apache-15zqjvi" data-anchor="_apache">14.3.2. Apache</h4>
|
7110
|
+
<div class="admonitionblock">
|
7111
|
+
<table><tr>
|
7112
|
+
<td class="icon">
|
7113
|
+
<img src="./images/icons/note.png" alt="Note">
|
7114
|
+
</td>
|
7115
|
+
<td class="content">This subsection describes how to set environment variables on Apache itself, not on apps served through Phusion Passenger for Apache. The environment variables you set here will be passed to all apps, but you cannot customize them on a per-app basis. See also <a href="#env_vars_passenger_apps">Setting environment variables on Phusion Passenger-served apps</a>.</td>
|
7116
|
+
</tr></table>
|
7117
|
+
</div>
|
7118
|
+
<div class="paragraph"><p>On Debian and Ubuntu, with an Apache installed through apt, Apache environment variables are defined in the file <span class="monospaced">/etc/apache2/envvars</span>. This is a shell script so environment variables must be specified with the shell syntax.</p></div>
|
7119
|
+
<div class="paragraph"><p>On Red Hat, Fedora, CentOS and ScientificLinux, with an Apache installed through YUM, Apache environment variables are defined in <span class="monospaced">/etc/sysconfig/httpd</span>.</p></div>
|
7120
|
+
<div class="paragraph"><p>On OS X they are defined in <span class="monospaced">/System/Library/LaunchDaemons/org.apache.httpd.plist</span>, as explained <a href="/System/Library/LaunchDaemons/org.apache.httpd.plist">here on Stack Overflow</a>.</p></div>
|
7121
|
+
<div class="paragraph"><p>On other systems, or if you did not install Apache through the system’s package manager, the configuration file for environment variables is specific to the vendor that supplied Apache. There may not even be such a configuration file. You should contact the vendor for support.</p></div>
|
7122
|
+
</div>
|
7123
|
+
<div class="sect3">
|
7124
|
+
<a href="javascript:void(0)" class="comments empty" title="Add a comment"><span class="count"></span></a><span class="anchor_helper" id="_nginx"></span><h4 data-comment-topic="nginx-l7ztbb" data-anchor="_nginx">14.3.3. Nginx</h4>
|
7125
|
+
<div class="admonitionblock">
|
7126
|
+
<table><tr>
|
7127
|
+
<td class="icon">
|
7128
|
+
<img src="./images/icons/note.png" alt="Note">
|
7129
|
+
</td>
|
7130
|
+
<td class="content">This subsection describes how to set environment variables on Nginx itself, not on apps served through Phusion Passenger for Nginx. The environment variables you set here will be passed to all apps, but you cannot customize them on a per-app basis. See also <a href="#env_vars_passenger_apps">Setting environment variables on Phusion Passenger-served apps</a>.</td>
|
7131
|
+
</tr></table>
|
7132
|
+
</div>
|
7133
|
+
<div class="paragraph"><p>If you installed Nginx through <a href="#install_on_debian_ubuntu">the Brightbox packages</a>, then you can define environment variables in <span class="monospaced">/etc/default/nginx</span>. This is a shell script so you must use the <span class="monospaced">export FOO=bar</span> syntax.</p></div>
|
7134
|
+
<div class="paragraph"><p>Otherwise, environment variables are best set through the script which starts Nginx. For example, if you installed Nginx from source and you used
|
7135
|
+
the Nginx init script described in the <a href="http://www.modrails.com/documentation/Users%20guide%20Nginx.html">Phusion Passenger Users Guide, Nginx version</a>,
|
7136
|
+
then you should edit that script to define the environment variables. Those init scripts are regular shell scripts, so use the <span class="monospaced">export FOO=bar</span> syntax. Just make sure your set your environment variables before the script starts Nginx.</p></div>
|
7137
|
+
<div class="admonitionblock">
|
7138
|
+
<table><tr>
|
7139
|
+
<td class="icon">
|
7140
|
+
<img src="./images/icons/note.png" alt="Note">
|
7141
|
+
</td>
|
7142
|
+
<td class="content">Setting environment variables on Nginx has no effect on the <a href="#flying_passenger">Flying Passenger daemon</a> because the daemon is started seperately. You should set the environment variables in the shell right before starting the daemon.</td>
|
7143
|
+
</tr></table>
|
7144
|
+
</div>
|
7145
|
+
</div>
|
7146
|
+
<div class="sect3">
|
7147
|
+
<a href="javascript:void(0)" class="comments empty" title="Add a comment"><span class="count"></span></a><span class="anchor_helper" id="_cron"></span><h4 data-comment-topic="cron-1kjp7ck" data-anchor="_cron">14.3.4. cron</h4>
|
7148
|
+
<div class="paragraph"><p>To make environment variables permanent for cron jobs, add those variables to the relevant crontab. But note that inside crontabs you cannot refer to existing environment variables with the <span class="monospaced">$</span> syntax because crontabs are not shell scripts. You have to specify the entire value.</p></div>
|
7149
|
+
<div class="listingblock">
|
7150
|
+
<div class="title">What to put in "crontab -e"</div>
|
7151
|
+
<div class="content monospaced">
|
7152
|
+
<pre># Environment variable definitions
|
7153
|
+
FOO=bar
|
7154
|
+
APXS2=/usr/sbin/apxs2
|
7155
|
+
|
7156
|
+
# **WRONG!** You cannot refer to existing variables with the `$` syntax!
|
7157
|
+
PATH=/usr/bin:$PATH
|
7158
|
+
# **WRONG!** You cannot use the 'export' keyword!
|
7159
|
+
export PATH=/usr/bin:/usr/local/bin
|
7160
|
+
# Correct:
|
7161
|
+
PATH=/usr/bin:/usr/local/bin
|
7162
|
+
|
7163
|
+
# Jobs:
|
7164
|
+
# m h dom mon dow command
|
7165
|
+
* * * * * frobnicator</pre>
|
7166
|
+
</div>
|
7167
|
+
</div>
|
7168
|
+
</div>
|
7169
|
+
<div class="sect3">
|
7170
|
+
<a href="javascript:void(0)" class="comments empty" title="Add a comment"><span class="count"></span></a><span class="anchor_helper" id="env_vars_passenger_apps"></span><h4 data-comment-topic="phusion-passenger-served-apps-478vyt" data-anchor="env_vars_passenger_apps">14.3.5. Phusion Passenger-served apps</h4>
|
7171
|
+
<div class="paragraph"><p>You can pass environment variables to Phusion Passenger-served apps through various methods:</p></div>
|
7172
|
+
<div class="ulist"><ul>
|
7173
|
+
<li>
|
7174
|
+
<p>
|
7175
|
+
When running Apache, use the <span class="monospaced">PassEnv</span> and <span class="monospaced">SetEnv</span> directives of <a href="http://httpd.apache.org/docs/2.4/mod/mod_env.html">mod_env</a>. This is supported starting from Phusion Passenger 4.0.
|
7176
|
+
</p>
|
7177
|
+
</li>
|
7178
|
+
<li>
|
7179
|
+
<p>
|
7180
|
+
When running Nginx, use the <span class="monospaced">env</span> directive. Unlike Apache, Nginx’s <span class="monospaced">env</span> directive can only be set globally and cannot be customized on a per-virtual host basis.
|
7181
|
+
</p>
|
7182
|
+
</li>
|
7183
|
+
<li>
|
7184
|
+
<p>
|
7185
|
+
Through your <span class="monospaced">bashrc</span>. Starting from version 4.0, Phusion Passenger 4.0 spawns applications through bash and inherit all bash environment variables. Phusion Passenger Standalone tends to be started from the shell and thus inherits all environment variables set by the shell.
|
7186
|
+
</p>
|
7187
|
+
</li>
|
7188
|
+
<li>
|
7189
|
+
<p>
|
7190
|
+
Through Apache and Nginx, as described earlier in this chapter. Any environment variables that you set on Apache and Nginx itself are inherited by Phusion Passenger, and thus by Phusion Passenger-served apps as well.
|
7191
|
+
</p>
|
7192
|
+
</li>
|
7193
|
+
<li>
|
7194
|
+
<p>
|
7195
|
+
Through the application itself. Most programming languages provide APIs for setting environment variables. For example in Ruby you can write:
|
7196
|
+
</p>
|
7197
|
+
<div class="listingblock">
|
7198
|
+
<div class="content">
|
7199
|
+
<!-- Generator: GNU source-highlight 2.11.1
|
7200
|
+
by Lorenzo Bettini
|
7201
|
+
http://www.lorenzobettini.it
|
7202
|
+
http://www.gnu.org/software/src-highlite -->
|
7203
|
+
<pre><tt>ENV<span style="color: #990000">[</span><span style="color: #FF0000">'FOO'</span><span style="color: #990000">]</span> <span style="color: #990000">=</span> <span style="color: #FF0000">'bar'</span></tt></pre>
|
7204
|
+
</div>
|
7205
|
+
</div>
|
7206
|
+
<div class="paragraph"><p>In Python you can write:</p></div>
|
7207
|
+
<div class="listingblock">
|
7208
|
+
<div class="content">
|
7209
|
+
<!-- Generator: GNU source-highlight 2.11.1
|
7210
|
+
by Lorenzo Bettini
|
7211
|
+
http://www.lorenzobettini.it
|
7212
|
+
http://www.gnu.org/software/src-highlite -->
|
7213
|
+
<pre><tt><span style="font-weight: bold"><span style="color: #000080">import</span></span> os
|
7214
|
+
os<span style="color: #990000">.</span>environ<span style="color: #990000">[</span><span style="color: #FF0000">'FOO'</span><span style="color: #990000">]</span> <span style="color: #990000">=</span> <span style="color: #FF0000">'bar'</span></tt></pre>
|
7215
|
+
</div>
|
7216
|
+
</div>
|
7217
|
+
</li>
|
7218
|
+
</ul></div>
|
7219
|
+
</div>
|
7220
|
+
</div>
|
7221
|
+
<div class="sect2">
|
7222
|
+
<a href="javascript:void(0)" class="comments empty" title="Add a comment"><span class="count"></span></a><span class="anchor_helper" id="env_vars_and_sudo"></span><h3 data-comment-topic="environment-variables-and-sudo-1odzcpz" data-anchor="env_vars_and_sudo">14.4. Environment variables and sudo</h3>
|
7223
|
+
<div class="paragraph"><p>The <span class="monospaced">sudo</span> command resets all environment variables before running the specified command, for security reasons. So if you set environment variables before running <span class="monospaced">sudo passenger-install-xxx-module</span>, <span class="monospaced">sudo passenger-status</span> or any other commands, then the environment variables are not correctly passed to the command. You can solve this by running sudo with <span class="monospaced">-E</span> (preserve environment variables):</p></div>
|
7224
|
+
<div class="listingblock">
|
7225
|
+
<div class="content">
|
7226
|
+
<!-- Generator: GNU source-highlight 2.11.1
|
7227
|
+
by Lorenzo Bettini
|
7228
|
+
http://www.lorenzobettini.it
|
7229
|
+
http://www.gnu.org/software/src-highlite -->
|
7230
|
+
<pre><tt>user@localhost bash$ <span style="font-weight: bold"><span style="color: #0000FF">export</span></span> <span style="color: #009900">APXS2</span><span style="color: #990000">=</span>/usr/sbin/apxs<span style="color: #993399">2</span>
|
7231
|
+
user@localhost bash$ sudo -E passenger-install-apache<span style="color: #993399">2</span>-module</tt></pre>
|
7232
|
+
</div>
|
7233
|
+
</div>
|
7234
|
+
<div class="paragraph"><p>Alternatively, you can obtain a root prompt with sudo first, and <strong>then</strong> set the environment variables, before running any further commands:</p></div>
|
7235
|
+
<div class="listingblock">
|
7236
|
+
<div class="content monospaced">
|
7237
|
+
<pre>user@localhost bash$ sudo -s
|
7238
|
+
Password: ...
|
7239
|
+
root@localhost bash# export APXS2=/usr/sbin/apxs2
|
7240
|
+
root@localhost bash# passenger-install-apache2-module</pre>
|
7241
|
+
</div>
|
7242
|
+
</div>
|
7243
|
+
</div>
|
7244
|
+
</div>
|
7245
|
+
</div>
|
6460
7246
|
</div>
|
6461
7247
|
<div id="footnotes"><hr></div>
|
6462
7248
|
<div id="footer">
|