• Status: Solved
  • Priority: Medium
  • Security: Public
  • Views: 365
  • Last Modified:

cgi wont run under apache

hi all,
i wrote a cgi that use some so files(shared object).
when i run it from a shell, everything is ok.
when i run it as cgi, it failed and said it can't find the so  file.
i added to httpd.conf:
 "SetEnv LD_LIBRARY_PATH /mypath/toso"
and it still not working.

do you have any idea ????

appreciate any help
  • 5
  • 2
  • 2
  • +1
1 Solution
Why not just add the directories that contain the needed shared libs to /etc/ld.so.conf and run ldconfig to rebuild the cache. Then restart Apache and your cgi will be able to find the shared libs.
o_helmanAuthor Commented:
hi jlevie
i tried it but it still not working
is there a way to know in what directories the apache is looking when he search for so files?

I'd start with writing a wrapper script for your cgi like this:

#! /usr/bin/sh
echo "Content-Type:text/html"; echo ""
echo '<HTML><BODY><PRE>'
echo "/usr/bin/ldd /path/to/your.cgi"
      /usr/bin/ldd /path/to/your.cgi
echo '</PRE></BODY></HTML>'
exit 0
A proven path to a career in data science

At Springboard, we know how to get you a job in data science. With Springboard’s Data Science Career Track, you’ll master data science  with a curriculum built by industry experts. You’ll work on real projects, and get 1-on-1 mentorship from a data scientist.

Apache will use the system shared library search path as shown in /etc/ld.so.conf and any directories in the LD_LIBRARY_PATH env var of the shell that started Apache. You can check to see that the shared libs were found by ldconfig by examining the output of 'ldconfig -p'. Generally all that's necessary is to have the libs in the ld cache, but there are some cases where an application needs certain env variables set that tell it things about it's run time environment. What, exactly, are you trying to do in the cgi?
o_helmanAuthor Commented:
im building a cgi that use some 3rd party libraries to convert files.
i tried building a script and the strange thing happened:
when i run ldconfig -p from shell, he gave me all the necessary files from the right directory.
when i ran it from the script (as cgi) he didnt show the necessary so files. !!!!!!!!!!!!
like he doesn't have them.

how can this be?
o_helmanAuthor Commented:
my mistake.........it does show the right libs from the cgi

so whats wrong ??????????????/

o_helmanAuthor Commented:
here is the result of my script:
LD_LIBRARY_PATH= /home/ori/wiexp
/usr/bin/ldd /usr/local/apacge/cgi-bin/convert
        libsc_da.so => not found
        libsc_ex.so => not found
        libsc_fa.so => not found
        libsc_ch.so => not found
        libsc_fi.so => not found
        libsc_ut.so => not found

ldconfig -l
=> /home/ori/wiexp/libvs_zip.so
        libvs_xy.so (libc6) => /home/ori/wiexp/libvs_xy.so
        libvs_xl5.so (libc6) => /home/ori/wiexp/libvs_xl5.so
        libvs_w97.so (libc6) => /home/ori/wiexp/libvs_w97.so
        libvs_w6.so (libc6) => /home/ori/wiexp/libvs_w6.so
=> /home/ori/wiexp/libsc_da.so
        libsc_da.so(libc6) => /home/ori/wiexp/libsc_da.so
all the so that im looking for.
so whats wrong ?????????
any idea?

o_helmanAuthor Commented:
i solved the problem.
home/ori didnt have access for xwr. !!!!!!!!!!!!

i chmod to 777 and all is working now

thanks guys for your help  
chmod 555 should be enough
This question will be placed in PAQ, and points refunded.


Community Support Administrator  
Question has a verified solution.

Are you are experiencing a similar issue? Get a personalized answer when you ask a related question.

Have a better answer? Share it in a comment.

Join & Write a Comment

Featured Post

Free Tool: Port Scanner

Check which ports are open to the outside world. Helps make sure that your firewall rules are working as intended.

One of a set of tools we are providing to everyone as a way of saying thank you for being a part of the community.

  • 5
  • 2
  • 2
  • +1
Tackle projects and never again get stuck behind a technical roadblock.
Join Now