Nginx部署Springboot项目&&配置Https访问

目录

前言

一、https证书下载并配置

二、SpringBoot项目配置

三、Nginx配置文件

前言

本文是基于Docker安装的Nginx,并且假设已经配置好证书的Nginx进行项目部署,证书配置参考

Docker搭建Nginx并配置ssl证书_熟透的蜗牛的博客-CSDN博客

一、https证书下载并配置

1、项目基于Springboot内置Tomcat,启动,下载Tomcat证书

2、解压之后放入项目中的根目录中

 3、修改application.yml配置文件

server:
  port: 9100
  ssl:
    key-store: classpath:123_www.example.pfx #证书的路径
    key-store-password: 666666 #密码

4、如果最后访问时候报错,可以尝试把该证书上传到服务器和jar包同一目录下。

二、SpringBoot项目配置

1、tomcat 配置类


import org.apache.catalina.Context;
import org.apache.catalina.connector.Connector;
import org.apache.tomcat.util.descriptor.web.SecurityCollection;
import org.apache.tomcat.util.descriptor.web.SecurityConstraint;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.boot.web.embedded.tomcat.TomcatServletWebServerFactory;
import org.springframework.boot.web.servlet.server.ServletWebServerFactory;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;

/**
 * @author xiaojie
 * @version 1.0
 * @description: tomcat配置http转htttps
 * @date 2022/5/7 8:52
 */
@Configuration
public class TomcatConfig {
    @Value("${my.httpServer.port}")
    private Integer httpServerPort; //http的端口
    @Value("${server.port}")
    private Integer serverPort;//https的端口,也是配置文件中配置的端口

    @Bean
    public ServletWebServerFactory servletContainer() {
        TomcatServletWebServerFactory tomcat = new TomcatServletWebServerFactory() {
            @Override
            protected void postProcessContext(Context context) {
                SecurityConstraint securityConstraint = new SecurityConstraint();
                securityConstraint.setUserConstraint("CONFIDENTIAL");
                SecurityCollection collection = new SecurityCollection();
                collection.addPattern("/*");
                securityConstraint.addCollection(collection);
                context.addConstraint(securityConstraint);
            }
        };
        tomcat.addAdditionalTomcatConnectors(redirectConnector());
        return tomcat;
    }

    private Connector redirectConnector() {
        Connector connector = new Connector("org.apache.coyote.http11.Http11NioProtocol");
        connector.setScheme("http");
        connector.setPort(httpServerPort);
        connector.setSecure(false);
        connector.setRedirectPort(serverPort);
        return connector;
    }
}

 配置文件

my:
  httpServer:
    port: 8100

2、然后将文件打包,并命名为xxx_9100.jar,上传到服务器。

将上面的端口8100修改为8101,9100端口不修改,在启动参数中修改,打包后上传到服务器。

打俩个jar包是为了做主备,也可以只打一个jar。

三、Nginx配置文件

1、myapp.conf

upstream myapp{
 server ip:9100; #此处的ip写服务器的真实ip,因为是docker构建的,不然可能访问不到
 server ip:9101 backup; #备机
}
server {
    listen 443 ssl;  
	server_name www.example.com; 
	ssl_certificate certs/1_www.example.com.pem;  
	ssl_certificate_key certs/1_www.example.com.key; 
	
	ssl_session_timeout 5m;
	ssl_protocols TLSv1.1 TLSv1.2 TLSv1.3;
	ssl_prefer_server_ciphers on;
	ssl_ciphers ECDHE-RSA-AES128-GCM-SHA256:ECDHE:ECDH:AES:HIGH:!NULL:!aNULL:!MD5:!ADH:!RC4;
	
	ssl_session_cache shared:SSL:1m;

	fastcgi_param  HTTPS        on;
	fastcgi_param  HTTP_SCHEME     https;
	
    location / {
		proxy_set_header Host $host;
		proxy_set_header X-Real-IP $remote_addr;
		proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
		proxy_connect_timeout   10s;
		proxy_send_timeout      60s;
		proxy_read_timeout      60s;
        proxy_ignore_client_abort   on;
		proxy_pass https://myapp/; #此处与上面的upstream处对应
    }
	
    error_page   500 502 503 504  /50x.html;
    location = /50x.html {
        root   html;
    }
}

