on 2011 Jun 20 9:57 AM
Hi, I've been a long time user of SQL Anywhere, and I've just downloaded the latest for OSx. Everything is great, but after some searching around, I realized there was no pre-compiled version of the PHP module for OSx, although it is mentioned on the website for version 12. I've tried to compile & install it myself, but was not successful.
Is it possible a downloadable PHP module could be made available for OSx ?
Mac OSx 10.6.7 PHP 5.3.4
You can compile the SQL Anywhere module as an extension:
$ cd <sqlanywhere module source directory> $ phpize $ make $ make install
Once that's done, the module will be installed in your PHP extensions directory. You must also add an entry to your php.ini to load the module.
Now you need to ensure that the Apache process can find the SQL Anywhere client libraries.
What you need is the lib64
directory of your SQL Anywhere installation to be included in the DYLD_LIBRARY_PATH
environment variable (LD_LIBRARY_PATH
on Linux).
If you are using the "Web Sharing" option from your System Settings, you should be able to set this in /System/Library/LaunchDaemons/org.apache.httpd.plist
Add a tag something like:
<key>EnvironmentVariables</key> <dict> <key>DYLD_LIBRARY_PATH</key> <string>/Applications/SQLAnywhere12/System/lib64</string> </dict>
This should go at the same depth as the other key
tags.
If you are using another Apache installation, you will have to find the equivalent configuration file for your installation.
Note, too, that it is vital that the path you include (lib64 or lib32) refers to the same pointer size as the Apache process that's running.
You must be a registered user to add a comment. If you've already registered, sign in. Otherwise, register and sign in.
I will make a note to get a Mac OS X example posted somewhere. The reason I summarized the comments that led to an answer was so that it would be documented here on this forum. You are right, though. A more official documentation source would be nice.
Up to this point, when i encounter such a problem, I always go to the website first for documentation and examples. So for myself, had there been a detailed & complete example with reasonable documentation for this case, it would have saved me a lot of time. That seems logical for things that aren't justified or driven by customer demands. In any case, I'm very happy to have the problem solved, very happy with the product, and appreciate the support found here.
FWIW, Mohammed is going to add a README to the source distribution that will include build instructions and a few specific examples for configuring Apache. This is the easiest thing for us to distribute and keep up to date. PHP is a moving target, whereas our docs and white-papers tend to be more static. Also, if you are looking for how to build and install the module, you will already have the source code.
There are currently no plans to maintain a downloadable binary version of the PHP driver for Mac OS X. Maintaining these binary downloads would require engineering and QA effort that we would like to be able to justify with significant demand from customers.
If you have trouble compiling the module, please post details about your specific problem and we'll do our best to help you.
You must be a registered user to add a comment. If you've already registered, sign in. Otherwise, register and sign in.
Ok thank you, i do understand. I have successfully compiled php, including sqlanywhere, no compile errors, and i did a "sudo make install" also with no errors, but when i restart apache, its still running the old version of PHP. I think the new version is being installed in /usr/local/bin, instead of /usr/bin This is my best guess.
Any suggestions would be appreciated.
tom.
So you are compiling the SQL Anywhere module into PHP? Okay. Once you have it compiled, you will need to update the PHP module that's installed in Apache.
This may vary depending on your system. I found this blog post that might be helpful:
http://www.phpied.com/installing-php-and-apache-on-mac-osx-that-was-pretty-easy/
The alternative method is to leave the current PHP installation in place. You can compile the SQL Anywhere module as an extension:
$ cd <sqlanywhere module source directory> $ phpize $ make $ make install
Once that's done, the module will be installed in your PHP extensions directory. You must also add an entry to your php.ini
to load the module. Then it will be done.
Finally, you alternative worked, thank you! I have apache on my mac that is aware of sqlanywhere. I still have a problem on OSx that i previously had on Linux. The SQLAnywhere client version indicates this: "The SQLAnywhere client libraries could not be loaded. Please ensure that libdbcapi.so can be found in your LD_LIBRARY_PATH environment variable."
To solve this on Linux, (fedora) I had to create the following file: /etc/sysconfig/httpd In this file i put "source /Applications/SQLAnywhere12/System/bin64/sa_config.sh" I believe apache reads this file when starting up, and knows where the client libraries are.
I have no idea where, or what file to modify on OSx so apache will load the SQLAnywere client libraries.
Suggestions would be greatly appreciated once again!
tom.
Tom: FYI, note that I have been converting your responses (which have been answers) to comments. Rather than adding an answer when responding to a person's comment please use the "reply" button (the little box with arrow pointing up-and-right) which appears under each comment ... unless you are actually adding an answer to your original question. Thanks.
User | Count |
---|---|
71 | |
10 | |
8 | |
7 | |
7 | |
6 | |
6 | |
6 | |
6 | |
5 |
You must be a registered user to add a comment. If you've already registered, sign in. Otherwise, register and sign in.