使用阿里云服务器后的linux学习(1)

作者阿里云代理 文章分类 分类:linux图文教程 阅读次数 已被围观 872

1 认识inux

基于CentOS7版本学习,Linux一切皆文件:文件就是读写权限

学习方式:|

1、认识Linux

2、基本的命令(重点:Git讲了一些基本的命令(文件操作、目录管理、文件属性、Vim编辑器、账号管理、磁盘管理....))

3、软件的安装和部署! ( java、tomcat、docker )
Linux--Redis--Docker

linux在服务器端用的比较多,大型项目都是部署到Linux服务器上的,linux在开源社区的地位依然岿然不动。

Linux简介

Linux内核最初只是由芬兰人林纳斯·托瓦兹(Linus Torvalds )在赫尔辛基大学上学时出于个人爱好而编写的。
Linux是一套免费使用和自由传播的类Unix操作系统,是一个基于POSX(可移植操作系统接口)和UNX的多用户、多任务、支持多线程和多CPU的操作系统。
Linux能运行主要的UNIX工具软件、应用程序和网络协议。它支持32位和64位硬件。Linux继承了Unix以网络为核心的设计思想,是一个性能稳定的多用户网络操作系统。

Linux发行版

image-20210904092332858

Linux应用领域

今天各种场合都有使用各种Linux发行版,从嵌入式设备到超级计算机,并且在服务器领域确定了地位,通常服务器使用LAMP ( Linux + Apache + MySQL+PHP)或LNMP ( Linux + Nginx+ MySQL + PHP )组合。
目前Linux不仅在家庭与企业中使用,并且在政府中也很受欢迎。

  • 巴西联邦政府由于支持Linux 而世界闻名。
  • 有新闻报道俄罗斯军队自己制造的Linux发布版的,做为G.H.ost项目已经取得成果。
  • 印度的Kerala联邦计划在向全联邦的高中推广使用Linux。
  • 中华人民共和国为取得技术独立,在龙芯处理器中排他性地使用Linux。
  • 在西班牙的一些地区开发了自己的Linux发布版,并且在政府与教育领域广泛使用,如Extremadura地区的gnuLinEx和Andalusia地区的Guadalinex。
  • 葡萄牙同样使用自己的Linux发布版Caixa Magica,用于Magalh?es 笔记本电脑和e-escola政府软件。·法国和德国同样开始逐步采用Linux。
linux与Windows区别

image-20210904092937748

1.1 shell

image-20211201162222539

Linux内核叫kernel

2 Vmware虚拟机讲解

教学网址:(14条消息) 为什么在真机上没有VMware Network Adapter VMnet0虚拟网卡呢?vmware虚拟机三种网卡_weixin_41632560的博客-CSDN博客

注意:只要能与主机进行通信就都可以用xshel连接

三种模式对应的网卡(网络适配器)

image-20210904093548745

注意所有的虚拟网卡都是在宿主机的,而不是虚部主机上的,我以前一直以为是虚拟主机上的网卡,宿主机拿到消息之后通过虚拟网卡连接到该网段的虚拟交换机,然后发送消息

并且有各自的IP和MAC

image-20210904093735969

这些虚拟网卡(是虚拟交换机的端口)都会连接到虚拟交换机,因为交换机上也是有网卡的

这里为什么没有桥接模式的虚拟网卡:因为桥接模式相当于是真实的电脑连接到网桥上(路由器上,),其实他连接的也是虚拟网桥,

为什么在真机上没有VMware Network Adapter VMnet0虚拟网卡呢?(设计出虚拟网卡的目的是为了让主机和虚拟机通信,因为桥接模式下相对于路由器而言,虚拟机和主机的地位是平等的,可以将将两个ip地址设置成一个网段即可通信了,就没有必要再设计一块虚拟网卡出来;在NAT模式下,虚拟机网络和主机网络就不是一个网段上,从虚拟NAT设备的设计上就可以看出来,要想在NAT模式下,虚拟机和主机通信必须设计出一个网卡VMware Network Adapter VMnet8出来,将来为二者通信使用;仅主机模式的目的就是让虚拟机只能和主机通信,不允许虚拟机上外网,保证虚拟机的安全性,因此必须设计一块虚拟网卡VMware Network Adapter VMnet1出来,另外此处的虚拟网卡的概念和虚拟机1、虚拟机2、虚拟机3...虚拟机n中内部的网卡(在虚拟机终端上通过命令ifconfig查看到的网卡譬如etho 或ens33)不是一回事,不要把Vmnet1和VMware Network Adapter VMnet1混淆起来,前者是交换机,后者是虚拟网卡。在主机上的控制面板-->网络和Internet--->网络连接界面上显示的是虚拟网络(指NAT和仅主机模式网络)一一对应的虚拟网卡,不是虚拟机1安装上ubuntu后使用ifconfig查看到的eth0或ens33的网卡。这就是刚才虚拟机(ip:192.168.1.141)和主机(ip:192.168.1.10)在桥接模式下能Ping通,但在NAT模式下ping不通的原因:查看虚拟网卡VMware Network Adapter VMnet8的属性根本就没有设置和虚拟机同一网段的ip地址,只是自动获取ip,但是在虚拟机网络编辑器中NAT模式下也没有勾选“使用本地DHCP服务将ip分配给虚拟机”,并且在/etc/network/interfaces的配置文件中使用了static静态ip.如果将VMware Network Adapter VMnet8的ip设置成和192.168.1.141同一个网段使用静态ip的话就可以虚拟机和主机的通信了。)

