1.下载cat

  cat 地址:https://github.com/dianping/cat

  进入opt 创建cat文件夹

  cd /opt/

  mkdir cat

  cd cat

  下载cat

  git clone https://github.com/dianping/cat.git

2.安装

2.1.安装docker-compose

wget https://github.com/docker/compose/releases/download/1.14.0-rc2/docker-compose-Linux-x86_64

rename docker-compose-Linux-x86_64 docker-compose docker-compose-Linux-x86_64

chmod +x /usr/local/bin/docker-compose

再通过docker-compose version命令进行查看

2.2 Docker快速部署

说明

  1. 支持本机模式快速部署。
  2. docker/Dockerfile包含CAT依赖的环境,可以作为源码部署的参考。
  3. 默认的运行方式是集成了一个mysql镜像,可以修改为自己的mysql的详细配置。默认运行的mysql服务,将mysql数据挂载到了docker/mysql/volume中。

容器构建

cd docker
修改Dockerfile,由于tomcat和maven下载地址变了,需要修改版本号和下载地址
vi Dockerfile 替换原来的内容为下面内容
 

ENV TOMCAT_MAJOR_VERSION 7
ENV TOMCAT_MINOR_VERSION 7.0.94

RUN wget http://mirror.bit.edu.cn/apache/tomcat/tomcat-${TOMCAT_MAJOR_VERSION}/v${TOMCAT_MINOR_VERSION}/bin/apache-tomcat-${TOMCAT_MINOR_VERSION}.tar.gz && \
tar zxf apache-tomcat-*.tar.gz && \
mv apache-tomcat-${TOMCAT_MINOR_VERSION}/* . && \
rm -rf apache-tomcat-*

#MAVEN
ENV MAVEN_VERSION_MAJOR 3
ENV MAVEN_VERSION_MINOR 6.1

RUN wget http://mirror.bit.edu.cn/apache/maven/maven-${MAVEN_VERSION_MAJOR}/${MAVEN_VERSION_MAJOR}.${MAVEN_VERSION_MINOR}/binaries/apache-maven-${MAVEN_VERSION_MAJOR}.${MAVEN_VERSION_MINOR}-bin.tar.gz
RUN tar xvf apache-maven-${MAVEN_VERSION_MAJOR}.${MAVEN_VERSION_MINOR}-bin.tar.gz
RUN rm apache-maven-${MAVEN_VERSION_MAJOR}.${MAVEN_VERSION_MINOR}-bin.tar.gz
RUN mv apache-maven-${MAVEN_VERSION_MAJOR}.${MAVEN_VERSION_MINOR} /usr/local/apache-maven
ENV M2_HOME=/usr/local/apache-maven
ENV M2=$M2_HOME/bin
ENV PATH=$M2:$PATH
CMD java -version && mvn -version

同步docker时区
vi docker-compose.yml
cat 和cat_mysql volumes 节点下添加
      - "/etc/localtime:/etc/localtime"
修改client.xml
vi client.xml
<?xml version="1.0" encoding="utf-8"?>
<config mode="client">
<servers>
<server ip="192.168.1.206" port="2280" http-port="8080"/>
</servers>
</config>
ip为宿主机ip
执行 docker-compose up

第一次运行以后,数据库中没有表结构,需要通过下面的命令创建表:

docker exec cat-mysql bash -c "mysql -uroot -Dcat < /init.sql"

说明:<container_id>需要替换为容器的真实id。通过 docker ps 可以查看到mysql容器id

依赖配置说明

  1. datasources.xml

    • CAT数据库配置,默认配置是mysql镜像,可以按需替换
  2. docker-compose.yml
    • 通过docker-compose启动的编排文件,文件中包含cat和mysql。可以屏蔽掉mysql的部分,并且修改cat的环境变量,改为真实的mysql连接信息。
  3. client.xml
    • CAT 初始化默认的路由列表,配置此文件可以将客户端数据上报指向到不同环境。
  4. datasources.sh
    • 辅助脚本,脚本作用时修改datasources.xml,使用环境变量中制定的mysql连接信息。(通过sed命令替换)

3.设置开机启动

docker update --restart=always cat

docker update --restart=always cat-mysql

4.开启端口

firewall-cmd --zone=public  --permanent --add-port=2280/tcp

firewall-cmd --zone=public  --permanent --add-port=8080/tcp

5.访问

http://ip:8080/cat

6.配置cat

config 默认用户名:admin 密码:adin

配置服务器

配置路由

7.问题及解决

1、问题总揽

在部署cat的过程中遇到若干个坑,在此记录一下。参考github上的部署说明。在部署完成后,打开cat页面,有问题的cat服务器会显示“**有问题的cat服务器[ip:127.0.0.1]”**等若干式样。下图所示为正常的cat监控。

不正常的cat服务器会在上图划横线的地方显示“有问题的cat服务器ip[]”等关键滋字样。

2、问题原因

出现这个字样的原因是client.xml,server.xml以及开启服务后,客户端路由,服务端配置的ip地址有误所导致的。(注:在github上的配置说明中没有提到server.xml的配置。有若干坑。)

3、解决方法

配置单机版cat时,以上提到的ip地址全部换成服务端内网ip地址即可。

A、打开终端,找出内网IP地址。

使用ifconfig命令查看本机内网地址。如下所示。

找到en0下的inet部分的ip地址即为服务端的内网地址。

B、修改CLIENT.XML等文件中IP地址。

client.xml文件如下所示:

<?xml version="1.0" encoding="utf-8"?>
<config mode="client">
<servers>
<server ip="192.168.43.238" port="2280" http-port="8080"/>
</servers>
</config>

其中中的ip地址为对应的内网地址。

server.xml文件。

<?xml version="1.0" encoding="utf-8"?>
<!-- Configuration for development environment-->
<config local-mode="false" hdfs-machine="false" job-machine="true" alert-machine="true">
<storage local-base-dir="/data/appdatas/cat/bucket/" max-hdfs-storage-time="15" local-report-storage-time="7" local-logivew-storage-time="7">
</storage>
<console default-domain="Cat" show-cat-domain="true">
<!--将172.16.90.114修改为部署CAT的内网IP,请不要写127.0.0.1和外网IP -->
<remote-servers>192.168.43.238:8080</remote-servers>
</console>
</config>

修改完上述两个文件后,启动tomcat服务器。

这时还是会显示有问题的cat服务器。

C、修改客户端路由配置

如下图所示。

修改完成后,点击提交和重算路由

D、修改服务端配置


在图中3出,修改为内网ip。修改完后,点击提交。
最后就得到了正常的cat服务器。摘自:http://www.freesion.com/article/589046467/

docker 安装cat的更多相关文章

  1. docker 安装

    Docker使用了一种叫AUFS的文件系统,这种文件系统可以让你一层一层地叠加修改你的文件,最底下的文件系统是只读的,如果需要修改文件,AUFS会增加一个可写的层(Layer),这样有很多好处,例如不 ...

  2. Docker安装及基本使用方法

    Docker安装 CentOS6上安装Docker # yum -y install epel-release # yum -y install docker-io CentOS7上安装Docker ...

  3. Docker安装目录

    操作系统为 # cat /etc/redhat-release CentOS Linux release (Core) docker安装 # yum install -y docker docker安 ...

  4. docker安装hadoop集群

    docker安装hadoop集群?图啥呢?不图啥,就是图好玩.本篇博客主要是来教大家如何搭建一个docker的hadoop集群.不要问 为什么我要做这么无聊的事情,答案你也许知道,因为没有女票.... ...

  5. Docker安装和卸载

    一:卸载旧版本 老版本的Docker被称为docker或docker-engine.如果安装了这些,请卸载它们以及相关的依赖项. $ sudo yum remove docker \ docker-c ...

  6. Docker安装入门 -- 中间件镜像

    Docker安装入门 -- 中间件镜像 php-fpm 1.docker build -t csphere/php-fpm:5.4 .   //在当前目录下创建镜像 2.docker run -d - ...

  7. Docker安装Nginx1.11.10+php7+MySQL

    Docker安装php-fpm 1.编辑Dockerfile FROM php:7.1.3-fpm ADD sources.list /etc/apt/sources.list RUN cp /usr ...

  8. 使用Docker安装Jenkins

    Jenkins Jenkins是一个开源软件项目,是基于Java开发的一种持续集成工具,用于监控持续重复的工作,旨在提供一个开放易用的软件平台,使软件的持续集成变成可能. 环境准备 腾讯云 硬件配置: ...

  9. Docker安装步骤

    在学习springcloud的消息总线时,需要安装rabbitmq,因为rabbitmq是用erlang开发的,所以安装rabbitmq又需要先安装erlang,总之安装过程中遇到各种坑,然而最终还是 ...

随机推荐

  1. [Luogu1938][USACO09NOV]找工就业Job Hunt

    原题链接:https://www.luogu.org/problem/show?pid=1938 这一道题有一个比较难的点就是,这一张图上,是点上有权.既然点上有权的话,我们就不好一下子使用最短路了. ...

  2. hive中为分区表增加字段需要注意默认不会修改已有分区的字段,导致查询时新增字段为null

    若向hive表添加字段,通常会使用下面这种语句 alter table default.testparquet add columns(c8 string); 但是对于分区表来说, 1. 若新建的分区 ...

  3. ISO C 字符串创建算符 “#”

    使用用途: #define doit(name) pr_limits(#name, name) doit(RLIMIT_CORE); 这将由C预处理程序扩展为: pr_limits("RLI ...

  4. createElement 函数

    我们知道,vue函数的渲染其实是由render函数的回调函数createElement 来创建的虚拟dom,那么它到底是怎么创建组件的? 尚未理解透彻[捂脸],有待补充,参考如下: https://w ...

  5. 4412 Linux设备总线

    总线_设备_驱动注册流程详解 注册流程图 • 设备一般都需要先注册,才能注册驱动– 现在越来越多的热拔插设备,反过来了.先注册驱动,设备来了再注册 设备 • 本节使用的命令– 查看总线的命令#ls / ...

  6. delphi 异形窗体可半透明

    unit xDrawForm; interface uses Windows, Messages, SysUtils, Classes, Controls, Forms, Menus, Graphic ...

  7. HTTP协议之-URL

    一.URL url统一资源定位符 1.URL格式: 方案.就是指所使用的协议,类似http:// 服务器的地址,类似i.cnblogs.com/ 制定web服务器的某个资源路径 方案://服务器位置/ ...

  8. php面试专题---5、流程控制考点

    php面试专题---5.流程控制考点 一.总结 一句话总结: 看代码不要先看函数里面的内容,要用的时候再去看:注意静态,注意变量作用域,php中的内置函数需要去归类总结,就是太容易忘记了 1.写出如下 ...

  9. crontab不能正常执行的五种原因

    1 crond服务未启动 crontab不是Linux内核的功能,而是依赖一个crond服务,这个服务可以启动当然也可以停止.如果停止了就无法执行任何定时任务了,解决的方法是打开它: crond 或 ...

  10. mysql捕捉所有SQL语句

    MySQL可以通过开通general_log参数(可动态修改)来扑捉所有在数据库执行的SQL语句.显示参数:mysql> show variables like 'general%log%';+ ...