主頁 > 作業系統 > 行程管理

行程管理

2020-10-02 01:46:42 作業系統

關于行程 process

====================================================================================
What is a process? 什么是行程
Process life cycle 行程的生命周期
Process states 行程狀態

什么是行程?
行程是已啟動的可執行程式的運行實體,行程有以下組成部分:
? 已分配記憶體的地址空間;
? 安全屬性,包括所有權憑據和特權;
? 程式代碼的一個或多個執行執行緒;
? 行程狀態,
程式: 二進制檔案,靜態 /bin/date, /usr/sbin/httpd,/usr/sbin/sshd, /usr/local/nginx/sbin/ngix
行程: 是程式運行的程序, 動態,有生命周期及運行狀態,

行程的生命周期

父行程復制自己的地址空間(fork)創建一個新的(子)行程結構,每個新行程分配一個唯一的行程 ID (PID),滿足跟蹤安全性
之需,PID 和 父行程 ID (PPID)是子行程環境的元素,任何行程都可以創建子行程,所有行程都是第一個系統行程的后代:
Centos5/6: init
Centos7: systemd

子行程繼承父行程的安全性身份、過去和當前的檔案描述符、埠和資源特權、環境變數,以及程式代碼,隨后,子行程可能exec
自己的程式代碼,通常,父行程在子行程運行期間處于睡眠(sleeping)狀態,當子行程完成時發出(exit)信號請求,在退出時,
子行程已經關倍訓丟棄了其資源環境,剩余的部分稱之為僵停(僵尸Zombie),父行程在子行程退出時收到信號而被喚醒,清理剩
余的結構,然后繼續執行其自己的程式代碼,

行程狀態
在多任務處理作業系統中,每個CPU(或核心)在一個時間點上只能處理一個行程,在行程運行時,它對CPU 時間和資源分配的要求
會不斷變化,從而為行程分配一個狀態,它隨著環境要求而改變,

 

查看行程Process

了解如行程的:
? PID,PPID
? 當前的行程狀態
? 記憶體的分配情況
? CPU和已花費的實際時間
? 用戶UID,它決定行程的特權

靜態查看行程 ps
注:ps -aux 不同于 ps aux

[root@CentOS7 ~]# ps aux |less
USER PID %CPU %MEM VSZ RSS TTY STAT START TIME COMMAND
root 1 0.0 0.0 2164 648 ? Ss 08:47 0:00 init [5]

USER: 運行行程的用戶
PID: 行程ID
%CPU: CPU占用率
%MEM: 記憶體占用率
VSZ: 占用虛擬記憶體
RSS: 占用實際記憶體 駐留記憶體
TTY: 行程運行的終端
STAT: 行程狀態 man ps (/STATE)
R 運行
S 可中斷睡眠 Sleep
D 不可中斷睡眠
T 停止的行程
Z 僵尸行程
X 死掉的行程

Ss s行程的領導者,父行程
S< <優先級較高的行程
SN N優先級較低的行程
R+ +表示是前臺的行程組
Sl 以執行緒的方式運行
START: 行程的啟動時間
TIME: 行程占用CPU的總時間
COMMAND: 行程檔案,行程名

[root@CentOS7 ~]# ps aux --sort %cpu |less
[root@CentOS7 ~]# ps aux --sort -%cpu |less
[root@CentOS7 ~]# ps aux --sort rss |less
[root@CentOS7 ~]# ps aux --sort -rss |less

