色婷五一,精品亚洲欧美一区二区三区日产 ,精选国产AV剧情,无码丰满少妇2在线观看

18600329666

咨詢技術(shù)專家

掃一掃
與技術(shù)專家在線溝通

Menu
Linux下php,php-fpm ngnix mysql安裝配置
     NGINX+LINUX+PHP+MYSQL是web應(yīng)用開發(fā)的最佳運(yùn)行環(huán)境之一,收到開發(fā)者青睞,NGINX能夠處理大量靜態(tài)化并發(fā)提高服務(wù)器負(fù)載,本文以源碼安裝的方式講解php,nginx,mysql的安裝以及優(yōu)化配置問題
安裝nginx
編譯環(huán)境gcc g++ 開發(fā)庫之類的需要提前裝好。

安裝make:

yum -y install gcc automake autoconf libtool make

安裝g++:

yum install gcc gcc-c++

 


一般我們都需要先裝pcre, zlib,前者為了重寫rewrite,后者為了gzip壓縮。

1.選定源碼目錄

可以是任何目錄,本文選定的是/usr/local/src

cd /usr/local/src

2.安裝PCRE庫

ftp://ftp.csx.cam.ac.uk/pub/software/programming/pcre/pcre-8.39.tar.gz 下載最新的 PCRE 源碼包,使用下面命令下載編譯和安裝 PCRE 包:

復(fù)制代碼
 
cd /usr/local/src
wget ftp://ftp.csx.cam.ac.uk/pub/software/programming/pcre/pcre-8.39.tar.gz
tar -zxvf pcre-8.39.tar.gz
cd pcre-8.39
./configure
make && make install
 
復(fù)制代碼

3.安裝zlib庫

http://zlib.net/zlib-1.2.11.tar.gz 下載最新的 zlib 源碼包,使用下面命令下載編譯和安裝 zlib包:

復(fù)制代碼
  cd /usr/local/src
  wget http://zlib.net/zlib-1.2.11.tar.gz
  tar -zxvf zlib-1.2.11.tar.gz
  cd zlib-1.2.11
  ./configure
  make && make install
復(fù)制代碼

4.安裝ssl(某些vps默認(rèn)沒裝ssl)

cd /usr/local/src
wget https://www.openssl.org/source/openssl-1.1.0b.tar.gz
tar -zxvf openssl-1.1.0b.tar.gz
./config
make && make install

5.安裝nginx

以安裝最新穩(wěn)定版ngixn-1.10.2為例子,其他版本也一樣。

下面是把 Nginx 安裝到 /usr/local/nginx 目錄下的詳細(xì)步驟

 cd /usr/local/src
 wget http://nginx.org/download/nginx-1.10.2.tar.gz
 tar -zxvf nginx-1.10.2.tar.gz
 cd nginx-1.10.2

1、添加nginx用戶和用戶組

groupadd -r nginx
useradd -r -g nginx nginx

你可能收到提示已經(jīng)有了nginx 用戶和組這個無所謂有了更好。

2、配置nginx安裝參數(shù)

復(fù)制代碼
  ./configure 
  --prefix=/usr/local/nginx 
  --sbin-path=/usr/local/nginx/sbin/nginx 
  --conf-path=/usr/local/nginx/nginx.conf 
  --pid-path=/usr/local/nginx/nginx.pid 
  --user=nginx 
  --group=nginx 
  --with-http_ssl_module 
  --with-http_flv_module 
 --with-http_mp4_module  
 --with-http_stub_status_module 
 --with-http_gzip_static_module 
 --http-client-body-temp-path=/var/tmp/nginx/client/ 
 --http-proxy-temp-path=/var/tmp/nginx/proxy/ 
 --http-fastcgi-temp-path=/var/tmp/nginx/fcgi/ 
 --http-uwsgi-temp-path=/var/tmp/nginx/uwsgi 
 --http-scgi-temp-path=/var/tmp/nginx/scgi 
 --with-pcre=/usr/local/src/pcre-8.39 
 --with-zlib=/usr/local/src/zlib-1.2.11 
 --with-openssl=/usr/local/src/openssl-1.1.0b 
復(fù)制代碼

注:當(dāng)前所在目錄一定要是/usr/local/src/nginx-1.10.2

--with-pcre=/usr/local/src/pcre-8.39 指的是pcre-8.39 的源碼路徑。

--with-zlib=/usr/local/src/zlib-1.2.11 指的是zlib-1.2.11 的源碼路徑。

--with-openssl=/usr/local/src/openssl-1.1.0b 指的是openssl-1.1.0b 的源碼路徑。

編譯安裝

1 make && make install

安裝成功后 /usr/local/nginx 目錄下如下:

3、啟動

確保系統(tǒng)的 80 端口沒被其他程序占用,運(yùn)行/usr/local/nginx/sbin/nginx 命令來啟動 Nginx

 netstat -ano|grep 80
