nginx整合tomcat(solr)

     一台测试机,为了多个项目同时在一台测试机上测试,可以使用了nginx挂载多个tomcat应用。我使用的ubuntu 12.0.4。

准备:下载nginx : http://nginx.org/download/nginx-1.5.0.tar.gz

        : 下载tomcat:http://mirrors.cnnic.cn/apache/tomcat/tomcat-6/v6.0.37/bin/apache-tomcat-6.0.37.tar.gz

如果链接无效,可以去官网上面下载。也可以使用附件里的包。

export.zip:http://pan.baidu.com/share/link?shareid=2574750123&uk=168777878

tomcat:http://pan.baidu.com/share/link?shareid=2589332527&uk=168777878

solr.zip:http://pan.baidu.com/share/link?shareid=2595428937&uk=168777878

1.安装nginx

  ubuntu系统自带了一个版本的系统 需要先卸载:sudo apt-get --purge remove nginx

  创建nginx存放目录,这个可以随便定,我放在/export/servers/nginx 首先创建文件夹,命令如下:

$cd /
$mkdir export 
$cd export 
$mkdir servers
$cd servers
$mkdir nginx
$cd nginx

  把之前下载的nginx 包 放到/export/servers/nginx 目录下并解压压缩包

$tar -xzvf nginx-1.5.0.tar.gz
$cd nginx-1.5.0

  接下来编译安装:

$cd /export/servers/nginx/nginx-1.5.0
$./configure --prefix=/export/servers/nginx/nginx-1.5.0/sbin
$make 
$sudo make install

 执行可能报错:

./configure: error: the HTTP rewrite module requires the PCRE library.
You can either disable the module by using --without-http_rewrite_module
option, or install the PCRE library into the system, or build the PCRE library
statically from the source with nginx by using --with-pcre=<path> option.

 

 原因缺少pcre library

 解决方法:

 下载pcre 官网 http://www.pcre.org/

 下载地址: http://sourceforge.net/projects/pcre/files/pcre/8.33/pcre-8.33.tar.gz/download

#解压包
$tar -xzvf pcre-8.33.tar.gz
$cd pcre-8.33
$sudo ./configure --prefix =/usr/local/pcre
$sudo make 
$sudo make install
 

 悲剧的是在执行./confugure时候还是会报错

configure: error: You need a C++ compiler for C++ support.
 

 从错误中看没有g++,没办法只能安装

$sudo apt-get install g++
 

 然后执行上面的安装pcre 如果还是报错,看看少什么就安装什么。

 我这最后安装成功,如果回去继续安装nginx,继续报错,少了zlib按照上面的方法安装

./configure: error: the HTTP gzip module requires the zlib library.
You can either disable the module by using --without-http_gzip_module
option, or install the zlib library into the system, or build the zlib 
library statically from the source with nginx by using --with-zlib=
<path> option.
 

 解决上面的问题 继续重复之前的安装。这次终于没有问题了,也可以在安装是先disbale这两个模块,以后需要了安装。执行下面:

$./configure --prefix=/export/servers/nginx/nginx-1.5.0/sbin  --withou
t-http_rewrite_module --without-http_gzip_module
$make
$make install
 启动nginx
$cd /export/servers/nginx/nginx-1.5.0/sbin/sbin
$./nginx
浏览器访问localhost

Welcome to nginx!

If you see this page, the nginx web server is successfully installed and working. Further configuration is required.

For online documentation and support please refer to nginx.org.
Commercial support is available at nginx.com.

Thank you for using nginx.

nginx安装成功:

