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 | 移动到这个档案的最后一行(常用) |
nG | n 为数字。移动到这个档案的第 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] 亦即是退格键) (常用) |
nx | n 为数字,连续向后删除 n 个字符。举例来说,我要连续删除 10 个字符, 『10x』。 |
dd | 删除游标所在的那一整行(常用) |
ndd | n 为数字。删除光标所在的向下 n 行,例如 20dd 则是删除 20 行 (常用) |
d1G | 删除光标所在到第一行的所有数据 |
dG | 删除光标所在到最后一行的所有数据 |
d$ | 删除游标所在处,到该行的最后一个字符 |
d0 | 那个是数字的 0 ,删除游标所在处,到该行的最前面一个字符 |
yy | 复制游标所在的那一行(常用) |
nyy | n 为数字。复制光标所在的向下 n 行,例如 20yy 则是复制 20 行(常用) |
y1G | 复制游标所在行到第一行的所有数据 |
yG | 复制游标所在行到最后一行的所有数据 |
y0 | 复制光标所在的那个字符到该行行首的所有数据 |
y$ | 复制光标所在的那个字符到该行行尾的所有数据 |
p, P | p 为将已复制的数据在光标下一行贴上,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:三种软件安装方式及服务器基本环境搭建
-
确定你是CentOS7及以上版本
[root@192 Desktop]# cat /etc/redhat-release CentOS Linux release 7.2.1511 (Core)
-
yum安装gcc相关(需要确保 虚拟机可以上外网 )
yum -y install gcc yum -y install gcc-c++
-
卸载旧版本
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
-
安装需要的软件包
yum install -y yum-utils device-mapper-persistent-data lvm2
-
设置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
-
更新yum软件包索引
yum makecache fast
-
安装Docker CE
yum -y install docker-ce docker-ce-cli containerd.io
-
启动docker
systemctl start docker
-
测试
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重启