[alice@CentOS7 ~]$ sudo yum -y install httpd
[alice@CentOS7 ~]$ sudo systemctl start httpd
[root@CentOS7 ~]# ps auxf |grep httpd
root 9279 0.0 0.0 4264 672 pts/1 S+ 14:37 0:00 \_ grep httpd
root 8310 0.0 0.1 10092 2912 ? Ss 14:19 0:00 /usr/sbin/httpd
apache 8311 0.0 0.0 10092 2060 ? S 14:19 0:00 \_ /usr/sbin/httpd
apache 8312 0.0 0.0 10092 2060 ? S 14:19 0:00 \_ /usr/sbin/httpd
apache 8313 0.0 0.0 10092 2060 ? S 14:19 0:00 \_ /usr/sbin/httpd
apache 8314 0.0 0.0 10092 2060 ? S 14:19 0:00 \_ /usr/sbin/httpd
apache 8315 0.0 0.0 10092 2060 ? S 14:19 0:00 \_ /usr/sbin/httpd
apache 8316 0.0 0.0 10092 2060 ? S 14:19 0:00 \_ /usr/sbin/httpd
apache 8318 0.0 0.0 10092 2060 ? S 14:19 0:00 \_ /usr/sbin/httpd
apache 8319 0.0 0.0 10092 2060 ? S 14:19 0:00 \_ /usr/sbin/httpd

[root@CentOS7 ~]# ps -ef
UID PID PPID C STIME TTY TIME CMD
root 1 0 0 08:47 ? 00:00:00 init [5]

//自定義顯示欄位
[root@CentOS7 ~]# ps axo user,pid,ppid,%mem,command
[root@CentOS7 ~]# ps axo user,pid,ppid,%mem,command |grep httpd
root 8310 1 0.1 /usr/sbin/httpd
apache 8311 8310 0.0 /usr/sbin/httpd
apache 8312 8310 0.0 /usr/sbin/httpd
apache 8313 8310 0.0 /usr/sbin/httpd
apache 8314 8310 0.0 /usr/sbin/httpd
apache 8315 8310 0.0 /usr/sbin/httpd
apache 8316 8310 0.0 /usr/sbin/httpd
apache 8318 8310 0.0 /usr/sbin/httpd
apache 8319 8310 0.0 /usr/sbin/httpd
root 9236 6798 0.0 grep httpd
[root@CentOS7 ~]# ps axo user,pid,ppid,%mem,%cpu,command --sort -%cpu |less

//查看指定行程的PID
[yang@iZm5eiwihahzq6ds23gbf6Z ~]$ cat /run/sshd.pid
830
[root@CentOS7 ~]# ps aux |grep sshd
root 10180 0.0 0.0 7224 1024 ? Ss 16:00 0:00 /usr/sbin/sshd
[root@CentOS7 ~]# pgrep -l sshd
10180 sshd
[root@CentOS7 ~]# pgrep sshd
10180
[root@CentOS7 ~]# pidof sshd
10180

//查看行程樹
[root@CentOS7 ~]# pstree

動態查看行程 top
[root@CentOS7 ~]# top
[root@CentOS7 ~]# top -d 1
[root@CentOS7 ~]# top -d 1 -p 10126 查看指定行程的動態資訊
[root@CentOS7 ~]# top -d 1 -p 10126,1
[root@CentOS7 ~]# top -d 1 -u apache 查看指定用戶的行程
[root@CentOS7 ~]# top -d 1 -b -n 2 > top.txt 將2次top資訊寫入到檔案

第一部分:系統整體統計資訊
top - 14:15:04 up 47 min, 2 users, load average: 0.25, 0.18, 0.12
Tasks: 235 total, 1 running, 234 sleeping, 0 stopped, 0 zombie
Cpu(s): 8.9%us, 1.0%sy, 0.0%ni, 90.1%id, 0.0%wa, 0.0%hi, 0.0%si, 0.0%st
Mem: 7944064k total, 746164k used, 7197900k free, 35724k buffers
Swap: 1048568k total, 0k used, 1048568k free, 261492k cached

load average: 0.86, 0.56, 0.78 系統最近 1分鐘,5分鐘,15分鐘平均負載

第二部分:行程資訊
命令
h|?幫助
M 按記憶體的使用排序
P 按CPU使用排序
N 以PID的大小排序
R 對排序進行反轉
f 自定義顯示欄位
1 顯示所有CPU的負載

< 向前
> 向后
z 彩色
W 保存top環境設定

使用信號控制行程

kill,killall,pkill,top

給行程發送信號
[root@CentOS7 ~]# kill -l //列出所有支持的信號
編號 信號名
1) SIGHUP 重新加載配置
2) SIGINT 鍵盤中斷^C
3) SIGQUIT 鍵盤退出
9) SIGKILL 強制終止
15) SIGTERM 終止(正常結束),預設信號
18) SIGCONT 繼續
19) SIGSTOP 停止
20)SIGTSTP 暫停^Z

