IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 系统运维 -> Linux上安装httpd2.4.46 (apache)做SSL证书卸载方案 -> 正文阅读

[系统运维]Linux上安装httpd2.4.46 (apache)做SSL证书卸载方案

1、安装apache之前先确认Linux的基本编译环境是否正常安装,如果没有使用管理用户执行以下命令:

yum install -y gcc*

yum install -y glib*

yum install -y libtool

否则在安装过程中会报错:

checking build system type... x86_64-unknown-linux-gnu

checking host system type... x86_64-unknown-linux-gnu

checking target system type... x86_64-unknown-linux-gnu

Configuring APR library

Platform: x86_64-unknown-linux-gnu

checking for working mkdir -p... yes

APR Version: 1.5.2

checking for chosen layout... apr

checking for gcc... no

checking for cc... no

2、以上编译环境安装好后,开始安装apache必须要的apr库。不同的apache版本有需要匹配不同的版本的apr安装包。先将下载好的apr安装包拷贝到服务目录下,我使用的apr-1.5.2.tar.gz

然后解压安装包文件tar -zxf apr-1.5.2.tar.gz

[root@ensemble1 app]# tar -zxf apr-1.5.2.tar.gz

然后进入安装目录apr-1.5.2执行以下命令

[root@ensemble1 apr-1.5.2]# ./configure --prefix=/usr/local/apr

安装成功后开始进行编译安装,执行以下命令:

[root@ensemble1 apr-1.5.2]# make && make install

3、安装apache之前先确认apr是不是安装了,如果没有安装先安装apr-util

[root@ensemble1 app]# tar -zxf apr-util-1.5.4.tar.gz

[root@ensemble1 app]# cd apr-util-1.5.4

然后进行编译安装:

[root@ensemble1 apr-util-1.5.4]# ./configure --prefix=/usr/local/apr-util --with-apr=/usr/local/apr/bin/apr-1-config

[root@ensemble1 apr-util-1.5.4]# make && make instal

4、安装pcre,使用的是pcre-8.10版本,将安装包上传到服务器进行解压

[root@ensemble1 app]# unzip pcre-8.10.zip

[root@ensemble1 app]# cd pcre-8.10

编译安装

[root@ensemble1 pcre-8.10]# ./configure --prefix=/usr/local/pcre

[root@ensemble1 pcre-8.10]# make && make install

5、安装apache

使用的是httpd-2.4.46安装包,将安装包解压到/app/app目录下

在httpd-2.4.46安装目录下执行

[root@ensemble1 httpd-2.4.46]tar -zxf httpd-2.4.46.tar.gz

[root@ensemble1 httpd-2.4.46]cd httpd-2.4.46

[root@ensemble1 httpd-2.4.46]# ./configure --prefix=/app/app/apache24 --with-apr=/usr/local/apr --with-apr-util=/usr/local/apr-util --with-pcre=/usr/local/pcre? --enable-so --enable-rewrite

注意:此处安装的Apache是没有启用SSL模块的,也可以直接修改这个命令直接加载SSL库,这样就不用执行第6步,我实现安装未配置SSL模块然后再增加SSL卸载。命令如下:

[root@ensemble1 httpd-2.4.46]# ./configure --prefix=/app/app/apache24 --with-apr=/usr/local/apr --with-apr-util=/usr/local/apr-util --with-pcre=/usr/local/pcre? --with-ssl =/usr/local/openssl --enable-so --enable-rewrite --enable-ssl

然后开始安装:

[root@ensemble1 httpd-2.4.46]# make && make instal

安装完成后启动时候报一下错误:

[root@ensemble1 bin]# ./apachectl configtest

AH00558: httpd: Could not reliably determine the server's fully qualified domain name, using fe80::f816:3eff:feb8:c6e7. Set the 'ServerName' directive globally to suppress this message

Syntax OK

[root@ensemble1 bin]# ./apachectl start

AH00558: httpd: Could not reliably determine the server's fully qualified domain name, using fe80::f816:3eff:feb8:c6e7. Set the 'ServerName' directive globally to suppress this message

原因:

http.conf 文件中没有配置ServerName localhost

处理方案:修改http.conf文件的配置,增加ServerName localhost

#ServerName www.example.com:80

ServerName localhost

6、配置SSL卸载的so库,及配置文件

第一步,检查安装的apache是否安装了SSL的,上面安装的httpd是不带SSL模块的,需要手动加载SSL的so库。

第二步,把apache源码包里的modules/md文件夹中的所有文件复制到/usr/include/目录

[root@ensemble1 bin]$ cp /app/tools/httpd-2.4.46/modules/md/* /usr/include/

第三步,执行以下代码,安装SSL模块

[root@ensemble1 bin]$ cd /app/tools/httpd-2.4.46

[root@ensemble1 httpd-2.4.46]$ /app/app/apache24/bin/apxs -a -i -DHAVE_OPENSSL=1 -I/usr/include/openssl -L/usr/lib64/openssl -c /app/tools/httpd-2.4.46/modules/ssl/*.c -lcrypto -lssl –ldl

注意:apxs 命令是 apache编译安装模块的命令

???????????? -I? 安装

???????????? -a激活模块(向httpd.conf添加LoadModule ssl_module modules/mod_ssl.so指令)

?????? ? ? ? -c编译指定的模块

执行以上步骤时,必须确保linux系统安装了openssl ,如果没有先使用root用户执行以下命令

yum install -y openssl openssl-devel

7、在安装完成的apache配置对应的SSL站点服务器证书到服务器的目录,然后修改配置文件,增加SSL卸载配置

证书目录:/app/app/apache24/crt

配置文件:

Listen 8855

<VirtualHost *:8855>

??????????? DocumentRoot "/app/app/shared"

??????????? ServerName www.xxxx.com

??????????? ServerAlias www.xxxx.com

?????? ?????ErrorLog "logs/8899/error-xxxx.log"

??????????? CustomLog "logs/8899/access-xxxx.log" common

??? ????????SSLEngine on

??? ????????SSLProtocol -all +TLSv1.2 +TLSv1.1 +TLSv1

SSLCipherSuite DHE-RSA-AES128-GCM-SHA256:ECDHE:ECDH:AES:HIGH:!NULL:!aNULL:!MD5:!ADH:!RC4

??????????? SSLCertificateFile "/app/app/apache24/crt/server.crt"

??????????? SSLCertificateKeyFile "/app/app/apache24/crt/server.key"

????????? ??SSLCertificateChainFile "/app/app/apache24/crt/cfca.crt"

</VirtualHost>

然后到/app/app/apache24/bin目录下增加执行 ./apachectl restart? 重启apache,在浏览器中输入https://www.xxxx.com:8855/aaaa? ,此时证书加载成功

  系统运维 最新文章
配置小型公司网络WLAN基本业务(AC通过三层
如何在交付运维过程中建立风险底线意识,提
快速传输大文件,怎么通过网络传大文件给对
从游戏服务端角度分析移动同步(状态同步)
MySQL使用MyCat实现分库分表
如何用DWDM射频光纤技术实现200公里外的站点
国内顺畅下载k8s.gcr.io的镜像
自动化测试appium
ctfshow ssrf
Linux操作系统学习之实用指令(Centos7/8均
上一篇文章      下一篇文章      查看所有文章
加:2022-04-01 23:49:45  更:2022-04-01 23:50:46 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/18 6:54:34-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码