Spring Cloud Config Server无法从本地文件系统服务

时间:2015-12-28 00:28:38

标签: docker spring-boot spring-cloud

注意:我已阅读thisthis问题。没有帮助。

我创建了一个Spring配置服务器Docker镜像。目的是能够运行具有不同配置文件和搜索位置的多个容器。这是它与上述问题的不同之处,其中属性是从git加载的,或者是从启动时配置服务器已知的类路径位置加载的。我的配置服务器也传统上部署在Tomcat中,而不是使用重新打包的启动jar。

当我访问http://<docker host>:8888/movie-service/native时,我没有内容(见下文)。我期待的内容将在问题的最后给出。

{"name":"movie-service","profiles":["native"],"label":"master","propertySources":[]}

我已经尝试过阳光下的所有事情,但却无法让它发挥作用。

配置服务器 main:

@SpringBootApplication
@EnableConfigServer
@EnableDiscoveryClient
public class ConfigServer extends SpringBootServletInitializer {
    /* Check out the EnvironmentRepositoryConfiguration for details */
    public static void main(String[] args) {
        SpringApplication.run(ConfigServer.class, args);
    }

    @Override
    protected SpringApplicationBuilder configure(SpringApplicationBuilder application) {
        return application.sources(ConfigServer.class);
    }
}

配置服务器 application.yml

spring:
  cloud:
    config:
      enabled: true
      server:
        git:
          uri: ${CONFIG_LOCATION}
        native:
          searchLocations: ${CONFIG_LOCATION}
server:
  port: ${HTTP_PORT:8080}

配置服务器 bootstrap.yml

spring:
  application:
    name: config-service

eureka:
  instance:
    hostname: ${CONFIG_HOST:localhost}
    preferIpAddress: false
  client:
    registerWithEureka: ${REGISTER_WITH_DISCOVERY:true}
    fetchRegistry: false
    serviceUrl:
      defaultZone: http://${DISCOVERY_HOST:localhost}:${DISCOVERY_PORT:8761}/eureka/

Docker运行命令

docker run -it -p 8888:8888 \
-e CONFIG_HOST="$(echo $DOCKER_HOST | grep -Eo '([0-9]{1,3}\.){3}[0-9]{1,3}')" \
-e HTTP_PORT=8888 \
-e CONFIG_LOCATION="file:///Users/<some path>/config/" \
-e REGISTER_WITH_DISCOVERY="false" \
-e SPRING_PROFILES_ACTIVE=native xxx

配置目录

/Users/<some path>/config
--- movie-service.yml
movie-service.yml

内容

themoviedb:
  url: http://api.themoviedb.org

1 个答案:

答案 0 :(得分:0)

自己想出来。除非使用this.HasRequired(t => t.Activity1) .WithMany(t => t.Predecessors) .HasForeignKey(m => m.Activity1_ID) .WillCascadeOnDelete(false); this.HasRequired(t => t.Activity2) .WithMany(t => t.Successors) .HasForeignKey(m => m.Activity2_ID) .WillCascadeOnDelete(false); 标志在运行时挂载文件系统目录,否则Docker容器无权访问主机文件系统。

为了完整起见,这是完整的Docker -v命令:

run