1: 給vsftpd行程發送信號1,15
[root@CentOS7 ~]# ps aux |grep vsftpd
root 9160 0.0 0.0 52580 904 ? Ss 21:54 0:00 /usr/sbin/vsftpd /etc/vsftpd/vsftpd.conf
[root@CentOS7 ~]# kill -1 9160 //發送重啟信號
root 9160 0.0 0.0 52580 904 ? Ss 21:54 0:00 /usr/sbin/vsftpd /etc/vsftpd/vsftpd.conf

[root@CentOS7 ~]# kill 9160 //發送停止信號
[root@CentOS7 ~]# ps aux |grep vsftpd

//1
[yang@iZm5eiwihahzq6ds23gbf6Z ~]$ ps aux |grep crond
root 478 0.0 0.1 124144 1572 ? Ss 09:35 0:00 /usr/sbin/crond -n
[yang@iZm5eiwihahzq6ds23gbf6Z ~]$ sudo kill -1 478
[yang@iZm5eiwihahzq6ds23gbf6Z ~]$ ps aux |grep crond
root 478 0.0 0.1 124144 1572 ? Ss 09:35 0:00 /usr/sbin/crond -n

//15
[yang@iZm5eiwihahzq6ds23gbf6Z ~]$ sudo kill 478
[yang@iZm5eiwihahzq6ds23gbf6Z ~]$ ps aux |grep crond
[yang@iZm5eiwihahzq6ds23gbf6Z ~]$ sudo systemctl start crond
[yang@iZm5eiwihahzq6ds23gbf6Z ~]$ ps aux |grep crond
root 22319 0.0 0.1 124140 1548 ? Ss 14:54 0:00 /usr/sbin/crond -n

2:信號測驗9,15
[root@CentOS7 ~]# touch file1 file2
[root@CentOS7 ~]# tty
/dev/pts/1
[root@CentOS7 ~]# vim file1

[root@CentOS7 ~]# tty
/dev/pts/2
[root@CentOS7 ~]# vim file2

[root@CentOS7 ~]# ps aux |grep vim
root 4362 0.0 0.2 11104 2888 pts/1 S+ 23:02 0:00 vim file1
root 4363 0.1 0.2 11068 2948 pts/2 S+ 23:02 0:00 vim file2

[root@CentOS7 ~]# kill 4362
[root@CentOS7 ~]# kill -9 4363

[root@CentOS7 ~]# killall vim //給所有vim行程發送信號
[root@CentOS7 ~]# killall httpd

3:信號測驗18,19
[root@CentOS7 ~]# ps aux |grep sshd
root 5571 0.0 0.0 64064 1164 ? Ss 09:35 0:00 /usr/sbin/sshd

[root@CentOS7 ~]# kill -STOP 5571
[root@CentOS7 ~]# ps aux |grep sshd
root 5571 0.0 0.0 64064 1164 ? Ts 09:35 0:00 /usr/sbin/sshd

[root@CentOS7 ~]# kill -cont 5571
[root@CentOS7 ~]# ps aux |grep sshd
root 5571 0.0 0.0 64064 1164 ? Ss 09:35 0:00 /usr/sbin/sshd

[yang@iZm5eiwihahzq6ds23gbf6Z ~]$ ps aux |grep crond
root 22319 0.0 0.1 124140 1568 ? Ss 14:54 0:00 /usr/sbin/crond -n
yang 22427 0.0 0.0 112648 964 pts/2 R+ 15:07 0:00 grep --color=auto crond
[yang@iZm5eiwihahzq6ds23gbf6Z ~]$
[yang@iZm5eiwihahzq6ds23gbf6Z ~]$ sudo kill -19 22319
[yang@iZm5eiwihahzq6ds23gbf6Z ~]$ ps aux |grep crond
root 22319 0.0 0.1 124140 1568 ? Ts 14:54 0:00 /usr/sbin/crond -n
yang 22431 0.0 0.0 112648 964 pts/2 R+ 15:07 0:00 grep --color=auto crond
[yang@iZm5eiwihahzq6ds23gbf6Z ~]$
[yang@iZm5eiwihahzq6ds23gbf6Z ~]$ sudo kill -cont 22319
[yang@iZm5eiwihahzq6ds23gbf6Z ~]$ ps aux |grep crond
root 22319 0.0 0.1 124140 1568 ? Ss 14:54 0:00 /usr/sbin/crond -n
yang 22436 0.0 0.0 112648 960 pts/2 R+ 15:08 0:00 grep --color=auto crond

