Linux CentOS 6.5 中安装与配置JDK-7-tomcat-nginx-rabbitmq

系统环境:CentOS-6.5
安装方式:rpm安装
软件:jdk-7-linux-i586.rpm
下载地址:http://www.Oracle.com/technetwork/java/javase/downloads/index.html


检验系统原版本
[root@localhost ~]# java -version
java version "1.7.0_24"
OpenJDK Runtime Environment (build 1.7.0_24-b18)
OpenJDK HotSpot(TM) Client VM (build 24.45-b08, mixed mode, sharing)


进一步查看JDK信息:
[root@localhost ~]# rpm -qa | grep java
tzdata-java-2012c-1.el6.noarch
java-1.7.0-openjdk-1.7.0.45-1.45.1.11.1.el6.x86_64


卸载OpenJDK,执行以下操作:
[root@localhost ~]# rpm -e --nodeps tzdata-java-2012c-1.el6.noarch
[root@localhost ~]# rpm -e --nodeps java-1.7.0-openjdk-1.7.0.45-1.45.1.11.1.el6.x86_64


安装JDK
上传新的jdk-7-linux-i586.rpm软件到/usr/local/执行以下操作:
[root@localhost ckb]# rpm -ivh jdk-7-linux-i586.rpm
JDK默认安装在/usr/java中。


验证安装
执行以下操作,查看信息是否正常:
[root@localhost bin]# java
[root@localhost bin]# javac
[root@localhost bin]# java -version
java version "1.7.0_71"
Java(TM) SE Runtime Environment (build 1.7.0_71-b18)
Java HotSpot(TM) Client VM (build 24.45-b08, mixed mode, sharing)


配置环境变量
我的机器安装完jdk-7-linux-i586.rpm后不用配置环境变量也可以正常执行javac、java –version操作,因此我没有进行JDK环境变量的配置。但是为了以后的不适之需,这里还是记录一下怎么进行配置,操作如下:
修改系统环境变量文件
vi + /etc/profile


向文件里面追加以下内容:
JAVA_HOME=/usr/java/jdk1.7.0_71
JRE_HOME=/usr/java/jdk1.7.0_71/jre
PATH=$PATH:$JAVA_HOME/bin:$JRE_HOME/bin
CLASSPATH=:$JAVA_HOME/lib/dt.jar:$JAVA_HOME/lib/tools.jar:$JRE_HOME/lib
export JAVA_HOME JRE_HOME PATH CLASSPATH


使修改生效
[root@localhost ~]# source /etc/profile  //使修改立即生效
[root@localhost ~]# echo $PATH  //查看PATH值


查看系统环境状态
[root@localhost ~]# echo $PATH
/usr/lib/qt-3.3/bin:/usr/local/bin:/bin:/usr/bin:/usr/local/sbin:/usr/sbin:/sbin:/usr/java/jdk1.7.0_71/bin:
/usr/java/jdk1.7.0_71/jre/bin:/home/ckb/bin






开发防火墙端口配置


防火墙开放8080端口
增加8080端口到防火墙配置中,执行以下操作:
[root@localhost ~]/sbin/iptables -I INPUT -p tcp --dport 8080 -j ACCEPT #开启8080端口 
[root@localhost ~]/etc/rc.d/init.d/iptables save #保存配置 
[root@localhost ~]/etc/rc.d/init.d/iptables restart #重启防火墙


#第一个Tomcat

CATALINA_BASE=/usr/local/apache-tomcat-6.0.35
CATALINA_HOME=/usr/local/apache-tomcat-6.0.35
export CATALINA_BASE CATALINA_HOME


#第二个Tomcat
CATALINA_2_BASE=/usr/local/apache-tomcat-6.0.35-second
CATALINA_2_HOME=/usr/local/apache-tomcat-6.0.35-second
export CATALINA_2_BASE CATALINA_2_HOME


#第一个Tomcat路径
TOMCAT_HOME=/usr/local/apache-tomcat-6.0.35
export TOMCAT_HOME


#第二个Tomcat路径
TOMCAT_2_HOME=/usr/local/apache-tomcat-6.0.35-second
export TOMCAT_2_HOME

(2)把tomcat_2/conf下的server.xml打开,修改关闭端口与启动端口。这样就可以在linux下同时运行两个tomcat了。运行更多tomcat方法是一样的。

(3)主要要点就是tomcat启动的时候会去查找tomat 的根目录,而这是通过查询系统环境变量CATALINA_HOME 以及

CATALINA_BASE 来做到的,于是我们只需要设置这两个变量即可。
现在我们把tomcat拷贝成2份,分别为 tomcat1 和 tomcat2,tomcat1 我们使用之前配置好的默认配置

(CATALINA_HOME 以及 CATALINA_BASE 均指向 tomca1 目录),但tomcat2 我们不能再使用系统上配置的这两个


变量了,那么我们就在 tomcat2的bin目录下面的 catalina.sh 临时修改设置 CATALINA_HOME 和 CATALINA_BASE


