- 浏览: 106881 次
- 性别:
- 来自: 成都
文章分类
最新评论
-
lws0402:
sghys 写道附件根本没这代码代码都贴在网上了,很简单。附件 ...
jdk 1.5 搭建 jax-ws -
sghys:
附件根本没这代码
jdk 1.5 搭建 jax-ws -
dukunpeng22:
按照楼主的思路,也可以做一个文字的倒影效果,蛮不错的
ImageView倒影效果 -
yangpanwww:
哈哈。。原因不是你说的这个原因吧
在 tomc ...
Xfire调用webservice出错 -
mapeijie888:
貌似还是不行啊 兄弟贴代码出来看看
javah编译带包class文件出错解决方法
terracotta + tomcat + nginx集群
- 博客分类:
- java
今天研究了一下terracotta + tomcat的集群,记录一下。
一、环境
本机,ip:192.168.2.158 win7 64位
虚拟机,ip:192.168.81.128 RedHat 64位
本机装两个tomcat 和 一个terracotta,虚拟机装一个teracotta。
虚拟机也要装jdk,因为terracotta需要jdk的支持。
terracotta安装目录,win7为G:\java_workspaces\terracotta-3.7.7 虚拟机为/usr/lws_life/terracotta-3.7.7
二、步骤
1、将terracotta安装目录下sessions文件夹里的terracotta-session-1.3.7.jar 和 common文件夹里的 terracotta-toolkit-1.6-runtime-5.7.0.jar 文件 都拷贝到 tomcat的lib中(两个tomcat都需要拷贝)。
2、在terracotta安装目录下创建tc-config.xml的配置文件,内容如下
3、修改tomcat安装目录conf文件夹中的context.xml文件,添加内容如下:
4、配置nginx,配置文件为nginx安装目录下conf文件夹中的nginx.conf,主要修改代码如下:
5、启动terracotta服务。
win7 下进入cmd模式,进入terracotta的bin目录,执行如下命令
linux下,进入terracotta的bin目录,执行如下命令
注意:这里启动需要指定tc-config.xml文件,否则会使用默认的配置文件。
如果linux下不能执行该命令,需要赋予权限,最简单的就是 chmod 777 -R <terracotta安装路径>
如果配置无误,会看到下面的信息
[img]
[/img]
6、启动tomcat服务 和 nginx服务。
访问 http://127.0.0.1(nginx 和 tomcat都是装在本机的,所以可以用127.0.0.1访问,项目部署时去掉项目名,比如http://127.0.0.1:8080/coal 访问的要改为 http://127.0.0.1:8080访问)
7、测试
查看sessionId,应该会在原有的sessionId后面加上 .X,X为数字,代表不同的服务器,如hgdjfgdhsgfjhsjhg.1或 hgdjfgdhsgfjhsjhg.2,这时关闭其中一台tomcat,项目可以正常运行,然后启动关闭的tomcat,在关闭另一台tomcat,发现session已经共享,说明集群配置成功
一、环境
本机,ip:192.168.2.158 win7 64位
虚拟机,ip:192.168.81.128 RedHat 64位
本机装两个tomcat 和 一个terracotta,虚拟机装一个teracotta。
虚拟机也要装jdk,因为terracotta需要jdk的支持。
terracotta安装目录,win7为G:\java_workspaces\terracotta-3.7.7 虚拟机为/usr/lws_life/terracotta-3.7.7
二、步骤
1、将terracotta安装目录下sessions文件夹里的terracotta-session-1.3.7.jar 和 common文件夹里的 terracotta-toolkit-1.6-runtime-5.7.0.jar 文件 都拷贝到 tomcat的lib中(两个tomcat都需要拷贝)。
2、在terracotta安装目录下创建tc-config.xml的配置文件,内容如下
<?xml version="1.0" encoding="UTF-8" ?> <tc:tc-config xmlns:tc="http://www.terracotta.org/config" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://www.terracotta.org/schema/terracotta-6.xsd"> <tc-properties> <property name="l2.nha.dirtydb.autoDelete" value="true"/> <property name="l1.cachemanager.enabled" value="true"/> <property name="logging.maxLogFileSize" value="1024"/> </tc-properties> <system> <configuration-model>development</configuration-model> </system> <servers> <!-- 这里配置第一台 terracotta服务器信息 --> <server host="192.168.2.158" name="MyServer1" bind="192.168.2.158"> <data>G:/java_workspaces/terracotta-3.7.7/server-data</data> <logs>G:/java_workspaces/terracotta-3.7.7/server-logs</logs> <index>G:/java_workspaces/terracotta-3.7.7/server-index</index> <statistics>G:/java_workspaces/terracotta-3.7.7/server-statistics</statistics> <!-- 这些端口都是默认的 --> <dso-port bind="192.168.2.158">9510</dso-port> <jmx-port bind="192.168.2.158">9520</jmx-port> <l2-group-port bind="192.168.2.158">9530</l2-group-port> <authentication/> <http-authentication> <user-realm-file>G:/java_workspaces/terracotta-3.7.7/realm.properties</user-realm-file> </http-authentication> <dso> <client-reconnect-window>120</client-reconnect-window> <persistence> <mode>temporary-swap-only</mode> </persistence> <garbage-collection> <enabled>true</enabled> <verbose>false</verbose> <interval>3600</interval> </garbage-collection> </dso> </server> <!-- 这里配置第二台terracotta服务器信息 --> <server host="192.168.81.128" name="MyServer2" bind="192.168.81.128"> <data>/usr/lws_file/terracotta-3.7.7/server-data</data> <logs>/usr/lws_file/terracotta-3.7.7/server-logs</logs> <index>/usr/lws_file/terracotta-3.7.7/server-index</index> <statistics>/usr/lws_file/terracotta-3.7.7/server-statistics</statistics> <dso-port bind="192.168.81.128">9510</dso-port> <jmx-port bind="192.168.81.128">9520</jmx-port> <l2-group-port bind="192.168.81.128">9530</l2-group-port> <authentication/> <http-authentication> <user-realm-file>/usr/lws_file/terracotta-3.7.7/realm.properties</user-realm-file> </http-authentication> <dso> <client-reconnect-window>120</client-reconnect-window> <persistence> <mode>temporary-swap-only</mode> </persistence> <garbage-collection> <enabled>true</enabled> <verbose>false</verbose> <interval>3600</interval> </garbage-collection> </dso> </server> <ha> <mode>networked-active-passive</mode> <networked-active-passive> <election-time>5</election-time> </networked-active-passive> </ha> <update-check> <enabled>true</enabled> <period-days>10</period-days> </update-check> </servers> <clients> <logs>logs-%i</logs> </clients> </tc:tc-config>
3、修改tomcat安装目录conf文件夹中的context.xml文件,添加内容如下:
<?xml version="1.0" encoding="UTF-8"?> <Context> <WatchedResource>WEB-INF/web.xml</WatchedResource> <!-- 主要添加这一段 我用的tomcat6.0, tcConfigUrl为terracotta服务器的地址,端口就是tc-config.xml文件中设置的dso端口,这里默认为9510,多个服务器信息用逗号分隔 --> <Valve className="org.terracotta.session.TerracottaTomcat60xSessionValve" tcConfigUrl="192.168.2.158:9510,192.168.81.128:9510"/> </Context>
4、配置nginx,配置文件为nginx安装目录下conf文件夹中的nginx.conf,主要修改代码如下:
#这里是配置nginx的负载均衡 有四种负载均衡的方式,这里采用权值的分配 upstream mysvr { #weigth参数表示权值,权值越高被分配到的几率越大 #本机上的Squid开启3128端口 #这里的ip和端口请对照tomcat做相应修改 server 127.0.0.1:8080 weight=1; server 127.0.0.1:8081 weight=1; } server { #监听80端口 listen 80; server_name localhost; location / { #这里的mysvr为上方配置的 负载均衡的信息 proxy_pass http://mysvr; proxy_redirect off; proxy_set_header Host $host; proxy_set_header X-Real-IP $remote_addr; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; client_max_body_size 10m; client_body_buffer_size 128k; #该值表示一台服务器down了之后,如果分配给该服务器资源,链接超过1秒钟,就重新分配资源 proxy_connect_timeout 1; 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; } }
5、启动terracotta服务。
win7 下进入cmd模式,进入terracotta的bin目录,执行如下命令
start-tc-server.bat -f <安装路径>/tc-config.xml
linux下,进入terracotta的bin目录,执行如下命令
start-tc-server.sh -f <安装路径>/tc-config.xml
注意:这里启动需要指定tc-config.xml文件,否则会使用默认的配置文件。
如果linux下不能执行该命令,需要赋予权限,最简单的就是 chmod 777 -R <terracotta安装路径>
如果配置无误,会看到下面的信息
[img]
[/img]
6、启动tomcat服务 和 nginx服务。
访问 http://127.0.0.1(nginx 和 tomcat都是装在本机的,所以可以用127.0.0.1访问,项目部署时去掉项目名,比如http://127.0.0.1:8080/coal 访问的要改为 http://127.0.0.1:8080访问)
7、测试
查看sessionId,应该会在原有的sessionId后面加上 .X,X为数字,代表不同的服务器,如hgdjfgdhsgfjhsjhg.1或 hgdjfgdhsgfjhsjhg.2,这时关闭其中一台tomcat,项目可以正常运行,然后启动关闭的tomcat,在关闭另一台tomcat,发现session已经共享,说明集群配置成功
发表评论
-
java生成不重复的用户邀请码
2016-05-26 11:00 7020直接上代码,根据一个值M(可以是用户唯一表示,如主键id,或手 ... -
jdk 1.5 搭建 jax-ws
2013-09-26 11:30 4465从jdk1.6开始,可以直接搭建jax-ws,但是jdk1.5 ... -
找不到WEB-INF下的proxool.xml的问题
2011-05-12 15:09 2091在windows下部署正常的系统,移植到linux下,启动时报 ... -
applet
2011-03-24 16:45 1497在jsp页面使用applet时。总是报错——找不到类。 主要是 ... -
(转载)java单例模式的6种写法
2011-03-11 16:33 1804第一种(懒汉,线程不安全) public class Sing ... -
javah编译带包class文件出错解决方法
2011-01-04 11:04 2460用JNI时,需要把class文件编译成.h文件 不带包名的cl ... -
java获得字符串中的指定字符
2010-11-12 10:16 1624正则表达式除了匹配一串字符串是否符合某种格式,还能从文本中过滤 ... -
判断文件是否为图片文件
2010-08-30 11:32 4318判断文件是否为图片,仅通过后缀名判断很不全面,如果把一个txt ... -
Java动态调用方法
2010-05-26 11:52 21015public void function(String s ... -
java UDP传输
2010-05-26 11:47 1180TCP通过 ServerSocket 和 Socket 来实现 ... -
java UDP打印
2010-05-26 11:45 951采用UDP的通讯方式,调用java自带的awt打印接口 服务 ... -
基于prototype.js和spring的ajax分页
2010-05-26 11:42 1725这是一个基于prototype.js的ajax分页,运用了sp ... -
java soap + tomcat 开发
2010-05-26 11:34 3684不带javaBean的SOAP调用 首先,下载soap.wa ... -
java过滤关键字
2010-05-26 11:29 3263KeywordFilter.java: 1. imp ... -
java ftp操作
2010-05-26 11:14 1671简单的写了个java对ftp的操作 用的是commons-n ... -
tomcat一闪而过启动失败
2010-05-26 11:11 14731、手动点击startup.bat受,一闪而过 在用文本打开 ...
相关推荐
Terracotta的基本原理是对于集群间共享的数据,当在一个节点发生变化的时候,Terracotta只把变化的部分发送给...在对比测试中,采用Terracotta搭建Tomcat集群,节点达到8个时候,整个集群的吞吐量还一直是线性增长的。
其实terracotta集群tomcat这方面的资料也算不少了··但还是会很容易出现错误·· 希望我这个文档能帮助大家!
NULL 博文链接:https://lihongchao87.iteye.com/blog/1727802
本文介绍如何配置Tomcat和Terracotta服务器将普通的Web应用部署到集群中,实现跨Tomcat节点的session复制,以达到负载均衡、提高系统吞吐量和灾难恢复的效果。
Terracotta实现基于Tomcat的Web应用集群
记载了terracotta如何与tomcat、jetty等服务器的集群,解释了tc-config.xml中各个配置的作用
2008Amazon四星半新书_The+Definitive+Guide+to+Terracotta_+Cluster+the+JVM+for+Spring,+Hibernate+and+P.rar
java ehcache terracotta 集群, 分布式缓存配置
terracotta集群负载,是个好东西
linux安装包terracotta-3.7.7.tar.gz,用于tomcat的session集群
Terracotta
ehcache3集群相关资源,包括ehcache-clustered-3.10.0-kit、ehcache-3.10.0.jar、ehcache-clustered-3.10.0.jar、terracotta-3.7.7.tar.gz、ehcache-transactions-3.10.0.jar
《基于Terracotta和Continuent的可扩展集群架构》 1) 关键应用架构待解决的集群问题 2) 基于JVM的透明数据复制技术 3) Oracle RAC 的开源数据库替代技术 演讲人:程勇 灰狐开源社区共同创始人
terracotta-toolkit-1.3-runtime-3.2.0.jar 集群实现JAR
Terracotta 3.2.1 英文文档
terracotta-ee-3.5.2破解版
terracotta license.key ,
terracotta-eclipse-plugin-3.7.7-2013-08-19_16-03-48.tar(terracotta的Eclipse插件) 发现官网挺卡的,有时候下不了,先传上来吧,供国内用户下载,这个算最新的吧。2014-02-17下载的。