Centos7+Nginx通过windows CA颁发及配置SSL服务

简介:

近期在学习Linux的相关知识,作为一个运维工程师所必备的知识点,一个web服务尤其运行在互联网上的很容易攻击,所以为了保证安全最起码的需要对web服务配置SSL,这样能提高一定的安全性,所以我们今天介绍,Centos7+Nginx通过windows CA颁发及配置SSL服务,当然如果是生成环境的话,一般都会申请第三方证书,比如沃通等第三方证书颁发机构,今天我们主要使用的是内部的windows CA服务为nginx颁发证书,当然也可以使用Nginx的自签名证书,但是那样每次访问都会有相关的警告 提醒,具体见下:

环境介绍:

Hostname:DC.IXMSOFT.COM

IP:192.168.5.10

Role:DC、DNS、CA

OS:windows Server 2016

Hostname:D-S.IXMSOFT.COM

IP:192.168.5.20

Role:Nginx Service

OS: Centos 7.1

准备操作系统后及安装完成对应的配置:

1.hostnamectl set-hostname d-s

2.vim /etc/selinux/config--->selinux:disabled

3.添加防火墙规则:firewall-cmd –zone=public  --add-port=”80/tcp” –permenant

接下来就是安装nginx仓库

1
yum  install  http: //nginx .org /packages/centos/7/noarch/RPMS/nginx-release-centos-7-0 .el7.ngx.noarch.rpm

clip_image001

1
yum  install  nginx

clip_image001[4]

clip_image002

我们同样给nginx配置一个页面,主要是为了区分

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
vim  /usr/share/nginx/html/index .html
<html>
< head >
<title>Welcome to Nginx!< /title >
<style>
body {
35em;
margin: 0 auto;
font-family: Tahoma, Verdana, Arial, sans-serif;
}
< /style >
< /head >
<body bgcolor= "#BE77FF" >
<h1>Welcome to D-S Nginx Service< /h1 >
<h2>HostName:D-S< /h2 >
<h2>IP:192.168.5.20< /h2 >
< /body >
< /html >

然后启动nginx服务

1
systemctl start nginx

clip_image003

接下来开始申请私钥

1
2
3
cd  /etc/pki/tls
Openssl genrsa -out server.key 2048
Server.key 是私钥

clip_image004

用私钥serverkey 文件生成证书请求文件csr

1
2
3
4
5
6
7
8
9
openssl req -new -key server.key -out server.csr
Server.csr 是证书请求文件
域名,也称为 Common Name,因为特殊的证书不一定是域名:nginx.ixmsoft.com
组织或公司名字(Organization):Example, Ixmsoft
部门(Department):可以不填写,城市(City):Beijing
省份(State / Province):Beijing
国家(Country):CN
加密强度:2048 位,如果你的机器性能强劲,也可以选择 4096 位
如果是泛域名证书,则应该填写*.ixmsoft.com

clip_image005

clip_image006

我们打开刚才生成的csr文件

clip_image007

此时,我们有了csr文件我们通过这个文件在内部的windows CA服务器上申请证书

clip_image008

使用base64位编码的CMC或者RKCS提交证书申请

clip_image009

然后我们将csr文件的内容粘贴,选择web服务证书模板提交

clip_image010

一定要下载basic64编码这个类型,不然在nginx启动的时候回报错

clip_image011

下载证书完成

clip_image012

我们将该证书上传到192.168.5.20上,nginx服务器上

clip_image013

我们将证书拷贝到证书目录下

1
2
cp  certnew.cer  /etc/pki/tls
ls

clip_image001[6]

我们为了证书统一 配置,再nginx的目录下创建了一个ssl目录,专门存放证书文件

1
2
cd  /etc/nginx
Mkdir ssl

clip_image002[4]

然后我们将刚才的那三个文件拷贝到这个目录下

1
cp  /etc/pki/tls/server .key server.csr certnew.crt  /etc/nginx/ssl/

clip_image003[4]

clip_image004[4]

我们为了好记名,将申请的证书修改名字及扩展名

1
mv  certnew.cer web.pem

clip_image005[4]

在配置ssl之前,我们先访问以下,默认是80

clip_image006[4]

clip_image007[4]

接下来我们配置ssl,默认的配置文件

1
vim  /etc/nginx/conf .d /default .conf

clip_image008[4]

我们因为不使用80,所以default.conf用不到,mv default.conf default.conf.bak 重命名

我们在/etc/nginx/conf.d/下新建一个配置文件

1
2
3
4
5
6
7
8
9
10
11
12
vim nginx-ssl.conf
server {
listen 443;
server_name nginx.ixmsoft.com;
ssl on;
ssl_certificate  /etc/nginx/ssl/web .pem;
ssl_certificate_key  /etc/nginx/ssl/server .key;
access_log logs /ssl_access .log;
location / {
root  /usr/share/nginx/html ;
}
}