vmnet0 桥接模式

为什么没有vmnet0网卡,因为本身虚拟机和宿主机ip在同一个网段了,能够通过虚拟交换机交流,就不需要虚拟网卡了

桥接模式就是将主机网卡与虚拟机虚拟的网卡利用虚拟网桥进行通信。在桥接的作用下,类似于把物理主机虚拟为一个交换机,所有桥接设置的虚拟机连接到这个交换机的一个接口上,物理主机也同样插在这个交换机当中,所以所有桥接下的网卡与网卡都是交换模式的,相互可以访问而不干扰。在桥接模式下,虚拟机ip地址需要与主机在同一个网段,如果需要联网,则网关与DNS需要与主机网卡一致。其网络结构如下图所示:

image-20210904095538212

私有网段肯定有NAT模式的

vmnet1 主机模式

Host-Only模式其实就是NAT模式去除了虚拟NAT设备,然后使用VMware Network Adapter VMnet1虚拟网卡连接VMnet1虚拟交换机来与虚拟机通信的,Host-Only模式将虚拟机与外网隔开,使得虚拟机成为一个独立的系统,只与主机相互通讯。其网络结构如下图所示:也就是说虚拟机不能通过NAT访问外网了,只能与宿主机通信

image-20210904103652796

在这个模式下,也能通过一定的配置实现联外网的

vmnet8 NAT模式

从主机的“VMWare Virtual Ethernet Adapter for VMnet8”虚拟网卡出来,连接到vmnet8虚拟交换机,虚拟交换机的另外的口连接到虚拟的NAT服务器(这也是一个Vmware组件),还有一个口 连接到虚拟DHCP服务器,其他的口连虚拟机,虚拟机的网关即是“VMWare Virtual Ethernet Adapter for VMnet8”网卡所在的机器,废话,这肯定就是你的Host机器啦。同样,用ipconfig也可以看出来,你的虚拟机的默认网关也指向了你的 “VMWare Virtual Ethernet Adapter for VMnet8”虚拟网卡地址。相比之下,可以看出来,NAT组网方式和Host-Only方式,区别就在于是否多了一个NAT服务。提供DHCP服务,宿主计算机相当于一台开启了DHCP功能的路由器

image-20210904101851383

注意虚拟网卡是在宿主机上(因为一个主机可以有多个网卡,不同的网卡可以再同一网段,也可以再不同网段,我认为虚拟交换机应该是带有vnet的),由于虚拟交换机本身已经为数字信号了,所以虚拟机上不需要网卡,只要虚拟交换机能够识别其IP地址就行,我想NAT模式是通过宿主机的IP地址作为NAT地址的

在NAT模式中,主机网卡直接与虚拟NAT设备相连,然后虚拟NAT设备与虚拟DHCP服务器一起连接在虚拟交换机VMnet8上,这样就实现了虚拟机联网。那么我们会觉得很奇怪,为什么需要虚拟网卡VMware Network Adapter VMnet8呢?原来我们的VMware Network Adapter VMnet8虚拟网卡主要是为了实现主机与虚拟机之间的通信。而连接外网是不需要这个虚拟网卡的,就算吧虚拟网卡关了,也能访问外网,在之后的设置步骤中,我们可以加以验证。..

image-20210904103508357

image-20210904102857336

相当于虚拟机NAT转换出去之后是宿主机的IP地址

交换机与路由器

它们的主要工作如下:
路由器:寻址,转发(依靠 IP 地址)
交换机:过滤,转发(依靠 MAC 地址)

