系统环境

IP

salt-master-1:192.168.0.156

salt-master-2:192.168.0.157

node-test-1:192.168.0.158

node-test-2:192.168.0.159

系统版本

CentOS release 5.9 (Final)

内核版本

2.6.18-348.el5 x86_64

软件版本

JDK

1.7.79

activemq

5.5.1

软件安装

源码安装

JDK

wget http://192.168.0.155/soft/java/jdk-7u79-linux-x64.gz

tar xzf jdk-7u79-linux-x64.gz -C /usr/local/

vim /etc/profile

#JAVA ENV

export JAVA_HOME=/usr/local/jdk1.7.0_79

export CLASSPATH=:.${JAVA_HOME}/lib/dt.jar:${JAVA_HOME}/lib/tools.jar

export PATH=${JAVA_HOME}/bin:${PATH}

source /etc/profile

java –version

java version "1.7.0_79"

Java(TM) SE Runtime Environment (build 1.7.0_79-b15)

Java HotSpot(TM) 64-Bit Server VM (build 24.79-b02, mixed mode)

activemq

wget http://archive.apache.org/dist/activemq/apache-activemq/5.5.1/apache-activemq-5.5.1-bin.tar.gz

tar xzf apache-activemq-5.5.1-bin.tar.gz -C /usr/local/

cd /usr/local/apache-activemq-5.5.1/

bin/activemq start

http://192.168.0.158:8161/admin/

bin/activemq stop

activemq主从

Shared File System Master Slave

NFS服务
  1. 在192.168.0.156上搭建NFS服务

yum -y install nfs-utils nfs-utils-lib-devel

vim /etc/exports

/data/kahadb 192.168.0.0/24(rw,no_root_squash,sync)

mkdir -p /data/kahadb

service nfs start

  1. 将NFS共享盘分别挂载到192.168.0.158和192.168.0.159

mkdir -p /data/kahadb

mount 192.168.0.156:/data/kahadb /data/kahadb

  1. 测试NFS服务和挂载是否正常
    1. 在192.168.0.156上创建test.txt

touch /data/kahadb/test.txt

  1. 分别在192.168.0.158和192.168.0.159上查看是否有test.txt文件

ll /data/kahadb/

activemq配置

vim /usr/local/apache-activemq-5.5.1/conf/activemq.xml

<persistenceAdapter>

<!--    <kahaDB directory="${activemq.base}/data/kahadb"/> -->

<kahaDB directory="/data/kahadb"/>

</persistenceAdapter>

重启activemq

/usr/local/apache-activemq-5.5.1/bin/activemq restart

activemq主从测试
  1. 只关闭192.168.0.157的activemq

/usr/local/apache-activemq-5.5.1/bin/activemq stop

  1. 开启192.168.0.157的activemq

/usr/local/apache-activemq-5.5.1/bin/activemq start

  1. 关闭192.168.0.159的activemq

/usr/local/apache-activemq-5.5.1/bin/activemq stop

  1. 开启192.168.0.159的activemq

/usr/local/apache-activemq-5.5.1/bin/activemq start

  1. 关闭192.168.0.158和192.168.0.159的activemq
  1. 开启192.168.0.158和192.168.0.159的activemq
  1. 停用192.168.0.156的NFS服务
  1. 停用192.168.0.156的NFS并重启activemq
  1. 打192.168.0.156的NFS服务并重启activemq

JDBC Master Slave

mysql安装配置

1           在192.168.0.156上安装mysql

yum -y install mysql mysql-devel mysql-server

2           启动mysql

service mysqld start

3           创建activemq数据库

mysql> create database activemq default character set utf8;

mysql> grant all on activemq.* to "activemq"@"192.168.0.%" identified by "activemq@test";

mysql> flush privileges;

activemq配置

5.9和5.14测试失败

vim /usr/local/apache-activemq-5.5.1/conf/activemq.xml

<destinationPolicy>

<policyMap><policyEntries>

<policyEntry topic="FOO.>">

<dispatchPolicy>

<strictOrderDispatchPolicy />

</dispatchPolicy>

<subscriptionRecoveryPolicy>

<lastImageSubscriptionRecoveryPolicy />

</subscriptionRecoveryPolicy>

</policyEntry>

