LAMP=Linux+Apache+Mysql+Php

来源:http://www.cnblogs.com/caicairui/archive/2017/06/16/7025873.html
-Advertisement-
Play Games

一、當前互聯網主流web服務 靜態服務: 1.apache 中小型靜態web服務的主流,web伺服器中的老大哥 2.nginx 大型新型網路靜態web服務主流,web伺服器中的初生牛犢 3.lighttpd 靜態web服務不溫不火,逐漸被淘汰的意味,社區不活躍,效率很高。 動態服務: 1.IIS(I ...


一、當前互聯網主流web服務

靜態服務:

1.apache---中小型靜態web服務的主流,web伺服器中的老大哥

2.nginx---大型新型網路靜態web服務主流,web伺服器中的初生牛犢

3.lighttpd---靜態web服務不溫不火,逐漸被淘汰的意味,社區不活躍,效率很高。

動態服務:

1.IIS(Internet information services)---微軟的web伺服器(aspaspx

2.tomcat---中小企業動態web服務主流,互聯網java容器主流(jspdo

3.resin---大型動態網站web服務主流,互聯網java容器主流(jspdo

4.phpfcgi---大中小網站,php程式的解析容器

  a.配合apachephp不是守護進程,而是mod_php5.so(module)

  b.配合nginxlighttpdphp守護進程模式,FCGI模式。

 

二、apache的安裝

1.首先確定安裝httpd服務(yum install httpd -y

確定:yum install gcc gcc++ zlib zlib-devel -y

2.安裝apache(地址http://apache.fayea.com/httpd/上官網上找)

apache源碼編譯:

./configure --prefix=/application/apache2.2.32 \

--enable-expires \

--enable-headers \

--enable-modules=most \

--enable-so \

--with-mpm=worker \

--enable-deflate \

--enable-rewrite

make &&make install

3.啟動apache服務:

1)查看apache語法是否可行:[root@localhost local]# /application/apache/bin/apachectl -t

2)啟動apache服務:[root@localhost local]# /application/apache/bin/apachectl start

3)查看是否啟動apache服務:lsof -i:80或者ps -ef|grep apache

 

 

it works 表示成功

如果不ok檢查埠,防火牆,selinux,進程

strace追蹤進程的命令

修改編譯內容在/application/apache/htdocs/下 有index.html

 

三、/application/apache目錄結構

 

 

 

 

 

apache優化1.把root@localhost conf]# vi httpd.conf 里的Index前面加-號或者直接刪除

 

 

 

/application/apache/conf/extra 三個重點文件

 

四、虛擬主機

1.虛擬主機:部署多個站點,每個站點希望用不同的功能變數名稱和站點目錄,或者是不同的埠,不同的IP的時候需要虛擬主機。

一句話,一個http服務要配置多個站點,就需要虛擬機。

虛擬機分類:

a.基於功能變數名稱

b.基於埠

c.基於IP

 

2.搭建虛擬機(基於功能變數名稱)

功能變數名稱                   站點目錄

www.etiantian.org        /var/html/www

blog.etiantian.org        /var/html/blog

bbs.etiantian.org         /var/html/bbs

創建主頁文件:

[root@localhost apache]# mkdir /var/html/{www,blog,bbs} -p

[root@localhost apache]# touch /var/html/{www,blog,bbs}/index.html

[root@localhost apache]# for name in www blog bbs;do echo "http://$name.etiantian.org" >/var/html/$name/index.html;done

[root@localhost apache]# for name in www blog bbs;do cat /var/html/$name/index.html;done

 

vim /application/apache/conf/extra/httpd-vhosts.conf

<VirtualHost *:80>

ServerAdmin [email protected]

DocumentRoot "/var/html/www"

ServerName www.etiantian.org

ServerAlias etiantian.org

ErrorLog "logs/www-error_log"

CustomLog "logs/www-access_log" common

</VirtualHost>

 

<VirtualHost *:80>

ServerAdmin [email protected]

DocumentRoot "/var/html/blog"

ServerName blog.etiantian.org

ErrorLog "logs/blog-error_log"

CustomLog "logs/blog-access_log" common

</VirtualHost>

 

<VirtualHost *:80>

ServerAdmin [email protected]

DocumentRoot "/var/html/bbs"

ServerName bbs.etiantian.org

ErrorLog "logs/bbs-error_log"

CustomLog "logs/bbs-access_log" common

</VirtualHost>

 

vim /application/apache/conf/httpd.conf(去點下兩行註釋)

 

 

 

[root@localhost extra]# /application/apache/bin/apachectl -t

Syntax OK

檢查語法

[root@localhost extra]# /application/apache/bin/apachectl graceful 重啟apache

 

vim /application/apache/conf/httpd.conf 在最末行加入下麵的內容:

<Directory "/application/apache2.2.32/htdocs">

Options FollowSymLinks

AllowOverride None

Order allow,deny

Allow from all

</Directory>

以上配置是防止403出錯,之後檢查語法是否錯誤http://blog.csdn.net/u011130583/article/details/42363831(有錯誤查看

 

修改windows本地system32 drives hosts (192.168.76.128 www.etiantian.org blog.etiantian.org bbs.etiantian.org

[root@localhost extra]# grep "^Include" /application/apache/conf/httpd.conf

Include conf/extra/httpd-mpm.conf

Include conf/extra/httpd-vhosts.conf

 

一.mysql

創建mysqluseradd mysql -g mysql -M -s /sbin/nologin

 

mysql的編譯:

./configure --prefix=/application/mysql5.1.72 \

--with-unix-socket-path=/application/mysql5.1.72/tmp/mysql.sock \

--localstatedir=/application/mysql5.1.72/data \

--enable-assembler \

--enable-thread-safe-client \

--with-mysqld-user=mysql \

--with-big-tables \

--without-debug \

--with-pthread \

--enable-assembler \

--with-extra-charsets=complex \

--with-readline \

--with-ssl \

--with-embedded-server \

--enable-local-infile \

--with-plugins=partition,innobase \

--with-mysqld-ldflags=-all-static \

--with-client-ldflags=-all-static

yum -y install ncurses-devel(出錯解決方案)

 

root@localhost application]# cd /home/cai/tools/

[root@localhost tools]# cd mysql-5.1.72/support-files/

[root@localhost support-files]# cp my-small.cnf /etc/my.cnf

cp:是否覆蓋"/etc/my.cnf"? y

[root@localhost support-files]# cd /etc/

[root@localhost etc]# less my.cnf

[root@localhost etc]# mkdir /application/mysql/date -p

[root@localhost etc]# chown -R mysql.mysql /application/mysql

[root@localhost etc]#/application/mysql/bin/mysql_install_db --basedir=/application/mysql --datadir=/application/mysql/data/ --user=mysql

Installing MySQL system tables...

170314 20:15:22 [Warning] '--skip-locking' is deprecated and will be removed in a future release. Please use '--skip-external-locking' instead.

OK

Filling help tables...

170314 20:15:22 [Warning] '--skip-locking' is deprecated and will be removed in a future release. Please use '--skip-external-locking' instead.

OK

 

To start mysqld at boot time you have to copy

support-files/mysql.server to the right place for your system

 

PLEASE REMEMBER TO SET A PASSWORD FOR THE MySQL root USER !

To do so, start the server, then issue the following commands:

 

/application/mysql/bin/mysqladmin -u root password 'new-password'

/application/mysql/bin/mysqladmin -u root -h localhost.localdomain password 'new-password'

 

Alternatively you can run:

/application/mysql/bin/mysql_secure_installation

 

which will also give you the option of removing the test

databases and anonymous user created by default. This is

strongly recommended for production servers.

 

See the manual for more instructions.

 

You can start the MySQL daemon with:

cd /application/mysql ; /application/mysql/bin/mysqld_safe &

 

You can test the MySQL daemon with mysql-test-run.pl

cd /application/mysql/mysql-test ; perl mysql-test-run.pl

 

Please report any problems with the /application/mysql/scripts/mysqlbug script!

 

 

啟動mysql :/application/mysql/bin/mysqld_safe &(啟動服務註意添加到開機自啟動)

[root@localhost support-files]# netstat -lntup|grep mysql (確認是否啟動了該服務)

 

vi /etc/profile在最後添加用戶一行

 

 

 

關閉:

mysqladmin shutdown

 

 

/application/mysql/bin/mysqladmin -u root -h localhost.localdomain password 'new-password' 設置密碼

mysql -uroot -p(設置過密碼後登錄mysql的方法)

 

二、php

LAMP下的php

apache==libphp5.so

nginx php==fcgi php-

 

yum -y install gcc gcc-c++ autoconf libjpeg libjpeg-devel libpng libpng-devel freetype freetype-devel libxml2 libxml2-devel zlib zlib-devel glibc glibc-devel glib2 glib2-devel bzip2 bzip2-devel ncurses ncurses-devel curl curl-devel e2fsprogs e2fsprogs-devel krb5 krb5-devel libidn libidn-devel openssl openssl-devel openldap openldap-devel nss_ldap openldap-clients openldap-servers(需要安裝的各種庫)

 

yum install zlib libxml libjpeg freetype libpng gd curl libiconv zlib-devel libxml2-devel libjpeg-devel freetype-devel libpng-devel gd-devel curl-devel -y(oldboy里的)

libiconv庫需要(編譯安裝)

 

php編譯:

 

./configure \

--prefix=/application/php5.3.27 \

--with-apxs2=/application/apache/bin/apxs \

--with-mysql=/application/mysql \

--with-xmlrpc \

--with-openssl \

--with-zlib \

--with-freetype-dir \

--with-gd \

--with-jpeg-dir \

--with-png-dir \

--with-iconv=/usr/local/libiconv \

--enable-short-tags \

--enable-sockets \

--enable-zend-multibyte \

--enable-soap \

--enable-mbstring \

--enable-static \

--enable-gd-native-ttf \

--with-curl \

--with-xsl \

--enable-ftp \

--with-libxml-dir

 

[root@localhost php]# ll /application/apache/modules/

總用量 23908

-rw-r--r-- 1 root root 9262 4月 15 09:27 httpd.exp

-rwxr-xr-x 1 root root 24465701 4月 15 10:15 libphp5.so

[root@localhost php]# grep libphp5 /application/apache/conf/httpd.conf

LoadModule php5_module modules/libphp5.so

 

配置php文件:

 

 

有兩個,一個是生產環境 一個是開發環境(測試環境)

[root@localhost php-5.3.27]# diff php.ini-development php.ini-production

[root@localhost php-5.3.27]# cp php.ini-production /application/php/lib/php.ini

小結:正式配置文件一般關閉顯示LOG,不輸出LOG

 

配置apache支持php

vim /application/apache/conf/httpd.conf 修改98行 ServerName 192.168.76.128:80

 

 

vim /application/apache/conf/httpd.conf 在311行下添加兩行

AddType application/x-httpd-php .php .phtml

AddType application/x-httpd-php-source .phps

 

 

user daemon 修改為其他的 底下的也該(預設的大家都知道必須修改)

166行 修改為

 

 

[root@localhost conf]# diff httpd.conf httpd.conf.ori

67,68c67,68

< User www

< Group www

---

> User daemon

> Group daemon

168c168

< DirectoryIndex index.php index.html

---

> DirectoryIndex index.html

320,321d319

< AddType application/x-httpd-php .php .phtml

< AddType application/x-httpd-php-source .phps

 

添加www用戶:useradd www -s /sbin/nologin -M

[root@localhost conf]# /application/apache/bin/apachectl graceful 重啟apache服務

 

測試php 在以建的虛擬機中 /var/html/blog vi index.php

 

[root@localhost blog]# cat index.php

<?php

phpinfo();

?>

 

 

出現這個界面表示php+apache成功

 

vi /var/html/blog/index.php

 

<?php

//$link_id=mysql_connect('主機名','用戶','密碼');

$link_id=mysql_connect('localhost','root','oldboy123') or mysql_error();

 

if($link_id){

echo "mysql successful by oldboy !";

}else{

echo mysql_error();

}

?>

 

 

上界面表示mysql成功


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

-Advertisement-
Play Games
更多相關文章
  • myloader恢復主要流程 1、首先由myloader主線程完成建庫建表,依次將備份目錄下建庫和建表文件執行應用到目標資料庫實例中; 2、接著myloader主線程會生成多個工作線程,由這些工作線程將所有database.table.*.sql文件中的記錄導入到對應表中,這個階段是並行的,並行粒度 ...
  • 1 安裝目標與規劃 交易系統1台HP DL580 G9伺服器將安裝Oracle11gR2 。 1.1 安裝介質版本 主機名 his1 IP地址 192.168.40.102 Oracle Grid軟體 Oracle DB軟體版本 Oracle Enterprise11g 補丁集版本 Oracle 1 ...
  • Department表 Employee表 查詢結果: 查詢每個部門的人員名稱 首先創建視圖查詢出各個部門的人員名稱: 然後把查詢結果拼接 ...
  • 一、等待事件的相關知識 1.1 等待事件主要可以分為兩類,即空閑(IDLE)等待事件和非空閑(NON-IDLE)等待事件。1). 空閑等待事件指ORACLE正等待某種工作,在診斷和優化資料庫的時候,不用過多註意這部分事件。2). 非空閑等待事件專門針對ORACLE的活動,指資料庫任務或應用運行過程中 ...
  • zabbix中有自帶對linux伺服器時間進行監控的模板,用的key是system.localtime返回當前的系統時間,而配置tigger報警時是用的fuzzytime(N)方法,該方法是將返回的系統時間與監控伺服器的時間進行對比,如果大於N,則報警。 存在一下3個問題: 1、監控伺服器並不一定是 ...
  • CentOS 7上安裝Jenkins Jenkins 安裝 只安裝不介紹 步驟1:更新CentOS 7 Linux系統管理員的最佳做法之一是使系統保持最新。安裝最新的穩定包,然後重新啟動。 1 2 3 sudo yum install epel-release sudo yum update sud ...
  • Redis 3.2.9 安裝 Redis 3.2.9 編譯安裝 1, 安裝相關軟體包 2, 下載redis源碼包 wget http://source.goyun.org:8000/source/Redis/redis-3.2.9.tar.gz 3, 解壓&&編譯&&安裝 4, 創建相應目錄 5, ...
  • 時間片(timeslice)又稱為“量子(quantum)”或” 處理器片(processor slice)”是分時操作系統分配給每個正在運行的進程微觀上的一段CPU時間(在搶占內核中是:從進程開始運行直到被搶占的時間)。現代操作系統(如:Windows、Linux、Mac OS X等)允許同時運行 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...