Linux 伺服器即 LNMP 環境搭建(Git倉庫上篇)

奧小晨發表於2018-02-09

前言:上一篇寫到Git倉庫的搭建,有朋友說伺服器還沒搭建好,所以這裡來一篇環境搭建的。

注:我搭建是Centos6版本以上的,Centos7以上有大的改變

一、配置防火牆,開啟80埠、3306埠,刪除原有的iptables ,新增合適的配置

rm -rf /etc/sysconfig/iptablesvim /etc/sysconfig/iptables複製程式碼

新增一下內容:

# Firewall configuration written by system-config-firewall
# Manual customization of this file is not recommended
.*filter
:INPUT ACCEPT [0:0]
:FORWARD ACCEPT [0:0]
:OUTPUT ACCEPT [0:0]
-A INPUT -m state --state ESTABLISHED,RELATED -j ACCEPT
-A INPUT -p icmp -j ACCEPT-A INPUT -i lo -j ACCEPT
-A INPUT -m state --state NEW -m tcp -p tcp --dport 22 -j ACCEPT
-A INPUT -m state --state NEW -m tcp -p tcp --dport 80 -j ACCEPT
-A INPUT -m state --state NEW -m tcp -p tcp --dport 3306 -j ACCEPT
-A INPUT -j REJECT --reject-with icmp-host-prohibited
-A FORWARD -j REJECT --reject-with icmp-host-prohibited
COMMIT複製程式碼

:wq儲存退出,重啟防火牆使配置生效

/etc/init.d/iptables restart     centos 7.0以上執行  systemctl restart firewalld.service複製程式碼

關閉SELINUX

rm -rf  /etc/selinux/configvim /etc/selinux/config複製程式碼

然後新增一行內容:

SELINUX=disabled複製程式碼

:wq 儲存退出

進行重啟系統

shutdown -r now複製程式碼

注意:配置好防火牆必須重啟系統

二、安裝第三方yum源

安裝下載工具

yum install wget複製程式碼

下載

wget http://www.atomicorp.com/installers/atomic複製程式碼

安裝

sh ./atomic複製程式碼

更新yum源

yum check-update複製程式碼

三、安裝Nginx

刪除系統自帶的軟體包

yum remove httpd* php*複製程式碼

安裝nginx

yum install -y nginx複製程式碼

設定nginx開機啟動

chkconfig nginx on   Centos 7.0 以上執行 systemctl enable nginx.service複製程式碼

啟動nginx

service nginx startCentos 7.0 以上 systemctl start  nginx.service複製程式碼

注:nginx啟動可能失敗,需要修改配置檔案報錯如下

Starting nginx:nginx:[emerg] socket() [::]:80 failed (97:Address family not supported by protocol)  [FAILED]複製程式碼

處理方法

vim /etc/nginx/conf.d/default.conf複製程式碼

listen       80 default_server;
listen       [::]:80 default_server;複製程式碼

改為:

listen       80;#listen       [::]:80 default_server;複製程式碼

儲存退出:wq,重啟成功

啟動成功後,開啟瀏覽器,輸入ip地址,可看到nginx歡迎頁

四、安裝PHP

檢查當前安裝的PHP包

yum list installed | grep php複製程式碼

如果有安裝的PHP包,先刪除他們,如:

yum remove php.x86_64 php-cli.x86_64 php-common.x86_64複製程式碼

配置安裝包源:

Centos 5.X 
 rpm -Uvh http://mirror.webtatic.com/yum/el5/latest.rpm
CentOs 6.x  
 rpm -Uvh http://mirror.webtatic.com/yum/el6/latest.rpm
CentOs 7.X  
 rpm -Uvh https://mirror.webtatic.com/yum/el7/epel-release.rpm  
 rpm -Uvh   https://mirror.webtatic.com/yum/el7/webtatic-release.rpm複製程式碼

注:不同版本伺服器需要配置對應的安裝包,如果想刪除上面安裝的包重新安裝

rpm -qa | grep webstaticrpm -e  [上面搜尋到的包即可]複製程式碼

執行安裝

yum -y install php56w.x86_64
yum -y --enablerepo=webtatic install php56w-devel
yum -y install php56w-gd.x86_64 php56w-ldap.x86_64  php56w-mbstring.x86_64 php56w-mcrypt.x86_64 
yum -y install php56w-mysql.x86_64 php56w-pdo.x86_64 php56w-opcache.x86_64複製程式碼

注:每條命令看到Complete!才成功

安裝PHP FPM

yum -y install php56w-fpm複製程式碼

