1、需要一台服务器(阿里云,腾讯云、实体服务器都行,本次是以实体服务器为依照做的)

2、安装docker   

3、开始配置disconf

 

第一步:环境准备

要使用disconf,肯定是开发环境需求,因此需要 mysql 和 redis

上云的小伙伴可以直接购买云上的服务,比如阿里云的RDS和redis

没有上云的小伙伴可以在本地自己搭建,也可以使用docker搭建,但总之需要和disconf分开来。

这里就不介绍mysql和redis的搭建了,小伙伴可以自己上网查找

1、服务器

2、docker

3、mysql

4、redis

 

第二步:选择指定镜像版本centos 7.4 (版本不限制,看自己的喜好)

https://hub.docker.com/search/?q=&type=image docker 官方下载镜像的地址,主要是需要找到centos7.4在docker中的具体名称

本地docker build 本地docker部署DNF_mysql

docker pull centos:7.4.1708    #下载公共镜像

docker images         #查看已有镜像

 

 

第三步:以centos:7.4.1708 镜像 为模板创建容器

docker run -dit \
-p 8085:8085 -p 2181:2181 \
-v /usr/local/centos_data:/usr/local/centos_data \
-v /etc/localtime:/etc/localtime:ro \
--restart=always \
--name centos01 \
centos:7.4.1708

解释:
-p 8085:8085 -p 2181:2181  主要是为了后面弄好之后可以直接测试访问
-v /usr/local/centos_data:/usr/local/centos_data 主要是需要有一个传输安装包的共享目录
-v /etc/localtime:/etc/localtime:ro 容器和宿主机的时间同步
--restart=always 容器随机自启动

 

第四步:进入容器centos,然后安装 nginx ,tomcat ,jdk、zookeeper、mysql客户端、redis客户端

共享目录:

/usr/local/centos_data

nginx安装:

wget http://nginx.org/download/nginx-1.14.2.tar.gz    ## 下载nginx安装包的命令  
yum -y install pcre-devel openssl openssl-devel gcc gcc-c++ #安装依赖包
./configure --prefix=/usr/local/nginx  #编译安装,指定安装位置
make
make install


 

启动并测试,将监听的端口改为8085

curl http://127.0.0.1:8085

tomcat和jdk安装:

  ##下载jdk安装包

wget --no-check-certificate --no-cookies --header "Cookie: oraclelicense=accept-securebackup-cookie" https://download.oracle.com/otn-pub/java/jdk/8u201-b09/42970487e3af4f5aa5bca3f542482c60/jdk-8u201-linux-x64.tar.gz
##下载tomcat安装包,链接可能会失效,因为版本更新
wget https://mirrors.tuna.tsinghua.edu.cn/apache/tomcat/tomcat-8/v8.5.39/bin/apache-tomcat-8.5.39.tar.gz


##安装jdk:

[root@a0a2568d002d centos_data]# mkdir /usr/java
[root@a0a2568d002d centos_data]# tar -zxvf jdk-8u201-linux-x64.tar.gz -C /usr/java
[root@a0a2568d002d centos_data]# vi /etc/profile
  export JAVA_HOME=/usr/java/jdk1.8.0_201
  export JRE_HOME=${JAVA_HOME}/jre
  export CLASSPATH=.:${JAVA_HOME}/lib:${JRE_HOME}/lib
  export PATH=${JAVA_HOME}/bin:$PATH

[root@a0a2568d002d centos_data]# vi /etc/profile
[root@a0a2568d002d centos_data]# source /etc/profile
[root@a0a2568d002d centos_data]# java -version
java version "1.8.0_201"
Java(TM) SE Runtime Environment (build 1.8.0_201-b09)
Java HotSpot(TM) 64-Bit Server VM (build 25.201-b09, mixed mode)

##安装tomcat

