linux下如何部署php項目?

来源:https://www.cnblogs.com/a609251438/archive/2019/12/23/12088708.html
-Advertisement-
Play Games

linux下部署php項目環境可以分為兩種,一種使用Apache,php,mysql的壓縮包安裝,一種用yum命令進行安裝。 使用三種軟體的壓縮包進行安裝,需要手動配置三者之間的關係。apache和php之間的配置沒有什麼難度,但是和mysql進行配置的時候就需要對php的瞭解了。 我的官方群點擊此 ...


linux下部署php項目環境可以分為兩種,一種使用Apache,php,mysql的壓縮包安裝,一種用yum命令進行安裝。

使用三種軟體的壓縮包進行安裝,需要手動配置三者之間的關係。apache和php之間的配置沒有什麼難度,但是和mysql進行配置的時候就需要對php的瞭解了。

我的官方群點擊此處

以下是用yum在linux中配置php環境:

MySql

  1.mysql和apache最好是首先進行安裝的,因為在配置php的時候需要與mysql和apache進行關聯配置和測試

首先下載mysql-sever文件,因為博主linux環境是CentOS版本,yum源中貌似沒有正常安裝mysql時的mysql-sever文件,需要去官網上下載

1.下載mysql-service文件
[root@tele-1 ~]# wget
mysql-service
[root@tele-1 ~]# rpm -ivh mysql-community-release-el7-5.noarch.rpm

2.安裝mysql

[root@tele-1 ~]# yum install mysql-community-server

3.安裝完畢之後啟動mysql服務

[root@tele-1 ~]# service mysqld restart

4. 初步安裝的mysql是沒有密碼的,用戶名預設是root。所以我們需要修改密碼,用mysql命令行進行修改

 1.進入mysql命令行

[root@tele-1 ~]# mysql -urootWelcome to the MySQL monitor.  Commands end with ; or \g.Your MySQL connection id is 474801Server version: 5.6.36 MySQL Community Server (GPL)

 

Copyright (c) 2000, 2017, Oracle and/or its affiliates. All rights reserved.Oracle is a registered trademark of Oracle Corporation and/or its

affiliates. Other names may be trademarks of their respective

owners.Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.mysql>

2.使用命令進行密碼修改

mysql> set password for 'root'@'localhost' = password('你要修改的密碼');
Query OK, 0 rows affected (0.06 sec) 

5.因為博主是用本地navicat軟體來連接linux下的mysql的,所以如果要在本地訪問的話,就需要改一下mysql資料庫中的user表了

1.操作mysql資料庫表

mysql> use mysql;

Reading table information for completion of table and column names

You can turn off this feature to get a quicker startup with -A

 

Database changedmysql>

2.查看user表中的數據(在mysql命令行中可以直接進行sql語句編寫)

mysql> select * from user;+-----------+------+-----------------------------------+-------------+-------------+-------------+-------------+-------------+-----------+-------------+---------------+--------------+-----------+------------+-----------------+------------+------------+--------------+------------+-----------------------+------------------+--------------+-----------------+------------------+------------------+----------------+---------------------+--------------------+------------------+------------+--------------+------------------------+----------+------------+-------------+--------------+---------------+-------------+-----------------+----------------------+-----------------------+-----------------------+------------------+

| Host      | User | Password                                  | Select_priv | Insert_priv | Update_priv | Delete_priv | Create_priv | Drop_priv | Reload_priv | Shutdown_priv | Process_priv | File_priv | Grant_priv | References_priv | Index_priv | Alter_priv | Show_db_priv | Super_priv | Create_tmp_table_priv | Lock_tables_priv | Execute_priv | Repl_slave_priv | Repl_client_priv | Create_view_priv | Show_view_priv | Create_routine_priv | Alter_routine_priv | Create_user_priv | Event_priv | Trigger_priv | Create_tablespace_priv | ssl_type | ssl_cipher | x509_issuer | x509_subject | max_questions | max_updates | max_connections | max_user_connections | plugin                | authentication_string | password_expired |

+-----------+------+-----------------------------------+-------------+-------------+-------------+-------------+-------------+-----------+-------------+---------------+--------------+-----------+------------+-----------------+------------+------------+--------------+------------+-----------------------+------------------+--------------+-----------------+------------------+------------------+----------------+---------------------+--------------------+------------------+------------+--------------+------------------------+----------+------------+-------------+--------------+---------------+-------------+-----------------+----------------------+-----------------------+-----------------------+------------------+| %         | root | *3ce8dad2446975d8b0c771bd7e48d15b | Y           | Y           | Y           | Y           | Y           | Y         | Y           | Y             | Y            | Y         | Y          | Y               | Y          | Y          | Y            | Y          | Y                     | Y                | Y            | Y               | Y                | Y                | Y              | Y                   | Y                  | Y                | Y          | Y            | Y                      |          |            |             |              |             0 |           0 |               0 |                    0 | mysql_native_password |                       | N                || localhost | root | *3ce8dad2446975d8b0c771bd7e48d15b | Y           | Y           | Y           | Y           | Y           | Y         | Y           | Y             | Y            | Y         | Y          | Y               | Y          | Y          | Y            | Y          | Y                     | Y                | Y            | Y               | Y                | Y                | Y              | Y                   | Y                  | Y                | Y          | Y            | Y                      |          |            |             |              |             0 |           0 |               0 |                    0 | mysql_native_password |                       | N                |

