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

[经验分享] Resin+Nginx动静分离和负载均衡

[复制链接]
累计签到:1 天
连续签到:1 天
发表于 2017-2-15 09:21:41 | 显示全部楼层 |阅读模式
案例:目前很多人喜欢Nginx+tomcat动静分离,或者反代后端tomcat集群,不过很多人也喜欢用Resin。
本人花了些功夫总结了Resin和tomcat区别:
特性\容器
resin
tomcat
公司
CAUCHO
Apache
是否收费
不完全免费(pro版本收费)
完全免费
Eclipse下调试开发
适中
复杂
性能
轻量级,pro版本支持负载均衡,以及缓存功能
轻量级(NIO模式性能高些),支持负载均衡
多实例
略麻烦
比较简单
集群部署
支持
支持
是否支持php
新版本支持(但很少用)
默认不支持(可配置)
用户喜好
略少
略多
常用组合
Nginx+Resin or+其它
Nginx+tomcat+or其它
报错机制
简单
复杂
标准|开发|行为喜好
两者在标准支持,开发使用,用户喜好有很大关系
常用JavaEE容器有很多:Tomcat、Resin、JBoss、Glassfish ,注意weblogic属于应用服务器。
1、安装配置Resin:
1.1)jdk目录创建:
1
2
3
4
5
6
7
8
9
[iyunv@resin ~]# tar zxvfjdk-7u75-linux-x64.tar.gz
[iyunv@resin ~]# mkdir/usr/local/jdk1.7
[iyunv@resin ~]# mvjdk1.7.0_75/* /usr/local/jdk1.7/
[iyunv@resin ~]# cat/etc/profile.d/jdk.sh
export JAVA_HOME=/usr/local/jdk1.7/
exportCLASSPATH=.:$JAVA_HOME/lib/dt.jar:$JAVA_HOME/lib/tools.jar
exportPATH=$PATH:$JAVA_HOME/bin
export JAVA_HOMECLASSPATH PATH
[iyunv@resin ~]#



1.2)Resin安装配置:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
[iyunv@resin ~]# yum install ntpdate -y
[iyunv@resin~]# ntpdate time.windows.com安装resin
[iyunv@resin~]# tar xf resin-4.0.50.tar.gz -C /usr/local/
[iyunv@resin~]# cd /usr/local
[iyunv@resin~]# #./configure --prefix=/usr/local/resin
[iyunv@resin~]# #make
[iyunv@resin ~]# #make install
[iyunv@resin local]# ln -s resin-4.0.50 resin
[iyunv@resin local]#cat / etc/profile.d/resin.sh
exportRESIN_HOME=/usr/local/resin
[iyunv@resin local]#
[iyunv@resin local]#cp /usr/local/resin/bin/resin.sh /etc/init.d/resin
[iyunv@resin local]#chmod +x /etc/init.d/resin
[iyunv@resin local]#/etc/init.d/resin start



wKioL1iipR3A9JKIAAEMwGUHI8g203.png
1.3)首页访问:
wKioL1iipWGwgVtWAAA3GJlrWQY907.png
1.4)配置多个项目:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
[iyunv@resin ~]# cd /usr/local/resin/conf
[iyunv@resin conf]# vim resin.xml
#配置多个项目:
<clusterid="app1">
<!-- define the servers in the cluster -->
<server-multiid-prefix="app1"address-list="${app1_servers}"port="6800"/>  //端口1
<!-- the default host, matching any host name -->
<hostid=""root-directory=".">
<web-appid="/"root-directory="/usr/local/resin/webapps/app1"/>   //项目1
</host>
</cluster>
<clusterid="app2">
<!-- define the servers in the cluster -->
<server-multiid-prefix="app2"address-list="${app2_servers}"port="6801"/> //端口2
<!-- the default host, matching any host name -->
<hostid=""root-directory=".">
<web-appid="/"root-directory="/usr/local/resin/webapps/app2"/> //项目2
</host>
</cluster>



1.4.1)定义端口:
1
2
3
4
5
# app-tier Triad servers: app-0 app-1 app-2
app1_servers      : 127.0.0.1:6800
app2_servers      : 127.0.0.1:6801
app1.http          : 8080
app2.http          : 8081