[root@a0a2568d002d centos_data]# mkdir /usr/local/tomcat
[root@a0a2568d002d centos_data]# tar -xf apache-tomcat-8.5.39.tar.gz -C /usr/local/tomcat
[root@a0a2568d002d centos_data]# vi /usr/local/tomcat/apache-tomcat-8.5.39/bin/setenv.sh
         JAVA_OPTS="-Xms1024m -Xmx1024m -Xss1024K -XX:MetaspaceSize=64m -XX:MaxMetaspaceSize=128m"
[root@a0a2568d002d centos_data]# chmod +x /usr/local/tomcat/apache-tomcat-8.5.39/bin/setenv.sh




##修改监听端口为8015,然后启动测试

[root@a0a2568d002d centos_data]# curl http://127.0.0.1:8015


 

 

zookeeper安装:

官网地址: http://zookeeper.apache.org/

镜像地址: http://mirror.bit.edu.cn/apache/zookeeper/

下载zookeeper: 

wget https://mirrors.tuna.tsinghua.edu.cn/apache/zookeeper/zookeeper-3.4.13/zookeeper-3.4.13.tar.gz ##链接会过期

 

单独的zookeeeper需要下载安装java,这里已经有jdk了,因此不需要。

[root@a0a2568d002d centos_data]# mkdir /usr/local/zookeeper
[root@a0a2568d002d centos_data]# tar -xf zookeeper-3.4.13.tar.gz -C /usr/local/zookeeper

解压后在zookeeper的conf目录下创建配置文件zoo.cfg,里面的配置信息可参考统计目录下的zoo_sample.cfg文件,我们这里配置为:

[root@a0a2568d002d conf]# cd /usr/local/zookeeper/zookeeper-3.4.13/conf/
[root@a0a2568d002d conf]# vi zoo.cfg
tickTime=2000
initLimit=10
syncLimit=5
dataDir=/opt/zookeeper-data/
clientPort=2181

tickTime:指定了ZooKeeper的基本时间单位(以毫秒为单位);

initLimit:指定了启动zookeeper时,zookeeper实例中的随从实例同步到领导实例的初始化连接时间限制,超出时间限制则连接失败(以tickTime为时间单位);

syncLimit:指定了zookeeper正常运行时,主从节点之间同步数据的时间限制,若超过这个时间限制,那么随从实例将会被丢弃;

dataDir:zookeeper存放数据的目录;

clientPort:用于连接客户端的端口。

启动:

[root@a0a2568d002d conf]# cd /usr/local/zookeeper/zookeeper-3.4.13/bin/
[root@a0a2568d002d bin]# ./zkServer.sh start
ZooKeeper JMX enabled by default
Using config: /usr/local/zookeeper/zookeeper-3.4.13/bin/../conf/zoo.cfg
Starting zookeeper ... STARTED

检查ZooKeeper是否正在运行

[root@a0a2568d002d bin]#yum -y install nc 

[root@a0a2568d002d bin]# echo ruok | nc localhost 2181  ##若是正常运行的话会打印“imok”。
imok


 

 

mysql客户端安装:

下载安装包:

wget https://dev.mysql.com/get/Downloads/MySQL-5.7/mysql-5.7.24-1.el7.x86_64.rpm-bundle.tar

 解压:

[root@a0a2568d002d centos_data]# mkdir mysql
[root@a0a2568d002d centos_data]# tar -xf mysql-5.7.24-1.el7.x86_64.rpm-bundle.tar -C mysql
[root@a0a2568d002d centos_data]# ls mysql
mysql-community-client-5.7.24-1.el7.x86_64.rpm    mysql-community-embedded-compat-5.7.24-1.el7.x86_64.rpm  mysql-community-minimal-debuginfo-5.7.24-1.el7.x86_64.rpm
mysql-community-common-5.7.24-1.el7.x86_64.rpm    mysql-community-embedded-devel-5.7.24-1.el7.x86_64.rpm   mysql-community-server-5.7.24-1.el7.x86_64.rpm
mysql-community-devel-5.7.24-1.el7.x86_64.rpm     mysql-community-libs-5.7.24-1.el7.x86_64.rpm             mysql-community-server-minimal-5.7.24-1.el7.x86_64.rpm
mysql-community-embedded-5.7.24-1.el7.x86_64.rpm  mysql-community-libs-compat-5.7.24-1.el7.x86_64.rpm      mysql-community-test-5.7.24-1.el7.x86_64.rpm