| 127.0.0.1 | root | *3ce8dad2446975d8b0c771bd7e48d15b | Y           | Y           | Y           | Y           | Y           | Y         | Y           | Y             | Y            | Y         | Y          | Y               | Y          | Y          | Y            | Y          | Y                     | Y                | Y            | Y               | Y                | Y                | Y              | Y                   | Y                  | Y                | Y          | Y            | Y                      |          |            |             |              |             0 |           0 |               0 |                    0 | mysql_native_password |                       | N                |

| ::1       | root | *3ce8dad2446975d8b0c771bd7e48d15b | Y           | Y           | Y           | Y           | Y           | Y         | Y           | Y             | Y            | Y         | Y          | Y               | Y          | Y          | Y            | Y          | Y                     | Y                | Y            | Y               | Y                | Y                | Y              | Y                   | Y                  | Y                | Y          | Y            | Y                      |          |            |             |              |             0 |           0 |               0 |                    0 | mysql_native_password |                       | N                || tele-1    |      |                                           | N           | N           | N           | N           | N           | N         | N           | N             | N            | N         | N          | N               | N          | N          | N            | N          | N                     | N                | N            | N               | N                | N                | N              | N                   | N                  | N                | N          | N            | N                      |          |            |             |              |             0 |           0 |               0 |                    0 | mysql_native_password | NULL                  | N                |

+-----------+------+-----------------------------------+-------------+-------------+-------------+-------------+-------------+-----------+-------------+---------------+--------------+-----------+------------+-----------------+------------+------------+--------------+------------+-----------------------+------------------+--------------+-----------------+------------------+------------------+----------------+---------------------+--------------------+------------------+------------+--------------+------------------------+----------+------------+-------------+--------------+---------------+-------------+-----------------+----------------------+-----------------------+-----------------------+------------------+

5 rows in set (0.00 sec)mysql>

表中是修改之後的表了,想要遠程訪問,就需要上邊紅色標註的數據了,Host指的是可以訪問此資料庫的ip地址,%代表的是所有的請求都可以連接進來。

大家可以修改一條數據,也可以添加一條數據。但是最好不要修改上邊藍色標註的數據,修改語句就是下邊的格式

mysql> update user set Host = '%' where ???

4.最後推出exit或者\q都是退出mysql命令行的方法

mysql> \q

Bye

安裝Apache

  1.apache安裝方法相對簡單

[root@tele-2 ~]# yum install httpd

2.外網訪問虛擬機中的地址,我們就需要修改一下apache的配置文件/etc/httpd/conf/httpd.conf

找到  #ServerName 改為  ServerName localhost:80

如圖所示:

找到  #Listen  改為  Listen:8080(linux中開放的埠號80XX)

 3.修改完成之後我們需要再次啟動httpd服務,並查看啟動狀態

[root@tele-2 ~]# service httpd startRedirecting to /bin/systemctl start  httpd.service

[root@tele-2 ~]# service httpd statusRedirecting to /bin/systemctl status  httpd.service

● httpd.service - The Apache HTTP Server

   Loaded: loaded (/usr/lib/systemd/system/httpd.service; enabled; vendor preset: disabled)

   Active: active (running) since Mon 2017-06-05 15:57:34 CST; 5s ago

     Docs: man:httpd(8)

           man:apachectl(8)

  Process: 54532 ExecStop=/bin/kill -WINCH ${MAINPID} (code=exited, status=0/SUCCESS)

  Process: 39046 ExecReload=/usr/sbin/httpd $OPTIONS -k graceful (code=exited, status=0/SUCCESS)

 Main PID: 54573 (httpd)

   Status: "Processing requests..."

   Memory: 15.8M

   CGroup: /system.slice/httpd.service

           ├─54573 /usr/sbin/httpd -DFOREGROUND

           ├─54576 /usr/sbin/httpd -DFOREGROUND

           ├─54577 /usr/sbin/httpd -DFOREGROUND

           ├─54578 /usr/sbin/httpd -DFOREGROUND

           ├─54579 /usr/sbin/httpd -DFOREGROUND

           └─54580 /usr/sbin/httpd -DFOREGROUND

 

Jun 05 15:57:34 tele-2 systemd[1]: Starting The Apache HTTP Server...Jun 05 15:57:34 tele-2 systemd[1]: Started The Apache HTTP Server.

4.此時你就可以訪問你的伺服器了,輸入localhost或者ip地址,出現一個Apache test page powered by centos的測試頁面