踢出一個從遠程登錄到本機的用戶
[root@CentOS7 ~]# pkill --help
pkill: invalid option -- '-'
Usage: pkill [-SIGNAL] [-fvx] [-n|-o] [-P PPIDLIST] [-g PGRPLIST] [-s SIDLIST]
[-u EUIDLIST] [-U UIDLIST] [-G GIDLIST] [-t TERMLIST] [PATTERN]
[root@CentOS7 ~]# pkill -u alice

[root@CentOS7 ~]# w
15:46:44 up 2:19, 4 users, load average: 0.17, 0.12, 0.08
USER TTY FROM LOGIN@ IDLE JCPU PCPU WHAT
root tty1 :0 21:32 ? 4:22 4:22 /usr/bin/Xorg :
root pts/0 :0.0 15:46 0.00s 0.00s 0.00s w
root pts/3 172.16.8.100 15:46 2.00s 0.01s 0.00s sleep 50000

[yang@iZm5eiwihahzq6ds23gbf6Z ~]$ w
15:17:25 up 5:42, 3 users, load average: 0.00, 0.01, 0.05
USER TTY FROM LOGIN@ IDLE JCPU PCPU WHAT
yang pts/0 123.120.22.32 15:00 21.00s 0.00s 0.00s -bash
yang pts/1 123.120.22.32 15:00 5.00s 0.00s 0.00s w
yang pts/2 123.120.22.32 12:04 13.00s 0.12s 0.02s vim file1
[yang@iZm5eiwihahzq6ds23gbf6Z ~]$ pkill -t pts/2 //終止pts/2上所有行程
[yang@iZm5eiwihahzq6ds23gbf6Z ~]$ pkill -9 -t pts/2 //終止pts/2上所有行程 并結束該pts/2

[yang@iZm5eiwihahzq6ds23gbf6Z ~]$ w
15:20:59 up 5:45, 3 users, load average: 0.00, 0.01, 0.05
USER TTY FROM LOGIN@ IDLE JCPU PCPU WHAT
yang pts/0 123.120.22.32 15:00 3:55 0.00s 0.00s -bash
yang pts/1 123.120.22.32 15:00 3.00s 0.01s 0.00s w
yang pts/2 123.120.22.32 15:20 3.00s 0.00s 0.00s -bash
[yang@iZm5eiwihahzq6ds23gbf6Z ~]$ sudo pkill -u yang

行程優先級nice

Linux 行程調度及多任務
相對優先級nice
查看行程的nice級別
啟動具有不同nice級別的行程
更改現有行程的nice級別


Linux 行程調度及多任務
每個CPU(或CPU核心)在一個時間點上只能處理一個行程,通過時間片技術,Linux實際能夠運行的行程(和執行緒數)可以超
出實際可用的CPU及核心數量,Linux內核行程調度程式將多個行程在CPU核心上快速切換,從而給用戶多個行程在同時運行的印象,


相對優先級 nice
由于不是每個行程都與其他行程同樣重要,可告知行程調度程式為不同的行程使用不同的調度策略,常規系統上運行的大多
數行程所使用的調度策略為 SCHED_OTHER (也稱為SCHED_NORMAL),但還有其它一些調度策略用于不同的目的,

SCHED_OTHER 調度策略運行的行程的相對優先級稱為行程的 nice 值,可以有40種不同級別的nice值,

 

 

nice 值越高: 表示優先級越低,例如+19,該行程容易將CPU 使用量讓給其他行程,
nice 值越低: 表示優先級越高,例如-20,該行程更不傾向于讓出CPU,

