docker容器中的JetBrains / Teamtools“无法侦听地址0.0.0.0和端口443”

时间:2018-06-29 15:11:58

标签: docker https jetbrains-hub macvlan

问题

我正在尝试在docker容器中设置JetBrains Hub,Youtrack,Upsource和Teamcity,并将它们配置为可在自己的IP(macvlan)上使用,默认端口80重定向到HTTPS的443和443(因此端口号不会显示在浏览器中。

但是我得到的是:

  

无法在地址0.0.0.0和端口443上侦听

将teamtools保留在其默认端口8080和8443上,或者为它们提供2000以上的端口似乎也可以。

我用fuser 443/tcpnetstat -tulpn进行了检查,但端口80或443上没有任何运行。(必须为容器中的软件包安装软件包)

我尝试将侦听地址设置为NIC IP或172.0.0.1,但这也被拒绝:

root@teamtools [ /opt/teamtools ]# docker run --rm -it \
    -v /opt/hub/data:/opt/hub/data \
    -v /opt/hub/conf:/opt/hub/conf \
    -v /opt/hub/logs:/opt/hub/logs \
    -v /opt/hub/backups:/opt/hub/backups \
    jetbrains/hub:2018.2.9840 \
    configure --listen-address=192.168.1.211
* Configuring JetBrains Hub 2018.2
* Setting property 'listen-address' to '192.168.1.211' from arguments
[APP-WRAPPER] Failed to configure Hub: java.util.concurrent.ExecutionException: com.jetbrains.bundle.exceptions.BadConfigurationException: Could not listen on address {192.168.1.211} . Please specify another listen address in property listen-address

问题:

  1. 为什么不能设置端口80和443?
  2. 为什么它适用于以上端口 2000?
  3. 在没有反向代理的情况下如何使这项工作有效? ((反向代理还带来了很多其他问题,我希望通过此设置来避免)

设置

ESXi 6.7 Host
  - vSwitch0 (Allow promiscuous mode:   Yes)
     - port group: VM Netork (Allow promiscuous mode:   No)
       - other VMs
     - port group: Promiscuous Ports (Allow promiscuous mode:   Yes)
       - Teamtools VM (Photon OS 2.0, IP: 192.168.1.210)
         - firewall based on: https://unrouted.io/2017/08/15/docker-firewall/
         - docker/docker-compose
           - hub                         (IP: 192.168.1.211:80/443)
           - youtrack                    (IP: 192.168.1.212:80/443)
           - upsource                    (IP: 192.168.1.213:80/443)
           - teamcity-server             (IP: 192.168.1.214:80/443)
           - teamcity_db (MariaDB 10.3)  (IP: 192.168.1.215:3306)

docker-compose.yml

version: '2'
networks:
  macnet:
    driver: macvlan
    driver_opts:
      parent: eth0
    ipam:
      config:
        - subnet: 192.168.1.0/24
          gateway: 192.168.1.1 

services:
  hub:
    # set a custom container name so no more than one container can be created from this config
    container_name: hub
    image: "jetbrains/hub:2018.2.9840"
    restart: unless-stopped
    volumes:
      - /opt/hub/data:/opt/hub/data
      - /opt/hub/conf:/opt/hub/conf
      - /opt/hub/logs:/opt/hub/logs
      - /opt/hub/backups:/opt/hub/backups
      - /opt/teamtools:/opt/teamtools
    expose:
      - "80"
      - "443"
      - "8080"
      - "8443"
    networks:
      macnet:
        ipv4_address: 192.168.1.211
    domainname: office.mydomain.com
    hostname: hub
    environment:
      - "JAVA_OPTS=-J-Djavax.net.ssl.trustStore=/opt/teamtools/certs/keyStore.p12 -J-Djavax.net.ssl.trustStorePassword=xxxxxxxxxxxxxx"
...

1 个答案:

答案 0 :(得分:2)

上游是由非root用户jetbrans运行。 https://www.w3.org/Daemon/User/Installation/PrivilegedPorts.html