Linux下部署java项目详细过程

在我们项目开发完毕并通过测试后会将它部署到企业服务器中,常见的是Linux服务器,下面为大家详细讲解一下Linux中部署java项目具体方法。

1、准备VMware

2、安装Linux系统(本人安装的是Fedora版本)

3、安装jdk

其实Fedora本身就自带的有OpenJDK。可以使用java -version查看版本信息。这里介绍去官网自己下载jdk的步骤。

  1. 在官网下载jdk 下载点击这里 32位的电脑就下载x86,如果是64位就下载x64。注意要下载Linux版本用箭头标注的两个。

  2. 使用 xshell 和 xftp 工具将文件传输到Linux虚拟机中,工具下载链接

  3. 参照Fedora的文档进行操作,将jdk替换为自己在网上下载的。 创建一个文件夹:

    sudo mkdir -p /usr/local/java
    

    将压缩包移动到该文件夹并进行解压:

    sudo cp -r jdk-8u40-linux-x64.tar.gz /usr/local/java
    sudo tar xvzf jdk-8u45-linux-x64.tar.gz
    

    配置环境变量:

    sudo nano /etc/profile
    // 在文件末尾添加
    JAVA_HOME=/usr/local/java/jdk1.8.0_45
    PATH=$PATH:$HOME/bin:$JAVA_HOME/bin
    export JAVA_HOME
    export PATH
    

    设置告诉系统新的Oracle Java版本可用:

    sudo update-alternatives --install“ / usr / bin / java”“ java”“ /usr/local/java/jdk1.8.0_45/bin/java”
    sudo update-alternatives --install“ / usr / bin / javac”“ javac”“ /usr/local/java/jdk1.8.0_45/bin/javac” 1
    sudo update-alternatives --install“ /usr/bin/javaws.itweb”“ javaws.itweb”“ /usr/local/java/jdk1.8.0_45/bin/javaws.itweb” 1
    

    将Oracle Java JDK设置为默认值:

    sudo update-alternatives --set java /usr/local/java/jdk1.8.0_45/bin/java
    sudo update-alternatives --set javac /usr/local/java/jdk1.8.0_45/bin/javac
    sudo update-alternatives --set javaws.itweb /usr/local/java/jdk1.8.0_45/bin/javaws.itweb
    

    重新加载配置文件:

    source /etc/profile
    

    重启系统:

    reboot
    

    查看java版本:

    java -version
    

4、安装tomcat

  1. 去官网下载tomcat 的Linux版本的压缩包
  2. 通过xshell 和 xftp工具传输到linux系统中
  3. 同样创建一个文件夹接受存放压缩包
  4. 解压压缩包,进入tomcat的bin目录下,启动./startup.sh可在主机上浏览器中输入ip+:8080看到tomcat的启动界面。

5、安装MySQL

我是直接用yum进行安装,不过最新下载下来的不是mysql而是和mysql差不多的数据库mariaDB。 yum install -y mysql-server mysql mysql-devel 可以自动安装好mysql 不过安装好之后我启动mysql之后出现了如下问题:

[root@localhost ~]# systemctl start mysql.service
Failed to start mysql.service: Unit mysql.service not found.

解决方法如下:

# yum install mariadb-server -y //如果已安装可以省略# systemctl start mariadb.service //启动服务# systemctl enable mariadb.service //开机启动服务# mysql -u root -p //登录mysql

为了安全,我们还要进行一次数据库加固:

[root@~ localhost]#mysql_secure_installation  #数据库安全加固

NOTE: RUNNING ALL PARTS OF THIS SCRIPT IS RECOMMENDED FOR ALL MariaDB
     SERVERS IN PRODUCTION USE!  PLEASE READ EACH STEP CAREFULLY!

In order to log into MariaDB to secure it, we'll need the current password for the root user.  If you've just installed MariaDB, and
you haven't set the root password yet, the password will be blank, so you should just press enter here. Enter current password for root (enter for none):   #默认密码为空,故只按回车键!密码为空不安全,需要首先设置 OK, successfully used password, moving on... Setting the root password ensures that nobody can log into the MariaDB root user without the proper authorisation. Set root password? [Y/n] Y    #是否设置root的登录密码:Y需要设置 New password: Re-enter new password: Password updated successfully!  #密码已设置成功 Reloading privilege tables.. ... Success! By default, a MariaDB installation has an anonymous user, allowing anyone to log into MariaDB without having to have a user account created for them.  This is intended only for testing, and to make the installation go a bit smoother.  You should remove them before moving into a production environment. Remove anonymous users? [Y/n] Y    #是否移除anonymous用户 ... Success! Normally, root should only be allowed to connect from 'localhost'.  This ensures that someone cannot guess at the root password from the network. Disallow root login remotely? [Y/n] Y    #是否不允许root的远程登录 ... Success! By default, MariaDB comes with a database named 'test' that anyone can access.  This is also intended only for testing, and should be removed before moving into a production environment. Remove test database and access to it? [Y/n] n  #是否移除test数据库,并禁止访问 ... skipping. Reloading the privilege tables will ensure that all changes made so far will take effect immediately. Reload privilege tables now? [Y/n] Y    #是否重载权限表 ... Success! Cleaning up... All done!  If you've completed all of the above steps, your MariaDB
installation should now be secure.

Thanks for using MariaDB!

完成之后,就可以启动MySQL服务进行登录,建库和建表操作。可以将本机中的sql脚本导出然后发送到虚拟机中使用 source+路径的方式进行导入 例如:source /etc/local/SQLfile/javaweb.sql 我这里还有另外一种方法,就是开启MariaDB的远程服务,让我们用本机的Navicat即可连接到虚拟机中的MariaDB服务。开启方法: 首先创建一个用户,并赋予他所有的权限:

GRANT ALL PRIVILEGES ON *.* TO 'root'@'%'IDENTIFIED BY '123456' WITH GRANT OPTION;

这里就是创建了一个root用户,他的密码是123456,享受各种权限,这个用来在本机的Navicat上进行登录。之后不要忘记刷新权限:

FLUSH PRIVILEGES;

之后就可以在Navicat上进行连接了:

6、java项目打包

这里还要区分一下,如果你是springboot项目,那么就可以直接打包成为jar包,放在虚拟机任意位置,使用java -jar ProjectName 即可运行。 方法一:打包jar包的方法:

  1. 首先修改pom文件这个地方,改为jar

  2. 调出右边的maven窗口,依次点击clean和 install

  3. 在项目中会出现一个target目录,在这个目录中就可以看到打包之后的文件。

方法二: 如果是普通的maven项目,需要打包成为war包,然后放在tomcat的webapps目录中。 打包war包的方法与打包jar类似,只有一个步骤不一样,那就是上边jar部分需要改成war。

遇到的问题

  1. xshell连接不上虚拟机

    解决:Fedora中没有开启ssh服务,使用命令

    # service sshd start
  2. Fedora不能切换到root用户

    解决: 这个是因为安装的时候没有默认生成root,这里需要我们初始化一个root,使用如下命令:

    # sudo su# passwd root
    // 之后输入两次密码即可,注意密码位数不能小于8位
    
  3. 设置ssh服务开机自启动

    由于虚拟机每次启动之后都要重新开启一下ssh服务,所以这里我们索性直接将它加入到开机启动项中,允许其开机自启。设置方法:

    设置开机自动启动
    # systemctl enable sshd
    关闭开机自动启动
    # systemctl disable sshd
    设置好之后重启电脑即可
    # reboot

文章来源网络,作者:运维,如若转载,请注明出处:https://shuyeidc.com/wp/219764.html<

(0)
运维的头像运维
上一篇2025-04-14 06:30
下一篇 2025-04-14 06:31

相关推荐

  • 个人主题怎么制作?

    制作个人主题是一个将个人风格、兴趣或专业领域转化为视觉化或结构化内容的过程,无论是用于个人博客、作品集、社交媒体账号还是品牌形象,核心都是围绕“个人特色”展开,以下从定位、内容规划、视觉设计、技术实现四个维度,详细拆解制作个人主题的完整流程,明确主题定位:找到个人特色的核心主题定位是所有工作的起点,需要先回答……

    2025-11-20
    0
  • 社群营销管理关键是什么?

    社群营销的核心在于通过建立有温度、有价值、有归属感的社群,实现用户留存、转化和品牌传播,其管理需贯穿“目标定位-内容运营-用户互动-数据驱动-风险控制”全流程,以下从五个维度展开详细说明:明确社群定位与目标社群管理的首要任务是精准定位,需明确社群的核心价值(如行业交流、产品使用指导、兴趣分享等)、目标用户画像……

    2025-11-20
    0
  • 香港公司网站备案需要什么材料?

    香港公司进行网站备案是一个涉及多部门协调、流程相对严谨的过程,尤其需兼顾中国内地与香港两地的监管要求,由于香港公司注册地与中国内地不同,其网站若主要服务内地用户或使用内地服务器,需根据服务器位置、网站内容性质等,选择对应的备案路径(如工信部ICP备案或公安备案),以下从备案主体资格、流程步骤、材料准备、注意事项……

    2025-11-20
    0
  • 如何企业上云推广

    企业上云已成为数字化转型的核心战略,但推广过程中需结合行业特性、企业痛点与市场需求,构建系统性、多维度的推广体系,以下从市场定位、策略设计、执行落地及效果优化四个维度,详细拆解企业上云推广的实践路径,精准定位:明确目标企业与核心价值企业上云并非“一刀切”的方案,需先锁定目标客户群体,提炼差异化价值主张,客户分层……

    2025-11-20
    0
  • PS设计搜索框的实用技巧有哪些?

    在PS中设计一个美观且功能性的搜索框需要结合创意构思、视觉设计和用户体验考量,以下从设计思路、制作步骤、细节优化及交互预览等方面详细说明,帮助打造符合需求的搜索框,设计前的规划明确使用场景:根据网站或APP的整体风格确定搜索框的调性,例如极简风适合细线条和纯色,科技感适合渐变和发光效果,电商类则可能需要突出搜索……

    2025-11-20
    0

发表回复

您的邮箱地址不会被公开。必填项已用 * 标注