设为首页 收藏本站
查看: 1476|回复: 0

[经验分享] Linux下安装配置 Jdk1.6+Tomcat6.0.x+MySql5.x

[复制链接]

尚未签到

发表于 2018-12-8 07:46:53 | 显示全部楼层 |阅读模式
  本篇以Redhat AS5,内核为Linux 2.6.18-8.el5 为例,其中Redhat/Fedora系列基本一致,其他Linux或者版本均可以参考。

STEP 1
软件下载:
1. jdk1.6.x   http://java.sun.com/javase/downloads/index.jsp
2. tomcat6.x   http://tomcat.apache.org/download-60.cgi
3. mysql5.x    http://dev.mysql.com/downloads/mysql/5.0.html
                   http://dev.mysql.com/get/Downloads/MySQL-5.0/mysql-5.0.51a-linux-i686.tar.gz/from/pick
4. JDBC connector   http://dev.mysql.com/downloads/connector/j/5.1.html

假如以上文件都已经成功下载,并放到了/home/work/software/下,假设你是work用户。

SETP 2
1. JDK安装
     1.1  解压并授权给下载程序可以执行的权限
        [work@localhost webServer]$ chmod a+r jdk-6u10-beta-linux-i586.bin
        *** 一段许可协议 ***
        Do you agree to the above license terms? [yes or no]
        [work@localhost webServer]$ yes
        ***  解压过程 ***
        Done.
        # 出现一段许可协议,提示是否同意上面的条款,输入yes。

        [work@localhost webServer]$ mv jdk1.6.0_10 /home/work/usr/local/
        [work@localhost local]$ ln -s jdk1.6.0_10 jdk
        完成后,将解压后的jdk1.6.0_10文件夹移动到专门的目录下面,还可以做一个符号连接

    1.2  配置Java环境变量
        直接编辑/etc/profile文件或者在/etc/profile.d/文件下新建java.sh文件
        普通用户没有编辑权限,可以授权或者切换到root账户来编辑该文件。
        [work@localhost local]$ vim /etc/profile.d/java.sh
        这里以新建的java.sh文件为例子(也推荐这种方式),添加内容如下:

        #set java 环境变量
        JAVA_HOME=/home/work/usr/local/jdk
        PATH=$PATH:/$JAVA_HOME/bin
        CLASSPATH=.:$JAVA_HOME/lib
        JRE_HOME=$JAVA_HOME/jre
        export JAVA_HOME PATH>
    1.3  设置java和javac的符号连接,这是把默认的jdk(本系统默认是JDK1.4)改成刚新装的jdk1.6
        [work@localhost local]#cd /usr/bin #切到usr/bin目录
        [work@localhost local]#su root     #切换到root账号,分别作符号连接
        [root@localhost bin]# ln -s -f /home/work/usr/local/jdk/jre/bin/java
        [root@localhost bin]# ln -s -f /home/work/usr/local/jdk/bin/javac

    JDK安装完成,有问题请参考:http://jiarry.bokee.com/2425368.html

2.  Tomcat安装
    2.1  解压后移动文件夹到指定目录
        [work@localhost webServer]$ tar -zxvf apache-tomcat-6.0.16.tar.gz
        [work@localhost webServer]$ mv apache-tomcat-6.0.16 /home/work/usr/local/
    2.2  配置环境变量
        编辑刚新建的/etc/profile.d/java.sh文件(如果没有新建就编辑/etc/profile文件),添加TOMCAT_HOME
        TOMCAT_HOME = /home/work/usr/local/tomcat
        export JAVA_HOME PATH>
