File: installation-on-macosx.rst

package info (click to toggle)
mod-wsgi 5.0.2-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 2,824 kB
  • sloc: ansic: 15,512; python: 3,697; makefile: 219; sh: 107
file content (163 lines) | stat: -rw-r--r-- 7,302 bytes parent folder | download | duplicates (5)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
=======================
Installation On MacOS X
=======================

If you are using MacOS X, mod_wsgi can be compiled from source code
against the standard versions of Python and Apache httpd server supplied
with the operating system. To do this though you will first need to have
installed the Xcode command line tools.

The Xcode command line tools package provides a C compiler, along with
header files and support tools for the Apache httpd server. If you have
already set up your system so as to be able to install additional Python
packages which include C extensions, you likely will already have the
Xcode command line tools.

Install Xcode command line tools
--------------------------------

To install the Xcode command line tools you should run the command::

    xcode-select --install

If this gives you back the error message::

    xcode-select: error: command line tools are already installed, use "Software Update" to install updates

then the tools have already been installed. As noted by the warning
message, do make sure you have run a system software update to ensure
that you have the latest versions of these tools.

If you do not already have the Xcode command line tools installed, running
that ``xcode-select`` command should result in you being prompted to
install them. This may ask you to provide the details of an administrator
account along with the password for that account.

Note that it is not necessary to install the whole of the Xcode
developer application from the MacOS X App Store, only the command line
tools using ``xcode-select``. If you have installed the Xcode developer
application, still ensure that the command line tools are installed and
ensure you have run the system software update.

Configuring and building mod_wsgi
---------------------------------

If you are using the Python and Apache httpd server packages provided with
the operating system, all you need to do to configure the mod_wsgi source
code before building it is to run in the mod_wsgi source code directory::

    ./configure

This should yield output similar to::

    checking for apxs2... no
    checking for apxs... /usr/sbin/apxs
    checking for gcc... gcc
    checking whether the C compiler works... yes
    checking for C compiler default output file name... a.out
    checking for suffix of executables...
    checking whether we are cross compiling... no
    checking for suffix of object files... o
    checking whether we are using the GNU C compiler... yes
    checking whether gcc accepts -g... yes
    checking for gcc option to accept ISO C89... none needed
    checking for prctl... no
    checking Apache version... 2.4.18
    checking for python... /usr/bin/python
    configure: creating ./config.status
    config.status: creating Makefile

The ``configure`` script should show that it has detected ``apxs`` as being
located at ``/usr/sbin/apxs`` and ``python`` as being at ``/usr/bin/python``.

If you get different values for ``apxs`` and ``python`` then it means
that you likely have a separate installation of Python or the Apache
httpd server installed on your system. If this is the case, to ensure that
you use the versions of Python and Apache httpd server provided with the
operating system instead use the command::

    ./configure --with-python=/usr/bin/python --with-apxs=/usr/sbin/apxs

Once you have configured the source code by running ``configure``, you
can build mod_wsgi using the command::

    make

This will compile the mod_wsgi source code and produce a single
``mod_wsgi.so`` file which then needs to be installed into a common
location so that the Apache httpd server can use it.

Installing the mod_wsgi module
------------------------------

What you need to do to install the mod_wsgi module depends on which version
of MacOS X you are using.

For the Apache httpd server provided by the operating system, the directory
``/usr/libexec/apache2`` is used to store the compiled modules. Prior to
MacOS X El Capitan (10.11) this directory was writable and the mod_wsgi
module could be installed here along with all the default modules. With the
introduction of the System Integrity Protection (SIP_) feature in MacOS X
El Capitan this directory is not writable, not even to the root user.

Because of this, if you are using a version of MacOS X prior to MacOS X El
Capitan (10.11) you can use the command::

    sudo make install

to install the mod_wsgi module. As ``sudo`` is being run, you will be
prompted for your password. The module will be installed into the
directory ``/usr/libexec/apache2``. Within the Apache httpd server
configuration file you can then use the standard ``LoadModule`` line
of::

    LoadModule wsgi_module libexec/apache2/mod_wsgi.so

If however you are using MacOS X El Capitan (10.11) or later, the mod_wsgi
module will need to be installed into a different location. If you don't
and try to run just ``sudo make install``, it will fail with the output::

    ./apxs -i -S LIBEXECDIR=/usr/libexec/apache2 -n 'mod_wsgi' src/server/mod_wsgi.la
    /usr/share/httpd/build/instdso.sh SH_LIBTOOL='./libtool' src/server/mod_wsgi.la /usr/libexec/apache2
    ./libtool --mode=install install src/server/mod_wsgi.la /usr/libexec/apache2/
    libtool: install: install src/server/.libs/mod_wsgi.so /usr/libexec/apache2/mod_wsgi.so
    install: /usr/libexec/apache2/mod_wsgi.so: Operation not permitted
    apxs:Error: Command failed with rc=4653056
    .
    make: *** [install] Error 1

The directory you use to install the mod_wsgi module is up to you, but
one suggested option is that you use the directory
``/usr/local/httpd/modules``. Just ensure that this isn't already used
by a separate installation of the Apache httpd server.

To install the mod_wsgi module into this directory use the command::

    sudo make install LIBEXECDIR=/usr/local/httpd/modules

The output from the command will be similar to::

    mkdir -p /usr/local/httpd/modules
    ./apxs -i -S LIBEXECDIR=/usr/local/httpd/modules -n 'mod_wsgi' src/server/mod_wsgi.la
    /usr/share/httpd/build/instdso.sh SH_LIBTOOL='./libtool' src/server/mod_wsgi.la /usr/local/httpd/modules
    ./libtool --mode=install install src/server/mod_wsgi.la /usr/local/httpd/modules/
    libtool: install: install src/server/.libs/mod_wsgi.so /usr/local/httpd/modules/mod_wsgi.so
    libtool: install: install src/server/.libs/mod_wsgi.lai /usr/local/httpd/modules/mod_wsgi.la
    libtool: install: install src/server/.libs/mod_wsgi.a /usr/local/httpd/modules/mod_wsgi.a
    libtool: install: chmod 644 /usr/local/httpd/modules/mod_wsgi.a
    libtool: install: ranlib /usr/local/httpd/modules/mod_wsgi.a
    libtool: install: warning: remember to run `libtool --finish /usr/libexec/apache2'
    chmod 755 /usr/local/httpd/modules/mod_wsgi.so

The warning about needing to run ``libtool --finish`` can be ignored as it
is not required for everything to work.

With the mod_wsgi module installed in this location, the ``LoadModule`` line
in the Apache httpd configuration file should be::

    LoadModule wsgi_module /usr/local/httpd/modules/mod_wsgi.so

Normal steps to then configure the Apache httpd server and mod_wsgi for
your specific WSGI application would then be followed.

.. _SIP: https://en.wikipedia.org/wiki/System_Integrity_Protection