日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

LAMP构架概述及相关服务的搭建(附带搭建论坛实验)

發布時間:2024/2/28 编程问答 39 豆豆
生活随笔 收集整理的這篇文章主要介紹了 LAMP构架概述及相关服务的搭建(附带搭建论坛实验) 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

LAMP構架概述及相關服務的搭建

  • 一、LAMP概述
    • 1、相關組件的主要作用:
    • 2、注意事項
  • 二、手工編譯安裝Apache服務
    • 1、關閉防火墻
    • 2、將安裝Apache所需軟件包傳到/opt目錄下
    • 3、安裝環境依賴包
    • 4、解壓三個壓縮包
    • 5、配置軟件模塊
    • 6、編譯及安裝
    • 7、優化配置文件路徑,并把httpd服務的可執行程序文件放入路徑環境變量的目錄中便于系統識別
    • 8、添加httpd系統服務
      • ①、方法一:
      • ②、方法二:
    • 9、修改 /etc/httpd.conf 服務配置文件
    • 10、瀏覽器訪問驗證
    • 11、使用域名訪問
  • 三、手工編譯mysql數據庫
    • 1、將安裝mysql 所需軟件包傳到/opt目錄下
    • 2、安裝環境依賴包
    • 3、配置軟件模塊
    • 4、編譯及安裝
    • 5、創建mysql用戶
    • 6、修改mysql 配置文件
    • 7、更改mysql安裝目錄和配置文件的屬主屬組
    • 8、設置路徑環境變量
    • 9、初始化數據庫
    • 10、添加mysqld系統服務
    • 11、修改mysql 的登錄密碼,并授權遠程登錄
  • 四、手工編譯安裝PHP
    • 1、將安裝PHP 所需軟件包傳到/opt目錄下
    • 2、安裝GD庫和GD庫關聯程序,用來處理和生成圖片
    • 3、配置軟件模塊
    • 4、編譯及安裝
    • 5、復制模版文件作為PHP 的主配置文件,并進行修改
    • 6、優化把PHP 的可執行程序文件放入路徑環境變量的目錄中便于系統識別
    • 7、修改httpd 服務的配置文件,讓apache支持PHP```
    • 8、驗證PHP 測試頁
  • 五、使用LAMP搭建論壇
    • 1、完成LAMP的搭建
    • 2、創建數據庫,并進行授權
    • 3、上傳并解壓論壇壓縮包
    • 4、更改論壇目錄的屬主
    • 5、瀏覽器訪問驗證
    • 6、論壇后臺管理員頁面

一、LAMP概述

  • LAMP架構是目前成熟的企業網站應用模式之一,指的是協同工作的一整套系統和相關軟件,能夠提供靜態和動態Web站點服務以及其應用開發環境。
  • LAMP是一個縮寫詞,具體包括Linux操作系統、Apache網站服務器、MySQL數據庫服務器、PHP(或Perl、Python)網頁編程語言。

1、相關組件的主要作用:

  • (平臺)Linux:作為LAMP架構的基礎,提供用于支撐Web站點的操作系統,能夠與其他三個組件提供更好的穩定性,兼容性(AMP組件也支持Windows、UNIX等平臺) 。
  • (前臺)Apache:作為LAMP架構的前端,是一款功能強大,穩定性好的Web服務器程序,該服務器直接面向用戶提供網站訪問,發送網頁,圖片等文件內容。
  • (后臺)MySQL:作為LAMP架構的后端,是一款流行的開源關系數據庫系統。在企業網站、業務系統等應用中,各種賬戶信息、產品信息,客戶資料、業務數據等都可以存儲到MySQL數據庫,其他程序可以通過SQL語句來查詢,更改這些信息。
  • (中間連接)PHP/Perl/Python:作為三種開發動態網頁的編程語言,負責解釋動態網頁文件,負責溝通Web服務器和數據庫系統以協同工作,并提供Web應用程序的開發和運行環境。其中PHP是一種被廣泛應用的開放源代碼的多用途腳本語言,它可以嵌入到HTML中,尤其適合于Web應用開發。

2、注意事項

  • 在構建LAMP平臺時,各組件的安裝順序依次為Linux、Apache、MySQL、PHP。
  • 其中Apache和MySQL的安裝并沒有嚴格的順序,PHP環境的安裝一般放到最后安裝,負責溝通 Web 服務器和數據庫系統以協同工作。

二、手工編譯安裝Apache服務

1、關閉防火墻

2、將安裝Apache所需軟件包傳到/opt目錄下

3、安裝環境依賴包

gcc #C語言的編譯器 gcc-c++ #C++的編譯器 make #源代碼編譯器(源代碼轉換成二進制文件) pcre #pcre是一個Perl函數庫,包括perl 兼容的正則表達式庫 pcre-devel #perl的接口開發包 expat-devel #用于支持網站解析HTML、XML文件 perl #perl語言編譯器

4、解壓三個壓縮包

5、配置軟件模塊

mv apr-1.6.2 /opt/httpd-2.4.29/srclib/apr mv apr-util-1.6.0 /opt/httpd-2.4.29/srclib/apr-utilcd /opt/httpd-2.4.29/ ./configure \ --prefix=/usr/local/httpd \ #指定將 httpd 服務程序的安裝路徑 --enable-so \ #啟用動態加載模塊支持,使 httpd 具備進一步擴展功能的能力 --enable-rewrite \ #啟用網頁地址重寫功能,用于網站優化、防盜鏈及目錄遷移維護 --enable-charset-lite \ #啟動字符集支持,以便支持使用各種字符集編碼的頁面 --enable-cgi #啟用CGI(通用網關接口)腳本程序支持,便于網站的外部擴展應用訪問能力

6、編譯及安裝

make #make -j 2 表示開2核同時進行編譯 make install

7、優化配置文件路徑,并把httpd服務的可執行程序文件放入路徑環境變量的目錄中便于系統識別

ln -s /usr/local/httpd/conf/httpd.conf /etc/ ln -s /usr/local/httpd/bin/* /usr/local/bin/

8、添加httpd系統服務

①、方法一:

cp /usr/local/httpd/bin/apachectl /etc/init.d/httpd #用于service服務管理 chmod +x /etc/init.d/httpd vi /etc/init.d/httpd #!/bin/bash #在第一行前插入新行,添加此三行內容 # chkconfig: 35 85 21 #35級別自動運行 第85個啟動 第21個關閉 # description: Apache is a World Wide Web serverchkconfig --add httpd #將httpd服務加入到service管理器systemctl start httpd.service 或 service httpd start

②、方法二:

vim /lib/systemd/system/httpd.service [Unit] Description=The Apache HTTP Server #描述 After=network.target #描述服務類別 [Service] Type=forking #后臺運行方式 PIDFile=/usr/local/httpd/logs/httpd.pid #PID文件位置 ExecStart=/usr/local/bin/apachectl $OPTIONS #啟動服務 ExecReload=/bin/kill -HUP $MAINPID #根據PID重載配置 [Install] WantedBy=multi-user.targetsystemctl start httpd.service systemctl enable httpd.service

9、修改 /etc/httpd.conf 服務配置文件


10、瀏覽器訪問驗證

11、使用域名訪問

三、手工編譯mysql數據庫

1、將安裝mysql 所需軟件包傳到/opt目錄下

2、安裝環境依賴包

yum -y install \ gcc \ gcc-c++ \ ncurses \ #字符終端下圖形互動功能的動態庫 ncurses-devel \ #ncurses開發包 bison \ #語法分析器 cmake #mysql需要用cmake編譯安裝

3、配置軟件模塊

tar zxvf mysql-5.7.17.tar.gz tar zxvf boost_1_59_0.tar.gzcd /opt mv boost_1_59_0 /usr/local/boost #重命名cd /opt/mysql-5.7.17/ cmake \ -DCMAKE_INSTALL_PREFIX=/usr/local/mysql \ -DMYSQL_UNIX_ADDR=/usr/local/mysql/mysql.sock \ -DSYSCONFDIR=/etc \ -DSYSTEMD_PID_DIR=/usr/local/mysql \ -DDEFAULT_CHARSET=utf8 \ -DDEFAULT_COLLATION=utf8_general_ci \ -DWITH_EXTRA_CHARSETS=all \ -DWITH_INNOBASE_STORAGE_ENGINE=1 \ -DWITH_ARCHIVE_STORAGE_ENGINE=1 \ -DWITH_BLACKHOLE_STORAGE_ENGINE=1 \ -DWITH_PERFSCHEMA_STORAGE_ENGINE=1 \ -DMYSQL_DATADIR=/usr/local/mysql/data \ -DWITH_BOOST=/usr/local/boost \ -DWITH_SYSTEMD=1

  • 存儲引擎選項:
    • MYISAM,MERGE,MEMORY,和CSV引擎是默認編譯到服務器中,并不需要明確地安裝。
    • 靜態編譯一個存儲引擎到服務器,使用-DWITH_engine_STORAGE_ENGINE= 1
    • 可用的存儲引擎值有:ARCHIVE, BLACKHOLE, EXAMPLE, FEDERATED, INNOBASE (InnoDB), PARTITION (partitioning support), 和PERFSCHEMA (Performance Schema)
  • 注意:
    • 如果在CMAKE的過程中有報錯,當報錯解決后,需要把源碼目錄中的CMakeCache.txt文件刪除,然后再重新CMAKE,否則錯誤依舊

4、編譯及安裝

make && make install

5、創建mysql用戶

useradd -M -s /sbin/nologin mysql

6、修改mysql 配置文件

vim /etc/my.cnf #刪除原配置項,再重新添加下面內容 [client] #客戶端設置 port = 3306 socket = /usr/local/mysql/mysql.sock [mysql] #服務端設置 port = 3306 socket = /usr/local/mysql/mysql.sock auto-rehash #開啟自動補全功能[mysqld] #服務全局設置 user = mysql #設置管理用戶 basedir=/usr/local/mysql #指定數據庫的安裝目錄 datadir=/usr/local/mysql/data #指定數據庫文件的存儲路徑 port = 3306 #指定端口 character-set-server=utf8 #設置服務器字符集編碼格式為utf8 pid-file = /usr/local/mysql/mysqld.pid #指定pid 進程文件路徑 socket=/usr/local/mysql/mysql.sock #指定數據庫連接文件 bind-address = 0.0.0.0 #設置監聽地址,0.0.0.0代表允許所有,如允許多個IP需空格隔開 skip-name-resolve #禁用DNS解析 max_connections=2048 #設置mysql的最大連接數 default-storage-engine=INNODB #指定默認存儲引擎 max_allowed_packet=16M #設置數據庫接收的數據包大小的最大值 server-id = 1 #指定服務ID號sql_mode=NO_ENGINE_SUBSTITUTION,STRICT_TRANS_TABLES,NO_AUTO_CREATE_USER,NO_AUTO_VALUE_ON_ZERO,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,PIPES_AS_CONCAT,ANSI_QUOTES

  • sql_mode常用值如下:
    • NO_ENGINE_SUBSTITUTION
      如果需要的存儲引擎被禁用或未編譯,那么拋出錯誤。不設置此值時,用默認的存儲引擎替代,并拋出一個異常

    • STRICT_TRANS_TABLES
      在該模式下,如果一個值不能插入到一個事務表中,則中斷當前的操作,對非事務表不做限制

    • NO_AUTO_CREATE_USER
      禁止GRANT創建密碼為空的用戶

    • NO_AUTO_VALUE_ON_ZERO
      mysql中的自增長列可以從0開始。默認情況下自增長列是從1開始的,如果你插入值為0的數據會報錯

    • NO_ZERO_IN_DATE
      不允許日期和月份為零

    • NO_ZERO_DATE
      mysql數據庫不允許插入零日期,插入零日期會拋出錯誤而不是警告

    • ERROR_FOR_DIVISION_BY_ZERO
      在INSERT或UPDATE過程中,如果數據被零除,則產生錯誤而非警告。默認情況下數據被零除時MySQL返回NULL

    • PIPES_AS_CONCAT
      將"||"視為字符串的連接操作符而非或運算符,這和Oracle數據庫是一樣的,也和字符串的拼接函數Concat相類似

    • ANSI_QUOTES
      啟用ANSI_QUOTES后,不能用雙引號來引用字符串,因為它被解釋為識別符

7、更改mysql安裝目錄和配置文件的屬主屬組

chown -R mysql:mysql /usr/local/mysql/ chown mysql:mysql /etc/my.cnf

8、設置路徑環境變量

echo 'export PATH=/usr/local/mysql/bin:/usr/local/mysql/lib:$PATH' >> /etc/profile source /etc/profile

9、初始化數據庫

cd /usr/local/mysql/bin/ ./mysqld \ --initialize-insecure \ #生成初始化密碼為空 --user=mysql \ #指定管理用戶 --basedir=/usr/local/mysql \ #指定數據庫的安裝目錄 --datadir=/usr/local/mysql/data #指定數據庫文件的存儲路徑

10、添加mysqld系統服務

cp /usr/local/mysql/usr/lib/systemd/system/mysqld.service /usr/lib/systemd/system/ #用于systemctl服務管理 systemctl daemon-reload #刷新識別 systemctl start mysqld.service #開啟服務 systemctl enable mysqld #開機自啟動 netstat -anpt | grep 3306 #查看端口

11、修改mysql 的登錄密碼,并授權遠程登錄

mysqladmin -u root -p password "abc123" #給root賬號設置密碼為abc123,提示輸入的是原始密碼(為空)mysql -u root -p grant all privileges on *.* to 'root'@'%' identified by 'abc123'; #授予root用戶可以在所有終端遠程登錄,使用的密碼是abc123,并對所有數據庫和所有表有操作權限show databases; #查看當前已有的數據庫

四、手工編譯安裝PHP

1、將安裝PHP 所需軟件包傳到/opt目錄下

2、安裝GD庫和GD庫關聯程序,用來處理和生成圖片


3、配置軟件模塊

tar jxvf php-7.1.10.tar.bz2 cd /opt/php-7.1.10/./configure \ --prefix=/usr/local/php7 \ #指定將 PHP 程序的安裝路徑 --with-apxs2=/usr/local/httpd/bin/apxs \ #指定Apache httpd服務提供的apxs 模塊支持程序的文件位置 --with-mysql-sock=/usr/local/mysql/mysql.sock \ #指定mysql 數據庫連接文件的存儲路徑 --with-config-file-path=/usr/local/php7 #設置 PHP 的配置文件 php.ini 將要存放的位置 --with-mysqli \ #添加 MySQL 擴展支持 #mysqli擴展技術不僅可以調用MySQL的存儲過程、處理MySQL事務,而且還可以使訪問數據庫工作變得更加穩定 --with-zlib \ #支持zlib功能,提供數據壓縮 --with-curl \ #開啟curl擴展功能,實現HTTP的Get下載和Post請求的方法 --with-gd \ #激活gd 庫的支持 --with-jpeg-dir \ #激活jpeg 的支持 --with-png-dir \ #激活png 的支持 --with-freetype-dir \ --with-openssl \ --enable-mbstring \ #啟用多字節字符串功能,以便支持中文等代碼 --enable-xml \ #開啟擴展性標記語言模塊 --enable-session \ #會話 --enable-ftp \ #文本傳輸協議 --enable-pdo \ #函數庫 --enable-tokenizer \ #令牌解釋器 --enable-zip #ZIP壓縮格式

4、編譯及安裝

make && make install

5、復制模版文件作為PHP 的主配置文件,并進行修改

cp /opt/php-7.1.10/php.ini-development /usr/local/php7/php.ini #在測試環境時使用php.ini-development文件,而在生產環境時使用php.ini-production文件 vim /usr/local/php7/php.ini --1170--修改 mysqli.default_socket = /usr/local/mysql/mysql.sock --939--取消注釋,修改 date.timezone = Asia/Shanghai

6、優化把PHP 的可執行程序文件放入路徑環境變量的目錄中便于系統識別

7、修改httpd 服務的配置文件,讓apache支持PHP```

vim /etc/httpd.conf --393--插入以下內容 AddType application/x-httpd-php .php AddType application/x-httpd-php-source .phps --255--修改首頁文件名設置 DirectoryIndex index.html index.php---檢查支持php7的模塊是否存在------ LoadModule php7_module modules/libphp7.so

8、驗證PHP 測試頁

rm -rf /usr/local/httpd/htdocs/index.html #刪除默認靜態首頁文件 vim /usr/local/httpd/htdocs/index.php #編寫動態首頁文件 <?php phpinfo(); ?>systemctl restart httpd.service #重啟服務瀏覽器訪問 http://192.168.184.80

五、使用LAMP搭建論壇

1、完成LAMP的搭建

2、創建數據庫,并進行授權

3、上傳并解壓論壇壓縮包


4、更改論壇目錄的屬主

ps aux #查看發現論壇進程的用戶名是daemon cd /usr/local/httpd/htdocs/bbs chown -R daemon ./config chown -R daemon ./data chown -R daemon ./uc_client chown -R daemon ./uc_server/data


5、瀏覽器訪問驗證

6、論壇后臺管理員頁面

總結

以上是生活随笔為你收集整理的LAMP构架概述及相关服务的搭建(附带搭建论坛实验)的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。