3.    测试安装
    3.1   检查环境变量和java版本
        分别输入下面的命令,检查输出是否与设置的相符合:
        [work@localhost ~]$ echo $JAVA_HOME            
                /home/work/usr/local/jdk
        [work@localhost ~]$ echo $PATH
                输出的含有/home/work/usr/local/jdk/bin:
        [work@localhost ~]$ echo $CLASSPATH
                .:/home/work/usr/local/jdk/lib
        [work@localhost ~]$ echo $TOMCAT_HOME
                /home/work/usr/local/tomcat

        设置/usr/bin下面java和javac的符号连接后,看到的应是新的jdk1.6
        [work@localhost ~]$ java -version
        java version "1.6.0_10-beta"
        Java(TM) SE Runtime Environment (build 1.6.0_10-beta-b25)
        Java HotSpot(TM) Client VM (build 11.0-b12, mixed mode, sharing)
        
        如果没有设置符号连接,将是默认的jdk1.4
        [work@localhost ~]$ java -version
        java version "1.4.2"
        gij (GNU libgcj) version 4.1.1 20070105 (Red Hat 4.1.1-52)

    3.2   启动tomcat
        [work@localhost local]$ sh /home/work/usr/local/tomcat/bin/startup.sh
        在浏览器地址栏输入    http://localhost:8080/
        如果能看到Tomcat的欢迎页表示整合成功,至此已经完成了Java/JSP服务器的搭建。

    3.3  给Tomcat添加项目
        3.3.1  修改tomcat/conf/server.xml,在之间增加如test项目:

            workDir="/home/work/usr/local/tomcat/work/test" />
        
        这样就增加了一个为test的项目,path是web请求访问路径,docBase是目录实际放的目录,workDir是tomcat解析工作目录,可以放到tomcat的work下。
        可以他通过 http://localhost:8080/test 来访问test项目
        至此,Tomcat配置完成。如果要开启目录浏览和servlet直接访问功能,可以参照下面的配置。

        3.3.2  开启目录浏览,tomcat默认是不开启目录浏览的,可以通过修改web.xml里的listings的值来设定,改false为true。如下:
        listings
            true

        3.3.3  默认不开启servlet直接访问,可以修改web.xml和context.xml文家的配置来开启,如下:
        web.xml。找到这段,打开注释
        invoker
            
              org.apache.catalina.servlets.InvokerServlet
            
        还有这段,也开启是注释
        
            invoker
        
        context.xml。在Context里增加privileged
        

SETP 3 MySql与JDBC connector
1.  解压缩mysql-5.0.51a-linux-i686.tar.gz包,移动到指定位置
    [work@localhost webServer]$ tar -zxvf mysql-5.0.51a-linux-i686.tar.gz
    [work@localhost webServer]$ mv mysql-5.0.51a-linux-i686 /home/work/usr/local/