我们可以看出这两者的主要工作就是转发数据,但是不同之处是,依靠的地址不同,这是一个根本区别!

路由器内有一份路由表,里面有它的寻址信息(就像是一张地图),它收到网络层的数据报后,会根据路由表和选路算法将数据报转发到下一站(可能是路由器、交换机、目的主机)

交换机内有一张MAC表,里面存放着和它相连的所有设备的MAC地址,它会根据收到的数据帧的首部信息内的目的MAC地址在自己的表中查找,如果有就转发,如果没有就放弃

image-20210904100528062

交换机是数据连接层,通过MAC地址查找的,路由器是通过IP地址查找的,路由器所连的是一个网段,当然这里也可以有虚拟局域网

通过拓扑图我们应该知道:
每一个路由器与其之下连接的设备,其实构成一个局域网
交换机工作在路由器之下,就是也就是交换机工作在局域网内
交换机用于局域网内网的数据转发
路由器用于连接局域网和外网

3 远程服务器

image-20210904110146763

端口号

image-20210904110251720

4 走近Linux系统

挂载:指的就是将设备文件中的顶级目录连接到 Linux 根目录下的某一目录(最好是空目录),访问此目录就等同于访问设备文件。也就是说把文件目录放在Linux系统文件目录的某一个文件夹中

1 开机关机

开机会启动许多程序。它们在Windows叫做"服务" ( service ),在Linux就叫做""守护进程" ( daemon ) 。

注意Windows开机运行系统也是需要系统的一些服务启动的

开机成功后,它会显示一个文本登录界面,这个界面就是我们经常看到的登录界面,在这个登录界面中会提示用户输入用户名,而用户输入的用户将作为参数传给login程序来验证用户的身份,密码是不显示的,输完回车即可!
一般来说,用户的登录方式有三种:

  • 命令行登录
  • ssh登录
  • 图形界面登录
  • 最高权限账户为root,可以操作一切!
关机

在linux领域内大多用在服务器上,很少遇到关机的操作。毕竟服务器上跑一个服务是永无止境的,除非特殊情况下,不得已才会关机。

关机指令为:shutdown ;

sync # 将数据由内存同步到硬盘中。 shutdown # 关机指令,你可以man shutdown 来看一下帮助文档。例如你可以运行如下命令关机: shutdown –h 10 # 这个命令告诉大家,计算机将在10分钟后关机 shutdown –h now # 立马关机 shutdown –h 20:25 # 系统会在今天20:25关机 shutdown –h +10 # 十分钟后关机 shutdown –r now # 系统立马重启 shutdown –r +10 # 系统十分钟后重启 reboot # 就是重启,等同于 shutdown –r now halt # 关闭系统,等同于shutdown –h now 和 poweroff

最后总结一下,不管是重启系统还是关闭系统,首先要运行 sync 命令,把内存中的数据写到磁盘中。

系统目录结构

1、一切皆文件
2、根目录/,所有的文件都挂载在这个节点下|

登录系统后,在当前命令窗口下输入命令:

ls /

你会看到如下图所示:

image-20210904113020469

树状目录结构:(Linux的一切资源都挂载在这个 / 根节点下)

image-20210904113040351

以下是对这些目录的解释:

  • /bin:bin是Binary的缩写, 这个目录存放着最经常使用的命令。
  • /boot: 这里存放的是启动Linux时使用的一些核心文件,包括一些连接文件以及镜像文件。
  • /dev : dev是Device(设备)的缩写, 存放的是Linux的外部设备,在Linux中访问设备的方式和访问文件的方式是相同的。(比如你插进去了一个U盘,就可以在这里看见)
  • ==/etc: 这个目录用来存放所有的系统管理所需要的配置文件和子目录。(redis、java)==
  • ==/home:用户的主目录,在Linux中,每个用户都有一个自己的目录,一般该目录名是以用户的账号命名的。(/home/jmk)==
  • /lib:这个目录里存放着系统最基本的动态连接共享库,其作用类似于Windows里的DLL文件。
  • /lost+found:这个目录一般情况下是空的,当系统非法关机后,这里就存放了一些文件。(电脑突然关机后的文件就会放在这个)
  • /media:linux系统会自动识别一些设备,例如U盘、光驱等等,当识别后,linux会把识别的设备挂载到这个目录下。
  • /mnt:系统提供该目录是为了让用户临时挂载别的文件系统的,我们可以将光驱挂载在/mnt/上,然后进入该目录就可以查看光驱里的内容了。(可以吧VCD、DVD挂载到这个,我们后面会把一些本地文件挂载到这个目录下)
  • ==/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:存放服务器网站相关的资源,环境,网站的项目,本地的虚拟机里面是没有的,购买的服务器是有的(宝塔一键安装的就在这里)==

