Windows用Tomcat发布Java项目

举报
Damon小智 发表于 2024/06/30 23:32:35 2024/06/30
【摘要】 对于云服务器,程序员一般不会陌生,如果项目需要发布到现网,那么服务器是必不可缺的一项硬性条件,那么如何在云服务器上部署一个项目,需要做哪些配置准备,下面就由本文档为大家讲解,本篇以Tomcat服务器发布J2EE项目为例。


1、本地准备

准备一个可运行的Javaweb项目,mysql连接正常,在eclipse中将项目打成war文件。

2sql备份

我用的Navicat,推荐下面这个免安装的版本:
链接:https://pan.baidu.com/s/1y9flZHD9AgGfhz1pebPNyg
提取码:kkaf

备份成功,后面只要把这个SQL文件导入数据库就可以了

服务器准备

3、准备服务器

购买好了进入控制台,找到刚刚购买的服务器,点击登录

下载RDP文件

双击进入,会要求输入用户名密码,忘了回控制台重置

进入后图,服务器就相当于放在云服务商的一部电脑,但是这台电脑具有内网和外()网两个ip,我们正常在本地发布应用,外网是访问不到的。在云服务器上本地发布,就相当于直接发布在外网,所有终端都可以访问。

4、云服务器上安装JDKMySQLtomcat

安装JDK,进https://www.oracle.com/technetwork/java/javase/downloads/jdk8-downloads-2133151.html下载exe,双击安装。

1)新建环境变量JAVA_HOME

变量名:JAVA_HOME
变量值:C:\Program Files\Java\jdk1.8.0_221

2)配置path

变量名:path
变量值最前面加上%JAVA_HOME%\bin;%JAVA_HOME%\jre\bin;
(如果原先的值没有用;结尾,要补一个;把值隔开)

3)新增CLASSPATH变量

变量名:CLASSPATH
变量值:.;%JAVA_HOME%\lib\dt.jar;%JAVA_HOME%\lib\tools.jar

4)执行java -version如果出现如下图界面则证明安装成功

Windows上安装MySQL

点击链接https://dev.mysql.com/downloads/mysql/下载 zip 包。

直接解压到想要安装的目录

创建my.ini文件,内容写为:

[mysqld]

port=3306

#basedir是安装路径,datadir是安装路径\Data

basedir=C:\mysql-8.0.17-winx64

datadir=C:\mysql-8.0.17-winx64\Data

max_connections=200

max_connect_errors=10

character-set-server=utf8mb4

default-storage-engine=MyISAM

default_authentication_plugin=mysql_native_password

[mysql]

default-character-set=utf8mb4

[client]

port=3306

default-character-set=utf8mb4

配置环境变量

变量名:MYSQL_HOME
变量值:C:\mysql-8.0.17-winx64

以管理员身份打开 cmd 命令行工具,切换目录:
cd C:\web\mysql-8.0.11\bin

初始化数据库:
mysqld –initialize –console

执行完成后,会输出 root 用户的初始默认密码,如:
2019-09-20T02:35:05.464644Z 5 [Note] [MY-010454] [Server] A temporary password is generated for root@localhost: APWCY5ws&hjQ
APWCY5ws&hjQ 就是初始密码,可以在登陆后修改密码)

输入以下安装命令:
mysqld install

启动输入以下命令即可:
net start mysql

正常情况:

异常情况:

查看服务有没有开启,如果MySQL服务正常,这种情况不影响使用

登录MySQL mysql -u root -p

设置(或修改)root用户密码:
mysql> update mysql.user set authentication_string=password(“****”) where user = “root”;  
(此处引号中的内容是密码,自己可以随便设置,为了后边方便不用修改war包中的连接配置,建议和本地MySQL设置一样的密码)

保存修改后的密码:
mysql> flush privileges;  #作用:相当于保存,执行此命令后,设置才生效,若不执行,还是之前的密码不变

5、安装tomcat,并发布J2EE项目

注册tomcat,要用到tomcatservice.bat,如果你的tomcat没有这个,就重新下载一个有service.battomcat