2. 参照INSTALL-BINARY文件安装mysql,一定要仔细阅读并认真执行,这里是二进制的安装包,如果下载的是源码就需要先编译
    2.1  建立一个mysql符号连接
    [work@localhost local]$ cd /home/work/usr/local/
    [root@localhost local]# ln -s mysql-5.0.51a-linux-i686 mysql

    切换到root账号,添加mysql用户和组
    [work@localhost local]$ su root
    [root@localhost local]# su -
    [root@localhost ~]# groupadd mysql
    [root@localhost ~]# useradd -g mysql mysql

    回到/home/work/usr/local/mysql/,更改目录所属为mysql
    [root@localhost ~]# cd /home/work/usr/local/mysql/   
    [root@localhost mysql]# chown -R mysql .
    [root@localhost mysql]# chgrp -R mysql .

    执行脚本生成mysql系统数据库
    [root@localhost mysql]# scripts/mysql_install_db  --user=mysql

    Installing MySQL system tables...
    OK
    Filling help tables...
    OK
    ……
    出现成功提示之后,授权返还给work,但是data目录仍然给mysql账号   

    [root@localhost mysql]# chown -R work .
    [root@localhost mysql]# chown -R mysql data

    2.2  看/var/run/是否有mysqld目录,如果没有就新建一个,并在mysqld目录下新建mysqld.pid的空白文件。(本步骤并不是必须的)
    [root@localhost mysql]# cd  /var/run/mysqld
    [root@localhost run]# mkdir mysqld
    [root@localhost mysqld]# cd mysqld
    [root@localhost run]# chown -R mysql mysqld .
    [root@localhost run]# chgrp -R mysql mysqld .
    [root@localhost mysql]#su mysql   
    [mysql@localhost mysql]$ vi /var/run/mysqld/mysqld.pid

    查看/tmp/下是否有mysql.sock文件,没有的话把/home/mysql/mysql.sock做个符号连接到/tmp/临时文件夹下。(本步骤并不是必须的)
    如果不建立符号连接,就需要通过在启动是加入 --socket=/home/mysql/mysql.sock参数来启动
    [root@localhost mysql]# ln -s /home/mysql/mysql.sock /tmp/mysql.sock
    [root@localhost tmp]# chown -R mysql mysql.sock
    [root@localhost tmp]# chgrp -R mysql mysql.sock

    也可以查看一下/etc/my.cnf,看里面配置的指向与自己的安装是否一致有datadir,basedir,socket等。(本步骤并不是必须的)
    [root@localhost tmp]# cat /etc/my.cnf

    2.3  启动mysql服务,非mysql帐号就加上--user=msyql
    [root@localhost mysql]# bin/mysqld_safe --user=mysql &
    [root@localhost mysql]# Starting mysqld daemon with databases from /var/lib/mysql

    启动成功后,查看一下mysql的进程:
    [root@localhost mysql]# ps -el | grep mysqld
    4 S     0 14213 13164  0  84   0 -  1171 wait   pts/0    00:00:00 mysqld_safe
    4 S   502 14241 14213  0  85   0 -  8223 -      pts/0    00:00:00 mysqld
    1 S   502 14242 14241  0  78   0 -  8223 -      pts/0    00:00:00 mysqld
    1 S   502 14243 14242  0  85   0 -  8223 rt_sig pts/0    00:00:00 mysqld
    [root@localhost tmp]# netstat -na | grep 3306
    tcp        0      0 0.0.0.0:3306                0.0.0.0:*                   LISTEN      
    可以查看mysql 3306端口是否运行中

    2.4  登录mysql试一下,可用其他账户
    [root@localhost mysql]# su work
    [work@localhost mysql]$ cd /home/work/usr/local/mysql/
    [work@localhost mysql]$ bin/mysql -uroot -p密码
    或者mysql用户[mysql@localhost mysql]$ bin/mysql -uroot -p密码,将看到成功登录信息。

    Welcome to the MySQL monitor.  Commands end with ; or \g.
    Your MySQL connection>    Server version: 5.0.51a MySQL Community Server (GPL)
    Type 'help;' or '\h' for help. Type '\c' to clear the buffer.
    mysql> \s
    --------------
    bin/mysql  Ver 14.12 Distrib 5.0.51a, for pc-linux-gnu (i686) using readline 5.0

    Connection>    Current database:
    urrent user:           root@localhost
    SL:                    Not in use
    urrent pager:          stdout
    sing outfile:          ''
    Using delimiter:        ;
    Server version:         5.0.51a MySQL Community Server (GPL)
    Protocol version:       10
    Connection:             Localhost via UNIX socket
    Server characterset:    latin1
    Db     characterset:    latin1
    Client characterset:    latin1
    Conn.  characterset:    latin1
    UNIX socket:            /tmp/mysql.sock
    Uptime:                 8 min 33 sec

    Threads: 1  Questions: 7  Slow queries: 0  Opens: 11  Flush tables: 1  Open tables: 6  Queries per second avg: 0.014
    --------------
   
    mysql> create database myapp;
    Query OK, 1 row affected (0.00 sec)

    2.5  配置自动启动,也root账户
    [root@localhost mysql]# cp support-files/mysql.server /etc/rc.d/init.d/mysqld
    [root@localhost mysql]# chmod 777 /etc/init.d/mysqld
    [root@localhost init.d]# su -
    [root@localhost ~]# chkconfig --add mysqld

    至此,mysql配置完成。

