WebLogic11g-集群相关概念
weblogic集群架构相关的概念有:
1、服务器(server,控制台选择环境-服务器)
2、集群(cluster,控制台选择环境-集群)
3、计算机(machine,控制台选择环境-计算机)
4、节点管理器(nodemanager,)
下面根据对这4个概念一一介绍【概念相对来说比较难描述的,如果有描述不当的地方,敬请指正,在此谢过!】。
1、服务器(server)
weblogic集群的服务器分三类:
1)AdminServer(公司老板)
主要用于管理,包括应用部署,动态创建server,以及各种服务配置.所以集群环境下不会将应用、数据源等服务部署到AdminServer上面,因为AdminServer仅仅是充当管理者角色而已。运维过程中,还起到监控其它服务器状态的作用。
2)ProxyServer(前台MM)
主要受理各种外部请求,然后将具体工作交给具体的服务器(一线员工)。所以集群环境下,也不会将应用部署到ProxyServer上。
3)Server(一线员工)
实际干活的服务器,把前台MM接受到的任务进行实际处理,处理完了反馈给客户端
由此可见,AdminServer只负责管理、ProxyServer负责受理分配、而普通的Server就负责干活。
2、集群(cluster)
控制台里面配置的集群,仅仅用于设置server之间的多播通信。server之间使用多播通信,互相告诉自己状态是否可用。
3、计算机(machine)
可选配置。控制台里面配置的计算机,仅仅用于配置“节点管理器”信息(地址、端口)。然后根据配置信息向节点管理器发送操作命令。
4、节点管理器(nodemanager)
可选服务。节点管理器在集群架构中,不是必须的。它的作用是用来管理server的生命周期,如果没有使用节点管理器,那么集群中的所有server的启动、关闭等常用的操作,必须通过运行startManagedWebLogic.cmd脚本来完成。该脚本位置是:
D:\server\weblogic11\user_projects\domains\springside3\bin
如果启动server1(一般称为受管服务器,即接受管理的普通server),那么启动命令如下:
- 其中:
- server1 启动的受管服务器的名称
- address 该域的管理服务器的IP地址
- port 该域的管理服务器的监听端口
所以有些集群环境下,你能看到有多少个server,就有多少个启动脚本,实际上就是执行上面这个命令。
如果集群中的server分布在多台主机上面,那每次启动服务非常不方便,所以这时候,节点管理器就派上用场了,节点管理器负责管理本机server的启动、关闭等生命周期。
附上一幅图,肯能更直观些:
概念讲完了,接着讨论在前两篇中涉及到的一些疑问。
1、为什么配置集群时,把server1、server2添加到集群,而配置计算机时,添加了proxy、server1、server2呢?
server1、server2纳入集群,是因为它们要通过组播地址互相检测运行状态,proxy在集群架构中仅仅作为前端代理,与集群的server有着本质的区别。配置计算机时,添加proxy、server1、server2,是因为这三个server在同一台主机,并且把proxy的启动、关闭交给节点管理器处理。这里也不可以不添加proxy,但是proxy的运行就要靠startManagedWebLogic
proxy 127.0.0.1:7001
这样的命令来执行了。
2、控制台里面配置的集群,与整个集群架构的区别是什么?
控制台里面的集群仅仅是个配置(名称、消息传送模式),只有设置了消息传送模式,集群中的server才根据这个模式来互相传递消息。
而整个集群架构是通过对服务器、集群配置、计算机配置(可选)、节点管理器服务(可选)以及负载均衡等的统一管理,来达到高并发、高可用的目的。
细心的同学应该还记得消息传送模式那里有两个选择:单点传送、多点传送。它们的区别是什么?
单点传送是weblogic10版本之后才有效的,之前都是多点传送方式。它们之间的区别可参考:http://www.blogjava.net/beansoft/archive/2012/02/23/370623.html
文章里面的两幅图已经清楚描述了通信方式的区别,其中还有个单点传送、多点传送的区别。
3、配置计算机的一些细节:
1)新建计算机的时候,有个“操作系统”,可选择:UNIX、其它。这里主要是确定节点管理所在的主机操作系统类型。windows系统就选择其它;linux、unix、solaris就选择unix。
2)节点管理器属性配置中,有个类型选择【SSH/RSH/SSL/普通】,这个配置是告诉AdminServer与节点管理器交互时采用哪种类型传递。weblogic使用手册中介绍节点管理器的章节可供参考:
http://edocs.weblogicfans.net/wls/docs92/server_start/nodemgr.html
节点管理器分为两种:基于java的、基于脚本的
我目前见过较多的还是使用java+ssl这样的组合方式。(不过ssl配置稍微麻烦点)
如果你的server使用了“定制标识和定制信任”,那么节点管理器配置【位置:D:\server\weblogic11\wlserver_10.3\common\nodemanager\nodemanager.properties】也要增加如下配置:
- KeyStores=CustomIdentityAndCustomTrust
- CustomIdentityAlias=example
- CustomIdentityKeyStoreFileName=example.jks
这是按照我之前SSL制作的秘钥库来配置的。
至于节点管理器的其它配置信息可参考官方文档。
WebLogic11g-集群相关概念的更多相关文章
- Ubuntu14.04 weblogic11g集群环境测试
在当前域下面新建两个服务器,服务器信息设置: server1:127.0.0.1:7010 server2:127.0.0.1:7020 第一步:新建服务器 (1)进入“服务器”,点击新建: (2)填 ...
- Spark中集群相关概念
来源:http://spark.apache.org/docs/latest/cluster-overview.html Term Meaning Application User program b ...
- Redis单机版以及集群版的安装搭建以及使用
1,redis单机版 1.1 安装redis n 版本说明 本教程使用redis3.0版本.3.0版本主要增加了redis集群功能. 安装的前提条件: 需要安装gcc:yum install g ...
- redis安装、测试&集群的搭建&踩过的坑
1 redis的安装 1.1 安装redis 版本说明 本教程使用redis3.0版本.3.0版本主要增加了redis集群功能. 安装的前提条件: 需要安装gcc:yum install gcc- ...
- 搭建 RabbitMQ Server 高可用集群
阅读目录: 准备工作 搭建 RabbitMQ Server 单机版 RabbitMQ Server 高可用集群相关概念 搭建 RabbitMQ Server 高可用集群 搭建 HAProxy 负载均衡 ...
- 搭建 RabbitMQ Server 高可用集群【转】
阅读目录: 准备工作 搭建 RabbitMQ Server 单机版 RabbitMQ Server 高可用集群相关概念 搭建 RabbitMQ Server 高可用集群 搭建 HAProxy 负载均衡 ...
- Redis之集群环境搭建
前面文章介绍了Redis的主从复制,虽然该模式能够在一定程度上提高系统的稳定性,但是在数据访问量比较大的情况下,单个master应付起来还是比较吃力的,这时我们可以考虑将redis集群部署,本文就来重 ...
- Redis项目实战---应用及理论(二)---Redis集群原理
一. Redis官方推荐集群方案:Redis Cluster 适用于redis3.0以后版本, redis cluster 是redis官方提供的分布式解决方案,在3.0版本后推出的,有 ...
- ElasticSearch 集群 & 数据备份 & 优化
ElasticSearch 集群相关概念 ES 集群颜色状态 ①. - 红色:数据都不完整 ②. - 黄色:数据完整,但是副本有问题 ③. - 绿色:数据和副本全都没有问题 ES 集群节点类型 ①. ...
- 通过 Docker 部署 Redis 6.x 集群
要点步骤总结: # 这里演示使用同一台主机上 # 创建各节点存储路径 mkdir -p /opt/redis/{7000,7001,7002,7003,7004,7005} # 创建各节点配置文件 c ...
随机推荐
- linux安装ftp
安装vsftpd 1.以管理员(root)身份执行以下命令 1. yum install vsftpd 2.设置开机启动vsftpd ftp服务 1. chkconfig vsftpd on 3. ...
- Python里面 search0和 match0的区别?
这是正则表达式里面的函数: match()函数只检测RE是不是在string的开始位置匹配,search()会扫描整个string查找匹配: 也就是说match()只有在0位置匹配成功的话才有返回,如 ...
- 用一个div模拟textarea的实现
<textarea> 标签定义一个多行的文本输入控件.但是它不能像div一样随着内容增加而自动增加,一言不合就出现滚动条,有是有为了更好的交互,可能需要使用div来模拟textarea的实 ...
- 55. Jump Game(中等)
Given an array of non-negative integers, you are initially positioned at the first index of the arra ...
- gcc创建静态库和共享库
静态库和动态(共享)库静态库:编译程序在编译使用库提供的功能代码的程序时将代码复制到该程序然后编译成可执行程序,这种库成为静态库共享库:共享库比静态库的处理方式更加灵活,因而其产生的可执行文件更小,其 ...
- web缓存之--http缓存机制
一.web缓存可以分为数据库缓存.代理服务器缓存.浏览器缓存. 其中浏览器缓存又包含很多内容:http缓存.indexDb.cookie.localStorage等.本片只讨论http缓存相关内容. ...
- 用ECMAScript4 ( ActionScript3) 实现Unity的热更新 -- CustomYieldInstruction 自定义中断指令
ActionScript3脚本引擎为了方便热更新逻辑开发,提供的从脚本继承Unity类库功能在一些情况下可以提供开发的便利. 这次来建立一个示例,演示一下如何在脚本中自定义协程中断指令 Unity中的 ...
- ubuntu部署mipsel64交叉编译环境
最近找到个不错的交叉工具链,据传能够编译mipsel64的程序,决定试试. 首先当然是安装环境: apt install -y gcc libncursesada3-dev 下载,解压,进入 三部曲: ...
- 关于Application_End 与 Application_Start事件触发情况的测试(待续)
测试项目搭建 定义一个简单的Mvc项目,有如下文件: (1) public class Startup { public void Configuration(IAppBuilder app) { a ...
- Junit4 java.lang.Exception: No runnable methods
出现如下错误: java.lang.Exception: No runnable methods at org.junit.runners.BlockJUnit4ClassRunner.validat ...