首页 > 代码库 > nginx+Tomcat实现动静分离架构

nginx+Tomcat实现动静分离架构

最近新部署了一个项目jlj-cms-erp-web,要求使用nginx+Tomcat将静态页面和动态的请求分开处理,减轻Tomcat服务器的压力

在部署项目的这台机器上(192.168.1.110)并没有nginx,所以还需要将这台机器上生成的静态页面备份到装有nginx的另一台机器上(192.168.1.191)

首先安装tomcat,具体过程不详细写了,见博客

http://itzhongxin.blog.51cto.com/12734415/1915155

注意修改端口号、jvmRoute、Context path、启动内存,

在项目下的webapps文件夹中新建一个www文件夹,该文件夹中的文件将被备份

我们用rsync命令来实现两台机器之间的备份,先配置被备份端,就是没有安装nginx的机器

安装依赖包

apt-get update
apt-get install gcc
apt-get install make
tar -zxvf rsync-3.1.2.tar.gz 
cd rsync-3.1.2
./configure --prefix=/usr/local/rsync && make && make install

安装完成后在/usr/local/rsync目录下应该产生bin share两个目录
然后在当前目录下创建log、pid、conf、password 分别存放日志、程序进程号、配置文件、密码

设置配置文件

vim rsyncd.conf
use chroot = nomax 
connections = 10
pid file = /usr/local/rsync/pid/rsyncd.pid
log file = /usr/local/rsync/log/rsyncd.log
[www]     #随便起的名字,但是要与备份端相同!
uid = root
gid = root
path = /opt/tomcat8.0.24/jlj-cms-erp-web/webapps/www  #需要备份的路径
comment = wwwbackup
read only = no
#write only = no
list = yes
hosts allow = 192.168.1.191/24   #备份到此机器上
hosts dengy = *
auth users = backup
secrets file = /usr/local/rsync/password/server.pass   #密码文件路径

设置密码文件

vim server.pass 
backup:BACKup_194

修改密码文件权限

chmod 600 server.pass

启动rsync服务

/usr/local/rsync/bin/rsync --daemon --config=/usr/local/rsync/conf/rsyncd.conf

过滤程序是否启动成功

ps -ef | grep rsync
root 22620  1  0 15:17 ?  00:00:00 ./bin/rsync --daemon --config=/usr/local/rsyn/conf/rsyncd.conf

然后在/opt/tomcat8.0.24/jlj-cms-erp-web/webapps/www下解压一个site.zip包,该文件夹中有大量静态HTML文件,我们需要将他同步到192.168.1.191上


接下来配置备份端,同上

安装完成后在/usr/local/rsync目录下应该产生bin share两个目录
创建pwd目录存放密码文件

vim server.pass 
BACKup_194

修改密码文件权限

chmod 600 server.pass


在/var/www下新建一个jljapp文件夹,将东西备份到该路径下

测试一下,是否能备份成功

rsync -vzrtopg --progress --password-file=/usr/local/rsync/pwd/server.pass backup@192.168.1.110::
www
 /var/www/jljapp

*此处标红必须与被备份端中rsync.conf中模块名相同

看一下备份路径中有没有成功的备份到我们需要的东西

cd /var/www/jljapp
ll

如果备份成功,编写一个脚本

cd /usr/local/rsync/bin
vim rsyncback_110_www.sh
#!/bin/sh
/usr/bin/rsync -vzrtopg --progress --password-file=/usr/local/rsync/pwd/server.pass backup@192.168.1.110::www /var/www/jljapp

修改脚本权限

chmod a+x rsyncback_110_www.sh

制定任务计划,设定每周五晚上8点执行同步任务

#每隔五分钟,备份110cms产生的html
*/5 * * * *  /bin/sh /usr/local/rsync/bin/rsyncback_110_www.sh

备份工作完成了,接下来就是nginx将请求转发到tomcat上了

在被备份端,也就是192.168.1.110上部署项目jlj-cms-erp-web

将项目包解压到/opt/tomcat8.0.24/jlj-cms-erp-web/webapps下,将压缩包删除

启动项目,查看日志

cd bin/
./startup.sh 
tail -f ../logs/catalina.out


在nginx机器上绑定域名,nginx收到客户端的访问请求,就根据地址转发到对应的tomcat服务器上

现在的需求是有三个域名,需要三个配置文件

cms.erp.jinlejia.com
cmsstyle.erp.jinlejia.com
mhelp.erp.jinlejia.com

需要修改nginx的配置文件,新建一个jljapp文件夹,放三个配置文件

cd /etc/nginx/conf.d
mkdir jljapp

复制一个之前项目配置好的文件来修改

cp group_js.conf jljapp/mhelp.conf
vim mhelp.conf
server {    
    listen      80;
    server_name  mhelp.erp.jinlejia.com;
    root   /var/www/jljapp/site/help;
    index  index.html index.htm;
       location / {
    }
    error_page  404 500 502 503 504  /404.html;
        location = /404.html {
        root   /usr/share/nginx/html;
    }
}
cp mhelp.conf cmsstyle.confvim cmsstyle.conf
server {
    listen      80;
    server_name cmsstyle.erp.jinlejia.com;
    root   /var/www/jljapp;
    index  index.html index.htm;
    location / {
    }
    error_page  404 500 502 503 504  /404.html;
        location = /404.html {
        root   /usr/share/nginx/html;
    }
}
cp sso.conf  jljapp/cms.confcd jljapp/vim cms.conf 
upstream jljappcms {
    server 192.168.1.110:8010  weight=20 max_fails=2 fail_timeout=30s;
                  ip_hash;
}
server {
    listen       80;
    server_name cms.erp.jinlejia.com;
    root   /Disk/var/www/index;
    index  index.html index.htm;
    proxy_max_temp_file_size 0;
    large_client_header_buffers 4 16k;
    client_max_body_size 300m;
    client_body_buffer_size 128k;
    proxy_connect_timeout 600;
    proxy_read_timeout 600;
    proxy_send_timeout 600;
     proxy_buffering on;
    proxy_buffer_size 64k;
    proxy_buffers   32 64k;
    proxy_busy_buffers_size 128k;
    location / {
    proxy_pass      http://jljappcms;
    proxy_set_header HOST   $host;
    proxy_set_header X-Real-IP      $remote_addr;
    proxy_set_header X-Forwarded-FOR $proxy_add_x_forwarded_for;
        }
    #error_page   500 502 503 504  /50x.html;
    #location = /50x.html {
    #root   /usr/share/nginx/html;
            }
}


最后修改主配置文件,在最后一行添加,当nginx加载配置文件时,自动加载include中的子配置文件

vim nginx.conf
include /etc/nginx/conf.d/jljapp/*.conf;

重启一下nginx

service nginx restart




本文出自 “学习改变命运” 博客,请务必保留此出处http://itzhongxin.blog.51cto.com/12734415/1925160

nginx+Tomcat实现动静分离架构