</policyEntries></policyMap>

</destinationPolicy>

<persistenceAdapter>

<jdbcPersistenceAdapter         dataDirectory="activemq-data"

dataSource="#mysql-ds"

createTablesOnStartup="false"/> (第一次启动时设置为true,建三张表)

</persistenceAdapter>

<bean id="mysql-ds" class="org.apache.commons.dbcp.BasicDataSource" destroy-method="close">

<property name="driverClassName" value="com.mysql.jdbc.Driver"/>

<property name="url" value="jdbc:mysql://192.168.0.156:3306/activemq?relaxAutoCommit=true"/>

<property name="username" value="activemq"/>

<property name="password" value="activemq@test"/>

<property name="poolPreparedStatements" value="true"/>

</bean>

主从测试

测试方法未知

Replicated LevelDB Store

该功能从5.9.0开始支持,5.9.0之前版本不支持

zookeeper安装配置

wget http://192.168.0.155/soft/apache/zookeeper/zookeeper-3.3.6.tar.gz

tar xzf zookeeper-3.3.6.tar.gz -C /usr/local/

cp /usr/local/zookeeper-3.3.6/conf/zoo_sample.cfg /usr/local/zookeeper-3.3.6/conf/zoo.cfg

vim /usr/local/zookeeper-3.3.6/conf/zoo.cfg

# The number of milliseconds of each tick

tickTime=2000

# The number of ticks that the initial

# synchronization phase can take

initLimit=10

# The number of ticks that can pass between

# sending a request and getting an acknowledgement

syncLimit=5

# the directory where the snapshot is stored.

dataDir=/usr/local/zookeeper-3.3.6/data

# the port at which the clients will connect

clientPort=2181

server.1=192.168.0.157:2888:3888

server.2=192.168.0.158:2888:3888

server.3=192.168.0.159:2888:3888

mkdir -p /usr/local/zookeeper-3.3.6/data

l  192.168.0.157添加myid

echo "1" > /usr/local/zookeeper-3.3.6/data/myid

l  192.168.0.158添加myid

echo "2" > /usr/local/zookeeper-3.3.6/data/myid

l  192.168.0.159添加myid

echo "3" > /usr/local/zookeeper-3.3.6/data/myid

/usr/local/zookeeper-3.3.6/bin/zkServer.sh start

activemq配置

vim /usr/local/apache-activemq-5.9.1/conf/activemq.xml

<broker xmlns="http://activemq.apache.org/schema/core" brokerName="uce-core" dataDirectory="${activemq.data}">

<persistenceAdapter>

<replicatedLevelDB

directory="/data/kahadb"

replicas="3"

bind="tcp://0.0.0.0:0"

zkAddress="192.168.0.157:2181,192.168.0.158:2181,192.168.0.159:2181"

zkPath="/data/leveldb-stores"

hostname="192.168.0.157"

/>

</persistenceAdapter>

官网标准配置:

<broker brokerName="broker" ... >

...

<persistenceAdapter>

<replicatedLevelDB

directory="activemq-data"(可自定义)

replicas="3"(必须3台,1主+2备)

bind="tcp://0.0.0.0:0"(默认设置即可)

zkAddress="zoo1.example.org:2181,zoo2.example.org:2181,zoo3.example.org:2181"

zkPassword="password"(可设置也不可设置,设置值三台必须一致)

zkPath="/activemq/leveldb-stores"(可自定义)

hostname="broker1.example.org"(必须跟本机地址一致)

/>

</persistenceAdapter>

...

</broker>

主从测试

只要停用master,而另两台可自动运行

