Changes for page Development Tools-Running Through Apache
Last modified by Aaron Rosenzweig on 2011/05/09 01:46
From version 26.1
edited by Mike Schrag
on 2007/07/23 21:42
on 2007/07/23 21:42
Change comment:
There is no comment for this version
Summary
-
Page properties (3 modified, 0 added, 0 removed)
Details
- Page properties
-
- Title
-
... ... @@ -1,1 +1,1 @@ 1 - Programming__WebObjects-Development Tools-Running Through Apache1 +Development Tools-Running Through Apache - Author
-
... ... @@ -1,1 +1,1 @@ 1 -XWiki. mschrag1 +XWiki.kiddyr - Content
-
... ... @@ -1,25 +1,33 @@ 1 -If you are accessing your application with URLs that look like http: ~/~/localhost:45437/cgi-bin/WebObjects/AppName.woa/Programming__WebObjects-Web Applications-Development-Direct Connect]]. See that page for why you don't want to be using Direct Connect. See this page for how to stop.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>>Development-Direct Connect]]. See that [[page>>Development-Direct Connect]] for why you don't want to be using Direct Connect. See this page for how to stop. 2 2 3 - =Turning on Apache=3 +A summary of the following steps that applies specifically to MacOS X 10.5.5 can be found here: [[Running Through Apache - Leopard & Snow Leopard Client - Summary>>Running Through Apache - Leopard & Snow Leopard Client - Summary]] 4 4 5 - Goto **System Preferences -> Sharing-> Services** and turnon**Personal Web Sharing** if it is not alreadyon.5 += Turning on Apache = 6 6 7 +Go to **System Preferences > Sharing > Services** and turn on **Personal Web Sharing** if it is not already on. 8 + 7 7 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. 8 8 9 -= Restarting ApacheFix#1: Explicitly Setting Your Hostname =11 += Optional Extra Configuration: Explicitly Setting Your Hostname = 10 10 11 11 {{info title="Useful Information"}} 12 12 13 -The changes in this section are only required if you want your hostname to be stable across network changes. While this simplifies many aspects of development (like testing cookies), it cause sproblems if you need to be able to access yourwebserverfrom a remote machine, including if you need to be able to test your web app from a Parallels VM.15 +The changes in this section are only required if you want your hostname to be stable across network changes. While this simplifies many aspects of development (like testing cookies and https), it may cause problems with those specific aspects (cookies, https, etc.) if you need to be able to access your dev machine from a remote machine, including if you need to be able to test your web app from a Parallels VM. 14 14 17 +Bonjour Delays: Apparently the procedure here is also useful for preventing "Bonjour" delays when you launch the browser to test your app on your development machine. 18 + 15 15 {{/info}} 16 16 17 -== Edit Apache Config 21 +== Edit Apache Config == 18 18 19 - Note: **Do NOT tryto usethe/ Rendezvous name of yourmachineinhisstep.**It will causeyou grief.Accept thisand don't even try. You havebeenwarned.23 +{{warning title="Bonjour, comment ça va? .... Trés bien, merci!"}} 20 20 21 - Edit**/etc/httpd/httpd.conf**,findthelinecontaining**ServerName**andchangeittothis:25 +*Do NOT try to use the Bonjour / Rendezvous name of your machine in this step.* It will cause you grief. Accept this and don't even try. You have been warned. 22 22 27 +{{/warning}} 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**. 30 + 23 23 {{code}} 24 24 25 25 ServerName localhost ... ... @@ -26,16 +26,68 @@ 26 26 27 27 {{/code}} 28 28 29 -That line may be commented out by default. You can simply uncomment it (remove the leading pound sign) and t henrestartapache: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 30 30 31 31 {{code}} 32 32 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 + 33 33 sudo apachectl restart 34 34 35 35 {{/code}} 36 36 37 -== Tell wotaskd toUseLocalhostToo==85 +== Tell the adaptor to use localhost == 38 38 87 +Edit **/System/Library/WebObjects/Adaptors/Apache2.2/apache.conf** to make sure that your enabled/uncommented WebObjectsConfig property looks like this: 88 + 89 +{{code}} 90 + 91 +WebObjectsConfig http://localhost:1085 10 92 + 93 +{{/code}} 94 + 95 +(Note on Tiger, aka OS X 10.4.X, replace **Apache2.2** with **Apache** in the path above) 96 + 97 +== Tell wotaskd to Use Localhost Too == 98 + 39 39 Edit **/System/Library/WebObjects/JavaApplications/wotaskd.woa/Contents/Resources/Properties** 40 40 41 41 Add this line after the **WOPort=1085** one: ... ... @@ -48,6 +48,8 @@ 48 48 49 49 Now you need to restart wotaskd: 50 50 111 +===== OS X Tiger 10.4 ===== 112 + 51 51 {{code}} 52 52 53 53 sudo systemstarter stop "WebObjects Services" ... ... @@ -57,82 +57,72 @@ 57 57 58 58 or 59 59 60 - restartwotaskdandwomonitor with launchctlifyour WebObjectsinstalllaunchesthat way.122 +===== OS X 10.5 Leopard (where launchd is used to control wotaskd) ===== 61 61 62 -== Finally, Configure your Application == 63 - 64 -Add or edit these launch parameters: 65 - 66 66 {{code}} 67 67 68 --WODirectConnectEnabled false 69 --WOHost localhost 70 --WOAdaptorURL http://localhost/cgi-bin/WebObjects 71 --WOPort 5555 126 +sudo launchctl stop com.apple.webobjects.wotaskd 72 72 73 73 {{/code}} 74 74 75 - The WOPort is optional, but useful if you wantconsistent URLs for bookmarks and such. Youcanuse any number you want, butit needs to be unique for eachapplication youlaunch (or rather,youcan only run one app instance on a given WOPortat a time). In WOLips, WOPort, WODirectConnectEnabled,andWOAdaptorURLalreadyexist and just need tobeupdated.WOHost does not, and needs to be added. The dashinfrontof thename ("-WOHost")is important and must be in the name forthesetting to workproperly.130 +launchd should automatically start wotaskd again for you if configured properly. 76 76 77 -You may wantto setthis in yourglobal WOLips settings so you don'thavetoset itevery time youmake anew launch configuration. You will need togobackandmodify existinglaunchconfigurations with these settings even if you set it globally.Global settings onlyapplyto newlycreated launch configurations.132 +You can check for whether wotaskd is running as a launchd job by typing 78 78 79 - = Restarting ApacheFix #2: Kickstart =134 +{{code}} 80 80 81 - Thealternative way to restart apacheisohavea scriptrun any time your network changes. It turnsout that OS X supports such a capability already via Kickstart.136 +sudo launchctl list | grep webobjects 82 82 83 - == Making a restart script ==138 +{{/code}} 84 84 85 - Create a scriptnamed/usr/local/bin/restartApache andsetthe contentsto:140 +which will give something like this: 86 86 87 87 {{code}} 88 88 89 -#!/bin/bash 90 -/usr/sbin/apachectl stop 91 -sleep 1 92 -/usr/sbin/apachectl start 144 +43 - com.apple.webobjects.wotaskd 93 93 94 94 {{/code}} 95 95 96 - ==ModifyingKicker==148 +(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"]] 97 97 98 -1. Edit /System/Library/SystemConfiguration/Kicker.bundle/Contents/Resources/Kicker.xml 99 -1. At the end of the <array> section, add the following block of XML: 150 +== Finally, Configure your Application == 100 100 152 +Add or edit these launch parameters: 153 + 101 101 {{code}} 102 102 103 - <dict> 104 - <key>execCommand</key> 105 - <string>/usr/local/bin/restartApache</string> 106 - <key>execUID</key> 107 - <integer>0</integer> 108 - <key>keys</key> 109 - <array> 110 - <string>State:/Network/Global/DNS</string> 111 - <string>State:/Network/Global/IPv4</string> 112 - <string>State:/Network/Global/IPv6</string> 113 - <string>State:/Network/Global/NetInfo</string> 114 - </array> 115 - <key>name</key> 116 - <string>restart_apache</string> 117 - </dict> 156 +-WODirectConnectEnabled false 157 +-WOHost localhost 158 +-WOAdaptorURL http://localhost/cgi-bin/WebObjects 159 +-WOPort 5555 118 118 119 119 {{/code}} 120 120 121 - ==Restart==163 +The WOPort is optional, but useful if you want consistent URLs for bookmarks and such. You can use any number you want, but it needs to be unique for each application you launch (or rather, you can only run one app instance on a given WOPort at a time). In WOLips, WOPort, WODirectConnectEnabled, and WOAdaptorURL already exist and just need to be updated. WOHost does not, and needs to be added. The dash in front of the name ("-WOHost") is important and must be in the name for the setting to work properly. 122 122 123 - Restart yourmachine(youmaybeable togetawaywithjustloggingoutand backin).Anynetworkchanges willnowautomatically restartApache.165 +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. 124 124 125 -= =ExtraCredit ==167 += Apache Restart = 126 126 127 - I also like to have a growlnotificationfire whenmyApacherestarts. Todothis:169 +{{info title="Why would I need this?"}} 128 128 129 - 1.grab thegrowlshellscript from http:~/~/www.macosxhints.com/dlfiles/growl_sh.txt.130 - 1.next,at the endofyour/usr/local/bin/restartApachescript,youcanadd:171 +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. 172 +If you already implemented the "localhost" explicit hostname setup above, then you will probably not need to bother with this section. 131 131 174 +No, really. Why would one need this? Is there a difference between ("apachectl stop" ; "apachectl start") and "apachectl restart"? If so, that may be a problem with apachectl. If there is a difference, why is the difference important? What bad thing will happen if one only uses "apachectl restart"? 175 + 176 + 177 +{{/info}} 178 + 179 +== Making a restart script == 180 + 181 +Create a script named /usr/local/bin/restartApache and set the contents to: 182 + 132 132 {{code}} 133 133 134 -export G_APPLICATION_ICON=EOModeler.app 135 -export G_TITLE=WebObjects 136 -/usr/local/bin/growl "Apache Restarted" 185 +#!/bin/bash 186 +/usr/sbin/apachectl stop 187 +sleep 1 188 +/usr/sbin/apachectl start 137 137 138 138 {{/code}}