为tomcat2的根目录即可,如果再加tomcat 以此类推即可。


打开catalina.sh ,找到下面红字,在下面增加如下代码
# OS specific support.  $var _must_ be set to either true or false.
# myself : add
export CATALINA_BASE=$CATALINA_2_BASE
export CATALINA_HOME=$CATALINA_2_HOME


#设置虚拟机参数
JAVA_OPTS="-server -Xms512m -Xmx512m -Xss512K -XX:PermSize=128m -XX:MaxPermSize=256m"




#####安装nginx######

Nginx 一般有两个版本,分别是稳定版和开发版,您可以根据您的目的来选择这两个版本的其中一个,下面是把 Nginx 安装到 /usr/local/nginx 目录下的详细步骤:


cd /usr/local/
wget http://nginx.org/download/nginx-1.2.8.tar.gz
tar -zxvf nginx-1.2.8.tar.gz
cd nginx-1.2.8  
./configure --prefix=/usr/local/nginx 
make
make install
--with-pcre=/usr/src/pcre-8.21 指的是pcre-8.21 的源码路径。
--with-zlib=/usr/src/zlib-1.2.7 指的是zlib-1.2.7 的源码路径。



启动

确保系统的 80 端口没被其他程序占用,
/usr/local/nginx/sbin/nginx
检查是否启动成功:
netstat -ano|grep 80 有结果输入说明启动成功
打开浏览器访问此机器的 IP,如果浏览器出现 Welcome to nginx! 则表示 Nginx 已经安装并运行成功。


重启
/usr/local/nginx/sbin/nginx –s reload


修改配置文件
cd /usr/local/nginx/conf
vi nginx.conf


常用配置
#nginx运行用户和组
user    www www;  
#启动进程,通常设置成和cpu的数量相等
worker_processes  4;
#全局错误日志及PID文件
pid /var/run/nginx.pid;
error_log  /var/log/nginx/error.log;
events {
        #epoll是多路复用IO(I/O Multiplexing)中的一种方式,但是仅用于linux2.6以上内核,可以大大提高nginx的性能


use epoll;
         #单个后台worker process进程的最大并发链接数
        worker_connections  10240;
}


#设定http服务器,利用它的反向代理功能提供负载均衡支持
http {
        include       mime.types;
        default_type  application/octet-stream;
         error_page 400 403 500 502 503 504  /50x.html;
        index index.html index.shtml;
        autoindex off;
         fastcgi_intercept_errors on;
        sendfile        on;


        # These are good default values.
        tcp_nopush      on;
        tcp_nodelay     off;

        # output compression saves bandwidth
        gzip  off;
         #gzip_static on;
        #gzip_min_length  1k;
        gzip_http_version 1.0;
        gzip_comp_level 2;
        gzip_buffers  4 16k;
        gzip_proxied any;
        gzip_disable "MSIE [1-6]\.";
        gzip_types  text/plain text/html text/css application/x-javascript application/xml application/xml+rss text/javascript;
        #gzip_vary on;
        server_name_in_redirect off;

#设定负载均衡的服务器列表
        upstream portals {
                  server 172.16.68.134:8082 max_fails=2 fail_timeout=30s;
                  server 172.16.68.135:8082 max_fails=2 fail_timeout=30s;
                  server 172.16.68.136:8082 max_fails=2 fail_timeout=30s;
                  server 172.16.68.137:8082 max_fails=2 fail_timeout=30s;


        }


        #upstream overflow {
         #       server 10.248.6.34:8090 max_fails=2 fail_timeout=30s;      
         #       server 10.248.6.45:8080 max_fails=2 fail_timeout=30s;       
        #
        }

        server {
                #侦听8080端口
                listen       8080;
                server_name  127.0.0.1;
                   #403、404页面重定向地址
                   error_page  403 = http://www.e100.cn/ebiz/other/217/403.html;
                   error_page  404 = http://www.e100.cn/ebiz/other/218/404.html;
                   proxy_connect_timeout      90;
                   proxy_send_timeout         180;
                   proxy_read_timeout         180;
                   proxy_buffer_size 64k;
                   proxy_buffers 4 128k;
                   proxy_busy_buffers_size 128k;
                   client_header_buffer_size 16k;
                   large_client_header_buffers 4 64k;
                #proxy_send_timeout         3m;
                #proxy_read_timeout         3m;
                #proxy_buffer_size          4k;
                #proxy_buffers              4 32k;
                proxy_set_header Host $http_host;
                proxy_max_temp_file_size 0;


                #proxy_hide_header Set-Cookie;               
         #       if ($host != 'www.e100.cn' ) {
         #                rewrite ^/(.*)$ http://www.e100.cn/$1 permanent;

         #       }
    
 deny all;
               }

                   location ~ ^/resource/res/img/blue/space.gif {
                    proxy_pass http://tecopera;
               }

               location = / {
                   rewrite ^(.*)$  /ebiz/event/517.html last;
               }


                   location = /ebiz/event/517.html {
                    add_header Vary Accept-Encoding;
                    root /data/web/html;
                    expires 10m;
               }

               location = /check.html {
                    root /usr/local/nginx/html/;
                    access_log off;
               }

               location = /50x.html {
                    root /usr/local/nginx/html/;
                    expires 1m;
                    access_log off;
               }


              location = /index.html {
                       add_header Vary Accept-Encoding;
                      #定义服务器的默认网站根目录位置
                    root /data/web/html/ebiz;
                    expires 10m;
               }