安装:

[root@a0a2568d002d mysql]# rpm -ivh mysql-community-common-5.7.24-1.el7.x86_64.rpm 
warning: mysql-community-common-5.7.24-1.el7.x86_64.rpm: Header V3 DSA/SHA1 Signature, key ID 5072e1f5: NOKEY
Preparing... ################################# [100%]
Updating / installing...
1:mysql-community-common-5.7.24-1.e################################# [100%]
[root@a0a2568d002d mysql]# rpm -ivh mysql-community-libs-5.7.24-1.el7.x86_64.rpm 
warning: mysql-community-libs-5.7.24-1.el7.x86_64.rpm: Header V3 DSA/SHA1 Signature, key ID 5072e1f5: NOKEY
Preparing... ################################# [100%]
Updating / installing...
1:mysql-community-libs-5.7.24-1.el7################################# [100%]
[root@a0a2568d002d mysql]# rpm -ivh mysql-community-client-5.7.24-1.el7.x86_64.rpm 
warning: mysql-community-client-5.7.24-1.el7.x86_64.rpm: Header V3 DSA/SHA1 Signature, key ID 5072e1f5: NOKEY
Preparing... ################################# [100%]
Updating / installing...
1:mysql-community-client-5.7.24-1.e################################# [100%]


 

测试:

用来测试连接已经准备好的mysql库:

本地docker build 本地docker部署DNF_本地docker build_02

 

 

redis客户端安装:

下载安装包:

wget http://download.redis.io/releases/redis-4.0.0.tar.gz

安装:

[root@a0a2568d002d centos_data]# mkdir /usr/local/redis
[root@a0a2568d002d centos_data]# tar -xf redis-4.0.0.tar.gz /usr/local/redis
[root@a0a2568d002d redis]# cd /usr/local/redis/redis-4.0.0/
[root@a0a2568d002d redis-4.0.0]# make
[root@a0a2568d002d redis-4.0.0]# make install

链接远程redis进行测试:

[root@a0a2568d002d ~]# redis-cli -h 192.168.2.87 -p 6379
192.168.2.87:6379> AUTH "a123"
OK
192.168.2.87:6379> ping
PONG
192.168.2.87:6379>


 

 

第五步:最后创建disconf 

参考文档

https://github.com/knightliao/disconf/tree/master/disconf-web/profile/rd git项目地址

构建:

Disconf进行构建时需要maven命令,所以需要安装Maven。

 

安装Maven的命令:

[root@a0a2568d002d ~]# yum -y install wget
[root@a0a2568d002d ~]# wget http://repos.fedorapeople.org/repos/dchen/apache-maven/epel-apache-maven.repo -O /etc/yum.repos.d/epel-apache-maven.repo
[root@a0a2568d002d ~]# yum -y install apache-maven

配置文件所在路径: /usr/local/disconf/resource 配置源码所在路径:/usr/local/disconf/src 配置War包所在路径:/usr/local/disconf/war

[root@a0a2568d002d ~]# mkdir -p /usr/local/disconf/{resource,src,war} [root@a0a2568d002d ~]# ls /usr/local/disconf/ resource src war

进入到disconf/src下,在GitHub上面直接下载源码,利用下面的命令:

[root@a0a2568d002d ~]# cd /usr/local/disconf/src/
[root@a0a2568d002d src]# yum -y install git
[root@a0a2568d002d src]# git clone https://github.com/knightliao/disconf.git

 

