您的位置:首页网页设计JSP教程 → 在Linux上架设支持JSP+PHP的Web服务器

在Linux上架设支持JSP+PHP的Web服务器

时间:2004/11/7 3:35:00来源:本站整理作者:蓝点我要评论(0)

  近年来Linux在服务器市场占有比例日渐攀升,除了缘于Linux的免费和安全性之外,还因为Linux上的应用服务日益丰富。大部分常见的服务都在Linux上有了较好的解决方案。而对于Intenet上应用最广泛的Web服务来说,Linux的表现就更为出色。谁也无法说 清Internet上究竟有多少个网站,但在众多网站中,采用PHP和JSP开发的网站无疑占居了极大的市场份额。下面就介绍一下如何在Linux上架设支持JSP+PHP+MySQL的Web服务器


  对于Web服务,apache无疑是首选。数据库方面选用MySQL,这对于一般应用也够了,当然Linux下也可以安装oracle、DB2等大型数据库,可是它们费用昂贵。至于对于开发语言的支持,JSP和PHP无疑是当前最主流和应用最广泛的web开发语言了。所有这些软件我们可以从以下网站上找到:


  Resin:http://www.caucho.com/
  JDK:http://java.sun.com/
  Apache:http://www.apache.org
  MySQLhttp://www.mysql.com
  PHP:http://www.php.net
  MM.MySQLhttp://mmmysql.sourceforge.net/


  从以上网站下载对应的软件,笔者下载的软件如下:


  mysql-4.0.15.tar.gz
  apache_1.3.28.tar.gz
  php-4.3.3.tar.gz
  resin-3.0.3.tar.gz
  mysql-connector-java-3.1.0-alpha.tar.gz
  j2sdk-1_4_2_01-linux-i586.bin


  一、安装MySQL


  MySQL的安装比较简单,但是编译过程可能有点长,具体步骤如下:


  # tar -xzpvf mysql-4.0.15.tar.gz
  # adduser  -s /bin/false mysql
  # ./configure  --prefix=/usr/local/terry_yu/mysql --enable-assembler
--with-innodb --with-charset=gb2312
  # make
  # make install
  # /usr/local/terry_yu/mysql/bin/mysql_install_db
  # chown -R root /usr/local/terry_yu/mysql/
  # chown -R mysql /usr/local/terry_yu/mysql/var
  # chgrp -R mysql /usr/local/terry_yu/mysql/
  # /usr/local/terry_yu/mysql/bin/mysql_install_db


  修改/etc/ld.so.conf,在最后加入以下一行:


  /usr/local/terry_yu/mysql/lib/mysql/lib
 
  然后执行以下命令:


  # ldconfig


  用以下命令启动MySQL


  /usr/local/terry_yu/mysql/bin/mysqld_safe &


  用以下命令修改MySQL的root密码:


  /usr/local/terry_yu/mysql/bin/mysqladmin -uroot password abcdefg


  用以下命令可以进入MySQL的命令行方式:


  [root@terry root]# /usr/local/terry_yu/mysql/bin/mysql -uroot -p
  Enter password:
  Welcome to the MySQL monitor.  Commands end with ; or \g.
  Your MySQL connection id is 1 to server version: 4.0.15


  Type 'help;' or '\h' for help. Type '\c' to clear the buffer.


  mysql> quit
  Bye


  出现以上信息表示MySQL已经成功运行了。


  二、安装JDK


  # chmod 755 j2sdk-1_4_2_01-linux-i586.bin
  # ./j2sdk-1_4_2_01-linux-i586.bin
  # mv j2sdk1.4.2_01/ /usr/local/terry_yu/
  # cd /usr/local/terry_yu/
  # ln -s j2sdk1.4.2_01/ jdk
  # ln -s jdk/jre/ jre


  # vi /etc/profile
  JAVA_HOME=/usr/local/terry_yu/jdk
  RESIN_HOME=/usr/local/terry_yu/resin
  CLASSPATH=.:../$JAVA_HOME/lib:$JAVA_HOME/jre/lib:$RESIN_HOME/lib:/usr/  local/terry_yu/jdbc
  PATH=$PATH:$JAVA_HOME/bin:$JAVA_HOME/jre/bin


  退出当前登录的环境,重新登录,这样刚刚设定的环境变量就会生效,然后用如下命令测试:


  [root@terry root]# java -version
  java version "1.4.2_01"
  Java(TM) 2 Runtime Environment, Standard Edition (build 1.4.2_01-b06)
  Java HotSpot(TM) Client VM (build 1.4.2_01-b06, mixed mode)


  看到类似信息就表示JDK环境已经好了。其实在上面的/etc/profile中,我们不仅仅设置了JDK的环境变量,还一并设置了Resin和JDBC的环境变量,这些都是后面安装Resin所必需的设定。


  三、安装MySQL的JDBC


  MySQL的JDBC的相关环境变量已经在前面设置好了,所以余下的只是按以下命令安装:


  # tar  -xzpvf mysql-connector-java-3.1.0-alpha.tar.gz
  # mv mysql-connector-java-3.1.0-alpha /usr/local/terry_yu/
  # cd /usr/local/terry_yu/
  # ln -s mysql-connector-java-3.1.0-alpha/ jdbc


  四、安装Apache


  http://apache.linuxforum.net/dist/httpd/apache_1.3.28.tar.gz


  需要注意的是,编译apache时候必须加入了DSO支持,如果没有,请加入 --enable-module=so 选项重新编译apache


  # tar -xzpvf apache_1.3.28.tar.gz
  # cd apache_1.3.28/
  # ./configure --prefix=/usr/local/terry_yu/apache --enable-module=most
