linux下nginx与tomcat整合

来源:互联网 发布:淘宝商城权威检测 编辑:程序博客网 时间:2024/05/22 04:33

Linux下nginx和tomcat整合

1、  安装nginx

下载nginx-1.7.7.tar.gz

tar –zxvf nginx-1.7.7.tar.gz

./configure

make

make install

 

执行完后会提示一个错误,说缺少PCRE library 这个是HTTP Rewrite 模块,也即是url静态化的包
可上传pcre-8.36.tar.gz,输入如下命令安装:

#tar zxvf pcre-8.36.tar.gz

#cd pcre-8.36

#./configure

#make

#make install

 

linux下安装安装pcre-8.36 configure:error: You need a C++ compiler for C++ support。

 

linux下安装安装pcre-8.36

./configure --prefix=/usr/local/pcre  出现以下错误

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

解决办法,使用yum安装c++编译器。

yum install -y gcc gcc-c++

 

安装成功后,启动nginx提示:errorwhile loading shared libraries: libpcre.so.1: cannot open shared object file:No such file or directory,意思是找不到libpcre.so.1这个模块,而导致启动失败。

 

[root@lee ~]# /usr/local/webserver/nginx/sbin/nginx

nginx: error while loading shared libraries: libpcre.so.1: cannot open shared object file: No such file or directory

经过搜索资料,发现部分linux系统存有的通病。要解决这个方法非常容易,方法如下:

如果是32位系统

[root@lee ~]# ln -s /usr/local/lib/libpcre.so.1 /lib

如果是64位系统

[root@lee ~]# ln -s /usr/local/lib/libpcre.so.1 /lib64

然后在启动nginx就OK了

[root@lee ~]#/usr/local/webserver/nginx/sbin/nginx

 

2nginx安装成功后的安装目录为/usr/local/nginx
conf文件夹中新建proxy.conf,用于配置一些代理参数,内容如下:

 

#!nginx (-) 

# proxy.conf 

proxy_redirect          off;

proxy_set_header        Host $host;

proxy_set_header        X-Real-IP$remote_addr;  #获取真实ip

#proxy_set_header      X-Forwarded-For   $proxy_add_x_forwarded_for; #获取代理者的真实ip

client_max_body_size    10m;

client_body_buffer_size 128k;

proxy_connect_timeout   90;

proxy_send_timeout      90;

proxy_read_timeout      90;

proxy_buffer_size       4k;

proxy_buffers           4 32k;

proxy_busy_buffers_size 64k;

proxy_temp_file_write_size 64k;

 

 

编辑安装目录下conf文件夹中的nginx.conf,输入如下内容  

#运行nginx所在的用户名和用户组

#user  www www; 

  

#启动进程数

worker_processes 8;

#全局错误日志及PID文件

error_log /usr/local/nginx/logs/nginx_error.log  crit;

  

pid       /usr/local/nginx/nginx.pid;

  

#Specifies the value for maximum filedescriptors that can be opened by this process.

  

worker_rlimit_nofile 65535;

#工作模式及连接数上限

events

{

  use epoll;

  worker_connections 65535;

}

#设定http服务器,利用它的反向代理功能提供负载均衡支持

http

