我们的 Linux 主要是系统调用和内核那两层。
当然直观地看,我们使用的操作系统还包含一些在其上运行的应用程序,比如文本编辑器、浏览器、电子邮件等。
Linux 本身只是操作系统的内核。
内核是使其它程序能够运行的基础。它实现了多任务和硬件管理,用户或者系统管理员交互运行的所有程序实际上都运行在内核之上。
其中有些程序是必需的,比如说,命令行解释器(shell),它用于用户交互和编写 shell 脚本。
Linux之父 Linus 没有自己去开发这些应用程序,而是使用已有的自由软件。这减少了搭建开发环境所需花费的工作量。实际上,他经常改写内核,使得那些程序能够更容易地在 Linux 上运行。许多重要的软件,包括 C 编译器,都来自于自由软件基金 GNU 项目。GNU 项目开始于 1984 年,目的是为了开发一个完全类似于 UNIX 的免费操作系统。为了表扬 GNU 对 Linux 的贡献,许多人把 Linux 称为 GNU/Linux(GNU 有自己的内核)。
命令解析器
),类似于 DOS 下的 command(命令行)和后来的 cmd.exe 。它之所以被称作 Shell 是因为它隐藏了操作系统底层的细节。有壳就有核,这里的核就是指 UNIX/Linux 内核,Shell 是指“提供给使用者使用界面”的软件(命令解析器)
shell 既是用户交互的界面,也是控制系统的脚本语言。
1.RedHat系列:Redhat、Centos、Fedora等
2.Debian系列:Debian、Ubuntu等
RedHat系列的包管理工具是yum
Debian系列的包管理工具是apt-get
1、步骤1:cat /etc/os-release
2、步骤2:分别对于redhat、debain版本:
查看 redhat 版本命令:
cat /etc/redhat-release
查看 debain 版本命令:
cat /etc/debian_version
[root@iZwz9535z41cmgcpkm7i81Z ~]# cat /etc/redhat-release
CentOS Linux release 7.9.2009 (Core)
原因:是因为升级了,通过yum 升级了,yum update
1、rpm 是Linux软件扩展名,是Red Hat Linux提供的一种包封装格式。现在许多Linux发行版本都使用。
2、后缀为.deb是Debain Linux提供的一种包封装格式。
3、后缀为.tar.gz、tar.Z、tar.bz2或.tgz是使用Unix系统打包工具tar打包的。
4、后缀为.bin 的一般是一些商业软件
与直接从源代码安装相比,软件包管理易于安装和卸载;易于更新已安装的软件包;易于保护配置文件;易于跟踪已安装文件。
几乎所有的Linux发行版本都使用某种形式的软件包管理安装、更新和卸载软件。
rpm 最初是 Red Hat Linux 发行版专门用来管理 Linux 各项套件的程序,现在许多Linux发行版本都使用。
□ 使用举例:
RPM命令主要参数:
-a 查询所有套件
-q 使用询问模式,当遇到任何问题时,rpm指令会先询问用户
-l 显示套件的文件列表
-i 安装软件
-t 测试安装,不是真的安装
-p 显示安装进度
-f 忽略任何错误
-U 升级安装
-v 检测套件是否正确安装
RedHat系列的包管理工具是yum
Debian系列的包管理工具是apt-get
Yellow dog Updater Modified的简称,起初是由yellow dog这一发行版的开发者研发,用python写成,最初叫做yup(yellow dog updater),
后来被改名为 yum。
简洁的配置文件(/etc/yum.conf,/etc/yum.repos.d 下的文件)
更加方便地 添加/删除/更新RPM包.
自动解决包的倚赖性问题.
更加方便地管理大量系统的更新问题.
yum的关键之处是要有可靠的repository(软件仓库)
软件仓库,它可以是http或ftp站点, 也可以是本地软件池,但必须包含rpm的header,
header包括了rpm包的各种信息,包括描述,功能,提供的文件,依赖性等
。
正是收集了这些 header并加以分析,才能自动化地完成余下的任务。
[root@iZwz9535z41cmgcpkm7i81Z etc]# cat yum.conf
[main]
cachedir=/var/cache/yum/$basearch/$releasever # yum缓存的目录,yum在此存储下载的rpm包和数据库,一般是/var/cache/yum
keepcache=0 # 是否保存缓存,为0,让缓存一直为空
debuglevel=2 # debuglevel:除错级别,0-10,默认是2
logfile=/var/log/yum.log # yum的日志文件,默认是/var/log/yum.log
exactarch=1 # 准确匹配,精确匹配硬件平台,只有完全相同才更新。有两个选项1和0,代表是否只升级和你安装软件包cpu体系一致的包
obsoletes=1 # 当使用升级模式时,一些包没有用了,可以删除(取值1)
gpgcheck=1 # 安装时是否检查RPM包的PGP签名
plugins=1 # Yum插件是否可用
installonly_limit=5 # 安装限制 # bugtracker_url:bug 跟踪路径
bugtracker_url=http://bugs.centos.org/set_project.php?project_id=23&ref=http://bugs.centos.org/bug_report_page.php? category=yum # 目录
distroverpkg=centos-release # 定从哪里获取系统版本相关的信息
mirrorlist 镜像站点
baseurl 仓库路径(固定路径)
enabled=1 是否打开仓库,为1则是打开仓库,为0则是关闭仓库
gpgcheck 是否需要查阅RPM文件内数字证书,0表示不检查,1表示检查 (GPG是加密和数字签名的免费工具)
gpgkey 数字证书公钥文件所在位置,使用默认值
[root@iZwz9535z41cmgcpkm7i81Z yum.repos.d]# cat CentOS-Base.repo
[base]
name=CentOS-$releasever - Base
failovermethod=priority
baseurl=http://mirrors.cloud.aliyuncs.com/centos/$releasever/os/$basearch/
gpgcheck=1
gpgkey=http://mirrors.cloud.aliyuncs.com/centos/RPM-GPG-KEY-CentOS-7
#released updates
[updates]
name=CentOS-$releasever - Updates
failovermethod=priority
baseurl=http://mirrors.cloud.aliyuncs.com/centos/$releasever/updates/$basearch/
gpgcheck=1
gpgkey=http://mirrors.cloud.aliyuncs.com/centos/RPM-GPG-KEY-CentOS-7
#additional packages that may be useful
[extras]
name=CentOS-$releasever - Extras
failovermethod=priority
baseurl=http://mirrors.cloud.aliyuncs.com/centos/$releasever/extras/$basearch/
gpgcheck=1
gpgkey=http://mirrors.cloud.aliyuncs.com/centos/RPM-GPG-KEY-CentOS-7
#additional packages that extend functionality of existing packages
[centosplus]
name=CentOS-$releasever - Plus
failovermethod=priority
baseurl=http://mirrors.cloud.aliyuncs.com/centos/$releasever/centosplus/$basearch/
gpgcheck=1
enabled=0
gpgkey=http://mirrors.cloud.aliyuncs.com/centos/RPM-GPG-KEY-CentOS-7
#contrib - packages by Centos Users
[contrib]
name=CentOS-$releasever - Contrib
failovermethod=priority
baseurl=http://mirrors.cloud.aliyuncs.com/centos/$releasever/contrib/$basearch/
gpgcheck=1
enabled=0
gpgkey=http://mirrors.cloud.aliyuncs.com/centos/RPM-GPG-KEY-CentOS-7
和maven、npm一样,凡是看到,涉及到自动管理包,必须考虑的是下载速度的提速。
■ 配置一下阿里云镜像加速:
1)系统是 debain:
记得先备份,可以选择创建一个文件夹,然后拷贝一份放进去
root@f1cfb81dedfd:/etc/apt# mkdir cat sources.list.backup
root@f1cfb81dedfd:/etc/apt# cp sources.list ./sources.list.backup
root@f1cfb81dedfd:/etc/apt/sources.list.backup# cd ../
使用命令 echo 覆盖+追加方式 [若是没有vim工具,则使用bash命令]
deb https://mirrors.aliyun.com/debian bullseye main
deb https://mirrors.aliyun.com/debian-security bullseye-security main
deb https://mirrors.aliyun.com/debian bullseye-updates main
执行一下更新命令:
apt-get update -y
2)系统是 redhat:
记得先备份,可以选择创建一个文件夹,然后拷贝一份放进去
root@f1cfb81dedfd:/etc/yum.repos.d# mv /etc/yum.repos.d /etc/yum.repos.d.backup
root@f1cfb81dedfd:/etc/yum.repos.d#
在阿里云镜像官网下载文件 CentOS-Base.repo [下载对应你的系统版本的Centos-Base.repo,下载的名字不是这个,可以自己改一下哦]
使用工具xftp,删除掉原先的CentOS-Base.repo,然后将下载下来的CentOS-Base.repo,传输到/etc/yum.repos.d目录下
-y(当安装/卸载/更新过程提示选择全部为"yes")
安装:yum install xxx
删除:yum remove xxx
升级: yum update xxx
查询:yum list 列出yum服务器上面所有的软件名称
清除缓存:
生成缓存:yum makecache
● vim的常用模式有分为命令模式,插入模式,正常模式,可视模式。
正常模式:主要用来浏览文本内容。一开始打开vim都是正常模式。按 Esc键 任何情况,都可以返回正常模式
插入编辑模式:用来向文本中添加内容的。在正常模式下,按 Insert 键,即可进入插入编辑模式。
注意:退出vim,如果使用vim修改任何文本后需要保存并退出,需要在正常模式下(Esc键),输入 shift+zz
(或者在正常模式,进入命令模式后,按 :wq )进行保存,然后再退出vim。
保存并退出 卡了,就再次切换模式为插入模式,然后再切回来正常模式,shift+zz
[root@iZwz9535z41cmgcpkm7i81Z shan]# echo 'hello'
hello
[root@iZwz9535z41cmgcpkm7i81Z shan]# touch test.txt
[root@iZwz9535z41cmgcpkm7i81Z shan]# vim test.txt
# test.txt 的内容:
# name
my name is kangkang
# age
18
# love
my love is i believe.
[root@iZwz9535z41cmgcpkm7i81Z shan]# echo 'ru guo ni shuo yes,jiu keyi la'>test.txt
[root@iZwz9535z41cmgcpkm7i81Z shan]# cat test.txt
ru guo ni shuo yes,jiu keyi la
[root@iZwz9535z41cmgcpkm7i81Z shan]# touch test2.txt
[root@iZwz9535z41cmgcpkm7i81Z shan]# vim test2.txt
# test2.txt 的内容:
# subjectName
tomorrow i need to study english.
# class
3
# score
just-so-so.
[root@iZwz9535z41cmgcpkm7i81Z shan]# echo 'time is today'>> test2.txt
[root@iZwz9535z41cmgcpkm7i81Z shan]# cat test2.txt
#subjectName
tomorrow i need to study english.
# class
3
# score
just-so-so.
time is today
自己购买一台云服务器,通过xshell 连接远程服务器,然后动手使用linux命令,例如使用linux部署一个项目。
- 购买云服务器、配置、安装xshell、搭建环境的文章:https://www.cnblogs.com/shan333/p/16185323.html
- 掌握使用Linux命令部署项目,使用的就是方式3虚拟机运行centos的文章:https://www.cnblogs.com/shan333/p/16226229.html
动手敲一遍使用linux命令部署一个项目,到这里,就具备了linux的基本命令的掌握,足够学习docker等其他板块啦,遇到不会的动手百度或翻看手册。
ssh ip地址
ssh 121.5.151.236
,若是使用虚拟机运行centos,则ssh命令不用执行,这个ssh命令跳过。pwd
ifconfig
◇ 看到有网卡在工作中即可up、running
[root@mysql ~]# ifconfig
eth0: flags=4163<UP,BROADCAST,RUNNING,MULTICAST> mtu 1500
inet 192.168.0.111 netmask 255.255.255.0 broadcast 192.168.0.255
inet6 fe80::8c18:4c0c:35b:f89c prefixlen 64 scopeid 0x20<link>
ether 00:0c:29:bf:7a:4b txqueuelen 1000 (Ethernet)
RX packets 396 bytes 43132 (42.1 KiB)
RX errors 0 dropped 0 overruns 0 frame 0
TX packets 189 bytes 25028 (24.4 KiB)
TX errors 0 dropped 0 overruns 0 carrier 0 collisions 0
......
# eth0:网卡名称
# UP:表示网卡是开启状态
# BROADCAST:表示网卡支持广播
# RUNNING:表示网卡的网线已经被接上,在工作中
# MULTICAST:表示网卡支持组播
# Link encap:网卡的接口类型,这里是以太网
# HWaddr:网卡的硬件地址,俗称的MAC地址
# inet addr:IPv4地址,如果是IPv6会写成inet6 addr
# Bcast:广播地址
# Mask:子网掩码
# MTU:网络最大传输单元
# Metric:到达网关的度量值,参考:http://m.chinabyte.com/network/191/12287691_gfh.shtml
# RX packets:网络从启动到现在为止接收的数据包大小,单位是字节,error 发生错误的数据包,dropped 被丢弃的数据包
# TX packets:网络从启动到现在为止发送的数据包大小,单位是字节,error 发生错误的数据包,dropped 被丢弃的数据包
# collisions:发生碰撞的数据包,如果发生太多次,表明网络状况不太好
# txqueuelen:传输数据的缓冲区的储存长度
# RX bytes:总接收字节总量
# TX bytes:总发送字节总量
# Memory:网卡硬件的内存地址
free -h
参数详解
-h 以合适的单位显示内存使用情况,最大为三位数,自动计算对应的单位值
# total: 内存总数
# used: 已经使用内存数
# free: 完全空闲内存
# shared: 多个进程共享的内存
# buffers: 用于块设备数据缓冲,记录文件系统metadata(目录,权限,属性等)
# cached: 用于文件内容的缓冲
# available:真正剩余的可被程序应用的内存数
df -lh
# 参数详解
# Used:已经使用的空间
# Avail:可以使用的空间
# Mounted on:挂载的目录
mkdir code
cd code/
git clone https://gitee.com/yushanstar/code-shan-mp-server.git
问题:-bash: git: command not found
- 解决:给远程Linux系统(远程服务器)安装上git,命令:yum install -y git
- 然后继续执行拉取项目代码的命令,拉取完成之后,使用ls命令查看
cd code-shan-mp-server/
或cd code-shan-mp-server
进入项目目录 【cd 目录的/,可以加或不加】
ls
du -sh *
cat README.md
# 看到时一个java的springboot框架的项目---需要安装jdk
cat /etc/os-release
# 是rehat发行版的命令 # 看到时centos版本,那直接使用系统自带的软件管理器 yum
cat /etc/redhat-release
# 是debain发行版的命令
cat /etc/debian_version
yum install java-1.8.0-openjdk* -y
使用yum 安装jdk
java -version
which java
# Linux which命令用于查找文件。
# which指令会在环境变量$PATH设置的目录里查找符合条件的文件。
wget https://dlcdn.apache.org/maven/maven-3/3.8.5/binaries/apache-maven-3.8.5-bin.tar.gz
下载maven
问题:ERROR: cannot verify dlcdn.apache.org's certificate, issued by ‘/C=US/O=Let's Encrypt/CN=R3’:
Issued certificate has expired.
To connect to dlcdn.apache.org insecurely, use `--no-check-certificate'.
- 解决:报错证书问题,则安装证书: yum install -y ca-certificates
- 然后执行执行wget命令下载maven的安装包
ls
查看所有文件
tar -zxvf apache-maven-3.8.5-bin.tar.gz
./apache-maven-3.8.5/bin/mvn
解压后得到maven的二进制可执行文件
./apache-maven-3.8.5/bin/mvn --help
./apache-maven-3.8.5/bin/mvn install
构建maven项目
问题:[INFO] Scanning for projects…
[INFO] ------------------------------------------------------------------------
[INFO] BUILD FAILURE
解决:
更改maven镜像为阿里云镜像:
cd apache-maven-3.8.5/conf/ vim settings.xml # 更改maven镜像为阿里云镜像,找到<mirrors>,将原来的镜像<mirror> 注释掉,然后添加阿里云镜像
<mirror> <id>nexus-aliyun</id> <mirrorOf>*,!jeecg,!jeecg-snapshots</mirrorOf> <name>Nexus aliyun</name> <url>http://maven.aliyun.com/nexus/content/groups/public</url> </mirror> <mirror> <id>alimaven</id> <mirrorOf>central</mirrorOf> <name>aliyun maven</name> <url>http://maven.aliyun.com/nexus/content/repositories/central/</url> </mirror></code></pre></li>
然后退出回到目录code-shan-mp-server下【命令是 cd ../../】,重新执行一下maven的构建命令
find -name '*.jar*'
查找jar包位置
# find 将开始在当前目录(用"."表示)中查找任何扩展名为"java"的文件:
find . -name "*.java"
cp ./target/code-shan-mp-server-1.0.0.jar ./
将jar包复制到外面
mv code-shan-mp-server-1.0.0.jar code-shan.jar
ls
查看改名后情况
java -jar code-shan.jar
启动java的maven项目
# 浏览器查看项目运行情况
地址:服务器的ip:8080/hello
# 看到 hello,shan,则部署运行项目成功啦
不过此时咱的界面卡住了----使用后台启动项目
nohup java -jar code-shan.jar &
问题:命令:nohup java -jar code-nav.jar & 没能让项目跑起来【nohup java -jar 命令启动jar包,项目仍然会莫名其妙挂掉的解决方法】
出现:nohup: ignoring input and appending output to ‘nohup.out’
- 不是问题,这是一个提示信息,提示证明运行成功,同时把程序运行的输出信息放到当前目录的 nohup.out 文件中去。
# 查看程序是否跑起来
jobs
ps -ef
ps -ef|grep 'java'
# 从文件内容查找匹配指定字符串的行:
grep "被查找的字符串" 文件名
netstat -ntlp
curl localhost:8080/dog
# 看到hello,shan 则运行部署成功
[root@iZwz9535z41cmgcpkm7i81Z code-shan-mp-server]# curl localhost:8080/hello
hello,shan[root@iZwz9535z41cmgcpkm7i81Z code-shan-mp-server]#
clear
history
如果本文对你有帮助的话记得给一乐点个赞哦,感谢!
手机扫一扫
移动阅读更方便
你可能感兴趣的文章