PHP

  1.php安裝命令

[root@tele-2 ~]# yum install php

2.直接一路安裝,安裝完成之後再次重啟httpd服務

[root@tele-2 ~]# service httpd startRedirecting to /bin/systemctl start  httpd.service

 3.重啟之後我們進行測試PHP相關信息,我們新建一個PHP界面進行測試

在apache預設頁面路徑/var/www/html下新建一個test.php頁面,添加代碼

<?php phpinfo();?>

  4.訪問這個頁面,輸入localhost/test.php,或者

ip:埠號/test.php就可以看見php環境的配置信息了。如圖:

關聯php和mysql

1.搜索模塊

[root@tele-2 ~]# yum search php

2.安裝相關模塊

[root@tele-2 ~]# yum install php-mysql php-gd php-imap php-ldap php-odbc php-pear php-xml  php-xmlrpc

3.安裝完成,重啟mysqld,重啟httpd

重新訪問剛纔的info.php,我們發現已經多了MySQL的相關信息。如右圖:

至此,php在linux中的運行環境就已經成功配置完成了。

  1.mysql yum安裝預設文件夾及相關命令

/var/lib/mysql/

 

:/usr/share/mysql(mysql.server)

 

/usr/bin(mysqladmin mysqldump)

 

my.cnf: /etc/my.cnf

 

:/etc/rc.d/init.d/mysql


:service mysql start
停止命令:service mysql stop
運行狀態:service mysql status

 2.apache

配置文件路徑:/etc/httpd/conf/httpd.conf
service httpd start
service httpd stop
運行狀態:service httpd status

3.php

php預設頁面路徑:/var/www/html

以上就是linux下如何部署php項目

詳細內容請關註我的知乎專欄

以上內容希望幫助到大家,很多PHPer在進階的時候總會遇到一些問題和瓶頸,業務代碼寫多了沒有方向感,不知道該從那裡入手去提升,對此我整理了一些資料,包括但不限於:分散式架構、高可擴展、高性能、高併發、伺服器性能調優、TP6,laravel,YII2,Redis,Swoole、Swoft、Kafka、Mysql優化、shell腳本、Docker、微服務、Nginx等多個知識點高級進階乾貨需要的可以免費分享給大家,需要的可以加入我的官方群點擊此處


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 實現文件分離 1.頭文件中不要使用using namespace,由於c++編譯的特性,由於初學還沒深入瞭解,不做具體編譯的解釋 2.由於沒有了命名空間,所以string定義要寫成std::string 3.main.cpp中引入staff.cpp,staff.cpp中引入staff.h main. ...
  • 對java對象的強制類型轉換稱為造型 從子類到父類的類型轉換可以自動進行; 從父類到子類的類型轉換必須通過造型(強制類型轉換)實現; 無繼承關係的引用類型間的轉換是非法的; ...
  • object類是所有java類的根父類 如果在類的聲明中未使用extends關鍵字指明父類,則預設父類為object類。 object類中的主要方法 public boolean equals(Object obj) 對象比較 public int hashCode() 取得hash碼 public ...
  • HoJe男孩子你要加油阿 準備材料微信支付需要的參數統一下單二維碼回調介面用到的工具類 . 準備材料 首先肯定是要有微信的開發文檔開發文檔地址再然後就是一些必的參數註意:回調地址非同步接收微信支付結果通知的回調地址,通知url必須為外網可訪問的url,不能攜帶參數。 再然後就是微信的SDK . 微信支 ...
  • jdk1.8新特性知識點: Lambda表達式 Stream API 函數式介面 方法引用和構造器調用 介面中的預設方法和靜態方法 新時間日期API default Lambda表達式 Lambda就是把我們之前一些複雜的代碼更簡單化,比如集合內容的判斷比較/排序,我們之前可以進行遍歷判斷取出我們想 ...
  • 使用path或者re_path後,在url中都可以包含參數,而有時候想指定預設的參數,可以通過在urls.py中寫兩個url都指向同一個視圖函數。一個帶參數一個不帶參數。同時,在視同函數的參數中設置預設值。這樣,當匹配到不帶參數的url時,就會使用預設值。實例代碼: urls.py 1 from d ...
  • 從Excel到Python:最常用的36個Pandas函數關於Excel,你一定用的到的36個Python函數 本文涉及pandas最常用的36個函數,通過這些函數介紹如何完成數據生成和導入、數據清洗、預處理,以及最常見的數據分類,數據篩選,分類彙總,透視等最常見的操作。 生成數據表 常見的生成數據 ...
  • 本文主要和大家分享最詳細的linux安裝php過程,然後寫好了nginx的安裝配置,後面就是php的安裝和mysql的安裝,不過時間有限,而且放篇里也太長,所以都是分開來寫,php安裝完畢後就是mysql的配置了。 一:檢查是否安裝了php 1)yum安裝檢查:yum list已安裝| grep p ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...