前言:上一篇寫到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版本庫的搭建哦。
哈哈,知識在於分享,願大家一塊成長。