xxx@xxx:~$ :
第一个 xxx 只的是 用户名
第二个 xxx 代表的是 HOST主机
~ : 当前用户的根, 根的位置在 /home/用户名
$ : 代表当前用户是一个普通用户
# : 代表当前用户是超级用户
查看当前命令所在的位置
- pwd
文件夹/文件的常见命令
- mkdir
- ls
- rmdir
- rm
创建文件夹mkdir
mkdir test mkdir .test mkdir ~/test mkdir /home/xxx/test -- 递归的创建 test/a/b目录 mkdir -p test/a/b -v : 显示创建目录的信息
查看目录下的所有文件/文件夹 ls
-l : 以列表的形式格式化数据
drwxr-xr-x 2 xxx xxx 4096 9月 1 18:37 公共的 drwxr-xr-x 2 xxx xxx 4096 9月 1 18:37 模板 ... 第一列由10个字符组成,由 0-9 标识每一个字符 0 : d (文件夹) , - (文件), l (软连接) 1-3: 文件所属用户的权限 4-6: 文件所属用户组所在的权限 7-9: 其他用户所对应的权限 r : 读 w : 写 x : 可执行 第三列 代表文件所属用户 第四列 代表文件所属用户组
-a : 显示包含隐藏的文件 和 . 和 …
-A : 不显示 . 和 …
常见的命令
ls -l
ls -la
ls -ld
ll ==> ls -lap
删除文件夹 rmdir / rm
rmdir : 删除空目录
rmdir -p 路径 递归的删除空目录
rm 常见的参数
-f : 强制删除、忽略不存在 -i : 删除的时候、进行提示 -r : 递归的删除文件夹以及下面的所有的内容 -d : 删除空目录
rm -f
rm -rf
rm -i
rm -ri
PS: 禁止使用一个命令 rm -rf /
文件的基本操作
文件的创建
touch file : 新建一个空的文件
文件的编辑
- vi 编辑器
- vim 编辑器
sudo apt install vim
vim的三种操作模式
- 命令模式
- 编辑模式
- 命令底线模式
vim命令模式
当用户输入 vim 文件名
回车后、将自动进入命令模式
dd : 删除光标所在的行
xdd : x代表删除的行数
d$ : 从光标所在的位置删除到行的末尾
d0 : 从光标所在的位置删除到行的头部,不删除光标所在的位置
dG : 光标所在的位置,删除到底部
dxG : 从光标所在的位置,删除到指定的行
yy : 复制光标所在的行
xyy : x 代表复制的行数
y$ : 从光标所在的位置 复制到行的末尾
y0 : 从光标所在的位置 复制到行的头部
p : 粘贴
gg : 快速设置光标的位置到 文档的头部
G : 移动到文档的尾部
xG : x 代表 光标移动到的行数
. : 重复上一个命令
/ : 从上到下搜索
"htmlcode">
-- 添加一个 组 sudo groupadd test01 -- 删除一个 组 sudo groupdel test01 -- 创建一个 admin账户, 并设置了 该账户的主目录 sudo useradd -g test01 -d /home/admin -m admin -- 创建一个禁止登录的账户 (安装服务的比较常用) sudo useradd -s /bin/false admin (ubuntu) sudo useradd -s /sbin/nologin admin (centos) -- 把一个 用户 和 组进行关联 adduser 用户 组 # 查询 admin 用户的信息 id admin -- 删除用户 userdel -r admin usermod : 用来修改用户 groupmod : 用来修改组
其他命令
查看某个服务的进程信息
ps -ef | grep 某个服务的名字
杀死某个进程
sudo kill -9 pid
在 linux 搜索文件
sudo find / -name mysql*
Redis数据库
- Redis是一个NoSQL(非关系型数据库)
- Redis是一个基于内存的 KEY-VALUE 结构的数据库
- Redis是一个基于单线程的数据库
Redis支持的存储的数据类型
- String 字符串
- Hash 哈希
- List 列表
- Set 集合
- ZSet 有序集合
RDBMS
- 高度组织化结构化数据
- 结构化查询语言(SQL) (SQL)
- 数据和关系都存储在单独的表中。
- 数据操纵语言,数据定义语言
- 严格的一致性
- 基础事务
NoSQL
- 代表着不仅仅是SQL
- 没有声明性查询语言
- 没有预定义的模式
- 键 - 值对存储,列存储,文档存储,图形数据库
- 最终一致性,而非ACID属性
- 非结构化和不可预知的数据
- CAP定理
- 高性能,高可用性和可伸缩性
Linux安装 redis
自动安装
sudo apt install redis-server sudo systemctl restart redis sudo systemctl start redis sudo systemctl stop redis
手动安装
下载 redis安装包
wget http://download.redis.io/releases/redis-6.0.7.tar.gz
解压 redis-6.0.7.tar.gz 到 ~/app
tar -zxvf redis-6.0.7.tar.gz -C ~/app
先切换到 app目录
cd ~/app
创建一个软连接
ln -s ~/app/redis-6.0.7 ~/app/redis
编译 redis
-- 如果提示 make 不存在,则 安装 sudo apt install make -- 如果提示 /bin/sh: 1: cc: not found ,则需要安装 sudo apt install gcc make MALLOC=libc
将 redis的命令安装到 /usr/local/bin目录
sudo make install
启动 redis
redis-server ~/app/redis/redis.conf
通用命令
- 5种数据类型都支持的命令
- ttl : 查看某个键的剩余存活时间,单位是 秒,-2代表过期(不存在), -1 代表没有过期时间
- pttl : 查看某个键的剩余存活时间,单位是 毫秒
- keys * : 查看当前数据库下,所有的键
- del key : 删除键
- type : 查看键对应的类型
string命令
- set key value [ex seconds] [px milliseconds] [nx|xx]: 添加一个字符串
- setnx key value : key如果不存在,才添加 key-value
- mset key value key value … : 批量设置多个键值对数据
- getset key value : 将 key 设置为 value ,并返回 key的旧值
- get key : 根据键获取对应的值
- mget key… : 批量获取多个键对应的值
- getrange key start end : 获取key对应字符串的 范围
- strlen key : 获取 key 对应值的长度
- incr key : 对 key对应的值 + 1, 值必须是一个数字类型的字符串
- incrby key increment: 对 key对应的值 + increment, 值必须是一个数字类型的字符串
- decr key : 自减 1
- decrby key increment
- setex key seconds value : 添加一个字符串并设置过期时间,单位是秒
- psetex key milliseconds value : 添加一个字符串并设置过期时间,单位是毫秒
Hash命令
hset key field value : 添加一个字典、字典的键 field ,值是 value
hmset key field value [field value]… 批量添加字典中的键值对
hget key field : 获取字典中 field 对应的值
hgetall key : 获取 key 对应的字典
hkeys key : 获取 key对应的字典对应的所有的键
hvals key : 获取key 对应的字典对应的所有的值
hlen key : 获取字典对应的长度
hincrby key field increment : 将字典中对应 field属性的值自增 increment
hexists key field : 判断字典中是否存在 field属性
hdel key field : 删除字典中对应的 field 属性和值
list命令
lpush key val… : 向列表的头部插入数据
rpush key val… : 向列表的尾部插入数据
linsert key before/after ele val : 向 ele元素的前/后插入 val
lrange key start end : 查询从 start - end 区间的 数据、
lindex key index : 查询 index位置的元素
lset key index ele : 修改index位置的元素为 ele
lpop key : 删除第一个元素
rpop key : 删除最后一个元素
lrem key count val :
count = 0 : 删除列表中所有的 valcount > 0 : 从列表的头部删除 count 个 valcount < 0 : 从列表的尾部删除 count个 val
llen key : 获取列表长度
ltrim key start end : 截取列表中从start -end 之间的元素,返回列表
set命令 sadd key member… : 添加成员smembers key : 查看集合中所有的成员srem key member … : 删除指定的成员spop key [count] : 随机从集合中删除 count个成员,如果不指定 count ,默认是1scard key : 获取集合的长度sismember key member : 判断 member 是否是集合中的成员srandmember key [count] : 随机从集合中 返回 count个成员
zset命令
zadd key score member [score member]… : 向集合中添加成员和分数、分数是一个double 类型,用来进行排序
zrange key start end [withscores] : 升序查询所有的成员
zrevrange key start end [withscores] : 降序查询所有的成员
zrangebyscore key min max : 升序查询分数在 min-max 之间的所有成员
zrevrangebyscore key max min : 降序查询分数在 min-max 之间的所有成员
zrank key member : 查询成员在集合中的索引位置
zrevrank key member : 查询某个成员在集合中的排名,从0开始
zscore key member : 查询某个成员的分数
zcount key min max : 查询分数在min-max之间的人数
zcard key : 获取成员数量
zrem key member… : 删除集合中的指定成员
zremrangebyscore key min max : 移除成绩在 min-max之间的所有成员
zremrangebyrank key start stop : 移除排名从 start-stop之间的所有成员
zrangebylex key min max: 要求有序集合中所有的成员分数相同
min -
代表最小值, (
代表不包含 [
代表包含
max +
代表最大值, (
代表不包含 [
代表包含
zrangebylex zset - + : 查询集合中所有数据 zrangebylex zset (a [d : 查询集合 大于 a 小于等于d zrangebylex zset [a (d : 查询集合 大于等 a 小于d