centos7nginx使用acme.sh免费获取ssl证书笔记

  1. 安装nginx(注意需要安装ssl模块)
    安装gcc
    #查看gcc版本
    gcc -V
    #安装gcc
    yum -y install gcc

    安装pcre pcre-devel

    yum install -y pcre pcre-devel

    安装zlib

    yum install -y zlib zlib-devel

    安装openssl

    yum install -y openssl openssl-devel

    下载最新稳定版nginx-1.20.1并安装

    wget http://nginx.org/download/nginx-1.20.1.tar.gz
    
    tar -zxvf nginx-1.20.1.tar.gz
    
    cd nginx-1.20.1
    
    #配置添加ssl模块
    ./configure --prefix=/usr/local/nginx --with-http_ssl_module
    
    make
    
    make install
    
    #查看nginx所含模块
    /usr/local/nginx/sbin/nginx -V
    
    #加入nginx环境变量方便使用
    vi /etc/profile
    
    PATH=$PATH:/usr/local/nginx/sbin
    export PATH
    
    source /etc/profile

  2. 安装acme.sh
    #回到root根目录
    cd
    
    curl  https://get.acme.sh | sh
    

    设置acme.sh别名方便使用

    alias acme.sh=~/.acme.sh/acme.sh
    echo 'alias acme.sh=~/.acme.sh/acme.sh' >>/etc/profile
    source /etc/profile

    更改acme.sh获取zeroSSL证书
    参考https://www.ffis.me/archives/2110.html
    注意:如果域名没有使用DNSPod动态解析的,用下述命令配置默认证书获取来源

    acme.sh --set-default-ca  --server zerossl

    注意:如果域名没有使用DNSPod动态解析的,用下述命令申请证书

    acme.sh --issue  -d xxx.com  --nginx /usr/local/nginx/conf/nginx.conf

    请先把nginx的server_name  xxxx.com 配置为在用域名,并启动nginx。
    安装证书

    acme.sh --install-cert -d xxx.com \
    --key-file       /usr/local/nginx/conf/ssl/xxx.com.key \
    --fullchain-file /usr/local/nginx/conf/ssl/xxx.com.crt \
    --reloadcmd     "systemctl force-reload nginx.service"

    配置nginx ssl证书
     

    server {
            listen 443 ssl;
            server_name xxx.com;
    
            root html;
            index index.html index.htm;
            ssl_certificate   /usr/local/nginx/conf/ssl/xxx.com.cer;
            ssl_certificate_key  /usr/local/nginx/conf/ssl//xxx.com.key;
            ssl_session_timeout 5m;
            ssl_ciphers ECDHE-RSA-AES128-GCM-SHA256:ECDHE:ECDH:AES:HIGH:!NULL:!aNULL:!MD5:!ADH:!RC4;
            ssl_protocols TLSv1 TLSv1.1 TLSv1.2;
            ssl_prefer_server_ciphers on;
            location / {
                root html;
                index index.html index.htm;
            }
        }

     

 

 

 

 

 

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要在CentOS 7服务器上安装和部署Nginx SSL证书,可以按照以下步骤进行操作: 1. 连接到远程服务器: ``` ssh username@192.168.1.24 ``` 将`username`替换为你的用户名,`192.168.1.24`替换为你的服务器IP地址。 2. 安装Nginx: 如果你的服务器上尚未安装Nginx,请使用以下命令进行安装: ``` sudo yum install nginx ``` 3. 准备SSL证书: 将SSL证书文件和私钥文件上传到服务器。确保证书文件和私钥文件是匹配的,并且命名符合约定(例如`cert.pem`和`key.pem`)。 4. 配置Nginx: 打开Nginx的配置文件(通常是在`/etc/nginx/nginx.conf`或`/etc/nginx/conf.d/default.conf`中),并进行以下配置更改: - 在`http`块中,添加一个新的`server`块来定义HTTPS服务器: ``` server { listen 443 ssl; server_name your-domain.com; ssl_certificate /path/to/cert.pem; ssl_certificate_key /path/to/key.pem; ... } ``` 将`your-domain.com`替换为你的域名,将`/path/to/cert.pem`和`/path/to/key.pem`替换为SSL证书文件和私钥文件的路径。 - 如果你的应用程序使用了其他Nginx配置(如代理等),请在此`server`块中进行相应的配置更改。 5. 检查配置文件: 运行以下命令检查Nginx配置文件是否正确: ``` sudo nginx -t ``` 6. 启用防火墙规则(如果需要): 如果服务器启用了防火墙(如firewalld或iptables),请确保允许通过HTTPS访问。例如,使用以下命令启用HTTP和HTTPS规则: ``` sudo firewall-cmd --zone=public --add-service=http --permanent sudo firewall-cmd --zone=public --add-service=https --permanent sudo firewall-cmd --reload ``` 7. 启动Nginx服务: 使用以下命令启动Nginx服务: ``` sudo systemctl start nginx ``` 现在,你的Nginx服务器应该已经配置了SSL证书,并且可以通过HTTPS访问。确保你的域名已经指向了服务器的IP地址,并测试访问以验证证书是否正确安装和部署。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值