百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术教程 > 正文

Linux搭建Weblogic集群

csdh11 2025-02-27 14:48 18 浏览

一、Java环境配置

拿到新申请的两台Linux机器后,首先需要安装JDK,下载地址请戳这里。

1、执行命令:rpm -qa | grep java,查询是否存在系统自带的openjdk。

如果为空,则不存在自带的openjdk;如果不为空,需要执行命令:rpm -e –nodeps+包名来删除自带的openjdk。

2、安装下载的jdk

(1)首先上传下载好的jdk tar包到Linux服务器。这里在/opt目录下新建software和modules目录,software目录存放未解压的tar包,modules目录存放解压后的tar包。

(2)执行命令:tar -zxvf
./jdk-8u221-linux-x64.tar.gz -C ../modules/将tar包解压到modules目录下。

(3)执行vi /etc/profile命令配置Java环境变量。在/etc/profile文件底部加如下代码并保存退出。

(4)执行source /etc/profile命令生效。

二、检查防火墙

1、查看防火墙状态

systemctl status firewalld.service

2、关闭防火墙:

systemctl stop firewalld.service

3、禁用防火墙:

systemctl disable firewalld.service

三、安装Weblogic集群

首先需要下载Weblogic的安装包,点击这里下载~

1、首先安装Weblogic不能使用root用户,所以需要新建一个普通用户。使用如下命令新建一个普通用户,这里普通用户的名字命名为:nwsj。

 groupadd nwsj # 新建nwsj用户组
 useradd -g nwsj nwsj # 在nwsj用户组下新建用户nwsj
 echo "qdswjnwsj" | passwd --stdin "nwsj" # 修改nwsj用户的密码
 echo "nwsj ALL=(ALL) ALL" >> /etc/sudoers # 赋予nwsj用户sudo权限

2、在/目录下新建app目录,并更改所属的用户和用户组。Weblogic安装在此目录下。

3、在服务器1上安装Weblogic服务器。

(1)在服务器1的/app下创建目录bea12c3,作为Weblogic的安装路径。

cd /app
mkdir bea12c3

(2)将Weblogic的安装上传到/app目录下。

(3)修改weblogic/oraInst.loc配置文件。

inventory_loc=/app/weblogic/oraInventory
inst_group=weblogic

(4)修改weblogic/wls.rsp配置文件。

ORACLE_HOME=/app/bea12c3

(5)将这两个配置文件上传到/app/weblogic目录下。

(6)采用静默安装的方式安装Weblogic。

cd /app/
java -jar fmw_12.2.1.3.0_wls.jar -silent -responseFile /app/weblogic/wls.rsp -invPtrLoc /app/weblogic/oraInst.loc

当看到出现下图所示的内容时,说明安装成功:

4、在服务器1上创建Weblogic域

(1)首先使用如下命令设置环境变量。

export MV_HOME=/app/bea12c3
export WL_HOME=$MV_HOME/wlserver
export CONFIG_JVM_ARGS=-Djava.security.egd=file:/dev/./urandom
mkdir -p $MV_HOME/user_projects/domains

(2)运行wlst.sh文件,创建Weblogic域。

$WL_HOME/common/bin/wlst.sh

(3)复制下面脚本在wlst控制台中回车运行。

readTemplate('/app/bea12c3/wlserver/common/templates/wls/wls.jar');
set('AdminServerName','nwsjAdminServer');
set('ProductionModeEnabled','true');
set('Name','nwsjDomain');
cd('/Server/AdminServer');
set('ListenAddress','服务器1的ip');
set('Name','nwsjAdminServer');
set('ListenPort',9003);
cd('/');
create('nwsjCluster','Cluster');
cd('/');
create('nwsjServer1','Server');
create('nwsjServer2','Server');
assign('Server','nwsjServer1,nwsjServer2','Cluster','nwsjCluster');
cd('/Server/nwsjServer1');
set('ListenAddress','服务器1的ip');
set('ListenPort',9001);
cd('/Server/nwsjServer2');
set('ListenAddress','服务器2的ip');
set('ListenPort',9001);
writeTemplate('/app/bea12c3/wlserver/common/templates/domains/ssfw.jar');
closeTemplate();
createDomain('/app/bea12c3/wlserver/common/templates/domains/ssfw.jar','/app/bea12c3/user_projects/domains/nwsjDomain','weblogic','weblogic@nwsj2019');
exit()