我们保证配置文件没有问题,可以使用以下命令测试

1
Nginx -t

clip_image009[4]

查看端口信息

clip_image010[4]

接下来我们尝试访问,443可以访问了,而且证书加载都是对的

clip_image011[4]

如果想访问80跳转到443,那么我们需要修改刚才的nginx_ssl.conf文件。

我们需要配置一下

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
server {
listen 80;
server_name nginx.ixmsoft.com;
rewrite ^(.*) https: // $server_name$1 permanent;
}
server {
listen 443;
server_name nginx.ixmsoft.com;
ssl on;
ssl_certificate  /etc/nginx/ssl/web .pem;
ssl_certificate_key  /etc/nginx/ssl/server .key;
access_log logs /ssl_access .log;
location / {
root  /usr/share/nginx/html ;
}
}

这样重启nginx后,使用80访问后会自动跳转到443端口的https下



本文转自 高文龙 51CTO博客,原文链接:http://blog.51cto.com/gaowenlong/1882407,如需转载请自行联系原作者

相关文章
|
2月前
|
自然语言处理 大数据 应用服务中间件
大数据-172 Elasticsearch 索引操作 与 IK 分词器 自定义停用词 Nginx 服务
大数据-172 Elasticsearch 索引操作 与 IK 分词器 自定义停用词 Nginx 服务
64 5
|
25天前
|
存储 负载均衡 Java
如何配置Windows主机MPIO多路径访问存储系统
Windows主机多路径(MPIO)是一种技术,用于在客户端计算机上配置多个路径到存储设备,以提高数据访问的可靠性和性能。本文以Windows2012 R2版本为例介绍如何在客户端主机和存储系统配置多路径访问。
69 13
如何配置Windows主机MPIO多路径访问存储系统
|
13天前
|
监控 安全 网络安全
Windows Server管理:配置与管理技巧
Windows Server管理:配置与管理技巧
44 3
|
15天前
|
负载均衡 前端开发 JavaScript
Nginx 代理多服务
以上是 Nginx 代理多服务的几种常见方式,在实际应用中,可以根据具体的业务需求和系统架构选择合适的代理方式,并结合其他 Nginx 的功能和配置来优化和完善系统的性能和功能。
|
27天前
|
关系型数据库 MySQL Linux
在 CentOS 7 中通过编译源码方式安装 MySQL 数据库的详细步骤,包括准备工作、下载源码、编译安装、配置 MySQL 服务、登录设置等。
本文介绍了在 CentOS 7 中通过编译源码方式安装 MySQL 数据库的详细步骤,包括准备工作、下载源码、编译安装、配置 MySQL 服务、登录设置等。同时,文章还对比了编译源码安装与使用 RPM 包安装的优缺点,帮助读者根据需求选择最合适的方法。通过具体案例,展示了编译源码安装的灵活性和定制性。
82 2
|
2月前
|
监控 安全 Linux
CentOS7下安装配置ntp服务的方法教程
通过以上步骤,您不仅能在CentOS 7系统中成功部署NTP服务,还能确保其配置合理、运行稳定,为系统时间的精确性提供保障。欲了解更多高级配置或遇到特定问题,提供了丰富的服务器管理和优化资源,可作为进一步学习和求助的平台。
71 1
|
2月前
|
缓存 负载均衡 应用服务中间件
Nginx 实现一个端口代理多个前后端服务
【10月更文挑战第19天】Nginx 的强大功能不仅限于此,它还可以与其他技术和工具相结合,为我们的应用提供更强大的支持和保障。在不断发展的互联网时代,掌握 Nginx 的使用技巧将为我们的工作和生活带来更多的便利和效益。
|
2月前
|
安全 Java 测试技术
ToB项目身份认证AD集成(二):快速搞定window server 2003部署AD域服务并支持ssl
本文详细介绍了如何搭建本地AD域控测试环境,包括安装AD域服务、测试LDAP接口及配置LDAPS的过程。通过运行自签名证书生成脚本和手动部署证书,实现安全的SSL连接,适用于ToB项目的身份认证集成。文中还提供了相关系列文章链接,便于读者深入了解AD和LDAP的基础知识。
|
2月前
|
弹性计算 关系型数据库 数据安全/隐私保护
阿里云国际版如何配置Windows服务器的虚拟内存
阿里云国际版如何配置Windows服务器的虚拟内存
|
数据采集 应用服务中间件 Linux
一篇文章教会你在Windows和Linux系统下搭建Nginx
一篇文章教会你在Windows和Linux系统下搭建Nginx
436 0
一篇文章教会你在Windows和Linux系统下搭建Nginx
下一篇
无影云桌面