Przeglądaj źródła

fedora + bbr

support fedora 29+ remove old bbr script and change it to easy way
MHSanaei 2 lat temu
rodzic
commit
6337efb786
3 zmienionych plików z 119 dodań i 51 usunięć
  1. 4 3
      README.md
  2. 29 14
      install.sh
  3. 86 34
      x-ui.sh

+ 4 - 3
README.md

@@ -27,7 +27,7 @@ certbot renew --dry-run
 # Default settings
 
 - Port: 2053
-- username and password will be generated randomly you can see them after you install it (x-ui "7")
+- username and password will be generated randomly if you skip to modify your own security(x-ui "7")
 - database path: /etc/x-ui/x-ui.db
 
 before you set ssl on settings
@@ -39,13 +39,14 @@ After you set ssl on settings
 # Enable Traffic For Users:
 
 **copy and paste to xray Configuration :** (you don't need to do this if you have a fresh install)
-- [for enable traffic](https://raw.githubusercontent.com/MHSanaei/3x-ui/main/media/for%20enable%20traffic.txt)
-- [for enable traffic+block all iran ip address](https://raw.githubusercontent.com/MHSanaei/3x-ui/main/media/for%20enable%20traffic%2Bblock%20all%20iran%20ip.txt)
+- [for enable traffic](https://raw.githubusercontent.com/mhsanaei/3x-ui/main/media/for%20enable%20traffic.txt)
+- [for enable traffic+block all iran ip address](https://raw.githubusercontent.com/mhsanaei/3x-ui/main/media/for%20enable%20traffic%2Bblock%20all%20iran%20ip.txt)
 
 # Suggestion System
 - Ubuntu 20.04+
 - Debian 10+
 - CentOS 8+
+- Fedora 29+
 
 # Pictures
 

+ 29 - 14
install.sh

@@ -10,9 +10,12 @@ cur_dir=$(pwd)
 # check root
 [[ $EUID -ne 0 ]] && echo -e "${red}Fatal error:${plain} Please run this script with root privilege \n " && exit 1
 
-# check os
+# Check OS
 if [[ -f /etc/redhat-release ]]; then
     release="centos"
+    if grep -q "Fedora" /etc/redhat-release; then
+        release="fedora"
+    fi
 elif cat /etc/issue | grep -Eqi "debian"; then
     release="debian"
 elif cat /etc/issue | grep -Eqi "ubuntu"; then
@@ -25,6 +28,8 @@ elif cat /proc/version | grep -Eqi "ubuntu"; then
     release="ubuntu"
 elif cat /proc/version | grep -Eqi "centos|red hat|redhat"; then
     release="centos"
+elif grep -q "Fedora" /etc/*-release; then
+    release="fedora"
 else
     echo -e "${red} Check system OS failed, please contact the author! ${plain}\n" && exit 1
 fi
@@ -49,7 +54,7 @@ fi
 
 os_version=""
 
-# os version
+# get OS version
 if [[ -f /etc/os-release ]]; then
     os_version=$(awk -F'[= ."]' '/VERSION_ID/{print $3}' /etc/os-release)
 fi
@@ -57,18 +62,28 @@ if [[ -z "$os_version" && -f /etc/lsb-release ]]; then
     os_version=$(awk -F'[= ."]+' '/DISTRIB_RELEASE/{print $2}' /etc/lsb-release)
 fi
 
-if [[ x"${release}" == x"centos" ]]; then
-    if [[ ${os_version} -le 7 ]]; then
-        echo -e "${red} Please use CentOS 8 or higher ${plain}\n" && exit 1
-    fi
-elif [[ x"${release}" == x"ubuntu" ]]; then
-    if [[ ${os_version} -lt 20 ]]; then
-        echo -e "${red} Please use Ubuntu 20 or higher ${plain}\n" && exit 1
-    fi
-elif [[ x"${release}" == x"debian" ]]; then
-    if [[ ${os_version} -lt 9 ]]; then
-        echo -e "${red} Please use Debian 10 or higher ${plain}\n" && exit 1
-    fi
+# set minimum version number for each OS
+case ${release} in
+    centos)
+        min_version=8
+        ;;
+    ubuntu)
+        min_version=20
+        ;;
+    debian)
+        min_version=10
+        ;;
+    fedora)
+        min_version=29
+        ;;
+    *)
+        echo -e "${red} Unsupported OS ${plain}\n" && exit 1
+        ;;
+esac
+
+# check if OS version meets minimum version requirement
+if [[ ${os_version} -lt ${min_version} ]]; then
+    echo -e "${red} Please use ${release^} ${min_version} or higher ${plain}\n" && exit 1
 fi
 
 install_base() {

+ 86 - 34
x-ui.sh

@@ -20,48 +20,76 @@ function LOGI() {
 # check root
 [[ $EUID -ne 0 ]] && LOGE "ERROR: You must be root to run this script! \n" && exit 1
 
-# check os
+# Check OS and set release variable
 if [[ -f /etc/redhat-release ]]; then
-    release="centos"
-elif cat /etc/issue | grep -Eqi "debian"; then
+    if grep -Eqi "CentOS" /etc/redhat-release; then
+        release="centos"
+    elif grep -Eqi "Fedora" /etc/redhat-release; then
+        release="fedora"
+    fi
+elif grep -Eqi "debian" /etc/issue; then
     release="debian"
-elif cat /etc/issue | grep -Eqi "ubuntu"; then
+elif grep -Eqi "ubuntu" /etc/issue; then
     release="ubuntu"
-elif cat /etc/issue | grep -Eqi "centos|red hat|redhat"; then
+elif grep -Eqi "centos" /etc/issue; then
     release="centos"
-elif cat /proc/version | grep -Eqi "debian"; then
+elif grep -Eqi "debian" /proc/version; then
     release="debian"
-elif cat /proc/version | grep -Eqi "ubuntu"; then
+elif grep -Eqi "ubuntu" /proc/version; then
     release="ubuntu"
-elif cat /proc/version | grep -Eqi "centos|red hat|redhat"; then
+elif grep -Eqi "centos" /proc/version; then
     release="centos"
+elif grep -Eqi "fedora" /proc/version; then
+    release="fedora"
 else
-    LOGE "check system OS failed,please contact with author! \n" && exit 1
+    echo "Failed to check the system OS, please contact the author!" >&2
+    exit 1
 fi
 
+echo "The OS release is: $release"
+
 os_version=""
 
 # os version
 if [[ -f /etc/os-release ]]; then
     os_version=$(awk -F'[= ."]' '/VERSION_ID/{print $3}' /etc/os-release)
-fi
-if [[ -z "$os_version" && -f /etc/lsb-release ]]; then
+elif [[ -f /etc/lsb-release ]]; then
     os_version=$(awk -F'[= ."]+' '/DISTRIB_RELEASE/{print $2}' /etc/lsb-release)
+elif [[ -f /etc/fedora-release ]]; then
+    os_version=$(awk -F'[= ]+' '/release/{print $3}' /etc/fedora-release)
 fi
 
-if [[ x"${release}" == x"centos" ]]; then
-    if [[ ${os_version} -le 6 ]]; then
-        LOGE "please use CentOS 7 or higher version! \n" && exit 1
-    fi
-elif [[ x"${release}" == x"ubuntu" ]]; then
-    if [[ ${os_version} -lt 16 ]]; then
-        LOGE "please use Ubuntu 16 or higher version!\n" && exit 1
-    fi
-elif [[ x"${release}" == x"debian" ]]; then
-    if [[ ${os_version} -lt 8 ]]; then
-        LOGE "please use Debian 8 or higher version!\n" && exit 1
-    fi
-fi
+case "${release}" in
+    centos)
+        if [[ ${os_version} -le 8 ]]; then
+            echo "Please use CentOS 8 or higher version!"
+            exit 2
+        fi
+        ;;
+    ubuntu)
+        if [[ ${os_version} -lt 20 ]]; then
+            echo "Please use Ubuntu 20 or higher version!"
+            exit 2
+        fi
+        ;;
+    debian)
+        if [[ ${os_version} -lt 10 ]]; then
+            echo "Please use Debian 10 or higher version!"
+            exit 2
+        fi
+        ;;
+    fedora)
+        if [[ ${os_version} -lt 29 ]]; then
+            echo "Please use Fedora 29 or higher version!"
+            exit 2
+        fi
+        ;;
+    *)
+        echo "Unknown release type '${release}'"
+        exit 2
+        ;;
+esac
+
 
 confirm() {
     if [[ $# > 1 ]]; then
@@ -288,17 +316,41 @@ show_log() {
     fi
 }
 
-migrate_v2_ui() {
-    /usr/local/x-ui/x-ui v2-ui
+enable_bbr() {
 
-    before_show_menu
-}
+if grep -q "net.core.default_qdisc=fq" /etc/sysctl.conf && grep -q "net.ipv4.tcp_congestion_control=bbr" /etc/sysctl.conf; then
+  echo -e "${green}BBR is already enabled!${plain}"
+  exit 0
+fi
+
+# Check the OS and install necessary packages
+if [[ "$(cat /etc/os-release | grep -E '^ID=' | awk -F '=' '{print $2}')" == "ubuntu" ]]; then
+  sudo apt-get update && sudo apt-get install -yqq --no-install-recommends ca-certificates
+elif [[ "$(cat /etc/os-release | grep -E '^ID=' | awk -F '=' '{print $2}')" == "debian" ]]; then
+  sudo apt-get update && sudo apt-get install -yqq --no-install-recommends ca-certificates
+elif [[ "$(cat /etc/os-release | grep -E '^ID=' | awk -F '=' '{print $2}')" == "fedora" ]]; then
+  sudo dnf -y update && sudo dnf -y install ca-certificates
+elif [[ "$(cat /etc/os-release | grep -E '^ID=' | awk -F '=' '{print $2}')" == "centos" ]]; then
+  sudo yum -y update && sudo yum -y install ca-certificates
+else
+  echo "Unsupported operating system. Please check the script and install the necessary packages manually."
+  exit 1
+fi
+
+# Enable BBR
+echo "net.core.default_qdisc=fq" | sudo tee -a /etc/sysctl.conf
+echo "net.ipv4.tcp_congestion_control=bbr" | sudo tee -a /etc/sysctl.conf
+
+# Apply changes
+sudo sysctl -p
+
+# Verify that BBR is enabled
+if [[ $(sysctl net.ipv4.tcp_congestion_control | awk '{print $3}') == "bbr" ]]; then
+  echo -e "${green}BBR has been enabled successfully.${plain}"
+else
+  echo -e "${red}Failed to enable BBR. Please check your system configuration.${plain}"
+fi
 
-install_bbr() {
-    # temporary workaround for installing bbr
-    bash <(curl -L -s https://raw.githubusercontent.com/teddysun/across/master/bbr.sh)
-    echo ""
-    before_show_menu
 }
 
 update_shell() {
@@ -713,7 +765,7 @@ show_menu() {
         check_install && disable
         ;;
     15)
-        install_bbr
+        enable_bbr
         ;;
     16)
         ssl_cert_issue