#定义反向代理访问名称
                   location ~ ^/ecps-portal/* {
                   # expires 10m;


#重定向集群名称
                    proxy_pass http://portals;
                    #proxy_pass http://172.16.68.134:8082;
               }

                   location ~ ^/fetionLogin/* {
                   # expires 10m;
                    proxy_pass http://portals;
                    #proxy_pass http://172.16.68.134:8082;
                }

                 #location  ~ ^/business/* {                                                                      
                #   # expires 10m;                                                                                
                #    proxy_pass http://172.16.68.132:8088;                                                                   
                #    #proxy_pass http://172.16.68.134:8082;                                                       
                #}


                   location ~ ^/rsmanager/* {
                    expires 10m;
                    root /data/web/;
                    #proxy_pass http://rsm;
               }


#定义nginx处理的页面后缀

                   location ~* (.*)\.(jpg|gif|htm|html|png|js|css)$  {
                           root /data/web/html/;
#页面缓存时间为10分钟
                        expires 10m;
                   }
 
#设定查看Nginx状态的地址     
               location ~* ^/NginxStatus/ {
                    stub_status on;
                   access_log off;
                    allow 10.1.252.126;
                    allow 10.248.6.49;
                    allow 127.0.0.1;
                    deny all;
               }

         #       error_page   405 =200 @405;
         #       location @40;
         #       {
         #                proxy_pass http://10.248.6.45:8080;
         #       }  
               access_log  /data/logs/nginx/access.log combined;
               error_log   /data/logs/nginx/error.log;
        }

         server {
                listen       8082;
                server_name  _;
               location = /check.html {
                    root /usr/local/nginx/html/;
                    access_log off;
               }              
        }

         server {
                   listen       8088;
                   server_name  _;
                   location ~ ^/* {
                   root /data/web/b2bhtml/;
                   access_log off;
         }                
         }

        server {
                listen       9082;
                server_name  _;
        # location ~ ^/resource/* {
        # expires 10m;
         # root /data/web/html/;
         # 

  }
                location  / {
                     root /data/web/html/sysMaintain/;
                       if (!-f $request_filename) {
                           rewrite ^/(.*)$ /sysMaintain.html last;
                           }
                }
        }
}



nginx 跳转指定接口

场景:

进行stub测试时,程序访问的不是真正的接口,而是stub接口(提供假数据).

但是程序中写的域名,不可能写stub的ip.

如果写死stub的ip,那么到时候上线时还得改代码.(只要动代码,就是有风险的)

所以就需要做一个映射.

使用nginx 实现这个功能

配置文件名称:yunmasoft.com.conf 

配置文件内容:

  1. server {  
  2.         listen 80;  
  3.         server_name yunmasoft.com www.yunmasoft.com;  
  4.         if ( $uri ~* "^/user/loginInput$" ) {  
  5.                 rewrite ^/(.*)$ http://123.57.250.51/$1 redirect;  
  6.         }  
  7.         location / {  
  8.                 proxy_pass    http://182.92.97.72:8083;  
  9.                 # proxy_redirect on ;   
  10.                 index index.php index.html index.htm;  
  11.         }  
  12.         error_page 500 502 503 504 /50x.html;  
  13. }  


yum安装RabbitMQ

需要的软件:epel-release-5-4.noarch.rpm(fedora源) 
1.安装前准备 
wget http://download.slogra.com/epel-release-5-4.noarch.rpm 
rpm -ivh epel-release-5-4.noarch.rpm 
wget -P /etc/yum.repos.d/ http://repos.fedorapeople.org/repos/peter/erlang/epel-erlang.repo 
yum clean all 
yum -y install erlang

2.安装rabbitmq 
rpm --import http://www.rabbitmq.com/rabbitmq-signing-key-public.asc 
wget http://www.rabbitmq.com/releases/rabbitmq-server/v2.8.5/rabbitmq-server-2.8.5-1.noarch.rpm 
rpm -ivh rabbitmq-server-2.8.5-1.noarch.rpm

3.启动rabbitmq并设置开机启动 
chkconfig rabbitmq-server on 
/sbin/service rabbitmq-server start

4.检查rabbitmq是否启动 
ps aux|grep rabbitmq

你可能感兴趣的:(Linux CentOS 6.5 中安装与配置JDK-7-tomcat-nginx-rabbitmq)