微服务spring-cloud配置中心config-server本地化部署是怎样的

这期内容当中小编将会给大家带来有关微服务spring-cloud 配置中心config-server本地化部署是怎样的,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。

保山网站建设公司成都创新互联公司,保山网站设计制作,有大型网站制作公司丰富经验。已为保山1000+提供企业网站建设服务。企业网站搭建\成都外贸网站制作要多少钱,请找那个售后服务好的保山做网站的公司定做!

一、服务端:需要增加配置中心服务器config-server工程;

1、pom.xml增加相关配置信息

<dependency>
    <groupId>org.springframework.cloud</groupId>
    <artifactId>spring-cloud-config-server</artifactId>
</dependency>

2、启动类中增加

@EnableConfigServer
@SpringBootApplication
public class ConfigServerApplication {

    public static void main(String[] args) {
        SpringApplication.run(ConfigServerApplication.class, args);
    }

}

3.yml配置文件

server:
  port: 8707
spring:
  application:
    name: config-server
  profiles:
    active: native
  cloud:
    config:
      server:
        native:
          search-locations: 
                - file:/home/wshop/service/config
                #- classpath:/config
#        git:
#          uri: ssh://git@127.0.0.1:61317/home/git/repo/java/cloud-config
#          searchPaths: dev
#          lable: master
#          strict-host-key-checking: false
#          ignore-local-ssh-settings: true
#          private-key: |
#            -----BEGIN RSA PRIVATE KEY-----
#            MIIEpQIBAAKCAQEAx8S2qMyPTZxyw6+OB7PSLRM5WH+e1FPaKiqYwLzj1v0f9yGP
#            2cf41Si8m1y7o/tyaqoNiHbVkWlBvS5Pn6JCD3hlNQxCump2ZG2XqGg46EdDt52E
#            PWB2u4flSqzp4hMN+/5ChY1FTCg7IXY6uOxJ3U864MuZ6ChumxfgyYCmLb7mkX+D
#            S8vmDqNx5AGn9UscrhhdTuMMyw6HolUMdCQmpSyNyWQWk9caVKOvQlTGKG2nCAah
#            apGHShjghpCsASGo+qk7/af/ZrRoJEj2eeu8MCLBcdyd5MOZhf/xr3wCXIZItxCJ
#            P2qyPDg8s6umv6oW7nsKsy0qUcovZTqp1XkAawIDAQABAoIBABsuO8Ap3RGtSLwx
#            ZbzMjbtOU04kRyMSqat1EkWfLczxsei5K05xc/zkxwzIiEteignTS3YW3SYk0SoB
#            ZBoPRLfAJN0b5vRgSe2OL8VdMOkB0UfpabXEK0OG0P7hGg2FlDCGPtzXBOfAzZLW
#            +FRy6fXvss4lRbKd1bbKf+5Kz9GHWy8gKWnpm9CXhnGvqCrxMkkBWuDOwpRK8VSx
#            NIUj6wZwtpSOqWJPLzB3ZCrLKhFxmaHA8cYZdiFp/5P/N5Hq+9zy+uFReCfhcr33
#            d7KgLnD1hnQdkuY7O2Jg9PTJUlxb41+W0WY4ZYW5igvtk8zirperuLbeHBbpQvsx
#            6CBx8akCgYEA9WZP9MF/joMHdtt0Mn663ycL9PEA233psnLghxeKNXR/n22MtK9Y
#            CAnHO9mNiBp7nUUDKRtGwsUytUQt0BcuhikxisY+WoeKv1lmLperz6Qv7n4TTN3D
#            7edX6lQVLV8Q0k26Cf6kKEf9Noy0Utz8AWEMzK9XwMzIVa5+RB14t9cCgYEA0GXM
#            z3MZvEe7IQnQGNvWzRFZ3lQEmpOUzzluOj+fBNh9A8v4+U5GAw7QQop5L5//rD7n
#            7DUhl5BoZOhUzdBTQr6q4rs05EBphPrwZgpGGDWXmmBzMD88fM5j1bKOC2c3ZqLs
#            TVOdWTsj+iNqvxnfvMYB6U5PdM06wVObM0Q+WY0CgYEAqOlxo7EE0d1S5/cKNi+R
#            stbDfNooI8Rx7a7WA26WMHOzuf5uyaeulNiYZf34dR86X6ak0xv98szUTE8XP5R1
#            kP5LowgWKQFskV3CEiQLKCHodU7omUI1p91M99IBvQzu87A6ffm7cW8=
#            -----END RSA PRIVATE KEY-----
eureka:
  client:
    serviceUrl:
      defaultZone: http://127.0.0.1:8700/eureka/
    registry-fetch-interval-seconds: 10
    healthcheck:
      enabled: true
  instance:
    lease-expiration-duration-in-seconds: 10
    lease-renewal-interval-in-seconds: 10

4.在linux目录“/home/wshop/service/config”下增加共享配置文件“base-dev.yml”:

文件内容比如:

# 配置hystrix
feign:
  hystrix:
    enabled: true

ribbon:
  ReadTimeout: 400000
  ConnectTimeout: 400000

# 配置hystrix
hystrix:
  metrics:
    enabled: true
  threadpool:
    default:
      coreSize: 101  #线程池核心线程数
  command:
    default:
      execution:
        isolation:
          thread:
            timeoutInMilliseconds: 400000 #超时时间,如果超时,则实现服务降级处理
      circuitBreaker:
        requestVolumeThreshold: 100  #当在配置时间窗口内达到此数量后,进行短路。默认20个
        sleepWindowInMilliseconds: 5000  #短路多久以后开始尝试是否恢复,默认5s
        errorThresholdPercentage: 50%  #出错百分比阈值,当达到此阈值后,开始短路。默认50%

management:
  endpoint:
    health:
      show-details: always
    web:
      exposure:
        include: hystrix.stream

4.run脚本启动,并访问测试

run脚本范例:

#!/bin/bash
#########################################################################
# File Name: run.sh
# Function:
# Author: Mason
# Version: V1.0
# Created Time: 28/1/2019 11:41:48
#########################################################################

# chkconfig: - 98 33
# description: Starts and stops the java project daemon \
#              used to provide some java jar packet services.

source /etc/profile

# base env parameters setting
BASEDIR=$(dirname $(readlink -f $0))
APPNAME=config-server
VERSION=1.0.0


JAVAOPT="-Xms256m -Xmx512m -XX:PermSize=128M -XX:MaxPermSize=256M"


# define some functions
get_pid(){
   PID=$(ps -ef|grep ${APPNAME} |grep "java" |grep -v grep |awk '{print $2}')
}

start(){
   if [ -z ${PID} ];then
      nohup java ${JAVAOPT} -Dlogging.config=${BASEDIR}/logback-spring.xml -D$APPNAME  -jar ${BASEDIR}/${APPNAME}-${VERSION}.jar --spring.config.location=${BASEDIR}/application.yml &>/dev/null &

      inter=1
      time=10
      i=0
      while ((i < time));do
         get_pid
         #if [ $(netstat -lntup|grep -c $PID) -le 1 ];then
          if((i>(time-2)));then
                if [ ${PID} ];then
                    echo "${APPNAME} started OK."
                    break
                else
                    sleep ${inter}
                    let i++
                fi
            else
                sleep ${inter}
                let i++
            fi
      done
      if ((i == time));then
         echo "${APPNAME} started FAIL in $((inter*time)) second!"
         exit 1
      fi
   else
      echo "${APPNAME} is still running with pid ${PID}!"
      exit 1
   fi
}

stop(){
   if [ ! -z ${PID} ];then
      kill -9 ${PID} && echo "${APPNAME} was killed."
   else
      echo "${APPNAME} is not running!"
      exit 1
   fi
}

restart(){
   stop
   start
}

status(){
   if [ ! -z ${PID} ];then
      echo "${APPNAME} is running with pid ${PID}"
   else
      echo "${APPNAME} is not running."
   fi
}

# the main program started
get_pid
case "$1" in
  start)
        start
        ;;
  stop)
        stop
        ;;
  restart)
        restart
        ;;
  status)
        status
        ;;
  *)
        echo $"Usage: $0 {start|stop|restart|status}"
        exit 2
esac
exit $?

http://192.168.60.235:8707/base-dev.yml

微服务spring-cloud 配置中心config-server本地化部署是怎样的

说明服务端已经启动成功;

二、客户端

1.在linux目录“/home/wshop/service/config”下增加共享配置文件“bootstrap.yml”:

其内内容如下:

spring:
  cloud:
    config:
      uri: http://127.0.0.1:8707/        #Config server的uri
      profile: dev                       #指定的环境
      name: base

启动客户端应用jar中增加配置:

/home/wshop/service/config/bootstrap.yml

完整启动命令:

nohup java ${JAVAOPT} -Dlogging.config=${BASEDIR}/logback-spring.xml -D$APPNAME  -jar ${BASEDIR}/${APPNAME}-${VERSION}.jar --spring.config.location=${BASEDIR}/application.yml,/home/wshop/service/config/bootstrap.yml &>/dev/null &

重新启动客户端,即实现客户端应用接入配置中心功能。

上述就是小编为大家分享的微服务spring-cloud 配置中心config-server本地化部署是怎样的了,如果刚好有类似的疑惑,不妨参照上述分析进行理解。如果想知道更多相关知识,欢迎关注创新互联行业资讯频道。

分享名称:微服务spring-cloud配置中心config-server本地化部署是怎样的
网址分享:https://www.cdcxhl.com/article38/jijjsp.html

成都网站建设公司_创新互联,为您提供建站公司网页设计公司响应式网站定制开发网站排名外贸网站建设

广告

声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联

h5响应式网站建设