zoukankan      html  css  js  c++  java
  • Linux搭建disconf(一)

    disconf是一个专门用来集中管理分布式配置文件的一款开源项目,因为公司的项目都用到了这个,所以我也想从0开始学习一下disconf是如何使用的。需要补充说明的是,disconf已经很久没有人维护了,原则上已经是被淘汰的产品了,不建议在上面花太多时间。

    注意:如果你想省去不必要的麻烦,mysql一定要换成官方要求的5.0.45版本,以下的搭建过程是基于jdk 1.8和mysql 8.0.18的,所以搭建过程有点复杂。第二篇文章是对disconf搭建完成后存在问题的总结,分析,和解决。如果你跟着本教程走到了最后,可以参见点击下方链接,那里将会解决你的疑问。为了不必要的麻烦,请你的文件目录一定要和我的保持一致,即目录名,文件名严格和我的一样,切记!切记!

    链接:Linux搭建disconf(二)

    1:disconf依赖的环境,要想成功搭建disconf必须先在你的Linux系统中安装以下软件,至于这些软件的安装过程,自行百度,也可以点击下方相关链接,那里有详细的安装教程,这里不做细说

    2:cd /usr/local/mysoft (如果你的local目录下没有mysoft文件夹,则新建一个。我一般把自定义安装的软件都放在mysoft目录下) 

    [root@myLinux bin]# cd /usr/local/mysoft/
    [root@myLinux mysoft]# ls
    apache-maven-3.5.4  apache-tomcat-7.0.93  jdk1.8.0_251  nginx-1.12.0  redis-5.0.7  zookeeper-3.4.14

    3:在mysoft目录下新建一个disconf文件夹

    [root@myLinux mysoft]# mkdir disconf

    [root@myLinux mysoft]# ls
    apache-maven-3.5.4  apache-tomcat-7.0.93  disconf  jdk1.8.0_251  nginx-1.12.0  redis-5.0.7  zookeeper-3.4.14

    4:cd disconf/  进入disconf目录

    5:在disconf目录下新建3个文件夹,分别是resource  src  war

    [root@myLinux disconf]# mkdir resource
    [root@myLinux disconf]# mkdir src
    [root@myLinux disconf]# mkdir war

    [root@myLinux disconf]# ls
    resource src war

    6:cd src 进入src目录

    7:git clone https://github.com/knightliao/disconf.git

      下载disconf源码(假如克隆代码时提示没有git命令,则要先安装git:yum install git -y)

    [root@myLinux src]# git clone https://github.com/knightliao/disconf.git

    8:克隆完成后进入src目录ls,发现src目录下多了一个disconf文件夹,它就是我们下载的disconf源码

    [root@myLinux src]# ls
    disconf

    9:cd disconf/disconf-web/profile/rd  在src目录下执行这段命令,进入rd文件夹

    [root@myLinux src]# cd disconf/disconf-web/profile/rd
    [root@myLinux rd]# ls
    application-demo.properties  jdbc-mysql.properties  log4j.properties  logback.xml  redis-config.properties  zoo.properties

    9:cp * /usr/local/mysoft/disconf/resource   将rd文件夹下的所有文件拷贝到我们前面新建的resource目录下

    [root@myLinux rd]# cp * /usr/local/mysoft/disconf/resource

    10:cd /usr/local/mysoft/disconf/resource/  进入resource目录

    [root@myLinux rd]# cd /usr/local/mysoft/disconf/resource/
    [root@myLinux resource]# ls
    application-demo.properties  jdbc-mysql.properties  log4j.properties  logback.xml  redis-config.properties  zoo.properties

    11:mv application-demo.properties application.properties   将application-demo.properties文件重命名为application.properties

    [root@myLinux resource]# mv application-demo.properties application.properties
    [root@myLinux resource]# ls application.properties jdbc
    -mysql.properties log4j.properties logback.xml redis-config.properties zoo.properties

    12:vim application.properties   编辑application.properties,将domain的值改为你自己服务器的ip  (ESC键  :wq 退出并保存)

    #
    # u670du52a1u5668u7684domain
    #
    
    domain=72.46.188.188
    
    #
    # u90aeu7bb1u8bbeu7f6e
    #
    
    EMAIL_MONITOR_ON = true
    EMAIL_HOST = smtp.163.com
    EMAIL_HOST_PASSWORD = password
    EMAIL_HOST_USER = sender@163.com
    EMAIL_PORT = 25
    DEFAULT_FROM_EMAIL = disconf@163.com
    
    # 
    # u5b9au65f6u6821u9a8cu4e2du5fc3u7684u914du7f6eu4e0eu6240u6709u5ba2u6237u7aefu914du7f6eu7684u4e00u81f4u6027
    #
    CHECK_CONSISTENCY_ON= true

    13:vim jdbc-mysql.properties   编辑jdbc-mysql.properties文件

      如果你服务器中的mysql 是8.0版本,请做如下配置,用户名和密码根据自己实际的情况填写

    jdbc.driverClassName=com.mysql.cj.jdbc.Driver
    
    jdbc.db_0.url=jdbc:mysql://72.46.188.188:3306/disconf?useUnicode=true&characterEncoding=UTF-8&useSSL=true&serverTimezone=GMT
    jdbc.db_0.username=root
    jdbc.db_0.password=root
    
    jdbc.maxPoolSize=20
    jdbc.minPoolSize=10
    jdbc.initialPoolSize=10
    jdbc.idleConnectionTestPeriod=1200
    jdbc.maxIdleTime=3600

    14:vim redis-config.properties    编辑redis-config.properties,做如下配置,不要问为什么

    redis.group1.retry.times=2
    
    redis.group1.client1.name=BeidouRedis1
    redis.group1.client1.host=127.0.0.1
    redis.group1.client1.port=6379
    redis.group1.client1.timeout=5000
    redis.group1.client1.password=foobared
    
    redis.group1.client2.name=BeidouRedis2
    redis.group1.client2.host=127.0.0.1
    redis.group1.client2.port=6379
    redis.group1.client2.timeout=5000
    redis.group1.client2.password=foobared
    
    redis.evictor.delayCheckSeconds=300
    redis.evictor.checkPeriodSeconds=30
    redis.evictor.failedTimesToBeTickOut=6

    15:vim zoo.properties    编辑zoo.properties文件,将hosts的值改为自己服务器ip:2181(zookeeper的端口号)

    hosts=72.46.188.188:2181
    
    # zookeeperu7684u524Du7F00u8DEFu5F84u540D
    zookeeper_url_prefix=/disconf

    16:vim /etc/profile   配置环境变量,在配置文件中新增如下配置

    ONLINE_CONFIG_PATH=/usr/local/mysoft/disconf/resource
    WAR_ROOT_PATH=/usr/local/mysoft/disconf/war
    export ONLINE_CONFIG_PATH
    export WAR_ROOT_PATH

    17:source /etc/profile 使配置文件生效

    [root@myLinux resource]# source /etc/profile

    18:cd /usr/local/mysoft/disconf/src/disconf/disconf-web  编辑该目录下的pom文件,在该pom文件的profiles节点中新增以下内容

    <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>

    ps:该pom文件较长,使用vim编辑器,修改容易出错,我们可以使用xftp进入/usr/local/mysoft/disconf/src/disconf/disconf-web目录,右击pom文件,用记事本编辑,编辑完成后ctrl+s保存

    19:cd /usr/local/mysoft/disconf/src/disconf  进入该目录,编辑该目录下的pom文件,将该目录下的mysq 5.0l驱动依赖换成8.0的驱动依赖(因为我的mysql是8.0版本,如果你的是mysql 5.0则不需要执行此步骤)

    20:cd /usr/local/mysoft/disconf/src/disconf/disconf-web 进入该目录下执行 sh deploy/deploy.sh 命令(该过程有点长,请耐心等待)

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

    21:部署完毕后 cd /usr/local/mysoft/disconf/war  进入我们前面新建的war目录下,可以发现该目录下多了如下文件

    [root@myLinux disconf-web]# cd /usr/local/mysoft/disconf/war
    [root@myLinux war]# ll
    total 38200
    -rw-r--r-- 1 root root      422 Apr 30 15:00 application.properties
    -rw-r--r-- 1 root root 39064307 Apr 30 18:24 disconf-web.war
    drwxr-xr-x 4 root root     4096 Apr 30 18:24 html
    -rw-r--r-- 1 root root      344 Apr 30 17:54 jdbc-mysql.properties
    -rw-r--r-- 1 root root      186 Apr 30 14:53 jpaas_control
    -rw-r--r-- 1 root root      764 Apr 30 14:58 log4j.properties
    -rw-r--r-- 1 root root     2229 Apr 30 14:58 logback.xml
    drwxr-xr-x 3 root root     4096 Apr 30 18:24 META-INF
    -rw-r--r-- 1 root root      499 Apr 30 17:17 redis-config.properties
    -rw-r--r-- 1 root root       49 Apr 30 14:53 Release
    drwxr-xr-x 2 root root     4096 Apr 30 18:26 tmp
    drwxr-xr-x 4 root root     4096 Apr 30 18:24 WEB-INF
    -rw-r--r-- 1 root root      105 Apr 30 17:18 zoo.properties

    22:cd /usr/local/mysoft/apache-tomcat-7.0.93/conf  进入你自己的tomcat的conf目录下

    [root@myLinux war]# cd /usr/local/mysoft/apache-tomcat-7.0.93/conf
    [root@myLinux conf]# ls
    Catalina  catalina.policy  catalina.properties  context.xml  logging.properties  server.xml  tomcat-users.xml  web.xml

    23:vim server.xml   编辑server.xml,在host节点中添加如下内容

      <Context path="" docBase="/usr/local/mysoft/disconf/war"></Context>

    24:cd /usr/local/nginx/conf  进入你自己的nginx的conf目录

    [root@myLinux conf]# cd /usr/local/nginx/conf
    [root@myLinux conf]# ls
    fastcgi.conf          fastcgi_params          koi-utf  mime.types          nginx.conf          scgi_params          uwsgi_params          win-utf
    fastcgi.conf.default  fastcgi_params.default  koi-win  mime.types.default  nginx.conf.default  scgi_params.default  uwsgi_params.default

    25:vim nginx.conf  编辑nginx.conf文件(编辑这里时要注意,不要按空格,否则容易出错)

        upstream disconf {
            server 72.46.188.188:8080;        #代理tomcat,动态请求转发至后端tomcat程序,自己的服务器ip:tomcat的端口号
        }
    
        server {
            listen       8081;                #服务端口号
            server_name  72.46.188.188;       #它必须与 application.properties配置文件中的domain保持一致。
    
            #charset koi8-r;
    
            #access_log  logs/host.access.log  main;
    
            location / {
                #root   html;
                #index  index.html index.htm;
                root /usr/local/mysoft/disconf/war/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;
            }

    26:cd /usr/local/mysoft/disconf/src/disconf/disconf-web/sql  进入该目录下按照readme.md的指示,在Navicat中依次执行sql,初始化数据库

    - 0-init_table.sql create db,tables
    - 1-init_data.sql create data
    - 201512/20151225.sql patch
    - 20160701/20160701.sql patch

    27:开启你的zookeeper,mysql,nginx,tomcat,redis服务,在地址栏中输入  服务器ip:8081  如果出现如下界面,则初步完成

    28:点击登录,账号密码都为admin,如果出现下面界面,说明你的disconf搭建成功

     29:假如你登录时长时间没反应,并提示系统内部错误,则可以做如下尝试,到数据库中执行flush hosts命令

    30:假如还不能解决,则需要查看日志,了解错误信息,再另寻其他解决方案

      我的关于disconf的日志信息保存在  /usr/local/mysoft/apache-tomcat-7.0.93/log

      /usr/local/mysoft/apache-tomcat-7.0.93/bin/log两个目录下

      

    31:如果登录成功,我们新建一个配置文件试试(报错,并且文件在新建之后就删不掉了,因为我们新建配置文件时,内部程序没有返回该配置文件在数据库中的主键)

    查看日志,报如下错误,这是因为在将新建的配置文件数据插入数据库时,没有返回主键所致,根本原因在于其内部代码是基于mysql 5.0写的,不兼容新版本的mysql(头皮发麻,折腾了半天,白忙活了)

    Caused by: java.sql.SQLException: Generated keys not requested. You need to specify Statement.RETURN_GENERATED_KEYS to Statement.executeUpdate(), Statement.executeLargeUpdate() or Connection.prepareStatement().
    at com.mysql.cj.jdbc.exceptions.SQLError.createSQLException(SQLError.java:129) ~[mysql-connector-java-8.0.18.jar:8.0.18]
    at com.mysql.cj.jdbc.exceptions.SQLError.createSQLException(SQLError.java:97) ~[mysql-connector-java-8.0.18.jar:8.0.18]
    at com.mysql.cj.jdbc.exceptions.SQLError.createSQLException(SQLError.java:89) ~[mysql-connector-java-8.0.18.jar:8.0.18]
    at com.mysql.cj.jdbc.exceptions.SQLError.createSQLException(SQLError.java:63) ~[mysql-connector-java-8.0.18.jar:8.0.18]
    at com.mysql.cj.jdbc.StatementImpl.getGeneratedKeys(StatementImpl.java:1376) ~[mysql-connector-java-8.0.18.jar:8.0.18]

    32:解决方案我已经想出来了,具体参见文章开头的链接

  • 相关阅读:
    武道之路-炼体期五重天中期
    武道之路-炼体期五重天
    武道之路-炼体期四重天巅峰
    修改Oracle监听端口
    完美解决IE(IE6/IE7/IE8)不兼容HTML5标签的方法
    Create Linked Server SQL Server 2008
    Oracle:ODP.NET Managed 小试牛刀
    jquery ajax跨域请求webservice webconfig配置
    oracle 11g ORA-12541: TNS: 无监听程序 (DBD ERROR: OCIServerAttach)
    oracle 11g 一直提示 严重: 监听程序未启动或数据库服务未注册到该监听程序
  • 原文地址:https://www.cnblogs.com/misterwu/p/12811246.html
Copyright © 2011-2022 走看看