查看行程的nice級別
1. 使用top查看nice級別
NI: 實際nice級別
PR: 將nice級別顯示為映射到更大優先級佇列,-20映射到0,+19映射到39

3. 使用ps查看nice級別
[root@CentOS7 ~]# ps axo pid,command,nice --sort=-nice
[root@CentOS7 ~]# ps axo pid,command,nice,cls --sort=-nice
TS 表示該行程使用的調度策略為SCHED_OTHER

啟動具有不同nice級別的行程
啟動行程時,通常會繼承父行程的 nice級別,默認為0,
[root@CentOS7 ~]# nice -n -5 sleep 6000 &
[root@CentOS7 ~]# ps axo command,pid,nice |grep sleep

[root@CentOS7 ~]# nice -n -20 systemctl start httpd
[root@CentOS7 ~]# ps axo pid,command,nice,cls |grep httpd
11116 /usr/sbin/httpd -20 TS
11119 /usr/sbin/httpd -20 TS
11120 /usr/sbin/httpd -20 TS
11121 /usr/sbin/httpd -20 TS
11122 /usr/sbin/httpd -20 TS
11123 /usr/sbin/httpd -20 TS
11124 /usr/sbin/httpd -20 TS
11125 /usr/sbin/httpd -20 TS
11126 /usr/sbin/httpd -20 TS

更改現有行程的nice級別
1. 使用top更改nice級別
r 調整行程的優先級(Nice Level) (-20高) ---0--- (19低)

2. 使用shell更改nice級別
[root@CentOS7 ~]# sleep 7000 &
[3] 10089
[root@CentOS7 ~]# renice -20 10089
10089: old priority 0, new priority -20

控制 jobs

控制是一個命令列功能,允許一個shell 實體來運行和管理多個命令,
如果沒有控制,父行程fork()一個子行程后,將sleeping,直到子行程退出,
使用控制,可以選擇性暫停,恢復,以及異步運行命令,讓 shell 可以在子行程運行期間回傳接受其他命令,

foreground, background, and controlling terminal

foreground: 前臺行程是在終端中運行的命令,該終端為行程的控制終端,前臺行程接收鍵盤產生的輸入和信號,并允許從終端讀取或寫入到終端,
background: 后臺行程沒有控制終端,它不需要終端的互動,

示例1:
[root@CentOS7 ~]# sleep 3000 & //運行程式(時),讓其在后臺執行
[root@CentOS7 ~]# sleep 4000 //^Z,將前臺的程式掛起(暫停)到后臺
[2]+ Stopped sleep 4000

[root@CentOS7 ~]# ps aux |grep sleep
root 8895 0.0 0.0 100900 556 pts/0 S 12:13 0:00 sleep 3000
root 8896 0.0 0.0 100900 556 pts/0 T 12:13 0:00 sleep 4000

[root@CentOS7 ~]# jobs //查看后臺
[1]- Running sleep 3000 &
[2]+ Stopped sleep 4000

[root@CentOS7 ~]# bg %2 //讓2在后臺運行
[root@CentOS7 ~]# fg %1 //將1調回到前臺
[root@CentOS7 ~]# kill %1 //kill 1,終止PID為1的行程
[root@CentOS7 ~]# (while :; do date; sleep 2; done) & //行程在后臺運行,但輸出依然在當前終端
[root@CentOS7 ~]# (while :; do date; sleep 2; done) &>/dev/null &

示例2:如何管理遠程主機
[root@CentOS7 ~]# ssh 172.16.50.240
[root@www ~]# yum -y install screen
[root@www ~]# screen -S install_apache

==斷網后,重新連接==
[root@www ~]# screen -list
There are screens on:
28958.install_nginx (Detached)
29013.install_apache (Detached)
2 Sockets in /var/run/screen/S-root.
[root@www ~]# screen -r 29013

proc 檔案系統


虛擬檔案系統: 內核、行程運行的狀態資訊
[root@CentOS7 ~]# du -sh /proc
0 /proc