(4)创建运行脚本。

export DOMAIN_HOME=/app/bea12c3/user_projects/domains/nwsjDomain
mkdir -p $DOMAIN_HOME/servers/nwsjServer1/security
touch $DOMAIN_HOME/servers/nwsjServer1/security/boot.properties
echo 'username=weblogic'>>$DOMAIN_HOME/servers/nwsjServer1/security/boot.properties
echo 'password=weblogic@nwsj2019'>>$DOMAIN_HOME/servers/nwsjServer1/security/boot.properties
touch $DOMAIN_HOME/bin/startnwsjServer1.sh
echo 'export USER_MEM_ARGS="-Xms512m -Xmx512m -XX:MetaspaceSize=512m -XX:MaxMetaspaceSize=1024m"'>>$DOMAIN_HOME/bin/startnwsjServer1.sh
echo 'export JAVA_OPTIONS="-Djava.security.egd=file:/dev/./urandom"'>>$DOMAIN_HOME/bin/startnwsjServer1.sh
echo 'export DOMAIN_PRODUCTION_MODE=true'>>$DOMAIN_HOME/bin/startnwsjServer1.sh
echo 'nohup ./startManagedWebLogic.sh nwsjServer1 http://192.168.0.193:9003 >ssfw1.log 2>&1 &'>>$DOMAIN_HOME/bin/startnwsjServer1.sh
echo 'sleep 1'>>$DOMAIN_HOME/bin/startnwsjServer1.sh
echo 'tail -f ssfw1.log'>>$DOMAIN_HOME/bin/startnwsjServer1.sh
chmod u+x $DOMAIN_HOME/bin/startnwsjServer1.sh

5、使用nwsj用户登录服务器2。

(1)将服务器1上面的bea12c3目录分发到服务器2上面的app目录下。

 cd /app
 scp -r nwsj@服务器1的ip:/app/bea12c3 .
 scp -r nwsj@服务器1的ip:/app/weblogic .

(2)设置环境变量。

export MV_HOME=/app/bea12c3/
export WL_HOME=$MV_HOME/wlserver
export CONFIG_JVM_ARGS=-Djava.security.egd=file:/dev/./urandom
export DOMAIN_HOME=/app/bea12c3/user_projects/domains/nwsjDomain

(3)设置启动脚本。

cd /app/bea12c3/user_projects/domains/nwsjDomain/bin
mv startnwsjServer1.sh startnwsjServer2.sh

使用vi startnwsjServer2.sh命令修改startnwsjServer2.sh命令,修改如下:

(4)设置安全信息

cd /app/bea12c3/user_projects/domains/nwsjDomain/servers
mv nwsjServer1/ nwsjServer2/

6、启动Weblogic服务器。

(1)在服务器1上启动管理端。

cd $DOMAIN_HOME
nohup ./startWebLogic.sh &
tail -f nohup.out

(2)在服务器1上启动被管节点1。

cd $DOMAIN_HOME/bin
./startnwsjServer1.sh

(3)在服务器2上启动被管节点2。

cd $DOMAIN_HOME/bin
./startnwsjServer2.sh

7、管理端地址:http:// 服务器1的
ip:9003/console/login/LoginForm.jsp

欢迎大家关注我的头条号,私信“python",学习资料包免费分享给需要的朋友,另有python学习交流群,可以交流学习拓展人脉。

相关推荐

探索Java项目中日志系统最佳实践:从入门到精通