将/usr/local/disconf/src/disconf/disconf-web/profile/rd   路径下的配置文件拷贝到 /usr/local/disconf/resource(要将application-demo.properties文件改名为application.properties),并修改相应的配置文件。

[root@a0a2568d002d rd]# cp /usr/local/disconf/src/disconf/disconf-web/profile/rd/* /usr/local/disconf/resource/
[root@a0a2568d002d rd]# cd /usr/local/disconf/resource/
[root@a0a2568d002d resource]# mv application-demo.properties application.properties

 

 

修改相应的4个配置文件(application.properties  、jdbc-mysql.properties 、 redis-config.properties  、zoo.properties)

vi application.properties

本地docker build 本地docker部署DNF_mysql_03

 

 

 vi jdbc-mysql.properties

本地docker build 本地docker部署DNF_2d_04

 

 

vi redis-config.properties

本地docker build 本地docker部署DNF_centos_05

 

修改相应的host和port,如果redis是集群,可配置相应的节点;如果redis是单机版,也必须配置两个redis-client(否则会 报错),两个redis-client配置相同的host和port即可。

 

vi zoo.properties

本地docker build 本地docker部署DNF_本地docker build_06

 

 

 

修改环境变量,将创建的配置文件的路径和war包的路径配置在环境变量中。

[root@a0a2568d002d resource]# vi /etc/profile

ONLINE_CONFIG_PATH=/usr/local/disconf/resource
WAR_ROOT_PATH=/usr/local/disconf/war
export ONLINE_CONFIG_PATH
export WAR_ROOT_PATH[root@a0a2568d002d resource]# source /etc/profile

 

 

进入到disconf-web路径下,修改其pom文件,将以下内容加入到pom文件的profiles结点下,如果JDK的版本低于1.8,则此步骤不需要执行:

<profile>
    <id>doclint-java8-disable</id>
    <activation>
      <jdk>[1.8,)</jdk>
    </activation>
    <build>
      <plugins>
        <plugin>
          <groupId>org.apache.maven.plugins</groupId>
          <artifactId>maven-javadoc-plugin</artifactId>
          <configuration>
            <additionalparam>-Xdoclint:none</additionalparam>
          </configuration>
        </plugin>
      </plugins>
    </build>
  </profile>

 

[root@a0a2568d002d resource]# cd /usr/local/disconf/src/disconf/disconf-web
[root@a0a2568d002d disconf-web]# ls
README.md  bin  deploy  html  pom.xml  profile  sql  src
[root@a0a2568d002d disconf-web]# vi pom.xml

本地docker build 本地docker部署DNF_mysql_07

 

注意:在这个配置文件中会发现有乱码的情况,这是因为docker安装的centos系统不识别中文

 

 开始构建:

利用deploy/deploy.sh进行构建,构建过程会download很多东西,可能会有些慢,虚拟机要一直保持能上网的状态:

[root@a0a2568d002d disconf-web]# cd /usr/local/disconf/src/disconf/disconf-web/
[root@a0a2568d002d disconf-web]# sh deploy/deploy.sh


构建完成后,在war目录下会生成相应的内容

 


修改相应的配置文件:

配置Tomcat 将构建时打成的war包部署到Tomcat中,需要修改Tomcat的server.xml文件,在Host节点下设定Context:

[root@544cefc71c42 disconf]# vi /usr/local/tomcat1/apache-tomcat-8.5.37/conf/server.xml
<Context path="" docBase="/usr/local/disconf/war"></Context>

本地docker build 本地docker部署DNF_mysql_08

 

 

 

配置nginx

修改nginx.conf文件,将下面的内容添加进去:

http {
。。。
upstream disconf {
    server 127.0.0.1:8015;#Tomcat的IP和端口号,这里改成了8015
}

server {
    listen   8085;   #nginx监听的端口号
    server_name localhost;  #可自行定义,但必须与application.properties中的domain属性的值一样
    access_log logs/disconf/access.log;
    error_log logs/disconf/error.log;
    location / {
        root /usr/local/disconf/war/html;   #html所在的路径
        if ($query_string) {
            expires max;
        }
}

    location ~ ^/(api|export) {
        proxy_pass_header Server;
        proxy_set_header Host $http_host;
        proxy_redirect off;
        proxy_set_header X-Real-IP $remote_addr;
        proxy_set_header X-Scheme $scheme;
        proxy_pass http://disconf;
    }
}
}


 


 初始化数据库:

在/usr/local/disconf/src/disconf/disconf-web/sql目录下有sql文件,将这些sql文件初始化到数据库中。

这四个sql文件的执行是有顺序的,按照sql/readme.md文件中的顺序执行。

cd /usr/local/disconf/src/disconf/disconf-web/sql

mysql -h192.168.2.87 -uroot -p'Aa@123456' < 0-init_table.sql 创建disconf库和表

mysql -h192.168.2.87 -uroot -p'Aa@123456' disconf < 1-init_data.sql 创建数据

mysql -h192.168.2.87 -uroot -p'Aa@123456' disconf < 201512/20151225.sql    创建path

mysql -h192.168.2.87 -uroot -p'Aa@123456' disconf < 20160701/20160701.sql   创建path

 

里面默认有6个用户:

namepwdadminadmintestUser1MhxzKhl9209testUser2MhxzKhl167testUser3MhxzKhl783testUser4MhxzKhl8758testUser5MhxzKhl112

 

 

 登录测试:

本地docker build 本地docker部署DNF_centos_09

 

 

 

第六步,准备做成镜像并启动容器:

1、先重启容器

[root@xiangdong centos_data]# docker restart centos
[root@xiangdong centos_data]# docker exec -it centos /bin/bash

2、查看环境变量是否生效

1、java
[root@a0a2568d002d /]# java -version
openjdk version "1.8.0_201"
OpenJDK Runtime Environment (build 1.8.0_201-b09)
OpenJDK 64-Bit Server VM (build 25.201-b09, mixed mode)
2、中文识别问题是否解决

本地docker build 本地docker部署DNF_2d_10

 

 3、做成镜像

[root@xiangdong centos_data]# docker commit centos disconf:v3.0


 

4、然后以此镜像创建新的容器,删除旧的容器,查看是否能访问disconf

docker run -dit \
-p 8085:8085 -p 2181:2181 \
-v /usr/local/centos_data:/usr/local/centos_data \
-v /etc/localtime:/etc/localtime:ro \
--restart=always \
--name disconf01 \
disconf:v3.0


 

 

本地docker build 本地docker部署DNF_2d_11

本地docker build 本地docker部署DNF_mysql_12

 

 

 

第七步:设置程序随容器自启动(这一步也可以放在第六步之前)

经过试验得出结论:

需要删除旧的容器,然后启动新的容器时加上新的参数才能设置开启自启:

docker run -dit \
-p 8085:8085 -p 2181:2181 \
-v /usr/local/centos_data:/usr/local/centos_data \
-v /etc/localtime:/etc/localtime:ro \
--restart=always \
--privileged=true \
-e "container=docker" \
--name disconf01 \
disconf:v3.0 \
/usr/sbin/init

 

nginx自启动设置

进入容器配置nginx随机自启:

[root@ecaea7d3388c /]# cd /lib/systemd/system/
[root@ecaea7d3388c system]# vi nginx.service
[Unit]
Description=nginx service
After=network.target 

[Service] 
Type=forking 
ExecStart=/usr/local/nginx/sbin/nginx
ExecReload=/usr/local/nginx/sbin/nginx -s reload
ExecStop=/usr/local/nginx/sbin/nginx -s quit
PrivateTmp=true 

[Install] 
WantedBy=multi-user.target[root@ecaea7d3388c system]# systemctl enable nginx



最后重启容器测试验证


 

学习:


[Unit]:服务的说明 Description:描述服务 After:描述服务类别 [Service]服务运行参数的设置 Type=forking是后台运行的形式 ExecStart为服务的具体运行命令 ExecReload为重启命令 ExecStop为停止命令 PrivateTmp=True表示给服务分配独立的临时空间 注意:[Service]的启动、重启、停止命令全部要求使用绝对路径 [Install]运行级别下服务安装的相关设置,可设置为多用户,即系统运行级别为3

# systemctl start nginx.service  启动nginx服务
# systemctl stop nginx.service  停止服务
# systemctl restart nginx.service  重新启动服务
# systemctl list-units --type=service 查看所有已启动的服务
# systemctl status nginx.service 查看服务当前状态
# systemctl enable nginx.service 设置开机自启动
# systemctl disable nginx.service 停止开机自启动

 一个常见的错误

Warning: nginx.service changed on disk. Run 'systemctl daemon-reload' to reload units.

直接按照提示执行命令systemctl daemon-reload 即可。

 

tomcat自启动

[root@ecaea7d3388c /]# vi /lib/systemd/system/tomcat.service
[Unit]
Description=tomcat
After=network.target[Service]
Type=oneshot
ExecStart=/usr/local/tomcat/apache-tomcat-8.5.39/bin/startup.sh
ExecStop=/usr/local/tomcat/apache-tomcat-8.5.39/bin/shutdown.sh
ExecReload=/bin/kill -s HUP $MAINPID
RemainAfterExit=yes[Install]
WantedBy=multi-user.target 
 
[root@ecaea7d3388c /]# systemctl enable tomcat.service
[root@ecaea7d3388c /]# systemctl start tomcat.service


zookeeper自启动设置:

 

[root@ecaea7d3388c bin]# vi /lib/systemd/system/zookeeper.service
[Unit]
Description=Zookeeper
After=network.target[Service]
Type=forking
User=root
Group=root
ExecStart=/usr/local/zookeeper/zookeeper-3.4.13/bin/zkServer.sh start
ExecStop=/usr/local/zookeeper/zookeeper-3.4.13/bin/zkServer.sh stop
PIDFile=/opt/zookeeper-data/zookeeper_server.pid
[Install]
WantedBy=multi-user.target 
 
[root@ecaea7d3388c bin]# systemctl enable zookeeper.service

 

 

曾经遇到过的问题:

1、导入数据库的表有乱码的情况,原因:

    可能 1、容器disconf内用了mariadb而不是mysql客户端,导致导入时出现了一些问题

    可能 2、中文不识别,导致导入数据库数据时出现乱码情况

 

2、zk信息没有

    主要配置文件 zoo.properties 需要修改和琢磨,并且需要真实的运行一个程序,需要开发配合导入一个

 

3、修改配置文件不生效

    一共有3个目录下有这些配置文件:

    4个配置文件: redis-config.properties、 zoo.properties、application.properties、 jdbc-mysql.properties

    所在目录:

    /usr/local/disconf/resource

    /usr/local/disconf/war

    /usr/local/disconf/war/WEB-INF/classes

    比如说修改了/usr/local/disconf/war 目录下的zoo.properties文件,需要同时更新另外两个目录的zoo.properties文件

    或者直接同步目录

cp /usr/local/disconf/war/{redis-config.properties,zoo.properties,application.properties,jdbc-mysql.properties} /usr/local/disconf/resource
cp /usr/local/disconf/war/{redis-config.properties,zoo.properties,application.properties,jdbc-mysql.properties} /usr/local/disconf/war/WEB-INF/classes

 4、无法设置nginx开启自启

  删除旧容器,重启容器时加上参数:

            1、--privileged=true 

            2、-e "container=docker" 

            3、/usr/sbin/init


    

**** 好看的皮囊千篇一律,有趣的灵魂万里挑一 **** 好评点赞 !!!!!!!!!!!!!!!!!!!!!!!!!!!