nginx是个优秀的反向代理服务器,用户访问web应用的时候,直接面对的的nginx,而真正的web服务器就挂载在nginx后面,继而解决之前的如何将tomcat挂载到nginx下面,接下来讨论

 1.部署tomcat 实例

   我创建两个tomcat实例,然后分别在两个tomcat下面,各放一个solr应用,如果想了解solr可以参考(http://lucene.apache.org/solr/),其实solr就是一个web应用。具体就不介绍了。我主要是搭建一个master/slave solr应用。同时挂在nginx下面。首先安装两个tomcat:

创建两个文件夹:

/export/home/tomcat/domains/master.solr.com/server1 和 /export/home/tomcat/domains/slave.solr.com/server1

解压tomcat-6.0.37.tar.gz 然后把里面的所有文件全部拷贝到这两个文件下面。

root@lcpc:/export/home/tomcat/domains/master.solr.com/server1$ ls
bin   lib      logs    RELEASE-NOTES  temp     work
conf  LICENSE  NOTICE  RUNNING.txt    webapps
  上面是两个文件夹的内容。tomcat安装完成,如果添加更多项目,类似。

接下来创建项目的文件的存放文件夹,因为有两个项目所以创建两个文件夹:

/export/data/WebRoot/master.solr.com 和 /export/data/WebRoot/slave.solr.com

root@lcpc:/export/data/WebRoot/master.solr.com$ ls
admin.html  css  favicon.ico  img  js  META-INF  tpl  WEB-INF
 文件夹内文件列表如上,

接下来修改tomcat配置文件,添加tomcat项目存放的路径,这样便于维护。

 1.在/export/home/tomcat/domains/master.solr.com/server1/conf/Catalina/localhost增加文件ROOT.xml,docBase指向项目文件所在的文件夹
<?xml version='1.0' encoding='UTF-8'?>$                                       
<Context path="/" docBase="/export/data/WebRoot/master.solr.com">$
</Context>
 2.在/export/home/tomcat/domains/slave.solr.com/server1/conf/Catalina/localhost增加文件ROOT.xml
<?xml version='1.0' encoding='UTF-8'?>                                       
<Context path="/" docBase="/export/data/WebRoot/slave.solr.com">
</Context>
修改tomcat的http端口号码,由于在同一个机子运行两个tomcat,端口号肯定不能相同的。需要修改的/export/home/tomcat/domains/master.solr.com/server1/conf/server.xml文件
<Server port="8000" shutdown="SHUTDOWN"> 该端口改为8000,tomcat服务的
端口号。<Connector port="9000" protocol="HTTP/1.1" 
connectionTimeout="20000" redirectPort="8443" /> 该端口改为9000
同样的修改/export/home/tomcat/domains/master.solr.com/server1/conf/server.xml文件,端口号码不能重复
<Server port="8001" shutdown="SHUTDOWN"> 该端口改为8001
<Connector port="9001" protocol="HTTP/1.1" connectionTimeout="20000" 
redirectPort="8443" /> 该端口改为9001 http端口号
 tomcat配置全部修改完成,分别进入两个tomcat安装目录的bin文件夹,启动master tomcat
root@lcpc:/export/home/tomcat/domains/master.solr.com/server1/bin$
 ./startup.sh 
Using CATALINA_BASE:/export/home/tomcat/domains/master.solr.com/server1
Using CATALINA_HOME:/export/home/tomcat/domains/master.solr.com/server1
Using CATALINA_TMPDIR:
/export/home/tomcat/domains/master.solr.com/server1/temp
Using JRE_HOME:/opt/java/jdk1.6.0_38/jre
Using CLASSPATH:/export/home/tomcat/domains/master.solr.com/server1/bin
/bootstrap.jar
   启动slavet tomcat
root@lcpc:/export/home/tomcat/domains/slave.solr.com/server1/bin$ 
./startup.sh 
Using CATALINA_BASE:/export/home/tomcat/domains/slave.solr.com/server1
Using CATALINA_HOME:/export/home/tomcat/domains/slave.solr.com/server1
Using CATALINA_TMPDIR:/export/home/tomcat/domains/slave.solr.com/server
1/temp
Using JRE_HOME:/opt/java/jdk1.6.0_38/jre
Using CLASSPATH:/export/home/tomcat/domains/slave.solr.com/server1/bin
/bootstrap.jar
 然后在浏览器中访问127.0.0.1:9000 和127.0.0.1:9001可以看solr的主界面,使用两个不同的端口号都成功启动。

 说明tomcat没有问题,接下来就是让这两个tomcat挂在到nginx下面,然后我们通过域名访问,nginx会自动负载到各自的web应用中,接下来要做的就是修改nginx的配置文件

首先在/export/servers/nginx/nginx-1.5.0/sbin/conf下面创建一个存放nginx配置文件的domains文件夹,在domains创建两个配置文件master.solr.nginx.conf和slave.solr.nginx.conf ,还需要创建两个存放log文件的目录 /export/servers/nginx/nginx-1.5.0/sbin/logs/master.solr.com和 /export/servers/nginx/nginx-1.5.0/sbin/logs/slave.solr.com

#master nginx conf 
upstream tomcat_master.solr {
      server 127.0.0.1:9000  weight=10 max_fails=2 fail_timeout=30s;
    }
server          {
                listen                   80;
                server_name              master.solr.com; #项目域名
                access_log /export/servers/nginx
/nginx-1.5.0/sbin/logs/master.solr.com/master.solr.com_access.log main; #存放log文件目录
                error_log  /export/servers/nginx
/nginx-1.5.0/sbin/logs/master.solr.com/master.solr.com_error.log warn;
                error_page 411 = @my_error;
                location @my_error {
                 }
                root /export/data/WebRoot/master.solr.com;#master 项目文件的目录 
      location / {
        proxy_next_upstream     http_500 http_502 http_503 http_504 error timeout invalid_header;
        proxy_set_header        Host  $host;
        proxy_set_header        X-Forwarded-For $proxy_add_x_forwarded_for;#反向代理获取用户访问的ip地址
        proxy_pass              http://tomcat_master.solr;
        expires                 1d;
        }
        location /logs/ {
                autoindex       off;
                deny all;
        }
}
 
upstream tomcat_slave.solr {
      server 127.0.0.1:9001  weight=10 max_fails=2 fail_timeout=30s;
    }
server          {
                listen                   80;
                server_name              slave.solr.com;#项目域名 slave
                access_log               /export/servers/nginx
/nginx-1.5.0/sbin/logs/slave.solr.com/slave.solr.com_access.log main;#slave 访问log
                error_log                /export/servers/nginx
/nginx-1.5.0/sbin/logs/slave.solr.com/slave.solr.com_error.log warn;
                error_page 411 = @my_error;
                location @my_error {
                 }
                root /export/data/WebRoot/slave.solr.com;
#slave项目文件存放目录,之前已经配置过了
      location / {
        proxy_next_upstream     http_500 http_502 http_503
 http_504 error timeout invalid_header;
        proxy_set_header        Host  $host;
        proxy_set_header        X-Forwarded-For
 $proxy_add_x_forwarded_for;
        proxy_pass              http://tomcat_slave.solr;
        expires                 1d;
        }
        location /logs/ {
                autoindex       off;
                deny all;
        }
}
   以上两个文件创建之后,修要修改nginx的总的配置文件 /export/servers/nginx/nginx-1.5.0/sbin/conf/nginx.conf
user                                    username  username; 
worker_processes                        2;
error_log                               /export/servers/nginx
/nginx-1.5.0/sbin/logs/error.log  warn; #配置nginx error log位置
pid                                     /export/servers
/nginx/nginx-1.5.0/sbin/logs/nginx.pid;
worker_rlimit_nofile                    65535;
events
{
                                        use epoll;
                                        worker_connections 65535;
#配置工作连接数
}
http
{
        include                         mime.types;
#       default_type                    text/plain;
#application/octet-stream
        default_type                    application/octet-stream;
        server_tokens                   off;
        log_format main                 '$remote_addr - 
$remote_user [$time_local] '
 '"$request" $status $bytes_sent '
'"$http_referer" "$http_user_agent" '
        #charset                        utf-8;
        server_names_hash_bucket_size   128;
        client_header_buffer_size       32k;
        large_client_header_buffers     4 32k;
        client_max_body_size            300m;
        sendfile                        on;
        tcp_nopush                      on;
        keepalive_timeout               0;
        tcp_nodelay                     on;
        client_body_buffer_size         512k;
        fastcgi_intercept_errors        on;
        proxy_connect_timeout           90;
        proxy_read_timeout              180;
        proxy_send_timeout              180;
        proxy_buffer_size               256k;
        proxy_buffers                   4 256k;
        proxy_busy_buffers_size         256k;
        proxy_temp_file_write_size      256k;
        server_name_in_redirect         off;
        proxy_hide_header       X-Powered-By;
        error_page 400 401 402 403 404 405 408 410 412
 413 414 415 500 501 502 503 506 = 
http://www.baidu.com/search/error.html; #借用下百度的error页
include domains/*; 
#所有的配置文件都包含到nginx.conf文件中了这里面的文件就是master.solr.nginx.conf ,slave.solr.nginx.conf
        server
                {
                 listen                 80;
                 server_name            www.baidu.com;
        location / {
                 access_log             off;
                 }
        location /logs {
                 access_log             off;
                 }
        location /html {
                 access_log             off;
                 }
        }
}
 
 所有的配置都已经完成,然后用有root权限的帐号启动nginx(执行/export/servers/nginx/nginx-1.5.0/sbin/sbin下面的nginx)
root@lcpc:/export/servers/nginx/nginx-1.5.0/sbin/sbin# ./nginx
 
 修改host文件,增加下面两行host
vim /etc/hosts
127.0.0.1 master.solr.com
127.0.0.1 slave.solr.com
 打开浏览器访问master.solr.com 和slave.solr.com现实solr管理页

访问不同的域名,nginx自动去访问了相应的项目,打开/export/servers/nginx

/nginx-1.5.0/sbin/logs/master.solr.com/master.solr.com_access.log 可以看到

刚刚的访问log

127.0.0.1 - - [29/Jun/2013:00:33:15 +0800] "GET /null/admin/system?wt=
json HTTP/1.1" 404 1142 "http://127.0.0.1/" "Mozilla/5.0 (X11; Ubuntu;
 Linux i686; rv:17.0) Gecko/20100101 Firefox/17.0" server_names_hash_
bucket_size128
127.0.0.1 - - [29/Jun/2013:00:35:38 +0800] "GET /null/admin/syste
m?wt=json HTTP/1.1" 404 1142 "http://master.solr.com/" "Mozilla/5.0
 (X11; Ubuntu; Linux i686; rv:17.0) Gecko/20100101 Firefox/17.0" s
erver_names_hash_bucket_size128
127.0.0.1 - - [29/Jun/2013:00:36:10 +0800] "GET /null/admin/syste
m?wt=json HTTP/1.1" 404 1142 "http://master.solr.com/" "Mozilla/5.
0 (X11; Ubuntu; Linux i686; rv:17.0) Gecko/20100101 Firefox/17.0" 
server_names_hash_bucket_size128

 打开/export/servers/nginx/nginx-1.5.0/sbin/logs/slave.solr.com/slave.solr.com_access.log

127.0.0.1 - - [29/Jun/2013:00:29:07 +0800] "GET /null/admin/system?wt=
json HTTP/1.1" 404 1142 "http://slave.solr.com/" "Mozilla/5.0 (X11; Ub
untu; Linux i686; rv:17.0) Gecko/20100101 Firefox/17.0" server_names_ha
sh_bucket_size128
127.0.0.1 - - [29/Jun/2013:00:29:07 +0800] "GET /img/ico/construction.p
ng HTTP/1.1" 200 861 "http://slave.solr.com/css/styles/common.css" "Mo
zilla/5.0 (X11; Ubuntu; Linux i686; rv:17.0) Gecko/20100101 Firefox/1
7.0" server_names_hash_bucket_size128
127.0.0.1 - - [29/Jun/2013:00:29:07 +0800] "GET /img/favicon.ico HTTP/
1.1" 200 1454 "-" "Mozilla/5.0 (X11; Ubuntu; Linux i686; rv:17.0) Geck
o/20100101 Firefox/17.0" server_names_hash_bucket_size128
127.0.0.1 - - [29/Jun/2013:00:38:37 +0800] "GET /null/admin/system?wt=j
son HTTP/1.1" 404 1142 "http://slave.solr.com/" "Mozilla/5.0 (X11; Ubu
ntu; Linux i686; rv:17.0) Gecko/20100101 Firefox/17.0" server_names_ha
sh_bucket_size128

 总结:1.安装nginx

            2.安装tomcat 配置项目文件路径

            3.配置项目nginx upstream ,配置nginx总的配置文件

            4.修改host文件用于测试

相关推荐