点击Archives

选择需要的版本,我用的是v8.5.45,选好了点击去之后再点击bin/

选择这个下载

下载完解压到想要存放的安装目录

我的tomcat的路径是:C:\Program Files\apache-tomcat-8.5.45所以下列的变量值就是我的tomcat路径:

1)新建变量名:CATALINA_BASE
变量值:C:\Program Files\apache-tomcat-8.5.45

2)新建变量名:CATALINA_HOME
变量值:C:\Program Files\apache-tomcat-8.5.45

3 编辑变量名: Path
添加变量值:;%CATALINA_HOME%\lib;%CATALINA_HOME%\bin;
(分号是把path的各个变量分开)

修改conf文件夹里的server.xml文件,如图,port是端口,一般是8080,我自己设得是70,添加URIEncoding=”UTF-8″,防止中文乱码。

管理员身份打开cmd, cdtomcatbin目录,输service install安装服务。

(这张图借的,版本号和我的不一样,只做示意)

在服务里可以看到有tomcat8

后面启动直接startup,只要tomcat这个窗口不关,外网就可以直接访问部署在里面的项目。

浏览器网址输入localhost:70/ 配置成功会跳到此页面。

把备份的sql数据存到云服务器的MySQL里面

我在云端也有一个Navicat

数据已经在数据库里了

war包放在tomcat安装目录的webapps

启动tomcatcmdstartup),访问 localhost:70/CRM

6、防火墙开放70端口

7、开放安全组

控制台安全组开放70端口

8、访问公网IP

这时再用本地的浏览器已经可以访问云服务器上的项目了

9、运行成功项目之前遇到的问题

连接MySQL的时候报错The server time zone value ‘Öйú±ê׼ʱ¼ä’ is unrec

500报错:java.sql.SQLException: The server time zone value ‘Öйú±ê׼ʱ¼ä’ is unrecognized or represents more than one time zone. You must configure either the server or JDBC driver (via the serverTimezone configuration property) to use a more specifc time zone value if you want to utilize time zone support.

解决方法:在语句”jdbc:mysql://localhost:3366/db_crm “后添加”?serverTimezone=GMT%2B8″:

关于Unknown character set index for field ‘255’ received from server

原因是MySQL版本高,mysqljar版本低造成mysqljar的编码错乱引起的

链接:https://pan.baidu.com/s/18rxjcc9bfuCO8NOSVh0EVQ
提取码:2c3x

mysql-connector-java-8.0.11.jar这个jar包复制到项目文件夹下WebContent\WEB-INF\lib里。

替换过后可能会出现 [在工程和使用过原来包的java文件上会出现红叉],将有红叉的java文件找到,将有红×的那一行删掉,再重新导那个包就可以了。

运行过程中,jQuery前端框架自带easyui-lang-zh_CN.js里的中文乱码了

因为在服务器之前本地运行是正常的,所以排除项目本身的问题,云服务商为了用户的傻瓜式操作,不会让我们去为了基础功能手动改配置的,所以也不可能有问题。最后排除到版本不同的tomcat上。

步骤一:

tomcat目录下的conf文件夹下,打开server.xml文件 ;
Connector 中添加 URIEncoding=”UTF-8″;

步骤二:

tomcat目录下的bin文件夹下,打开catalina.bat文件

setlocal下增加一行:

set JAVA_OPTS=-Dfile.encoding=UTF8

步骤三:

打开注册表,找到HKEY_CURRENT_USERConsoleTomcat,找到CodePage项,没有则创建,更改值为十进制的65001,点击确定。

或直接复制下面代码,保存为.bat文件,直接运行。

set rr="HKCU\Console\Tomcat"

reg add %rr% /v "CodePage" /t REG_DWORD /d 0x0000fde9 /f>nul \

重新启动tomcat后,完美解决。


【版权声明】本文为华为云社区用户原创内容,转载时必须标注文章的来源(华为云社区)、文章链接、文章作者等基本信息, 否则作者和本社区有权追究责任。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。