You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

1016 lines
36 KiB

2 months ago
  1. #!/bin/bash
  2. PATH=/bin:/sbin:/usr/bin:/usr/sbin:/usr/local/bin:/usr/local/sbin:~/bin
  3. export PATH
  4. LANG=en_US.UTF-8
  5. Btapi_Url='http://www.example.com'
  6. if [ ! -d /www/server/panel/BTPanel ];then
  7. echo "============================================="
  8. echo "Error, 5.x Can't use this command to upgrade!"
  9. exit 0;
  10. fi
  11. Updating="/tmp/update_to7.pl"
  12. if [ -f "$Updating" ];then
  13. echo "Error, $Updating file exists. Please delete this $Updating before executing the command."
  14. exit 0;
  15. else
  16. touch $Updating
  17. fi
  18. # public_file=/www/server/panel/install/public.sh
  19. # publicFileMd5=$(md5sum ${public_file} 2>/dev/null|awk '{print $1}')
  20. # md5check="f3fb69f071f7fa800e5f2d5ec3e128c3"
  21. # if [ "${publicFileMd5}" != "${md5check}" ]; then
  22. # wget -O Tpublic.sh https://node.aapanel.com/install/public.sh -T 20;
  23. # publicFileMd5=$(md5sum Tpublic.sh 2>/dev/null|awk '{print $1}')
  24. # if [ "${publicFileMd5}" == "${md5check}" ]; then
  25. # \cp -rpa Tpublic.sh $public_file
  26. # fi
  27. # rm -f Tpublic.sh
  28. # fi
  29. # . $public_file
  30. if [ -f /etc/redhat-releas ]; then
  31. Centos8Check=$(cat /etc/redhat-release | grep ' 8.' | grep -iE 'centos|Red Hat')
  32. if [ "${Centos8Check}" ];then
  33. if [ ! -f "/usr/bin/python" ] && [ -f "/usr/bin/python3" ] && [ ! -d "/www/server/panel/pyenv" ]; then
  34. ln -sf /usr/bin/python3 /usr/bin/python
  35. fi
  36. fi
  37. fi
  38. # download_Url=$NODE_URL
  39. # if [ "$download_Url" = "" ];then
  40. # download_Url=https://node.aapanel.com
  41. # fi
  42. download_Url=https://node.aapanel.com
  43. Set_Centos7_Repo(){
  44. MIRROR_CHECK=$(cat /etc/yum.repos.d/CentOS-Base.repo |grep "[^#]mirror.centos.org")
  45. if [ "${MIRROR_CHECK}" ] && [ "${is64bit}" == "64" ];then
  46. echo "Centos7 official repository source has been discontinued , Replacement in progress."
  47. if [ -d "/etc/yumBak" ];then
  48. mv /etc/yumBak /etc/yumBak_$(date +%Y_%m_%d_%H_%M_%S)
  49. fi
  50. \cp -rpa /etc/yum.repos.d/ /etc/yumBak
  51. sed -i 's/mirrorlist=/#mirrorlist=/g' /etc/yum.repos.d/CentOS-*.repo
  52. sed -i 's|#baseurl=http://mirror.centos.org|baseurl=http://vault.epel.cloud|g' /etc/yum.repos.d/CentOS-*.repo
  53. fi
  54. MIRROR_CHECK22=$(cat /etc/yum.repos.d/CentOS-Base.repo |grep "mirrorlist.centos.org"|grep -v '^#')
  55. if [ "${MIRROR_CHECK22}" ] && [ "${is64bit}" == "64" ];then
  56. echo "Centos7 official repository source has been discontinued , Replacement in progress."
  57. if [ -d "/etc/yumBak" ];then
  58. mv /etc/yumBak /etc/yumBak_$(date +%Y_%m_%d_%H_%M_%S)
  59. fi
  60. \cp -rpa /etc/yum.repos.d/ /etc/yumBak
  61. \cp -rpa /etc/yum.repos.d/CentOS-Base.repo /etc/yum.repos.d/CentOS-Base.repo_bt_bak
  62. cat > /etc/yum.repos.d/CentOS-Base.repo << EOF
  63. # CentOS-Base.repo
  64. [base]
  65. name=CentOS-\$releasever - Base
  66. #mirrorlist=http://mirrorlist.centos.org/?release=\$releasever&arch=\$basearch&repo=os&infra=\$infra
  67. baseurl=http://vault.epel.cloud/centos/\$releasever/os/\$basearch/
  68. gpgcheck=1
  69. gpgkey=file:///etc/pki/rpm-gpg/RPM-GPG-KEY-CentOS-7
  70. #released updates
  71. [updates]
  72. name=CentOS-\$releasever - Updates
  73. #mirrorlist=http://mirrorlist.centos.org/?release=\$releasever&arch=\$basearch&repo=updates&infra=\$infra
  74. baseurl=http://vault.epel.cloud/centos/\$releasever/updates/\$basearch/
  75. gpgcheck=1
  76. gpgkey=file:///etc/pki/rpm-gpg/RPM-GPG-KEY-CentOS-7
  77. #additional packages that may be useful
  78. [extras]
  79. name=CentOS-\$releasever - Extras
  80. #mirrorlist=http://mirrorlist.centos.org/?release=\$releasever&arch=\$basearch&repo=extras&infra=\$infra
  81. baseurl=http://vault.epel.cloud/centos/\$releasever/extras/\$basearch/
  82. gpgcheck=1
  83. gpgkey=file:///etc/pki/rpm-gpg/RPM-GPG-KEY-CentOS-7
  84. #additional packages that extend functionality of existing packages
  85. [centosplus]
  86. name=CentOS-\$releasever - Plus
  87. #mirrorlist=http://mirrorlist.centos.org/?release=\$releasever&arch=\$basearch&repo=centosplus&infra=\$infra
  88. baseurl=http://vault.epel.cloud/centos/\$releasever/centosplus/\$basearch/
  89. gpgcheck=1
  90. enabled=0
  91. gpgkey=file:///etc/pki/rpm-gpg/RPM-GPG-KEY-CentOS-7
  92. EOF
  93. fi
  94. ALI_CLOUD_CHECK=$(grep Alibaba /etc/motd)
  95. Tencent_Cloud=$(cat /etc/hostname |grep -E VM-[0-9]+-[0-9]+)
  96. if [ "${ALI_CLOUD_CHECK}" ] || [ "${Tencent_Cloud}" ];then
  97. return
  98. fi
  99. yum install tree -y
  100. if [ "$?" != "0" ] ;then
  101. if [ -d "/etc/yumBak" ];then
  102. mv /etc/yumBak /etc/yumBak_$(date +%Y_%m_%d_%H_%M_%S)
  103. fi
  104. \cp -rpa /etc/yum.repos.d/ /etc/yumBak
  105. if [ -z "${download_Url}" ];then
  106. download_Url="https://node.aapanel.com"
  107. fi
  108. curl -Ssk --connect-timeout 20 -m 60 -O ${download_Url}/src/el7repo.tar.gz
  109. if [ -f "/usr/bin/wget" ] && [ ! -s "el7repo.tar.gz" ];then
  110. wget --no-check-certificate -O el7repo.tar.gz ${download_Url}/src/el7repo.tar.gz -t 3 -T 20
  111. fi
  112. # rm -f /etc/yum.repos.d/*.repo
  113. tar -xvzf el7repo.tar.gz -C /etc/yum.repos.d/
  114. rm -f el7repo.tar.gz
  115. fi
  116. }
  117. Set_Centos8_Repo(){
  118. HUAWEI_CHECK=$(cat /etc/motd |grep "Huawei Cloud")
  119. if [ "${HUAWEI_CHECK}" ] && [ "${is64bit}" == "64" ];then
  120. \cp -rpa /etc/yum.repos.d/ /etc/yumBak
  121. sed -i 's/mirrorlist/#mirrorlist/g' /etc/yum.repos.d/CentOS-*.repo
  122. sed -i 's|#baseurl=http://mirror.centos.org|baseurl=http://vault.epel.cloud|g' /etc/yum.repos.d/CentOS-*.repo
  123. rm -f /etc/yum.repos.d/epel.repo
  124. rm -f /etc/yum.repos.d/epel-*
  125. fi
  126. ALIYUN_CHECK=$(cat /etc/motd|grep "Alibaba Cloud ")
  127. if [ "${ALIYUN_CHECK}" ] && [ "${is64bit}" == "64" ] && [ ! -f "/etc/yum.repos.d/Centos-vault-8.5.2111.repo" ];then
  128. rename '.repo' '.repo.bak' /etc/yum.repos.d/*.repo
  129. wget https://mirrors.aliyun.com/repo/Centos-vault-8.5.2111.repo -O /etc/yum.repos.d/Centos-vault-8.5.2111.repo
  130. wget https://mirrors.aliyun.com/repo/epel-archive-8.repo -O /etc/yum.repos.d/epel-archive-8.repo
  131. sed -i 's/mirrors.cloud.aliyuncs.com/url_tmp/g' /etc/yum.repos.d/Centos-vault-8.5.2111.repo && sed -i 's/mirrors.aliyun.com/mirrors.cloud.aliyuncs.com/g' /etc/yum.repos.d/Centos-vault-8.5.2111.repo && sed -i 's/url_tmp/mirrors.aliyun.com/g' /etc/yum.repos.d/Centos-vault-8.5.2111.repo
  132. sed -i 's/mirrors.aliyun.com/mirrors.cloud.aliyuncs.com/g' /etc/yum.repos.d/epel-archive-8.repo
  133. fi
  134. MIRROR_CHECK=$(cat /etc/yum.repos.d/CentOS-Linux-AppStream.repo |grep "[^#]mirror.centos.org")
  135. if [ "${MIRROR_CHECK}" ] && [ "${is64bit}" == "64" ];then
  136. \cp -rpa /etc/yum.repos.d/ /etc/yumBak
  137. sed -i 's/mirrorlist/#mirrorlist/g' /etc/yum.repos.d/CentOS-*.repo
  138. sed -i 's|#baseurl=http://mirror.centos.org|baseurl=http://vault.epel.cloud|g' /etc/yum.repos.d/CentOS-*.repo
  139. fi
  140. yum install tree -y
  141. if [ "$?" != "0" ] ;then
  142. if [ -z "${download_Url}" ];then
  143. download_Url="https://node.aapanel.com"
  144. fi
  145. if [ -d "/etc/yumBak" ];then
  146. mv /etc/yumBak /etc/yumBak_$(date +%Y_%m_%d_%H_%M_%S)
  147. fi
  148. \cp -rpa /etc/yum.repos.d/ /etc/yumBak
  149. curl -Ss --connect-timeout 20 -m 60 -O ${download_Url}/src/el8repo.tar.gz
  150. if [ -f "/usr/bin/wget" ] && [ ! -s "el8repo.tar.gz" ];then
  151. wget --no-check-certificate -O el8repo.tar.gz ${download_Url}/src/el8repo.tar.gz -t 3 -T 20
  152. fi
  153. rm -f /etc/yum.repos.d/*.repo
  154. tar -xvzf el8repo.tar.gz -C /etc/yum.repos.d/
  155. rm -f el8repo.tar.gz
  156. fi
  157. }
  158. if [ -f "/etc/redhat-release" ];then
  159. Centos7Check=$(cat /etc/redhat-release | grep ' 7.' | grep -iE 'centos|Red Hat')
  160. if [ "${Centos7Check}" ];then
  161. Set_Centos7_Repo
  162. fi
  163. Centos8Check=$(cat /etc/redhat-release | grep ' 8.' | grep -iE 'centos|Red Hat')
  164. CentOS_Stream_8=$(cat /etc/redhat-release | grep 'CentOS Stream release 8' | grep -iE 'centos|Red Hat')
  165. if [ "${Centos8Check}" ] || [ "${CentOS_Stream_8}" ];then
  166. Set_Centos8_Repo
  167. fi
  168. fi
  169. setup_path="/www"
  170. python_bin=$setup_path/server/panel/pyenv/bin/python
  171. cpu_cpunt=$(cat /proc/cpuinfo | grep ^processor | wc -l)
  172. is64bit=$(getconf LONG_BIT)
  173. GetSysInfo() {
  174. if [ -s "/etc/redhat-release" ]; then
  175. SYS_VERSION=$(cat /etc/redhat-release)
  176. elif [ -s "/etc/issue" ]; then
  177. SYS_VERSION=$(cat /etc/issue)
  178. fi
  179. SYS_INFO=$(uname -a)
  180. SYS_BIT=$(getconf LONG_BIT)
  181. MEM_TOTAL=$(free -m | grep Mem | awk '{print $2}')
  182. CPU_INFO=$(getconf _NPROCESSORS_ONLN)
  183. echo -e ${SYS_VERSION}
  184. echo -e Bit:${SYS_BIT} Mem:${MEM_TOTAL}M Core:${CPU_INFO}
  185. echo -e ${SYS_INFO}
  186. echo -e "Please screenshot the above error message and post to the forum forum.aapanel.com for help"
  187. }
  188. Red_Error(){
  189. echo '============== Update Failed! ==============='
  190. printf '\033[1;31;40m%b\033[0m\n' "$@";
  191. GetSysInfo
  192. if [[ "$Install_pyenv_fielded" == "yes" ]] && [ -d "$pyenv_path/pyenv_update-panel" ]; then
  193. if [ -d "$pyenv_path/pyenv" ]; then
  194. if [ -d "$pyenv_path/pyenv_update-fail" ]; then
  195. rm -rf $pyenv_path/pyenv_update-fail
  196. fi
  197. mv $pyenv_path/pyenv $pyenv_path/pyenv_update-fail
  198. fi
  199. echo "Restoring pyenv directory"
  200. mv $pyenv_path/pyenv_update-panel $pyenv_path/pyenv
  201. fi
  202. /etc/init.d/bt start
  203. rm -f $Updating
  204. echo '============== Update Failed! ==============='
  205. exit 1;
  206. }
  207. Get_Pack_Manager() {
  208. if [ -f "/usr/bin/yum" ] && [ -d "/etc/yum.repos.d" ]; then
  209. PM="yum"
  210. elif [ -f "/usr/bin/apt-get" ] && [ -f "/usr/bin/dpkg" ]; then
  211. PM="apt-get"
  212. fi
  213. }
  214. Install_RPM_Pack() {
  215. if [ -f "/etc/redhat-release" ] && [ $(cat /etc/os-release|grep PLATFORM_ID|grep -oE "el8") ];then
  216. yum config-manager --set-enabled powertools
  217. yum config-manager --set-enabled PowerTools
  218. fi
  219. if [ -f "/etc/redhat-release" ] && [ $(cat /etc/os-release|grep PLATFORM_ID|grep -oE "el9") ];then
  220. dnf config-manager --set-enabled crb -y
  221. fi
  222. sed -i 's/SELINUX=enforcing/SELINUX=disabled/' /etc/selinux/config
  223. #yum remove -y python-requests python3-requests python-greenlet python3-greenlet
  224. yumPacks="libcurl-devel wget tar gcc make zip unzip openssl openssl-devel gcc libxml2 libxml2-devel libxslt* zlib zlib-devel libjpeg-devel libpng-devel libwebp libwebp-devel freetype freetype-devel lsof pcre pcre-devel vixie-cron crontabs icu libicu-devel c-ares libffi-devel bzip2-devel ncurses-devel sqlite-devel readline-devel tk-devel gdbm-devel db4-devel libpcap-devel xz-devel firewalld ipset libpq-devel"
  225. yum install -y ${yumPacks}
  226. for yumPack in ${yumPacks}; do
  227. rpmPack=$(rpm -q ${yumPack})
  228. packCheck=$(echo ${rpmPack} | grep not)
  229. if [ "${packCheck}" ]; then
  230. yum install ${yumPack} -y
  231. fi
  232. done
  233. if [ -f "/usr/bin/dnf" ]; then
  234. dnf install -y redhat-rpm-config
  235. fi
  236. ALI_OS=$(cat /etc/redhat-release | grep "Alibaba Cloud Linux release 3")
  237. if [ -z "${ALI_OS}" ]; then
  238. yum install epel-release -y
  239. fi
  240. }
  241. Install_Deb_Pack() {
  242. debPacks="wget curl libcurl4-openssl-dev gcc make zip unzip tar openssl libssl-dev gcc libxml2 libxml2-dev libxslt-dev zlib1g zlib1g-dev libjpeg-dev libpng-dev lsof libpcre3 libpcre3-dev cron net-tools swig build-essential libffi-dev libbz2-dev libncurses-dev libsqlite3-dev libreadline-dev tk-dev libgdbm-dev libdb-dev libdb++-dev libpcap-dev xz-utils git ufw ipset sqlite3 uuid-dev libpq-dev liblzma-dev"
  243. #DEBIAN_FRONTEND=noninteractive apt-get install -y $debPacks --allow-downgrades --allow-remove-essential --allow-change-held-packages
  244. DEBIAN_FRONTEND=noninteractive apt-get install -y $debPacks --force-yes
  245. for debPack in ${debPacks}; do
  246. packCheck=$(dpkg -l ${debPack})
  247. if [ "$?" -ne "0" ]; then
  248. DEBIAN_FRONTEND=noninteractive apt-get install -y $debPack --force-yes
  249. fi
  250. done
  251. }
  252. Get_Versions() {
  253. redhat_version_file="/etc/redhat-release"
  254. deb_version_file="/etc/issue"
  255. if [[ $(grep "Amazon Linux" /etc/os-release) ]]; then
  256. os_type="Amazon-"
  257. os_version=$(cat /etc/os-release | grep "Amazon Linux" | grep -Eo '([0-9]+\.)+[0-9]+' | grep -Eo '^[0-9]+')
  258. return
  259. fi
  260. if [[ $(grep OpenCloudOS /etc/os-release) ]]; then
  261. os_type="OpenCloudOS-"
  262. os_version=$(cat /etc/os-release | grep OpenCloudOS | grep -Eo '([0-9]+\.)+[0-9]+' | grep -Eo '^[0-9]+')
  263. if [[ $os_version == "7" ]]; then
  264. os_type="el"
  265. os_version="7"
  266. fi
  267. return
  268. fi
  269. if [[ $(grep "Linux Mint" $deb_version_file) ]]; then
  270. os_version=$(cat $deb_version_file | grep "Linux Mint" | grep -Eo '([0-9]+\.)+[0-9]+' | grep -Eo '^[0-9]+')
  271. if [ "${os_version}" = "" ]; then
  272. os_version=$(cat $deb_version_file | grep "Linux Mint" | grep -Eo '[0-9]+')
  273. fi
  274. # Linux-Mint 使用 ubuntu pyenv
  275. os_type='ubuntu'
  276. if [[ "$os_version" =~ "21" ]]; then
  277. os_version="22"
  278. echo "$os_version"
  279. fi
  280. if [[ "$os_version" =~ "20" ]]; then
  281. os_version="20"
  282. echo "$os_version"
  283. fi
  284. return
  285. fi
  286. if [[ $(grep openEuler /etc/os-release) ]]; then
  287. os_type="openEuler-"
  288. os_version=$(cat /etc/os-release | grep openEuler | grep -Eo '([0-9]+\.)+[0-9]+' | grep -Eo '^[0-9]+')
  289. return
  290. fi
  291. if [[ $(grep AlmaLinux /etc/os-release) ]]; then
  292. os_type="Alma-"
  293. os_version=$(cat /etc/os-release | grep AlmaLinux | grep -Eo '([0-9]+\.)+[0-9]+' | grep -Eo '^[0-9]+')
  294. return
  295. fi
  296. if [[ $(grep Rocky /etc/os-release) ]]; then
  297. os_type="Rocky-"
  298. os_version=$(cat /etc/os-release | grep Rocky | grep -Eo '([0-9]+\.)+[0-9]+' | grep -Eo '^[0-9]+')
  299. return
  300. fi
  301. if [[ $(grep Anolis /etc/os-release) ]] && [[ $(grep VERSION /etc/os-release|grep 8.8) ]];then
  302. if [ -f "/usr/bin/yum" ];then
  303. os_type="anolis"
  304. os_version="8"
  305. return
  306. fi
  307. fi
  308. if [ -s $redhat_version_file ]; then
  309. os_type='el'
  310. if [[ $(grep 'Alibaba Cloud Linux (Aliyun Linux) release 2' $redhat_version_file) ]]; then
  311. os_version="7"
  312. return
  313. fi
  314. is_aliyunos=$(cat $redhat_version_file | grep Aliyun)
  315. if [ "$is_aliyunos" != "" ]; then
  316. return
  317. fi
  318. if [[ $(grep "Red Hat" $redhat_version_file) ]]; then
  319. os_type='el'
  320. os_version=$(cat $redhat_version_file | grep "Red Hat" | grep -Eo '([0-9]+\.)+[0-9]+' | grep -Eo '^[0-9]')
  321. return
  322. fi
  323. if [[ $(grep "Alibaba Cloud Linux release 3 " /etc/redhat-release) ]]; then
  324. os_type="ali-linux-"
  325. os_version="3"
  326. return
  327. fi
  328. if [[ $(grep "Alibaba Cloud" /etc/redhat-release) ]] && [[ $(grep al8 /etc/os-release) ]];then
  329. os_type="ali-linux-"
  330. os_version="al8"
  331. return
  332. fi
  333. if [[ $(grep TencentOS /etc/redhat-release) ]]; then
  334. os_type="TencentOS-"
  335. os_version=$(cat /etc/redhat-release | grep TencentOS | grep -Eo '([0-9]+\.)+[0-9]+')
  336. if [[ $os_version == "2.4" ]]; then
  337. os_type="el"
  338. os_version="7"
  339. elif [[ $os_version == "3.1" ]]; then
  340. os_version="3.1"
  341. fi
  342. return
  343. fi
  344. os_version=$(cat $redhat_version_file | grep CentOS | grep -Eo '([0-9]+\.)+[0-9]+' | grep -Eo '^[0-9]')
  345. if [ "${os_version}" = "5" ]; then
  346. os_version=""
  347. fi
  348. if [ -z "${os_version}" ]; then
  349. os_version=$(cat /etc/redhat-release | grep Stream | grep -oE "8|9")
  350. fi
  351. else
  352. os_type='ubuntu'
  353. os_version=$(cat $deb_version_file | grep Ubuntu | grep -Eo '([0-9]+\.)+[0-9]+' | grep -Eo '^[0-9]+')
  354. if [ "${os_version}" = "" ]; then
  355. os_type='debian'
  356. os_version=$(cat $deb_version_file | grep Debian | grep -Eo '([0-9]+\.)+[0-9]+' | grep -Eo '[0-9]+')
  357. if [ "${os_version}" = "" ]; then
  358. os_version=$(cat $deb_version_file | grep Debian | grep -Eo '[0-9]+')
  359. fi
  360. if [ "${os_version}" = "8" ]; then
  361. os_version=""
  362. fi
  363. if [ "${is64bit}" = '32' ]; then
  364. os_version=""
  365. fi
  366. else
  367. if [ "$os_version" = "14" ]; then
  368. os_version=""
  369. fi
  370. if [ "$os_version" = "12" ]; then
  371. os_version=""
  372. fi
  373. if [ "$os_version" = "19" ]; then
  374. os_version=""
  375. fi
  376. if [ "$os_version" = "21" ]; then
  377. os_version=""
  378. fi
  379. if [ "$os_version" = "20" ]; then
  380. os_version2004=$(cat /etc/issue | grep 20.04)
  381. if [ -z "${os_version2004}" ]; then
  382. os_version=""
  383. fi
  384. fi
  385. fi
  386. fi
  387. }
  388. Install_Openssl111(){
  389. Get_Versions
  390. if [ -f "/www/server/panel/openssl_make.pl" ]; then
  391. openssl_make="yes"
  392. rm -f /www/server/panel/openssl_make.pl
  393. fi
  394. CPU_arch=$(uname -m)
  395. if [[ "${CPU_arch}" == "aarch64" ]];then
  396. CPU_arch="-aarch64"
  397. elif [[ "${CPU_arch}" == "x86_64" ]];then
  398. # x86_64 默认为空
  399. CPU_arch=""
  400. else
  401. openssl_make="yes"
  402. fi
  403. if [[ $os_type = "el" ]] && [[ $os_version == "7" ]] && [[ $openssl_make != "yes" ]]; then
  404. wget --no-check-certificate -O openssl111.tar.gz ${download_Url}/install/src/openssl111${CPU_arch}.tar.gz -t 5 -T 20
  405. tmp_size=$(du -b openssl111.tar.gz | awk '{print $1}')
  406. if [ $tmp_size -lt 5014046 ]; then
  407. rm -f openssl111.tar.gz
  408. Red_Error "ERROR: Download openssl111.tar.gz fielded."
  409. fi
  410. tar zxvf openssl111.tar.gz -C /usr/local/
  411. rm -f openssl111.tar.gz
  412. if [ ! -f "/usr/local/openssl111/bin/openssl" ];then
  413. Red_Error "/usr/local/openssl111/bin/openssl file does not exist!"
  414. fi
  415. export LD_LIBRARY_PATH=/usr/local/openssl111/lib:$LD_LIBRARY_PATH
  416. echo "/usr/local/openssl111/lib" > /etc/ld.so.conf.d/zopenssl111.conf
  417. ldconfig
  418. else
  419. if [ -f "/usr/bin/yum" ] && [ -d "/etc/yum.repos.d" ]; then
  420. yum install -y perl lksctp-tools-devel
  421. else
  422. apt install -y perl
  423. fi
  424. opensslVersion="1.1.1o"
  425. wget --no-check-certificate -O openssl-${opensslVersion}.tar.gz ${download_Url}/src/openssl-${opensslVersion}.tar.gz -t 5 -T 20
  426. tmp_size=$(du -b openssl-${opensslVersion}.tar.gz | awk '{print $1}')
  427. if [ $tmp_size -lt 9056386 ]; then
  428. rm -f openssl-${opensslVersion}.tar.gz
  429. Red_Error "ERROR: Download openssl-${opensslVersion}.tar.gz fielded."
  430. fi
  431. tar -zxvf openssl-${opensslVersion}.tar.gz
  432. if [ ! -d "openssl-${opensslVersion}" ];then
  433. Red_Error "Decompression failed openssl-${opensslVersion} Directory does not exist!"
  434. fi
  435. cd openssl-${opensslVersion}
  436. ./config --prefix=/usr/local/openssl111 --openssldir=/usr/local/openssl111 enable-md2 enable-rc5 sctp zlib-dynamic shared -fPIC
  437. make -j$cpu_cpunt
  438. make install
  439. if [ ! -f "/usr/local/openssl111/bin/openssl" ];then
  440. Red_Error "Compilation failed /usr/local/openssl111/bin/openssl file does not exist!"
  441. fi
  442. export LD_LIBRARY_PATH=/usr/local/openssl111/lib:$LD_LIBRARY_PATH
  443. echo "/usr/local/openssl111/lib" > /etc/ld.so.conf.d/zopenssl111.conf
  444. ldconfig
  445. cd ..
  446. rm -rf openssl-${opensslVersion} openssl-${opensslVersion}.tar.gz
  447. fi
  448. openssl111Check=$(/usr/local/openssl111/bin/openssl version|grep 1.1.1)
  449. if [ -z "${openssl111Check}" ];then
  450. Red_Error "openssl-1.1.1 install failed!"
  451. fi
  452. }
  453. Check_Openssl_Version(){
  454. if [ -f "/etc/redhat-release" ]; then
  455. check_os_version=$(cat /etc/redhat-release | grep -E "Red Hat|CentOS" | grep -Eo '([0-9]+\.)+[0-9]+' | grep -Eo '^[0-9]')
  456. # echo "$check_os_version"
  457. fi
  458. OPENSSL_VER=$(openssl version|grep -oE '1.0|1.1.0')
  459. if [ "$check_os_version" == "7" ] || [ "${OPENSSL_VER}" ]; then
  460. if [ ! -f "/usr/local/openssl111/bin/openssl" ]; then
  461. Install_Openssl111
  462. else
  463. export LD_LIBRARY_PATH=/usr/local/openssl111/lib:$LD_LIBRARY_PATH
  464. openssl111Check=$(/usr/local/openssl111/bin/openssl version|grep 1.1.1)
  465. if [ -z "${openssl111Check}" ];then
  466. Install_Openssl111
  467. fi
  468. if [ ! -f "/etc/ld.so.conf.d/openssl111.conf" ] || [ ! -f "/etc/ld.so.conf.d/zopenssl111.conf" ]; then
  469. echo "/usr/local/openssl111/lib" > /etc/ld.so.conf.d/zopenssl111.conf
  470. ldconfig
  471. fi
  472. ldconfig
  473. fi
  474. Use_Openssl111="yes"
  475. fi
  476. }
  477. Update_Py_Lib(){
  478. # Need to use Werkzeug 2.2.3
  479. mypip="/www/server/panel/pyenv/bin/pip3"
  480. Werkzeug_path="/www/server/panel/script/Werkzeug-2.2.3-py3-none-any.whl"
  481. # pycountry_path="/www/server/panel/script/pycountry-24.6.1-py3-none-any.whl"
  482. pyOpenSSL_path="/www/server/panel/script/pyOpenSSL-23.1.1-py3-none-any.whl"
  483. #change_pip_package_list=$( $mypip list | grep -E "Werkzeug|lxml|pycountry" )
  484. change_pip_package_list=$( $mypip list | grep -E "Werkzeug|lxml" )
  485. Werkzeug_v=$(echo "$change_pip_package_list" | grep Werkzeug | grep 2.2.3)
  486. if [ "$Werkzeug_v" = "" ];then
  487. echo "Update Werkzeug"
  488. $mypip uninstall Werkzeug -y
  489. $mypip install $Werkzeug_path
  490. Werkzeug_v_2=$($mypip list |grep Werkzeug | grep 2.2.3)
  491. if [ "$Werkzeug_v_2" = "" ];then
  492. $mypip install Werkzeug==2.2.3
  493. fi
  494. fi
  495. # pycountry_v=$(echo "$change_pip_package_list" | grep pycountry)
  496. # if [ "$pycountry_v" = "" ];then
  497. # echo "Update pycountry"
  498. # $mypip install $pycountry_path
  499. # rm -f $pycountry_path
  500. # pycountry_v_2=$($mypip list |grep pycountry)
  501. # if [ "$pycountry_v_2" = "" ];then
  502. # $mypip install pycountry
  503. # fi
  504. # fi
  505. # pyOpenSSL_v=$(echo "$change_pip_package_list" | grep pyOpenSSL | grep 23.1.1)
  506. # if [ "$pyOpenSSL_v" = "" ];then
  507. # echo "Update pyOpenSSL"
  508. # $mypip uninstall pyOpenSSL cryptography -y
  509. # $mypip install $pyOpenSSL_path cryptography==40.0.2
  510. # pyOpenSSL_v_2=$($mypip list |grep pyOpenSSL | grep 23.1.1)
  511. # if [ "$pyOpenSSL_v_2" = "" ];then
  512. # $mypip install pyOpenSSL==23.1.1 cryptography==40.0.2
  513. # fi
  514. # fi
  515. lxml_v=$(echo "$change_pip_package_list" | grep lxml | grep 5.2.1)
  516. if [ "$lxml_v" != "" ];then
  517. echo "Update lxml"
  518. $mypip uninstall lxml -y
  519. # bt 16 升级脚本时安装,安装时间久 这里不开,下面进行处理了
  520. # echo "Please wait a moment to install lxml, it will take a long time."
  521. # $mypip install lxml==5.0.0
  522. # lxml_v_2=$($mypip list |grep lxml | grep 5.2.1)
  523. # if [ "$lxml_v_2" = "" ];then
  524. # $mypip install lxml==5.0.0
  525. # fi
  526. fi
  527. }
  528. Install_Python_Lib() {
  529. # openssl version is lower than 1.1.1 and needs to be installed, such as CentOS 7
  530. Check_Openssl_Version
  531. curl -Ss --connect-timeout 3 -m 60 $download_Url/install/pip_select.sh | bash
  532. pyenv_path="/www/server/panel"
  533. if [ -f $pyenv_path/pyenv/bin/python ]; then
  534. is_ssl=$($python_bin -c "import ssl" 2>&1 | grep cannot)
  535. $pyenv_path/pyenv/bin/python3.12 -V
  536. if [ $? -eq 0 ] && [ -z "${is_ssl}" ]; then
  537. chmod -R 700 $pyenv_path/pyenv/bin
  538. is_package=$($python_bin -m psutil 2>&1 | grep package)
  539. if [ "$is_package" = "" ]; then
  540. wget --no-check-certificate -O $pyenv_path/pyenv/pip.txt $download_Url/install/pyenv/3.12/pip_en_3.12.txt -t 5 -T 20
  541. $pyenv_path/pyenv/bin/pip install -U pip
  542. $pyenv_path/pyenv/bin/pip install -U setuptools
  543. $pyenv_path/pyenv/bin/pip install -r $pyenv_path/pyenv/pip.txt
  544. fi
  545. source $pyenv_path/pyenv/bin/activate
  546. chmod -R 700 $pyenv_path/pyenv/bin
  547. return
  548. else
  549. rm -rf $pyenv_path/pyenv
  550. fi
  551. fi
  552. py_version="3.12.3"
  553. python_version="-3.12"
  554. mkdir -p $pyenv_path
  555. echo "True" >/www/disk.pl
  556. if [ ! -w /www/disk.pl ]; then
  557. Red_Error "ERROR: Install python env fielded." "ERROR: path [www] cannot be written, please check the directory/user/disk permissions!"
  558. fi
  559. os_type='el'
  560. os_version='7'
  561. # is_export_openssl=0
  562. Get_Versions
  563. echo "OS: $os_type - $os_version"
  564. is_aarch64=$(uname -m | grep aarch64)
  565. if [ "$is_aarch64" != "" ]; then
  566. is64bit="aarch64"
  567. fi
  568. if [ -f "/www/server/panel/pymake.pl" ]; then
  569. os_version=""
  570. rm -f /www/server/panel/pymake.pl
  571. fi
  572. if [ "${os_version}" != "" ]; then
  573. pyenv_file="/www/pyenv.tar.gz"
  574. wget --no-check-certificate -O $pyenv_file $download_Url/install/pyenv/3.12/pyenv-${os_type}${os_version}-x${is64bit}${python_version}.tar.gz -t 5 -T 20
  575. if [ "$?" != "0" ];then
  576. wget --no-check-certificate -O $pyenv_file $download_Url/install/pyenv/3.12/pyenv-${os_type}${os_version}-x${is64bit}${python_version}.tar.gz -t 5 -T 20
  577. fi
  578. tmp_size=$(du -b $pyenv_file | awk '{print $1}')
  579. if [ $tmp_size -lt 122271175 ]; then
  580. rm -f $pyenv_file
  581. echo "ERROR: Download python env fielded."
  582. else
  583. echo "Install python env..."
  584. tar zxvf $pyenv_file -C $pyenv_path/ >/dev/null
  585. chmod -R 700 $pyenv_path/pyenv/bin
  586. if [ ! -f $pyenv_path/pyenv/bin/python ]; then
  587. Install_pyenv_fielded="yes"
  588. rm -f $pyenv_file
  589. Red_Error "ERROR: Install python env fielded. Please try again."
  590. fi
  591. $pyenv_path/pyenv/bin/python3.12 -V
  592. if [ $? -eq 0 ]; then
  593. rm -f $pyenv_file
  594. ln -sf $pyenv_path/pyenv/bin/pip3.12 /usr/bin/btpip
  595. ln -sf $pyenv_path/pyenv/bin/python3.12 /usr/bin/btpython
  596. source $pyenv_path/pyenv/bin/activate
  597. return
  598. else
  599. rm -f $pyenv_file
  600. rm -rf $pyenv_path/pyenv
  601. fi
  602. fi
  603. fi
  604. Get_Pack_Manager
  605. if [ "${PM}" = "yum" ]; then
  606. Install_RPM_Pack
  607. elif [ "${PM}" = "apt-get" ]; then
  608. Install_Deb_Pack
  609. fi
  610. cd /www
  611. python_src='/www/python_src.tar.xz'
  612. python_src_path="/www/Python-${py_version}"
  613. wget --no-check-certificate -O $python_src $download_Url/src/Python-${py_version}.tar.xz -t 5 -T 20
  614. tmp_size=$(du -b $python_src | awk '{print $1}')
  615. if [ $tmp_size -lt 10703460 ]; then
  616. Install_pyenv_fielded="yes"
  617. rm -f $python_src
  618. Red_Error "ERROR: Download python source code fielded. Please try again."
  619. fi
  620. tar xvf $python_src
  621. rm -f $python_src
  622. cd $python_src_path
  623. if [[ $Use_Openssl111 = "yes" ]]; then
  624. # centos7 或者低openssl于1.1.1使用
  625. export OPENSSL_DIR=/usr/local/openssl111
  626. ./configure --prefix=$pyenv_path/pyenv \
  627. LDFLAGS="-L$OPENSSL_DIR/lib" \
  628. CPPFLAGS="-I$OPENSSL_DIR/include" \
  629. --with-openssl=$OPENSSL_DIR
  630. else
  631. ./configure --prefix=$pyenv_path/pyenv
  632. fi
  633. make -j$cpu_cpunt
  634. make install
  635. if [ ! -f $pyenv_path/pyenv/bin/python3.12 ]; then
  636. rm -rf $python_src_path
  637. Install_pyenv_fielded="yes"
  638. Red_Error "ERROR: Make python env fielded. Please try again."
  639. fi
  640. cd ~
  641. rm -rf $python_src_path
  642. wget --no-check-certificate -O $pyenv_path/pyenv/bin/activate $download_Url/install/pyenv/activate.panel -t 5 -T 20
  643. wget --no-check-certificate -O $pyenv_path/pyenv/pip.txt $download_Url/install/pyenv/3.12/pip-3.12.3.txt -t 5 -T 20
  644. ln -sf $pyenv_path/pyenv/bin/pip3.12 $pyenv_path/pyenv/bin/pip
  645. ln -sf $pyenv_path/pyenv/bin/python3.12 $pyenv_path/pyenv/bin/python
  646. ln -sf $pyenv_path/pyenv/bin/pip3.12 /usr/bin/btpip
  647. ln -sf $pyenv_path/pyenv/bin/python3.12 /usr/bin/btpython
  648. chmod -R 700 $pyenv_path/pyenv/bin
  649. $pyenv_path/pyenv/bin/pip install -U pip
  650. $pyenv_path/pyenv/bin/pip install -U setuptools
  651. # $pyenv_path/pyenv/bin/pip install -U wheel==0.34.2
  652. $pyenv_path/pyenv/bin/pip install -r $pyenv_path/pyenv/pip.txt
  653. source $pyenv_path/pyenv/bin/activate
  654. btpip install psutil
  655. btpip install gevent
  656. is_gevent=$($python_bin -m gevent 2>&1 | grep -oE package)
  657. is_psutil=$($python_bin -m psutil 2>&1 | grep -oE package)
  658. if [ "${is_gevent}" != "${is_psutil}" ]; then
  659. Install_pyenv_fielded="yes"
  660. Red_Error "ERROR: psutil/gevent install failed! Please try again."
  661. fi
  662. }
  663. delete_useless_package() {
  664. /www/server/panel/pyenv/bin/pip uninstall aliyun-python-sdk-kms -y >/dev/null 2>&1
  665. /www/server/panel/pyenv/bin/pip uninstall aliyun-python-sdk-core -y >/dev/null 2>&1
  666. /www/server/panel/pyenv/bin/pip uninstall aliyun-python-sdk-core-v3 -y >/dev/null 2>&1
  667. /www/server/panel/pyenv/bin/pip uninstall qiniu -y >/dev/null 2>&1
  668. /www/server/panel/pyenv/bin/pip uninstall cos-python-sdk-v5 -y >/dev/null 2>&1
  669. }
  670. Upgrade_python312() {
  671. # 获取/www目录所在分区的可用空间(以KB为单位)
  672. available_kb=$(df -k /www | awk 'NR==2 {print $4}')
  673. # 1GB = 1024MB = 1024*1024KB
  674. available_gb=$((available_kb / 1024 / 1024))
  675. echo "/www partition currently available space: "$available_gb" G"
  676. # 判断可用空间是否小于1GB
  677. if [ "$available_gb" -lt 1 ]; then
  678. echo -e "\033[31m The available space is less than 1G.\033[0m"
  679. echo -e "\033[31m It is recommended to clean or upgrade the server space before upgrading.\033[0m"
  680. rm -f $Updating
  681. exit 1;
  682. fi
  683. # /etc/init.d/bt stop
  684. if [ -f /etc/init.d/bt_syssafe ]; then
  685. echo "Turning off System hardening"
  686. System_hardening="yes"
  687. /etc/init.d/bt_syssafe stop
  688. if [ -d "/etc/rc.d/" ]; then
  689. chattr -iaR /etc/rc.d/
  690. fi
  691. chattr -iaR /etc/init.d
  692. fi
  693. if [ -d "/www/server/panel/pyenv" ]; then
  694. echo "Backup old pyenv"
  695. if [ -d "/www/server/panel/pyenv_update-panel" ];then
  696. mv /www/server/panel/pyenv_update-panel /www/server/panel/pyenv_update-panel_$(date +%Y_%m_%d_%H_%M_%S)
  697. fi
  698. mv /www/server/panel/pyenv /www/server/panel/pyenv_update-panel
  699. fi
  700. Install_Python_Lib
  701. delete_useless_package
  702. }
  703. Check_python_version() {
  704. is_loongarch64=$(uname -a | grep loongarch64)
  705. if [ "$is_loongarch64" != "" ]; then
  706. echo "loongarch64 does not currently support upgrades"
  707. rm -f $Updating
  708. exit
  709. fi
  710. if [ -f "/www/server/panel/pyenv/bin/python" ]; then
  711. get_python_version=$(/www/server/panel/pyenv/bin/python -V)
  712. if [[ ${get_python_version} =~ "Python 3.7." ]]; then
  713. echo ${get_python_version}
  714. Upgrade_python312
  715. else
  716. if [[ ${get_python_version} =~ "Python 3.12." ]]; then
  717. echo -e "Python3.12 No upgrade required"
  718. else
  719. Upgrade_python312
  720. fi
  721. fi
  722. else
  723. echo -e "/www/server/panel/pyenv/bin/python Does not exist, cannot determine python version"
  724. Upgrade_python312
  725. fi
  726. }
  727. Check_python_version
  728. Check_Openssl_Version
  729. # mypip="pip"
  730. # env_path=/www/server/panel/pyenv/bin/activate
  731. # if [ -f $env_path ];then
  732. # mypip="/www/server/panel/pyenv/bin/pip"
  733. # fi
  734. mypip="/www/server/panel/pyenv/bin/pip"
  735. pip_list=$($mypip list)
  736. setuptools_v=$(echo "$pip_list"|grep setuptools)
  737. if [ "$setuptools_v" = "" ];then
  738. $mypip install setuptools
  739. fi
  740. requests_v=$(echo "$pip_list"|grep requests)
  741. if [ "$requests_v" = "" ];then
  742. $mypip install requests
  743. fi
  744. openssl_v=$(echo "$pip_list"|grep pyOpenSSL)
  745. if [ "$openssl_v" = "" ];then
  746. $mypip install -I pyOpenSSL
  747. fi
  748. pymysql=$(echo "$pip_list"|grep PyMySQL)
  749. if [ "$pymysql" = "" ];then
  750. $mypip install PyMySQL
  751. fi
  752. GEVENT_V=$(echo "$pip_list"|grep "gevent "|awk '{print $2}'|cut -f 1 -d '.')
  753. if [ "${GEVENT_V}" -le "1" ];then
  754. $mypip install -I gevent
  755. fi
  756. pycryptodome=$(echo "$pip_list"|grep pycryptodome)
  757. if [ "$pycryptodome" = "" ];then
  758. $mypip install pycryptodome
  759. fi
  760. lxml=$(echo "$pip_list"|grep lxml | grep 5.2.1)
  761. if [ "$lxml" != "" ];then
  762. $mypip uninstall lxml -y
  763. echo "Please wait a moment to install lxml, it will take a long time."
  764. $mypip install lxml==5.0.0
  765. fi
  766. lxml_2=$($mypip list|grep lxml)
  767. if [ "$lxml_2" = "" ];then
  768. $mypip install lxml==5.0.0
  769. fi
  770. # $mypip install pyOpenSSL -I
  771. # $mypip install python-telegram-bot==20.3
  772. # $mypip install paramiko -I
  773. telegram_v=$(echo "$pip_list"|grep python-telegram-bot)
  774. if [ "$telegram_v" = "" ];then
  775. $mypip install python-telegram-bot==20.3
  776. fi
  777. # pycountry_v=$(echo "$pip_list"|grep pycountry)
  778. # if [ "$pycountry_v" = "" ];then
  779. # $mypip install pycountry==24.6.1
  780. # fi
  781. if [ -f "/www/server/panel/plugin/linuxsys/linuxsys_main.py" ]; then
  782. distro_v=$(echo "$pip_list"|grep distro)
  783. if [ "$distro_v" = "" ];then
  784. $mypip install distro
  785. fi
  786. fi
  787. if [ -f "/www/server/panel/plugin/aws_s3/aws_s3_main.py" ]; then
  788. boto3_v=$(echo "$pip_list"|grep boto3)
  789. if [ "$boto3_v" = "" ];then
  790. $mypip install boto3
  791. fi
  792. fi
  793. if [ -f "/www/server/panel/plugin/frp/frp_main.py" ]; then
  794. toml_v=$(echo "$pip_list"|grep toml)
  795. if [ "$toml_v" = "" ];then
  796. $mypip install toml
  797. fi
  798. fi
  799. if [ -f "/www/server/panel/plugin/supervisor/supervisor_main.py" ]; then
  800. pyasynchat_v=$(echo "$pip_list"|grep pyasynchat)
  801. if [ "$pyasynchat_v" = "" ];then
  802. $mypip install pyasynchat
  803. fi
  804. Supervisor_plugin=/www/server/panel/plugin/supervisor
  805. Supervisor_py=/www/server/panel/pyenv/lib/python3.12/site-packages/supervisor
  806. if [ -d "$Supervisor_py" ]; then
  807. \cp -rpaf $Supervisor_py/options.py $Supervisor_plugin/options.py.bak
  808. \cp -rpaf $Supervisor_plugin/options.py $Supervisor_py/options.py
  809. \cp -rpaf $Supervisor_py/rpcinterface.py $Supervisor_plugin/rpcinterface.py.bak
  810. \cp -rpaf $Supervisor_plugin/rpcinterface.py $Supervisor_py/rpcinterface.py
  811. echo bt > $Supervisor_py/bt.pl
  812. fi
  813. fi
  814. if [ -f "$setup_path/server/panel/pyenv/bin/python3.12" ] && [ ! -f "$setup_path/server/panel/data/upgrade_plugins_3.12.pl" ];then
  815. chmod +x $setup_path/server/panel/tools.py
  816. $setup_path/server/panel/pyenv/bin/python3 $setup_path/server/panel/tools.py upgrade_plugins
  817. fi
  818. if [[ "$System_hardening" == "yes" ]]; then
  819. echo "Turning on System hardening"
  820. /etc/init.d/bt_syssafe start
  821. fi
  822. only_update_pyenv312="/tmp/only_update_pyenv312.pl"
  823. if [ -f "$only_update_pyenv312" ]; then
  824. Update_Py_Lib
  825. rm -f $Updating $only_update_pyenv312
  826. /etc/init.d/bt restart
  827. echo "$only_update_pyenv312 file exists, Only update Python3.12 environment complete!"
  828. exit 0;
  829. fi
  830. version=$(curl -Ss --connect-timeout 12 -m 2 $Btapi_Url/api/panel/getLatestOfficialVersion)
  831. check_version_num=$( echo "$version"|grep -Eo '^[0-9]+' )
  832. if [ "$check_version_num" = '' ];then
  833. echo "Check version failed!"
  834. version='7.0.13'
  835. fi
  836. if [ "$version" = '' ];then
  837. version='7.0.13'
  838. fi
  839. # if [ "$1" ];then
  840. # version="$1"
  841. # fi
  842. wget --no-check-certificate -t 5 -T 20 -O /tmp/panel.zip $Btapi_Url/install/update/LinuxPanel_EN-${version}.zip
  843. dsize=$(du -b /tmp/panel.zip|awk '{print $1}')
  844. if [ $dsize -lt 10240 ];then
  845. echo "Failed to get update package, please update or contact aaPanel Operation"
  846. rm -f $Updating
  847. exit;
  848. fi
  849. unzip -o /tmp/panel.zip -d $setup_path/server/ > /dev/null
  850. rm -f /tmp/panel.zip
  851. Update_Py_Lib
  852. cd $setup_path/server/panel/
  853. check_bt=`cat /etc/init.d/bt`
  854. if [ "${check_bt}" = "" ];then
  855. chattr -i /etc/init.d/bt
  856. rm -f /etc/init.d/bt
  857. wget --no-check-certificate -O /etc/init.d/bt $download_Url/install/src/bt7_en.init -t 5 -T 20
  858. chmod +x /etc/init.d/bt
  859. fi
  860. rm -f /www/server/panel/*.pyc
  861. rm -f /www/server/panel/class/*.pyc
  862. rm -f /www/server/panel/class/__pycache__/*.pyc
  863. rm -f /www/server/panel/class_v2/__pycache__/*.pyc
  864. rm -f /www/server/panel/class/*.so
  865. if [ ! -f /www/server/panel/data/userInfo.json ]; then
  866. echo "{\"id\":1,\"uid\":1,\"last_login_ip\":\"127.0.0.1\",\"username\":\"Administrator\",\"email\":\"admin@aapanel.com\",\"status\":1,\"token\":\"aaa.bbb.ccc\"}" > /www/server/panel/data/userInfo.json
  867. fi
  868. grep "www:x" /etc/passwd > /dev/null
  869. if [ "$?" != 0 ];then
  870. Run_User="www"
  871. groupadd ${Run_User}
  872. useradd -s /sbin/nologin -g ${Run_User} ${Run_User}
  873. fi
  874. chattr -i /etc/init.d/bt
  875. chmod +x /etc/init.d/bt
  876. echo "====================================="
  877. rm -f /dev/shm/bt_sql_tips.pl
  878. process=$(ps aux|grep -E "task.pyc|main.py"|grep -v grep|awk '{print $2}')
  879. if [ "$process" != "" ];then
  880. kill $process
  881. fi
  882. /etc/init.d/bt restart
  883. # /etc/init.d/bt start
  884. # echo 'True' > /www/server/panel/data/restart.pl
  885. rm -f $Updating
  886. echo "Successfully upgraded to[$version]${Ver}";
  887. if [ -f "/www/server/panel/beta_git_1_line.log" ];then
  888. rm -f /www/server/panel/beta_git_1_line.log
  889. fi
  890. if [ -f "/www/server/panel/pro_git_1_line.log" ];then
  891. rm -f /www/server/panel/pro_git_1_line.log
  892. fi