linux 常見的標識與Redis資料庫詳解
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 代表 游標移動到的行數
. : 重複上一個命令
/ : 從上到下搜尋
? : 從下到上搜索
搜尋到內容後,如果要查詢下一個,先按回車,在按 n / N
vim 編輯模式
從命令模式進入到編輯模式,需要按下
- i : 在游標所在的位置 前 插入資料
- a : 在游標所在的位置 後 插入資料
- o : 在游標所在行的 下一行(新的空白行)插入資料
如果從編輯模式要切換到 命令模式,則按下 ESC
vim 命令底線模式
從命令模式切換到命令底線模式 使用 :
即可
:w 儲存,不退出
:q 不儲存,退出(檔案未改變)
:wq 儲存並退出
:w! 強制寫入,針對只讀檔案
:q! 強制退出,(檔案被修改、且不儲存)
:wq! 強制儲存並退出
:set nu 顯示行數
:set nonu 關閉行數
檢視檔案
cat -n file
nl file
tail -f file : 主要用來做日誌的監控
檔案的複製
cp -r source dict : 拷貝目錄/檔案
-r : 用來拷貝目錄
-f : 強制性檔案拷貝
-i : 覆蓋的時候進行提示
兩個linux伺服器資料進行拷貝
將遠端伺服器的資料、拷貝到本地伺服器
scp [-r] user@host:檔案路徑 拷貝到本地路徑
將本地伺服器的資料、拷貝到遠端伺服器
scp [-r] 本地路徑 拷貝到 user@host:檔案路徑
檔案的移動
mv source dest
如果 dest 是一個目錄的話,是檔案的移動
如果 dest 是一個檔案的話, 是檔案的重新命名
檔案的許可權
r 讀 4
w 寫 2
x 可執行 1
chmod [-R ] 777 檔案/資料夾
u 使用者
g 組
o 其他
a 所有
chmod u+r 檔案
chmod u-r 檔案
更改檔案的所屬使用者
chown [-R] 使用者名稱[:組名] 檔案
新增組/使用者 groupadd,adduser,useradd
-- 新增一個 組 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
到此這篇關於linux 常見的標識與Redis資料庫的文章就介紹到這了,更多相關linux Redis資料庫內容請搜尋我們以前的文章或繼續瀏覽下面的相關文章希望大家以後多多支援我們!