activemq部署的更多相关文章

  1. ActiveMQ部署步骤和后台管理网站Service Unavailable问题解决笔记

    最近部署ActiveMQ的时候,发现有的服务器可以打开后台管理网址,有的服务器无法打开,Jetty报503 Service Unavailable. 搞了很久终于发现了问题,现将部署和解决过程做笔记如 ...

  2. ActiveMQ部署和503的错误

    最近部署ActiveMQ的时候,发现有的服务器可以打开后台管理网址,有的服务器无法打开,Jetty报503 Service Unavailable. 搞了很久终于发现了问题,现将部署和解决过程做笔记如 ...

  3. ActiveMQ部署和代码尝试(二)

    部署和代码尝试 1. 部署在linux 上的acvtiveMQ 要可以通过前台windows 的页面访问,必须把linux 的IP和 windows的 IP 地址配置到同一个网关下 .这种情况一般都是 ...

  4. ActiveMQ安装部署(Windows)

    JMS(Java Messaging Service)是Java平台上有关面向消息中间件的技术规范,它便于消息系统中的Java应用程序进行消息交换,并且通过提供标准的产生.发送.接收消息的接口简化企业 ...

  5. ActiveMQ(七)_伪集群和主从高可用使用

      一.本文目的         介绍如何在同一台虚拟机上搭建高可用的Activemq服务,集群数量包含3个Activemq,当Activemq可用数>=2时,整个集群可用.         本 ...

  6. php 利用activeMq+stomp实现消息队列

    php 利用activeMq+stomp实现消息队列 一.activeMq概述 ActiveMQ 是Apache出品,最流行的,能力强劲的开源消息总线.ActiveMQ 是一个完全支持JMS1.1和J ...

  7. ActiveMQ(七)_伪集群和主从高可用使用(转)

    本文转自: https://www.cnblogs.com/gossip/p/5977489.html 一.本文目的         介绍如何在同一台虚拟机上搭建高可用的Activemq服务,集群数量 ...

  8. Hello Activemq

    0. 如果永远是localhost 可能一直low下去 1.下载安装 activemq 1.1 从官网下载activemq.tar.gz 并上传(rz)到linux系统 并解压 tar zxvf /* ...

  9. ActiveMQ学习总结

    一.消息中间件的产生的背景 1.在网络通讯中,Http请求默认采用同步请求方式,基于请求与响应模式 2.在客户端与服务器进行通讯时,客户端调用服务端接口后,必须等待服务端完成处理后返回结果给客户端才能 ...

随机推荐

  1. Django的auth【认证】模块简介

    首先我们先来复习一下路由别名如何使用,这里仅仅复习一下二级路由的路由别名该如何使用 ·1.在视图函数中使用二级路由别名,需要加上app的名称+“:”+ “路由别名” from django.urls ...

  2. C盘文件过大,C盘空间莫名丢失,pagefile.sys文件

    设置显示隐藏文件和受保护的系统文件后此文件会显示pagefile.sys这个是window的页面文件,作为系统的虚拟内存使用,和你的物理内存一样大,你内存已经很大了,不用开虚拟内存了.在系统高级属性下 ...

  3. cloudera-hdfs 告警处理

    2018-03-13 11:15:17,215 WARN [org.apache.flume.sink.hdfs.HDFSEventSink] - HDFS IO error org.apache.h ...

  4. gson所需jar包

    共需要四个jar包,分别为: gson-2.0.jar log4j-1.2.17.jar slf4j-api-1.7.10.jar slf4j-log4j12-1.7.10.jar 如果想要进行文件读 ...

  5. webpack搭建自己的项目

    使用代理的方式参考地址:http://www.cnblogs.com/wangyongcun/p/7665687.html npm 常用模块 npm init 创建package.json文件 一值回 ...

  6. 一位大牛整理的Python资源

    Python基本安装: * http://www.python.org/ 官方标准Python开发包和支持环境,同时也是Python的官方网站:    * http://www.activestate ...

  7. 用js实现回车登录而不用点击登录按钮

    在你的登录jsp里面,添加一个js <script> function on_return(){ //on_return这是方法名 if(window.event.keyCode == 1 ...

  8. 8.Mysql数据类型选择

    8.选择合适的数据类型8.1 CHAR与VARCHAR CHAR固定长度的字符类型,char(n) 当输入长度不足n时将用空格补齐,char(n)占用n个字节,CHAR类型输出时会截断尾部的空格,即使 ...

  9. java 字符串截取类 区分中文、英文、数字、标点符号

    package com.founder.fix.ims; /** * @author WANGYUTAO * 操作字符串 */ public class SubString { // public s ...

  10. swoole的EventLoop学习

    我们先使用php来写一个socket的服务端.先从最开始的模型开始将起逐步引申到为何要使用eventloop 1.最简单的socket服务端,直接按照官方文档来执行 <?php $sock = ...