Last modified by Aaron Rosenzweig on 2011/05/09 01:46

From version 34.1
edited by Kieran Kelleher
on 2008/11/23 19:28
Change comment: There is no comment for this version
To version 42.1
edited by Kieran Kelleher
on 2007/10/18 08:27
Change comment: There is no comment for this version

Summary

Details

Page properties
Content
... ... @@ -1,7 +1,5 @@
1 1  If you are accessing your application with URLs that look like [[http://localhost:45437/cgi-bin/WebObjects/AppName.woa/]] (with the xxx:portnum instead of xxxx/-portnum) ... then you are using the [[Evil Direct Connect>>Web Applications-Development-Direct Connect]]. See that [[page>>Web Applications-Development-Direct Connect]] for why you don't want to be using Direct Connect. See this page for how to stop.
2 2  
3 -A summary of the following steps that applies specifically to MacOS X 10.5.5 can be found here: [[Running Through Apache - Leopard Client 10.5.5 - Summary]]
4 -
5 5  = Turning on Apache =
6 6  
7 7  Go to **System Preferences > Sharing > Services** and turn on **Personal Web Sharing** if it is not already on.
... ... @@ -8,7 +8,7 @@
8 8  
9 9  When you turn on your web server, Apache will listen on the network interfaces that were configured when it starts. If you change networks, you may need to manually restart apache. You can do this by either stopping and restarting Personal Web Sharing, or you can run "apachectl restart" from the commandline as the root user. Because this can get annoying if you are working on a laptop, or periodically using VPN's, there are a couple ways to make this process easier.
10 10  
11 -= Optional Extra Configuration: Explicitly Setting Your Hostname =
9 += Restarting Apache Fix #1: Explicitly Setting Your Hostname =
12 12  
13 13  {{info title="Useful Information"}}
14 14  
... ... @@ -26,7 +26,7 @@
26 26  
27 27  {{/warning}}
28 28  
29 -Edit **/etc/httpd/httpd.conf**, find the line containing **ServerName** and change it to this. If you use Leopard (OS X 10.5), the file is at **/etc/apache2/httpd.conf**.
27 +Edit **/etc/httpd/httpd.conf**, find the line containing **ServerName** and change it to this:
30 30  
31 31  {{code}}
32 32  
... ... @@ -34,50 +34,10 @@
34 34  
35 35  {{/code}}
36 36  
37 -That line may be commented out by default. You can simply uncomment it (remove the leading pound sign). You will also need to find this block
35 +That line may be commented out by default. You can simply uncomment it (remove the leading pound sign) and then restart apache:
38 38  
39 39  {{code}}
40 40  
41 -# First, we configure the "default" to be a very restrictive set of
42 -# features.
43 -#
44 -<Directory />
45 - Options FollowSymLinks
46 - AllowOverride None
47 - Order deny,allow
48 - Deny from all
49 -</Directory>
50 -
51 -{{/code}}
52 -
53 -And modify like so:
54 -
55 -{{code}}
56 -
57 -# First, we configure the "default" to be a very restrictive set of
58 -# features.
59 -#
60 -<Directory />
61 - Options FollowSymLinks
62 - AllowOverride None
63 -# Order deny,allow
64 -# Deny from all
65 -</Directory>
66 -
67 -{{/code}}
68 -
69 -Got to the very end of **/etc/apache2/httpd.conf** and add :
70 -
71 -{{code}}
72 -
73 -Include /System/Library/WebObjects/Adaptors/Apache2.2/apache.conf
74 -
75 -{{/code}}
76 -
77 -Then restart apache:
78 -
79 -{{code}}
80 -
81 81  sudo apachectl restart
82 82  
83 83  {{/code}}
... ... @@ -84,7 +84,7 @@
84 84  
85 85  == Tell the adaptor to use localhost ==
86 86  
87 -Edit **/System/Library/WebObjects/Adaptors/Apache2.2/apache.conf** to make sure that your enabled/uncommented WebObjectsConfig property looks like this:
45 +Edit **/System/Library/WebObjects/Adaptors/Apache/apache.conf** to make sure that your enabled/uncommented WebObjectsConfig property looks like this:
88 88  
89 89  {{code}}
90 90  
... ... @@ -92,8 +92,6 @@
92 92  
93 93  {{/code}}
94 94  
95 -(Note on Tiger (OS X 10.4.X, replace **Apache2.2** with **Apache** in the path above)
96 -
97 97  == Tell wotaskd to Use Localhost Too ==
98 98  
99 99  Edit **/System/Library/WebObjects/JavaApplications/wotaskd.woa/Contents/Resources/Properties**
... ... @@ -118,7 +118,6 @@
118 118  or
119 119  
120 120  restart wotaskd and womonitor with launchctl if your WebObjects install launches that way.
121 -(In 10.5 it appears to be necessary to launch with launchctl. See [[Running Monitor and wotaskd on Mac OS X 10.5 "client">>WO 5.4 Getting Started||anchor="javamonitor"]]
122 122  
123 123  == Finally, Configure your Application ==
124 124  
... ... @@ -137,15 +137,10 @@
137 137  
138 138  You may want to set this in your global WOLips settings so you don't have to set it every time you make a new launch configuration. You will need to go back and modify existing launch configurations with these settings even if you set it globally. Global settings only apply to newly created launch configurations.
139 139  
140 -= Apache Restart =
95 += Restarting Apache Fix #2: Kickstart =
141 141  
142 -{{info title="Why would I need this?"}}
97 +The alternative way to restart apache is to have a script run any time your network changes. It turns out that OS X supports such a capability already via Kickstart.
143 143  
144 -If you have a laptop and you get an "Application cannot be found" or some such error in the browser after auto-switching networks (for example going from a work network to a home network), restarting apache can resolve the error condition most of the time. A script is shown below to do that.
145 -If you already implemented the "localhost" explicit hostname setup above, then you will probably not need to bother with this section.
146 -
147 -{{/info}}
148 -
149 149  == Making a restart script ==
150 150  
151 151  Create a script named /usr/local/bin/restartApache and set the contents to:
... ... @@ -158,3 +158,47 @@
158 158  /usr/sbin/apachectl start
159 159  
160 160  {{/code}}
111 +
112 +== Modifying Kicker ==
113 +
114 +1. Edit /System/Library/SystemConfiguration/Kicker.bundle/Contents/Resources/Kicker.xml
115 +1. At the end of the <array> section, add the following block of XML:
116 +
117 +{{code}}
118 +
119 +<dict>
120 + <key>execCommand</key>
121 + <string>/usr/local/bin/restartApache</string>
122 + <key>execUID</key>
123 + <integer>0</integer>
124 + <key>keys</key>
125 + <array>
126 + <string>State:/Network/Global/DNS</string>
127 + <string>State:/Network/Global/IPv4</string>
128 + <string>State:/Network/Global/IPv6</string>
129 + <string>State:/Network/Global/NetInfo</string>
130 + </array>
131 + <key>name</key>
132 + <string>restart_apache</string>
133 + </dict>
134 +
135 +{{/code}}
136 +
137 +== Restart ==
138 +
139 +Restart your machine (you may be able to get away with just logging out and back in). Any network changes will now automatically restart Apache.
140 +
141 +== Extra Credit ==
142 +
143 +I also like to have a growl notification fire when my Apache restarts. To do this:
144 +
145 +1. grab the growl shell script from [[http://www.macosxhints.com/dlfiles/growl_sh.txt]].
146 +1. next, at the end of your /usr/local/bin/restartApache script, you can add:
147 +
148 +{{code}}
149 +
150 +export G_APPLICATION_ICON=EOModeler.app
151 +export G_TITLE=WebObjects
152 +/usr/local/bin/growl "Apache Restarted"
153 +
154 +{{/code}}