AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / unix / 问题 / 503381
Accepted
Nani
Nani
Asked: 2019-02-28 08:54:33 +0800 CST2019-02-28 08:54:33 +0800 CST 2019-02-28 08:54:33 +0800 CST

如何在同一域中为多个端口配置“https”?

  • 772

我有一个网站(apache web 服务器,ubuntu 14.04)设置http://example.com并配置了端口 1996 和 1980。

这些链接适用于http

http://example.com/myproject
http://example.com:1996/
http://example.com:1980/

然后我安装了 SSL 证书并将此服务器配置为使用https.

但是这些链接不起作用

https://example.com:1996 
https://example.com:1980

如何https在同一个域中配置多个端口?

默认配置:

<VirtualHost *:80>
               ServerAdmin webmaster@localhost
        DocumentRoot /var/www/html
        ErrorLog ${APACHE_LOG_DIR}/error.log
        CustomLog ${APACHE_LOG_DIR}/access.log combined
</VirtualHost>

<VirtualHost *:443>

        ServerAdmin webmaster@localhost
        DocumentRoot /var/www/html
        ErrorLog ${APACHE_LOG_DIR}/error.log
        CustomLog ${APACHE_LOG_DIR}/access.log combined
        ServerName example.com
        SSLEngine on
        SSLCertificateFile /home/ubuntu/ssl_cert/signed_cert.crt
        SSLCertificateKeyFile /home/ubuntu/ssl_cert/server.key

</VirtualHost>

端口.conf:

Listen 80

<IfModule ssl_module>
    Listen 443
</IfModule>

<IfModule mod_gnutls.c>
    Listen 443
</IfModule>
debian https
  • 1 1 个回答
  • 9452 Views

1 个回答

  • Voted
  1. Best Answer
    Rui F Ribeiro
    2019-02-28T09:18:13+08:002019-02-28T09:18:13+08:00

    编辑:调试用户设置,发现netstat已经有一个使用 1996/TCP 的进程:

    netstat -nlp | grep 1996
    tcp 0 0 0.0.0.0:1996 0.0.0.0:* LISTEN 4729/python
    

    所以配置示例,改为1997/TCP。


    Apache/mod_ssl必须被告知 1997/TCP 和 1980/TCP 是 HTTPS 端口。默认情况下 443/TCP 是已知的,但任何其他 TLS 感知 TCP 端口都必须添加到配置中。

    否则,任何非 443/TCP 端口将仅作为支持 HTTP 的端口处理。

    例如,在 CentOS 中,您必须/etc/httpd/conf.d/ssl.conf在 Debian/Ubuntu 中添加/etc/apache2/ports.conf以下行:

    Listen 1997 https
    Listen 1980 https
    

    您还必须在相应的虚拟主机中定义端口:

    <VirtualHost *:1997>
    Servername example.com
    ....
    </VirtualHost>
    
    <VirtualHost *:1980>
    Servername example.com
    ....
    </VirtualHost>
    

    它也鲜为人知,您可以执行以下操作(仅作为示例,如果您仍然拥有使用 :*443 的虚拟主机,请不要使用它):

    <VirtualHost *:443 *:1980>
    Servername example.com
    ....
    </VirtualHost>
    

    编辑配置文件后,您必须重新启动 Apache。在 Debian/Ubuntu 中,它会重新启动:

    sudo service apache2 restart
    

    从Apache - 绑定到地址和端口

    使用 Listen 指定协议

    对于大多数配置,Listen 的可选的第二个协议参数不是必需的。如果未指定,https 是端口 443 的默认值,http 是所有其他端口的默认值。该协议用于确定应由哪个模块处理请求,并使用 AcceptFilter 指令应用特定于协议的优化。

    如果您在非标准端口上运行,您只需要设置协议。例如,在端口 8443 上运行 https 站点:

    听 192.170.2.1:8443 https

    重要提示: 每个端口只能配置一个监听线路/指令。如果您已经有这些端口的 Listen 指令,您可以评论它们或在它们前面添加 https。否则,在启动 Apache 时,您将有一个“地址已在使用中”。

    最后一段的 TLDR:你已经有一个重复的 至少 1996 年在可能的 apache2.conf 中,把它拿出来。(不,它正在被另一个正在运行的服务使用)

    第二个注意事项:不要使用您可能在其他正在运行的服务上配置的端口。

    • 4

相关问题

  • GRUB 配置以识别同一 Linux 发行版的不同桌面环境(安装)

  • astyle 不会更改源文件格式

  • 接收有关全新 Debian 的电子邮件

  • Debian Stretch:libgs_plugin_systemd-updates.so 中的 gnome-software 段错误

  • 如何在拼音输入法中输入ü?

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    模块 i915 可能缺少固件 /lib/firmware/i915/*

    • 3 个回答
  • Marko Smith

    无法获取 jessie backports 存储库

    • 4 个回答
  • Marko Smith

    如何将 GPG 私钥和公钥导出到文件

    • 4 个回答
  • Marko Smith

    我们如何运行存储在变量中的命令?

    • 5 个回答
  • Marko Smith

    如何配置 systemd-resolved 和 systemd-networkd 以使用本地 DNS 服务器来解析本地域和远程 DNS 服务器来解析远程域?

    • 3 个回答
  • Marko Smith

    dist-upgrade 后 Kali Linux 中的 apt-get update 错误 [重复]

    • 2 个回答
  • Marko Smith

    如何从 systemctl 服务日志中查看最新的 x 行

    • 5 个回答
  • Marko Smith

    Nano - 跳转到文件末尾

    • 8 个回答
  • Marko Smith

    grub 错误:你需要先加载内核

    • 4 个回答
  • Marko Smith

    如何下载软件包而不是使用 apt-get 命令安装它?

    • 7 个回答
  • Martin Hope
    user12345 无法获取 jessie backports 存储库 2019-03-27 04:39:28 +0800 CST
  • Martin Hope
    Carl 为什么大多数 systemd 示例都包含 WantedBy=multi-user.target? 2019-03-15 11:49:25 +0800 CST
  • Martin Hope
    rocky 如何将 GPG 私钥和公钥导出到文件 2018-11-16 05:36:15 +0800 CST
  • Martin Hope
    Evan Carroll systemctl 状态显示:“状态:降级” 2018-06-03 18:48:17 +0800 CST
  • Martin Hope
    Tim 我们如何运行存储在变量中的命令? 2018-05-21 04:46:29 +0800 CST
  • Martin Hope
    Ankur S 为什么 /dev/null 是一个文件?为什么它的功能不作为一个简单的程序来实现? 2018-04-17 07:28:04 +0800 CST
  • Martin Hope
    user3191334 如何从 systemctl 服务日志中查看最新的 x 行 2018-02-07 00:14:16 +0800 CST
  • Martin Hope
    Marko Pacak Nano - 跳转到文件末尾 2018-02-01 01:53:03 +0800 CST
  • Martin Hope
    Kidburla 为什么真假这么大? 2018-01-26 12:14:47 +0800 CST
  • Martin Hope
    Christos Baziotis 在一个巨大的(70GB)、一行、文本文件中替换字符串 2017-12-30 06:58:33 +0800 CST

热门标签

linux bash debian shell-script text-processing ubuntu centos shell awk ssh

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve