主頁 > 作業系統 > 谷歌BBR擁塞演算法內核更新

谷歌BBR擁塞演算法內核更新

2020-09-30 09:48:06 作業系統

為什么想到這個呢,演算法什么的又不太懂,這是 因為搭建VPN + BBR 與之簡直絕配

有的人搭建SSR ,配一個什么銳速,還需要降內核版本, 而且還容易出錯,降了之后更加容易出現兼容性問題,所以偶爾看到了google的BBR 擁塞阻塞演算法 

演算法原理不知道,也不想去深究 , 原理 這篇博客 講得還是很清楚的 ,可以一探

Google 開源了其 TCP BBR 擁塞控制演算法,并提交到了 Linux 內核,從 4.9 開始,Linux 內核已經用上了該演算法,根據谷歌的風格,Google 總是先在自家的生產環境上線運用后,才會將代碼開源,此次也不例外,
根據大佬的實地測驗,在部署了最新版內核并開啟了 TCP BBR 的機器上,網速甚至可以提升好幾個數量級,

根據某個大佬開發的一鍵安裝的腳本,可以實作最新內核的安裝和 TCP BBR 腳本
腳本如下:

  1 #!/usr/bin/env bash
  2 #
  3 # Auto install latest kernel for TCP BBR
  4 #
  5 # System Required:  CentOS 6+, Debian7+, Ubuntu12+
  6 #
  7 # Copyright (C) 2016-2018 Teddysun <[email protected]>
  8 #
  9 # URL: https://teddysun.com/489.html
 10 #
 11 
 12 red='\033[0;31m'
 13 green='\033[0;32m'
 14 yellow='\033[0;33m'
 15 plain='\033[0m'
 16 
 17 cur_dir=$(pwd)
 18 
 19 [[ $EUID -ne 0 ]] && echo -e "${red}Error:${plain} This script must be run as root!" && exit 1
 20 
 21 [[ -d "/proc/vz" ]] && echo -e "${red}Error:${plain} Your VPS is based on OpenVZ, which is not supported." && exit 1
 22 
 23 if [ -f /etc/redhat-release ]; then
 24     release="centos"
 25 elif cat /etc/issue | grep -Eqi "debian"; then
 26     release="debian"
 27 elif cat /etc/issue | grep -Eqi "ubuntu"; then
 28     release="ubuntu"
 29 elif cat /etc/issue | grep -Eqi "centos|red hat|redhat"; then
 30     release="centos"
 31 elif cat /proc/version | grep -Eqi "debian"; then
 32     release="debian"
 33 elif cat /proc/version | grep -Eqi "ubuntu"; then
 34     release="ubuntu"
 35 elif cat /proc/version | grep -Eqi "centos|red hat|redhat"; then
 36     release="centos"
 37 else
 38     release=""
 39 fi
 40 
 41 is_digit(){
 42     local input=${1}
 43     if [[ "$input" =~ ^[0-9]+$ ]]; then
 44         return 0
 45     else
 46         return 1
 47     fi
 48 }
 49 
 50 is_64bit(){
 51     if [ $(getconf WORD_BIT) = '32' ] && [ $(getconf LONG_BIT) = '64' ]; then
 52         return 0
 53     else
 54         return 1
 55     fi
 56 }
 57 
 58 get_valid_valname(){
 59     local val=${1}
 60     local new_val=$(eval echo $val | sed 's/[-.]/_/g')
 61     echo ${new_val}
 62 }
 63 
 64 get_hint(){
 65     local val=${1}
 66     local new_val=$(get_valid_valname $val)
 67     eval echo "\$hint_${new_val}"
 68 }
 69 
 70 #Display Memu
 71 display_menu(){
 72     local soft=${1}
 73     local default=${2}
 74     eval local arr=(\${${soft}_arr[@]})
 75     local default_prompt
 76     if [[ "$default" != "" ]]; then
 77         if [[ "$default" == "last" ]]; then
 78             default=${#arr[@]}
 79         fi
 80         default_prompt="(default ${arr[$default-1]})"
 81     fi
 82     local pick
 83     local hint
 84     local vname
 85     local prompt="which ${soft} you'd select ${default_prompt}: "
 86 
 87     while :
 88     do
 89         echo -e "\n------------ ${soft} setting ------------\n"
 90         for ((i=1;i<=${#arr[@]};i++ )); do
 91             vname="$(get_valid_valname ${arr[$i-1]})"
 92             hint="$(get_hint $vname)"
 93             [[ "$hint" == "" ]] && hint="${arr[$i-1]}"
 94             echo -e "${green}${i}${plain}) $hint"
 95         done
 96         echo
 97         read -p "${prompt}" pick
 98         if [[ "$pick" == "" && "$default" != "" ]]; then
 99             pick=${default}
100             break
101         fi
102 
103         if ! is_digit "$pick"; then
104             prompt="Input error, please input a number"
105             continue
106         fi
107 
108         if [[ "$pick" -lt 1 || "$pick" -gt ${#arr[@]} ]]; then
109             prompt="Input error, please input a number between 1 and ${#arr[@]}: "
110             continue
111         fi
112 
113         break
114     done
115 
116     eval ${soft}=${arr[$pick-1]}
117     vname="$(get_valid_valname ${arr[$pick-1]})"
118     hint="$(get_hint $vname)"
119     [[ "$hint" == "" ]] && hint="${arr[$pick-1]}"
120     echo -e "\nyour selection: $hint\n"
121 }
122 
123 version_ge(){
124     test "$(echo "$@" | tr " " "\n" | sort -rV | head -n 1)" == "$1"
125 }
126 
127 get_latest_version() {
128     latest_version=($(wget -qO- https://kernel.ubuntu.com/~kernel-ppa/mainline/ | awk -F'\"v' '/v[4-9]./{print $2}' | cut -d/ -f1 | grep -v - | sort -V))
129 
130     [ ${#latest_version[@]} -eq 0 ] && echo -e "${red}Error:${plain} Get latest kernel version failed." && exit 1
131 
132     kernel_arr=()
133     for i in ${latest_version[@]}; do
134         if version_ge $i 4.14; then
135             kernel_arr+=($i);
136         fi
137     done
138 
139     display_menu kernel last
140 
141     if [[ `getconf WORD_BIT` == "32" && `getconf LONG_BIT` == "64" ]]; then
142         deb_name=$(wget -qO- https://kernel.ubuntu.com/~kernel-ppa/mainline/v${kernel}/ | grep "linux-image" | grep "generic" | awk -F'\">' '/amd64.deb/{print $2}' | cut -d'<' -f1 | head -1)
143         deb_kernel_url="https://kernel.ubuntu.com/~kernel-ppa/mainline/v${kernel}/${deb_name}"
144         deb_kernel_name="linux-image-${kernel}-amd64.deb"
145         modules_deb_name=$(wget -qO- https://kernel.ubuntu.com/~kernel-ppa/mainline/v${kernel}/ | grep "linux-modules" | grep "generic" | awk -F'\">' '/amd64.deb/{print $2}' | cut -d'<' -f1 | head -1)
146         deb_kernel_modules_url="https://kernel.ubuntu.com/~kernel-ppa/mainline/v${kernel}/${modules_deb_name}"
147         deb_kernel_modules_name="linux-modules-${kernel}-amd64.deb"
148     else
149         deb_name=$(wget -qO- https://kernel.ubuntu.com/~kernel-ppa/mainline/v${kernel}/ | grep "linux-image" | grep "generic" | awk -F'\">' '/i386.deb/{print $2}' | cut -d'<' -f1 | head -1)
150         deb_kernel_url="https://kernel.ubuntu.com/~kernel-ppa/mainline/v${kernel}/${deb_name}"
151         deb_kernel_name="linux-image-${kernel}-i386.deb"
152         modules_deb_name=$(wget -qO- https://kernel.ubuntu.com/~kernel-ppa/mainline/v${kernel}/ | grep "linux-modules" | grep "generic" | awk -F'\">' '/i386.deb/{print $2}' | cut -d'<' -f1 | head -1)
153         deb_kernel_modules_url="https://kernel.ubuntu.com/~kernel-ppa/mainline/v${kernel}/${modules_deb_name}"
154         deb_kernel_modules_name="linux-modules-${kernel}-i386.deb"
155     fi
156 
157     [ -z ${deb_name} ] && echo -e "${red}Error:${plain} Getting Linux kernel binary package name failed, maybe kernel build failed. Please choose other one and try again." && exit 1
158 }
159 
160 get_opsy() {
161     [ -f /etc/redhat-release ] && awk '{print ($1,$3~/^[0-9]/?$3:$4)}' /etc/redhat-release && return
162     [ -f /etc/os-release ] && awk -F'[= "]' '/PRETTY_NAME/{print $3,$4,$5}' /etc/os-release && return
163     [ -f /etc/lsb-release ] && awk -F'[="]+' '/DESCRIPTION/{print $2}' /etc/lsb-release && return
164 }
165 
166 opsy=$( get_opsy )
167 arch=$( uname -m )
168 lbit=$( getconf LONG_BIT )
169 kern=$( uname -r )
170 
171 get_char() {
172     SAVEDSTTY=`stty -g`
173     stty -echo
174     stty cbreak
175     dd if=/dev/tty bs=1 count=1 2> /dev/null
176     stty -raw
177     stty echo
178     stty $SAVEDSTTY
179 }
180 
181 getversion() {
182     if [[ -s /etc/redhat-release ]]; then
183         grep -oE  "[0-9.]+" /etc/redhat-release
184     else
185         grep -oE  "[0-9.]+" /etc/issue
186     fi
187 }
188 
189 centosversion() {
190     if [ x"${release}" == x"centos" ]; then
191         local code=$1
192         local version="$(getversion)"
193         local main_ver=${version%%.*}
194         if [ "$main_ver" == "$code" ]; then
195             return 0
196         else
197             return 1
198         fi
199     else
200         return 1
201     fi
202 }
203 
204 check_bbr_status() {
205     local param=$(sysctl net.ipv4.tcp_congestion_control | awk '{print $3}')
206     if [[ x"${param}" == x"bbr" ]]; then
207         return 0
208     else
209         return 1
210     fi
211 }
212 
213 check_kernel_version() {
214     local kernel_version=$(uname -r | cut -d- -f1)
215     if version_ge ${kernel_version} 4.9; then
216         return 0
217     else
218         return 1
219     fi
220 }
221 
222 install_elrepo() {
223 
224     if centosversion 5; then
225         echo -e "${red}Error:${plain} not supported CentOS 5."
226         exit 1
227     fi
228 
229     rpm --import https://www.elrepo.org/RPM-GPG-KEY-elrepo.org
230 
231     if centosversion 6; then
232         rpm -Uvh https://www.elrepo.org/elrepo-release-6-9.el6.elrepo.noarch.rpm
233     elif centosversion 7; then
234         rpm -Uvh https://www.elrepo.org/elrepo-release-7.0-4.el7.elrepo.noarch.rpm
235     fi
236 
237     if [ ! -f /etc/yum.repos.d/elrepo.repo ]; then
238         echo -e "${red}Error:${plain} Install elrepo failed, please check it."
239         exit 1
240     fi
241 }
242 
243 sysctl_config() {
244     sed -i '/net.core.default_qdisc/d' /etc/sysctl.conf
245     sed -i '/net.ipv4.tcp_congestion_control/d' /etc/sysctl.conf
246     echo "net.core.default_qdisc = fq" >> /etc/sysctl.conf
247     echo "net.ipv4.tcp_congestion_control = bbr" >> /etc/sysctl.conf
248     sysctl -p >/dev/null 2>&1
249 }
250 
251 install_config() {
252     if [[ x"${release}" == x"centos" ]]; then
253         if centosversion 6; then
254             if [ ! -f "/boot/grub/grub.conf" ]; then
255                 echo -e "${red}Error:${plain} /boot/grub/grub.conf not found, please check it."
256                 exit 1
257             fi
258             sed -i 's/^default=.*/default=0/g' /boot/grub/grub.conf
259         elif centosversion 7; then
260             if [ ! -f "/boot/grub2/grub.cfg" ]; then
261                 echo -e "${red}Error:${plain} /boot/grub2/grub.cfg not found, please check it."
262                 exit 1
263             fi
264             grub2-set-default 0
265         fi
266     elif [[ x"${release}" == x"debian" || x"${release}" == x"ubuntu" ]]; then
267         /usr/sbin/update-grub
268     fi
269 }
270 
271 reboot_os() {
272     echo
273     echo -e "${green}Info:${plain} The system needs to reboot."
274     read -p "Do you want to restart system? [y/n]" is_reboot
275     if [[ ${is_reboot} == "y" || ${is_reboot} == "Y" ]]; then
276         reboot
277     else
278         echo -e "${green}Info:${plain} Reboot has been canceled..."
279         exit 0
280     fi
281 }
282 
283 install_bbr() {
284     check_bbr_status
285     if [ $? -eq 0 ]; then
286         echo
287         echo -e "${green}Info:${plain} TCP BBR has already been installed. nothing to do..."
288         exit 0
289     fi
290     check_kernel_version
291     if [ $? -eq 0 ]; then
292         echo
293         echo -e "${green}Info:${plain} Your kernel version is greater than 4.9, directly setting TCP BBR..."
294         sysctl_config
295         echo -e "${green}Info:${plain} Setting TCP BBR completed..."
296         exit 0
297     fi
298 
299     if [[ x"${release}" == x"centos" ]]; then
300         install_elrepo
301         [ ! "$(command -v yum-config-manager)" ] && yum install -y yum-utils > /dev/null 2>&1
302         [ x"$(yum-config-manager elrepo-kernel | grep -w enabled | awk '{print $3}')" != x"True" ] && yum-config-manager --enable elrepo-kernel > /dev/null 2>&1
303         if centosversion 6; then
304             if is_64bit; then
305                 rpm_kernel_name="kernel-ml-4.18.20-1.el6.elrepo.x86_64.rpm"
306                 rpm_kernel_devel_name="kernel-ml-devel-4.18.20-1.el6.elrepo.x86_64.rpm"
307                 rpm_kernel_url_1="http://repos.lax.quadranet.com/elrepo/archive/kernel/el6/x86_64/RPMS/"
308             else
309                 rpm_kernel_name="kernel-ml-4.18.20-1.el6.elrepo.i686.rpm"
310                 rpm_kernel_devel_name="kernel-ml-devel-4.18.20-1.el6.elrepo.i686.rpm"
311                 rpm_kernel_url_1="http://repos.lax.quadranet.com/elrepo/archive/kernel/el6/i386/RPMS/"
312             fi
313             rpm_kernel_url_2="https://dl.lamp.sh/files/"
314             wget -c -t3 -T60 -O ${rpm_kernel_name} ${rpm_kernel_url_1}${rpm_kernel_name}
315             if [ $? -ne 0 ]; then
316                 rm -rf ${rpm_kernel_name}
317                 wget -c -t3 -T60 -O ${rpm_kernel_name} ${rpm_kernel_url_2}${rpm_kernel_name}
318             fi
319             wget -c -t3 -T60 -O ${rpm_kernel_devel_name} ${rpm_kernel_url_1}${rpm_kernel_devel_name}
320             if [ $? -ne 0 ]; then
321                 rm -rf ${rpm_kernel_devel_name}
322                 wget -c -t3 -T60 -O ${rpm_kernel_devel_name} ${rpm_kernel_url_2}${rpm_kernel_devel_name}
323             fi
324             if [ -f "${rpm_kernel_name}" ]; then
325                 rpm -ivh ${rpm_kernel_name}
326             else
327                 echo -e "${red}Error:${plain} Download ${rpm_kernel_name} failed, please check it."
328                 exit 1
329             fi
330             if [ -f "${rpm_kernel_devel_name}" ]; then
331                 rpm -ivh ${rpm_kernel_devel_name}
332             else
333                 echo -e "${red}Error:${plain} Download ${rpm_kernel_devel_name} failed, please check it."
334                 exit 1
335             fi
336             rm -f ${rpm_kernel_name} ${rpm_kernel_devel_name}
337         elif centosversion 7; then
338             yum -y install kernel-ml kernel-ml-devel
339             if [ $? -ne 0 ]; then
340                 echo -e "${red}Error:${plain} Install latest kernel failed, please check it."
341                 exit 1
342             fi
343         fi
344     elif [[ x"${release}" == x"debian" || x"${release}" == x"ubuntu" ]]; then
345         [[ ! -e "/usr/bin/wget" ]] && apt-get -y update && apt-get -y install wget
346         echo -e "${green}Info:${plain} Getting latest kernel version..."
347         get_latest_version
348         if [ -n ${modules_deb_name} ]; then
349             wget -c -t3 -T60 -O ${deb_kernel_modules_name} ${deb_kernel_modules_url}
350             if [ $? -ne 0 ]; then
351                 echo -e "${red}Error:${plain} Download ${deb_kernel_modules_name} failed, please check it."
352                 exit 1
353             fi
354         fi
355         wget -c -t3 -T60 -O ${deb_kernel_name} ${deb_kernel_url}
356         if [ $? -ne 0 ]; then
357             echo -e "${red}Error:${plain} Download ${deb_kernel_name} failed, please check it."
358             exit 1
359         fi
360         [ -f ${deb_kernel_modules_name} ] && dpkg -i ${deb_kernel_modules_name}
361         dpkg -i ${deb_kernel_name}
362         rm -f ${deb_kernel_name} ${deb_kernel_modules_name}
363     else
364         echo -e "${red}Error:${plain} OS is not be supported, please change to CentOS/Debian/Ubuntu and try again."
365         exit 1
366     fi
367 
368     install_config
369     sysctl_config
370     reboot_os
371 }
372 
373 
374 clear
375 echo "---------- System Information ----------"
376 echo " OS      : $opsy"
377 echo " Arch    : $arch ($lbit Bit)"
378 echo " Kernel  : $kern"
379 echo "----------------------------------------"
380 echo " Auto install latest kernel for TCP BBR"
381 echo
382 echo " URL: https://teddysun.com/489.html"
383 echo "----------------------------------------"
384 echo
385 echo "Press any key to start...or Press Ctrl+C to cancel"
386 char=`get_char`
387 
388 install_bbr 2>&1 | tee ${cur_dir}/install_bbr.log
View Code

也可以采用在線安裝的方式:

wget --no-check-certificate https://github.com/teddysun/across/raw/master/bbr.sh && chmod +x bbr.sh && ./bbr.sh

安裝完成后,腳本會提示需要重啟 VPS,輸入 y 并回車后重啟,
重啟完成后,進入 VPS,驗證一下是否成功安裝最新內核并開啟 TCP BBR,輸入命令: 

uname -r

查看內核版本,顯示為最新版就表示 OK了

sysctl net.ipv4.tcp_available_congestion_control
回傳值一般為:
net.ipv4.tcp_available_congestion_control = bbr cubic reno
或者為:
net.ipv4.tcp_available_congestion_control = reno cubic bbr
=================================================================================
sysctl net.ipv4.tcp_congestion_control
回傳值一般為:
net.ipv4.tcp_congestion_control = bbr
=================================================================================
sysctl net.core.default_qdisc
回傳值一般為:
net.core.default_qdisc = fq
==================================================================================
lsmod | grep bbr
回傳值有 tcp_bbr 模塊即說明 bbr 已啟動,注意:并不是所有的 VPS 都會有此回傳值,若沒有也屬正常,

另外:

附上大佬的CentOS 下最新版內核 headers 安裝方法

本來打算在腳本里直接安裝 kernel-ml-headers,但會出現和原版內核 headers 沖突的問題,因此在這里添加一個腳本執行完后,手動安裝最新版內核 headers 之教程,
執行以下命令

yum --enablerepo=elrepo-kernel -y install kernel-ml-headers
根據 CentOS 版本的不同,此時一般會出現類似于以下的錯誤提示:

Error: kernel-ml-headers conflicts with kernel-headers-2.6.32-696.20.1.el6.x86_64
Error: kernel-ml-headers conflicts with kernel-headers-3.10.0-693.17.1.el7.x86_64
因此需要先卸載原版內核 headers ,然后再安裝最新版內核 headers,執行命令:

yum remove kernel-headers
確認無誤后,輸入 y,回車開始卸載,注意,有時候這么操作還會卸載一些對內核 headers 依賴的安裝包,比如 gcc、gcc-c++ 之類的,不過不要緊,我們可以在安裝完最新版內核 headers 后再重新安裝回來即可,
卸載完成后,再次執行上面給出的安裝命令,

yum --enablerepo=elrepo-kernel -y install kernel-ml-headers
成功安裝后,再把那些之前對內核 headers 依賴的安裝包,比如 gcc、gcc-c++ 之類的再安裝一次即可,

為什么要安裝最新版內核 headers 呢?
這是因為 ss-libev 版有個 tcp fast open 功能,如果不安裝的話,這個功能是無法開啟的,

內核升級方法
如果是 CentOS 系統,執行如下命令即可升級內核:

yum -y install kernel-ml kernel-ml-devel
如果你還手動安裝了新版內核 headers ,那么還需要以下命令來升級 headers :

yum -y install kernel-ml-headers
CentOS 6 的話,執行命令:

sed -i 's/^default=.*/default=0/g' /boot/grub/grub.conf
CentOS 7 的話,執行命令:

grub2-set-default 0
如果是 Debian/Ubuntu 系統,則需要手動下載最新版內核來安裝升級,
去這里下載最新版的內核 deb 安裝包,
如果系統是 64 位,則下載 amd64 的 linux-image 中含有 generic 這個 deb 包;
如果系統是 32 位,則下載 i386 的 linux-image 中含有 generic 這個 deb 包;
安裝的命令如下(以最新版的 64 位 4.12.4 舉例而已,請替換為下載好的 deb 包):

dpkg -i linux-image-4.12.4-041204-generic_4.12.4-041204.201707271932_amd64.deb
安裝完成后,再執行命令:

/usr/sbin/update-grub
最后,重啟 VPS 即可,

特別說明
如果你使用的是 Google Cloud Platform (GCP)更換內核,有時會遇到重啟后,整個磁盤變為只讀的情況,只需執行以下命令即可恢復:

mount -o remount rw /

 參考鏈接:

https://github.com/google/bbr/blob/master/Documentation/bbr-quick-start.md
http://elrepo.org/tiki/tiki-index.php
http://kernel.ubuntu.com/~kernel-ppa/mainline/

https://teddysun.com/489.html

 

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

標籤:Linux

上一篇:Bash腳本編程學習筆記07:回圈結構體

下一篇:shell基礎

標籤雲
其他(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