2 常用命令

绝对路径和相对路径

我们知道Linux的目录结构为树状结构,最顶级的目录为根目录 /。

其他目录通过挂载可以将它们添加到树中,通过解除挂载可以移除它们。

在开始本教程前我们需要先知道什么是绝对路径与相对路径。

绝对路径:

路径的写法,由根目录 / 写起,例如:/usr/share/doc 这个目录。

相对路径:

路径的写法,不是由 / 写起,例如由 /usr/share/doc 要到 /usr/share/man 底下时,可以写成:cd ../man 这就是相对路径的写法啦!

处理目录的常用命令

接下来我们就来看几个常见的处理目录的命令吧:

  • ls: 列出目录
  • cd:切换目录
  • pwd:显示目前的目录
  • mkdir:创建一个新的目录
  • rmdir:删除一个空的目录
  • cp: 复制文件或目录
  • rm: 移除文件或目录
  • mv: 移动文件与目录,或修改文件与目录的名称

你可以使用 man [命令] 来查看各个命令的使用文档,如 :man cp。

ls

ls (列出目录)

在Linux系统当中, ls 命令可能是最常被运行的。

语法:

[root@www ~]# ls [-aAdfFhilnrRSt] 目录名称

选项与参数:

  • -a :全部的文件,==连同隐藏文件( 开头为 . 的文件) 一起列出来(常用)==
  • -l :长数据串列出,==包含文件的属性与权限等等数据;(常用)==

将目录下的所有文件列出来(含属性与隐藏档)

[root@www ~]# ls -al ~
[root@www ~]# ls -ll ~等价于ll

cd

cd (切换目录)

cd是Change Directory的缩写,这是用来变换工作目录的命令。

语法:

cd [相对路径或绝对路径]

测试:

# 切换到用户目录下 [root@kuangshen /]# cd home  # 使用 mkdir 命令创建 kuangstudy 目录 [root@kuangshen home]# mkdir kuangstudy # 进入 kuangstudy 目录 [root@kuangshen home]# cd kuangstudy # 回到上一级 [root@kuangshen kuangstudy]# cd .. # 回到根目录 [root@kuangshen kuangstudy]# cd / # 表示回到自己的家目录,亦即是 /root 这个目录,如果是jmk用户则会回到/home/jmk [root@kuangshen kuangstudy]# cd ~ 

接下来大家多操作几次应该就可以很好的理解 cd 命令的。

pwd

pwd ( 显示目前所在的目录 )

pwd 是 Print Working Directory 的缩写,也就是显示目前所在目录的命令。

[root@kuangshen kuangstudy]#pwd [-P]

选项与参数:-P :显示出确实的路径,而非使用连接(link) 路径。

测试:

# 单纯显示出目前的工作目录 [root@kuangshen ~]# pwd /root # 如果是链接,要显示真实地址,可以使用 -P参数 [root@kuangshen /]# cd bin [root@kuangshen bin]# pwd -P /usr/bin

mkdir

mkdir (创建新目录)

如果想要创建新的目录的话,那么就使用mkdir (make directory)吧。

mkdir [-mp] 目录名称

选项与参数:

  • -m :配置文件的权限喔!直接配置,不需要看默认权限 (umask) 的脸色~
  • -p :帮助你直接将所需要的目录(包含上一级目录)递归创建起来!

测试:

# 进入我们用户目录下[root@kuangshen /]# cd /home# 创建一个 test 文件夹[root@kuangshen home]# mkdir test# 创建多层级目录[root@kuangshen home]# mkdir test1/test2/test3/test4mkdir: cannot create directory ‘test1/test2/test3/test4’:No such file or directory  # <== 没办法直接创建此目录啊!# 加了这个 -p 的选项,可以自行帮你创建多层目录![root@kuangshen home]# mkdir -p test1/test2/test3/test4# 创建权限为 rwx--x--x 的目录。[root@kuangshen home]# mkdir -m 711 test2[root@kuangshen home]# ls -ldrwxr-xr-x 2 root root 4096 Mar 12 21:55 testdrwxr-xr-x 3 root root 4096 Mar 12 21:56 test1drwx--x--x 2 root root 4096 Mar 12 21:58 test2

rmdir

rmdir ( 删除空的目录 )

语法:

rmdir [-p] 目录名称

