目錄:
1)LNMP簡介
2)安裝nginx1.4
3)安裝php7.2
4)安裝mariadb10.2
5)總結(jié)
一启摄、LNMP簡介
L:linux洁闰,是目前最流行的免費操作系統(tǒng)蝶糯,版本有很多琉雳,rehat,debian割笙,ubuntu沦偎,centos等等,我用的是centos7.5咳蔚。
N:nginx,是一個高性能的HTTP和反向代理服務(wù)器搔驼,也是一個IMAP/POP3/SMTP代理服務(wù)器谈火。nginx市場份額越來越大,這里也可以選擇Apache舌涨,老大哥糯耍,寶刀未老。
M:Mysql是一個小型關(guān)系型數(shù)據(jù)庫管理系統(tǒng)囊嘉,我覺得已經(jīng)不小了温技,對于絕大多數(shù)的情況,夠用了扭粱,這里我用的mariadb10.2舵鳞,mariadb和mysql都是出自同個作者,這里不講它們的故事琢蛤。
P:世界上最好的編程語言蜓堕,一種在服務(wù)器端執(zhí)行的嵌入HTML文檔的腳本語言。
linux+nginx+mysql/mariadb+php,這四個開源項目組在一起博其,成為一個免費套才、高效、擴展性強的網(wǎng)站服務(wù)系統(tǒng)慕淡,這是一個網(wǎng)站服務(wù)器架構(gòu)背伴,學(xué)會它就能打通任督二脈,無忌峰髓,跟著為師走傻寂。
二、安裝nginx
- 防火墻設(shè)置儿普,允許http,https通信崎逃。
firewall-cmd --zone=public --add-service=http --permanent //允許http通信
firewall-cmd --zone=public --add-service=https --permanent //允許https通信
firewall-cmd --zone-public --add-port=80/tcp --permanent 打開80端口
firewall-cmd --zone-public --add-port=443/tcp --permanent 打開443端口
firewall-cmd --zone-public --add-port=8080/tcp --permanent 打開8080端口
firewall-cmd --reload //重新加載配置
- 下載基本的庫文件
yum install pcre pcre-devel
yum install zlib zlib-devel
yum install openssl openssl-devel
- 配置nginx官方源,下載和安裝
rpm -Uvh http://nginx.org/packages/centos/7/noarch/RPMS/nginx-release-centos-7-0.el7.ngx.noarch.rpm
//安裝nginx
yum install nginx
- 了解基本配置文件
主配置文件:/etc/nginx/nginx.conf
默認(rèn)配置文件:/etc/nginx/conf.d/default.conf
我們編輯一下default.conf這個文件眉孩。
注意个绍,這里server_name 我寫的是我這臺電腦的局域網(wǎng)地址及訪問端口勒葱,你可以設(shè)置其它或者默認(rèn)不變
- 局域網(wǎng)訪問測試一下
systemctl start nginx
到這里nginx安裝使用成功,如果你這里無法訪問巴柿,絕大多數(shù)情況下是SELINUX和防火墻的問題凛虽。注意,如果你是云服務(wù)器的話是需要在服務(wù)商后臺那里添加安全組策略的广恢。
三凯旋、安裝php7.2
- 配置php7.2yum源
rpm -Uvh https://dl.fedoraproject.org/pub/epel/epel-release-latest-7.noarch.rpm
rpm -Uvh https://mirror.webtatic.com/yum/el7/webtatic-release.rpm
- 安裝php7.2及一些擴展工具
yum install php72w php72w-cli php72w-common php72w-devel php72w-embedded php72w-fpm php72w-gd php72w-mbstring php72w-mysqlnd php72w-opcache php72w-pdo php72w-xml
- 啟動php-fpm
systemctl start php-fpm //啟動
systemctl enable php-fpm //設(shè)置開機啟動
注意,nginx是通過php-fpm處理php文件的钉迷。
- 讓nginx支持php
vim /etc/nginx/conf.d/default.conf
location ~ \.php$ {
root /usr/share/nginx/html;
fastcgi_pass 127.0.0.1:9000;
fastcgi_index index.php;
fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
include fastcgi_params;
}
systemctl restart nginx //重啟服務(wù)
- 運行一個php文件
vim /usr/share/nginx/html/index.php //編輯文件
代碼如下:
<?php
phpinfo();
?>
保存至非,在瀏覽器訪問試一下。
四糠聪、安裝數(shù)據(jù)庫mariadb10.2
- 卸載系統(tǒng)自帶的數(shù)據(jù)庫
首先荒椭,centos7.5里面自帶的mariadb5.5版本的,所以第一步舰蟆,我先卸載掉很老老老老老老的版本趣惠。
rpm -qa|grep mariadb
yum remove mariadb-*文件
它會刪除一些依賴文件,不用擔(dān)心身害。
- 配置mariadb10.2yum源
vim /etc/yum.repos.d/MariaDB.repo
# MariaDB 10.2 CentOS repository list - created 2019-01-08 08:30 UTC
# http://downloads.mariadb.org/mariadb/repositories/
[mariadb]
name = MariaDB
baseurl = http://yum.mariadb.org/10.2/centos7-amd64
gpgkey=https://yum.mariadb.org/RPM-GPG-KEY-MariaDB
gpgcheck=1
以上配置的源是mariadb官方源味悄,下載速度,一個星期的時間是完全可以下載下來的塌鸯。
如果你想一根煙的時間就能完成下載侍瑟,替換為國內(nèi)源:
[mariadb]
name = MariaDB
baseurl = https://mirrors.ustc.edu.cn/mariadb/yum/10.2/centos7-amd64
gpgkey=https://mirrors.ustc.edu.cn/mariadb/yum/RPM-GPG-KEY-MariaDB
gpgcheck=1
保存退出。
yum clean&&yum update //更新一下yum源
yum install MariaDB-client MariaDB-server //安裝
systemctl start mariadb
systemctl enable mariadb //設(shè)置開機啟動
OK界赔,mariadb安裝完成丢习。
- 初始化mariadb
首先使用mysql_secure_installation命令進(jìn)行配置。
根據(jù)自己的要求配置淮悼,可以按照我的圖片走咐低。
Set root password? [Y/n] <– 是否設(shè)置root用戶密碼,輸入y并回車或直接回車
New password: <– 設(shè)置root用戶的密碼
Re-enter new password: <– 再輸入一次你設(shè)置的密碼
其他配置
Remove anonymous users? [Y/n] <– 是否刪除匿名用戶袜腥,回車
Disallow root login remotely? [Y/n] <–是否禁止root遠(yuǎn)程登錄,回車,
Remove test database and access to it? [Y/n] <– 是否刪除test數(shù)據(jù)庫见擦,回車
Reload privilege tables now? [Y/n] <– 是否重新加載權(quán)限表,回車
登錄
mysql -uroot -p //本地登錄
- 簡單配置mariadb
先配置服務(wù)端羹令,配置文件:/etc/my.cnf.d/server.cnf
vim /etc/my.cnf.d/server.cnf
在[mysqld]標(biāo)簽下添加以下內(nèi)容
init_connect='SET collation_connection = utf8_unicode_ci'
init_connect='SET NAMES utf8'
character-set-server=utf8
collation-server=utf8_unicode_ci
skip-character-set-client-handshake
保存退出
再配置客戶端鲤屡,配置文件:/etc/my.cnf.d/mysql-clients.cnf
vim /etc/my.cnf.d/mysql-clients.cnf
在[mysql]中添加
default-character-set=utf8
保存退出
重啟mariadb服務(wù)
systemctl restart mariadb
之后登錄mariadb,輸入下面代碼福侈,查看一下我們的設(shè)置有沒有成功酒来。
show variables like "%character%";show variables like "%collation%";
- 測試mariadb
現(xiàn)在nginx,php,mariadb都有了,我們來做個簡單的測試肪凛,寫個簡單的代碼堰汉,訪問數(shù)據(jù)庫辽社。
vim /usr/share/nginx/html/index.php
代碼:
<?php
$link=mysqli_connect("localhost","賬號","密碼","數(shù)據(jù)庫");
if(!$link){
echo "Game Over." .PHP_EOL;
echo "Debugging errno:" .mysqli_connect_errno() .PHP_EOL;
echo "Debugging error:" .mysqli_connect_error() .PHP_EOL;
exit;
}
else{
echo "Very Good" .PHP_EOL;
echo "Host information:" .mysqli_get_host_info($link) .PHP_EOL;
}
mysqli_close($link);
?>
我們在瀏覽器訪問看看。
有些朋友寫的不是localhost,而是127.0.0.1,可能會出現(xiàn)Permission denied權(quán)限問題翘鸭,如下圖滴铅。
這是因為selinux攔截了,我們設(shè)置以下就可以就乓。
setsebool httpd_can_network_connect_db = on
用localhost比127.0.0.1在安全及性能上都要好汉匙,感興趣的朋友可以閱讀相關(guān)文檔。
五生蚁、總結(jié)
到這里噩翠,LNMP就搭建成功了,我第一次配置的時候遇到很多權(quán)限問題邦投,其實也是好事绎秒。從問出現(xiàn),到分析問題,再到解決問題,你會收獲很多知識助被,那些問題讓你的腦袋不斷的思考鲸阻,最后,你打通了任督二脈阅懦。