但是有时候完全按照INSTALL-BINARY来安装,仍然会出现问题,如下:
***************************************************************
   
    1.  运行# bin/mysqld_safe --user=mysql & 后,若有提示STOPPING server from pid file /var/run/mysqld/mysqld.pid之类的。
    先检查一下安装日志,看是否提示/var/ran/下缺少mysqld目录及mysqld.pid文件,如是,就添加该目录
    [root@localhost mysql]# less /var/log/mysqld.log
    进入/var/run/创建mysqld目录,在/var/run/mysqld/下再创建空文件mysqld.pid,并给授权mysql账户
    mysqld.pid是运行时需要的文件,如果没有/var/ran/mysqld目录就建立一个,文件会自动生成,也可以不建立该文件。
    [root@localhost run]# cd /var/run/
    [root@localhost run]# mkdir mysqld
    [root@localhost mysqld]# cd mysqld
    [root@localhost mysqld]# touch mysqld.pid
    [root@localhost mysqld]# cd ..
    [root@localhost run]# chown -R mysql mysqld .
    [root@localhost run]# chgrp -R mysql mysqld .

    再启动服务就能成功了
    [root@localhost mysql]# bin/mysqld_safe --user=mysql &

    2.   如果mysql启动后,登录时出现错误提示:
    [root@localhost mysql]# bin/mysql -uroot -p
    ERROR 2002 (HY000): Can't connect to local MySQL server through socket '/tmp/mysql.sock' (2)
    则可能表示/tmp/下没有mysql.sock文件
     默认的mysql.sock 是在/var/lib/mysql/mysql.sock,从mysql安装目录(/home/mysql/)也有
    建一个符号连接到tmp下就可以了,并且把mysql.sock文件所属改为mysql账户
    [root@localhost mysql]# ln -s /home/mysql/mysql.sock /tmp/mysql.sock
    [root@localhost tmp]# cd /tmp/
    [root@localhost tmp]# chown -R mysql mysql.sock
    [root@localhost tmp]# chgrp -R mysql mysql.sock

    3. 给/var/lib/mysql/目录以及下面的所有文件授权给mysql账户。(但本步骤并不是必须的)
    [root@localhost mysql]# cd /var/lib/mysql/
    [root@localhost mysql]# chown -R mysql .
    [root@localhost mysql]# chgrp -R mysql .   
    [root@localhost mysql]# chmod a+w *

    4  另外还可以查看一下/etc/my.cnf文件,看一下里面配置项的指向,如socket等
    [root@localhost etc]# vim /etc/my.cnf
    [mysqld]
    datadir=/var/lib/mysql
    socket=/home/mysql/mysql.sock
    #socket=/var/lib/mysql/mysql.sock
    # Default to using old password format for compatibility with mysql 3.x
    # clients (those using the mysqlclient10 compatibility package).
    old_passwords=1
     
    [mysql.server]
    user=mysql
    basedir=/var/lib

    [mysqld_safe]
    log-error=/var/log/mysqld.log
    pid-file=/var/run/mysqld/mysqld.pid

    看下socket=/home/mysql/mysql.sock,这里的地址与/tmp/mysql.sock符号连接要对应上,
    /var/lib/mysql/目录下默认也有mysql.sock,/tmp/mysql.sock的符号连接如果指向的是这个地址,就不用修改了
    其他的配置也可以根据实际情况来修改,比如datadir,basedir,socket等
   
    以上修改一项就测试一下,最好先查一下是否存在mysql进程,可以kill已经存在的mysql进程,再重新启动mysql
    [root@localhost mysql]# bin/mysqld_safe --user=mysql &
    [root@localhost mysql]# bin/mysql -uroot -p   

    这些问题一般都是因为文件没有正确授权或者是/tmp/没有mysql.sock符号连接等原因导致的,以上几个方法能解决大部分同学遇到的问题,

    参照:
   http://lawzjf.itpub.net/post/417/451262
    http://www.chinaunix.net/jh/17/178508.html
   http://www.chinaunix.net/jh/17/416730.html

***************************************************************

   
    另外,mysql也可下载源码来编译安装。http://dev.mysql.com/downloads/mysql/5.0.html#linux-icc

