1. 购买服务器、域名并备案
## 2. 搭建环境
安装步骤就不详细说了,请自行百度(简单);如果会docker,搭环境就更easy啦。(新手还是不介意用,老老实实敲下命令吧,对你以后有帮助的)
##
3. 项目部署
注意:如下命令必须进入到Tomcat的bin
目录才能执行。如果你配置好了环境变量就可以在任何路径下执行了。
java ./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。
## 项目的数据库文件导入问题
java url = "jdbc:mysql://localhost:3306/数据库名"; 或 url = "jdbc:mysql://127.0.0.1:3306/数据库名"; 或 url = "jdbc:mysql://服务器IP地址:3306/数据库名";
因为项目上传至服务器后,说明 localhost
或127.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
## Nginx反向代理通过域名访问项目
java IP:8080IP:8081IP:8082或域名;8080域名:8081域名:8082
proxy_pass
代理的就是Tomcat服务器下的项目,Tomcat默认的端口号是
8080
,我这里改为了
8010
java server { #监听的端口号 listen 80; #一级域名或二级域名 server_name sh.yunxdr.top; #默认文档 index index.jsp index.html index.htm; location / { proxy_pass http://127.0.0.1:8010/项目名/; } }
注意:
http://localhost:8010/Tomcat解析的项目名或http://127.0.0.1:8010/Tomcat解析的项目名
为了以后一个Tomcat部署一个项目,可以在Linux服务器上复制多个Tomcat,然后通过修改Tomcat默认端口号来达到不同的项目名都可以使用二级域名来访问了。
但也可以在一个Tomcat下部署多个项目,此时每次部署新的项目时,以前的项目都会随着Tomcat的启动或关闭又要被执行一次,非常耗服务的内存和CPU,会让服务器变的更卡了。我之前部署项目就是采用了这个方法。
有的时候部署后,也出现访问不了项目,这是可能是nginx没有识别到默认文件,在代理的项目名后面加上项目的默认访问路径,如:
java proxy_pass http://127.0.0.1:8010/项目名/index.jsp;
java ./nginx -s reload
关注知了堂Java培训,分享更多Java web相关技能。