The combined availability of the iPad, OS X Server, and eZ Publish presents unique opportunities for delivering a great content experience throughout enterprises of all sizes. Apple OS X is a unix styled Operating System. While not as widely used or renowned as others, it provides undeniable advantages for installation and deployment simplicity, as well as controlled cost.
While iTunes, iPhone, and iPad make the headlines, the server systems powering the billions of downloads of multimedia and binary content have risen to meet the challenge in relative silence. Silence is a good thing in the server world, where "being noticed" means a problem has occurred.
Apple provides excellent documentation and tools to allow practically anyone to set up and configure OS X Server for Web services. MySQL and PHP are not enabled in a default configuration. The purpose of this document is to describe how to enable MySQL and PHP, then install eZ Publish in the simplest possible way.
While the Server version is not strictly required, and there are other options like the MAMP project, this document specifically focuses on how to deploy eZ Publish on the Snow Leopard Server Version of OS X.
Know how to use Finder for navigating file structure, Safari for downloading files.
Get it here for ~$500USD and install on any hardware that meets the requirements : http://store.apple.com/us/product/MC190Z/A
Here, choose the server version, get a 1 terabyte appliance, for about ~$1000 USD :
http://store.apple.com/us/browse/home/shop_mac/family/mac_mini
Or here to balance power required to available budget : http://store.apple.com/us/browse/home/shop_mac/family/xserve
Download eZ Publish here : http://ez.no/download.
Available support options here : http://ez.no/support_and_services
The following presumes Snow Leopard Server is installed and configured, with Web services enabled. Also that an admin account user is logged in to perform the eZ install.
Login as admin on the Snow Leopard Server to begin. Then :
Launch the Server Admin tool, it is the globe looking icon located on the dock in Snow Leopard Server. The Server Admin tool can also be installed on any Snow Leopard Mac for remote administration for use with headless servers or remote administration needs. It is the same tool and works the same way regardless of where it is installed.
There will be what Apple terms a "flippy triangle" to the left of the server you are administrating.
Click the flippy triangle to drop down a list of available services. The "Web" service is at the bottom of the service listings and should already be enabled. If not, open Server Preferences from the dock, then "Web", slide the switch to "On", and reload the services list.
Open a browser to the server address and verify the Mac OS X Server splash page displays.
The Mac-Apache-Mysql-PHP stack is included in every copy of Snow Leopard Server. Diehard linux-unix will be pleased to know that these, and other popular open source command line tools, are pre-installed and configured in Snow Leopard Server. PHP and MySQL must be enabled and started to complete the functionality.
The Apple documentation for working with the stack on SL Server http://www.apple.com/server/macosx/resources/documentation.html then select the "Web Technologies Administration" pdf download.
Current versions as of March 2010:
Power users need not settle for the default shipping versions of any of these, or wait on Apple to update versions. With Xcode tools installed, OS X Server can compile and run any POSIX compliant unix code. More http://www.apple.com/opensource/ and http://opensource.apple.com/
This adds MySQL to the services list under the flippy triangle, but notice that it is not started, the ball grayed rather than green like the other active services. That means a little more work is required.
To verify MySQL is working,
"CREATE DATABASE `ez43` DEFAULT CHARACTER SET utf8 COLLATE utf8_general_ci;"
Power users are not stuck with the default shipping version of MySQL. See "Upgrading MySQL" in the MAMP stack documentation referenced earlier.
Custom php versions and extensions work much the same on OS X as on any linux-unix. See appendix below or go to php.net for more info.
Launch Safari Web browser and test run an install. Be sure to use fully qualified domain name so it will be visible on lan/wan.
Click Finetune and receive a permissions error with 3 lines of commands in the top box.
Select all three lines and copy to the clipboard (Cmd-C). Click the Terminal application to make it active again. Switch to root user using su command. Unlike the standard version, su is enabled by default in the Server version of OS X. The password is the same as the original admin password unless it was forcibly changed after setup.
Paste from the clipboard into command window. The first two lines of command will run automatically. Pressing the enter key is required to invoke the final line. Should end with a clear prompt.
ImageMagick, Postgres, and Text Creation functions warnings remain, and can be safely ignored for now. OS X Server uses imageGD, eZ will notify you of that near the end of the install. See the Appendix for more regarding custom php extensions.
Make a choice of eZ extensions. The Website Interface with Demo content is my choice, any others should work.
Verify the database just created for this install is selected in the drop down selector.
Next appears a site security warning, which in my reasonably well researched opinion may be safely ignored. Don't take my word for it, do your own study. You may find reason to believe that OS X has tweaks in place on top of the virtual server system that make it secure enough for your use.
You have shell access with su, so creating an .htaccess file is not a problem. The problem with custom .htaccess on OS X Server is that Apache AllowOverride is set to None which means .htaccess files will be ignored. This is a server wide security setting, so do not change that setting wholesale for the server. Change it only on a per directory basis. If you feel .htaccess is necessary, and know what you are doing:
/etc/apache2/httpd.conf is the apache configuration file, then something like the below into the Directory listings.
<Directory "/Library/Webserver/Documents/ez43"> AllowOverride All </Directory>
Congratulations, that is it. Nice job by the eZ team to make such an easy install on OS X Snow Leopard Server. I have done it many times, on many servers, it is just this simple.
The steps outlined above provide a fast, high tech, high PR value way to roll out community portals and social networking sites. Simplicity is retained as the primary feature for the entire system. Simplicity-removing complexity, is gaining mindset as the key to systems of the future that will serve users first. Apple understands the power of simple, eZ Publish too. Beyond understanding the problem, both continue innovating, doing something about it! Combining the technologies builds powerful information systems that push the envelope of innovation forward. Rock solid stability, simple administration, easy updates, pick the three you need for your project, and add long term commitment and sound business models.
This article and more regarding how to use eZ Publish and Apple technologies to deliver the best possible Web content experience here :
http://webportalmaster.com/index.php/eng/osx/HowTo/Install-eZ-4.3-on-Snow-Leopard-Server
There are millions of webmasters, only one webportalmaster.com, where the quest to define the best Web communications models continues, daily.
Additional information links:
Working close to the metal, OS X is not much different than any other unix-linux. Like any distro, the paths are the biggest difference. Apple adds "user friendly" for their own users on top. They do this without taking anything away from "user friendly" for cli types.
If custom php versions are needed to meet requirements, http://ez.no/ezpublish/requirements, install Xcode tools from the install DVD for OS X Server, then start here.. http://www.opensource.apple.com/source/apache_mod_php/
Also, Marc Liyanage at Entropy.ch packages a compiled php for OS X which includes many popular extensions not included in a default install. http://www.entropy.ch/software/macosx/php/
For testing compiles, particularly as php transitions to version 6, OS X Server provides a nice interface for switching.
Essentially a pretty face wrapping Dynamic Shared Objects Support in httpd.conf.
To use custom php extensions without re-compiling php, Apache 2.2 on OS X (like most distro's) supports dynamic loading of php extensions via php.ini.
Or cli, "apachectl restart" will do the trick. No need to load the Server Admin tool just to restart apache if you are already at the command line. Use what you know.
Thanks for reading.
This article is available in PDF for offline reading : Install eZ Publish 4.3 on Apple Snow Leopard Server - PDF Version
Doug is Apple ACTC Server certified, blogs at http://www.ipliance.com. Experienced in 3gl and open source. Believes CMS, the Web, and mobile devices are key to 5gl interfaces.
Timing: | Jan 18 2025 00:08:53 |
Script start | |
Timing: | Jan 18 2025 00:08:53 |
Module start 'layout' | |
Timing: | Jan 18 2025 00:08:53 |
Module start 'content' | |
Timing: | Jan 18 2025 00:08:53 |
Module end 'content' | |
Timing: | Jan 18 2025 00:08:53 |
Script end |
Total runtime | 0.3767 sec |
Peak memory usage | 4,096.0000 KB |
Database Queries | 108 |
Checkpoint | Start (sec) | Duration (sec) | Memory at start (KB) | Memory used (KB) |
---|---|---|---|---|
Script start | 0.0000 | 0.0058 | 591.3359 | 152.6406 |
Module start 'layout' | 0.0058 | 0.0034 | 743.9766 | 39.4844 |
Module start 'content' | 0.0092 | 0.3649 | 783.4609 | 1,153.2969 |
Module end 'content' | 0.3741 | 0.0026 | 1,936.7578 | 32.2813 |
Script end | 0.3767 | 1,969.0391 |
Accumulator | Duration (sec) | Duration (%) | Count | Average (sec) |
---|---|---|---|---|
Ini load | ||||
Load cache | 0.0040 | 1.0727 | 16 | 0.0003 |
Check MTime | 0.0014 | 0.3656 | 16 | 0.0001 |
Mysql Total | ||||
Database connection | 0.0005 | 0.1383 | 1 | 0.0005 |
Mysqli_queries | 0.1016 | 26.9614 | 108 | 0.0009 |
Looping result | 0.0011 | 0.2912 | 106 | 0.0000 |
Template Total | 0.3467 | 92.0 | 2 | 0.1733 |
Template load | 0.0020 | 0.5341 | 2 | 0.0010 |
Template processing | 0.3446 | 91.4766 | 2 | 0.1723 |
Template load and register function | 0.0002 | 0.0473 | 1 | 0.0002 |
states | ||||
state_id_array | 0.0115 | 3.0445 | 20 | 0.0006 |
state_identifier_array | 0.0101 | 2.6803 | 21 | 0.0005 |
Override | ||||
Cache load | 0.0071 | 1.8832 | 303 | 0.0000 |
Sytem overhead | ||||
Fetch class attribute name | 0.0032 | 0.8387 | 35 | 0.0001 |
Fetch class attribute can translate value | 0.0003 | 0.0721 | 18 | 0.0000 |
class_abstraction | ||||
Instantiating content class attribute | 0.0001 | 0.0157 | 35 | 0.0000 |
XML | ||||
Image XML parsing | 0.0402 | 10.6624 | 18 | 0.0022 |
General | ||||
dbfile | 0.0338 | 8.9595 | 71 | 0.0005 |
String conversion | 0.0000 | 0.0026 | 4 | 0.0000 |
Note: percentages do not add up to 100% because some accumulators overlap |
Usage | Requested template | Template | Template loaded | Edit | Override |
---|---|---|---|---|---|
1 | node/view/full.tpl | full/article.tpl | extension/sevenx/design/simple/override/templates/full/article.tpl | ||
17 | content/datatype/view/ezxmltext.tpl | <No override> | extension/community_design/design/suncana/templates/content/datatype/view/ezxmltext.tpl | ||
63 | content/datatype/view/ezxmltags/paragraph.tpl | <No override> | extension/ezwebin/design/ezwebin/templates/content/datatype/view/ezxmltags/paragraph.tpl | ||
14 | content/datatype/view/ezxmltags/separator.tpl | <No override> | extension/community_design/design/suncana/templates/content/datatype/view/ezxmltags/separator.tpl | ||
14 | content/datatype/view/ezxmltags/newpage.tpl | <No override> | extension/community/design/standard/templates/content/datatype/view/ezxmltags/newpage.tpl | ||
16 | content/datatype/view/ezxmltags/header.tpl | <No override> | design/standard/templates/content/datatype/view/ezxmltags/header.tpl | ||
17 | content/datatype/view/ezxmltags/link.tpl | <No override> | design/standard/templates/content/datatype/view/ezxmltags/link.tpl | ||
18 | content/datatype/view/ezxmltags/embed.tpl | <No override> | design/standard/templates/content/datatype/view/ezxmltags/embed.tpl | ||
18 | content/view/embed.tpl | embed/image.tpl | extension/sevenx/design/simple/override/templates/embed/image.tpl | ||
18 | content/datatype/view/ezimage.tpl | <No override> | extension/sevenx/design/simple/templates/content/datatype/view/ezimage.tpl | ||
6 | content/datatype/view/ezxmltags/line.tpl | <No override> | design/standard/templates/content/datatype/view/ezxmltags/line.tpl | ||
11 | content/datatype/view/ezxmltags/li.tpl | <No override> | design/standard/templates/content/datatype/view/ezxmltags/li.tpl | ||
8 | content/datatype/view/ezxmltags/ul.tpl | <No override> | design/standard/templates/content/datatype/view/ezxmltags/ul.tpl | ||
17 | content/datatype/view/ezxmltags/emphasize.tpl | <No override> | design/standard/templates/content/datatype/view/ezxmltags/emphasize.tpl | ||
2 | content/datatype/view/ezxmltags/literal.tpl | <No override> | extension/community/design/standard/templates/content/datatype/view/ezxmltags/literal.tpl | ||
1 | content/datatype/view/ezxmltags/strong.tpl | <No override> | design/standard/templates/content/datatype/view/ezxmltags/strong.tpl | ||
1 | content/datatype/view/ezxmltags/embed-inline.tpl | <No override> | design/standard/templates/content/datatype/view/ezxmltags/embed-inline.tpl | ||
1 | content/view/embed-inline.tpl | <No override> | design/standard/templates/content/view/embed-inline.tpl | ||
1 | print_pagelayout.tpl | <No override> | extension/community/design/community/templates/print_pagelayout.tpl | ||
Number of times templates used: 244 Number of unique templates used: 19 |
Time used to render debug report: 0.0001 secs