我的编程空间,编程开发者的网络收藏夹
学习永远不晚

tomcat中的redis、activemq、activemq数据库调优的使用

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

tomcat中的redis、activemq、activemq数据库调优的使用

1.下载安装包redis-3.2.2.tar.gz,并且进行解压,解压后编译源码


[root@localhost soft]# tar  -zxvf redis-3.2.2.tar.gz 

[root@localhost soft]# cd redis-3.2.2

[root@localhost redis-3.2.2]# make

编译完成后提示

make[1]: Leaving directory `/soft/redis-3.2.2/class="lazy" data-src'

2.编译完成后,在class="lazy" data-src目录下有四个可执行文件redis-server、

[root@localhost redis-3.2.2]# mkdir /usr/local/redis

[root@localhost redis-3.2.2]# cp redis.conf /usr/local/redis/

[root@localhost redis-3.2.2]# cd class="lazy" data-src/

[root@localhost class="lazy" data-src]# cp redis-server /usr/local/redis/

[root@localhost class="lazy" data-src]# cp redis-benchmark /usr/local/redis/

[root@localhost class="lazy" data-src]# cp redis-cli /usr/local/redis/

[root@localhost class="lazy" data-src]# cd /usr/local/redis/

[root@localhost redis]# ls

redis-benchmark   #redis性能测试工具

redis-cli         #redis命令行操作工具

redis.conf        redis配置文件

redis-server      #服务器的daemon启动程序


3.修改配置文件

[root@localhost redis]# vi redis.conf 

61 #bind 127.0.0.1      注释这一行,默认是指至运行自己访问自己

128 daemonize yes       默认为no,改为yes,默认是不能以守护进程运行

480 requirepass 123456  默认是没有开启redis的密码,设置redis的密码为123456


4.redis启动服务

/usr/local/redis/redis-server /usr/local/redis/redis.conf    配置文件已经改写为守护进程的方式 

[root@fanxiaohui redis]# ps -elf | grep redis

5 S root       6524      1  0  80   0 - 33383 ep_pol 00:06 ?        00:00:00 /usr/local/redis/redis-server *:6379                     

0 S root       6528   3187  0  80   0 - 25814 pipe_w 00:06 pts/1    00:00:00 grep redis


5.客户端测试一下是否启动成功,开启认证功能后redis测试方法必须指定服务器IP地址、端口和密码

[root@fanxiaohui redis]# redis-cli -h 127.0.0.1 -p 6379 -a 123456

127.0.0.1:6379> set foo bar

OK

127.0.0.1:6379> get foo

"bar"

127.0.0.1:6379> 

可以看到取的值说明成功。


activemq Linux中的部署和安装


1.下载安装包apache-activemq-5.14.1-bin.tar.gz,并且进行解压,解压后编译源码

[root@fanxiaohui soft]# tar -zxvf apache-activemq-5.14.1-bin.tar.gz 

[root@fanxiaohui soft]# mv apache-activemq-5.14.1 /usr/local/apache-activemq

[root@fanxiaohui soft]# cd /usr/local/apache-activemq/bin/

2.启动activemq服务

/usr/local/activemq/bin/activemq start


3.查看端口是否有运行程序

[root@localhost bin]# netstat -anpult | grep 61616

tcp        0      0 :::61616                    :::*                        LISTEN

  3576/java


4.完成后添加开启自启动


[root@localhost bin]# cat /etc/rc.local 

#!/bin/sh

#

# This script will be executed *after* all the other init scripts.

# You can put your own initialization stuff in here if you don't

# want to do the full Sys V style init stuff.



touch /var/lock/subsys/local

/usr/local/activemq/bin/activemq start


5.apache-activemq调优配置 

持久化

ActiveMQ支持持久化,可以将接收到的消息保存到数据库中,就算ActiveMQ重启,也照样能将尚未派发的消息发送出去。

    ActiveMQ的持久化机制,对于Queue类型的消息,将存储在Broker,但是一旦其中一个消费者完成消费,则立即删除这条消息。

对于Topic类型的消息,即使所有的订阅者都完成了消费,Broker也不一定会马上删除无用消息,而是保留推送历史,之后会异步清除无用消息。

而每个订阅者消费到了哪条消息的offset会记录在Broker,以免下次重复消费。因为消息是顺序消费,先进先出,所以只需要记录上次消息消费到哪里就可以了。

配置持久化的方式,都是修改%ACTIVEMQ_HOME%conf/acticvemq.xml文件。


1。持久化为文件

这个你装ActiveMQ时默认就是这种,只要你设置消息为持久化就可以了。涉及到的配置和代码有

 <persistenceAdapter>

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

        </persistenceAdapter>

2.持久化 为 mysql

[root@fanxiaohui lib]# cd /usr/local/apache-activemq/lib

[root@fanxiaohui soft]# mv  mysql-connector-java-5.1.34.jar /usr/local/apache-activemq/lib/

 你首先需要把MySql的驱动放到ActiveMQ的Lib目录下,如mysql-connector-Java-5.1.34.jar。

[root@fanxiaohui soft]# cd /usr/local/apache-activemq/conf/

[root@fanxiaohui conf]# vi activemq.xml

     85        <persistenceAdapter>

     86                  <jdbcPersistenceAdapter dataSource="#mysql-ds" dataDirectory="${activemq.base}/data" createTablesOnStartup="true" useDatabaseLock="false" />

     87                  </persistenceAdapter>

...............................

...............................

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

    134                         <property name="driverClassName" value="com.mysql.jdbc.Driver"/>       #使用的JDBC驱动的完整有效的java 类名

    135                         <property name="url" value="jdbc:mysql://192.168.23.240:3306/activemqdb?relaxAutoC        ommit=true"/>  #传递给JDBC驱动的用于建立连接的URL

    136                         <property name="username" value="activemq"/>    # 传递给JDBC驱动的用于建立连接的用户名

    137                         <property name="password" value="activemq.123"/> #传递给JDBC驱动的用于建立连接的密码

    138                         <property name="poolPreparedStatements" value="true"/> #开启池的prepared statement 池功能

    139                         <property name="maxTotal" value="150"/>  # 最大活动连接:连接池在同一时间能够分配的最大活动连接的数量, 如果设置为非正数则表示不限制 

    140                         <property name="minIdle" value="5"/>     #最大空闲连接:连接池中容许保持空闲状态的最大连接数量,超过的空闲连接将被释放,如果设置为负数表示不限制

    141                         <property name="maxIdle" value="20"/>    #小空闲连接:连接池中容许保持空闲状态的最小连接数量,负数表示没有现在

    142                         <property name="initialSize" value="30"/>  #初始化连接:连接池启动时创建的初始化连接数量

    143                         <property name="maxWaitMillis" value="1000"/>  #最大等待时间:当没有可用连接时,连接池等待连接被归还的最大时间(以毫秒计数),超过时间则抛出异常,如果设置为-1表示无限等待

    144                         <property name="timeBetweenEvictionRunsMillis" value="10000"/>  #在空闲连接回收器线程运行期间休眠的时间值,以毫秒为单位.如果设置为非正数,则不运行空闲连接回收器线程

    145                         <property name="numTestsPerEvictionRun" value="10"/>  #在每次空闲连接回收器线程(如果有)运行时检查的连接数量

    146                         <property name="minEvictableIdleTimeMillis" value="10000"/>   #连接在池中保持空闲而不被空闲连接回收器线程(如果有)回收的最小时间值,单位毫秒

    147                         <property name="validationQuery" value="SELECT NOW() FROM DUAL"/> #SQL查询,用来验证从连接池取出的连接,在将连接返回给调用者之前.如果指定,则查询必须是一个SQL SELECT并且必须返回至少一行记录

    148             </bean>


从配置中可以看出数据库的名称是activemq,密码为:activemq.123 你需要手动在MySql中增加这个库。

mysql>

mysql>create database activemqdb;

mysql>grant all on activemqdb.* to "activemq"@"%" identified by "activemq.123";


数据库配置好后才能启动activemq服务


[root@fanxiaohui conf]# /usr/local/apache-activemq/bin/activemq start

INFO: Loading '/usr/local/apache-activemq//bin/env'

INFO: Using java '/usr/java/bin/java'

INFO: Starting - inspect logfiles specified in logging.properties and log4j.properties to get details

INFO: pidfile created : '/usr/local/apache-activemq//data/activemq.pid' (pid '4123')

[root@fanxiaohui conf]#  ps -elf | grep  activemq

0 S root       4123      1 40  80   0 - 768127 futex_ 02:03 pts/0   00:00:04 /usr/java/bin/java -Xms64M -Xmx1G -Djava.util.logging.config.file=logging.properties -Djava.security.auth.login.config=/usr/local/apache-activemq//conf/login.config -Dcom.sun.management.jmxremote -Djava.awt.headless=true -Djava.io.tmpdir=/usr/local/apache-activemq//tmp -Dactivemq.classpath=/usr/local/apache-activemq//conf:/usr/local/apache-activemq//../lib/: -Dactivemq.home=/usr/local/apache-activemq/ -Dactivemq.base=/usr/local/apache-activemq/ -Dactivemq.conf=/usr/local/apache-activemq//conf -Dactivemq.data=/usr/local/apache-activemq//data -jar /usr/local/apache-activemq//bin/activemq.jar start


再次查看数据库时出现三张表

mysql> show databases;

+--------------------+

| Database           |

+--------------------+

| information_schema |

| activemqdb         |

| data               |

| fanxiaohui         |

| mysql              |

| performance_schema |

| sys                |

| test               |

+--------------------+

8 rows in set (0.00 sec)


mysql> use activemqdb;

Database changed

mysql> show tables;

+----------------------+

| Tables_in_activemqdb |

+----------------------+

| ACTIVEMQ_ACKS        |

| ACTIVEMQ_LOCK        |

| ACTIVEMQ_MSGS        |

+----------------------+

3 rows in set (0.00 sec)  


activemq_acks   用于存储订阅关系,如果是持久化TOPIC,订阅者和服务器的订阅关系在这个表保存

activemq_msgs   用于存储消息,Queue和Topic都存储在这个表中


6.测试

配置好后可以登录监控管理页面去看队列情况


http://192.168.23.240:8161/admin

1.添加用户名和密码,在conf目录下找到jetty-realm.properties

cd /usr/local/activemq/conf/

vi jetty-realm.properties

     18 # Defines users that can access the web (console, demo, etc.)

     19 # username: password [,rolename ...]

     20 system: manager,admin                          添加这一行,管理员的账号和密码

     21 admin: admin, admin

     22 user: user, user

~

2.修改配置jetty.xml文件

cd /usr/local/activemq/conf/

[root@fanxiaohui conf]# vi  jetty.xml

     48 

     49     <bean id="rewriteHandler" class="org.eclipse.jetty.rewrite.handler.RewriteHandler">

     50         <property name="rules">

     51             <list>

     52                 <bean id="header" class="org.eclipse.jetty.rewrite.handler.HeaderPatternRule">

     53                   <property name="pattern" value="*"/>

     54                   <property name="name" value="X-FRAME-OPTIONS"/>

     55                   <property name="value" value="SAMEORIGIN"/>

     56                 </bean>

     57             </list>

     58         </property>

     59     </bean>

删除以上的行

     57                                 <!-- Enable embedded file server for Blob messages -->

     58                                 <!-- <bean class="org.eclipse.jetty.webapp.WebAppContext"> <property name="contextPath"

     59                                         value="/fileserver" /> <property name="resourceBase" value="${activemq.home}/webapps/fileserver"

     60                                         /> <property name="logUrlOnStart" value="true" /> <property name="parentLoaderPriority"

     61                                         value="true" /> </bean> -->


添加以上的行


免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

tomcat中的redis、activemq、activemq数据库调优的使用

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

Spring Boot中Redis数据库的使用实例

spring boot对常用的数据库支持外,对nosql 数据库也进行了封装自动化。redis介绍Redis是目前业界使用最广泛的内存数据存储。相比memcached,Redis支持更丰富的数据结构,例如hashes, lists, set
2023-05-31

redis数据库使用的数据结构类型

redis 中共有 9 种数据结构类型:键值对:储存单个键值对字符串:存储文本、数字或二进制数据列表:存储有序键值对集合:存储不重复的值有序集合:存储带有分值的元素,按分值排序哈希表:存储映射到值的键值对地理空间:存储地理位置和形状超日志:
redis数据库使用的数据结构类型
2024-04-19

Index在Oracle数据库性能调优中的位置

在Oracle数据库性能调优中,Index是一个非常重要的部分。Index是一种数据结构,用于加快数据查询操作的速度。通过在表中创建适当的索引,可以大大减少查询的响应时间,并提高数据库的性能。在Oracle数据库性能调优中,通常会对表的访
Index在Oracle数据库性能调优中的位置
2024-08-16

Redis数据库的使用场景介绍(避免误用Redis)

Redis 是目前 NoSQL 领域的当红炸子鸡,它象一把瑞士军刀,小巧、锋利、实用,特别适合解决一些使用传统关系数据库难以解决的问题。但是 Redis 不是银弹,有很多适合它解决的问题,但是也有很多并不适合它解决的问题。另外,Redis
2022-06-04

触发器在数据库性能调优中的潜在优势

触发器在数据库性能调优中的潜在优势包括自动化和简化代码、数据一致性、性能优化、标准化、高效率和安全性。以下是触发器在数据库性能调优中的潜在优势:自动化和简化代码触发器可以自动在表上执行特定的操作,无需手动编写和执行相关的SQL语句,从而
触发器在数据库性能调优中的潜在优势
2024-09-26

变量在Oracle数据库性能调优中的实践

在Oracle数据库性能调优中,变量是一个非常重要的因素。以下是一些关于变量在Oracle数据库性能调优中的实践:使用绑定变量:在SQL语句中使用绑定变量而不是硬编码的值可以提高性能。绑定变量可以减少SQL的解析时间,并且可以重复使用执行计
变量在Oracle数据库性能调优中的实践
2024-08-23

spring使用RedisTemplate操作Redis数据库的案例

小编给大家分享一下spring使用RedisTemplate操作Redis数据库的案例,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!一.什么是RedisRedis是一个非关系型数据库,具有很高的存取性能,一般用作缓存数据库
2023-06-14

递归查询在数据库性能调优中的策略

递归查询在数据库性能调优中的策略主要包括限制递归深度、索引优化、避免笛卡尔积等。以下是具体的策略和优化方法:限制递归深度使用 OPTION (MAXRECURSION n) 来限制递归的层数,避免无限制的递归。根据实际数据结构和需求调整
递归查询在数据库性能调优中的策略
2024-09-08

Python中SQLite数据库的使用

目录预备知识SQL语句创建数据表execute()方法插入记录查询SQL语句fetchall()SQLite_master表更新记录删除记录例题练习SQL(结构化查询语言)是一种通用数据库查询语言。SQL具有数据定义、数据操作和数据控制功能
2023-04-28

阿里云免费Redis数据库的使用指南

简介:本文将详细介绍如何在阿里云上免费使用Redis数据库,并提供详细的步骤和示例,以帮助您快速上手。正文:Redis是一个高性能的键值存储系统,常用于缓存、消息队列等场景。在阿里云上,您可以免费使用Redis数据库,并享受高可用性和强大的性能支持。步骤一:注册阿里云账号并购买Redis服务首先,您需要在阿里云上注册一
阿里云免费Redis数据库的使用指南
2024-01-25

Spring Boot人使用Redis数据库的缓存机制

Spring Boot人使用Redis数据库的缓存机制?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。本文章牵涉到的技术点比较多:spring Data JPA、Redis、Sp
2023-05-31

编程热搜

目录