/proc/cpuinfo
[root@CentOS7 ~]# grep 'processor' /proc/cpuinfo //邏輯cpu的個數
processor : 0
processor : 1
[root@CentOS7 ~]# grep 'physical id' /proc/cpuinfo //物理cpu的個數
physical id : 0
physical id : 0
==flags
lm(64位)
vmx 支持虛擬化 Intel
svm 支持虛擬化 AMD
[root@CentOS7 ~]# egrep 'lm|vmx|svm' /proc/cpuinfo
flags : fpu vme de clflush dts acpi lm constant_tsc pni monitor ds_cpl vmx est tm2 ssse3 cx16 xtpr lahf_lm
flags : fpu vme de clflush dts acpi lm constant_tsc pni monitor ds_cpl vmx est tm2 ssse3 cx16 xtpr lahf_lm

[root@CentOS7 ~]# lscpu
Architecture: x86_64
CPU op-mode(s): 32-bit, 64-bit
CPU(s): 4
On-line CPU(s) list: 0-3
Thread(s) per core: 2
Core(s) per socket: 2

Socket(s): 1
Virtualization: VT-x
L1d cache: 32K
L1i cache: 32K
L2 cache: 256K
L3 cache: 3072K
NUMA node0 CPU(s): 0-3

/proc/meminfo
[root@CentOS7 ~]# less /proc/meminfo
[root@CentOS7 ~]# free -m
total used free shared buff/cache available
Mem: 7950 704 6540 100 705 6908
Swap: 2047 0 2047

/proc/cmdline //內核啟動引數
[root@CentOS7 ~]# cat /proc/cmdline
BOOT_IMAGE=/vmlinuz-3.10.0-327.el7.x86_64 root=UUID=9b17ab4e-cd93-4f84-bd1e-7241a0baac9b ro rhgb quiet LANG=zh_CN.UTF-8

uptime
[root@CentOS7 ~]# uptime
17:20:58 up 8:33, 3 users, load average: 0.43, 0.36, 0.36

[root@CentOS7 ~]# cat /proc/sys/net/ipv4/ip_forward
1
[root@CentOS7 ~]# echo 0 > /proc/sys/net/ipv4/ip_forward
[root@CentOS7 ~]# cat /proc/sys/net/ipv4/ip_forward
0


















nice

轉載請註明出處,本文鏈接:https://www.uj5u.com/caozuo/146874.html

標籤:Linux

上一篇:使用VMware安裝CentOS 7

下一篇:存盤管理

標籤雲
其他(157675) Python(38076) JavaScript(25376) Java(17977) C(15215) 區塊鏈(8255) C#(7972) AI(7469) 爪哇(7425) MySQL(7132) html(6777) 基礎類(6313) sql(6102) 熊猫(6058) PHP(5869) 数组(5741) R(5409) Linux(5327) 反应(5209) 腳本語言(PerlPython)(5129) 非技術區(4971) Android(4554) 数据框(4311) css(4259) 节点.js(4032) C語言(3288) json(3245) 列表(3129) 扑(3119) C++語言(3117) 安卓(2998) 打字稿(2995) VBA(2789) Java相關(2746) 疑難問題(2699) 细绳(2522) 單片機工控(2479) iOS(2429) ASP.NET(2402) MongoDB(2323) 麻木的(2285) 正则表达式(2254) 字典(2211) 循环(2198) 迅速(2185) 擅长(2169) 镖(2155) 功能(1967) .NET技术(1958) Web開發(1951) python-3.x(1918) HtmlCss(1915) 弹簧靴(1913) C++(1909) xml(1889) PostgreSQL(1872) .NETCore(1853) 谷歌表格(1846) Unity3D(1843) for循环(1842)