2、启动项目

nohup java -jar -Dserver.port=9100 abc_9100.jar >log_9100.log &
nohup java -jar -Dserver.port=9101 abc_9101.jar >log_9101.log &

说明:9100和9101端口是nginx映射的端口,也是项目application.yml中配置项目的端口

3、启动项目

  • 2
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论
### 回答1: 要部署Spring Boot项目Nginx服务器上,需要执行以下步骤: 1. 在Spring Boot项目中打包成jar文件。 2. 在服务器上安装Nginx。 3. 在Nginx配置文件中配置反向代理,将请求转发到Spring Boot项目的运行端口。 4. 启动Spring Boot项目并启动Nginx服务。 5. 通过浏览器访问Nginx服务器的IP地址或域名,即可访问部署Spring Boot项目。 ### 回答2: Nginx是一款高性能的Web服务器软件,它不仅可以部署静态网页,也可以作为反向代理服务器。在部署Spring Boot项目时,我们可以将Nginx作为反向代理服务器,将客户端的请求转发到Spring Boot应用程序中,以便更好地管理和优化应用程序的性能。 具体步骤如下: 1.安装Nginx 在Linux系统上,可以使用包管理工具来安装Nginx,例如CentOS系统上可以使用yum命令进行安装: yum install nginx 2.配置Nginx 需要编辑Nginx配置文件,以便将请求转发到Spring Boot应用上。可以在Nginx配置文件中添加如下配置: location / { proxy_pass http://localhost:8080; proxy_set_header Host $host; proxy_set_header X-Real-IP $remote_addr; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; } 上述配置中,“proxy_pass”指定了转发请求的目标IP和端口,“proxy_set_header”指定了转发请求时需要保留的头信息。 3.启动NginxSpring Boot应用 完成Nginx配置后,可以启动Nginx服务器和Spring Boot应用程序,以便测试应用是否正常运行。可以使用如下命令分别启动NginxSpring Boot应用: systemctl start nginx java -jar demo.jar 这里假设应用程序的Jar包为“demo.jar”,可以根据自己的实际情况进行修改。 4.测试应用 最后,可以使用浏览器或命令行工具进行访问测试,以确认应用程序是否正常工作。在浏览器中输入Nginx服务器的地址和端口号,查看是否能够正常访问应用程序的页面。 总的来说,将Nginx作为反向代理服务器部署Spring Boot应用程序,可以提高应用程序的性能和可管理性。但需要注意的是,在配置Nginx时需要注意路径和端口号等相关配置,以确保不会产生冲突。 ### 回答3: Nginx是一个高性能的Web服务器和反向代理服务器,而Spring Boot是一个基于Spring框架的快速开发的Web应用程序框架。在将Spring Boot项目部署到生产环境中时,将Nginx作为其反向代理服务器,可以提高应用程序的可靠性、性能和安全性。 下面是在Linux操作系统上部署Spring Boot项目的步骤: 1.安装Java环境和Spring Boot应用程序,确保其能够在本地成功运行。 2.安装Nginx,通过命令“sudo apt-get install nginx”在Linux上进行安装。 3.在Nginx的默认配置文件“/etc/nginx/sites-available/default”中添加反向代理的配置信息。以下是一个针对Spring Boot应用程序的基本配置: server { listen 80; server_name example.com; location / { proxy_pass http://127.0.0.1:8080; proxy_set_header X-Real-IP $remote_addr; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; proxy_set_header Host $http_host; proxy_set_header X-Nginx-Proxy true; proxy_redirect off; } } 其中,“proxy_pass”指定Spring Boot应用程序的URL,“proxy_set_header”在请求转发时添加必要的HTTP header信息。 4.启动Nginx服务器。运行命令“sudo nginx -t”来检查配置文件中是否存在任何语法错误,然后运行命令“sudo service nginx start”来启动服务器。 5.访问Spring Boot应用程序,可以通过域名或IP地址访问。例如,“http://example.com”或“http://127.0.0.1:8080”。 总体来说,使用Nginx反向代理服务器可以帮助我们更好地管理和保护Spring Boot应用程序,并在性能和安全性方面提供更好的保障。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

熟透的蜗牛

永远满怀热爱,永远热泪盈眶

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值