项目部署(Linux)
Linux是一套免费使用和自由传播的操作系统
Linux概述
系统安装
Linux系统版本:
内核版:由Linux核心团队开发维护,免费开源,负责硬件控制
发行版:基于Linux内核版进行扩展,由各个厂商发行维护,有收费版本和免费版本
Linux的发行版:
Ubantu:以桌面应用为主,免费
RedHat:面向企业用户,收费
CentOS:RedHat的社区版,免费
Fedora:功能完备、快速更新,免费
openSUSE:对个人完全免费、图形界面华丽
红旗Linux:北京中科红旗软件技术有限公司开发
安装方式
物理机安装:直接将操作系统安装到服务器硬件上
虚拟机安装:通过虚拟机软件安装
虚拟机:指的是通过软件模拟的具有完整硬件系统功能、运行完全隔离环境中的完整计算机系统。VMWare WorkStation、VirtualBox、VMLite WorkStation
远程连接
常用的SHH(secure Shell,安全外壳协议)远程连接工具:Putty、SecureCRT、Xshell、FinalShell等
目录介绍
Linux系统中的目录特点:/是所有目录的顶点、目录结构像是一颗倒挂的树
根目录 / 下各个目录的作用及含义说明:
编号 | 目录 | 含义 |
---|---|---|
1 | /bin | 存放二进制可执行文件 |
2 | /boot | 存放系统引导时使用的各种文件 |
3 | /dev | 存放设备文件 |
4 | /etc | 存放系统配置文件 |
5 | /home | 存放系统用户的文件 |
6 | /lib | 存放程序运行所需的共享库和内核模块 |
7 | /opt | 额外安装的可选应用程序包所放置的位置 |
8 | /root | 超级用户目录 |
9 | /sbin | 存放二进制可执行文件,只有root用户才能访问 |
10 | /tmp | 存放临时文件 |
11 | /usr | 存放系统应用程序 |
12 | /var | 存放运行时需要改变数据的文件,例如日志文件 |
Linux常用命令
-
Linux 命令格式:
command ``[``-options``] [``parameter``]
-
说明:
-
command:命令名
-
[-options]:选项,可用来对命令进行控制,也可以省略 (可选)
-
[parameter]:参数,可以是零个、一个或多个(可选)
-
使用技巧:
-
Tab键自动补全
-
连续两次Tab键,给出操作提示
-
使用上下箭头快速调出曾经使用过的命令
-
使用clear命令或Ctrl+l快捷键实现清屏
目录操作命令
ls:
-
作用: 显示指定目录下的内容
-
语法:
ls [-al] [dir]
-
说明:
-a
显示所有文件及目录 (. 开头的隐藏文件也会列出)
-l
除文件名称外,同时将文件型态(d表示目录,-表示文件)、权限、拥有者、文件大小等信息详细列出
-
注意:
由于我们使用ls命令时经常需要加入-l选项,所以Linux为 ls -l
命令提供了一种简写方式,即 ll
-
常见用法:
ls -al 查看当前目录的所有文件及目录详细信息
ls -al /etc 查看/etc目录下所有文件及目录详细信息
ll 查看当前目录文件及目录的详细信息
cd:
-
作用: 用于切换当前工作目录,即进入指定目录
-
语法: cd [dirName]
-
特殊说明:
~ 表示用户的home目录
. 表示目前所在的目录
.. 表示目前目录位置的上级目录
-
举例:
cd .. 切换到当前目录的上级目录
cd ~ 切换到用户的home目录
cd /usr/local 切换到/usr/local目录
-
备注:
用户的home目录
root用户 /root
其他用户 /home/xxx
mkdir:
-
作用: 创建目录
-
语法:
mkdir [-p] dirName
-
说明:
-p: 确保目录名称存在,不存在的就创建一个。通过此选项,可以实现多层目录同时创建
-
举例:
mkdir itcast 在当前目录下,建立一个名为itcast的子目录
mkdir -p itcast/test 在工作目录下的itcast目录中建立一个名为test的子目录,若itcast目录不存在,则建立一个
rm:
-
作用: 删除文件或者目录
-
语法:
rm [-rf] name
-
说明:
-r: 将目录及目录中所有文件(目录)逐一删除,即递归删除
-f: 无需确认,直接删除
-
举例:
rm -r itcast/ 删除名为itcast的目录和目录中所有文件,删除前需确认
rm -rf itcast/ 无需确认,直接删除名为itcast的目录和目录中所有文件
rm -f hello.txt 无需确认,直接删除hello.txt文件
文件操作命令
-
cat
-
作用: 用于显示文件内容
-
语法:
cat [-n] fileName
-
说明:
-n
: 由1开始对所有输出的行数编号
-
举例:
cat /etc/profile 查看/etc目录下的profile文件内容
操作演示:
cat 指令会一次性查看文件的所有内容,如果文件内容比较多,这个时候查看起来就不是很方便了,这个时候我们可以通过一个新的指令more。
-
more
-
作用: 以分页的形式显示文件内容
-
语法:
more fileName
-
操作说明:
-
回车键 向下滚动一行
-
空格键 向下滚动一屏
-
b 返回上一屏
-
q或者Ctrl+C 退出more
-
-
举例:
-
more /etc/profile 以分页方式显示/etc目录下的profile文件内容
-
-
head
-
作用:查看文件开头的内容
-
语法:
head`` [``-n``] ``fileName
-
说明:
-
-n :输出文件开头的n行内容
-
-
举例:
-
head 1.log 默认显示1.log文件开头的10行内容
-
head -20 1.log 显示1.log文件开头的20行内容
-
-
tail
-
作用: 查看文件末尾的内容
-
语法: tail [-f] fileName
-
说明:
-f : 动态读取文件末尾内容并显示,通常用于日志文件的内容输出
-
举例:
-
tail /etc/profile 显示/etc目录下的profile文件末尾10行的内容 tail -20 /etc/profile 显示/etc目录下的profile文件末尾20行的内容 tail -f /itcast/my.log 动态读取/itcast目录下的my.log文件末尾内容并显示
-
如果我们不想查看文件尾部的数据了,可以直接使用快捷键 Ctrl+C , 结束当前进程。
拷贝操作命令
cp
-
作用: 用于复制文件或目录
-
语法: cp [-r] source dest
-
说明:
-r: 如果复制的是目录需要使用此选项,此时将复制该目录下所有的子目录和文件
-
举例:
cp hello.txt itcast/ 将hello.txt复制到itcast目录中
cp hello.txt ./hi.txt 将hello.txt复制到当前目录,并改名为hi.txt
cp -r itcast/ ./itheima/ 将itcast目录和目录下所有文件复制到itheima目录下
cp -r itcast/* ./itheima/ 将itcast目录下所有文件复制到itheima目录下
mv
-
作用: 为文件或目录改名、或将文件或目录移动到其它位置(第二个参数是已存在目录执行移动)
-
语法: mv source dest
-
举例:
-
mv hello.txt hi.txt 将hello.txt改名为hi.txt mv hi.txt itheima/ 将文件hi.txt移动到itheima目录中 mv hi.txt itheima/hello.txt 将hi.txt移动到itheima目录中,并改名为hello.txt mv itcast/ itheima/ 如果itheima目录不存在,将itcast目录改名为itheima mv itcast/ itheima/ 如果itheima目录存在,将itcast目录移动到itheima目录中
-
打包压缩命令
-
作用: 对文件进行打包、解包、压缩、解压
-
语法:
tar [-zcxvf] fileName [files]
包文件后缀为.tar表示只是完成了打包,并没有压缩
包文件后缀为.tar.gz表示打包的同时还进行了压缩
-
说明:
-
-z: z代表的是gzip,通过gzip命令处理文件,gzip可以对文件压缩或者解压
-
-c: c代表的是create,即创建新的包文件
-
-x: x代表的是extract,实现从包文件中还原文件
-
-v: v代表的是verbose,显示命令的执行过程
-
-f: f代表的是file,用于指定包文件的名称
-
-
举例:
-
打包
-
tar -cvf hello.tar ./* 将当前目录下所有文件打包,打包后的文件名为hello.tar tar -zcvf hello.tar.gz ./* 将当前目录下所有文件打包并压缩,打包后的文件名为hello.tar.gz
-
-
解包
-
tar -xvf hello.tar 将hello.tar文件进行解包,并将解包后的文件放在当前目录 tar -zxvf hello.tar.gz 将hello.tar.gz文件进行解压,并将解压后的文件放在当前目录 tar -zxvf hello.tar.gz -C /usr/local 将hello.tar.gz文件进行解压,并将解压后的文件放在/usr/local目录
-
-
文本编辑命令
vi & vim介绍
-
作用: vi命令是Linux系统提供的一个文本编辑工具,可以对文件内容进行编辑,类似于Windows中的记事本
-
语法: vi fileName
-
说明:
-
1). vim是从vi发展来的一个功能更加强大的文本编辑工具,编辑文件时可以对文本内容进行着色,方便我们对文件进行编辑处理,所以实际工作中vim更加常用。
-
2). 要使用vim命令,需要我们自己完成安装。可以使用下面的命令来完成安装:
yum install vim
-
vim使用
-
作用: 对文件内容进行编辑,vim其实就是一个文本编辑器
-
语法: vim fileName
-
说明:
-
1). 在使用vim命令编辑文件时,如果指定的文件存在则直接打开此文件。如果指定的文件不存在则新建文件。
-
2). vim在进行文本编辑时共分为三种模式,分别是 命令模式(Command mode),插入模式(Insert mode)和底行模式(Last line mode)。这三种模式之间可以相互切换。我们在使用vim时一定要注意我们当前所处的是哪种模式。
-
-
三种模式:
-
命令模式
-
A. 命令模式下可以查看文件内容、移动光标(上下左右箭头、gg、G)
-
B. 通过vim命令打开文件后,默认进入命令模式
-
C. 另外两种模式需要首先进入命令模式,才能进入彼此
-
命令模式指令 含义 gg 定位到文本内容的第一行 G 定位到文本内容的最后一行 dd 删除光标所在行的数据 ndd 删除当前光标所在行及之后的n行数据 u 撤销操作 i 或 a 或 o 进入插入模式(进入后光标所处的位置不同而已)
-
-
插入模式
-
A. 插入模式下可以对文件内容进行编辑
-
B. 在命令模式下按下[i,a,o]任意一个,可以进入插入模式。进入插入模式后,下方会出现【insert】字样
-
C. 在插入模式下按下ESC键,回到命令模式
-
-
-
底行模式
-
A. 底行模式下可以通过命令对文件内容进行查找、显示行号、退出等操作
-
B. 在命令模式下按下[:,/]任意一个,可以进入底行模式
-
C. 通过/方式进入底行模式后,可以对文件内容进行查找
-
D. 通过:方式进入底行模式后,可以输入wq(保存并退出)、q!(不保存退出)、set nu(显示行号)
-
底行模式指令 含义 :wq 保存并退出 :q! 不保存退出 :set nu 显示行号 :set nonu 取消行号显示 :n 定位到第n行,如 :10 就是定位到第10行
-
查找命令
find
-
作用: 在指定目录下查找文件
-
语法: find dirName -option fileName
-
举例:
-
find . –name "*.java
"
在当前目录及其子目录下查找.java结尾文件 -
find /itcast -name "*.java"
在/itcast目录及其子目录下查找.java结尾的文件
-
grep
-
作用: 从指定文件中查找指定的文本内容
-
语法:
grep [-inAB] word fileName
-
选项:
-
-i: 检索的关键字忽略(ignore)大小写
-
-n: 显示关键字所在的这一行的行号
-
-A: 输出关键字所在行及之后(After)的几行记录 (如:-A5 表示输出关键字所在行之后的5行记录)
-
-B: 输出关键字所在行及之前(Before)的几行记录 (如:-B5 表示输出关键字所在行之前的5行记录)
-
-
举例:
-
grep Hello HelloWorld.java 查找HelloWorld.java文件中出现的Hello字符串的位置 grep hello *.java 查找当前目录中所有.java结尾的文件中包含hello字符串的位置
-
Linux软件安装
安装方式介绍:
二进制发布包安装:软件已经针对具体平台编译打包发布,只要解压,修改配置即可
rpm安装:软件已经按照redhat的包管理规范进行打包,使用rpm命令进行安装,不能执行解决库依赖问题
yum安装:一种在线安装方式,本质上还是rpm安装,自动下载安装包并安装,安装过程中自动解决库依赖问题
源码编译安装:软件以源码工程的形式发布,需要自己编译打包
安装JDK
安装步骤:
1.使用FinalShell自带的上传工具将jdk的二进制发布包上传到Linux
2.解压安装包,命令为tar -zxvf jdk-21_linux-x64_bin.tar.gz -C /usr/local/
3.配置环境变量,使用vim命令修改/etc/profile
文件,在文件末尾加入如下配置
export JAVA_HOME=/usr/local/jdk-17.0.10
export PATH=$JAVA_HOME/bin:$PATH
4.重新加载profile文件
为了使更改的配置立即生效,需要重新加载profile文件,执行命令:
source /etc/profile
5.检查安装是否成功
java -version
安装MySql
对于MySQL数据库的安装,我们将要使用前面讲解的第一种安装方式进行安装。
1). 准备工作
在安装MySQL数据库之前,我们需要先检查一下当前Linux系统中,是否安装的有MySQL的相关服务(很多linux安装完毕之后,自带了低版本的mysql的依赖包),如果有,先需要卸载掉,然后再进行安装。
A. 通过rpm相关指令,来查询当前系统中是否存在已安装的mysql软件包,执行指令如下:
-
rpm -qa 查询当前系统中安装的所有软件 rpm -qa | grep mysql 查询当前系统中安装的名称带mysql的软件 rpm -qa | grep mariadb 查询当前系统中安装的名称带mariadb的软件
通过rpm -qa 查询到系统通过rpm安装的所有软件,太多了,不方便查看,所以我们可以通过管道符 | 配合着grep进行过滤查询。
通过查询,我们发现在当前系统中存在mariadb数据库,是CentOS7中自带的,而这个数据库和MySQL数据库是冲突的,所以要想保证MySQL成功安装,需要卸载mariadb数据库。
RPM:全称为 Red-Hat Package Manager,RPM软件包管理器,是红帽Linux用于管理和安装软件的工具。
B. 通过 rpm 相关指令,来卸载对应的组件,执行指令如下:
在rpm中,卸载软件的语法为:rpm -e --nodeps 软件名称
那么,我们就可以通过指令,卸载 mariadb,具体指令为: rpm -e --nodeps mariadb-libs-5.5.60-1.el7_5.x86_64
我们看到执行完毕之后, 再次查询 mariadb,就查不到了,因为已经被成功卸载了。
2). 将资料中提供的MySQL安装包上传到Linux并解压
A. 上传MySQL安装包
在课程资料中,提供的有MySQL的安装包 ,我们需要将该安装包上传到Linux系统的根目录 /root 下面。
B. 解压到 当前目录
执行如下指令:
tar -xvf mysql-8.0.30-linux-glibc2.12-x86_64.tar.xz
C. 将解压后的文件夹移动到 /usr/local 目录下, 并改名为 mysql
mv mysql-8.0.30-linux-glibc2.12-x86_64 /usr/local/mysql cd /usr/local/mysql
3). 配置系统环境变量
配置MySQL的环境变量, 通过vi编辑器编辑 /etc/profile
文件, 在尾部追加:
export MYSQL_HOME=/usr/local/mysql export PATH=$MYSQL_HOME/bin:$PATH
并执行如下指令, 注册MySQL为系统服务:
cp /usr/local/mysql/support-files/mysql.server /etc/init.d/mysql chkconfig --add mysql
5). 初始化数据库
#创建一个用户组, 组名就叫mysql groupadd mysql #创建一个系统用户 mysql, 并归属于用户组 mysql useradd -r -g mysql -s /bin/false mysql #初始化mysql mysqld --initialize --user=mysql --basedir=/usr/local/mysql --datadir=/usr/local/mysql/data
执行上述指令时, 会输入如下日志,在日志中就输出了MySQL中root用户的一个临时密码【记得复制出来,记录下来】:
-
启动MySQL
A. 启动MySQL服务
systemctl start mysql
B. 通过命令, 登录MySQL
#xxxxx 代表上述生成的root的临时密码 mysql -uroot -pxxxxx
-
配置MySQL
A. 修改root用户的密码
ALTER USER 'root'@'localhost' IDENTIFIED WITH mysql_native_password BY '1234';
注意: 这个root账号仅仅能够在本机**localhost上访问,我们在windows上是无法访问的。如果需要在window上或其他服务器上也能远程访问,需要创建一个账号,用于远程访问的。**
B. 创建账号, 并授权远程访问
CREATE USER 'root'@'%' IDENTIFIED BY '1234'; GRANT ALL PRIVILEGES ON *.* TO 'root'@'%'; FLUSH PRIVILEGES;
我们已经开启了MySQL的远程访问的权限,为什么还是连接不上MySQL服务器呢?? 这是因为Linux系统的防火墙,将我们的访问拦截了。
-
防火墙操作
Linux系统安装完毕后,系统启动时,防火墙自动启动,防火墙拦截了所有端口的访问。接下来我们就需要学习一下,如何操作防火墙,具体指令如下:
操作 | 指令 | 备注 |
---|---|---|
查看防火墙状态 | systemctl status firewalld / firewall-cmd --state | |
暂时关闭防火墙 | systemctl stop firewalld | |
永久关闭防火墙(禁用开机自启) | systemctl disable firewalld | 下次启动,才生效 |
暂时开启防火墙 | systemctl start firewalld | |
永久开启防火墙(启用开机自启) | systemctl enable firewalld | 下次启动,才生效 |
开放指定端口 | firewall-cmd --zone=public --add-port=8080/tcp --permanent | 需要重新加载生效 |
关闭指定端口 | firewall-cmd --zone=public --remove-port=8080/tcp --permanent | 需要重新加载生效 |
立即生效(重新加载) | firewall-cmd --reload | |
查看开放端口 | firewall-cmd --zone=public --list-ports |
注意: 要想在windows上能够访问MySQL,需要开放防火墙的3306端口 或者 直接关闭防火墙 ,执行如下指令:
#开发防火墙的3306端口号 firewall-cmd --zone=public --add-port=3306/tcp --permanent #重新加载 firewall-cmd --reload #查看开放的端口号 firewall-cmd --zone=public --list-ports
或者直接关闭防火墙:
systemctl stop firewalld
-
连接测试
关闭掉linux系统的防火墙之后,我们就可以打开windows上的命令行,通过mysql的客户端(命令行/图形化界面)来连接远程linux上安装的MySQL数据库了。
1). 客户端连接
2). 打开DataGrip图形化工具连接
执行资料中提供的SQL脚本 tlias.sql
。
安装Nginx
安装
Nginx的安装包,从官方下载下来的是c语言的源码包,我们需要自己编译安装。具体操作步骤如下:
1). 安装Nginx运行时需要的依赖
yum install -y pcre pcre-devel zlib zlib-devel openssl openssl-devel
安装C语言的编译环境.
yum install gcc-c++
2). 上传Nginx的源码包
3). 解压源码包到当前目录
tar -zxvf nginx-1.20.2.tar.gz
4). 进入到解压目录后,执行指令
#进入解压目录 cd nginx-1.20.2 #执行命令配置, 生成Makefile文件 ./configure --prefix=/usr/local/nginx
5). 执行命令进行编译和安装
#编译 make #编译安装 make install
启动Nginx
进入到nginx安装目录/usr/local/nginx
,启动nginx服务
cd /usr/local/nginx/ sbin/nginx
启动完毕之后,我们可以通过 ps
指令查询当前系统中的nginx进程,从而确认nginx是否启动 。
然后,我们就可以打开浏览器,访问服务器上的nginx 。
项目部署(Tlias)
前端:
1). 将nginx的安装目录的html中的静态资源文件先删除掉。
2). 将资料中提供的 "资料/06. 项目部署/前端/页面资源" 目录下的静态资源文件,全部上传到nginx安装目录下的 html 目录中.
3). 修改资料中提供的 nginx.conf
配置文件**,将其上传到nginx安装目录下的 conf 目录中.**
4). 重新加载nginx服务的配置文件
#重新加载配置文件 sbin/nginx -s reload
5). 再次访问nginx (可能会存在浏览器缓存, 可以按Ctrl+F5, 强制刷新清理缓存)
nginx服务常见操作指令:
-
启动: sbin/nginx
-
重载: sbin/nginx -s reload
-
停止: sbin/nginx -s stop
后端:
之前我们讲解Linux操作系统时,就提到,我们服务端开发工程师学习Linux系统的目的就是将来我们开发的项目绝大部分情况下都需要部署在Linux系统中。
-
环境准备
那现在,项目要上线了,要部署到linux服务器上了,我们也需要使用linux服务器上所安装的mysql数据库。
那此时,我们就可以再准备一份文件 application.yml
将里面的配置的mysql的ip地址及相关配置信息修改一下(配置Linux上安装的MySQL的信息):
#配置数据库连接信息 spring: datasource: driver-class-name: com.mysql.cj.jdbc.Driver url: jdbc:mysql://192.168.100.128:3306/tlias username: root password: 1234 servlet: multipart: max-file-size: 10MB #单个文件最大大小限制10MB max-request-size: 100MB #单个请求最大大小限制100MB #配置mybatis的日志输出到控制台 mybatis: configuration: log-impl: org.apache.ibatis.logging.stdout.StdOutImpl #配置mybatis的驼峰命名的映射开关 map-underscore-to-camel-case: true #查看事务管理的日志 logging: level: org.springframework.jdbc.support.JdbcTransactionManager: debug #阿里云oss配置 aliyun: oss: endpoint: https://oss-cn-beijing.aliyuncs.com bucketName: java422-web-ai
改造完毕之后,可以在本地的idea中先启动当前项目,然后访问一下,看看工程是否正常访问。
-
打包部署
1). 执行 package
指令,进行打包操作,将当前的springboot项目,打成一个jar包。 (跳过测试)
2). 在Linux服务器上创建一个目录,将jar包上传到服务器 。
mkdir -p /usr/local/app
3). 通过java命令,启动项目
#进入目录/usr/local/app cd /usr/local/app #运行jar包 java -jar tlias-web-management-0.0.1-SNAPSHOT.jar
项目启动起来之后,就可以打开浏览器测试啦。
-
阿里云OSS秘钥配置
由于在开发的时候,我们将访问阿里云OSS的AccessKeyId,AccessKeySecret都配置在了系统的环境变量中了。那现在项目部署到了Linux服务器中,调用阿里云OSS进行文件上传时,程序就会获取Linux系统中的环境变量。所以此时,我们需要将AccessKeyId,AccessKeySecret配置为Linux系统的环境变量。
1). 查看Windows系统之前配置的环境变量
echo %OSS_ACCESS_KEY_ID% echo %OSS_ACCESS_KEY_SECRET%
我们将上述自己的 AccessKeyId 与 AccessKeySecret 复制出来,然后在linux系统中配置环境变量。
2). 执行如下指令:
echo "export OSS_ACCESS_KEY_ID=LTAI5tFww3VE7EZSs9dfh7j6" >> /etc/profile echo "export OSS_ACCESS_KEY_SECRET=3eVYBbuK1F8rX5Tv0ge8lkKG1TrOL5" >> /etc/profile source /etc/profile
注意!!!:上述的绿色背景部分,是自己的阿里云OSS账号的 OSS_ACCESS_KEY_ID, OSS_ACCESS_KEY_SECRET,一个字符都不能错,在记事本中将命令组装好,然后再到命令行中执行。
注意!!!:上述的绿色背景部分,是自己的阿里云OSS账号的 OSS_ACCESS_KEY_ID, OSS_ACCESS_KEY_SECRET,一个字符都不能错,在记事本中将命令组装好,然后再到命令行中执行。
注意!!!:上述的绿色背景部分,是自己的阿里云OSS账号的 OSS_ACCESS_KEY_ID, OSS_ACCESS_KEY_SECRET,一个字符都不能错,在记事本中将命令组装好,然后再到命令行中执行。
执行完毕后,将finalShell的窗口关闭掉,重新打开一个新窗口(让环境变量生效),重新运行项目测试。
当前程序中存在的问题:
-
线上程序不会采用控制台霸屏的形式运行程序,而是将程序在后台运行
-
线上程序不会将日志输出到控制台,而是输出到日志文件,方便运维查阅信息
要解决上述这两个问题,我们就可以通过 nohup 指令让程序在后台运行。
-
后台运行
1). 后台运行程序
nohup java -jar tlias-web-management-0.0.1-SNAPSHOT.jar &> tlias.log &
通过上述指令就可以后台运行服务,服务运行之后, 所有的日志信息都会输出到 tlias.log 文件中。
2). 停止服务
#查看服务的进程信息 ps -ef|grep tlias #杀掉进程 kill -9 xxxxx
nohup命令说明:
-
nohup命令:英文全称 no hang up(不挂起),用于不挂断地运行指定命令,退出终端不会影响程序的运行
-
语法格式:
nohup command [ args … ] [&]
-
参数说明:
-
command:要执行的命令
-
args:一些参数,可以指定输出文件
-
&:让命令在后台运行
-
-
举例:
-
nohup java -jar boot工程.jar &> hello.log &
-
上述指令的含义为: 后台运行 java -jar 命令,并将日志输出到hello.log文件