{

  #设定mime类型

  include      mime.types;

  default_type application/octet-stream;

  include/usr/local/nginx/conf/proxy.conf;

  #charset  gb2312;

  #设定请求缓冲    

  server_names_hash_bucket_size 128;

  client_header_buffer_size32k;

  large_client_header_buffers 4 32k;

  client_max_body_size 8m;

        

  sendfile on;

  tcp_nopush    on;

  

  keepalive_timeout 60;

  

  tcp_nodelay on;

  

#  fastcgi_connect_timeout 300;

#  fastcgi_send_timeout 300;

#  fastcgi_read_timeout 300;

#  fastcgi_buffer_size 64k;

#  fastcgi_buffers 4 64k;

#  fastcgi_busy_buffers_size 128k;

#  fastcgi_temp_file_write_size128k;

  

#  gzip on;

#  gzip_min_length  1k;

#  gzip_buffers     4 16k;

#  gzip_http_version 1.0;

#  gzip_comp_level 2;

# gzip_types       text/plainapplication/x-javascript text/css application/xml;

#  gzip_vary on;

  

  #limit_zone crawler  $binary_remote_addr  10m;

 ###禁止通过ip访问站点

  server{

        server_name_;

        return 404;

        }

  

  

  server

  {

    listen       80;

    server_name localhost;

    index index.htmlindex.htm index.jsp;#设定访问的默认首页地址

    root /home/www/web/ROOT;#设定网站的资源存放路径

  

    #limit_conn  crawler  20;    

      

    location ~.*.jsp$ #所有jsp的页面均交由tomcat处理

    {

      indexindex.jsp;

      proxy_passhttp://localhost:8080;#转向tomcat处理

      }

        

      

    location ~.*\.(gif|jpg|jpeg|png|bmp|swf)$ #设定访问静态文件直接读取不经过tomcat

    {

      expires     30d;

    }

  

    location ~.*\.(js|css)?$

    {

      expires     1h;

    }    

  

#定义访问日志的写入格式

     log_format access  '$remote_addr - $remote_user [$time_local]"$request" '

              '$status$body_bytes_sent "$http_referer" '

              '"$http_user_agent"$http_x_forwarded_for';

    access_log /usr/local/nginx/logs/localhost.log access;#设定访问日志的存放路径

  

      }   

}

3、修改/usr/local/nginx/conf/nginx.conf配置文件后,请执行以下命令检查配置文件是否正确:

#/usr/local/nginx/sbin/nginx -t

如果屏幕显示以下两行信息,说明配置文件正确:  

the configuration file /usr/local/nginx/conf/nginx.confsyntax is ok

theconfiguration file /usr/local/nginx/conf/nginx.conf was tested successfully

如果提示unknown host,则可在服务器上执行:ping www.baidu.com如果也是同样提示unknown host则有两种可能:
    a、服务器没有设置DNS服务器地址,查看/etc/resolv.conf下是否设置,若无则加上
    b、防火墙拦截

 4、启动nginx的命令

#/usr/local/nginx/sbin/nginx

这时,输入以下命令查看Nginx主进程号:

ps -ef | grep "nginx: masterprocess" | grep -v "grep" | awk -F '' '{print $2}'

5、停止nginx的命令

#/usr/local/nginx/sbin/nginx -s stop

6、在不停止Nginx服务的情况下平滑变更Nginx配置
a、修改/usr/local/nginx/conf/nginx.conf配置文件后,请执行以下命令检查配置文件是否正确:

/usr/local/nginx/sbin/nginx -t

  如果屏幕显示以下两行信息,说明配置文件正确:

theconfiguration file /usr/local/nginx/conf/nginx.conf syntax is ok

theconfiguration file /usr/local/nginx/conf/nginx.conf was tested successfully

b、这时,输入以下命令查看Nginx主进程号:

ps -ef | grep "nginx: masterprocess" | grep -v "grep" | awk -F '' '{print $2}'

屏幕显示的即为Nginx主进程号,例如:
  6302
  这时,执行以下命令即可使修改过的Nginx配置文件生效:

kill -HUP 6302

  
或者无需这么麻烦,找到Nginx的Pid文件:

kill -HUP `cat/usr/local/nginx/nginx.pid`

7、nginx启动好后启动tomcat,此时输入http://主机ip地址即可看到“My web!” 

 

 

二、其他
stub_status
语法: stub_status on

默认值: None

作用域: location

创建一个 location 区域启用 stub_status

“stub status” 模块返回的状态信息跟 mathopd’s 的状态信息很相似. 返回的状态信息如下:

Active connections: 291

server accepts handled requests

16630948 16630948 31070465

Reading: 6 Writing: 179 Waiting: 106

active connections— 对后端发起的活动连接数

server acceptshandled requests — nginx 总共处理了 16630948 个连接, 成功创建 16630948 次握手 (证明中间没有失败的), 总共处理了 31070465 个请求 (平均每次握手处理了 1.8个数据请求)

reading — nginx 读取到客户端的Header信息数

writing — nginx 返回给客户端的Header信息数

waiting — 开启 keep-alive 的情况下,这个值等于 active – (reading+ writing),意思就是Nginx说已经处理完正在等候下一次请求指令的驻留连接

 

 

0 0
原创粉丝点击