选项与参数:-p :连同上一级『空的』目录也一起删除 递归删除

测试:

# 看看有多少目录存在?[root@kuangshen home]# ls -ldrwxr-xr-x 2 root root 4096 Mar 12 21:55 testdrwxr-xr-x 3 root root 4096 Mar 12 21:56 test1drwx--x--x 2 root root 4096 Mar 12 21:58 test2# 可直接删除掉,没问题[root@kuangshen home]# rmdir test# 因为尚有内容,所以无法删除![root@kuangshen home]# rmdir test1rmdir: failed to remove ‘test1’: Directory not empty# 利用 -p 这个选项,立刻就可以将 test1/test2/test3/test4 依次删除。[root@kuangshen home]# rmdir -p test1/test2/test3/test4

注意:这个 rmdir 仅能删除空的目录,你可以使用 rm 命令来删除非空目录,后面我们会将!

cp

cp ( 复制文件或目录 )

语法:

[root@www ~]# cp [-adfilprsu] 来源档(source) 目标档(destination)[root@www ~]# cp [options] source1 source2 source3 .... directory

选项与参数:

  • -a:相当於 -pdr 的意思,至於 pdr 请参考下列说明;(常用)
  • -p:连同文件的属性一起复制过去,而非使用默认属性(备份常用);
  • -d:若来源档为连结档的属性(link file),则复制连结档属性而非文件本身;
  • -r:递归持续复制,用於目录的复制行为;(常用)
  • -f:为强制(force)的意思,若目标文件已经存在且无法开启,则移除后再尝试一次;
  • -i:若目标档(destination)已经存在时,在覆盖时会先询问动作的进行(常用)
  • -l:进行硬式连结(hard link)的连结档创建,而非复制文件本身。
  • -s:复制成为符号连结档 (symbolic link),亦即『捷径』文件;
  • -u:若 destination 比 source 旧才升级 destination !

测试:

# 找一个有文件的目录,我这里找到 root目录[root@kuangshen home]# cd /root[root@kuangshen ~]# lsinstall.sh[root@kuangshen ~]# cd /home# 复制 root目录下的install.sh 到 home目录下[root@kuangshen home]# cp /root/install.sh /home[root@kuangshen home]# lsinstall.sh# 再次复制,加上-i参数,增加覆盖询问?[root@kuangshen home]# cp -i /root/install.sh /homecp: overwrite ‘/home/install.sh’? y # n不覆盖,y为覆盖

rm

rm ( 移除文件或目录 )移除了之后原地方的文件就删了

语法:

rm [-fir] 文件或目录

选项与参数:

  • -f :就是 force 的意思,忽略不存在的文件,不会出现警告信息;
  • -i :互动模式,在删除前会询问使用者是否动作
  • -r :递归删除啊!最常用在目录的删除了!这是非常危险的选项!!!

测试:

# 将刚刚在 cp 的实例中创建的 install.sh删除掉![root@kuangshen home]# rm -i install.shrm: remove regular file ‘install.sh’? y# 如果加上 -i 的选项就会主动询问喔,避免你删除到错误的档名!# 尽量不要在服务器上使用 rm -rf /

mv

mv ( 移动文件与目录,或修改名称 )

语法:

[root@www ~]# mv [-fiu] source destination[root@www ~]# mv [options] source1 source2 source3 .... directory

选项与参数:

  • -f :force 强制的意思,如果目标文件已经存在,不会询问而直接覆盖;
  • -i :若目标文件 (destination) 已经存在时,就会询问是否覆盖!
  • -u :若目标文件已经存在,且 source 比较新,才会升级 (update)

测试:

# 复制一个文件到当前目录[root@kuangshen home]# cp /root/install.sh /home# 创建一个文件夹 test[root@kuangshen home]# mkdir test# 将复制过来的文件移动到我们创建的目录,并查看[root@kuangshen home]# mv install.sh test[root@kuangshen home]# lstest[root@kuangshen home]# cd test[root@kuangshen test]# lsinstall.sh# 将文件夹重命名,然后再次查看![root@kuangshen test]# cd ..[root@kuangshen home]# mv test mvtest[root@kuangshen home]# lsmvtest

touch创建文件

创建文件

touch f1 ##这里已经创建f1文件,f1可以没有后缀

echo >>写入文件

echo "i love jmk" >> f1 ##这里f1是创建的文件,>>就能把这句话写进去
本公司销售:阿里云、腾讯云、百度云、天翼云、金山大米云、金山企业云盘!可签订合同,开具发票。

我有话说: