当前位置: 首页 > news >正文

Linux一篇通

目录

基本操作

系统目录结构

基本命令

目录管理命令

基本属性

描述属性

修改属性命令

文件内容查看命令 **常用**

链接文件(了解)

VIM编辑器

使用流程

Vim 按键说明

账号管理

添加用户 useradd 

删除用户 userdel

修改用户 usermod

切换用户 su username

查看主机名 hostname

修改主机名 hostname 修改的名字

用户密码设置 passwd 用户名

锁定账户 passwd -l 用户名

用户组管理

创建用户组 groupadd

删除用户组 groupdel

修改用户组权限信息名字 groupmod

切换用户组

文件查看  了解

/etc/passwd

/etc/shadow

/etc/group

磁盘管理

进程管理

环境安装

jdk安装

Tomcat安装

Docker安装(yum安装)

宝塔面安装


基本操作

字体大小:Ctrl+滚轮改变页面字体大小

文件上传

下载安装Xftp后点击如下按钮

解压命令:unzip filename.zip

建文件夹:mkdir filename

移动文件:mv 文件 目标文件夹

清屏:clear

查看文件:ls

查看全部文件:ls -al

sync:同步数据到硬盘(需要强制关机的前置操作,避免数据丢失)

shutdown:关机

shutdowm -h 10 #几分钟后关机
shutdowm -h now  #立马关机
shutdowm -h 20:25 #在20:25关机

reboot:重启

系统目录结构

1,一切皆文件

2,根目录/,所有文件都挂在在整个节点下

/www:存放服务器网站相关的资源,环境,网站的项目

里面的mysql这些就是之前在宝塔里面自动安装的

基本命令

目录管理命令

cd+目录名(绝对路径/开头的,相对路径对于相对路径的寻找../../):切换目录命令

cd ..:返回上一级目录

./:当前目录

ls:列出目录(最常用)

-a参数:all,查看全部文件,包括隐藏文件
-l参数:列出素有文件,包含文件的属性和权限,没有隐藏文件,所有Linux可以组合使用
-al:又可以看到隐藏文件又可以看到权限(组合使用)

pwd:显示当前用户所在的目录

mkdir:创建一个目录

mkdir -p:创建层级目录(递归创建)

rmdir:删除目录

rmdir -p:文件夹有东西时不可删,需要强制删除 (递归删除)

cp 原 新:复制文件或目录

rm:移除文件或者目录

-f:忽略不存在的文件,不会出现警告,强制删除
-r:递归删除目录
-i:互动,删除询问是都删除
rm -rf /   系统中所有文件删除,慎用

mv 旧 新:移动目录或文件;重命名文件

-f:强制
-u:只替换已经更新过的文件

基本属性

描述属性

1,第一个字符

d:目录

-:文件

l:链接文档,后面会有对应的具体目录->

b:装置文件里面的可供储存的接口设备(可随机存取装置)

c:装置文件里面的串行端口设备,如键盘鼠标(一次性读取装置)

2,后面9个字符,三个一组,以rwx三个参数组合(顺序固定)

r:可读read,没有此权限则显示为-

w:可写write,没有此权限则显示为-

x:可执行execute,没有此权限则显示为-

3,后续个符号

属主:是谁创建的

修改属性命令

1,chgrp:更改文件属组

chgrp [-R] 属组名 文件名
-R:递归更改文件数组,就是在更改某个文件目录属组时,如果加上-R的参数,那么该文件的所有文件的数组都会改变

2,chown:更改文件属主

chown [-R] :属主名 文件名
chown [-R]:属主名: 属组名 文件名

3,chmod:更改文件9个属性****重点掌握****

chmod [-R] xyz 文件名或目录

Linux文件属性有两种设置方法,一种是数字(常用),一种是符号。

Linux文件的基本权限就有九个,分别是owner/group/others三种身份各有自己read/write/execute权限。

比如:文件的权限字符为:『-rwxrwxrwx』, 使用数字来代表各个权限,各权限的分数对照表如下:

r:4      w:2         x:1可读可写不可执行   rw-   6可读可写可执行      rwx    7chmod 777  文件赋予所有用户可读可写可执行权限

每种身份(owner/group/others)各自的三个权限(r/w/x)分数是需要累加的,例如当权限为:[-rwxrwx---] 分数则是:

owner = rwx = 4+2+1 = 7group = rwx = 4+2+1 = 7others= --- = 0+0+0 = 0chmod 770 filename

文件内容查看命令 **常用**

cat:从第一行开始显示文件内容
tac:从最后一行开始显示,通cat相反

nl:显示的时候,顺序输出行号(看代码的时候需要显示行号)

more:一页一页的显示文件余下的内容(点击空格代表翻页,enter代表向下看一行,:f看当前行号)
less:与more类似,但比more更好的是,可以往前翻页(空格下翻页,键盘上下键翻动页面)

退出使用q命令,

向下查找字符串:/ 字符串

向上查找字符串:?字符串

n 代表向下继续寻找下一个;N代表向上寻找下一个

head:只看头几行,-n参数来控制看几行
tail:只看尾巴几行

ping:同windows的ping(如果ping不会终止,可采用Ctrl + C来手动终止命令)ifconfig:同windows的config:查看网路配置

网络配置目录:/etc/sysconfig/network-scripte

链接文件(了解)

分类:硬连接、软连接

硬链接:一个文件的多个路径(地位平等),删除其中一个不会影响另一个,必须全部删完(所有硬链接),文件才会整整删除,可达到防止“误删”的功能 

软连接:相当与windows的快捷方式,实际文件删除了,快捷方式也就无用了,指向无效

源文件改变,对应的链接文件也会改变 

创建文件 touch f1创建硬链接 ln f1 f2创建软链接 ln -d f1 f3输入字符串 echo

VIM编辑器

模式分类分类:命令模式,输入模式,底线命令模式

使用流程

最开始进来便进入命令模式

i:切换到输入模式,可的输入字符x:删除当前光标所在处的字符::切换到底线命令模式,以在最底一行给输入命令(如果是编辑模式,需要先推退出编辑模式,esc退出)

输入模式下可用命令

字符按键以及Shift组合,输入字符ENTER,回车键,换行BACK SPACE,退格键,删除光标前一个字符DEL,删除键,删除光标后一个字符方向键,在文本中移动光标HOME/END,移动光标到行首/行尾Page Up/Page Down,上/下翻页Insert,切换光标为输入/替换模式,光标将变成竖线/下划线ESC,退出输入模式,切换到命令模式

底线命令模式可用命令(省略了冒号)

q 退出程序w 保存文件

参考视频及文档

狂神说Linux03:Vim使用及账号用户管理

10、Vim编辑器的使用_哔哩哔哩_bilibili

Vim 按键说明

除了上面简易范例的 i, Esc, :wq 之外,其实 vim 还有非常多的按键可以使用。

第一部分:一般模式可用的光标移动、复制粘贴、搜索替换等

移动光标的方法
h 或 向左箭头键(←)光标向左移动一个字符
j 或 向下箭头键(↓)光标向下移动一个字符
k 或 向上箭头键(↑)光标向上移动一个字符
l 或 向右箭头键(→)光标向右移动一个字符
[Ctrl] + [f]屏幕『向下』移动一页,相当于 [Page Down]按键 (常用)
[Ctrl] + [b]屏幕『向上』移动一页,相当于 [Page Up] 按键 (常用)
[Ctrl] + [d]屏幕『向下』移动半页
[Ctrl] + [u]屏幕『向上』移动半页
+光标移动到非空格符的下一行
-光标移动到非空格符的上一行
数字< space>那个 n 表示『数字』,例如 20 。按下数字后再按空格键,光标会向右移动这一行的 n 个字符。
0 或功能键[Home]这是数字『 0 』:移动到这一行的最前面字符处 (常用)
$ 或功能键[End]移动到这一行的最后面字符处(常用)
H光标移动到这个屏幕的最上方那一行的第一个字符
M光标移动到这个屏幕的中央那一行的第一个字符
L光标移动到这个屏幕的最下方那一行的第一个字符
G移动到这个档案的最后一行(常用)
nGn 为数字。移动到这个档案的第 n 行。例如 20G 则会移动到这个档案的第 20 行(可配合 :set nu)
gg移动到这个档案的第一行,相当于 1G 啊!(常用)
n< Enter>n 为数字。光标向下移动 n 行(常用)
搜索替换
/word向光标之下寻找一个名称为 word 的字符串。例如要在档案内搜寻 vbird 这个字符串,就输入 /vbird 即可!(常用)
?word向光标之上寻找一个字符串名称为 word 的字符串。
n这个 n 是英文按键。代表重复前一个搜寻的动作。举例来说, 如果刚刚我们执行 /vbird 去向下搜寻 vbird 这个字符串,则按下 n 后,会向下继续搜寻下一个名称为 vbird 的字符串。如果是执行 ?vbird 的话,那么按下 n 则会向上继续搜寻名称为 vbird 的字符串!
N这个 N 是英文按键。与 n 刚好相反,为『反向』进行前一个搜寻动作。例如 /vbird 后,按下 N 则表示『向上』搜寻 vbird 。
删除、复制与粘贴
x, X在一行字当中,x 为向后删除一个字符 (相当于 [del] 按键), X 为向前删除一个字符(相当于 [backspace] 亦即是退格键) (常用)
nxn 为数字,连续向后删除 n 个字符。举例来说,我要连续删除 10 个字符, 『10x』。
dd删除游标所在的那一整行(常用)
nddn 为数字。删除光标所在的向下 n 行,例如 20dd 则是删除 20 行 (常用)
d1G删除光标所在到第一行的所有数据
dG删除光标所在到最后一行的所有数据
d$删除游标所在处,到该行的最后一个字符
d0那个是数字的 0 ,删除游标所在处,到该行的最前面一个字符
yy复制游标所在的那一行(常用)
nyyn 为数字。复制光标所在的向下 n 行,例如 20yy 则是复制 20 行(常用)
y1G复制游标所在行到第一行的所有数据
yG复制游标所在行到最后一行的所有数据
y0复制光标所在的那个字符到该行行首的所有数据
y$复制光标所在的那个字符到该行行尾的所有数据
p, Pp 为将已复制的数据在光标下一行贴上,P 则为贴在游标上一行!举例来说,我目前光标在第 20 行,且已经复制了 10 行数据。则按下 p 后, 那 10 行数据会贴在原本的 20 行之后,亦即由 21 行开始贴。但如果是按下 P 呢?那么原本的第 20 行会被推到变成 30 行。(常用)
J将光标所在行与下一行的数据结合成同一行
c重复删除多个数据,例如向下删除 10 行,[ 10cj ]
u复原前一个动作。(常用)
[Ctrl]+r重做上一个动作。(常用)

第二部分:一般模式切换到编辑模式的可用的按钮说明

进入输入或取代的编辑模式
i, I进入输入模式(Insert mode):i 为『从目前光标所在处输入』, I 为『在目前所在行的第一个非空格符处开始输入』。(常用)
a, A进入输入模式(Insert mode):a 为『从目前光标所在的下一个字符处开始输入』, A 为『从光标所在行的最后一个字符处开始输入』。(常用)
o, O进入输入模式(Insert mode):这是英文字母 o 的大小写。o 为『在目前光标所在的下一行处输入新的一行』;O 为在目前光标所在处的上一行输入新的一行!(常用)
r, R进入取代模式(Replace mode):r 只会取代光标所在的那一个字符一次;R会一直取代光标所在的文字,直到按下 ESC 为止;(常用)
[Esc]退出编辑模式,回到一般模式中(常用)

第三部分:一般模式切换到指令行模式的可用的按钮说明

指令行的储存、离开等指令
:w将编辑的数据写入硬盘档案中(常用)
:w!若文件属性为『只读』时,强制写入该档案。不过,到底能不能写入, 还是跟你对该档案的档案权限有关啊!
:q离开 vi (常用)
:q!若曾修改过档案,又不想储存,使用 ! 为强制离开不储存档案。
注意一下啊,那个惊叹号 (!) 在 vi 当中,常常具有『强制』的意思~
:wq储存后离开,若为 :wq! 则为强制储存后离开 (常用)
ZZ这是大写的 Z 喔!若档案没有更动,则不储存离开,若档案已经被更动过,则储存后离开!
:w [filename]将编辑的数据储存成另一个档案(类似另存新档)
:r [filename]在编辑的数据中,读入另一个档案的数据。亦即将 『filename』 这个档案内容加到游标所在行后面
:n1,n2 w [filename]将 n1 到 n2 的内容储存成 filename 这个档案。
:! command暂时离开 vi 到指令行模式下执行 command 的显示结果!例如 『:! ls /home』即可在 vi 当中看 /home 底下以 ls 输出的档案信息!
:set nu(设置代码行号,代码中经常使用)显示行号,设定之后,会在每一行的前缀显示该行的行号
:set nonu与 set nu 相反,为取消行号!

账号管理

添加用户 useradd 

useradd -选项 用户名

-m 使用者目录如不存在则自动建立。

理解:Linux中一切皆文件。这里添加用户就是网某一个文件写入用户信息了! /etc/passwd

-c comment 指定一段注释性描述。-d 目录 指定用户主目录,如果此目录不存在,则同时使用-m选项,可以创建主目录。-g 用户组 指定用户所属的用户组。-G 用户组,用户组 指定用户所属的附加组。-m 使用者目录如不存在则自动建立。-s Shell文件 指定用户的登录Shell。-u 用户号 指定用户的用户号,如果同时有-o选项,则可以重复使用其他用户的标识号。

删除用户 userdel

userdel -r filename   -r删除用户的时候也将他的目录页一并删掉

修改用户 usermod

修改用户 usermod 对应修改内容 修改哪个用户

修改完毕查看配置文件

切换用户 su username

1.切换用户的命令为:su username 【username是你的用户名哦】

2.从普通用户切换到root用户,还可以使用命令:sudo su

3.在终端输入exit或logout或使用快捷方式ctrl+d,可以退回到原来用户,其实ctrl+d也是执行的exit命令

4.在切换用户时,如果想在切换用户之后使用新用户的工作环境,可以在su和username之间加-,例如:【su - root】

$表示普通用户

#表示超级用户,也就是root用户

查看主机名 hostname

修改主机名 hostname 修改的名字

(修改之后重新连接生效)

用户密码设置 passwd 用户名

设置成功后,同样的连接新建一个,换一个账号密码登录即可,不再用root去跳转

 

用新账号密码登录的

锁定账户 passwd -l 用户名

/etc/passwd里面就有所有账户

passwd -l 用户名    锁定账户

passwd -u 用户名    解锁账户

解锁后密码为空,可重新设置

passwd -d 用户名     删掉了用户的密码,也不可登录了

用户组管理

属主,属组

创建用户组 groupadd

创建完用户组可以得到一个组id,也可以指定id:[-g 520] 不指定就会自增(查看组  cat /etc/group)

删除用户组 groupdel

修改用户组权限信息名字 groupmod

groupmod -g (新id)-n(新名字) 原名字

-g:修改id

-n:改名字

切换用户组

登录当前用户

$newgrp root   换到root组

文件查看  了解

文档参考:狂神说Linux03:Vim使用及账号用户管理

/etc/passwd

用户名:口令(登录密码,我们不可见):用户标识号;组标识号:注释性描述:主目录:登录shell

/etc/shadow

登录口令真正的加密后的用户口令存放地址,保证密码安全性

/etc/group

用户组信息

磁盘管理

df:列出文件系统整体的磁盘使用量

-h:按照M或者G查看

du:检查磁盘看空间使用量

-a:可以看到子文件夹

du -sm /*

进程管理

ps:查看当前系统中正在执行的各种进程的信息

ps-xx|grep 进程名字     过滤进程信息

-a:显示当前终端运行的所有进程信息(当前一个进程)

-u:以用户的信息显示进程

-x:显示后台运行进程的参数

#ps -aux  查看所有进程ps -aux|grep mysql  查看myslq的进程
ps -aux|grep redis  查看redis的进程
ps -aux|grep java   查看java的进程#|  在Linux这个叫做管道符   A|B#grep 查找文件中符合条件的字符串

ps -ef:可以查到父进程信息

ps -ef|grep mysql #看父进程我们一般可以通过目录树结构来查看pstree -pu-p 显示父id-u 显示用户组

结束进程:杀掉进程

kill -9 进程id

环境安装

安装软件方式:

  • rpm(jdk:在线发布一个sptingboot项目)
  • 解压缩(tomcat:启动并通过外网访问,发布网站)
  • yum在线安装(docke:直接安装运行跑起来docker即可)

jdk安装

1,下载JDK的rpm   Java Downloads | Oracle 中国

下载完成后,直接通过ftp,上传到服务器

2,安装java环境

# 检测当前系统是否存在java环境! java -version
# 如果有的话先卸载
# rpm -qa|grep jdk    #检测JDK版本信息
# rpm -e --nodeps jdk_...(上调命令检测出来的信息直接复制过来)# 卸载完毕之后即可安装JDK
# rpm -ivh rpm包# 配置环境变量

如果已经存在,先卸载 

安装JDK

配置环境变量  /etc/profile/

先找到jdk的路径

进入/etc/profile/进行环境变量配置

配置完 esc  :wq保存退出,之后查看一下配置文件无误 cat /etc/profile

然后 java -version确认无误

JAVA_HOME=/usr/java/jdk1.8.0_152
CLASSPATH=%JAVA_HOME%/lib:%JAVA_HOME%/jre/lib
PATH=$PATH:$JAVA_HOME/bin:$JAVA_HOME/jre/bin
export PATH CLASSPATH JAVA_HOME

如果不小心把环境变量配置错了,会导致ls等多数命令失效

解决方案:

[root@localhost ~]#  export PATH=/usr/bin:/usr/sbin:/bin:/sbin:/usr/X11R6/bin

[root@localhost ~]# vi /etc/profile

将profile错误的环境变量修改回来即可

让配置文件生效  source /ect/profile

发布一个项目

拿到一个boot项目,clean-->package-->打包完成后target目录下拿到jar包-->先本地测试是否能跑起来(cmd---java -jar jar包)--->ftp上传到服务器---->(查看防火墙开启的端口有哪些 fireall-cmd --list-ports)如果没有端口,先开启端口(firewall-cmd --zone=public --add-port=999/tcp --permanent)--->重启才能看端口(systemctl restart firewalld.service)---->查看端口(如果是阿里云需要配置安全组规则)--->java -jar jar包--->访问(公网ip:项目端口)

Tomcat安装

1,下载tomcat 

2,解压:unzip filename.zip

3,启动tamcat:./startup.sh   (进入tamcatde bin目录,如果8080端口开了,且阿里云安全组也开了就可直接访问远程了)

可能会报没有权限。此时使用chomd 700 startup.sh修改权限即可

4,结束:./shotdown.sh

防火墙命令

# 查看firewall服务状态
systemctl status firewalld# 开启、重启、关闭、firewalld.service服务
# 开启
service firewalld start
# 重启
service firewalld restart
# 关闭
service firewalld stop# 查看防火墙规则
firewall-cmd --list-all    # 查看全部信息
firewall-cmd --list-ports  # 只看端口信息# 开启端口
开端口命令:firewall-cmd --zone=public --add-port=80/tcp --permanent
重启防火墙:systemctl restart firewalld.service命令含义:
--zone #作用域
--add-port=80/tcp  #添加端口,格式为:端口/通讯协议
--permanent   #永久生效,没有此参数重启后失效

确保防火墙端口开了(开启后,重启防火墙次啊生效),阿里云安全组配置了,输入服务器公网id:8080就可以看到如下界面

Docker安装(yum安装)

1,检测系统版本

2,安装准备环境

yum -y install 包名   #yum install 安装命令  -y  代表所有提示都为y

yum -y install gcc

yum -y install gcc-c++

3,清除以前的版本

 sudo dnf remove docker \docker-client \docker-client-latest \docker-common \docker-latest \docker-latest-logrotate \docker-logrotate \docker-engine

4,根据官网安装即可

CentOS | Docker Docs

参考文档狂神说Linux04:三种软件安装方式及服务器基本环境搭建

  1. 确定你是CentOS7及以上版本

    [root@192 Desktop]# cat /etc/redhat-release
    CentOS Linux release 7.2.1511 (Core)
  2. yum安装gcc相关(需要确保 虚拟机可以上外网 )

    yum -y install gcc
    yum -y install gcc-c++
  3. 卸载旧版本

    yum -y remove docker docker-common docker-selinux docker-engine
    # 官网版本
    yum remove docker \docker-client \docker-client-latest \docker-common \docker-latest \docker-latest-logrotate \docker-logrotate \docker-engine
  4. 安装需要的软件包

    yum install -y yum-utils device-mapper-persistent-data lvm2
  5. 设置stable镜像仓库

    # 错误
    yum-config-manager --add-repo https://download.docker.com/linux/centos/docker-ce.repo
    ## 报错
    [Errno 14] curl#35 - TCP connection reset by peer
    [Errno 12] curl#35 - Timeout# 正确推荐使用国内的
    yum-config-manager --add-repo http://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo
  6. 更新yum软件包索引

    yum makecache fast
  7. 安装Docker CE

    yum -y install docker-ce docker-ce-cli containerd.io
  8. 启动docker

    systemctl start docker
  9. 测试

    docker versiondocker run hello-worlddocker images

我遇到的问题,解决方式如下:

request canceled while waiting for connection (Client.Timeout exceeded while awaiting headers)

阿里云镜像加速配置 

sudo mkdir -p /etc/docker    #新建一个docker目录sudo tee /etc/docker/daemon.json <<-'EOF'
{"registry-mirrors": ["https://yxzrazem.mirror.aliyuncs.com"]
}
EOF    #在/daemon.json中配置一个阿里云地址sudo systemctl daemon-reload   #镜像重启sudo systemctl restart docker    #docker重启

宝塔面安装


http://www.mrgr.cn/news/78363.html

相关文章:

  • 良好的并发编程习惯之不可变(Immutability)
  • 鸿蒙征文|鸿蒙心路旅程:从零到一的探索与成长——我的HarmonyOS
  • WSL安装不同版本ubuntu(已有ubuntu20.04,再装ubuntu18.04)
  • 【四轴】利用PWM捕获解析接收机信号
  • HTML和CSS 表单、表格练习
  • JAVA题目笔记(二十)Stream流综合练习+方法引用
  • 【TQ2440】02 串口连接进入u-boot
  • 【CSS in Depth 2 精译_061】9.4 CSS 中的模式库 + 9.5 本章小结
  • pta 题目(3)
  • 服务器记录所有用户docker操作,监控删除容器/镜像的人
  • 自动化运维(k8s)之微服务信息自动抓取:namespaceName、deploymentName等全解析
  • ComfyUI节点安装笔记
  • 数据结构--图
  • 【NLP 3、深度学习简介】
  • 1-深度学习干货总结(持续更新)
  • Matlab Simulink HDL Coder FPGA开发初体验—计数器
  • 表征对齐在训练DiT模型中的重要性
  • 【算法 python A*算法的实现】
  • 某j,mybatis-plus,多租户,多表关联查询 ,主表不追加租户条件bug解决
  • element ui select绑定的值是对象的属性时,显示异常.
  • SAP学习
  • Android 图形系统之一:概览
  • 【Zookeeper】三,Zookeeper的安装与基本操作
  • 《Learning Three.js》学习(1)使用Three.js创建三维场景
  • ABAP OOALV模板
  • 蓝桥杯备赛笔记(一)