【Linux】部署单机项目(自动化启动)---(图文并茂详细讲解)

news2024/12/23 8:08:19

目录

一 准备工作

1.1 连接服务器拷贝文件

1.2  解压

二 JDK安装

2.1 配置坏境变量

2.2 查看版本

三 Tomcat(自启动)

3.1 复制启动命令的位置

3.2 添加命令相关配置文件

3.2.1 配置jdk及tomcat目录

3.2.2 添加优先级     

3.3 设置自启动命令

3.4 开放端口

四 MySQL(自启动)

4.1 卸载mariadb

4.2在线下载MySQL安装包

4.3 MySQL安装包解压到指定目录

4.4 安装四个rpm

4.5 启动MySQL服务

4.6 登录mysql修改密码

4.7 授权

4.8 刷新

4.9 连接msyql

10 导入SQL脚本

五 部署项目


一 准备工作

1.1 连接服务器拷贝文件

该部署项目准备,jdk,tomcat,mysql,nginx。主机的MobaXterm工具连接我们的服务器再进行一个拖拉拷贝所需要的文件到服务器

1.2  解压

防止后面单个系列解压操作,我这边就直接将所有的要用的全部给解压,如下图
注:具体的tar -zxvf 后面解压包名根据自己的解压包名来。mysql解压包可以单独准备一个文件夹进行解压

tar -zxvf jdk-8u151-linux-x64.tar.gz    //jdk解压命令


tar -zxvf apache-tomcat-8.5.20.tar.gz   //tomcat解压命令



tar -xvf mysql-5.7.35-1.el7.x86_64.rpm-bundle.tar   //解压mysql命令

二 JDK安装

2.1 配置坏境变量

输入命令vi /etc/profile,添加jdk的坏境变量,添加如下的代码

#java environment
export JAVA_HOME=/javaxl/jdk1.8.0_151(jdk解压路径)
export JRE_HOME=${JAVA_HOME}/jre
export CLASSPATH=.:${JAVA_HOME}/lib:${JRE_HOME}/lib
export PATH=${JAVA_HOME}/bin:$PATH

注意:JAVA_HOME后的变量值是jdk安装目录,要根据自己jdk目录来,其它不变

2.2 查看版本

命令:java -version

三 Tomcat(自启动)

3.1 复制启动命令的位置

为了我们的tomcat每次重新启动项目都需要重新启动tomcat及mysql这样的操作繁琐,所以我们要学习如何给tomcat及mysql进行自启动这样每次Linux启动它们就jdk,mysql就紫气东来非常方便,下面小编带大家学习

进入tomcat安装目录下的bin根目录下,复制catalian.sh命令到/etc/init.d文件中,并且进入该init.d文件下修改该命令名称为tomcat。具体命令如下

cp catalina.sh /etc/init.d    //复制catalina.sh到/etc/init.d文件下
cd /etc/init.d   //进入init.d文件下
mv catalina.sh tomcat   //将catalina.sh名称改成tomcat名称

3.2 添加命令相关配置文件

3.2.1 配置jdk及tomcat目录

JAVA_HOME=/opt/Java/jdk1.8.0_151       <------------------jdk安装目录

CATALINA_HOME=/opt/Java/apache-tomcat-8.5.20     <----------tomcat安装目录

3.2.2 添加优先级     

#chkconfig: 23456 10 90

#description: tomcat service

3.3 设置自启动命令

chkconfig --add tomcat 

3.4 开放端口

开放8080端口就能让主机连接我们Linux中的tomcat,后续我们还要连接mysql这里我就也一起开放了3306的端口

#开放端口
firewall-cmd --zone=public --add-port=3306/tcp --permanent

如要设置8080端口把3306改成8080即可

---------------------------------------------------------------------------------------
#跟新防火墙规则
firewall-cmd --reload

---------------------------------------------------------------------------------------
#防火墙列表
firewall-cmd --zone=public --list-ports

---------------------------------------------------------------------------------------
#防火墙状态
systemctl status firewalld

---------------------------------------------------------------------------------------
#启动防火墙
systemctl start firewalld

---------------------------------------------------------------------------------------
#关闭防火墙
systemctl stop firewalld.service
systemctl disable firewalld.service 

四 MySQL(自启动)

4.1 卸载mariadb

#1.卸载mariadb,否则安装MySql会出现冲突(先查看后删除再查看)
[root@192 ~]#  rpm  -qa|grep mariadb    (查看mariadb)

mariadb-libs-5.5.56-2.el7.x86_64

----------------------------------------------------------------------------------
[root@192 ~]# rpm -e --nodeps mariadb-libs-5.5.56-2.el7.x86_64   (删除mariadb)

注:(nodeps后的根据自己查询的mariadb的来)

----------------------------------------------------------------------------------
[root@192 ~]# rpm -qa|grep mariadb

 在下面命令中,大概都是需要去执行的

但是第4.2二点自己已经拷贝了mysql安装包就不需要了

第4.3点根据自己的想要解压mysql的位置进行解压吧,然后下面其他红色命令都是要执行的

4.2在线下载MySQL安装包

(也可提前下载好上传)   前面我们自己上传了就不需要在线下载了
wget https://downloads.mysql.com/archives/get/p/23/file/mysql-5.7.35-1.el7.x86_64.rpm-bundle.tar

---------------------------------------------------------------------------------------------------------------

4.3 MySQL安装包解压到指定目录

mkdir mysql-5.7
tar -xvf mysql-5.7.35-1.el7.x86_64.rpm-bundle.tar -C mysql-5.7

---------------------------------------------------------------------------------------------------------------

4.4 安装四个rpm

开始安装,-ivh 其中i表示安装,v表示显示安装过程,h表示显示进度
cd mysql-5.7
rpm -ivh mysql-community-common-5.7.35-1.el7.x86_64.rpm
rpm -ivh mysql-community-libs-5.7.35-1.el7.x86_64.rpm
rpm -ivh mysql-community-client-5.7.35-1.el7.x86_64.rpm
rpm -ivh mysql-community-server-5.7.35-1.el7.x86_64.rpm

如果第四条下载失败使用下面的命令,再进行重新下载即可
sudo yum install -y perl

---------------------------------------------------------------------------------------------------------------

4.5 启动MySQL服务

systemctl start mysqld

systemctl enable mysqld.service  (自启动命令)

---------------------------------------------------------------------------------------------------------------

4.6 登录mysql修改密码

[root@192 mysql-5.7]# grep "password" /var/log/mysqld.log
2022-10-12T13:19:16.313408Z 1 [Note] A temporary password is generated for root@localhost: o8N#/CfWD+sh   <-----红色部分是初始密码
[root@192 mysql-5.7]# mysql -uroot -p


Enter password:o8N#/CfWD+sh   <-----填写初始密码,填的时候看不见
Welcome to the MySQL monitor.  Commands end with ; or \g.

#设置密码校验策略(0 or LOW),要不密码太LOW不让你过
set global validate_password_policy=0;
#设置密码校验长度,要不密码太短不让你过(多次测试发现密码最小长度为4位)
set global validate_password_length=4;
#更新密码
set password = password("123456");

---------------------------------------------------------------------------------------------------------------

4.7 授权

Centos7下无法远程连接mysql数据库
#数据库没有授权,允许以root身份远程登录mysql
GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' IDENTIFIED BY '123456' WITH GRANT OPTION;

--------------------------------------------------------------------------

4.8 刷新

FLUSH PRIVILEGES;

4.9 连接msyql

填写,inuxIP地址加上密码即可连接

主机连接Linux的数据库成功!

10 导入SQL脚本

 进入mysql导入我们的sql脚本

注:数据库名与密码与jar包中的是否一致

五 部署项目

将部署的jar包拷贝到tomcat下的webapps下

最后输入服务器重启命令:reboot

用服务器IP加项目路径进行访问

访问成功!这样以后访问该项目都不要再重新启动服务器啦

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1468719.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

CSP-J 2023 复赛第4题:旅游巴士

【题目来源】https://www.luogu.com.cn/problem/P9751https://www.acwing.com/problem/content/description/5313/【题目描述】 小 Z 打算在国庆假期期间搭乘旅游巴士去一处他向往已久的景点旅游。 旅游景点的地图共有 n 处地点&#xff0c;在这些地点之间连有 m 条道路。 其中…

【深度学习目标检测】十九、基于深度学习的芒果计数分割系统-含数据集、GUI和源码(python,yolov8)

使用深度学习算法检测芒果具有显著的优势和应用价值。以下是几个主要原因&#xff1a; 特征学习的能力&#xff1a;深度学习&#xff0c;特别是卷积神经网络&#xff08;CNN&#xff09;&#xff0c;能够从大量的芒果图像中自动学习和提取特征。这些特征可能是传统方法难以手动…

每日五道java面试题之spring篇(五)

目录&#xff1a; 第一题. 使用 Spring 有哪些方式&#xff1f;第二题. 什么是Spring IOC 容器&#xff1f;第三题. 控制反转(IoC)有什么作用?第四题. IOC的优点是什么&#xff1f;第五题. BeanFactory 和 ApplicationContext有什么区别&#xff1f; 第一题. 使用 Spring 有哪…

数据湖技术方案

围绕数据人工智能计算实现材料研发全流程加速需要&#xff0c;面向“数字反应堆”需要的数据湖服务&#xff0c;“数据湖”是统一存储池&#xff0c;可对接多种数据输入方式&#xff0c;可以存储任意规模的结构化、半结构化、非结构化数据。 数据湖可无缝对接多种计算分析平台&…

Mac安装Appium

一、环境依赖 一、JDK环境二、Android-SDK环境&#xff08;android自动化&#xff09;三、Homebrew环境四、Nodejs 安装cnpm 五、安装appium六、安装appium-doctor来确认安装环境是否完成七、安装相关依赖 二、重头大戏&#xff0c; 配置wda&#xff08;WebDriverAgent&#x…

《凤凰架构》 -分布式事务章节 读书笔记

分布式事务严谨的定义&#xff1a;分布式环境下的事务处理机制 CAP定理&#xff1a;在一个分布式系统中&#xff0c;涉及共享数据问题时&#xff0c;以下三个特性最多只能同时满足两个 一致性&#xff1a;代表数据在任何时刻、任何分布式节点中看到的都是符合预期的&#xff0…

跨界计算与控制,强化显控和UI, 君正MPU再添新旗舰--Ingenic MPU X2600隆重发布

近日&#xff0c;北京君正隆重发布MPU芯片新产品X2600。该产品以商业和工业应用的数个细分领域为重点目标市场&#xff0c;兼顾通用处理器应用需求。无论从CPU结构的设计&#xff0c;还是专门控制器和接口的配备&#xff0c;都体现了北京君正MPU团队“技术路线上追求自主跨界&a…

unity学习(40)——创建(create)角色脚本(panel)——UI

1.点击不同的头像按钮&#xff0c;分别选择职业1和职业2&#xff0c;create脚本中对应的函数。 2.调取inputfield中所输入的角色名&#xff08;限制用户名长度为7字符&#xff09;&#xff0c;但愿逆向的服务器可以查重名&#xff1a; 3.点击头衔&#xff0c;显示选择的职业&a…

4.寻找两个正序数组的中位数

题目&#xff1a;给定两个大小分别为 m 和 n 的正序&#xff08;从小到大&#xff09;数组 nums1 和 nums2。请你找出并返回这两个正序数组的 中位数 。 解题思路&#xff1a;用二分法查找。使用归并的方式&#xff0c;合并两个有序数组&#xff0c;得到一个大的有序数组。大的…

MongoDB实战 – 用Python访问MongoDB数据库

MongoDB实战 – 用Python访问MongoDB数据库 MongoDB in Action – Access MongoDB Databases with Python By JacksonML Python语言功能强大众所周知&#xff0c;在数据库管理领域也无所不能。MongoDB是文档数据库&#xff0c;属于NoSQL数据库的一种&#xff0c;在业界也非常…

07_html

文章目录 引言前端概述分类 HTML快速入门重要的body标签注释hr标签br标签一些常见的标签标题标签div标签span标签p标签a标签img标签路径问题 ol和ul标签table标签input标签&#xff08;表单元素&#xff09;textarea标签&#xff08;表单元素&#xff09;select标签&#xff08…

记录 | vscode go无法跳转问题解决

go 代码不能跳转 如果是windows下开发linux的一般要用 插件 Remote-ssh,就可以尽情的访问文件和路径了. 1.go代码跳转一方面是你要把所有的 vscode go 插件要安装上, 方法是ctrlshift p,输入Go:Install/Update ,回车之后,把这些都选中安装. 2020年之后的,都会采用go mod的…

Flink join详解(含两类API及coGroup、connect详解)

Flink SQL支持对动态表进行复杂而灵活的连接操作。 为了处理不同的场景&#xff0c;需要多种查询语义&#xff0c;因此有几种不同类型的 Join。 默认情况下&#xff0c;joins 的顺序是没有优化的。表的 join 顺序是在 FROM 从句指定的。可以通过把更新频率最低的表放在第一个、…

vue 中实现音视频播放进度条(满足常见开发需求)

由于开发需要&#xff0c;作者封装了一个音视频播放进度条的插件&#xff0c;支持 vue2 及 vue3 &#xff0c;有需要的朋友可联系作者&#xff0c;下面是对该款插件的介绍。 插件默认样式&#x1f447;&#xff08;插件提供了多个配置选项&#xff0c;可根据自身需求进行个性化…

zemax冉斯登目镜

两个焦距相等的平凸透镜组成&#xff0c;两个凸面相对&#xff0c;两者间距等于焦距的2/3 球差、轴向色差、畸变都小于惠更斯目镜 但是垂轴色差较大 可以当作普通放大镜使用 这里没有可以控制两个平凸透镜焦距相等 入瞳直径4mm波长0.51、0.56、0.61半视场15焦距28.2mm 镜头…

基于Java+SSM+Jsp宿舍管理系统(源码+演示视频+包运行成功+Maven版)

您好&#xff0c;我是码农小波&#xff08;wei158888&#xff09;&#xff0c;感谢您阅读本文&#xff0c;欢迎一键三连哦。 ❤️ 1. 毕业设计专栏&#xff0c;毕业季咱们不慌&#xff0c;上千款毕业设计等你来选。 目录 1、项目背景 2、项目演示 3、使用技术 4、系统设计 …

Dynamo批量将房间名称转换为模型文字

今天呢&#xff0c;我们简单聊聊如何把房间名称&#xff0c;变成模型文字&#xff0c;好在三维中能够看到房间名称。 本来吧&#xff0c;我觉得批量创建模型文字应该是个很简单的事&#xff0c;但是我在Dynamo中搜了下ModelText&#xff0c;发现只有一个在族环境中创建模型文字…

cmake如何将源文件按照指定的组织方式进行分组,在IDE例如vistual stdio或者xcode项目工程文件中展示和管理这些源文件

1、我们先来看下面的一个项目的结构 TestGroup工程下面的main.cpp同级的有两个文件夹&#xff0c;到时候我们想在IDE比如xcode或者visual stdio2019中也显示这样的结构怎么弄呢(答案是用cmake中的source_group函数) 2、假如没有用source_group生成的xcode工程是怎么样的&#…

Phind-70B-运行速度提高4倍的同时,缩小了与GPT-4 Turbo在代码质量上的差距

每周跟踪AI热点新闻动向和震撼发展 想要探索生成式人工智能的前沿进展吗&#xff1f;订阅我们的简报&#xff0c;深入解析最新的技术突破、实际应用案例和未来的趋势。与全球数同行一同&#xff0c;从行业内部的深度分析和实用指南中受益。不要错过这个机会&#xff0c;成为AI领…

从ChatGPT到Sora,来了解大模型训练中的存储

1 从chatGPT到Sora 2022年底&#xff0c;OpenAI推出人工智能聊天机器人ChatGPT&#xff0c;开启了大模型领域的“竞速跑”模式。2024年2月15日&#xff0c;随着视频生成模型Sora的横空出世&#xff0c;OpenAI再度掀起热潮。 Sora将视频生成内容拉到了一个全新的高度&#xff0c…