1.5)JDBC配置:
1
2
3
4
5
6
7
8
9
10
11
<database>
<jndi-name>jdbc/test</jndi-name>
<driver type="com.microsoft.jdbc.sqlserver.SQLServerDriver">
<url>jdbc:microsoft:sqlserver://localhost:3306;databasename=Northwind</url>  //后端数据库
<user>sa</user>
<password>password</password>  //密码
</driver>
<prepared-statement-cache-size>8</prepared-statement-cache-size>
<max-connections>20</max-connections>
<max-idle-time>30s</max-idle-time>
</database>



注意:jdbc文件可自己定义,需要导入相应的驱动包。
2、安装配置Nginx:

1
2
3
4
useradd nginx -M -s /sbin/nologin
tar xf nginx-1.9.2.tar.gz
cd nginx-1.9.2
./configure --user=nginx --group=nginx --prefix=/usr/local/nginx  --with-http_stub_status_module--with-http_ssl_module --with-http_realip_module  --with-http_flv_module --with-http_mp4_module --with-http_gzip_static_module&&make &&make install



2.1)nginx.conf配置负载均衡:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
user  nginx;

worker_processes  8;

#worker_cpu_affinity 00000001 00000010 00000100 00001000 00010000 00100000 01000000 10000000;

error_log  logs/error.log  info;

pid        /var/run/nginx.pid;

events {
use epoll;
worker_connections  1024;
}

http {
include       mime.types;

default_type  application/octet-stream;

charset UTF-8;

server_names_hash_bucket_size 128;

client_header_buffer_size 32k;

large_client_header_buffers 4 32k;

client_max_body_size 8m;

#limit_conn_zone $binary_remote_addr zone=one:32k;
#limit_conn_zone $binary_remote_addr zone=permitip:10m;

error_page   404 =  http://www.iyunv.net/404.html;

#error_page   404  = /40x.html;
#location = /40x.html{
#root   html;
#}

#error_page   500 502 503 504  /50x.html;
#location = /50x.html {
#root   html;
#}

open_file_cache max=102400 inactive=20s;

sendfile        on;

#autoindex on;

tcp_nopush  on;
tcp_nodelay on;

keepalive_timeout  60;

gzip  on;
gzip_min_length  1k;
gzip_buffers     4 16k;
gzip_http_version 1.0;
gzip_comp_level 2;
#gzip_types text/plain application/x-javascript text/css application/xml;
gzip_vary 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_size 128k;

#如果要启用负载均衡
#upstream www.xxx.com {   
#zone myapp1 64k;
#server 192.168.1.220:80 weight=1 max_fails=2 fail_timeout=30s slow_start=30s;
#server 192.168.1.221:80 weight=1 max_fails=2 fail_timeout=30s;   
#}

#upstream www.xxx.org {   
#zone myapp1 64k;
#server 192.168.1.220:80 weight=1 max_fails=2 fail_timeout=30s slow_start=30s;
#server 192.168.1.221:80 weight=1 max_fails=2 fail_timeout=30s;   
#}   
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 logs/access.log access;

include vhost/*.conf;
}



2.2)renzhiyuan.conf配置动静分离:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
server {
        listen       80;
        server_name  
        #路径根据 Resin定义路径配置,这里根据默认
        root   /usr/local/resin/webapps/ROOT;  
        index  index.html index.php index.jsp index.html;

#location ~ \.php$ {
#            root           html;
#            fastcgi_pass   127.0.0.1:9000;
#            fastcgi_index  index.php;
#            include        fastcgi.conf;
#        }

location ~ .(jsp|jspx|do)?$ {
proxy_set_header Host $host;
proxy_pass http://127.0.0.1:8080;
proxy_redirect off;

proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header Host $host;
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;
}

location ~ .*\.(htm|html|gif|jpg|jpeg|png|bmp|swf|ioc|rar|zip|txt|flv|mid|doc|ppt|pdf|xls|mp3|wma)$ {
expires      30d;
}

location ~ .*\.(js|css)?$ {
expires      12h;
}
}





运维网声明 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-342318-1-1.html 上篇帖子: resin配置jndi方式连接sql server 2005和2000 下篇帖子: resin日志
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

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

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

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

扫描微信二维码查看详情

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


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


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


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



合作伙伴: 青云cloud

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