/usr/local/nginx/sbin/nginx

可能會出現(xiàn)mkdir /var/tmp/nginx/client failed的提示

這時手動創(chuàng)建就可以了 mkdir -p /var/tmp/nginx/client就可以了

打開瀏覽器訪問此機(jī)器的 IP,如果瀏覽器出現(xiàn) Welcome to nginx! 則表示 Nginx 已經(jīng)安裝并運(yùn)行成功

ps:

若nginx成功運(yùn)行后,通過ip地址無法訪問服務(wù)器 則可能是防火墻的問題 需要開放80端口或關(guān)閉防火墻

開啟80端口 
firewall-cmd --zone=public --add-port=80/tcp --permanent 
命令含義: 
--zone #作用域 
--add-port=80/tcp #添加端口,格式為:端口/通訊協(xié)議 
--permanent #永久生效,沒有此參數(shù)重啟后失效 
重啟防火墻 
firewall-cmd --reload

或者永久關(guān)閉防火墻

systemctl stop firewalld.service  //停止防火墻
systemctl disable firewalld.service //不再開機(jī)停止運(yùn)行防火墻

 

nginx編譯選項

make是用來編譯的,它從Makefile中讀取指令,然后編譯。

make install是用來安裝的,它也從Makefile中讀取指令,安裝到指定的位置。

configure命令是用來檢測你的安裝平臺的目標(biāo)特征的。它定義了系統(tǒng)的各個方面,包括nginx的被允許使用的連接處理的方法,比如它會檢測你是不是有CC或GCC,并不是需要CC或GCC,它是個shell腳本,執(zhí)行結(jié)束時,它會創(chuàng)建一個Makefile文件。nginx的configure命令支持以下參數(shù):

  • --prefix=path    定義一個目錄,存放服務(wù)器上的文件 ,也就是nginx的安裝目錄。默認(rèn)使用 /usr/local/nginx。
  • --sbin-path=path 設(shè)置nginx的可執(zhí)行文件的路徑,默認(rèn)為  prefix/sbin/nginx.
  • --conf-path=path  設(shè)置在nginx.conf配置文件的路徑。nginx允許使用不同的配置文件啟動,通過命令行中的-c選項。默認(rèn)為prefix/conf/nginx.conf.
  • --pid-path=path  設(shè)置nginx.pid文件,將存儲的主進(jìn)程的進(jìn)程號。安裝完成后,可以隨時改變的文件名 , 在nginx.conf配置文件中使用 PID指令。默認(rèn)情況下,文件名 為prefix/logs/nginx.pid.
  • --error-log-path=path 設(shè)置主錯誤,警告,和診斷文件的名稱。安裝完成后,可以隨時改變的文件名 ,在nginx.conf配置文件中 使用 的error_log指令。默認(rèn)情況下,文件名 為prefix/logs/error.log.
  • --http-log-path=path  設(shè)置主請求的HTTP服務(wù)器的日志文件的名稱。安裝完成后,可以隨時改變的文件名 ,在nginx.conf配置文件中 使用 的access_log指令。默認(rèn)情況下,文件名 為prefix/logs/access.log.
  • --user=name  設(shè)置nginx工作進(jìn)程的用戶。安裝完成后,可以隨時更改的名稱在nginx.conf配置文件中 使用的 user指令。默認(rèn)的用戶名是nobody。
  • --group=name  設(shè)置nginx工作進(jìn)程的用戶組。安裝完成后,可以隨時更改的名稱在nginx.conf配置文件中 使用的 user指令。默認(rèn)的為非特權(quán)用戶。
  • --with-select_module --without-select_module 啟用或禁用構(gòu)建一個模塊來允許服務(wù)器使用select()方法。該模塊將自動建立,如果平臺不支持的kqueue,epoll,rtsig或/dev/poll。
  • --with-poll_module --without-poll_module 啟用或禁用構(gòu)建一個模塊來允許服務(wù)器使用poll()方法。該模塊將自動建立,如果平臺不支持的kqueue,epoll,rtsig或/dev/poll。
  • --without-http_gzip_module — 不編譯壓縮的HTTP服務(wù)器的響應(yīng)模塊。編譯并運(yùn)行此模塊需要zlib庫。
  • --without-http_rewrite_module  不編譯重寫模塊。編譯并運(yùn)行此模塊需要PCRE庫支持。
  • --without-http_proxy_module — 不編譯http_proxy模塊。
  • --with-http_ssl_module — 使用https協(xié)議模塊。默認(rèn)情況下,該模塊沒有被構(gòu)建。建立并運(yùn)行此模塊的OpenSSL庫是必需的。
  • --with-pcre=path — 設(shè)置PCRE庫的源碼路徑。PCRE庫的源碼(版本4.4 - 8.30)需要從PCRE網(wǎng)站下載并解壓。其余的工作是Nginx的./ configure和make來完成。正則表達(dá)式使用在location指令和 ngx_http_rewrite_module 模塊中。
  • --with-pcre-jit —編譯PCRE包含“just-in-time compilation”(1.1.12中, pcre_jit指令)。
  • --with-zlib=path —設(shè)置的zlib庫的源碼路徑。要下載從 zlib(版本1.1.3 - 1.2.5)的并解壓。其余的工作是Nginx的./ configure和make完成。ngx_http_gzip_module模塊需要使用zlib 。
  • --with-cc-opt=parameters — 設(shè)置額外的參數(shù)將被添加到CFLAGS變量。例如,當(dāng)你在FreeBSD上使用PCRE庫時需要使用:--with-cc-opt="-I /usr/local/include。.如需要需要增加 select()支持的文件數(shù)量:--with-cc-opt="-D FD_SETSIZE=2048".
  • --with-ld-opt=parameters —設(shè)置附加的參數(shù),將用于在鏈接期間。例如,當(dāng)在FreeBSD下使用該系統(tǒng)的PCRE庫,應(yīng)指定:--with-ld-opt="-L /usr/local/lib".

php-fpm安裝配置

nginx本身不能處理PHP,它只是個web服務(wù)器,當(dāng)接收到請求后,如果是php請求,則發(fā)給php解釋器處理,并把結(jié)果返回給客戶端。

nginx一般是把請求發(fā)fastcgi管理進(jìn)程處理,fascgi管理進(jìn)程選擇cgi子進(jìn)程處理結(jié)果并返回被nginx

本文以php-fpm為例介紹如何使nginx支持PHP

一、編譯安裝php-fpm

什么是PHP-FPM

PHP-FPM是一個PHP FastCGI管理器,是只用于PHP的,可以在 http://php-fpm.org/download下載得到.

PHP-FPM其實是PHP源代碼的一個補(bǔ)丁,旨在將FastCGI進(jìn)程管理整合進(jìn)PHP包中。必須將它patch到你的PHP源代碼中,在編譯安裝PHP后才可以使用。

新版PHP已經(jīng)集成php-fpm了,不再是第三方的包了,推薦使用。PHP-FPM提供了更好的PHP進(jìn)程管理方式,可以有效控制內(nèi)存和進(jìn)程、可以平滑重載PHP配置,比spawn-fcgi具有更多優(yōu)點,所以被PHP官方收錄了。在./configure的時候帶 –enable-fpm參數(shù)即可開啟PHP-FPM,其它參數(shù)都是配置php的,具體選項含義可以查看這里

安裝前準(zhǔn)備

添加 epel 源

# rpm -Uvh http://dl.fedoraproject.org/pub/epel/6/x86_64/epel-release-6-8.noarch.rpm

安裝依賴

# yum install gcc bison bison-devel zlib-devel libmcrypt-devel mcrypt mhash-devel openssl-devel libxml2-devel libcurl-devel bzip2-devel readline-devel libedit-devel sqlite-devel
1 yum -y install gcc gcc-c++ glibc
yum -y install libmcrypt-devel mhash-devel libxslt-devel 
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
復(fù)制代碼
 cd /usr/local/src
 wget http://php.net/get/php-5.6.30.tar.gz/from/this/mirror
 tar -zvxf php-5.6.30.tar.gz
 cd php-5.6.30
./configure --prefix=/usr/local/php --enable-fpm --with-mcrypt 
--enable-mbstring --enable-pdo --with-curl --disable-debug  --disable-rpath 
--enable-inline-optimization --with-bz2  --with-zlib --enable-sockets 
--enable-sysvsem --enable-sysvshm --enable-pcntl --enable-mbregex 
--with-mhash --enable-zip --with-pcre-regex --with-mysql --with-mysqli 
--with-gd --with-jpeg-dir --with-freetype-dir --enable-calendar
make && make install
復(fù)制代碼

以上就完成了php-fpm的安裝

下面是對php-fpm運(yùn)行用戶進(jìn)行設(shè)置

1、為php提供配置文件

1 cp php.ini-production /usr/local/php/etc/php.ini

2、為php-fpm提供配置文件

 

1 cd /usr/local/php
2 cp etc/php-fpm.conf.default etc/php-fpm.conf
3 vim etc/php-fpm.conf

修改
user = www
group = www

如果www用戶不存在,那么先添加www用戶

1 groupadd www
2 useradd -g www www
修改
pm.max_children = 150
pm.start_servers = 8
pm.min_spare_servers = 5
pm.max_spare_servers = 10
pid = /usr/local/php/var/run/php-fpm.pid 

3、啟動php-fpm

執(zhí)行

1 /usr/local/php/sbin/php-fpm
使用如下命令來驗正(如果此命令輸出有中幾個php-fpm進(jìn)程就說明啟動成功了):
1 ps aux | grep php-fpm

3、nginx和php-fpm整合

編輯/usr/local/nginx/nginx.conf

1 vim /usr/local/nginx/nginx.conf

修改如下:

紅框中“#”號去掉

紅框中“#”號去掉

添加紅框中內(nèi)容

改成如下

重新載入nginx的配置文件:

1 /usr/loca/nginx/sbin/nginx -s reload

4、測試php文件

 在/usr/local/nginx/html下創(chuàng)建index.php文件,輸入如下內(nèi)容

1 <?php
2     phpinfo();
3 ?>

5、瀏覽器訪問

訪問http://你的服務(wù)器ip/index.php,皆可以見到php信息了。


安裝Mysql5.7(解壓縮版)

#### 1、下載安裝包 
wget https://dev.mysql.com/get/Downloads/MySQL-5.7/mysql-5.7.18-linux-glibc2.5-x86_64.tar.gz
推薦下載通用安裝方法的TAR包

 

2.檢查庫文件是否存在,如有刪除。

[root@localhost Desktop]$ rpm -qa | grep mysql
mysql-libs-5.1.52-1.el6_0.1.x86_64
[root@localhost ~]$ rpm -e mysql-libs-5.1.52.x86_64 --nodeps
[root@localhost ~]$

3.檢查mysql組和用戶是否存在,如無創(chuàng)建。

[root@localhost ~]$ cat /etc/group | grep mysql
mysql:x:490:
[root@localhost ~]$ cat /etc/passwd | grep mysql
mysql:x:496:490::/home/mysql:/bin/bash

以上為默認(rèn)存在的情況,如無,執(zhí)行添加命令:

[root@localhost ~]$groupadd mysql
[root@localhost ~]$useradd -r -g mysql mysql
//useradd -r參數(shù)表示mysql用戶是系統(tǒng)用戶,不可用于登錄系統(tǒng)。

4.解壓TAR包,更改所屬的組和用戶

[root@localhost ~]$ cd /usr/local/
[root@localhost local]$ tar xvf mysql-5.7.12-linux-glibc2.5-x86_64.tar
[root@localhost local]$ tar xvfz mysql-5.7.12-linux-glibc2.5-x86_64.tar.gz
[root@localhost local]$ mv mysql-5.7.12-linux-glibc2.5-x86_64 /user/local/mysql
[root@localhost local]$ chown -R mysql mysql/
[root@localhost local]$ chgrp -R mysql mysql/
[root@localhost local]$ cd mysql/

5.安裝和初始化數(shù)據(jù)庫

[root@localhost mysql]$ bin/mysqld --user=mysql
[root@localhost mysql]$ cp -a ./support-files/my-default.cnf /etc/my.cnf
[root@localhost mysql]$ cp -a ./support-files/mysql.server  /etc/init.d/mysqld
[root@localhost mysql]$ cd bin/
[root@localhost bin]# ./mysqld_safe --user=mysql &
[root@localhost bin]# /etc/init.d/mysqld restart
Shutting down MySQL..2016-06-01T22:27:50.498694Z mysqld_safe mysqld from pid file /usr/local/mysql/data/localhost.localdomain.pid ended
 SUCCESS! 
Starting MySQL. SUCCESS! 
[1]+  Done                    ./mysqld_safe --user=mysql
[root@localhost bin]$ 
//設(shè)置開機(jī)啟動
[root@localhost bin]$ chkconfig --level 35 mysqld on
[root@localhost bin]$

6.初始化密碼

mysql5.7會生成一個初始化密碼,而在之前的版本首次登陸不需要登錄。

 [root@localhost bin]$ cat /root/.mysql_secret

 ,xxxxxR5H9

 [root@localhost bin]$./mysql -uroot -p

Enter password: 
mysql > update mysql.user set authentication_string=password('123qwe') where user='root';
Query OK, 0 rows affected, 1 warning (0.00 sec) 
mysql > alter user 'root'@'localhost' identified by '123qwe';
Query OK, 0 rows affected (0.00 sec)
mysql > flush privileges; 
Query OK, 0 rows affected (0.00 sec)

7.添加遠(yuǎn)程訪問權(quán)限

mysql > use mysql; 
Reading table information for completion of table and column names
You can turn off this feature to get a quicker startup with -A


Database changed
mysql> update user set host = '%' where user = 'root';
Query OK, 1 row affected (0.00 sec)
Rows matched: 1  Changed: 1  Warnings: 0


mysql> select host, user from user;
+-----------+-----------+
| host      | user      |
+-----------+-----------+
| %         | root      |
| localhost | mysql.sys |
+-----------+-----------+
//重啟生效
/etc/init.d/mysqld restart