window下Apache-http-server(httpd-2.4.12)安装与配置
由于Apache官网改变策略(2015年1月左右),官网不再提供Apache-http-server的windows的编译版本,但是提供了几个第三方的版本
http://httpd.apache.org/docs/current/platform/windows.html#down
分别是ApacheHaus、Apache Lounge、BitNami WAMP Stack、WampServer、XAMPP
笔者进的是ApacheHaus下载Apache 2.4.x VC9 64位版本
建议下载httpd-2.4.12-x64-r2.zip、httpd-2.4.12-x86-r2.zip
然后下载对应的VC9(VC2008)运行库
32位
http://www.microsoft.com/downloads/en/details.aspx?FamilyID=A5C84275-3B97-4AB7-A40D-3802B2AF5FC2
64位
http://www.microsoft.com/downloads/en/details.aspx?FamilyID=BA9257CA-337F-4B40-8C14-157CFDFFEE4E
安装好VC9运行库之后,将httpd-2.4.12-x64-r2.zip里面的Apache24文件夹放到D盘根目录(注意:必须放到根目录,其他目录启动和加载模块会出错)
然后打开命令行,切换到bin目录,运行httpd.exe
C:\Users\test>D: D:\>cd Apache24 D:\Apache24>cd bin D:\Apache24\bin>httpd.exe (OS 10048)通常每个套接字地址(协议/网络地址/端口)只允许使用一次。 : AH00072: mak e_sock: could not bind to address [::]:443 (OS 10048)通常每个套接字地址(协议/网络地址/端口)只允许使用一次。 : AH00072: mak e_sock: could not bind to address 0.0.0.0:443 AH00451: no listening sockets available, shutting down AH00015: Unable to open logs D:\Apache24\bin>
这里443端口被占用,我们可以通过netstat -ano查询那个进程在使用这个端口
参数解释:
-a 显示所有连接和侦听端口。 -n 以数字形式显示地址和端口号。 -o 显示拥有的与每个连接关联的进程 ID。
结果如下:
D:\Apache24\bin>netstat -ano 活动连接 协议 本地地址 外部地址 状态 PID TCP 0.0.0.0:135 0.0.0.0:0 LISTENING 704 TCP 0.0.0.0:443 0.0.0.0:0 LISTENING 2472 TCP 0.0.0.0:445 0.0.0.0:0 LISTENING 4 TCP 0.0.0.0:902 0.0.0.0:0 LISTENING 1664 TCP 0.0.0.0:912 0.0.0.0:0 LISTENING 1664 TCP 0.0.0.0:5938 0.0.0.0:0 LISTENING 2028 TCP 0.0.0.0:49152 0.0.0.0:0 LISTENING 496 TCP 0.0.0.0:49154 0.0.0.0:0 LISTENING 856 TCP 0.0.0.0:49156 0.0.0.0:0 LISTENING 1044 TCP 0.0.0.0:49157 0.0.0.0:0 LISTENING 1452 TCP 0.0.0.0:49158 0.0.0.0:0 LISTENING 600 TCP 0.0.0.0:49163 0.0.0.0:0 LISTENING 592 TCP 127.0.0.1:4300 0.0.0.0:0 LISTENING 3816 TCP 127.0.0.1:4301 0.0.0.0:0 LISTENING 3816 TCP 127.0.0.1:5939 0.0.0.0:0 LISTENING 2028 TCP 127.0.0.1:5939 127.0.0.1:58762 ESTABLISHED 2028 TCP 127.0.0.1:8307 0.0.0.0:0 LISTENING 2472 TCP 127.0.0.1:58762 127.0.0.1:5939 ESTABLISHED 4840 TCP 127.0.0.1:58972 127.0.0.1:58973 ESTABLISHED 5792 TCP 127.0.0.1:58973 127.0.0.1:58972 ESTABLISHED 5792 TCP 127.0.0.1:59811 127.0.0.1:2559 SYN_SENT 3172 TCP 172.18.62.201:139 0.0.0.0:0 LISTENING 4 TCP 172.18.62.201:59212 111.161.81.209:80 CLOSE_WAIT 3816 TCP 172.18.62.201:59274 111.161.81.209:80 CLOSE_WAIT 3816 TCP 172.18.62.201:59373 111.161.81.209:80 CLOSE_WAIT 3816 TCP 172.18.62.201:59427 111.161.81.209:80 CLOSE_WAIT 3816 TCP 172.18.62.201:59475 112.64.237.239:8080 TIME_WAIT 0 TCP 172.18.62.201:59555 92.51.156.100:5938 ESTABLISHED 2028 TCP 172.18.62.201:59607 111.161.81.209:80 CLOSE_WAIT 3816 TCP 172.18.62.201:59623 112.90.86.25:443 TIME_WAIT 0 TCP 172.18.62.201:59624 183.60.16.21:8080 TIME_WAIT 0 TCP 172.18.62.201:59626 183.60.16.21:8080 TIME_WAIT 0 TCP 172.18.62.201:59629 112.90.86.25:443 TIME_WAIT 0 TCP 172.18.62.201:59693 61.137.188.200:80 TIME_WAIT 0 TCP 172.18.62.201:59694 61.135.169.125:443 ESTABLISHED 5792 TCP 172.18.62.201:59699 111.206.76.33:443 ESTABLISHED 5792 TCP 172.18.62.201:59700 111.206.76.33:443 ESTABLISHED 5792 TCP 172.18.62.201:59701 111.206.76.33:443 ESTABLISHED 5792 TCP 172.18.62.201:59702 111.206.76.32:443 ESTABLISHED 5792 TCP 172.18.62.201:59703 111.206.76.32:443 TIME_WAIT 0 TCP 172.18.62.201:59704 61.135.169.121:443 ESTABLISHED 5792 TCP 172.18.62.201:59705 61.135.169.121:443 TIME_WAIT 0 TCP 172.18.62.201:59706 61.135.169.121:443 ESTABLISHED 5792 TCP 172.18.62.201:59707 61.135.169.121:443 TIME_WAIT 0 TCP 172.18.62.201:59708 23.59.139.27:80 TIME_WAIT 0 TCP 172.18.62.201:59709 23.59.139.27:80 TIME_WAIT 0 TCP 172.18.62.201:59714 61.135.169.125:443 ESTABLISHED 5792 TCP 172.18.62.201:59715 61.135.169.121:443 ESTABLISHED 5792 TCP 172.18.62.201:59719 61.135.169.125:80 ESTABLISHED 5792 TCP 172.18.62.201:59734 223.202.6.26:80 ESTABLISHED 5792 TCP 172.18.62.201:59736 223.202.6.26:80 TIME_WAIT 0 TCP 172.18.62.201:59745 202.106.182.252:80 TIME_WAIT 0 TCP 172.18.62.201:59746 123.125.29.224:80 ESTABLISHED 5792 TCP 172.18.62.201:59747 123.125.29.224:80 TIME_WAIT 0 TCP 172.18.62.201:59748 124.95.163.253:80 TIME_WAIT 0 TCP 172.18.62.201:59749 124.95.163.253:80 TIME_WAIT 0 TCP 172.18.62.201:59750 124.95.163.253:80 TIME_WAIT 0 TCP 172.18.62.201:59751 124.95.163.253:80 FIN_WAIT_1 5792 TCP 172.18.62.201:59754 124.95.163.253:80 TIME_WAIT 0 TCP 172.18.62.201:59759 124.95.163.253:80 TIME_WAIT 0 TCP 172.18.62.201:59760 218.30.115.254:80 TIME_WAIT 0 TCP 172.18.62.201:59762 124.95.163.253:80 TIME_WAIT 0 TCP 172.18.62.201:59766 124.40.53.35:80 ESTABLISHED 4380 TCP 172.18.62.201:59767 218.60.106.89:80 ESTABLISHED 4380 TCP 172.18.62.201:59768 218.60.106.89:80 ESTABLISHED 4380 TCP 172.18.62.201:59769 218.60.106.89:80 ESTABLISHED 4380 TCP 172.18.62.201:59770 23.42.177.49:80 ESTABLISHED 4380 TCP 172.18.62.201:59778 124.40.53.35:80 ESTABLISHED 4380 TCP 172.18.62.201:59779 124.95.163.253:80 TIME_WAIT 0 TCP 172.18.62.201:59780 124.95.163.253:80 TIME_WAIT 0 TCP 172.18.62.201:59802 1.1.1.1:80 SYN_SENT 3816 TCP 172.18.62.201:59807 123.125.125.85:80 TIME_WAIT 0 TCP 172.18.62.201:59809 125.39.120.82:443 SYN_SENT 5016 TCP 192.168.116.1:139 0.0.0.0:0 LISTENING 4 TCP 192.168.253.1:139 0.0.0.0:0 LISTENING 4 TCP [::]:135 [::]:0 LISTENING 704 TCP [::]:443 [::]:0 LISTENING 2472 TCP [::]:445 [::]:0 LISTENING 4 TCP [::]:49152 [::]:0 LISTENING 496 TCP [::]:49154 [::]:0 LISTENING 856 TCP [::]:49156 [::]:0 LISTENING 1044 TCP [::]:49157 [::]:0 LISTENING 1452 TCP [::]:49158 [::]:0 LISTENING 600 TCP [::]:49163 [::]:0 LISTENING 592 TCP [::1]:8307 [::]:0 LISTENING 2472 UDP 0.0.0.0:4000 *:* 3816 UDP 0.0.0.0:4001 *:* 3816 UDP 0.0.0.0:5355 *:* 1232 UDP 0.0.0.0:49152 *:* 968 UDP 0.0.0.0:51101 *:* 3816 UDP 0.0.0.0:52030 *:* 3816 UDP 0.0.0.0:52031 *:* 3816 UDP 0.0.0.0:52032 *:* 3816 UDP 0.0.0.0:54781 *:* 3164 UDP 0.0.0.0:57498 *:* 2028 UDP 0.0.0.0:61524 *:* 3816 UDP 0.0.0.0:61676 *:* 2772 UDP 0.0.0.0:62217 *:* 5016 UDP 0.0.0.0:62629 *:* 2772 UDP 0.0.0.0:63659 *:* 3816 UDP 127.0.0.1:1900 *:* 3356 UDP 127.0.0.1:50173 *:* 3356 UDP 172.18.62.201:137 *:* 4 UDP 172.18.62.201:138 *:* 4 UDP 172.18.62.201:1900 *:* 3356 UDP 172.18.62.201:5353 *:* 2028 UDP 192.168.116.1:137 *:* 4 UDP 192.168.116.1:138 *:* 4 UDP 192.168.116.1:1900 *:* 3356 UDP 192.168.116.1:5353 *:* 2028 UDP 192.168.253.1:137 *:* 4 UDP 192.168.253.1:138 *:* 4 UDP 192.168.253.1:1900 *:* 3356 UDP 192.168.253.1:5353 *:* 2028 UDP [::]:5355 *:* 1232 UDP [::]:57499 *:* 2028 UDP [::1]:1900 *:* 3356 UDP [::1]:5353 *:* 2028 UDP [::1]:50172 *:* 3356 UDP [fe80::481a:1efd:d5d4:a87b%23]:546 *:* 856 UDP [fe80::481a:1efd:d5d4:a87b%23]:546 *:* 856 UDP [fe80::481a:1efd:d5d4:a87b%23]:1900 *:* 3356 UDP [fe80::5919:851f:5249:17f1%21]:546 *:* 856 UDP [fe80::5919:851f:5249:17f1%21]:1900 *:* 3356 UDP [fe80::7495:5b85:a10c:3cb7%3]:546 *:* 856 UDP [fe80::7495:5b85:a10c:3cb7%3]:546 *:* 856 UDP [fe80::7495:5b85:a10c:3cb7%3]:1900 *:* 3356 D:\Apache24\bin>
这个结果太多了,加个findstr命令查一下
D:\Apache24\bin>netstat -ano|findstr :443 TCP 0.0.0.0:443 0.0.0.0:0 LISTENING 2472 TCP [::]:443 [::]:0 LISTENING 2472 D:\Apache24\bin>
可以看到PID为2472的进程占用了这个端口。
这是可以用进程管理器查看是那个进程占用,也可以用tasklist命令查看
D:\Apache24\bin>tasklist 映像名称 PID 会话名 会话# 内存使用 ========================= ======== ================ =========== ============ System Idle Process 0 Services 0 4 K System 4 Services 0 336 K smss.exe 304 Services 0 1,028 K csrss.exe 396 Services 0 4,972 K wininit.exe 496 Services 0 5,000 K services.exe 592 Services 0 6,648 K lsass.exe 600 Services 0 12,448 K svchost.exe 660 Services 0 10,908 K svchost.exe 704 Services 0 8,196 K nvvsvc.exe 872 Services 0 7,152 K QQPCRTP.exe 968 Services 0 17,028 K suservice.exe 640 Services 0 780 K svchost.exe 856 Services 0 21,956 K svchost.exe 1044 Services 0 40,112 K svchost.exe 1072 Services 0 23,148 K svchost.exe 1136 Services 0 85,796 K svchost.exe 1232 Services 0 17,028 K spoolsv.exe 1452 Services 0 12,920 K wlanext.exe 1476 Services 0 5,892 K conhost.exe 1484 Services 0 3,092 K svchost.exe 1564 Services 0 26,960 K svchost.exe 1692 Services 0 13,124 K TeamViewer_Service.exe 2028 Services 0 11,572 K vmnat.exe 1316 Services 0 4,988 K vmware-authd.exe 1664 Services 0 3,120 K vmnetdhcp.exe 2136 Services 0 10,352 K vmware-usbarbitrator64.ex 2156 Services 0 2,788 K vmware-hostd.exe 2472 Services 0 4,684 K svchost.exe 2604 Services 0 4,944 K svchost.exe 3356 Services 0 8,472 K SearchIndexer.exe 3828 Services 0 59,352 K audiodg.exe 3512 Services 0 9,668 K csrss.exe 6076 Console 4 39,188 K winlogon.exe 2388 Console 4 6,088 K dwm.exe 4452 Console 4 50,392 K nvxdsync.exe 3692 Console 4 17,764 K nvvsvc.exe 1756 Console 4 15,076 K TeamViewer.exe 4840 Console 4 37,488 K taskhostex.exe 3444 Console 4 13,120 K explorer.exe 4380 Console 4 158,964 K ChsIME.exe 5096 Console 4 6,064 K tv_w32.exe 4044 Console 4 5,240 K tv_x64.exe 1184 Console 4 4,940 K nvtray.exe 3172 Console 4 18,512 K SogouImeBroker.exe 5612 Console 4 57,096 K SogouImeLoader.exe 3516 Console 4 19,388 K SogouCloud.exe 4888 Console 4 14,436 K vmware-tray.exe 4956 Console 4 6,164 K QQPCTray.exe 5016 Console 4 86,072 K QQPCNetFlow.exe 4696 Console 4 2,756 K QQPCRealTimeSpeedup.exe 3164 Console 4 27,864 K 8021x.exe 5620 Console 4 57,760 K dllhost.exe 5144 Console 4 6,388 K firefox.exe 5792 Console 4 553,612 K plugin-container.exe 4116 Console 4 15,024 K FlashPlayerPlugin_17_0_0_ 4164 Console 4 11,996 K FlashPlayerPlugin_17_0_0_ 3140 Console 4 84,252 K QQProtect.exe 2772 Console 4 20,328 K QQ.exe 3816 Console 4 134,360 K TXPlatform.exe 3348 Console 4 2,116 K 360AP.exe 4632 Console 4 65,592 K 360AP.exe 5616 Console 4 11,272 K 360AP.exe 5220 Console 4 12,576 K cmd.exe 2912 Console 4 3,528 K conhost.exe 4404 Console 4 24,732 K notepad.exe 4396 Console 4 27,032 K SogouSmartInfo.exe 3496 Console 4 7,044 K tasklist.exe 4076 Console 4 6,676 K WmiPrvSE.exe 4244 Services 0 6,088 K D:\Apache24\bin>
加findstr的命令结果
D:\Apache24\bin>tasklist |findstr 2472 vmware-hostd.exe 2472 Services 0 4,684 K D:\Apache24\bin>
笔者这里是虚拟机占用,解决方法要么关闭服务器进程/服务,要么换端口号,笔者这里换端口号
打开conf目录下的httpd.conf,搜索ssl
找到如下文字
# Secure (SSL/TLS) connections # Note: The following must must be present to support # starting without SSL on platforms with no /dev/random equivalent # but a statically compiled-in mod_ssl. # <IfModule ssl_module> #Include conf/extra/httpd-ssl.conf Include conf/extra/httpd-ahssl.conf SSLRandomSeed startup builtin SSLRandomSeed connect builtin </IfModule>
从上面的文字可以看出ssl的配置文件在conf/extra/httpd-ahssl.conf目录下(注意:并不在conf/extra/httpd-ssl.conf目录,这一句被注释掉了)
将其中的443改成其他端口,如1443
第一处(Line 18)
Listen 443
改成
Listen 1443
第二处(Line 134,136)
<VirtualHost _default_:443>
SSLEngine on
ServerName localhost:443
SSLCertificateFile "${SRVROOT}/conf/ssl/server.crt"
SSLCertificateKeyFile "${SRVROOT}/conf/ssl/server.key"
DocumentRoot "${SRVROOT}/htdocs"
# DocumentRoot access handled globally in httpd.conf
CustomLog "${SRVROOT}/logs/ssl_request.log" \
"%t %h %{SSL_PROTOCOL}x %{SSL_CIPHER}x \"%r\" %b"
<Directory "${SRVROOT}/htdocs">
Options Indexes Includes FollowSymLinks
AllowOverride AuthConfig Limit FileInfo
Require all granted
</Directory>
</virtualhost>
改成
<VirtualHost _default_:1443>
SSLEngine on
ServerName localhost:1443
SSLCertificateFile "${SRVROOT}/conf/ssl/server.crt"
SSLCertificateKeyFile "${SRVROOT}/conf/ssl/server.key"
DocumentRoot "${SRVROOT}/htdocs"
# DocumentRoot access handled globally in httpd.conf
CustomLog "${SRVROOT}/logs/ssl_request.log" \
"%t %h %{SSL_PROTOCOL}x %{SSL_CIPHER}x \"%r\" %b"
<Directory "${SRVROOT}/htdocs">
Options Indexes Includes FollowSymLinks
AllowOverride AuthConfig Limit FileInfo
Require all granted
</Directory>
</virtualhost>
第三处(Line 150,152)
<VirtualHost *:443>
SSLEngine on
ServerName serverone.tld:443
SSLCertificateFile "${SRVROOT}/conf/ssl/serverone.crt"
SSLCertificateKeyFile "${SRVROOT}/conf/ssl/serverone.key"
DocumentRoot "${SRVROOT}/htdocs"
CustomLog "${SRVROOT}/logs/ssl_request.log" \
"%t %h %{SSL_PROTOCOL}x %{SSL_CIPHER}x \"%r\" %b"
<Directory "${SRVROOT}/htdocs">
Options Indexes Includes FollowSymLinks
AllowOverride AuthConfig Limit FileInfo
Require all granted
</Directory>
</virtualhost>
改成
<VirtualHost *:1443>
SSLEngine on
ServerName serverone.tld:1443
SSLCertificateFile "${SRVROOT}/conf/ssl/serverone.crt"
SSLCertificateKeyFile "${SRVROOT}/conf/ssl/serverone.key"
DocumentRoot "${SRVROOT}/htdocs"
CustomLog "${SRVROOT}/logs/ssl_request.log" \
"%t %h %{SSL_PROTOCOL}x %{SSL_CIPHER}x \"%r\" %b"
<Directory "${SRVROOT}/htdocs">
Options Indexes Includes FollowSymLinks
AllowOverride AuthConfig Limit FileInfo
Require all granted
</Directory>
</virtualhost>
第四处(Line 165,167)
<VirtualHost *:443> SSLEngine on ServerName servertwo.tld:443 SSLCertificateFile "${SRVROOT}/conf/ssl/servertwo.crt" SSLCertificateKeyFile "${SRVROOT}/conf/ssl/servertwo.key" DocumentRoot "${SRVROOT}/htdocs" CustomLog "${SRVROOT}/logs/ssl_request.log" \ "%t %h %{SSL_PROTOCOL}x %{SSL_CIPHER}x \"%r\" %b" <Directory "${SRVROOT}/htdocs"> Options Indexes Includes FollowSymLinks AllowOverride AuthConfig Limit FileInfo Require all granted </Directory> </virtualhost>
改成
<VirtualHost *:1443> SSLEngine on ServerName servertwo.tld:1443 SSLCertificateFile "${SRVROOT}/conf/ssl/servertwo.crt" SSLCertificateKeyFile "${SRVROOT}/conf/ssl/servertwo.key" DocumentRoot "${SRVROOT}/htdocs" CustomLog "${SRVROOT}/logs/ssl_request.log" \ "%t %h %{SSL_PROTOCOL}x %{SSL_CIPHER}x \"%r\" %b" <Directory "${SRVROOT}/htdocs"> Options Indexes Includes FollowSymLinks AllowOverride AuthConfig Limit FileInfo Require all granted </Directory> </virtualhost>
如果提示80端口占用,一般是IIS服务启动占用,解决方法也是两种,关闭IIS服务或者改端口,80端口在httpd.conf配置文件里面改
这时再用命令行输入
httpd.exe
不报错说明启动成功
浏览器打开http://localhost
看到Apache Haus的图标和It Works界面说明配置成功
将apache注册为系统服务
在管理员模式下启动命令行,输入httpd -k install
D:\Apache24\bin>httpd -k install Installing the 'Apache2.4' service The 'Apache2.4' service is successfully installed. Testing httpd.conf.... Errors reported here must be corrected before the service can be started. D:\Apache24\bin>
这是可以通过ApacheMonitor.exe界面控制apache服务器启动关闭重启
也可以执行以下命令来控制
httpd -k start httpd -k stop httpd -k restart