linux学习(含阿里云部署)

这篇博客介绍了Linux的基础知识,包括常用命令、目录结构、文件属性和权限管理,详细讲解了vim编辑器的使用。此外,还涉及了Linux磁盘管理和进程管理,特别提到了Tomcat的命令行启动及常用端口。最后,文章讨论了如何在阿里云上部署CentOS,并给出了新web项目和SpringBoot项目的部署策略。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Xshell连接教程:

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-lahSmN21-1620745550104)(C:\Users\Razer\AppData\Roaming\Typora\typora-user-images\image-20210404142305631.png)]

linux常用命令

hostname xxx #修改主机名为xxx

pwd  #(print working directory)确定你当前的工作目录

ls  #显示当前工作目录的内容 

ls -l  #:显示权限

ls -a  # 显示所有文件包括被隐藏的

mkdir [directory1] # 建立一个directory1目录

cd #转换目录

cd ..  #返回上一目录

cat或more #查看文件内容(读配置文件一般)

cp  #复制文件

cp [source] [destination] #(需为一已存在的文件夹)

rm  #(remove):删除文件

-f :就是 force 的意思,忽略不存在的文件,不会出现警告信息;

-r :recursive递归删除啊!最常用在目录的删除了!这是非常危险的选项!!

-i :互动模式,在删除前会询问使用者是否动作 

rmdir [directory] #删除文件夹

mv  #(move):重命名文件 

mv [source] [directory] #(source是原文件名,directory是修改后的名字)

find #查找文件 有点鸡肋

sudo rm -rf lock  #:以管理员身份,强制删除 lock

clear  #清屏

touch index.js  #新建一index.js文件

ls -a;ls -l  #多个命令行间用分号隔开

man [command] #查看命令行使用方法(manual)
/string 可以在介绍页面选中关键字查看

Linux概述

linux中一切皆文件! 根目录为 / ,所有文件都在此目录下

  • 开机会启动许多程序。它们在Windows叫做"服务"(service),在Linux就叫做"守护进程"(daemon)。
  • .bat 是windows的启动文件 .sh 是linux中的启动文件

linux目录

关于linux目录

  • /bin:bin是Binary的缩写, 这个目录存放着最经常使用的命令。
  • /boot: 这里存放的是启动Linux时使用的一些核心文件,包括一些连接文件以及镜像文件。
  • /dev : dev是Device(设备)的缩写, 存放的是Linux的外部设备,在Linux中访问设备的方式和访问文件的方式是相同的。
  • /etc: 这个目录用来存放所有的系统管理所需要的配置文件和子目录。
  • /home:用户的主目录,在Linux中,每个用户都有一个自己的目录,一般该目录名是以用户的账号命名的。
  • /lib:这个目录里存放着系统最基本的动态连接共享库,其作用类似于Windows里的DLL文件。
  • /lost+found:这个目录一般情况下是空的,当系统非法关机后,这里就存放了一些文件。
  • /media:linux系统会自动识别一些设备,例如U盘、光驱等等,当识别后,linux会把识别的设备挂载到这个目录下。
  • /mnt:系统提供该目录是为了让用户临时挂载别的文件系统的,我们可以将光驱挂载在/mnt/上,然后进入该目录就可以查看光驱里的内容了。
  • /opt:这是给主机额外安装软件所摆放的目录。比如你安装一个ORACLE数据库则就可以放到这个目录下。默认是空的。
  • /proc:这个目录是一个虚拟的目录,它是系统内存的映射,我们可以通过直接访问这个目录来获取系统信息。
  • /root:该目录为系统管理员,也称作超级权限者的用户主目录。
  • /sbin:s就是Super User的意思,这里存放的是系统管理员使用的系统管理程序。
  • /srv:该目录存放一些服务启动之后需要提取的数据。
  • /sys:这是linux2.6内核的一个很大的变化。该目录下安装了2.6内核中新出现的一个文件系统 sysfs 。
  • /tmp:这个目录是用来存放一些临时文件的。
  • /usr:这是一个非常重要的目录,用户的很多应用程序和文件都放在这个目录下,类似于windows下的program files目录。
  • /usr/bin: 系统用户使用的应用程序。
  • /usr/sbin: 超级用户使用的比较高级的管理程序和系统守护程序。
  • /usr/src: 内核源代码默认的放置目录。
  • /var:这个目录中存放着在不断扩充着的东西,我们习惯将那些经常被修改的目录放在这个目录下。包括各种日志文件。
  • /run:是一个临时文件系统,存储系统启动以来的信息。当系统重启时,这个目录下的文件应该被删掉或清除。
  • /www : 一般存放server服务器内容

注意 linux中路径都是以 / 隔开的,区别于windows的 \

文件属性:

在这里插入图片描述

实例中,boot文件的第一个属性用"d"表示。"d"在Linux中代表该文件是一个目录文件。

在Linux中第一个字符代表这个文件是目录、文件或链接文件等等:

  • 当为[ d ]则是目录
  • 当为[ - ]则是文件;
  • 若是[ l ]则表示为链接文档 ( link file );
  • 若是[ b ]则表示为装置文件里面的可供储存的接口设备 ( 可随机存取装置 );
  • 若是[ c ]则表示为装置文件里面的串行端口设备,例如键盘、鼠标 ( 一次性读取装置 )。