--enable-shared=max
  # make
  # make install


  察看编译进apache的模块:


  #/usr/local/terry_yu/apache/bin/httpd -l
  Compiled-in modules:
  http_core.c
  mod_so.c


  看到以上的信息表明apache支持DSO方式了。这样就可以用DSO的方式把php和resin的模块加进来。


  五、安装PHP


  安装PHP比较简单,我们先装PHP。


  # tar -xzpvf php-4.3.3.tar.gz
  # cd php-4.3.3/
  # ./configure --with-mysql=/usr/local/terry_yu/mysql
  --with-apxs=/usr/local/terry_yu/apache/bin/apxs
  # make
  # make install
  # cp php.ini-dist /usr/local/lib/php.ini


  编辑PHP的配置文件是/usr/local/lib/php.ini,将其中的register_globals变量修改成On,默认是Off的。需要将它改成On。否则会出现php不能直接读不到post或get的数据的现象。


  编辑Apache的配置文件/usr/local/terry_yu/apache/conf/httpd.conf,在文件结尾加上以下一行:


  AddType application/x-httpd-php .php .php3


  启动apache:


  # /usr/local/terry_yu/apache/bin/apachectl start


  然后可以用一个简单的php文件来测试PHP的安装,这个简单的PHP文件包含下列一行:


  


  将其保存为/usr/local/terry_yu/apache/htdocs/info.php,然后在浏览器中浏览,如果观看到以显示有“PHP Version4.3.3”标题的页面就表示整合PHP与Apache成功了。而且在这个页面中可以看到与PHP相关的选项,其中应该有关于MySQL的子项,这表明PHP已经内置了对MySQL的支持了。这样就表示PHP+MySQL+Apache的环境已经成功了,接下来是安装Resin来支持JSP环境。


  六.安装Resin


  http://www.caucho.com/download/resin-3.0.3.tar.gz


  下载的resin的安装包解开后应该可以直接单独运行的。笔者将其解开后放到/usr/local/terry_yu目录下


  # tar -xzpvf resin-3.0.3.tar.gz
  # mv resin-3.0.3 /usr/local/terry_yu/
  # cd /usr/local/terry_yu/
  # ln -s resin-3.0.3/ resin


  启动resin
  # /usr/local/terry_yu/resin/bin/httpd.sh start


  如果之前安装JDK时设置好了相关的环境变量,就能够从http://localhost:8080/上能看到resin的页面,这也就表示单独的resin运行成功了。然后,为了整合resin和apache,我们需要重新编译一下,以生成mod_caucho给Apache调用。


  # cd /usr/local/terry_yu/resin
  # ./configure --with-apache=/usr/local/terry_yu/apache
  # make
  # make install


  修改/usr/local/terry_yu/resin/conf/resin.conf,大约在第159行(安装的resin版本不同,配置文件的内容可能有所不同),将修改成自己的apache的DocumentRoot的值。


  
   
    
    
  /usr/local/terry_yu/apache/htdocs ##这里修改成/usr/local/terry_yu/apache/htdocs


     ...
    
   
  


  修改/usr/local/terry_yu/apache/conf/httpd.conf,在编译resin时,安装程序已经修改过httpd.conf,不过还不完全正确,应该改成类似以下的配置,如果你完全按本文进行的安装可以直接复制这些内容:


  LoadModule caucho_module libexec/mod_caucho.so
  AddModule mod_caucho.c


  
   ResinConfigServer localhost 6802
  
   SetHandler caucho-status
  

 

  修改完后,重新启动resin后生效:


  /usr/local/terry_yu/resin/bin/httpd.sh restart
  /usr/local/terry_yu/apache/bin/apachectl restart


  通过浏览器去访问http://localhost/caucho-status/,如果出现以下页面刚表示resin和apache已经成功整合了。



 


  然后再测试一下JSP对数据库的访问,在/usr/local/apache/htdocs/下面用jsp写一个简单的jsp文件来连接本机的MySQL数据库


  vi /usr/local/terry_yu/apache/htdocs/testdb.jsp


  输入以下内容,可以直接粘贴:


  
  
  Test JDBC For <a href="http://www.baidu.com/baidu?tn=sayyes&word=MySQL" target="_blank" rel="nofollow"><span class="unnamed8"><font color="#0000FF">MySQL</font></span></a>
  
  
  <%@ page contentType="text/html;charset=gb2312" %>
  <%
   Class.forName("com.mysql.jdbc.Driver").newInstance();
   java.sql.Connection conn;
   conn =
  java.sql.DriverManager.getConnection("jdbc:mysql://localhost/mysql?user=root&password=abcdefg");
  %>
  
  


  通过浏览器去访问http://localhost/testdb,如果看到了一个没有任何错误信息的空白页面,就表示jsp连接本机的MySQL数据库成功了,至此我们就完成了一个支持JSP+PHP+MySQL的Web服务器


  注:以上所有安装都是在Red Hat Linux9.0上完成的,所使用软件也均为目前(2003年9月)最新的版本。


  本文介绍了如何在Linux上架设同时支持JSP和PHP的Web Server,演示了MySQL、JDK、JDBC、Apache、PHP、Resin的安装和简单测试过程。


相关阅读 Windows错误代码大全 Windows错误代码查询激活windows有什么用Mac QQ和Windows QQ聊天记录怎么合并 Mac QQ和Windows QQ聊天记录Windows 10自动更新怎么关闭 如何关闭Windows 10自动更新windows 10 rs4快速预览版17017下载错误问题Win10秋季创意者更新16291更新了什么 win10 16291更新内容windows10秋季创意者更新时间 windows10秋季创意者更新内容kb3150513补丁更新了什么 Windows 10补丁kb3150513是什么

文章评论
发表评论

热门文章 没有查询到任何记录。

最新文章 没有查询到任何记录。 几个提升JSP应用程序效率的小方法JAVA面试问题宝典EL表达式语言的基础总结java常用图片读写程序

人气排行 java读取文本文件内容并获取文件大小教你5种JSP页面显示为乱码的解决方法教你java用getAddress方法取得IP地址spring依赖注入的3种实现方式JSP学习心得Java的字符串函数集锦告诉你jsp获取浏览者真实IP地址方法高手谈Java如何进阶