熱門瀏覽
  • CA和證書

    1、在 CentOS7 中使用 gpg 創建 RSA 非對稱密鑰對 gpg --gen-key #Centos上生成公鑰/密鑰對(存放在家目錄.gnupg/) 2、將 CentOS7 匯出的公鑰,拷貝到 CentOS8 中,在 CentOS8 中使用 CentOS7 的公鑰加密一個檔案 gpg -a ......

    uj5u.com 2020-09-10 00:09:53 more
  • Kubernetes K8S之資源控制器Job和CronJob詳解

    Kubernetes的資源控制器Job和CronJob詳解與示例 ......

    uj5u.com 2020-09-10 00:10:45 more
  • VMware下安裝CentOS

    VMware下安裝CentOS 一、軟硬體準備 1 Centos鏡像準備 1.1 CentOS鏡像下載地址 下載地址 1.2 CentOS鏡像下載程序 點擊下載地址進入如下圖的網站,選擇需要下載的版本,這里選擇的是Centos8,點擊如圖所示。 決定選擇Centos8后,選擇想要的鏡像源進行下載,此 ......

    uj5u.com 2020-09-10 00:12:10 more
  • 如何使用Grep命令查找多個字串

    如何使用Grep 命令查找多個字串 大家好,我是良許! 今天向大家介紹一個非常有用的技巧,那就是使用 grep 命令查找多個字串。 簡單介紹一下,grep 命令可以理解為是一個功能強大的命令列工具,可以用它在一個或多個輸入檔案中搜索與正則運算式相匹配的文本,然后再將每個匹配的文本用標準輸出的格式 ......

    uj5u.com 2020-09-10 00:12:28 more
  • git配置http代理

    git配置http代理 經常遇到克隆 github 慢的問題,這里記錄一下幾種配置 git 代理的方法,解決 clone github 過慢。 目錄 git配置代理 git單獨配置github代理 git配置全域代理 配置終端環境變數 git配置代理 主要使用 git config 命令 git單獨 ......

    uj5u.com 2020-09-10 00:12:33 more
  • Linux npm install 裝包時提示Error EACCES permission denied解

    npm install 裝包時提示Error EACCES permission denied解決辦法 ......

    uj5u.com 2020-09-10 00:12:53 more
  • Centos 7下安裝nginx,使用yum install nginx,提示沒有可用的軟體包

    Centos 7下安裝nginx,使用yum install nginx,提示沒有可用的軟體包。 18 (flaskApi) [root@67 flaskDemo]# yum -y install nginx 19 已加載插件:fastestmirror, langpacks 20 Loading ......

    uj5u.com 2020-09-10 00:13:13 more
  • Linux查看服務器暴力破解ssh IP

    在公網的服務器上經常遇到別人爆破你服務器的22埠,用來挖礦或者干其他嘿嘿嘿的事情~ 這種情況下正確的做法是: 修改默認ssh的22埠 使用設定密鑰登錄或者白名單ip登錄 建議服務器密碼為復雜密碼 創建普通用戶登錄服務器(root權限過大) 建立堡壘機,實作統一管理服務器 統計爆破IP [root ......

    uj5u.com 2020-09-10 00:13:17 more
  • CentOS 7系統常見快捷鍵操作方式

    Linux系統中一些常見的快捷方式,可有效提高操作效率,在某些時刻也能避免操作失誤帶來的問題。 ......

    uj5u.com 2020-09-10 00:13:31 more
  • CentOS 7作業系統目錄結構介紹

    作業系統存在著大量的資料檔案資訊,相應檔案資訊會存在于系統相應目錄中,為了更好的管理資料資訊,會將系統進行一些目錄規劃,不同目錄存放不同的資源。 ......

    uj5u.com 2020-09-10 00:13:35 more
最新发布
  • vim的常用命令

    Vim的6種基本模式 1. 普通模式在普通模式中,用的編輯器命令,比如移動游標,洗掉文本等等。這也是Vim啟動后的默認模式。這正好和許多新用戶期待的操作方式相反(大多數編輯器默認模式為插入模式)。 2. 插入模式在這個模式中,大多數按鍵都會向文本緩沖中插入文本。大多數新用戶希望文本編輯器編輯程序中一 ......

    uj5u.com 2023-04-20 08:43:21 more
  • vim的常用命令

    Vim的6種基本模式 1. 普通模式在普通模式中,用的編輯器命令,比如移動游標,洗掉文本等等。這也是Vim啟動后的默認模式。這正好和許多新用戶期待的操作方式相反(大多數編輯器默認模式為插入模式)。 2. 插入模式在這個模式中,大多數按鍵都會向文本緩沖中插入文本。大多數新用戶希望文本編輯器編輯程序中一 ......

    uj5u.com 2023-04-20 08:42:36 more
  • docker學習

    ###Docker概述 真實專案部署環境可能非常復雜,傳統發布專案一個只需要一個jar包,運行環境需要單獨部署。而通過Docker可將jar包和相關環境(如jdk,redis,Hadoop...)等打包到docker鏡像里,將鏡像發布到Docker倉庫,部署時下載發布的鏡像,直接運行發布的鏡像即可。 ......

    uj5u.com 2023-04-19 09:26:53 more
  • 設定Windows主機的瀏覽器為wls2的默認瀏覽器

    這里以Chrome為例。 1. 準備作業 wsl是可以使用Windows主機上安裝的exe程式,出于安全考慮,默認情況下改功能是無法使用。要使用的話,終端需要以管理員權限啟動。 我這里以Windows Terminal為例,介紹如何默認使用管理員權限打開終端,具體操作如下圖所示: 2. 操作 wsl ......

    uj5u.com 2023-04-19 09:25:49 more
  • docker學習

    ###Docker概述 真實專案部署環境可能非常復雜,傳統發布專案一個只需要一個jar包,運行環境需要單獨部署。而通過Docker可將jar包和相關環境(如jdk,redis,Hadoop...)等打包到docker鏡像里,將鏡像發布到Docker倉庫,部署時下載發布的鏡像,直接運行發布的鏡像即可。 ......

    uj5u.com 2023-04-19 09:19:04 more
  • Linux學習筆記

    IP地址和主機名 IP地址 ifconfig可以用來查詢本機的IP地址,如果不能使用,可以通過install net-tools安裝。 Centos系統下ens33表示主網卡;inet后表示IP地址;lo表示本地回環網卡; 127.0.0.1表示代指本機;0.0.0.0可以用于代指本機,同時在放行設 ......

    uj5u.com 2023-04-18 06:52:01 more
  • 解決linux系統的kdump服務無法啟動的問題

    問題:專案麒麟系統服務器的kdump服務無法啟動,沒有相關日志無法定位問題。 1、查看服務狀態是關閉的,重啟系統也無法啟動 systemctl status kdump 2、修改grub引數,修改“crashkernel”為“512M(有的機器數值太大太小都會導致報錯,建議從128M開始試,或者加個 ......

    uj5u.com 2023-04-12 09:59:50 more
  • 解決linux系統的kdump服務無法啟動的問題

    問題:專案麒麟系統服務器的kdump服務無法啟動,沒有相關日志無法定位問題。 1、查看服務狀態是關閉的,重啟系統也無法啟動 systemctl status kdump 2、修改grub引數,修改“crashkernel”為“512M(有的機器數值太大太小都會導致報錯,建議從128M開始試,或者加個 ......

    uj5u.com 2023-04-12 09:59:01 more
  • 你是不是暴露了?

    作者:袁首京 原創文章,轉載時請保留此宣告,并給出原文連接。 如果您是計算機相關從業人員,那么應該經歷不止一次網路安全專項檢查了,你肯定是收到過資訊系統技術檢測報告,要求你加強風險監測,確保你提供的系統服務堅實可靠了。 沒檢測到問題還好,檢測到問題的話,有些處理起來還是挺麻煩的,尤其是線上正在運行的 ......

    uj5u.com 2023-04-05 16:52:56 more
  • 細節拉滿,80 張圖帶你一步一步推演 slab 記憶體池的設計與實作

    1. 前文回顧 在之前的幾篇記憶體管理系列文章中,筆者帶大家從宏觀角度完整地梳理了一遍 Linux 記憶體分配的整個鏈路,本文的主題依然是記憶體分配,這一次我們會從微觀的角度來探秘一下 Linux 內核中用于零散小記憶體塊分配的記憶體池 —— slab 分配器。 在本小節中,筆者還是按照以往的風格先帶大家簡單 ......

    uj5u.com 2023-04-05 16:44:11 more