• JavaWeb项目部署到Linux服务器


    • 写这篇文章的目的就是为了方便以后遇到部署项目时不必要花更多的时间做些麻烦的事了。
    • 虽说当初第一次搭建的时候确实是花了不少时间和精力,但有时用到的又不算多。看起来简单,但实际操作中依然会漏掉,导致部署失败。所以才有了这次写作!

    1. 购买服务器、域名并备案

    • 阿里云、腾讯云、华为云啥的都可以选择,也不算贵。一般至少购买三个月才能备案。
    • 现在的备案都简化了好多,直接下载APP扫描就能成功备案了,之前我备案的时候差不多花了一个多月了,过程中也出现了些错误,当初还是邮寄幕布拍照上传照片的。

    2. 搭建环境

    3. 项目部署

    • 把要上传的java web项目打包成war包上传到Tomcat目录的webapps下,在还没启动Tomcat之前上传了项目的war包时,是不会被解压成文件夹的。只要Tomcat的webapp下的项目有所变动(增加或删除),都要重新启动Tomcat。

    注意:如下命令必须进入到Tomcat的bin目录才能执行。如果你配置好了环境变量就可以在任何路径下执行了。

    ./startup.sh		// 启动Tomcat
    ./shutdown.sh		// 关闭Tomcat
    
    • 上传到 webapp下的 war包会被解析成一个与项目名同名的文件夹,打开里面就是个类似于项目的分层结构,如果你的项目war包上传至webapp没有被解压成与项目名同名的文件夹,那就是你没有重新启动Tomcat,先执行上面关闭命令再执行启动命令。
    • 进入解压后的项目,可以发现,jsp文件都能在项目的根目录下看到到,javabean之类的java文件和lib目录、web.xml或其他配置文件 存在于根目录下的WEB-INF文件夹下,因为java代码会被编译成class文件存放于classes文件夹下。
    • 这里特别注意的一点是,如果java web项目是需要连接Linux服务器上的数据库的,注意把上传项目提前改成Linux服务器上的mysql数据库的用户名和密码再打包成war包。或直接在Linux下的Tomcat编译好的项目下进入项目路径更改,完成后保存文件,再关闭Tomcat接着启动Tomcat。

    项目的数据库文件导入问题

    • Linux下的项目数据库的访问地址依然不变,如:
    url = "jdbc:mysql://localhost:3306/数据库名"; 
    或
    url = "jdbc:mysql://127.0.0.1:3306/数据库名"; 
    或 
    url = "jdbc:mysql://服务器IP地址:3306/数据库名"; 
    
    • 因为项目上传至服务器后,说明 localhost127.0.0.1也是表示服务器本地路径,当然这里也可以选择用服务的公网IP,但一般不建议使用,因为此时的localhost或127.0.0.1就是表示此时服务器IP。

    • 本地Windows下的 Navicat 、SQLyog 或其他数据库可视化工具连接Linux服务器上的msyql,方便于直接导入项目上的数据库文件,可以访问我之前写过的文章来实现,这也是为了方便管理服务器上的mysql数据库。
      Navicat连接Linux服务器的mysql出现连接不上的问题

    • 本地mysql数据库导入Linux服务器上的mysql数据库

    • 首先,先把Windows下的数据库文件导出来并上传到服务器上,然后再创建好和本地Windows下同名的服务器上的数据库文件

    create database 数据库名
    
    • 切换到创建好的数据库中
    use 数据库名
    
    • 导入数据
    source 上传的数据库文件路径.sql
    
    • 如果不想这么麻烦,也可以直接用Navicat链接好服务器上的mysql,直接在Navicat上导入即可。

    Nginx反向代理通过域名访问项目

    • 解析好项目要用的域名,一般是用二级域名作为访问。
    • 其实可以直接用服务器上的IP地址来访问项目的,不必麻烦使用域名来访问了。但这种形式不光还要记住域名且还要端口号,部署项目一多,确实有些麻烦,如:
    IP:8080
    IP:8081
    IP:8082
    或
    域名;8080
    域名:8081
    域名:8082
    
    • 通过反向代理就不需要每次访问项目还要加上端口号了。
    • 打开 Nginx 的根路径,切换到 conf/下,打开 nginx.conf 文件,在http模块下增加一个server模块
    • 这里proxy_pass代理的就是Tomcat服务器下的项目,Tomcat默认的端口号是8080,我这里改为了8010
    server {
    		#监听的端口号
    		listen 80;
    		#一级域名或二级域名
    		server_name	sh.yunxdr.top;
    		#默认文档
    		index index.jsp index.html index.htm;
    		location / {
    			proxy_pass http://127.0.0.1:8010/项目名/;
    		}
    	}
    

    注意:

    • 这里特别注意 的是proxy_pass的IP地址,127.0.0.1localhost 表示的此时服务器的IP,切记不可使用服务器的公网IP,因为通过了域名解析后,使用IP来作为代理来通过二级域名是访问不了的
    • proxy_pass 这里可以使用。
    http://localhost:8010/Tomcat解析的项目名
    或
    http://127.0.0.1:8010/Tomcat解析的项目名
    
    • 为了以后一个Tomcat部署一个项目,可以在Linux服务器上复制多个Tomcat,然后通过修改Tomcat默认端口号来达到不同的项目名都可以使用二级域名来访问了。
    • 但也可以在一个Tomcat下部署多个项目,此时每次部署新的项目时,以前的项目都会随着Tomcat的启动或关闭又要被执行一次,非常耗服务的内存和CPU,会让服务器变的更卡了。我之前部署项目就是采用了这个方法。
    • 有的时候部署后,也出现访问不了项目,这是可能是nginx没有识别到默认文件,在代理的项目名后面加上项目的默认访问路径,如:
    proxy_pass http://127.0.0.1:8010/项目名/index.jsp;
    
    • 完成Nginx配置后,保存并退出,执行重载命令,使刚才的配置的文件生效。
    ./nginx -s reload
    
  • 相关阅读:
    DVWA的安装及报错解决
    隐写工具F5-steganography的使用
    python skimage库的安装
    密码学笔记——zip明文攻击
    密码学笔记-一段base64wp
    kali中网卡、ssh、apache的配置与开启
    密码学笔记——希尔密码
    密码学笔记——playfair密码
    使用electron-packager electron-builder electron-updater 打包vue项目,支持在线更新
    搭建vue脚手架,包含Axios、qs、Element-UI、mock等插件的安装配置
  • 原文地址:https://www.cnblogs.com/xdr630/p/14208737.html
Copyright © 2020-2023  润新知