接下来的字符中,以三个为一组,且均为『rwx』 的三个参数的组合。

其中,[ r ]代表可读(read)、[ w ]代表可写(write)、[ x ]代表可执行(execute)。

要注意的是,这三个权限的位置不会改变,如果没有权限,就会出现减号[ - ]而已。
在这里插入图片描述

因此,Linux系统按文件所有者、文件所有者同组用户和其他用户来规定了不同的文件访问权限。

修改权限

chmod 761 [filename] 
#change mode
#r:4    w:2    x:1
#761代表属主 可读可写可执行 7
      #属组 可读可写不可执行 6
  #其他用户  不可读不可写可执行 1

vim编辑器

vim编辑器

vim编辑器是一个小巧但功能强大的程序。vi编辑器有三种不同的模式:

插入模式——这个模式是通过在命令模式按下“i”键进入的。

命令模式——这是用户输入单键命令的模式。在其他模式中按下ESC键就可以进入命令模式。

​ 常见的执行删除操作的命令有:

​ dd 删除整个行

​ #dd 按照输入的数字(#),从当前行删除几行

​ yy 复制游标所在的那一行(常用)

​ D 删除光标位置后面全部内容

​ dw 删除光标所在位置的单词

冒号模式——从命令模式输入一个冒号(:)就可以进入这个模式。常见的冒号模式命令有:

wq保存且退出编辑器

:w 保存但不退出

:q 退出且不保存

:q! 强行退出vi,不保存。

:help 获取帮助

在系统提示符($)下输入命令vi和想要编辑(建立)的文件名

vi test.c

按键i进入插入模式。屏幕上看不到字符i,

按〈Esc〉键,从插入模式进入命令行模式,按o可换行

从命令行模式按:进入冒号模式。

输入wq,保存退出

磁盘管理

df -h  # 查看磁盘文件存储使用情况
du -h  #查看当前目录下文件占用存储情况

进程管理

ps #process status 查看当前进程情况

  • -a 显示全部
  • -u 以用户的信息显示进程
  • -x 显示后台运行进程的参数
#查看进程号
ps -aux | grep xxx.war  #这种命令使用最多,查看关于xxx.war的进程信息
#返回第二列就是进程号PID

#杀死进程号为pid的进程
kill -9 [pid]   #参数9是强制kill

#想查看父进程的话
pstree -pu
-p  显示父id
-u  显示用户组

| 在linux是管道符,将前面的结果传递给后面

Tomcat命令行启动

tar -zxvf apache-tomcat-9.0.22.tar.gz   # 解压压缩包

# 先cd进入bin目录
./startup.sh   # 启动tomcat
./shutdown.sh  # 关闭tomcat

常用默认端口

22 --ssh(secure shell)安全连接端口

80 -http 从WWW服务器传输超文本到本地浏览器的传输协议,传输的数据都是未加密的

443 --https ,HTTP的安全版,加入SSL层(Secure Sockets Layer)

3306 --mysql

关于在阿里云部署(CentOS)

除了防火墙要打开端口外,还需要设置安全组端口准入

firewall-cmd --list-ports #查看防火墙开放了的端口

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

--zone #作用域
--add-port=80/tcp  #添加端口,格式为:端口/通讯协议
--permanent  #永久生效,没有此参数重启后失效

systemctl restart firewalld.service  #重启防火墙

netstat -aon| grep "80"  #查看正在使用80端口的进程

kill -9 [pid]   #杀死进程,参数9是强制kill

java -jar xxx.jar  #运行jar包,(关闭终端时就会结束)

 
#后台运行
nohup java -jar xx.jar &   #nohup表示程序不被挂起 最后一个“&”表示后台运行程序

#若想关闭后台运行的程序要先查看进程号再kill掉
ps -aux | grep xxx.jar  


在这里插入图片描述24010就是进程号

新web项目

在tomcat里部署新项目时直接在webapps目录下新建一文件夹(例如名为JackWeb),而后直接120.78.xx.xx:8088/JackWeb 即可访问(8088是设置好的tomcat监听端口,可以修改)

webapps下的ROOT是根目录,若未指定访问项目名则自动访问ROOT项目

若只启动一个项目(还未试验):

由于tomcat默认启动会将webapps目录下所有项目启动,若只想启动其中一个项目可以

方法1: 修改tomcat目录下conf文件夹内server.xml

在标签中配置Context

<Context path="/hello" docBase="项目路径(E:\JetBrains\apache-tomcat-7.0.77\webapps\QIS\activiti-app)" debug="0"  privileged="true">
</Context>

path是url访问路径,docBase是项目所在位置

方法2:在conf目录中,在Catalina\localhost(此处需要注意目录的大小写)目录下新建一个XML文件,任意命名,只要和当前文件中的文件名不重复即可,代码如下。

<Context    path="/hello"   docBase="D:\eclipse3.2\workspace\hello\WebRoot"     debug="0"    privileged="true">      </Context>

这种方法相对来说比较灵活,并且可以设置别名

SpringBoot项目

在tomcat目录下 ,新建一文件夹webapps1 将jar包上传到这里,后台挂起运行后,直接访问 ip:port 就可

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值