設定php-fpm開機啟動

chkconfig php-fpm onCentos7.0以上   systemctl enable php-fpm.service複製程式碼

啟動php-fpm

/etc/init.d/php-fpm startCentos 7.0 以上 systemctl start  php-fpm.service複製程式碼

注:如果想更換到php5.5或5.4版本,直接把上面的56w換成55w或者54w就可以了

五、 安裝 MySQL

安裝

 yum install -y mysql mysql-server複製程式碼

啟動MySQL

/etc/init.d/mysqld start複製程式碼

設為開機啟動

chkconfig mysqld on複製程式碼

拷貝配置檔案(注意:如果/etc目錄下面預設有一個my.cnf,直接覆蓋即可)

cp /usr/share/mysql/my-medium.cnf /etc/my.cnf複製程式碼

為root使用者設定密碼

mysql_secure_installation複製程式碼

回車,根據提示輸入Y,輸入2次密碼,回車,根據提示一路輸入Y,最後出現:

Thanks for using MySQL!複製程式碼

MySql密碼設定完成,重新啟動 MySQL:

#重啟

/etc/init.d/mysqld restart複製程式碼

停止

/etc/init.d/mysqld stop複製程式碼

啟動

/etc/init.d/mysqld start複製程式碼

六、配置nginx

我存放的nginx路徑地址

[root@iZ2zeftluibm3hesz36v3tZ conf.d]# pwd
/etc/nginx/conf.d
複製程式碼

[root@iZ2zeftluibm3hesz36v3tZ conf.d]# ll
total 20
-rw-r--r-- 1 root root 1501 Feb  9 10:54 admin.shop.conf
-rw-r--r-- 1 root root  434 Dec 25 20:39 default.conf.bak
-rw-r--r-- 1 root root 1419 Feb  8 17:19 web.shop.conf
複製程式碼

因為nginx.conf裡面

include /etc/nginx/conf.d/*.conf;
複製程式碼

   在/etc/nginx/conf.d下面新建一個.conf的檔案 把這個東西複製進去

  {
              listen  80;
              server_name    解析域名;
              index index.php index.html index.htm default.html default.htm default.php;
              client_header_buffer_size 16k;
              large_client_header_buffers 4 32k;
              client_max_body_size 300m;
              client_body_buffer_size 128k;
              location / {
                        root               專案路徑;
                        index              index.php;

                       proxy_connect_timeout 3000;
                        proxy_send_timeout 3000;
                         proxy_read_timeout 3000;
                        proxy_buffer_size 4k;
                        proxy_buffers 4 32k;
                        proxy_busy_buffers_size 64k;

                        if (!-e $request_filename) {
                        rewrite ^/index.php(.*)$ /index.php?s=$1 last;
                        rewrite ^(.*)$ /index.php?s=$1 last;
                        break;
                                                   }
                          }

              location ~ \.php$ {
                        root               專案路徑;
                        fastcgi_pass   127.0.0.1:9000;
                        fastcgi_index  index.php;
                        fastcgi_param  SCRIPT_FILENAME  $document_root$fastcgi_script_name;
                        include        fastcgi_params;
                               }
}
複製程式碼

:wq 儲存退出

七、 配置php-fpm

vim /etc/php-fpm.d/www.conf複製程式碼

將使用者和使用者組設定為nginx,如:

修改使用者為nginx

user = nginx複製程式碼

修改組為nginx

group = nginx複製程式碼

八、開始測試

cd /var/www
vim index.php
複製程式碼
新增以下程式碼

<?php
 phpinfo();
?>
:wq!
複製程式碼
儲存退出

#設定許可權

chown nginx.nginx /var/www -R複製程式碼

#重啟nginx

service nginx restart複製程式碼

#重啟php-fpm

service php-fpm restart複製程式碼

這時你的mysql資料庫不能遠端連線的,此時你應該授權一下

USE mysql;  GRANT ALL PRIVILEGES ON *.* TO 'root'@'%'WITH GRANT OPTION;  FLUSH PRIVILEGES;複製程式碼

注意:GRANT ALL PRIVILEGES表示授權所有許可權,上面*.*中第一個*是授權可以訪問的資料庫名稱, root是使用者名稱, %表示授權所有的IP地址。

到這裡就大致寫完了,網上搭建伺服器環境的很多,我也是綜合各個前人經驗,加入一些自己的理解,希望對有需要的朋友能有一點小小的幫助。這裡推薦我上一篇Git版本庫的搭建哦。

哈哈,知識在於分享,願大家一塊成長。



相關文章