第一章 LNMP組合工作流程
在LNMP組合工作時,首先是用戶通過瀏覽器輸入域名請求Nginx Web服務,如果請求時靜態資源,則由Nginx解析返回給用戶;如果是動態請求(.php結尾),那麼Nginx就會把它通過Fast CGI接口發送給PHP引擎服務(FastCGI進程php-fpm)進行解析,如果這個動態請求要讀取數據庫數據,那麼PHP就會繼續向後請求MYSQL數據庫,一度去需要的數據,並最終通過Nginx服務把獲取的數據返回給用戶,這就是LNMP環境的基本請求順序流程。
第二章 MySQL數據庫優勢和特點
- 性能卓越、服務穩定,很少出現異常宕機。
- 開放源代碼且無版權制約,自主性強,使用成本低。
- 歷史悠久,社區及用戶非常活躍,遇到問題,可以很快獲取到幫助。
- 軟件體積小,安裝使用簡單,並且易於維護,安全及維護成本低。
- 支持多種操作系統,提供多種API接口,支持多種開發語言,特別是對流行的PHP語言無縫支持。
第三章 MYSQL安裝方式
序號 | MySQL安裝方式 | 特點說明 |
---|---|---|
1 | yum/rpm包安裝 | 特點是簡單、速度快、但是沒法定製安裝,入門新手常用這種方式 |
2 | 二進制安裝 | 解壓軟件,簡單配置後就可以使用,不用安裝,速度較快,專業DBA喜歡這種方式 |
3 | 源碼編譯安裝 | 特點是可以定製安裝,但是安裝時間長,例如:字符集安裝路徑,等 |
4 | 源碼軟件結合yum/rpm安裝 | 把源碼軟件製作成符合要求的rpm,放到yum倉庫裏,然後通過yum來安裝,結合了1和3有點,即安裝快捷,可任意制定參數,但是安裝着也許要更深能力 |
第四章 MYSQL安裝步驟
1. 安裝包放入指定路徑
cd /home/oldboy/tools/
wget http://ftp.iij.ad.jp/pub/db/mysql/Downloads/MySQL-5.6/mysql-5.6.34-linux-glibc2.5-x86_64.tar.gz
2. 解壓安裝包
[root@web02 ~]$ cd /home/oldboy/tools/
[root@web02 tools]$ ll
total 307688
-rw-r--r-- 1 root root 314149697 May 22 08:38 mysql-5.6.34-linux-glibc2.5-x86_64.tar.gz
drwxr-xr-x 9 1001 1001 4096 May 18 10:36 nginx-1.10.2
-rw-r--r-- 1 root root 910812 Oct 18 2016 nginx-1.10.2.tar.gz
[root@web02 tools]$ tar xf mysql-5.6.34-linux-glibc2.5-x86_64.tar.gz
3. 創建服務用戶
[root@web02 tools]$ useradd -s /sbin/nologin -M mysql
[root@web02 tools]$ id mysql
uid=502(mysql) gid=502(mysql) groups=502(mysql)
4. 查看目錄大小
[root@web02 tools]$ du -sh mysql-5.6.34-linux-glibc2.5-x86_64
1.1G mysql-5.6.34-linux-glibc2.5-x86_64
5. 移動到程序安裝目錄(規範)
[root@web02 tools]$ mv mysql-5.6.34-linux-glibc2.5-x86_64 /application/mysql-s.6.34
[root@web02 tools]$ ll /application/mysql-s.6.34/
total 68
6. 創建軟鏈接
[root@web02 tools]$ ln -s /application/mysql-s.6.34/ /application/mysql
[root@web02 tools]$ ll /application/mysql
lrwxrwxrwx 1 root root 26 May 22 10:01 /application/mysql -> /application/mysql-s.6.34/
7. 初始化數據庫服務
[root@web02 tools]$ /application/mysql/scripts/mysql_install_db --basedir=/application/mysql --datadir=/application/mysql/data --user=mysql
8. 複製MySQL啓動程序到init.d
[root@web02 tools]$ cp /application/mysql/support-files/mysql.server /etc/init.d/mysqld
[root@web02 tools]$ ll /etc/init.d/mysqld
-rwxr-xr-x 1 root root 10875 May 22 10:12 /etc/init.d/mysqld
[root@web02 tools]$ chmod +x /etc/init.d/mysqld
9. 更改默認目錄
sed -i 's#/usr/local/mysql#/application/mysql#g' /application/mysql/bin/mysqld_safe /etc/init.d/mysqld
10. MYSQL默認配置文件
ll /application/mysql/support-files/my-default.cnf
[root@web02 tools]$ cp /application/mysql/support-files/my-default.cnf /etc/my.cnf
11. 啓動MySQL服務
[root@web02 ~]$ /etc/init.d/mysqld start
Starting MySQL.. SUCCESS!
#[root@web02 ~]$ /application/mysql/bin/mysql -uroot
12. 設置命令變量
echo 'export PATH=/application/mysql/bin:$PATH' >>/etc/profile
source /etc/profile
which mysql
13. 登錄密碼方式
[root@web02 ~]$ mysqladmin -u root password 'oldboy123'
[root@web02 ~]$ mysql -u root -p
[root@web02 ~]$ mysql -uroot -p123456
第五章 PHP安裝
1. 安裝軟件包(依賴包)
cd /server/files
yum install zlib-devel libxml2-devel libjpeg-devel libjpeg-turbo-devel libiconv-devel freetype-devel libpng-devel gd-devel libcurl-devel libxslt-devel libxslt-devel -y
2. libiconv軟件安裝
wget http://ftp.gnu.org/pub/gnu/libiconv/libiconv-1.14.tar.gz
tar zxf libiconv-1.14.tar.gz
cd libiconv-1.14
./configure --prefix=/usr/local/libiconv
make && make install
yum -y install libmcrypt-devel mhash mcrypt
rpm -qa libmcrypt-devel mhash mcrypt
3. php編譯安裝
wget -O /etc/yum.repos.d/epel.repo http://mirrors.aliyun.com/repo/epel-6.repo #注意這裏是6的源,如果是7的請更換
wget http://tw1.php.net/distributions/php-5.5.32.tar.gz
tar xf php-5.5.32.tar.gz
cd php-5.5.32
./configure --prefix=/application/php-5.5.32 \
--with-mysql=mysqlnd \
--with-pdo-mysql=mysqlnd \
--with-iconv-dir=/usr/local/libiconv \
--with-freetype-dir \
--with-jpeg-dir \
--with-png-dir \
--with-zlib \
--with-libxml-dir=/usr \
--enable-xml \
--disable-rpath \
--enable-bcmath \
--enable-shmop \
--enable-sysvsem \
--enable-inline-optimization \
--with-curl \
--enable-mbregex \
--enable-fpm \
--enable-mbstring \
--with-mcrypt \
--with-gd \
--enable-gd-native-ttf \
--with-openssl \
--with-mhash \
--enable-pcntl \
--enable-sockets \
--with-xmlrpc \
--enable-soap \
--enable-short-tags \
--enable-static \
--with-xsl \
--with-fpm-user=www \
--with-fpm-group=www \
--enable-ftp \
--enable-opcache=no
##防錯
ln -s /application/mysql/lib/libmysqlclient.so.18 /usr/lib64/
touch ext/phar/phar.phar
make && make install
echo $?
5. 創建軟鏈接複製配置文件
[root@web02 php-5.5.32]$ ln -s /application/php-5.5.32/ /application/php
[root@web02 php-5.5.32]$ ll /application/php
lrwxrwxrwx 1 root root 24 May 22 11:35 /application/php -> /application/php-5.5.32/
cd /home/oldboy/tools/php-5.5.32
[root@web02 php-5.5.32]$ cp php.ini-production /application/php/lib/php.ini
cd /application/php/etc/
cp php-fpm.conf.default php-fpm.conf
6. 啓動
[root@web02 etc]$ /application/php/sbin/php-fpm
[root@web02 etc]$ ps -ef |egrep php-fpm.conf
tcp LISTEN 0 16384 127.0.0.1:9000
第六章 FastCGI網關接口
CGI的全稱爲“通用網關接口 (common Gateway interface)”,爲HTTP服務器與其他機器上的程序服務通信交流的一種工具,CGI程序必須運行在網絡服務器上。
傳統CGI接口方式的主要缺點是性能較差,因爲每次HTTP服務器遇到動態程序時都需要重新啓動解析器來執行解析,之後結構纔會被返回給HTTP服務器。這在處理高併發訪問時幾乎是不可用的,因此就誕生了FastCGI。;另外,傳統的CGI接口安全性也很差,故而現在已經很少被使用了。
第七章 建立Nginx和php連接
[root@web02 conf]$ pwd
/application/nginx/conf
[root@web02 conf]$ cat extra/blog.conf
server {
listen 80;
server_name blog.etiantian.org;
# 靜態請求處理的location
location / {
root html/blog;
index index.html index.htm;
}
# 動態請求處理的location
location ~* .*\.(php|php5)?$ {
root html/blog;
fastcgi_pass 127.0.0.1:9000;
fastcgi_index index.php;
include fastcgi.conf;
}
}
[root@web02 conf]$ /application/nginx/sbin/nginx -t
[root@web02 conf]$ /application/nginx/sbin/nginx -s reload
echo '<?php phpinfo(); ?>' >/application/nginx/html/blog/test_info.php
[root@web02 blog]# curl -I blog.etiantian.org
HTTP/1.1 200 OK
Server: nginx/1.10.2
Date: Mon, 22 May 2017 04:10:19 GMT
Content-Type: text/html
Content-Length: 14
Last-Modified: Fri, 19 May 2017 01:53:30 GMT
Connection: keep-alive
ETag: "591e501a-e"
Accept-Ranges: bytes
[root@web02 blog]# curl -I http://blog.etiantian.org/test_info.php
HTTP/1.1 200 OK
Server: nginx/1.10.2
Date: Mon, 22 May 2017 04:10:36 GMT
Content-Type: text/html
Connection: keep-alive
X-Powered-By: PHP/5.5.32
第八章 建立MySQL和php連接
[root@web02 conf]$ mysql -uroot -poldboy123
mysql> create database wordpress; ##mysql> drop database wordpress;
mysql> show databases;
mysql> grant all on wordpress.* to 'wordpress'@'localhost' identified by 'oldboy123';
mysql> flush privileges;
mysql> select user,host from mysql.user;
mysql> show databases;
+--------------------+
| Database |
+--------------------+
| information_schema |
| test |
| wordpress |
+--------------------+
3 rows in set (0.00 sec)
mysql> select user();
+---------------------+
| user() |
+---------------------+
| wordpress@localhost |
+---------------------+
1 row in set (0.00 sec)
[root@web02 conf]$ ll /application/mysql/data/
total 110620
-rw-rw---- 1 mysql mysql 56 May 22 10:33 auto.cnf
-rw-rw---- 1 mysql mysql 12582912 May 22 10:33 ibdata1
-rw-rw---- 1 mysql mysql 50331648 May 22 10:33 ib_logfile0
-rw-rw---- 1 mysql mysql 50331648 May 22 10:10 ib_logfile1
drwx------ 2 mysql mysql 4096 May 22 10:10 mysql
drwx------ 2 mysql mysql 4096 May 22 10:28 performance_schema
drwxr-xr-x 2 mysql mysql 4096 May 22 09:56 test
-rw-r----- 1 mysql root 2261 May 22 10:33 web02.err
-rw-rw---- 1 mysql mysql 5 May 22 10:33 web02.pid
drwx------ 2 mysql mysql 4096 May 22 12:16 wordpress
[root@web02 blog]# pwd
pplication/nginx/html/blog
[root@web02 blog]# vim test_mysql.php
<?php
//$link_id=mysql_connect('主機名','用戶','密碼');
//mysql -u用戶 -p密碼 -h 主機
$link_id=mysql_connect('localhost','wordpress','oldboy123') or mysql_error();
if($link_id){
echo "mysql successful by oldboy !\n";
}else{
echo mysql_error();
}
?>
[root@web02 conf]$ vim /application/nginx/conf/nginx.conf
worker_processes 1;
events {
worker_connections 1024;
}
http {
include mime.types;
default_type application/octet-stream;
sendfile on;
keepalive_timeout 66;
# include extra/www.conf;
# include extra/bbs.conf;
include extra/blog.conf;
第九章 站點數據轉移
1. 啓動MySQL服務推送備份文件至MySQL服務器/tmp目錄
[root@web02 ~]# /etc/init.d/mysqld start
[root@web02 ~]# ps -ef |egrep mysql
[root@web02 ~]# mysqldump -uroot -poldboy123 --all-databases >/tmp/mysqlbak.sql
[root@web02 ~]# scp -rp /tmp/mysqlbak.sql 172.16.1.51:/tmp
2. 備份文件導入MySQL
[root@mysql_51 tools]# mysql -uroot -poldboy123 </tmp/mysqlbak.sql
[root@mysql_51 tools]# mysql -uroot -poldboy123
[root@mysql_51 tools]# mysql -uroot -poldboy123
mysql> show databases;
mysql> select user,host from mysql.user;
mysql> grant all on wordpress.* to 'wordpress'@'172.16.1.0/255.255.255.0' identified by 'oldboy123';
mysql> select user,host from mysql.user;
[root@mysql_51 tools]# mysql -uwordpress -poldboy123 -h 172.16.1.51
[root@web02 blog]# pwd
/application/nginx/html/blog
[root@web02 blog]# vim wp-config.php
/** MySQL主機 */
define('DB_HOST', '172.16.1.51');