nginx 源码安装

安装nginx

安装pcre库是为了让nginx支持具备URI重写功能的rewrite模块

[root@www ~]# yum install pcre pcre-devel -y
[root@www ~]# rpm -qa  pcre pcre-devel

安装nginx 依赖的包 openssl-devel

[root@www ~]# yum install openssl openssl-devel 
[root@www ~]# rpm -qa openssl openssl-devel

下载nginx源码包

[root@www tools]# wget -q http://nginx.org/download/nginx-1.9.2.tar.gz 

解压

[root@www nginx-1.9.2]# tar xf nginx-1.9.2.tar.gz
[root@www nginx-1.9.2]# cd nginx-1.9.2

配置文件

[root@www nginx-1.9.2]# ./configure --user=nginx --group=nginx --prefix=/application/nginx-1.9.2/ --with-http_stub_status_module --with-http_ssl_module

安装

[root@www nginx-1.9.2]# make
[root@www nginx-1.9.2]# make install

创建软连接

[root@www nginx-1.9.2]# ln -s /application/nginx-1.9.2/ /application/nginx
[root@www nginx-1.9.2]# ls -l /application/nginx
lrwxrwxrwx 1 root root 25 Jan  7 03:16 /application/nginx -> /application/nginx-1.9.2/

检测nginx 配置文件知否正确

[root@www nginx-1.9.2]# /application/nginx/sbin/nginx -t
nginx: the configuration file /application/nginx-1.9.2//conf/nginx.conf syntax is ok
nginx: configuration file /application/nginx-1.9.2//conf/nginx.conf test is successful

启动nginx

[root@www nginx-1.9.2]# /application/nginx/sbin/nginx 

查看nginx服务对应的端口是否成功启动

[root@www nginx-1.9.2]# lsof -i :80
COMMAND  PID  USER   FD   TYPE DEVICE SIZE/OFF NODE NAME
nginx   3620  root    6u  IPv4  27305      0t0  TCP *:http (LISTEN)
nginx   3621 nginx    6u  IPv4  27305      0t0  TCP *:http (LISTEN)

在防火墙上开端口

#查看防火墙上已经开启的端口`
[root@www nginx]# firewall-cmd --zone=public --list-port
#在防火墙上永久开启80端口
[root@www nginx]# firewall-cmd --zone=public --add-port=80/tcp --permanent
#重新载入
[root@www nginx]# firewall-cmd --reload

查看nginx 的目录结构

[root@master /]# tree /application/nginx/
/application/nginx/
├── client_body_temp
├── conf
│   ├── fastcgi.conf
│   ├── fastcgi.conf.default
│   ├── fastcgi_params
│   ├── fastcgi_params.default
│   ├── koi-utf
│   ├── koi-win
│   ├── mime.types
│   ├── mime.types.default
│   ├── nginx.conf
│   ├── nginx.conf.default
│   ├── scgi_params
│   ├── scgi_params.default
│   ├── uwsgi_params
│   ├── uwsgi_params.default
│   └── win-utf
├── fastcgi_temp
├── html
│   ├── 50x.html
│   └── index.html
├── logs
│   ├── access.log
│   ├── error.log
│   └── nginx.pid
├── proxy_temp
├── sbin
│   └── nginx
├── scgi_temp
└── uwsgi_temp

nginx配置虚拟主机

编辑Nginx的配置文件

http {
    include       mime.types;
    default_type  application/octet-stream;

    #log_format  main  '$remote_addr - $remote_user [$time_local] "$request" '
    #                  '$status $body_bytes_sent "$http_referer" '
    #                  '"$http_user_agent" "$http_x_forwarded_for"';

    #access_log  logs/access.log  main;

    sendfile        on;
    #tcp_nopush     on;

    #keepalive_timeout  0;
    keepalive_timeout  65;

    #gzip  on;

    server {
	#nginx 默认监听的端口
        listen       80;
	#配置的虚拟主机的域名(测试环境中是自定义的)
        server_name  www.one.com;

        #charset koi8-r;

        #access_log  logs/host.access.log  main;

        location / {
		#新配置的虚拟主机所在根目录
            root   html/www;
            index  index.html index.htm;
        }

        #error_page  404              /404.html;

        # redirect server error pages to the static page /50x.html
        #
        error_page   500 502 503 504  /50x.html;
        location = /50x.html {
            root   html;
        }

        # proxy the PHP scripts to Apache listening on 127.0.0.1:80
        #
        #location ~ \.php$ {
        #    proxy_pass   http://127.0.0.1;
        #}

        # pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000
        #
        #location ~ \.php$ {
        #    root           html;
        #    fastcgi_pass   127.0.0.1:9000;
        #    fastcgi_index  index.php;
        #    fastcgi_param  SCRIPT_FILENAME  /scripts$fastcgi_script_name;
        #    include        fastcgi_params;
        #}

        # deny access to .htaccess files, if Apache's document root
        # concurs with nginx's one
        #
        #location ~ /\.ht {
        #    deny  all;
        #}

    }
	....
  }


修改完了配置文件,我们知道虚拟主机的关键部分是server{}括号中内容

根据配置的虚拟主机的根目录,创建站点目录和文件,因为Nginx编译安装的时候默认的站定目录是html,所以在改目录下创建

[root@master conf]# mkdir ../html/www -p
[root@master conf]# echo "http://www.one.com" > ../html/www/index.html
[root@master conf]# cat ../html/www/index.html 
http://www.one.com

重新加载配置文件

  • 检查Nginx配置文件语法是否正确
[root@master conf]# ../sbin/nginx -t
nginx: the configuration file /application/nginx-1.9.2//conf/nginx.conf syntax is ok
nginx: configuration file /application/nginx-1.9.2//conf/nginx.conf test is successful
  • 重新加载配置文件
[root@master conf]# ../sbin/nginx -s reload
  • 检查Nginx重启加载后的情况
[root@master conf]# ps -ef|grep nginx
root      10820      1  0 08:54 ?        00:00:00 nginx: master process /application/nginx/sbin/nginx
nginx     11152  10820  0 09:54 ?        00:00:00 nginx: worker process
root      11154  11088  0 09:54 pts/1    00:00:00 grep --color=auto nginx
  • 本机的hosts文件解析(不是必须这样做) 和访问测试
[root@master conf]# echo "192.168.85.129 www.one.com" >>/etc/hosts
[root@master conf]# tail /etc/hosts
127.0.0.1   localhost localhost.localdomain localhost4 localhost4.localdomain4
::1         localhost localhost.localdomain localhost6 localhost6.localdomain6
192.168.85.130 www.one.com
[root@master conf]# curl www.one.com
http://www.one.com			#本地测试成功
posted @ 2018-03-25 22:51  GT—Gaptain  阅读(194)  评论(0编辑  收藏  举报