3. mysql-connector-java安装
    3.1  解压缩,把jar文件移到tomcat lib目录下   
    [work@localhost webServer]$ tar -zxvf mysql-connector-java-5.1.6.tar.gz
    [work@localhost webServer]$ cp mysql-connector-java-5.1.6/mysql-connector-java-5.1.6-bin.jar /home/work/usr/local/tomcat/lib/
    3.2   配置数据池连接
        3.2 .1  修改tomcat/conf/server.xml,对原来test项目进行修改,添加数据池配置
      
  

        3.2 .2  在/home/work/dev/test/下建立WEB-INF/web.xml文件,加入如下内容:
   
  My Test App
     
      DB Connection
      jdbc/test
      javax.sql.DataSource
      Container
  
   

        3.2 .3  在tomcat的test项目下新建立一个jdbc_test.jsp文件(名字自己起),内容如下:
   
   
   
   
   
    This is a Java Server Page. I am Jarry!
    JSP+MySql JDBC Driver and Connection Pool Test:
   
     数据库连接池测试结果:
           out.println("检查成功!");
     } catch (ClassNotFoundException cnfe) {
      out.println("JDBC驱动创建失败!");
      cnfe.printStackTrace();
     }
   
      out.println("环境命名空间检查");
     try {
        javax.naming.Context ctx = new javax.naming.InitialContext();
      javax.naming.Context envContext =
       (javax.naming.Context) ctx.lookup("java:/comp/env");
      out.println("检查成功!");
      
      out.println("查找数据源");

         // org.apache.commons.dbcp.BasicDataSource ds =
         //   (org.apache.commons.dbcp.BasicDataSource) envContext.lookup("jdbc/test");
      DataSource ds =(DataSource)ctx.lookup("java:comp/env/jdbc/test");
      out.println("查找成功!");
             // 早期版本可以用BasicDataSource接收以获得比DataSource接口更具体的信息,便于错误查找

        // 测试数据库是否能执行,如果tomcat里server.xml配置的数据库可以执行的话就会成功输出数据库
     
     /*
       out.println("检查数据库");
       Connection conn = ds.getConnection();
       DatabaseMetaData metaData = conn.getMetaData();
       ResultSet rs = metaData.getCatalogs();
       while (rs.next())
       out.println(rs.getString(1) + "");
       rs.close();
    */

    } catch (javax.naming.NamingException e) {
      out.println("环境变量上下文创建失败!");
      e.printStackTrace();
    /*
     } catch (SQLException e) {
       out.println("数据库操作执行失败!");
       e.printStackTrace();
    */
     }
   %>

    重启Tomcat,访问http://localhost:/test/jdbc_test.jsp,若都能显示成功,便表示成功安装了
    参考:http://jiarry.bokee.com/6234733.html
        http://tomcat.apache.org/tomcat-6.0-doc/jndi-datasource-examples-howto.html
   

至此,一个Linux下的支持Java的eb Server就全部配置完成了。

参考:
Jdk1.6+Tomcat6+Apache2+jk_mod1.2+PHP5+MySql5安装与配置详解 http://jiarry.bokee.com/6738182.html (windows)
安装Jdk+Tomcat+Apache+PHP+MySql (Linux) 详细介绍  http://jiarry.bokee.com/2425368.html
http://docs.google.com/View?docid=dgh6pn6x_19ccgx54hd
  http://docs.google.com/Doc?id=dgh6pn6x_20cm4ktdcf
  
几个命令,安装时需要用到:
1..下载文件: wget URL
2.  压缩:tar —zxvf 文件名(.tar 或 .tar.gz) tar —jxvf 文件名(.tar.bz2)
3.  拷贝:cp 文件名 或 cp —Rf 文件夹名
4.  删除:rm 文件名 或 rm —Rf 文件夹名
5.  编辑文件命令:vi 文件名   ,   q!(不保存退出) : wq(保存退出)
6.  授权 chmod 777 * (文件名或者文件夹,支持通配符)
7.  更改用户权属  chown -R 用户 .
8.  更改用户组   chgrp -R 用户 .
9. 切换用户  su 用户
10. 用root执行命令  su -c “命令”
11. 查看mysql进程,如 ps -el | grep mysqld


运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-644453-1-1.html 上篇帖子: Apache + Tomcat集群配置详解 (2) 下篇帖子: IDEA9+Tomcat热部署配置二法
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表