TShopping

 找回密碼
 註冊
搜索
查看: 447|回復: 0
打印 上一主題 下一主題

[CentOS] CentOS 8 安裝 Http + php 7.4 + MySQL 8.0 改 root 密碼+phpMyAdmin

[複製鏈接]
跳轉到指定樓層
1#
發表於 2023-4-28 21:24:40 | 只看該作者 |只看大圖 回帖獎勵 |倒序瀏覽 |閱讀模式
 
Push to Facebook


環境
CentOS 8.2
安裝與啟動 MySQL
在 CentOS 8 以後 yum 漸漸的會被 dnf 取代,因此都會以 dnf 來做套件安裝移除的動作。開啟 Terminal,安裝 MySQL
  1. dnf update -y
複製代碼
  1. sudo dnf install -y mysql-server
複製代碼

  1. systemctl start mysqld.service   # 馬上開啟mysql daeman(MySQL服務)
複製代碼
  1. systemctl enable mysqld.service  # 之後開機也要自動開啟MySQL服務
複製代碼

  1. systemctl status mysqld.service  # 查詢MySQL服務的狀態
複製代碼


設定 root 密碼
簡易方法

可以使用 mysql_secure_installation 來設定與安全性相關的設定,這個設定工具透過互動式問答幫助管理者設定 root 密碼、移除匿名登入帳號、禁止 root 從遠端登入、移除測試用的資料庫。

  1. mysql_secure_installation
複製代碼

登入 MySQL
用密碼登入 MySQL ,看到 Welcome to the MySQL monitor. 就成功囉

進階方法
  1. mysql -u root   # ← 沒有密碼所以不用參數 -p
複製代碼
使用 SQL 修改密碼
  1. mysql>ALTER USER 'root'@'localhost' IDENTIFIED BY 'password';  # password 改為要設定的密碼
複製代碼
登入 MySQL
  1. mysql -u root -p
複製代碼

Enter password:        # ← 這裡輸入剛設定的密碼
Welcome to the MySQL monitor.  Commands end with ; or \g.

忘記 root 密碼
若是之前有裝過 MySQL,現在不記得 root 的密碼,請參考 HOW TO REMOVE MYSQL ENTIRELY FROM LINUX SYSTEM(CENTOS) 先清除舊的 MySQL 資料再安裝,預設密碼就會為空。


安裝 APACHE + PHP 7.4添加 EPEL 和 REMI 存儲庫
  1. yum -y install https://dl.fedoraproject.org/pub/epel/epel-release-latest-8.noarch.rpm
  2. yum -y install https://rpms.remirepo.net/enterprise/remi-release-8.rpm
複製代碼
  1. dnf -y install dnf-utils
  2. dnf module reset php -y
  3. dnf module install php:remi-7.4 -y
複製代碼
  1. php -v
複製代碼
  1. yum install httpd wget php-{pear,cgi,common,curl,mbstring,gd,mysqlnd,gettext,bcmath,json,xml,fpm,intl,zip,imap}
複製代碼
安裝PHP 7.2 元件可參考
  1. dnf -y install httpd php php-pdo php-pecl-zip php-json php-common php-fpm php-mbstring php-cli php-mysqlnd gdlib
複製代碼
下載phpMyAdmin 並解開上傳到網頁目錄

修改phpmyadmin設定檔
  1. vi config.inc.php
複製代碼
  1. systemctl restart httpd #啟動APACHE
  2. setsebool -P httpd_enable_homedirs=1 #開啟家目錄SETLINUX
  3. setsebool -P httpd_can_network_connect_db=1
  4. restorecon -R /home
  5. chmod 711 /home/user #家目錄開啟權限
  6. firewall-cmd --zone=public --add-port=80/tcp --permanent #開啟防火牆PORT 80
複製代碼
  1. firewall-cmd --permanent --zone=public --add-service=http
  2. firewall-cmd --permanent --zone=public --add-service=https
複製代碼
  1. firewall-cmd --reload
複製代碼
  1. yum install httpd-devel
  2. yum groupinstall 'Development tools'
複製代碼
  1. setsebool -P httpd_can_network_connect 1
  2. setsebool -P httpd_graceful_shutdown 1
  3. setsebool -P httpd_can_network_relay 1
  4. setsebool -P nis_enabled 1
  5. ausearch -c 'php-fpm' --raw | audit2allow -M my-phpfpm
  6. semodule -X 300 -i my-phpfpm.pp
複製代碼

如果有用PHP Smarty 3.1 一定要打開此SELINUX服務
  1. setsebool -P httpd_unified=1
複製代碼
不開會有錯誤訊息
  1. SELinux 防止 /usr/sbin/php-fpm 進行 write 存取於 目錄 templates_c 上。#012#012*****  插件 catchall_boolean (89.3 信賴度) 項建議   **********************************#012#012若您希望 allow httpd to unified#012接著 您必須啟用「httpd_unified」布林值以通知 SELinux。#012#012執行#012setsebool -P httpd_unified 1#012#012*****  插件 catchall (11.6 信
  2. 賴度) 項建議   ******************************************#012#012若您相信 php-fpm 應該預設允許在 templates_c directory 上作 write 存取。#012接著 您應將此回報為錯誤。#012您可產生本機模組,以允許這項存取。#012執行#012立刻允許此存取,請執行:#012# ausearch -c 'php-fpm' --raw | audit2allow -M my-phpfpm#012# semodule -X 300 -i my-phpfpm.pp#012
複製代碼

查詢APACHE模組
  1. apachectl -M
複製代碼

修改設定httpd.conf 如下
  1. vi /etc/httpd/conf/httpd.conf
複製代碼
  1. <Directory />
  2.     Options Indexes FollowSymLinks
  3.     AllowOverride none
  4.     Require all granted
  5. </Directory>
複製代碼



參考文章

http://n.sfs.tw/content/index/14380
https://www.server-world.info/en/note?os=CentOS_8&p=httpd&f=4
https://weirenxue.github.io/2021 ... tos_mysql_8_0_root/


https://computingforgeeks.com/how-to-install-php-7-4-on-centos-rhel-8/


 

臉書網友討論
*滑块验证:
您需要登錄後才可以回帖 登錄 | 註冊 |

本版積分規則



Archiver|手機版|小黑屋|免責聲明|TShopping

GMT+8, 2024-4-27 13:55 , Processed in 0.058484 second(s), 25 queries .

本論壇言論純屬發表者個人意見,與 TShopping綜合論壇 立場無關 如有意見侵犯了您的權益 請寫信聯絡我們。

Powered by Discuz! X3.2

© 2001-2013 Comsenz Inc.

快速回復 返回頂部 返回列表