探索Java项目中日志系统最佳实践:从入门到精通在现代软件开发中,日志系统如同一位默默无闻却至关重要的管家,它记录了程序运行中的各种事件,为我们排查问题、监控性能和优化系统提供了宝贵的依据。在Java...

用了这么多年的java日志框架,你真的弄懂了吗?

在项目开发过程中,有一个必不可少的环节就是记录日志,相信只要是个程序员都用过,可是咱们自问下,用了这么多年的日志框架,你确定自己真弄懂了日志框架的来龙去脉嘛?下面笔者就详细聊聊java中常用日志框架的...

物理老师教你学Java语言(中篇)(物理专业学编程)

第四章物质的基本结构——类与对象...

一文搞定!Spring Boot3 定时任务操作全攻略

各位互联网大厂的后端开发小伙伴们,在使用SpringBoot3开发项目时,你是否遇到过定时任务实现的难题呢?比如任务调度时间不准确,代码报错却找不到方向,是不是特别头疼?如今,随着互联网业务规模...

你还不懂java的日志系统吗 ?(java的日志类)

一、背景在java的开发中,使用最多也绕不过去的一个话题就是日志,在程序中除了业务代码外,使用最多的就是打印日志。经常听到的这样一句话就是“打个日志调试下”,没错在日常的开发、调试过程中打印日志是常干...

谈谈枚举的新用法--java(java枚举的作用与好处)

问题的由来前段时间改游戏buff功能,干了一件愚蠢的事情,那就是把枚举和运算集合在一起,然后运行一段时间后buff就出现各种问题,我当时懵逼了!事情是这样的,做过游戏的都知道,buff,需要分类型,且...

你还不懂java的日志系统吗(javaw 日志)

一、背景在java的开发中,使用最多也绕不过去的一个话题就是日志,在程序中除了业务代码外,使用最多的就是打印日志。经常听到的这样一句话就是“打个日志调试下”,没错在日常的开发、调试过程中打印日志是常干...

Java 8之后的那些新特性(三):Java System Logger

去年12月份log4j日志框架的一个漏洞,给Java整个行业造成了非常大的影响。这个事情也顺带把log4j这个日志框架推到了争议的最前线。在Java领域,log4j可能相对比较流行。而在log4j之外...

Java开发中的日志管理:让程序“开口说话”

Java开发中的日志管理:让程序“开口说话”日志是程序员的朋友,也是程序的“嘴巴”。它能让程序在运行过程中“开口说话”,告诉我们它的状态、行为以及遇到的问题。在Java开发中,良好的日志管理不仅能帮助...

吊打面试官(十二)--Java语言中ArrayList类一文全掌握

导读...

OS X 效率启动器 Alfred 详解与使用技巧

问:为什么要在Mac上使用效率启动器类应用?答:在非特殊专业用户的环境下,(每天)用户一般可以在系统中进行上百次操作,可以是点击,也可以是拖拽,但这些只是过程,而我们的真正目的是想获得结果,也就是...

Java中 高级的异常处理(java中异常处理的两种方式)

介绍异常处理是软件开发的一个关键方面,尤其是在Java中,这种语言以其稳健性和平台独立性而闻名。正确的异常处理不仅可以防止应用程序崩溃,还有助于调试并向用户提供有意义的反馈。...

【性能调优】全方位教你定位慢SQL,方法介绍下!

1.使用数据库自带工具...

全面了解mysql锁机制(InnoDB)与问题排查

MySQL/InnoDB的加锁,一直是一个常见的话题。例如,数据库如果有高并发请求,如何保证数据完整性?产生死锁问题如何排查并解决?下面是不同锁等级的区别表级锁:开销小,加锁快;不会出现死锁;锁定粒度...

看懂这篇文章,你就懂了数据库死锁产生的场景和解决方法

一、什么是死锁加锁(Locking)是数据库在并发访问时保证数据一致性和完整性的主要机制。任何事务都需要获得相应对象上的锁才能访问数据,读取数据的事务通常只需要获得读锁(共享锁),修改数据的事务需要获...