nginx安裝
本文是介紹使用源碼編譯安裝,包括具體的編譯參數信息。
正式開始前,編譯環境gcc g++ 開發庫之類的需要提前裝好。
安裝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 包:
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
3.安裝zlib庫
http://zlib.net/zlib-1.2.11.tar.gz 下載最新的 zlib 源碼包,使用下面命令下載編譯和安裝 zlib包:
4.安裝ssl(某些vps默認沒裝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
https://nginx.org/en/download.html
可以去nginx官網下載選擇的版本,盡量選擇穩定版的版本。
下面是把 Nginx 安裝到 /usr/local/nginx 目錄下的詳細步驟:
cd /usr/local/src wget https://nginx.org/download/nginx-1.16.1.tar.gz tar -zxvf nginx-1.16.1.tar.gz
cd nginx-1.16.1.tar.gz
1、添加nginx用戶和用戶組
groupadd -r nginx useradd -r -g nginx nginx
你可能收到提示已經有了nginx 用戶和組這個無所謂有了更好。
2、配置nginx安裝參數
./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 \
--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、啟動
確保系統的 80 端口沒被其他程序占用,運行/usr/local/nginx/sbin/nginx 命令來啟動 Nginx
netstat -ano|grep 80
/usr/local/nginx/sbin/nginx
可能會出現mkdir /var/tmp/nginx/client failed的提示
這時手動創建就可以了 mkdir -p /var/tmp/nginx/client就可以了
打開瀏覽器訪問此機器的 IP,如果瀏覽器出現 Welcome to nginx! 則表示 Nginx 已經安裝並運行成功
ps:
若nginx成功運行后,通過ip地址無法訪問服務器 則可能是防火牆的問題 需要開放80端口或關閉防火牆
開啟80端口
firewall-cmd --zone=public --add-port=80/tcp --permanent
命令含義:
--zone #作用域
--add-port=80/tcp #添加端口,格式為:端口/通訊協議
--permanent #永久生效,沒有此參數重啟后失效
重啟防火牆
firewall-cmd --reload
或者永久關閉防火牆
nginx編譯選項
make是用來編譯的,它從Makefile中讀取指令,然后編譯。
make install是用來安裝的,它也從Makefile中讀取指令,安裝到指定的位置。
configure命令是用來檢測你的安裝平台的目標特征的。它定義了系統的各個方面,包括nginx的被允許使用的連接處理的方法,比如它會檢測你是不是有CC或GCC,並不是需要CC或GCC,它是個shell腳本,執行結束時,它會創建一個Makefile文件。nginx的configure命令支持以下參數:
--prefix=
定義一個目錄,存放服務器上的文件 ,也就是nginx的安裝目錄。默認使用path
/usr/local/nginx。
--sbin-path=
設置nginx的可執行文件的路徑,默認為path
.prefix
/sbin/nginx--conf-path=
設置在nginx.conf配置文件的路徑。nginx允許使用不同的配置文件啟動,通過命令行中的-c選項。默認為path
.prefix
/conf/nginx.conf--pid-path=
path 設置nginx.pid文件,將存儲的主進程的進程號。安裝完成后,可以隨時改變的文件名 , 在nginx.conf配置文件中使用 PID指令。默認情況下,文件名 為
.prefix
/logs/nginx.pid--error-log-path=
設置主錯誤,警告,和診斷文件的名稱。安裝完成后,可以隨時改變的文件名 ,在nginx.conf配置文件中 使用 的error_log指令。默認情況下,文件名 為path
.prefix
/logs/error.log--http-log-path=
設置主請求的HTTP服務器的日志文件的名稱。安裝完成后,可以隨時改變的文件名 ,在nginx.conf配置文件中 使用 的access_log指令。默認情況下,文件名 為path
.prefix
/logs/access.log--user=
設置nginx工作進程的用戶。安裝完成后,可以隨時更改的名稱在nginx.conf配置文件中 使用的 user指令。默認的用戶名是nobody。name
--group=
設置nginx工作進程的用戶組。安裝完成后,可以隨時更改的名稱在nginx.conf配置文件中 使用的 user指令。默認的為非特權用戶。name
--with-select_module
--without-select_module 啟用或禁用構建一個模塊來允許服務器使用select()方法。該模塊將自動建立,如果平台不支持的kqueue,epoll,rtsig或/dev/poll。
--with-poll_module
--without-poll_module
啟用或禁用構建一個模塊來允許服務器使用poll()方法。該模塊將自動建立,如果平台不支持的kqueue,epoll,rtsig或/dev/poll。--without-http_gzip_module
— 不編譯壓縮的HTTP服務器的響應模塊。編譯並運行此模塊需要zlib庫。--without-http_rewrite_module
不編譯重寫模塊。編譯並運行此模塊需要PCRE庫支持。--without-http_proxy_module
— 不編譯http_proxy模塊。--with-http_ssl_module
— 使用https協議模塊。默認情況下,該模塊沒有被構建。建立並運行此模塊的OpenSSL庫是必需的。--with-pcre=
— 設置PCRE庫的源碼路徑。PCRE庫的源碼(版本4.4 - 8.30)需要從PCRE網站下載並解壓。其余的工作是Nginx的./ configure和make來完成。正則表達式使用在location指令和 ngx_http_rewrite_module 模塊中。path
--with-pcre-jit
—編譯PCRE包含“just-in-time compilation”(1.1.12中, pcre_jit指令)。--with-zlib=
—設置的zlib庫的源碼路徑。要下載從 zlib(版本1.1.3 - 1.2.5)的並解壓。其余的工作是Nginx的./ configure和make完成。ngx_http_gzip_module模塊需要使用zlib 。path
--with-cc-opt=
— 設置額外的參數將被添加到CFLAGS變量。例如,當你在FreeBSD上使用PCRE庫時需要使用:parameters
--with-cc-opt="-I /usr/local/include。
.如需要需要增加select()支持的文件數量
:--with-cc-opt="-D FD_SETSIZE=2048".
--with-ld-opt=
—設置附加的參數,將用於在鏈接期間。例如,當在FreeBSD下使用該系統的PCRE庫,應指定:parameters
--with-ld-opt="-L /usr/local/lib".
php安裝配置
安裝依賴
# 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
下載安裝包
cd /usr/local/src wget https://www.php.net/distributions/php-7.2.22.tar.gz tar -zvxf php-7.2.22.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
以上就完成了php-fpm的安裝
下面是對php-fpm運行用戶進行設置
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
3、啟動php-fpm
執行
1 /usr/local/php/sbin/php-fpm
1 ps aux | grep php-fpm
3、nginx和php-fpm整合
編輯/usr/local/nginx/nginx.conf
1 vim /usr/local/nginx/nginx.conf
修改如下:
紅框中“#”號去掉
紅框中“#”號去掉
添加紅框中內容
改成如下
重新載入nginx的配置文件:
1 /usr/loca/nginx/sbin/nginx -s reload
4、測試php文件
在/usr/local/nginx/html下創建index.php文件,輸入如下內容
1 <?php 2 phpinfo(); 3 ?>
5、瀏覽器訪問
訪問http://你的服務器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組和用戶是否存在,如無創建。
[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
以上為默認存在的情況,如無,執行添加命令:
[root@localhost ~]$groupadd mysql [root@localhost ~]$useradd -r -g mysql mysql //useradd -r參數表示mysql用戶是系統用戶,不可用於登錄系統。
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.安裝和初始化數據庫
[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]$ //設置開機啟動 [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.添加遠程訪問權限
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
【 引用】